/*
Theme Name:  BGlow
Theme URI:   https://naturalbglow.com
Description: Thème sur-mesure pour la marque B-GLOW — soins naturels.
Author:      B-GLOW
Version:     1.0.26
Text Domain: bglow
*/

/* ============================================================
   VARIABLES & RESET
============================================================ */
:root {
    --sage:       #c8e0ac;
    --sage-dark:  #9fc07d;
    --sage-light: #eef7e4;
    --black:      #0d0d0d;
    --dark:       #1a1a1a;
    --mid:        #6a6a6a;
    --soft:       #9a9a9a;
    --cream:      #faf9f7;
    --light:      #f3f3f0;
    --white:      #ffffff;
    --border:     #e4e4e0;
    --serif:      "Cormorant Garamond", Georgia, serif;
    --sans:       "Jost", "Helvetica Neue", Arial, sans-serif;
    --ease:       0.3s ease;
    --max:        1200px;
    --header-h:   100px; /* topbar + main header */

    /* Écraser les variables WooCommerce */
    --wc-global-color-primary:       #c8e0ac;
    --wc-global-color-primary-dark:  #9fc07d;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--sans);
    font-size: 15px;
    line-height: 1.75;
    color: var(--dark);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; height: auto; }
a   { text-decoration: none; color: inherit; transition: color var(--ease); }
ul  { list-style: none; }
button { border: none; background: none; cursor: pointer; font-family: var(--sans); }

.container {
    max-width: var(--max);
    margin: 0 auto;
    padding: 0 40px;
}

/* ============================================================
   BOUTONS
============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 13px 28px;
    font-family: var(--sans);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    border-radius: 40px;
    border: 1.5px solid transparent;
    transition: background var(--ease), border-color var(--ease), color var(--ease), transform 0.2s;
    cursor: pointer;
    white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }

.btn-primary {
    background: var(--sage);
    border-color: var(--sage);
    color: var(--dark);
}
.btn-primary:hover { background: var(--sage-dark); border-color: var(--sage-dark); }

.btn-outline {
    background: transparent;
    border-color: var(--dark);
    color: var(--dark);
}
.btn-outline:hover { background: var(--dark); color: var(--white); }

.btn-light {
    background: var(--white);
    border-color: var(--white);
    color: var(--dark);
}
.btn-light:hover { background: var(--sage-light); border-color: var(--sage-light); }

.btn-ghost {
    background: transparent;
    border-color: rgba(255,255,255,0.6);
    color: var(--white);
}
.btn-ghost:hover { background: rgba(255,255,255,0.15); border-color: rgba(255,255,255,0.9); }

.btn-sm { padding: 9px 20px; font-size: 11px; }
.btn-outline.btn-sm { border-color: var(--border); }

/* ============================================================
   TYPOGRAPHIE COMMUNE
============================================================ */
.section-header { text-align: center; margin-bottom: 60px; }
.section-eyebrow, .brand-eyebrow {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--sage-dark);
    margin-bottom: 14px;
}
.section-title {
    font-family: var(--serif);
    font-size: clamp(28px, 3.5vw, 44px);
    font-weight: 400;
    line-height: 1.15;
    color: var(--dark);
    margin-bottom: 16px;
    letter-spacing: -0.3px;
}
.section-desc {
    font-size: 15px;
    color: var(--mid);
    max-width: 580px;
    margin-inline: auto;
    line-height: 1.8;
}
.section-cta { text-align: center; margin-top: 48px; }

/* ============================================================
   HEADER
============================================================ */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    transition: background var(--ease), box-shadow var(--ease);
}

/* TOP BAR */
.topbar {
    background: rgba(255,255,255,0.06);
    border-bottom: 1px solid rgba(255,255,255,0.12);
    transition: background var(--ease), border-color var(--ease);
}
.topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 38px;
    font-size: 12px;
}
.topbar__link {
    display: flex;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,0.9);
    font-weight: 500;
    letter-spacing: 0.3px;
    transition: color var(--ease);
}
.topbar__link:hover { color: var(--white); }
.topbar__right { display: flex; align-items: center; gap: 20px; }
.topbar__account {
    display: flex;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,0.85);
    font-weight: 500;
}
.topbar__account:hover { color: var(--white); }

/* Scrolled state - topbar */
.site-header.scrolled .topbar {
    background: var(--light);
    border-bottom-color: var(--border);
}
.site-header.scrolled .topbar__link,
.site-header.scrolled .topbar__account { color: var(--dark); }

/* MAIN HEADER */
.header-main {
    background: transparent;
}
.header-main__inner {
    display: flex;
    align-items: center;
    height: 72px;
    gap: 40px;
}

/* Scrolled state - main header */
.site-header.scrolled .header-main {
    background: rgba(255,255,255,0.97);
    box-shadow: 0 1px 20px rgba(0,0,0,0.08);
    backdrop-filter: blur(12px);
}

/* Logo */
.header-logo {
    flex-shrink: 0;
    display: flex;
    align-items: center;
}
.header-logo__text {
    display: block;
    font-family: "GFS Didot", Didot, "Bodoni 72", "Bodoni MT", Georgia, serif;
    font-size: 30px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 10px;
    text-transform: uppercase;
    color: var(--white);
    transition: color 0.35s ease;
    /* Compenser le letter-spacing sur la dernière lettre */
    padding-right: 10px;
}
.site-header.scrolled .header-logo__text {
    color: var(--dark);
}

/* Navigation */
.header-nav { flex: 1; }
.header-nav__list {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 36px;
}
.header-nav__list a {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.9);
    position: relative;
    padding-bottom: 2px;
    transition: color var(--ease);
}
.header-nav__list a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 1px;
    background: currentColor;
    transition: width var(--ease);
}
.header-nav__list a:hover { color: var(--white); }
.header-nav__list a:hover::after { width: 100%; }
.site-header.scrolled .header-nav__list a { color: var(--dark); }
.site-header.scrolled .header-nav__list a:hover { color: var(--sage-dark); }

/* Header actions */
.header-actions {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 20px;
}

/* Langue */
.header-lang {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.lang-btn {
    color: rgba(255,255,255,0.7);
    padding: 2px 4px;
    transition: color var(--ease);
}
.lang-btn:hover, .lang-btn.active { color: var(--white); }
.site-header.scrolled .lang-btn { color: var(--soft); }
.site-header.scrolled .lang-btn:hover,
.site-header.scrolled .lang-btn.active { color: var(--dark); }
.lang-sep { color: rgba(255,255,255,0.3); font-size: 10px; }
.site-header.scrolled .lang-sep { color: var(--border); }
.lang-btn.active {
    color: var(--dark);
    background: var(--sage);
    border-radius: 3px;
}
.site-header:not(.scrolled) .lang-btn.active {
    color: var(--dark);
}
.page-template-page-contact .site-header .lang-btn,
.woocommerce-shop .site-header .lang-btn,
.post-type-archive-product .site-header .lang-btn,
.woocommerce-cart .site-header .lang-btn,
.page-template-page-cart .site-header .lang-btn,
.woocommerce-checkout .site-header .lang-btn,
.page-template-page-checkout .site-header .lang-btn,
.woocommerce-order-received .site-header .lang-btn,
.single-product .site-header .lang-btn {
    color: var(--dark);
}
.page-template-page-contact .site-header .lang-sep,
.woocommerce-shop .site-header .lang-sep,
.post-type-archive-product .site-header .lang-sep,
.woocommerce-cart .site-header .lang-sep,
.page-template-page-cart .site-header .lang-sep,
.woocommerce-checkout .site-header .lang-sep,
.page-template-page-checkout .site-header .lang-sep,
.woocommerce-order-received .site-header .lang-sep,
.single-product .site-header .lang-sep {
    color: rgba(26,26,26,0.28);
}

/* Panier */
.header-cart {
    position: relative;
    display: flex;
    align-items: center;
    color: rgba(255,255,255,0.9);
    transition: color var(--ease);
}
.header-cart:hover { color: var(--white); }
.site-header.scrolled .header-cart { color: var(--dark); }
.cart-badge {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 18px;
    height: 18px;
    background: var(--sage);
    color: var(--dark);
    font-size: 10px;
    font-weight: 700;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.cart-badge.is-empty { display: none; }

/* Mini panier popup */
.bglow-mini-cart {
    position: fixed;
    inset: 0;
    z-index: 3000;
    pointer-events: none;
    visibility: hidden;
}
.bglow-mini-cart.open {
    pointer-events: auto;
    visibility: visible;
}
.bglow-mini-cart__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.46);
    opacity: 0;
    transition: opacity var(--ease);
}
.bglow-mini-cart.open .bglow-mini-cart__overlay {
    opacity: 1;
}
.bglow-mini-cart__panel {
    position: absolute;
    top: 0;
    right: 0;
    width: min(440px, 100%);
    height: 100%;
    display: flex;
    flex-direction: column;
    background: var(--white);
    box-shadow: -22px 0 70px rgba(0,0,0,0.16);
    transform: translateX(100%);
    transition: transform 0.34s ease;
}
.bglow-mini-cart.open .bglow-mini-cart__panel {
    transform: translateX(0);
}
.bglow-mini-cart__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    padding: 34px 34px 24px;
    border-bottom: 1px solid var(--border);
}
.bglow-mini-cart__eyebrow {
    margin-bottom: 8px;
    color: var(--sage-dark);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
}
.bglow-mini-cart__head h2 {
    font-family: var(--serif);
    font-size: 34px;
    font-weight: 400;
    line-height: 1;
}
.bglow-mini-cart__close {
    position: relative;
    width: 34px;
    height: 34px;
    border: 1px solid var(--border);
    flex-shrink: 0;
}
.bglow-mini-cart__close span {
    position: absolute;
    top: 50%;
    left: 8px;
    right: 8px;
    height: 1px;
    background: var(--dark);
}
.bglow-mini-cart__close span:first-child { transform: rotate(45deg); }
.bglow-mini-cart__close span:last-child { transform: rotate(-45deg); }
.bglow-mini-cart__body {
    flex: 1;
    overflow-y: auto;
    padding: 8px 34px;
    position: relative;
}
.bglow-mini-cart__body::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.62);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--ease);
}
.bglow-mini-cart.is-loading .bglow-mini-cart__body::after {
    opacity: 1;
    pointer-events: auto;
}
.bglow-mini-cart__items {
    display: grid;
    gap: 0;
}
.bglow-mini-cart__item {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 22px 0;
    border-bottom: 1px solid var(--border);
}
.bglow-mini-cart__thumb {
    display: block;
    aspect-ratio: 1;
    background: var(--light);
    overflow: hidden;
}
.bglow-mini-cart__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.bglow-mini-cart__info {
    min-width: 0;
}
.bglow-mini-cart__name {
    display: block;
    margin-bottom: 6px;
    font-family: var(--serif);
    font-size: 18px;
    line-height: 1.18;
    color: var(--dark);
}
.bglow-mini-cart__name:hover {
    color: var(--sage-dark);
}
.bglow-mini-cart__meta {
    color: var(--mid);
    font-size: 13px;
}
.bglow-mini-cart__actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin: 10px 0 7px;
}
.bglow-mini-cart__qty-btn,
.bglow-mini-cart__qty-input,
.bglow-mini-cart__remove {
    min-height: 32px;
    border: 1px solid var(--border);
    background: var(--white);
    color: var(--dark);
    font-family: var(--sans);
}
.bglow-mini-cart__qty-btn {
    width: 32px;
    font-size: 18px;
    line-height: 1;
}
.bglow-mini-cart__qty-btn:hover {
    border-color: var(--dark);
}
.bglow-mini-cart__qty-input {
    width: 48px;
    padding: 0 6px;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    -moz-appearance: textfield;
}
.bglow-mini-cart__qty-input::-webkit-outer-spin-button,
.bglow-mini-cart__qty-input::-webkit-inner-spin-button {
    margin: 0;
    -webkit-appearance: none;
}
.bglow-mini-cart__remove {
    padding: 0 10px;
    color: var(--mid);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
}
.bglow-mini-cart__remove:hover {
    border-color: #b5483a;
    color: #b5483a;
}
.bglow-mini-cart.is-loading .bglow-mini-cart__qty-btn,
.bglow-mini-cart.is-loading .bglow-mini-cart__qty-input,
.bglow-mini-cart.is-loading .bglow-mini-cart__remove {
    cursor: wait;
    opacity: 0.55;
}
.bglow-mini-cart__line-total {
    color: var(--dark);
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
}
.bglow-mini-cart__empty {
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--mid);
    text-align: center;
}
.bglow-mini-cart__foot {
    padding: 24px 34px 34px;
    border-top: 1px solid var(--border);
    background: var(--cream);
}
.bglow-mini-cart__subtotal {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
    color: var(--dark);
}
.bglow-mini-cart__subtotal span {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.8px;
    text-transform: uppercase;
}
.bglow-mini-cart__subtotal strong {
    font-size: 18px;
}
.bglow-mini-cart__checkout,
.bglow-mini-cart__continue {
    width: 100%;
    min-height: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.bglow-mini-cart__checkout {
    background: var(--dark);
    color: var(--white);
    border: 1px solid var(--dark);
}
.bglow-mini-cart__checkout:hover {
    background: var(--sage);
    border-color: var(--sage);
    color: var(--dark);
}
.bglow-mini-cart__continue {
    margin-top: 10px;
    background: transparent;
    color: var(--dark);
    border: 1px solid var(--border);
}
.bglow-mini-cart__continue:hover {
    border-color: var(--dark);
}
body.mini-cart-open {
    overflow: hidden;
}

/* Burger mobile */
.header-burger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 28px;
    height: 28px;
    padding: 0;
}
.header-burger span {
    display: block;
    width: 100%;
    height: 1.5px;
    background: var(--white);
    transition: transform var(--ease), opacity var(--ease);
    transform-origin: center;
}
.site-header.scrolled .header-burger span { background: var(--dark); }
.header-burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.header-burger.open span:nth-child(2) { opacity: 0; }
.header-burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* MENU MOBILE */
.mobile-menu {
    display: none;
    flex-direction: column;
    background: var(--white);
    border-top: 1px solid var(--border);
    padding: 0;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, padding 0.3s ease;
}
.mobile-menu.open {
    max-height: 640px;
    padding: 18px 0 24px;
}
.mobile-menu__list { padding: 0 40px; }
.mobile-menu__list li { border-bottom: 1px solid var(--border); }
.mobile-menu__list a {
    display: block;
    padding: 14px 0;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--dark);
}
.mobile-menu__footer {
    padding: 20px 40px 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* ============================================================
   SECTION 1 — HERO SLIDER
============================================================ */
.hero {
    position: relative;
    height: 100vh;
    min-height: 600px;
    overflow: hidden;
}
.hero-slider { height: 100%; }
.hero-slide {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    opacity: 0;
    transition: opacity 0.8s ease;
}
.hero-slide.active { opacity: 1; z-index: 1; }
.hero-slide__inner {
    position: relative;
    z-index: 2;
    padding-top: var(--header-h);
    max-width: 560px;
}
.hero-slide__eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.75);
    margin-bottom: 20px;
    display: block;
}
.hero-slide__title {
    font-family: var(--serif);
    font-size: clamp(42px, 6vw, 76px);
    font-weight: 400;
    line-height: 1.05;
    color: var(--white);
    margin-bottom: 20px;
    letter-spacing: -1px;
    text-shadow: 0 2px 30px rgba(0,0,0,0.15);
}
.hero-slide__title em { font-style: italic; }
.hero-slide__sub {
    font-size: 15px;
    color: rgba(255,255,255,0.8);
    line-height: 1.7;
    margin-bottom: 36px;
}
.hero-slide__cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* Overlay sombre pour lisibilité */
.hero-slide::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.15) 60%, transparent 100%);
    z-index: 1;
}

/* Contrôles */
.hero-prev, .hero-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
    transition: background var(--ease);
    backdrop-filter: blur(4px);
}
.hero-prev { left: 32px; }
.hero-next { right: 32px; }
.hero-prev:hover, .hero-next:hover { background: rgba(255,255,255,0.3); }

.hero-dots {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    gap: 10px;
}
.hero-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,0.4);
    border: none;
    transition: background var(--ease), transform var(--ease);
    padding: 0;
}
.hero-dot.active {
    background: var(--white);
    transform: scale(1.3);
}

/* ============================================================
   SECTION 2 — BE GLOW, BE NATURAL + PRODUITS
============================================================ */
.section-brand {
    padding: 100px 0 80px;
    background: var(--cream);
}
.brand-statement {
    text-align: center;
    max-width: 640px;
    margin: 0 auto 70px;
}
.brand-title {
    font-family: var(--serif);
    font-size: clamp(34px, 4.5vw, 56px);
    font-weight: 400;
    line-height: 1.1;
    color: var(--dark);
    margin-bottom: 0;
    letter-spacing: -0.5px;
}
.brand-title em { font-style: italic; color: var(--sage-dark); }
.brand-sig {
    font-family: var(--serif);
    font-size: 15px;
    font-style: italic;
    color: var(--soft);
    margin: 10px 0 20px;
}
.brand-desc {
    font-size: 16px;
    color: var(--mid);
    line-height: 1.8;
    max-width: 500px;
    margin-inline: auto;
}

/* Produits */
.products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.product-card {
    background: var(--white);
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid var(--border);
    transition: box-shadow 0.3s, transform 0.25s;
}
.product-card:hover {
    box-shadow: 0 16px 48px rgba(0,0,0,0.10);
    transform: translateY(-6px);
}
.product-card__img-wrap {
    display: block;
    position: relative;
    aspect-ratio: 3/4;
    overflow: hidden;
    background: var(--light);
}
.product-card__img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}
.product-card:hover .product-card__img-wrap img { transform: scale(1.06); }
.product-card__badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--sage);
    color: var(--dark);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 20px;
}
.product-card__body {
    padding: 22px 24px 26px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.product-card__name {
    font-family: var(--serif);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.2;
    color: var(--dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.product-card__name a:hover { color: var(--sage-dark); }
.product-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 4px;
}
.product-card__price {
    font-size: 16px;
    font-weight: 600;
    color: var(--dark);
    text-align: right;
    white-space: nowrap;
}
.product-card__price .woocommerce-Price-amount { font-family: var(--sans); }
.product-card__price del { color: var(--soft); font-size: 13px; font-weight: 400; }
.product-card__price ins { text-decoration: none; }

/* ============================================================
   SECTION 3 — POURQUOI B-GLOW
============================================================ */
.section-why {
    padding: 100px 0;
    background: var(--white);
}
.why-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}
.why-card {
    padding: 48px 44px;
    border-right: 1px solid var(--border);
    transition: background var(--ease);
}
.why-card:last-child { border-right: none; }
.why-card:hover { background: var(--cream); }
.why-card__num {
    font-family: var(--serif);
    font-size: 52px;
    font-weight: 300;
    color: var(--sage);
    line-height: 1;
    display: block;
    margin-bottom: 16px;
    letter-spacing: -2px;
}
.why-card__line {
    width: 32px;
    height: 1px;
    background: var(--sage-dark);
    margin-bottom: 22px;
}
.why-card__title {
    font-family: var(--serif);
    font-size: 22px;
    font-weight: 400;
    line-height: 1.3;
    color: var(--dark);
    margin-bottom: 14px;
}
.why-card__text {
    font-size: 14px;
    color: var(--mid);
    line-height: 1.8;
}

/* Bordure haut sur la section */
.section-why { border-top: 1px solid var(--border); }
.why-grid { border: 1px solid var(--border); border-radius: 4px; overflow: hidden; }

/* ============================================================
   SECTION 4 — AVANT / APRÈS SWIPE (2 blocs)
============================================================ */
.section-results {
    padding: 100px 0;
    background: var(--cream);
}
.ba-duo {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    margin-bottom: 20px;
}
.ba-block { display: flex; flex-direction: column; gap: 14px; }
.ba-caption {
    text-align: center;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 1px;
    color: var(--mid);
    text-transform: uppercase;
}
.ba-compare {
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    user-select: none;
    cursor: col-resize;
    box-shadow: 0 16px 48px rgba(0,0,0,0.12);
    aspect-ratio: 3/4;
}
.ba-before, .ba-after {
    position: absolute;
    inset: 0;
}
.ba-before img, .ba-after img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
    pointer-events: none;
    display: block;
}
.ba-after { clip-path: inset(0 50% 0 0); }
.ba-tag {
    position: absolute;
    bottom: 16px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 20px;
    white-space: nowrap;
    z-index: 2;
}
.ba-before .ba-tag {
    left: 14px;
    background: rgba(255,255,255,0.88);
    color: var(--mid);
}
.ba-after .ba-tag {
    right: 14px;
    background: var(--sage);
    color: var(--dark);
}
.ba-handle {
    position: absolute;
    top: 0;
    left: 50%;
    bottom: 0;
    width: 44px;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 10;
    cursor: col-resize;
}
.ba-handle__line {
    position: absolute;
    inset: 0 50%;
    transform: translateX(-50%);
    width: 2px;
    background: var(--white);
    box-shadow: 0 0 8px rgba(0,0,0,0.25);
}
.ba-handle__btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--white);
    box-shadow: 0 4px 16px rgba(0,0,0,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.ba-handle__btn svg { width: 13px; height: 13px; color: var(--dark); }
.ba-note {
    text-align: center;
    font-size: 11px;
    color: var(--soft);
    font-style: italic;
}

/* ============================================================
   SECTION 6 — INSTAGRAM
============================================================ */
.section-instagram {
    padding: 90px 0 0;
    background: var(--white);
}
.instagram-feed-wrap {
    margin-top: 40px;
    overflow: hidden;
}

/* Topbar — devise */
.topbar__currency {
    display: flex;
    align-items: center;
    gap: 6px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}
.currency-btn {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    color: var(--dark);
    padding: 2px 6px;
    border-radius: 3px;
    transition: color var(--ease), background var(--ease);
}
.currency-btn:hover { color: var(--sage-dark); }
.currency-btn.active {
    color: var(--dark);
    background: var(--sage);
    border-radius: 3px;
}
.topbar__sep { color: rgba(26,26,26,0.25); font-size: 10px; }
.topbar__inner { position: relative; }
.site-header.scrolled .topbar__currency .currency-btn,
.site-header.scrolled .topbar__sep {
    color: var(--dark);
}

.woocommerce-Price-amount.amount {
    display: inline-block;
}
.bglow-price-secondary {
    display: block;
    margin-top: 2px;
    color: var(--sage-dark);
    font-size: 0.78em;
    font-weight: 700;
    line-height: 1.1;
    white-space: nowrap;
}
.co-order-line__price .bglow-price-secondary,
.co-order-table tfoot td .bglow-price-secondary,
.bglow-mini-cart__line-total .bglow-price-secondary {
    text-align: right;
}
.bglow-mini-cart__meta .bglow-price-secondary {
    display: inline-block;
    margin: 0 0 0 5px;
}

/* ============================================================
   SECTION 5 — ROUTINE EN 3 ÉTAPES (icônes)
============================================================ */
.section-routine {
    padding: 100px 0;
    background: var(--white);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.routine-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
}
.routine-step {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 52px 48px 56px;
    border-right: 1px solid var(--border);
    transition: background var(--ease);
    position: relative;
}
.routine-step:last-child { border-right: none; }
.routine-step:hover { background: var(--cream); }

/* Icône */
.routine-step__icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--sage-light);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 32px;
    flex-shrink: 0;
    transition: background var(--ease), transform var(--ease);
}
.routine-step:hover .routine-step__icon {
    background: var(--sage);
    transform: scale(1.08);
}
.routine-step__icon svg {
    width: 26px;
    height: 26px;
    color: var(--sage-dark);
    transition: color var(--ease);
}
.routine-step:hover .routine-step__icon svg { color: var(--dark); }

.routine-step__body {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.routine-step__num {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--sage-dark);
    margin-bottom: 10px;
    display: block;
}
.routine-step__action {
    font-family: var(--serif);
    font-size: 36px;
    font-weight: 400;
    font-style: italic;
    line-height: 1;
    color: var(--dark);
    margin-bottom: 18px;
    letter-spacing: -0.3px;
}
.routine-step__desc {
    font-size: 14px;
    color: var(--mid);
    line-height: 1.8;
    margin-bottom: 28px;
}
.routine-step__product {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dark);
    border-bottom: 1px solid var(--sage);
    padding-bottom: 3px;
}

/* ============================================================
   SECTION 6 — AVIS CLIENTES
============================================================ */
.section-reviews {
    padding: 100px 0;
    background: var(--light);
}
.reviews-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.review-card {
    background: var(--white);
    border-radius: 4px;
    padding: 36px 32px 40px;
    border: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 14px;
    transition: box-shadow 0.25s, transform 0.2s;
}
.review-card:hover {
    box-shadow: 0 12px 40px rgba(0,0,0,0.08);
    transform: translateY(-4px);
}
.review-card--featured {
    border-color: var(--sage);
    box-shadow: 0 8px 32px rgba(168,196,140,0.2);
}
.review-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--sage-light);
    color: var(--sage-dark);
    font-family: var(--serif);
    font-size: 22px;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.review-stars {
    color: var(--sage-dark);
    font-size: 15px;
    letter-spacing: 2px;
}
.review-text {
    font-family: var(--serif);
    font-size: 17px;
    font-style: italic;
    font-weight: 300;
    line-height: 1.7;
    color: var(--dark);
    flex: 1;
}
.review-author {
    font-size: 13px;
    font-weight: 600;
    color: var(--dark);
    letter-spacing: 0.5px;
}
.review-role {
    font-size: 11px;
    color: var(--soft);
    letter-spacing: 1px;
    text-transform: uppercase;
    font-weight: 500;
}

/* ============================================================
   PAGE HISTOIRE
============================================================ */
.history-page {
    background: var(--white);
    color: var(--dark);
}
.history-hero {
    position: relative;
    min-height: 52vh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    color: var(--white);
}
.history-hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.history-hero__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.7);
}
.history-hero__content {
    position: relative;
    z-index: 1;
    padding-top: 140px;
    padding-bottom: 64px;
}
.history-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.78);
    margin-bottom: 18px;
}
.history-hero h1 {
    max-width: 760px;
    font-family: var(--serif);
    font-size: clamp(38px, 5.8vw, 74px);
    font-weight: 400;
    line-height: 0.96;
    margin-bottom: 24px;
}
.history-hero h1 em {
    font-style: italic;
    font-weight: 300;
}
.history-hero p:last-child {
    max-width: 560px;
    font-size: clamp(17px, 2vw, 22px);
    color: rgba(255,255,255,0.86);
}
.history-story {
    padding: 110px 0;
    background: var(--cream);
}
.history-story__grid {
    display: grid;
    grid-template-columns: minmax(260px, 0.78fr) minmax(0, 1.22fr);
    gap: 80px;
    align-items: start;
}
.history-story__intro {
    position: sticky;
    top: 140px;
}
.history-story__intro h2 {
    font-family: var(--serif);
    font-size: clamp(34px, 4vw, 54px);
    font-weight: 400;
    line-height: 1.08;
}
.history-story__intro h2 em {
    font-style: italic;
    font-weight: 300;
}
.history-story__content {
    font-family: var(--serif);
    font-size: clamp(21px, 2.1vw, 30px);
    line-height: 1.48;
    color: var(--dark);
}
.history-story__content p + p {
    margin-top: 30px;
}
.history-universe {
    padding: 105px 0 115px;
    background: var(--white);
}
.history-values {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid var(--border);
    border-left: 1px solid var(--border);
}
.history-value {
    min-height: 310px;
    padding: 38px 34px;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    background: var(--white);
    transition: background var(--ease);
}
.history-value:hover {
    background: var(--cream);
}
.history-value span {
    display: block;
    margin-bottom: 28px;
    font-family: var(--serif);
    font-size: 38px;
    line-height: 1;
    color: var(--sage-dark);
}
.history-value h3 {
    margin-bottom: 14px;
    font-family: var(--serif);
    font-size: 28px;
    font-weight: 400;
    line-height: 1.12;
}
.history-value p {
    color: var(--mid);
    font-size: 14px;
    line-height: 1.78;
}

/* ============================================================
   PAGE CONTACT
============================================================ */

/* Header always opaque on contact page */
.page-template-page-contact .site-header .topbar {
    background: var(--light);
    border-bottom-color: var(--border);
}
.page-template-page-contact .site-header .topbar__link,
.page-template-page-contact .site-header .topbar__account,
.page-template-page-contact .site-header .topbar__currency .currency-btn,
.page-template-page-contact .site-header .topbar__sep,
.page-template-page-contact .site-header .header-nav__list a,
.page-template-page-contact .site-header .header-lang,
.page-template-page-contact .site-header .header-cart,
.page-template-page-contact .site-header .header-logo__text {
    color: var(--dark);
}
.page-template-page-contact .site-header .header-main {
    background: rgba(255,255,255,0.97);
    box-shadow: 0 1px 20px rgba(0,0,0,0.08);
    backdrop-filter: blur(12px);
}
.page-template-page-contact .site-header .header-burger span {
    background: var(--dark);
}

/* HERO */
.contact-hero {
    padding: 170px 0 80px;
    background: linear-gradient(170deg, var(--cream) 0%, var(--white) 65%);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.contact-hero::before {
    content: '';
    position: absolute;
    top: -120px;
    right: -160px;
    width: 520px;
    height: 520px;
    border-radius: 50%;
    background: var(--sage);
    opacity: 0.13;
    pointer-events: none;
}
.contact-hero::after {
    content: '';
    position: absolute;
    bottom: -80px;
    left: -100px;
    width: 340px;
    height: 340px;
    border-radius: 50%;
    background: var(--sage-dark);
    opacity: 0.08;
    pointer-events: none;
}
.contact-hero .section-eyebrow { margin-bottom: 18px; }
.contact-hero__title {
    font-family: var(--serif);
    font-size: clamp(42px, 6vw, 78px);
    font-weight: 400;
    line-height: 1.02;
    letter-spacing: -0.01em;
    color: var(--dark);
    margin-bottom: 22px;
}
.contact-hero__sub {
    font-size: 16px;
    color: var(--mid);
}

/* BODY */
.contact-body {
    padding: 80px 0 120px;
    background: var(--white);
}
.contact-grid {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 72px;
    align-items: start;
}

/* LEFT — Info */
.contact-info { position: sticky; top: 120px; }
.contact-info__item {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    padding: 22px 0;
    border-bottom: 1px solid var(--border);
}
.contact-info__item:first-child { padding-top: 0; }
.contact-info__icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sage);
    border-radius: 50%;
    color: var(--dark);
}
.contact-info__label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--mid);
    margin-bottom: 5px;
}
.contact-info__value {
    font-size: 15px;
    color: var(--dark);
    line-height: 1.6;
    text-decoration: none;
    transition: color var(--ease);
}
a.contact-info__value:hover { color: var(--sage-dark); }
.contact-whatsapp-btn {
    width: fit-content;
    margin-top: 12px;
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 18px;
    background: #25d366;
    color: var(--dark);
    border: 1px solid #25d366;
    border-radius: 2px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.4px;
    line-height: 1.2;
    text-transform: uppercase;
    transition: background var(--ease), border-color var(--ease), transform 0.2s;
}
.contact-whatsapp-btn:hover {
    background: #1fb85a;
    border-color: #1fb85a;
    transform: translateY(-1px);
}
.contact-info__divider {
    margin: 28px 0;
    border: none;
    border-top: 1px solid var(--border);
}
.contact-faq {
    padding: 26px;
    background: var(--cream);
    border: 1px solid var(--border);
}
.contact-faq__text {
    font-size: 14px;
    color: var(--mid);
    line-height: 1.75;
    margin-bottom: 16px;
}
.contact-faq__link {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dark);
    text-decoration: none;
    transition: color var(--ease);
}
.contact-faq__link:hover { color: var(--sage-dark); }

/* RIGHT — Form */
.contact-form-wrap__head { margin-bottom: 28px; }
.contact-form-wrap__title {
    font-family: var(--serif);
    font-size: clamp(30px, 4vw, 46px);
    font-weight: 400;
    line-height: 1.1;
    color: var(--dark);
    margin-top: 10px;
}
.contact-form-inner {
    background: var(--cream);
    border: 1px solid var(--border);
    padding: 40px 44px;
}
.contact-form-inner .wpcf7 { margin: 0; }
.contact-form-inner .wpcf7-form {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.contact-form-inner .wpcf7-form > p { position: relative; margin: 0; }
.contact-form-inner .wpcf7-form > p:nth-child(3),
.contact-form-inner .wpcf7-form > p:nth-child(4),
.contact-form-inner .wpcf7-form > p:nth-child(5) { grid-column: 1 / -1; }
.contact-form-inner .wpcf7-form br { display: none; }
.contact-form-inner .wpcf7-form-control-wrap { display: block; }
.contact-form-inner label {
    display: grid;
    gap: 9px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dark);
}
.contact-form-inner input[type="text"],
.contact-form-inner input[type="email"],
.contact-form-inner textarea {
    width: 100%;
    min-height: 54px;
    padding: 14px 16px;
    border: 1px solid rgba(26,26,26,0.14);
    border-radius: 0;
    background: var(--white);
    color: var(--dark);
    font-family: var(--sans);
    font-size: 15px;
    outline: none;
    transition: border-color var(--ease), box-shadow var(--ease);
}
.contact-form-inner textarea {
    min-height: 160px;
    resize: vertical;
}
.contact-form-inner input:focus,
.contact-form-inner textarea:focus {
    border-color: var(--sage-dark);
    box-shadow: 0 0 0 3px rgba(138,158,126,0.15);
}
.contact-form-inner input[type="submit"] {
    justify-self: start;
    min-height: 52px;
    padding: 0 40px;
    border: 1px solid var(--dark);
    border-radius: 0;
    background: var(--dark);
    color: var(--white);
    font-family: var(--sans);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background var(--ease), border-color var(--ease), color var(--ease), transform 0.2s;
}
.contact-form-inner input[type="submit"]:hover {
    transform: translateY(-2px);
    background: var(--sage-dark);
    border-color: var(--sage-dark);
    color: var(--white);
}
.contact-form-inner .wpcf7-spinner { margin-left: 12px; }
.contact-form-inner .wpcf7-not-valid-tip {
    margin-top: 6px;
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    color: #b5483a;
}
.contact-form-inner .wpcf7-response-output {
    grid-column: 1 / -1;
    margin: 0;
    padding: 14px 16px;
    border-color: var(--border);
    background: var(--white);
    font-size: 13px;
    color: var(--mid);
}

/* ============================================================
   PAGE SHOP
============================================================ */
.woocommerce-shop .site-header .topbar,
.post-type-archive-product .site-header .topbar {
    background: var(--light);
    border-bottom-color: var(--border);
}
.woocommerce-shop .site-header .topbar__link,
.woocommerce-shop .site-header .topbar__account,
.woocommerce-shop .site-header .topbar__currency .currency-btn,
.woocommerce-shop .site-header .topbar__sep,
.woocommerce-shop .site-header .header-nav__list a,
.woocommerce-shop .site-header .header-lang,
.woocommerce-shop .site-header .header-cart,
.woocommerce-shop .site-header .header-logo__text,
.post-type-archive-product .site-header .topbar__link,
.post-type-archive-product .site-header .topbar__account,
.post-type-archive-product .site-header .topbar__currency .currency-btn,
.post-type-archive-product .site-header .topbar__sep,
.post-type-archive-product .site-header .header-nav__list a,
.post-type-archive-product .site-header .header-lang,
.post-type-archive-product .site-header .header-cart,
.post-type-archive-product .site-header .header-logo__text {
    color: var(--dark);
}
.woocommerce-shop .site-header .header-main,
.post-type-archive-product .site-header .header-main {
    background: rgba(255,255,255,0.97);
    box-shadow: 0 1px 20px rgba(0,0,0,0.08);
    backdrop-filter: blur(12px);
}
.woocommerce-shop .site-header .header-burger span,
.post-type-archive-product .site-header .header-burger span {
    background: var(--dark);
}
.shop-page { background: var(--white); }

/* ── HERO ── */
.shop-hero {
    padding: 148px 0 80px;
    background: linear-gradient(150deg, var(--cream) 0%, #f0f5e8 60%, var(--white) 100%);
    border-bottom: 1px solid var(--border);
    overflow: hidden;
    position: relative;
}
.shop-hero::after {
    content: '';
    position: absolute;
    top: -200px;
    right: -200px;
    width: 700px;
    height: 700px;
    border-radius: 50%;
    background: var(--sage);
    opacity: 0.12;
    pointer-events: none;
}
.shop-hero__inner {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 60px;
    align-items: center;
}
.shop-hero__title {
    font-family: var(--serif);
    font-size: clamp(34px, 4.5vw, 62px);
    font-weight: 400;
    line-height: 1.05;
    color: var(--dark);
    margin-bottom: 20px;
    letter-spacing: -0.02em;
}
.shop-hero__title em { font-style: italic; color: var(--sage-dark); }
.shop-hero__desc {
    max-width: 480px;
    color: var(--mid);
    font-size: 15px;
    line-height: 1.8;
    margin-bottom: 36px;
}
.shop-hero__stats { display: flex; gap: 40px; }
.shop-hero__stat strong {
    display: block;
    font-family: var(--serif);
    font-size: 28px;
    font-weight: 400;
    line-height: 1;
    color: var(--dark);
    margin-bottom: 4px;
}
.shop-hero__stat span {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--mid);
}
.shop-hero__badge-wrap {
    display: flex;
    flex-direction: column;
    gap: 14px;
    position: relative;
    z-index: 1;
}
.shop-hero__badge {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 4px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.05);
    font-size: 13px;
    font-weight: 500;
    color: var(--dark);
}
.shop-hero__badge svg { flex-shrink: 0; color: var(--sage-dark); }

/* ── BARRE ── */
.shop-bar { border-bottom: 1px solid var(--border); background: var(--white); }
.shop-bar .container {
    display: flex;
    align-items: center;
    gap: 20px;
    height: 54px;
}
.shop-bar__count {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--mid);
    white-space: nowrap;
}
.shop-bar__line { flex: 1; height: 1px; background: var(--border); }

/* ── GRILLE PRODUITS ── */
.shop-products { padding: 72px 0 110px; }
.shop-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

/* ── CARTE PRODUIT ── */
.shop-card {
    display: flex;
    flex-direction: column;
    background: var(--white);
    border: 1px solid var(--border);
    transition: box-shadow 0.3s, transform 0.3s;
}
.shop-card:hover {
    box-shadow: 0 20px 60px rgba(0,0,0,0.10);
    transform: translateY(-6px);
}
.shop-card__visual {
    display: block;
    position: relative;
    aspect-ratio: 3/4;
    overflow: hidden;
    background: var(--light);
}
.shop-card__visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(.25,.46,.45,.94);
}
.shop-card:hover .shop-card__visual img { transform: scale(1.07); }
.shop-card__overlay {
    position: absolute;
    inset: 0;
    background: rgba(26,26,26,0.38);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 28px;
    opacity: 0;
    transition: opacity 0.35s ease;
}
.shop-card:hover .shop-card__overlay { opacity: 1; }
.shop-card__overlay-cta {
    display: inline-block;
    padding: 12px 28px;
    border: 1.5px solid rgba(255,255,255,0.9);
    color: var(--white);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    transform: translateY(10px);
    transition: transform 0.35s ease, background 0.25s ease;
}
.shop-card:hover .shop-card__overlay-cta {
    transform: translateY(0);
    background: rgba(255,255,255,0.15);
}
.shop-card__tag {
    position: absolute;
    top: 14px;
    left: 14px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 20px;
    z-index: 1;
}
.shop-card__tag--promo { background: #e8c4a0; color: #5c3d1e; }
.shop-card__tag--new   { background: var(--sage); color: var(--dark); }
.shop-card__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 22px 24px 28px;
    gap: 8px;
}
.shop-card__cat {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--sage-dark);
}
.shop-card__name {
    font-family: var(--serif);
    font-size: 22px;
    font-weight: 400;
    line-height: 1.2;
    color: var(--dark);
}
.shop-card__name a { transition: color var(--ease); }
.shop-card__name a:hover { color: var(--sage-dark); }
.shop-card__desc {
    font-size: 13px;
    color: var(--mid);
    line-height: 1.7;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.shop-card__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: 10px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}
.shop-card__price { font-size: 17px; font-weight: 600; color: var(--dark); }
.shop-card__price del { color: var(--soft); font-size: 13px; font-weight: 400; }
.shop-card__price ins { text-decoration: none; }
.shop-card__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--dark);
    text-decoration: none;
    padding-bottom: 2px;
    border-bottom: 1px solid var(--dark);
    transition: color var(--ease), border-color var(--ease);
}
.shop-card__btn:hover { color: var(--sage-dark); border-color: var(--sage-dark); }
.shop-empty {
    text-align: center;
    color: var(--mid);
    padding: 60px 0;
}

/* ── MANIFESTE ── */
.shop-manifesto { background: var(--sage); padding: 72px 0; }
.shop-manifesto__inner {
    display: grid;
    grid-template-columns: 60px 1fr auto;
    align-items: center;
    gap: 40px;
}
.shop-manifesto__deco { color: var(--dark); opacity: 0.35; }
.shop-manifesto__quote p {
    font-family: var(--serif);
    font-size: clamp(18px, 2.2vw, 26px);
    font-weight: 400;
    font-style: italic;
    line-height: 1.5;
    color: var(--dark);
}
.shop-manifesto__quote cite {
    display: block;
    margin-top: 12px;
    font-style: normal;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(26,26,26,0.5);
}
.shop-manifesto__promises {
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex-shrink: 0;
}
.shop-manifesto__promise {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    font-weight: 500;
    color: var(--dark);
    white-space: nowrap;
}
.shop-manifesto__promise svg { flex-shrink: 0; color: rgba(26,26,26,0.6); }

/* ============================================================
   PAGE PANIER
============================================================ */
.woocommerce-cart .site-header .topbar,
.page-template-page-cart .site-header .topbar {
    background: var(--light);
    border-bottom-color: var(--border);
}
.woocommerce-cart .site-header .topbar__link,
.woocommerce-cart .site-header .topbar__account,
.woocommerce-cart .site-header .topbar__currency .currency-btn,
.woocommerce-cart .site-header .topbar__sep,
.woocommerce-cart .site-header .header-nav__list a,
.woocommerce-cart .site-header .header-lang,
.woocommerce-cart .site-header .header-cart,
.woocommerce-cart .site-header .header-logo__text,
.page-template-page-cart .site-header .topbar__link,
.page-template-page-cart .site-header .topbar__account,
.page-template-page-cart .site-header .topbar__currency .currency-btn,
.page-template-page-cart .site-header .topbar__sep,
.page-template-page-cart .site-header .header-nav__list a,
.page-template-page-cart .site-header .header-lang,
.page-template-page-cart .site-header .header-cart,
.page-template-page-cart .site-header .header-logo__text {
    color: var(--dark);
}
.woocommerce-cart .site-header .header-main,
.page-template-page-cart .site-header .header-main {
    background: rgba(255,255,255,0.97);
    box-shadow: 0 1px 20px rgba(0,0,0,0.08);
    backdrop-filter: blur(12px);
}
.woocommerce-cart .site-header .header-burger span,
.page-template-page-cart .site-header .header-burger span {
    background: var(--dark);
}
.cart-page {
    background: var(--cream);
    color: var(--dark);
}
.cart-hero {
    padding: 132px 0 42px;
    background: var(--white);
    border-bottom: 1px solid var(--border);
}
.cart-hero h1 {
    max-width: 680px;
    margin: 10px 0 14px;
    font-family: var(--serif);
    font-size: clamp(34px, 4vw, 54px);
    font-weight: 400;
    line-height: 1.05;
    color: var(--dark);
}
.cart-hero p:last-child {
    max-width: 560px;
    color: var(--mid);
    font-size: 15px;
    line-height: 1.8;
}
.cart-section {
    padding: 54px 0 96px;
}
.cart-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 28px;
    align-items: start;
}
.cart-shell__main,
.cart-assurance {
    background: var(--white);
    border: 1px solid var(--border);
}
.cart-shell__main {
    min-width: 0;
    padding: 34px;
}
.cart-assurance {
    position: sticky;
    top: 118px;
    padding: 30px 28px;
}
.cart-assurance__eyebrow {
    margin-bottom: 12px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--sage-dark);
}
.cart-assurance h2 {
    margin: 0 0 26px;
    font-family: var(--serif);
    font-size: 28px;
    font-weight: 400;
    line-height: 1.18;
    color: var(--dark);
}
.cart-assurance__list {
    display: grid;
    gap: 20px;
    list-style: none;
}
.cart-assurance__list li {
    display: grid;
    grid-template-columns: 32px 1fr;
    gap: 14px;
    padding-top: 20px;
    border-top: 1px solid var(--border);
}
.cart-assurance__list span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--sage);
    border-radius: 50%;
    font-size: 10px;
    font-weight: 600;
    color: var(--dark);
}
.cart-assurance__list strong {
    display: block;
    margin-bottom: 5px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.4px;
    color: var(--dark);
}
.cart-assurance__list p {
    color: var(--mid);
    font-size: 13px;
    line-height: 1.65;
}
.cart-shell__main .woocommerce {
    display: grid;
    gap: 28px;
}
.cart-shell__main .woocommerce-notices-wrapper {
    margin: 0;
}
.cart-shell__main .woocommerce-message,
.cart-shell__main .woocommerce-info,
.cart-shell__main .woocommerce-error {
    border-top-color: var(--sage-dark);
    background: var(--light);
    color: var(--dark);
    font-size: 14px;
}
.cart-shell__main table.shop_table {
    border: 0;
    border-radius: 0;
    margin: 0;
}
.cart-shell__main table.shop_table th,
.cart-shell__main table.shop_table td {
    border-top: 1px solid rgba(26,26,26,0.1);
    padding: 18px 12px;
    color: var(--dark);
    font-size: 14px;
}
.cart-shell__main table.shop_table thead th {
    border-top: 0;
    padding-top: 0;
    color: var(--mid);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.8px;
    text-transform: uppercase;
}
.cart-shell__main .product-thumbnail img {
    width: 76px;
    height: 96px;
    object-fit: cover;
    background: var(--light);
}
.cart-shell__main .product-name a {
    font-family: var(--serif);
    font-size: 19px;
    line-height: 1.2;
    color: var(--dark);
}
.cart-shell__main .product-name a:hover {
    color: var(--sage-dark);
}
.cart-shell__main .product-remove a.remove {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    color: var(--mid) !important;
    font-size: 20px;
    line-height: 1;
}
.cart-shell__main .product-remove a.remove:hover {
    background: #b5483a;
    border-color: #b5483a;
    color: var(--white) !important;
}
.cart-shell__main .quantity .qty {
    width: 74px;
    min-height: 42px;
    border: 1px solid var(--border);
    border-radius: 0;
    color: var(--dark);
    font-family: var(--sans);
    font-size: 14px;
    text-align: center;
}
.cart-shell__main .coupon {
    display: flex;
    gap: 10px;
}
.cart-shell__main .coupon .input-text {
    width: min(240px, 100%);
    min-height: 48px;
    padding: 0 14px;
    border: 1px solid var(--border);
    border-radius: 0;
    color: var(--dark);
    font-family: var(--sans);
}
.cart-shell__main button.button,
.cart-shell__main .wc-proceed-to-checkout a.checkout-button,
.cart-shell__main .return-to-shop .button {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--dark);
    border-radius: 0;
    background: var(--dark);
    color: var(--white);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: background var(--ease), border-color var(--ease), color var(--ease), transform 0.2s;
}
.cart-shell__main button.button {
    padding: 0 22px;
}
.cart-shell__main button.button:hover,
.cart-shell__main .wc-proceed-to-checkout a.checkout-button:hover,
.cart-shell__main .return-to-shop .button:hover {
    transform: translateY(-2px);
    background: var(--sage-dark);
    border-color: var(--sage-dark);
    color: var(--white);
}
.cart-shell__main button.button:disabled,
.cart-shell__main button.button:disabled[disabled] {
    opacity: 0.45;
    color: var(--white);
}
.cart-shell__main .cart-collaterals {
    display: flex;
    justify-content: flex-end;
}
.cart-shell__main .cart-collaterals .cart_totals {
    width: min(420px, 100%);
    padding: 26px;
    background: var(--light);
    border: 1px solid var(--border);
}
.cart-shell__main .cart_totals h2 {
    margin: 0 0 16px;
    font-family: var(--serif);
    font-size: 30px;
    font-weight: 400;
    line-height: 1.15;
    color: var(--dark);
}
.cart-shell__main .cart_totals table.shop_table th,
.cart-shell__main .cart_totals table.shop_table td {
    padding: 14px 0;
}
.cart-shell__main .wc-proceed-to-checkout {
    padding: 18px 0 0;
}
.cart-shell__main .wc-proceed-to-checkout a.checkout-button {
    width: 100%;
    margin: 0;
    padding: 0 24px;
    font-size: 11px;
}
.cart-shell__main .cart-empty {
    margin: 0;
    padding: 54px 24px;
    background: var(--light);
    border: 1px solid var(--border);
    color: var(--mid);
    text-align: center;
}
.cart-shell__main .return-to-shop {
    margin: 0;
    text-align: center;
}

/* ============================================================
   PAGE CHECKOUT
============================================================ */
.woocommerce-checkout .site-header .topbar,
.page-template-page-checkout .site-header .topbar {
    background: var(--light);
    border-bottom-color: var(--border);
}
.woocommerce-checkout .site-header .topbar__link,
.woocommerce-checkout .site-header .topbar__account,
.woocommerce-checkout .site-header .topbar__currency .currency-btn,
.woocommerce-checkout .site-header .topbar__sep,
.woocommerce-checkout .site-header .header-nav__list a,
.woocommerce-checkout .site-header .header-lang,
.woocommerce-checkout .site-header .header-cart,
.woocommerce-checkout .site-header .header-logo__text,
.page-template-page-checkout .site-header .topbar__link,
.page-template-page-checkout .site-header .topbar__account,
.page-template-page-checkout .site-header .topbar__currency .currency-btn,
.page-template-page-checkout .site-header .topbar__sep,
.page-template-page-checkout .site-header .header-nav__list a,
.page-template-page-checkout .site-header .header-lang,
.page-template-page-checkout .site-header .header-cart,
.page-template-page-checkout .site-header .header-logo__text {
    color: var(--dark);
}
.woocommerce-checkout .site-header .header-main,
.page-template-page-checkout .site-header .header-main {
    background: rgba(255,255,255,0.97);
    box-shadow: 0 1px 20px rgba(0,0,0,0.08);
    backdrop-filter: blur(12px);
}
.woocommerce-checkout .site-header .header-burger span,
.page-template-page-checkout .site-header .header-burger span {
    background: var(--dark);
}
.checkout-page {
    background: var(--cream);
    color: var(--dark);
}
/* ============================================================
   CHECKOUT PAGE
============================================================ */
.co-page { padding-top: 110px; }

/* ── Hero ───────────────────────────────────────────────── */
.co-hero {
    background: var(--dark);
    padding: 52px 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.co-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}
.co-hero__left .section-eyebrow { color: var(--sage); }
.co-hero__left h1 {
    font-family: var(--serif);
    font-size: clamp(28px, 3vw, 44px);
    font-weight: 400;
    line-height: 1.08;
    color: var(--white);
    margin: 12px 0 16px;
}
.co-hero__left > p { color: rgba(255,255,255,0.5); font-size: 14px; line-height: 1.8; }
.co-hero__trust {
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 2px;
    overflow: hidden;
}
.co-trust-item {
    display: grid;
    grid-template-columns: 40px 1fr;
    gap: 14px;
    align-items: center;
    padding: 18px 22px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.co-trust-item:last-child { border-bottom: none; }
.co-trust-item__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    background: var(--sage);
    border-radius: 50%;
    font-size: 10px;
    font-weight: 700;
    color: var(--dark);
    flex-shrink: 0;
}
.co-trust-item strong { display: block; font-size: 13px; font-weight: 600; color: var(--white); margin-bottom: 2px; }
.co-trust-item p { font-size: 12px; color: rgba(255,255,255,0.45); line-height: 1.5; margin: 0; }

/* ── Main ───────────────────────────────────────────────── */
.co-main { padding: 48px 0 96px; }

/* Notices */
.co-main .woocommerce-notices-wrapper { margin-bottom: 20px; }

/* ── Grid 2 colonnes (notre wrapper propre) ─────────────── */
.co-checkout-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(410px, 0.62fr);
    gap: 36px;
    align-items: start;
}
.co-checkout-right {
    position: sticky;
    top: 124px;
}

/* ── Titres de section ──────────────────────────────────── */
.co-checkout-left .woocommerce-billing-fields h3,
.co-checkout-left .woocommerce-shipping-fields h3,
.co-order-heading {
    font-family: var(--serif);
    font-size: 22px;
    font-weight: 400;
    color: var(--dark);
    margin: 0 0 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border);
}
.co-order-heading { margin-bottom: 0; border-bottom: none; }

/* ── Champs billing : 2 colonnes 50/50 ──────────────────── */
.co-checkout-left .woocommerce-billing-fields__field-wrapper,
.co-checkout-left .woocommerce-shipping-fields__field-wrapper {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
}
.co-checkout-left .woocommerce-billing-fields__field-wrapper .form-row-wide,
.co-checkout-left .woocommerce-shipping-fields__field-wrapper .form-row-wide {
    grid-column: 1 / -1 !important;
}
.co-checkout-left .woocommerce-billing-fields__field-wrapper .form-row-first,
.co-checkout-left .woocommerce-billing-fields__field-wrapper .form-row-last,
.co-checkout-left .woocommerce-shipping-fields__field-wrapper .form-row-first,
.co-checkout-left .woocommerce-shipping-fields__field-wrapper .form-row-last {
    grid-column: auto !important;
    float: none !important;
    width: auto !important;
    clear: none !important;
}

/* ── Labels & champs ────────────────────────────────────── */
.co-checkout-left .form-row,
.co-checkout-right .form-row { margin: 0 0 16px; }
.co-checkout-left .form-row label {
    display: block;
    margin-bottom: 7px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--dark);
}
.co-checkout-left .required { color: var(--sage-dark); text-decoration: none; }

.co-checkout-left input.input-text,
.co-checkout-left textarea,
.co-checkout-left select,
.co-checkout-left .select2-container .select2-selection--single {
    min-height: 50px;
    border: 1px solid rgba(26,26,26,0.16);
    border-radius: 0;
    background: var(--white);
    color: var(--dark);
    font-family: var(--sans);
    font-size: 14px;
    box-sizing: border-box;
}
.co-checkout-left input.input-text,
.co-checkout-left textarea,
.co-checkout-left select { width: 100%; padding: 12px 14px; }
.co-checkout-left input.input-text:focus,
.co-checkout-left textarea:focus,
.co-checkout-left select:focus {
    border-color: var(--sage-dark);
    box-shadow: 0 0 0 3px rgba(138,158,126,0.15);
    outline: none;
}
.co-checkout-left .select2-container .select2-selection--single { display: flex; align-items: center; }
.co-checkout-left .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 14px;
    color: var(--dark);
}

/* ── Récapitulatif commande ─────────────────────────────── */
.co-recap {
    border: 1px solid var(--border);
    overflow: hidden;
}
.co-recap__head {
    display: grid;
    grid-template-columns: 18px 1fr;
    align-items: start;
    gap: 12px;
    background: var(--dark);
    padding: 16px 22px;
    color: var(--sage);
}
.co-recap__head svg {
    display: block;
    width: 16px;
    height: 16px;
    margin-top: 3px;
    flex-shrink: 0;
}
.co-order-heading {
    font-family: var(--serif);
    font-size: 18px;
    font-weight: 400;
    line-height: 1.22;
    color: var(--white);
    margin: 0;
    padding: 0;
    border: 0;
    letter-spacing: 0.01em;
}

/* Table produits */
#order_review {
    background: var(--white);
    padding: 0;
}
#order_review table.shop_table {
    border: 0;
    border-radius: 0;
    margin: 0;
    width: 100%;
    border-collapse: collapse;
}
#order_review table.shop_table thead tr {
    background: var(--light);
    border-bottom: 1px solid var(--border);
}
#order_review table.shop_table thead th {
    padding: 10px 22px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1.8px;
    text-transform: uppercase;
    color: var(--mid);
    border: 0;
}
#order_review table.shop_table tbody td {
    padding: 14px 22px;
    border-top: 1px solid var(--border);
    color: var(--dark);
    font-size: 13px;
    vertical-align: middle;
}
#order_review table.shop_table tbody td.product-name {
    font-weight: 500;
    line-height: 1.45;
    position: relative;
    padding-right: 38px;
}
#order_review table.shop_table tbody .product-quantity {
    display: inline-block;
    margin-top: 5px;
    color: var(--mid);
    font-size: 12px;
    font-weight: 500;
}
.co-order-product {
    position: relative;
    display: block;
}
.co-order-remove {
    position: absolute;
    top: -3px;
    right: -28px;
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
    background: transparent;
    color: #b5483a;
    font-family: var(--sans);
    font-size: 22px;
    font-weight: 400;
    line-height: 1;
    cursor: pointer;
    transition: color var(--ease), transform var(--ease), opacity var(--ease);
}
.co-order-remove:hover {
    color: #8f2f25;
    transform: scale(1.08);
}
.co-order-remove:disabled,
.co-order-remove.is-loading {
    opacity: 0.55;
    cursor: wait;
}
#order_review table.shop_table tbody td.product-total { text-align: right; color: var(--dark); font-weight: 600; }

/* Tfoot : sous-total / total */
#order_review table.shop_table tfoot tr th,
#order_review table.shop_table tfoot tr td {
    padding: 11px 22px;
    font-size: 13px;
    border-top: 1px solid var(--border);
    color: var(--dark);
}
#order_review table.shop_table tfoot tr.order-total {
    background: var(--sage);
}
#order_review table.shop_table tfoot tr.order-total th,
#order_review table.shop_table tfoot tr.order-total td {
    font-size: 15px;
    font-weight: 700;
    color: var(--dark);
    border-top: 2px solid rgba(0,0,0,0.08);
}
#order_review table.shop_table tfoot tr.order-total td strong { font-weight: 700; }

.co-order-table tfoot tr {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(max-content, 84px) 22px;
    gap: 10px;
    align-items: center;
    padding: 11px 18px;
    border-top: 1px solid var(--border);
}
.co-order-table tfoot tr th,
.co-order-table tfoot tr td {
    padding: 0 !important;
    border-top: 0 !important;
}
.co-order-table tfoot tr th {
    grid-column: 1;
}
.co-order-table tfoot tr td {
    grid-column: 2;
    text-align: right;
    white-space: nowrap;
}
.co-order-table tfoot tr.order-total {
    border-top: 2px solid rgba(0,0,0,0.08);
}

/* ── Paiement ───────────────────────────────────────────── */
#payment {
    background: var(--light);
    border-top: 1px solid var(--border);
    border-radius: 0;
    margin: 0;
    padding: 18px 20px;
}
#payment ul.payment_methods {
    border: 0;
    padding: 0;
    margin: 0 0 18px;
    list-style: none;
    display: grid;
    gap: 10px;
}
#payment ul.payment_methods li {
    position: relative;
    padding: 0;
    margin: 0;
}
#payment ul.payment_methods input.input-radio {
    position: absolute;
    top: 50%;
    left: 14px;
    z-index: 1;
    width: 16px;
    height: 16px;
    margin: 0;
    transform: translateY(-50%);
    accent-color: var(--dark);
    cursor: pointer;
}
#payment ul.payment_methods label {
    min-height: 50px;
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 13px 14px 13px 40px;
    border: 1px solid rgba(26,26,26,0.13);
    border-radius: 3px;
    background: var(--white);
    font-size: 12px;
    font-weight: 600;
    color: var(--dark);
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}
#payment ul.payment_methods label img {
    max-height: 18px;
    width: auto;
    margin-left: 4px;
    flex-shrink: 0;
}
#payment ul.payment_methods li:has(input.input-radio:checked) label {
    border-color: rgba(26,26,26,0.78);
    background: #fffefa;
    box-shadow: 0 8px 22px rgba(0,0,0,0.07), inset 0 0 0 1px rgba(26,26,26,0.78);
}
#payment ul.payment_methods li:has(input.input-radio:checked) label::before {
    content: '';
    width: 7px;
    height: 7px;
    flex-shrink: 0;
    margin-left: auto;
    background: var(--sage);
    border-radius: 50%;
}
#payment ul.payment_methods li.payment_method_cod label::after {
    content: 'Défaut';
    margin-left: auto;
    padding: 3px 7px;
    border: 1px solid rgba(26,26,26,0.16);
    border-radius: 999px;
    color: var(--mid);
    font-size: 7px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
}
#payment ul.payment_methods li:has(input.input-radio:checked).payment_method_cod label::after {
    display: none;
}
#payment ul.payment_methods li.payment_method_stripe label::after,
#payment ul.payment_methods li.payment_method_woocommerce_payments label::after {
    content: 'Carte';
    margin-left: auto;
    padding: 3px 7px;
    border: 1px solid rgba(26,26,26,0.16);
    border-radius: 999px;
    color: var(--mid);
    font-size: 7px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
}
#payment ul.payment_methods li:has(input.input-radio:checked).payment_method_stripe label::after,
#payment ul.payment_methods li:has(input.input-radio:checked).payment_method_woocommerce_payments label::after {
    display: none;
}
#payment .payment_box {
    background: var(--white);
    border: 1px solid rgba(26,26,26,0.1);
    border-top: 0;
    border-radius: 0 0 3px 3px;
    padding: 10px 14px 12px 40px;
    font-size: 12px;
    color: var(--mid);
    margin: 0;
}
#payment div.form-row { padding: 0; margin: 0; }
#place_order {
    display: block;
    width: 100%;
    min-height: 52px;
    border: none;
    border-radius: 0;
    background: var(--dark);
    color: var(--white);
    font-family: var(--sans);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background var(--ease), transform 0.18s;
}
#place_order:hover { background: var(--sage-dark); transform: translateY(-1px); }

.woocommerce-privacy-policy-text { display: none !important; }

/* Checkbox CGV */
.co-cgv {
    margin: 0 0 18px;
    padding: 14px 0 2px;
}
.co-cgv__label {
    position: relative;
    display: grid;
    grid-template-columns: 18px 1fr;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}
.woocommerce form .form-row label.co-cgv__label,
.woocommerce-page form .form-row label.co-cgv__label {
    display: grid;
}
.co-cgv__input {
    position: static;
    width: 17px;
    height: 17px;
    margin: 0;
    opacity: 1;
    overflow: visible;
    clip: auto;
    clip-path: none;
    accent-color: var(--dark);
}
.co-cgv__check {
    display: none;
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border: 1.5px solid rgba(26,26,26,0.3);
    background: var(--white);
    margin-top: 0;
    transition: border-color var(--ease), background var(--ease);
    position: relative;
}
.co-cgv__label:hover .co-cgv__check {
    border-color: var(--dark);
}
.co-cgv__input:focus-visible + .co-cgv__check {
    box-shadow: 0 0 0 3px rgba(138,158,126,0.22);
}
.co-cgv__input:checked + .co-cgv__check {
    background: var(--dark);
    border-color: var(--dark);
}
.co-cgv__input:checked + .co-cgv__check::after {
    content: '';
    position: absolute;
    left: 4px;
    top: 1px;
    width: 5px;
    height: 9px;
    border: 2px solid var(--white);
    border-top: none;
    border-left: none;
    transform: rotate(45deg);
}
.co-cgv__text {
    display: block;
    font-size: 12px;
    color: var(--mid);
    line-height: 18px;
}
.co-cgv__text a {
    color: var(--dark);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.co-cgv__text a:hover { color: var(--sage-dark); }

/* Checkout recap refined layout */
.co-order-table thead {
    display: none;
}
.co-order-table tbody td.product-name {
    padding: 14px 18px;
}
.co-order-line {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 36px minmax(max-content, 84px) 22px;
    gap: 10px;
    align-items: center;
    width: 100%;
}
.co-order-line__name {
    min-width: 0;
    display: block;
    overflow: hidden;
    color: var(--dark);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.35;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.co-order-line__qty {
    color: var(--mid);
    font-size: 12px;
    font-weight: 600;
    text-align: right;
    white-space: nowrap;
}
.co-order-line__price {
    color: var(--dark);
    font-size: 13px;
    font-weight: 700;
    text-align: right;
    white-space: nowrap;
}
.co-order-line__remove {
    width: 22px;
    height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
    background: transparent;
    color: #b5483a;
    font-size: 21px;
    font-weight: 400;
    line-height: 1;
    cursor: pointer;
    transition: color var(--ease), transform var(--ease), opacity var(--ease);
}
.co-order-line__remove:hover {
    color: #8f2f25;
    transform: scale(1.08);
}
.co-order-line__remove:disabled,
.co-order-line__remove.is-loading {
    opacity: 0.55;
    cursor: wait;
}

/* Checkout payment refined layout */
#payment ul.payment_methods {
    grid-template-columns: 1fr;
    gap: 10px;
}
#payment ul.payment_methods input.input-radio {
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}
#payment ul.payment_methods label.co-payment-card {
    min-height: 64px;
    display: grid;
    grid-template-columns: 16px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    padding: 12px;
    border: 1px solid rgba(26,26,26,0.12);
    border-radius: 6px;
    background: var(--white);
    box-shadow: none;
    white-space: normal;
}
#payment ul.payment_methods input.input-radio:checked + label.co-payment-card {
    border-color: var(--dark);
    background: #fffefa;
    box-shadow: 0 10px 24px rgba(0,0,0,0.07), inset 0 0 0 1px var(--dark);
}
#payment ul.payment_methods input.input-radio:checked + label.co-payment-card::before,
#payment ul.payment_methods label.co-payment-card::after {
    content: none !important;
}
.co-payment-card__mark {
    width: 16px;
    height: 16px;
    border: 1.5px solid rgba(26,26,26,0.28);
    border-radius: 50%;
    background: var(--white);
    position: relative;
}
#payment ul.payment_methods input.input-radio:checked + label .co-payment-card__mark {
    border-color: var(--dark);
    background: var(--dark);
}
#payment ul.payment_methods input.input-radio:checked + label .co-payment-card__mark::after {
    content: '';
    position: absolute;
    inset: 4px;
    border-radius: 50%;
    background: var(--sage);
}
.co-payment-card__body {
    min-width: 0;
    display: grid;
    gap: 3px;
}
.co-payment-card__top {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}
.co-payment-card__title {
    min-width: 0;
    display: block;
    overflow: hidden;
    color: var(--dark);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.2px;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.co-payment-card__tag {
    flex-shrink: 0;
    padding: 3px 6px;
    border-radius: 999px;
    background: var(--sage);
    color: var(--dark);
    font-size: 7px;
    font-weight: 800;
    letter-spacing: 0.8px;
    line-height: 1;
    text-transform: uppercase;
}
.co-payment-card__desc {
    overflow: hidden;
    color: var(--mid);
    font-size: 10px;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.co-payment-card__icon {
    display: none;
}
#payment .payment_box {
    grid-column: 1 / -1;
    margin-top: -10px;
    border-radius: 0 0 6px 6px;
    padding: 10px 12px;
}
.co-cgv__label {
    align-items: center;
}
.co-cgv__check {
    margin-top: 0;
}
.co-cgv__text {
    line-height: 18px;
    transform: translateY(-2px);
}

/* ── Masquer sections inutiles ──────────────────────────── */
.co-checkout-left .woocommerce-additional-fields { display: none !important; }
.woocommerce-checkout-review-order-table + .woocommerce-terms-and-conditions-wrapper { margin-top: 16px; }

/* ============================================================
   SECTION 7 — TRUST BAR (dans footer.php)
============================================================ */
.trust-bar {
    padding: 60px 0;
    background: var(--sage);
    border-top: 1px solid rgba(0,0,0,0.05);
}
.trust-bar__list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
}
.trust-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 0 36px;
    border-right: 1px solid rgba(0,0,0,0.1);
}
.trust-item:last-child { border-right: none; }
.trust-item svg {
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--dark);
    opacity: 0.7;
}
.trust-item strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--dark);
    margin-bottom: 4px;
    letter-spacing: 0.2px;
}
.trust-item span {
    font-size: 13px;
    color: rgba(0,0,0,0.58);
    line-height: 1.5;
}

/* ============================================================
   FOOTER
============================================================ */
.site-footer {
    background: var(--dark);
    color: rgba(255,255,255,0.75);
    padding: 60px 0 40px;
}
.footer-top {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-bottom: 40px;
    text-align: center;
}
.footer-logo span {
    font-family: var(--serif);
    font-size: 32px;
    font-weight: 500;
    letter-spacing: 6px;
    color: var(--white);
}
.footer-tagline {
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
}
.footer-social {
    display: flex;
    gap: 14px;
    margin-top: 6px;
}
.social-link {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,0.6);
    transition: border-color var(--ease), color var(--ease), background var(--ease);
}
.social-link:hover {
    border-color: var(--sage);
    color: var(--sage);
    background: rgba(200,224,172,0.08);
}
.footer-mid {
    border-top: 1px solid rgba(255,255,255,0.08);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    padding: 24px 0;
    margin-bottom: 28px;
}
.footer-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 11px;
    letter-spacing: 1px;
    text-transform: uppercase;
}
.footer-nav a {
    color: rgba(255,255,255,0.5);
    transition: color var(--ease);
}
.footer-nav a:hover { color: var(--white); }
.footer-sep { color: rgba(255,255,255,0.2); }
.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.footer-copy {
    font-size: 12px;
    color: rgba(255,255,255,0.3);
    letter-spacing: 0.5px;
}
.footer-lang {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
}
.footer-lang .lang-btn { color: rgba(255,255,255,0.4); padding: 2px 4px; }
.footer-lang .lang-btn:hover,
.footer-lang .lang-btn.active { color: var(--white); }
.footer-lang .lang-sep { color: rgba(255,255,255,0.2); font-size: 10px; }

/* ============================================================
   RESPONSIVE — 1024px
============================================================ */
@media (max-width: 1024px) {
    .container { padding: 0 28px; }
    :root { --header-h: 86px; }
    .header-nav { display: none; }
    .header-burger { display: flex; }
    .mobile-menu { display: flex; }
    .header-lang { display: flex; }
    .header-main__inner { justify-content: flex-start; }
    .header-actions { gap: 20px; margin-left: auto; }
    .topbar__right { display: none; }
    .topbar__currency {
        left: auto;
        right: 28px;
        transform: none;
    }
    .topbar__link {
        max-width: calc(100% - 128px);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .products-grid { grid-template-columns: repeat(2, 1fr); }
    .why-grid { grid-template-columns: 1fr; }
    .why-card { border-right: none; border-bottom: 1px solid var(--border); }
    .why-card:last-child { border-bottom: none; }
    .trust-bar__list { grid-template-columns: repeat(2, 1fr); }
    .trust-item { border-right: 1px solid rgba(0,0,0,0.1); border-bottom: 1px solid rgba(0,0,0,0.08); padding: 24px 28px; }
    .trust-item:nth-child(2n) { border-right: none; }
    .trust-item:nth-child(3),
    .trust-item:nth-child(4) { border-bottom: none; }
    .reviews-grid { grid-template-columns: 1fr 1fr; }
    .reviews-grid .review-card:nth-child(3) { display: none; }
    .history-story__grid { grid-template-columns: 1fr; gap: 42px; }
    .history-story__intro { position: static; }
    .history-values { grid-template-columns: repeat(2, 1fr); }
    .contact-grid { grid-template-columns: 1fr; gap: 48px; }
    .contact-info { position: static; }
    .contact-form-wrap__title { font-size: 32px; }
    .shop-products__grid { grid-template-columns: repeat(2, 1fr); }
    .shop-hero__inner { grid-template-columns: 1fr; }
    .shop-hero__badge-wrap { display: none; }
    .shop-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .shop-manifesto__inner { grid-template-columns: 1fr; gap: 28px; }
    .shop-manifesto__deco { display: none; }
    .cart-shell { grid-template-columns: 1fr; }
    .cart-assurance { position: static; }
    .cart-shell__main .cart-collaterals { justify-content: stretch; }
    .cart-shell__main .cart-collaterals .cart_totals { width: 100%; }
    .checkout-shell { grid-template-columns: 1fr; }
    .checkout-assurance { position: static; }
    .checkout-shell__main form.checkout { grid-template-columns: 1fr; }
    .checkout-shell__main #customer_details,
    .checkout-shell__main #order_review_heading,
    .checkout-shell__main #order_review {
        grid-column: 1;
    }
    .checkout-shell__main #order_review_heading { margin: 8px 0 -12px; }
    .co-checkout-grid { grid-template-columns: 1fr; gap: 34px; }
    .co-checkout-right { position: static; }
}

/* ============================================================
   RESPONSIVE — 768px
============================================================ */
@media (max-width: 768px) {
    :root { --header-h: 80px; }
    .container { padding: 0 20px; }

    /* Header */
    .header-main__inner { height: 56px; gap: 16px; }
    .header-logo__text { font-size: 22px; letter-spacing: 3px; }
    .topbar__inner { height: 34px; }
    .topbar__link {
        max-width: calc(100% - 118px);
        font-size: 11px;
    }
    .topbar__currency { right: 20px; gap: 4px; }
    .currency-btn { font-size: 10px; padding: 2px 5px; }
    .header-actions { gap: 14px; }
    .header-cart svg { width: 21px; height: 21px; }
    .mobile-menu__list,
    .mobile-menu__footer { padding-left: 24px; padding-right: 24px; }
    .bglow-mini-cart__panel { width: 100%; }
    .bglow-mini-cart__head { padding: 26px 22px 20px; }
    .bglow-mini-cart__head h2 { font-size: 30px; }
    .bglow-mini-cart__body { padding: 6px 22px; }
    .bglow-mini-cart__item {
        grid-template-columns: 64px 1fr;
        align-items: start;
        gap: 14px;
    }
    .bglow-mini-cart__line-total {
        grid-column: 2;
        justify-self: start;
        margin-top: -8px;
    }
    .bglow-mini-cart__foot { padding: 22px; }

    /* Hero */
    .hero { min-height: 100svh; }
    .hero-slide__inner { max-width: 100%; }
    .hero-prev { left: 16px; }
    .hero-next { right: 16px; }
    .hero-slide__cta { flex-direction: column; align-items: flex-start; }

    /* Sections */
    .section-brand,
    .section-why,
    .section-results,
    .section-routine,
    .section-reviews { padding: 70px 0; }

    /* Products — 2 visibles + scroll horizontal */
    .products-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        padding-left: 4px;
        padding-right: 4px;
        scrollbar-width: none;
    }
    .products-grid::-webkit-scrollbar { display: none; }
    .product-card {
        flex: 0 0 calc(50% - 10px);
        scroll-snap-align: start;
    }
    .product-card__body {
        padding: 14px 14px 16px;
        gap: 8px;
    }
    .product-card__name {
        font-size: 14px;
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .product-card__footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        margin-top: 2px;
    }
    .product-card__price {
        font-size: 14px;
        text-align: left;
    }

    /* Pourquoi B-Glow — 1 visible + scroll */
    .why-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        margin-left: -20px;
        margin-right: -20px;
        padding-left: 20px;
        padding-right: 20px;
        border: none;
        border-radius: 0;
        scrollbar-width: none;
    }
    .why-grid::-webkit-scrollbar { display: none; }
    .why-card {
        flex: 0 0 82%;
        scroll-snap-align: start;
        border: 1px solid var(--border);
        border-radius: 4px;
        border-bottom: 1px solid var(--border);
        padding: 28px 24px;
    }
    .why-card:last-child { border-bottom: 1px solid var(--border); }
    .why-card__num { font-size: 42px; margin-bottom: 12px; }
    .why-card__title { font-size: 19px; }
    .why-card__text { font-size: 13px; }

    /* Routine — 1 étape visible + scroll */
    .routine-steps {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        margin-left: -20px;
        margin-right: -20px;
        padding-left: 20px;
        padding-right: 20px;
        border: none;
        border-radius: 0;
        scrollbar-width: none;
    }
    .routine-steps::-webkit-scrollbar { display: none; }
    .routine-step {
        flex: 0 0 82%;
        scroll-snap-align: start;
        border: 1px solid var(--border);
        border-radius: 4px;
        border-bottom: 1px solid var(--border);
        padding: 28px 24px 32px;
    }
    .routine-step:last-child { border-bottom: 1px solid var(--border); }
    .routine-step__icon { width: 48px; height: 48px; margin-bottom: 22px; }
    .routine-step__action { font-size: 28px; margin-bottom: 12px; }
    .routine-step__desc { font-size: 13px; margin-bottom: 20px; }
    .routine-step__num { margin-bottom: 6px; }

    /* History */
    .history-hero { min-height: 50vh; }
    .history-hero__content { padding-top: 125px; padding-bottom: 54px; }
    .history-story { padding: 75px 0; }
    .history-story__grid { gap: 34px; }
    .history-story__content { font-size: 21px; }
    .history-story__content p + p { margin-top: 22px; }
    .history-universe { padding: 75px 0; }
    .history-values { grid-template-columns: 1fr; }
    .history-value { min-height: auto; padding: 30px 24px; }
    .contact-hero { padding: 130px 0 60px; }
    .contact-hero__title { font-size: 38px; }
    .contact-body { padding: 60px 0 80px; }
    .contact-form-inner { padding: 28px 22px; }
    .contact-form-inner .wpcf7-form { grid-template-columns: 1fr; }
    .contact-form-inner .wpcf7-form > p:nth-child(3),
    .contact-form-inner .wpcf7-form > p:nth-child(4),
    .contact-form-inner .wpcf7-form > p:nth-child(5) { grid-column: 1; }
    .contact-form-inner input[type="submit"] { width: 100%; }
    .shop-hero { padding: 112px 0 50px; }
    .shop-hero__title { font-size: 32px; }
    .shop-hero__stats { gap: 22px; }
    .shop-products { padding: 50px 0 70px; }
    .shop-products__grid { grid-template-columns: 1fr; gap: 22px; }
    .shop-grid { grid-template-columns: 1fr; gap: 22px; }
    .shop-manifesto { padding: 48px 0; }
    .shop-manifesto__promises { display: none; }
    .cart-hero { padding: 112px 0 38px; }
    .cart-hero h1 { font-size: 34px; }
    .cart-section { padding: 42px 0 72px; }
    .cart-shell { gap: 20px; }
    .cart-shell__main { padding: 22px 18px; }
    .cart-assurance { padding: 24px 20px; }
    .cart-assurance h2,
    .cart-shell__main .cart_totals h2 {
        font-size: 25px;
    }
    .cart-shell__main table.shop_table_responsive tr {
        margin-bottom: 16px;
        border: 1px solid var(--border);
    }
    .cart-shell__main table.shop_table_responsive tr td {
        padding: 13px 14px;
        border-top: 1px solid rgba(26,26,26,0.08);
    }
    .cart-shell__main table.shop_table_responsive tr td:first-child {
        border-top: 0;
    }
    .cart-shell__main table.shop_table_responsive tr td::before {
        color: var(--mid);
        font-size: 10px;
        font-weight: 700;
        letter-spacing: 1.3px;
        text-transform: uppercase;
    }
    .cart-shell__main .coupon {
        flex-direction: column;
    }
    .cart-shell__main .coupon .input-text,
    .cart-shell__main button.button {
        width: 100%;
    }
    .cart-shell__main .cart-collaterals .cart_totals {
        padding: 20px;
    }
    .checkout-hero { padding: 112px 0 38px; }
    .checkout-hero h1 { font-size: 34px; }
    .checkout-section { padding: 42px 0 72px; }

    /* Checkout hero (co-page) */
    .co-page { padding-top: 90px; }
    .co-hero { padding: 28px 0 32px; }
    .co-hero__inner { grid-template-columns: 1fr; gap: 22px; }
    .co-hero__left h1 { font-size: 26px; margin: 8px 0 10px; }
    .co-hero__left > p { font-size: 13px; }
    .co-trust-item { padding: 14px 16px; gap: 10px; }
    .co-trust-item__num { width: 30px; height: 30px; font-size: 9px; }
    .checkout-shell { gap: 20px; }
    .checkout-shell__main { padding: 22px 18px; }
    .checkout-assurance { padding: 24px 20px; }
    .checkout-assurance h2,
    .checkout-shell__main .woocommerce-billing-fields h3,
    .checkout-shell__main .woocommerce-additional-fields h3,
    .checkout-shell__main #order_review_heading {
        font-size: 25px;
    }
    .checkout-shell__main #order_review { padding: 18px; }
    .co-order-line {
        grid-template-columns: minmax(0, 1fr) 32px minmax(max-content, 76px) 22px;
        gap: 8px;
    }
    #payment ul.payment_methods {
        grid-template-columns: 1fr;
    }

    /* Reviews — côte à côte en scroll */
    .reviews-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        margin-left: -20px;
        margin-right: -20px;
        padding-left: 20px;
        padding-right: 20px;
        scrollbar-width: none;
    }
    .reviews-grid::-webkit-scrollbar { display: none; }
    .review-card {
        flex: 0 0 82%;
        scroll-snap-align: start;
        padding: 24px 22px 28px;
    }
    .review-text { font-size: 15px; }
    .review-avatar { width: 40px; height: 40px; font-size: 18px; }
    .reviews-grid .review-card:nth-child(3) { display: flex; }

    /* Trust */
    .trust-bar__list { grid-template-columns: 1fr; }
    .trust-item { border-right: none; border-bottom: 1px solid rgba(0,0,0,0.08); padding: 20px 0; }
    .trust-bar { padding: 40px 0; }

    /* Footer */
    .footer-bottom { flex-direction: column; gap: 16px; text-align: center; }

    /* BA compare */
    .ba-compare { aspect-ratio: 1/1; }
}

/* ============================================================
   PAGE THANK YOU
============================================================ */

.woocommerce-order-received .site-header .topbar { background: var(--light); border-bottom-color: var(--border); }
.woocommerce-order-received .site-header .header-nav__list a,
.woocommerce-order-received .site-header .header-lang,
.woocommerce-order-received .site-header .header-cart,
.woocommerce-order-received .site-header .header-logo__text { color: var(--dark); }
.woocommerce-order-received .site-header .header-main { background: rgba(255,255,255,0.97); box-shadow: 0 1px 20px rgba(0,0,0,0.08); }
.woocommerce-order-received .site-header .header-burger span { background: var(--dark); }

.ty-page { padding-top: 110px; background: var(--cream); min-height: 100vh; }

/* Hero */
.ty-hero { background: var(--dark); padding: 52px 0 56px; text-align: center; border-bottom: 1px solid rgba(255,255,255,0.06); }
.ty-hero--error { background: #3a1a1a; }
.ty-hero__icon { width: 72px; height: 72px; border-radius: 50%; background: rgba(168,196,140,0.15); border: 1px solid var(--sage); display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; color: var(--sage); }
.ty-hero__eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--sage); margin-bottom: 14px; }
.ty-hero__title { font-family: var(--serif); font-size: clamp(28px, 3.5vw, 46px); font-weight: 400; color: var(--white); line-height: 1.1; margin-bottom: 16px; }
.ty-hero__sub { font-size: 15px; color: rgba(255,255,255,0.5); line-height: 1.8; max-width: 520px; margin: 0 auto 28px; }
.ty-hero__sub strong { color: rgba(255,255,255,0.8); font-weight: 500; }
.ty-hero__actions { display: flex; gap: 12px; justify-content: center; }

/* Body */
.ty-body { padding: 48px 0 80px; }
.ty-grid { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 28px; align-items: start; }

/* Card */
.ty-card { background: var(--white); border: 1px solid var(--border); border-radius: 4px; padding: 28px 28px 30px; margin-bottom: 20px; }
.ty-card:last-child { margin-bottom: 0; }
.ty-card__title { font-family: var(--serif); font-size: 18px; font-weight: 400; color: var(--dark); margin-bottom: 20px; padding-bottom: 14px; border-bottom: 1px solid var(--border); }
.ty-card--message { background: var(--sage-light); border-color: rgba(168,196,140,0.4); padding: 22px 24px; }
.ty-message__text { font-family: var(--serif); font-size: 14px; font-style: italic; color: var(--dark); line-height: 1.8; margin: 0; }

/* Items */
.ty-items { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; }
.ty-item { display: grid; grid-template-columns: 64px 1fr auto; gap: 14px; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--border); }
.ty-item:last-child { border-bottom: none; }
.ty-item__img { width: 64px; height: 64px; border-radius: 3px; overflow: hidden; background: var(--light); flex-shrink: 0; }
.ty-item__img img { width: 100%; height: 100%; object-fit: cover; }
.ty-item__info { display: flex; flex-direction: column; gap: 4px; }
.ty-item__name { font-size: 14px; font-weight: 500; color: var(--dark); }
.ty-item__qty { font-size: 12px; color: var(--mid); }
.ty-item__price { font-size: 14px; font-weight: 600; color: var(--dark); white-space: nowrap; }

/* Totaux */
.ty-totals { border-top: 1px solid var(--border); padding-top: 16px; display: flex; flex-direction: column; gap: 10px; }
.ty-totals__row { display: flex; justify-content: space-between; font-size: 13px; color: var(--mid); }
.ty-totals__row--total { font-size: 15px; font-weight: 600; color: var(--dark); padding-top: 10px; border-top: 1px solid var(--border); margin-top: 4px; }

/* Détails */
.ty-details { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.ty-details li { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.ty-details__label { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--mid); font-weight: 500; flex-shrink: 0; }
.ty-details__value { font-size: 13px; color: var(--dark); font-weight: 500; text-align: right; }
.ty-status { display: inline-block; background: var(--sage-light); color: var(--sage-dark); font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 3px 10px; border-radius: 20px; }

/* Adresse */
.ty-address { font-style: normal; font-size: 13px; color: var(--mid); line-height: 1.8; }

/* WhatsApp */
.ty-whatsapp { background: var(--white); border: 1px solid var(--border); border-radius: 4px; padding: 24px 28px 28px; margin-bottom: 20px; }
.ty-whatsapp__inner { display: flex; gap: 16px; align-items: flex-start; margin-bottom: 20px; }
.ty-whatsapp__icon { width: 52px; height: 52px; border-radius: 50%; background: #e8f5e0; color: #25d366; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ty-whatsapp__text strong { display: block; font-size: 15px; font-weight: 600; color: var(--dark); margin-bottom: 6px; }
.ty-whatsapp__text p { font-size: 13px; color: var(--mid); line-height: 1.6; margin: 0; }
.ty-whatsapp__btn { display: inline-flex; align-items: center; gap: 10px; background: #25d366; color: #fff; font-family: var(--sans); font-size: 13px; font-weight: 600; letter-spacing: 0.5px; padding: 13px 24px; border-radius: 3px; text-decoration: none; transition: background 0.2s ease; width: 100%; justify-content: center; }
.ty-whatsapp__btn:hover { background: #1da851; color: #fff; }

/* Footer actions */
.ty-footer-actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }

/* Responsive */
@media (max-width: 1024px) {
    .ty-grid { grid-template-columns: 1fr; }
    .ty-aside { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
    .ty-aside .ty-card { margin-bottom: 0; }
    .ty-aside .ty-card--message { grid-column: 1 / -1; }
}
@media (max-width: 768px) {
    .ty-page { padding-top: 90px; }
    .ty-hero { padding: 32px 0 36px; }
    .ty-hero__title { font-size: 26px; }
    .ty-hero__sub { font-size: 13px; }
    .ty-body { padding: 28px 0 60px; }
    .ty-card { padding: 20px 18px 22px; margin-bottom: 14px; }
    .ty-aside { grid-template-columns: 1fr; }
    .ty-aside .ty-card--message { grid-column: auto; }
    .ty-item { grid-template-columns: 52px 1fr auto; gap: 10px; }
    .ty-item__img { width: 52px; height: 52px; }
    .ty-whatsapp { padding: 18px 18px 22px; margin-bottom: 14px; }
    .ty-whatsapp__inner { gap: 12px; }
    .ty-footer-actions { flex-direction: column; }
    .ty-footer-actions .btn { width: 100%; text-align: center; justify-content: center; }
}

/* ============================================================
   PAGE PRODUIT SINGLE
============================================================ */

/* Header toujours opaque */
.single-product .site-header .topbar { background: var(--light); border-bottom-color: var(--border); }
.single-product .site-header .topbar__link,
.single-product .site-header .topbar__account,
.single-product .site-header .topbar__currency .currency-btn,
.single-product .site-header .topbar__sep,
.single-product .site-header .header-nav__list a,
.single-product .site-header .header-lang,
.single-product .site-header .header-cart,
.single-product .site-header .header-logo__text { color: var(--dark); }
.single-product .site-header .header-main { background: rgba(255,255,255,0.97); box-shadow: 0 1px 20px rgba(0,0,0,0.08); backdrop-filter: blur(12px); }
.single-product .site-header .header-burger span { background: var(--dark); }

/* PAGE */
.sp-page { background: var(--white); }

/* BREADCRUMB */
.sp-breadcrumb { background: var(--light); border-bottom: 1px solid var(--border); margin-top: 110px; }

/* Notices WooCommerce sur la page produit */
.sp-page .woocommerce-notices-wrapper { margin: 0; }
.sp-page .woocommerce-message,
.sp-page .woocommerce-error,
.sp-page .woocommerce-info {
    border-top: none;
    border-radius: 0;
    padding: 16px 40px;
    font-size: 13px;
    margin: 0;
    background: var(--sage-light);
    border-left: none;
    border-bottom: 1px solid var(--border);
    color: var(--dark);
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    text-align: center;
}
.sp-page .woocommerce-message::before { display: none; }
.sp-page .woocommerce-message a.button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--dark);
    color: var(--light) !important;
    font-family: var(--sans);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 9px 20px;
    border-radius: 2px;
    text-decoration: none;
    white-space: nowrap;
    transition: background var(--ease), color var(--ease);
    flex-shrink: 0;
}
.sp-page .woocommerce-message a.button:hover {
    background: var(--sage-dark);
    color: var(--dark) !important;
}
.sp-breadcrumb .container {
    display: flex;
    align-items: center;
    gap: 8px;
    height: 44px;
    font-size: 12px;
    color: var(--mid);
    flex-wrap: wrap;
}
.sp-breadcrumb svg { color: var(--soft); flex-shrink: 0; }
.sp-breadcrumb a { color: var(--mid); transition: color var(--ease); }
.sp-breadcrumb a:hover { color: var(--dark); }
.sp-breadcrumb__current { color: var(--dark); font-weight: 500; }

/* ── LAYOUT PRINCIPAL ── */
.sp-layout { padding: 60px 0 80px; background: var(--white); }
.sp-layout__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: start;
}

/* ── GALERIE (sticky) ── */
.sp-gallery-col {
    position: sticky;
    top: 110px;
}
.sp-gallery-wrap {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 14px;
}

/* Vignettes verticales */
.sp-thumbstrip {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.sp-thumb {
    width: 80px;
    height: 80px;
    overflow: hidden;
    border: 2px solid transparent;
    background: var(--light);
    cursor: pointer;
    padding: 0;
    transition: border-color var(--ease);
    flex-shrink: 0;
}
.sp-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sp-thumb.active,
.sp-thumb:hover { border-color: var(--sage-dark); }

/* Image principale */
.sp-main-visual {
    position: relative;
    aspect-ratio: 3/4;
    overflow: hidden;
    background: var(--light);
}
.sp-main-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(.25,.46,.45,.94);
    display: block;
}
.sp-main-visual:hover img { transform: scale(1.04); }

.sp-badge {
    position: absolute;
    top: 16px;
    left: 16px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 5px 14px;
    border-radius: 20px;
    background: #e8c4a0;
    color: #5c3d1e;
    z-index: 2;
}
.sp-badge--new { background: var(--sage); color: var(--dark); }

.sp-zoom-hint {
    position: absolute;
    bottom: 14px;
    right: 14px;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(255,255,255,0.88);
    backdrop-filter: blur(6px);
    font-size: 11px;
    font-weight: 500;
    color: var(--dark);
    opacity: 0;
    transition: opacity var(--ease);
    pointer-events: none;
}
.sp-main-visual:hover .sp-zoom-hint { opacity: 1; }

/* ── INFOS (défile) ── */
.sp-info-col { padding-top: 4px; }

.sp-cat {
    display: inline-block;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--sage-dark);
    margin-bottom: 12px;
    text-decoration: none;
    transition: color var(--ease);
}
.sp-cat:hover { color: var(--dark); }

.sp-title {
    font-family: var(--serif);
    font-size: clamp(22px, 2.4vw, 32px);
    font-weight: 400;
    line-height: 1.06;
    color: var(--dark);
    letter-spacing: -0.02em;
    margin-bottom: 16px;
}

/* Étoiles */
.sp-rating { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.sp-stars { display: flex; gap: 2px; color: #c8a84b; }
.sp-rating__txt { font-size: 12px; color: var(--mid); }
.sp-rating__txt a { color: var(--mid); text-decoration: underline; transition: color var(--ease); }
.sp-rating__txt a:hover { color: var(--sage-dark); }

/* Prix */
.sp-price {
    font-size: 28px;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 18px;
    letter-spacing: -0.02em;
}
.sp-price del { color: var(--soft); font-size: 18px; font-weight: 400; margin-right: 8px; }
.sp-price ins { text-decoration: none; }
.sp-price .woocommerce-Price-amount { font-family: var(--sans); }

/* Description courte */
.sp-short-desc { font-size: 15px; color: var(--mid); line-height: 1.85; margin-bottom: 24px; }
.sp-short-desc p + p { margin-top: 10px; }

/* Icônes bénéfices */
.sp-features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    margin-bottom: 24px;
    background: var(--border);
    border: 1px solid var(--border);
}
.sp-feature {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
    padding: 18px 10px;
    background: var(--cream);
    transition: background var(--ease);
}
.sp-feature:hover { background: var(--sage-light); }
.sp-feature__icon {
    width: 46px;
    height: 46px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sage);
    border-radius: 50%;
    color: var(--dark);
    flex-shrink: 0;
}
.sp-feature span {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3px;
    line-height: 1.4;
    color: var(--dark);
}

.sp-divider { border: none; border-top: 1px solid var(--border); margin: 22px 0; }

/* ── AJOUTER AU PANIER ── */
.sp-atc { margin-bottom: 16px; }
.sp-atc form.cart {
    display: flex;
    align-items: stretch;
    gap: 10px;
}
.sp-atc .quantity { display: flex; align-items: center; }
.sp-atc .qty {
    width: 64px;
    height: 54px;
    text-align: center;
    border: 1px solid var(--border);
    border-radius: 0;
    font-family: var(--sans);
    font-size: 17px;
    font-weight: 600;
    color: var(--dark);
    background: var(--white);
    outline: none;
    transition: border-color var(--ease);
}
.sp-atc .qty:focus { border-color: var(--sage-dark); }
/* Forcer la couleur verte — écrase les styles WooCommerce par défaut */
.sp-atc .single_add_to_cart_button,
.sp-atc .single_add_to_cart_button.button,
.sp-atc .single_add_to_cart_button.alt,
.sp-atc button.single_add_to_cart_button,
.sp-atc input.single_add_to_cart_button,
.woocommerce .sp-atc .button,
.woocommerce .sp-atc .button.alt {
    flex: 1 !important;
    height: 54px !important;
    padding: 0 28px !important;
    border: none !important;
    border-radius: 0 !important;
    background: var(--sage) !important;
    background-color: var(--sage) !important;
    color: var(--dark) !important;
    font-family: var(--sans) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background var(--ease), color var(--ease), transform 0.2s !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    box-shadow: none !important;
    text-shadow: none !important;
}
.sp-atc .single_add_to_cart_button:hover,
.sp-atc .single_add_to_cart_button.button:hover,
.woocommerce .sp-atc .button:hover {
    background: var(--sage-dark) !important;
    background-color: var(--sage-dark) !important;
    color: var(--white) !important;
    transform: translateY(-2px) !important;
}
.sp-atc .single_add_to_cart_button:disabled,
.sp-atc .single_add_to_cart_button.button:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
    transform: none !important;
}

/* Lien composition */
.sp-more-link {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 12px;
    font-weight: 500;
    color: var(--mid);
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    text-decoration: underline;
    text-decoration-color: transparent;
    transition: color var(--ease), text-decoration-color var(--ease);
    margin-bottom: 4px;
}
.sp-more-link:hover { color: var(--sage-dark); text-decoration-color: var(--sage-dark); }

/* Garanties */
.sp-trust {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border: 1px solid var(--border);
    margin-bottom: 20px;
}
.sp-trust__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    padding: 20px 12px;
    border-right: 1px solid var(--border);
    transition: background var(--ease);
}
.sp-trust__item:last-child { border-right: none; }
.sp-trust__item:hover { background: var(--cream); }
.sp-trust__item > svg { flex-shrink: 0; color: var(--sage-dark); }
.sp-trust__item strong { display: block; font-size: 13px; font-weight: 600; color: var(--dark); line-height: 1.3; }
.sp-trust__item span { font-size: 12px; color: var(--mid); }

/* Méta */
.sp-meta { font-size: 12px; color: var(--mid); display: flex; flex-direction: column; gap: 4px; }
.sp-meta span { font-weight: 600; color: var(--dark); }
.sp-meta a { color: var(--mid); transition: color var(--ease); }
.sp-meta a:hover { color: var(--sage-dark); }

/* ── TABS PLEINE LARGEUR ── */
.sp-tabs-section {
    background: var(--white);
    border-top: 1px solid var(--border);
}
.sp-tabs__nav {
    display: flex;
    border-bottom: 1px solid var(--border);
    gap: 0;
}
.sp-tab-btn {
    padding: 20px 32px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--mid);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    cursor: pointer;
    transition: color var(--ease), border-color var(--ease);
}
.sp-tab-btn:hover { color: var(--dark); }
.sp-tab-btn.active { color: var(--dark); border-bottom-color: var(--sage-dark); }
.sp-tab-panel { display: none; }
.sp-tab-panel.active { display: block; }

/* Panel Description */
.sp-desc-grid {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 64px;
    padding: 60px 0;
    align-items: start;
}
.sp-desc-text {
    font-size: 16px;
    color: var(--mid);
    line-height: 2;
}
.sp-desc-text p + p { margin-top: 18px; }
.sp-desc-text h2, .sp-desc-text h3 {
    font-family: var(--serif);
    font-size: 24px;
    font-weight: 400;
    color: var(--dark);
    margin-bottom: 14px;
    margin-top: 32px;
}
.sp-desc-aside { display: flex; flex-direction: column; gap: 16px; }
.sp-desc-card {
    padding: 24px;
    background: var(--cream);
    border: 1px solid var(--border);
}
.sp-desc-card__icon {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sage);
    border-radius: 50%;
    color: var(--dark);
    margin-bottom: 14px;
}
.sp-desc-card h4 {
    font-family: var(--serif);
    font-size: 18px;
    font-weight: 400;
    color: var(--dark);
    margin-bottom: 8px;
}
.sp-desc-card p { font-size: 13px; color: var(--mid); line-height: 1.7; }

/* Vidéo format TikTok */
.sp-tiktok-video {
    display: block;
    text-decoration: none;
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid var(--border);
    transition: box-shadow var(--ease);
}
.sp-tiktok-video:hover { box-shadow: 0 8px 30px rgba(0,0,0,0.12); }
.sp-tiktok-video__thumb {
    position: relative;
    width: 100%;
    aspect-ratio: 9 / 14;
    background: #111;
    overflow: hidden;
}
.sp-tiktok-video__placeholder {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
}
.sp-tiktok-video__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.25);
}
.sp-tiktok-video__play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.sp-tiktok-video__play svg {
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.8);
    border-radius: 50%;
    padding: 16px;
    width: 64px;
    height: 64px;
    color: #fff;
    backdrop-filter: blur(4px);
    transition: transform var(--ease), background var(--ease);
}
.sp-tiktok-video:hover .sp-tiktok-video__play svg {
    transform: scale(1.1);
    background: rgba(255,255,255,0.25);
}
.sp-tiktok-video__bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 14px;
    background: var(--light);
    font-family: var(--sans);
    font-size: 12px;
    color: var(--mid);
    border-top: 1px solid var(--border);
}
.sp-tiktok-video__bar svg { color: var(--dark); flex-shrink: 0; }

/* Panel Composition */
.sp-attrs-wrap {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 60px;
    padding: 60px 0;
    align-items: start;
}
.sp-attrs-table { width: 100%; border-collapse: collapse; }
.sp-attrs-table thead th {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--mid);
    padding: 12px 16px;
    border-bottom: 2px solid var(--border);
    text-align: left;
}
.sp-attrs-table tbody td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    font-size: 14px;
    vertical-align: top;
}
.sp-attrs-table__label { font-weight: 600; color: var(--dark); width: 200px; }
.sp-attrs-table tbody td:last-child { color: var(--mid); }
.sp-attrs-aside {
    background: var(--sage);
    padding: 28px;
    border-radius: 2px;
}
.sp-attrs-aside__title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dark);
    margin-bottom: 18px;
}
.sp-attrs-aside ul { display: flex; flex-direction: column; gap: 10px; }
.sp-attrs-aside li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    font-weight: 500;
    color: var(--dark);
}
.sp-attrs-aside li svg { flex-shrink: 0; color: rgba(26,26,26,0.6); }

/* Panel Avis */
.sp-reviews-wrap { padding: 48px 0; max-width: 800px; }

/* ── PRODUITS ASSOCIÉS ── */
.sp-related { padding: 80px 0; background: var(--cream); border-top: 1px solid var(--border); }
.sp-related__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
    .sp-layout__inner { grid-template-columns: 1fr; gap: 40px; }
    .sp-gallery-col { position: static; }
    .sp-gallery-wrap { grid-template-columns: 64px 1fr; }
    .sp-main-visual { aspect-ratio: 4/3; }
    .sp-desc-grid { grid-template-columns: 1fr; }
    .sp-attrs-wrap { grid-template-columns: 1fr; }
    .sp-related__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .sp-breadcrumb {
        display: none;
    }
    .sp-page { padding-top: var(--header-h); }
    .sp-layout { padding: 20px 0 60px; }
    .sp-gallery-wrap { grid-template-columns: 1fr; }
    .sp-main-visual { aspect-ratio: 4 / 5; }
    .sp-thumbstrip { flex-direction: row; overflow-x: auto; gap: 8px; }
    .sp-thumb { width: 64px; height: 64px; flex-shrink: 0; }
    .sp-title { font-size: 28px; }
    .sp-price { font-size: 24px; }
    .sp-features { grid-template-columns: repeat(2, 1fr); }
    .sp-atc form.cart {
        flex-direction: row;
        gap: 10px;
        align-items: stretch;
    }
    .sp-atc .quantity {
        width: 72px;
        flex: 0 0 72px;
    }
    .sp-atc .qty {
        width: 72px;
        min-width: 72px;
        height: 52px;
    }
    .sp-atc .single_add_to_cart_button,
    .sp-atc .single_add_to_cart_button.button,
    .sp-atc .single_add_to_cart_button.alt,
    .sp-atc button.single_add_to_cart_button,
    .woocommerce .sp-atc .button,
    .woocommerce .sp-atc .button.alt {
        min-width: 0 !important;
        height: 52px !important;
        padding: 0 18px !important;
        font-size: 11px !important;
        letter-spacing: 1.4px !important;
        white-space: nowrap !important;
    }
    .sp-tabs__nav { overflow-x: auto; }
    .sp-tab-btn { padding: 16px 20px; white-space: nowrap; }
    .sp-related__grid { grid-template-columns: 1fr 1fr; gap: 14px; }
}

@media (max-width: 430px) {
    .header-logo__text { font-size: 20px; letter-spacing: 2.4px; }
    .header-main__inner { gap: 12px; }
    .hero-slide__title { font-size: 39px; }
    .hero-slide__sub { max-width: 270px; }
    .hero-slide__cta .btn {
        width: min(228px, 100%);
        justify-content: center;
    }
    .products-grid,
    .sp-related__grid {
        grid-template-columns: 1fr;
    }
    .product-card__name,
    .shop-card__name {
        font-size: 18px;
    }
    .sp-layout { padding-top: 28px; }
    .sp-main-visual { aspect-ratio: 1 / 1.15; }
    .sp-title {
        font-size: 25px;
        line-height: 1.12;
    }
    .sp-short-desc {
        font-size: 14px;
        line-height: 1.75;
    }
    .sp-feature { min-height: 128px; }
    .sp-atc form.cart {
        position: sticky;
        bottom: 12px;
        z-index: 40;
        padding: 10px;
        background: rgba(255,255,255,0.94);
        border: 1px solid var(--border);
        box-shadow: 0 14px 34px rgba(0,0,0,0.12);
        backdrop-filter: blur(12px);
    }
}

@media (max-width: 1024px) {
    .topbar__inner {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        gap: 10px;
        min-width: 0;
    }
    .topbar__currency {
        position: relative !important;
        inset: auto !important;
        transform: none !important;
        margin-left: auto;
        z-index: 3;
        flex-shrink: 0;
        display: inline-flex !important;
        align-items: center;
        justify-content: flex-end;
        visibility: visible;
        opacity: 1;
    }
    .topbar__currency .currency-btn {
        display: inline-flex;
        align-items: center;
        color: rgba(255,255,255,0.9);
        line-height: 1;
    }
    .topbar__currency .currency-btn.active {
        color: var(--dark);
    }
    .topbar__currency .topbar__sep {
        color: rgba(255,255,255,0.55);
    }
    .topbar__link {
        flex: 0 1 auto;
        max-width: calc(100% - 118px);
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}

@media (max-width: 430px) {
    .topbar__link {
        max-width: calc(100% - 104px);
    }
    .topbar__currency {
        gap: 3px;
    }
    .topbar__currency .currency-btn {
        font-size: 10px;
        letter-spacing: 1px;
        padding: 2px 5px;
    }
}

@media (max-width: 768px) {
    .topbar__inner {
        position: relative;
    }
    .topbar__link {
        max-width: calc(100% - 112px);
        padding-right: 8px;
    }
    .topbar__currency {
        position: fixed !important;
        top: 9px;
        right: 20px !important;
        left: auto !important;
        transform: none !important;
        margin-left: 0;
        width: 88px;
        display: inline-flex !important;
        justify-content: flex-end;
        pointer-events: auto;
        z-index: 2001;
    }
    .hero-slide__inner,
    .hero-slide__sub,
    .hero-slide__title {
        max-width: 100%;
        min-width: 0;
    }
    .hero-slide__sub {
        overflow-wrap: anywhere;
    }
    .hero-prev,
    .hero-next {
        display: none;
    }
    html,
    body {
        overflow-x: hidden;
    }
    .sp-info-col {
        min-width: 0;
    }
    .sp-title,
    .sp-short-desc {
        overflow-wrap: anywhere;
    }
}

html[dir="rtl"] body {
    direction: rtl;
    text-align: right;
}
html[dir="rtl"] .header-main__inner,
html[dir="rtl"] .topbar__inner,
html[dir="rtl"] .header-actions,
html[dir="rtl"] .footer-bottom,
html[dir="rtl"] .product-card__footer,
html[dir="rtl"] .shop-card__bottom,
html[dir="rtl"] .contact-info__item,
html[dir="rtl"] .trust-item,
html[dir="rtl"] .sp-trust__item,
html[dir="rtl"] .co-order-line,
html[dir="rtl"] .bglow-mini-cart__item {
    direction: rtl;
}
html[dir="rtl"] .hero-slide__inner,
html[dir="rtl"] .brand-statement,
html[dir="rtl"] .section-header,
html[dir="rtl"] .history-hero__content,
html[dir="rtl"] .contact-hero,
html[dir="rtl"] .shop-hero__content,
html[dir="rtl"] .cart-hero,
html[dir="rtl"] .co-hero__left {
    text-align: right;
}
html[dir="rtl"] .hero-slide__cta,
html[dir="rtl"] .contact-faq__link,
html[dir="rtl"] .shop-card__btn,
html[dir="rtl"] .bglow-mini-cart__actions {
    direction: rtl;
}
html[dir="rtl"] .topbar__currency,
html[dir="rtl"] .currency-btn,
html[dir="rtl"] .woocommerce-Price-amount,
html[dir="rtl"] .bglow-price-secondary,
html[dir="rtl"] .cart-badge,
html[dir="rtl"] .footer-copy {
    direction: ltr;
}
html[dir="rtl"] .header-nav__list,
html[dir="rtl"] .mobile-menu__list,
html[dir="rtl"] .footer-nav {
    direction: rtl;
}
html[dir="rtl"] .header-logo__text,
html[dir="rtl"] .footer-logo span {
    direction: ltr;
}
