/*
Theme Name: Bola Little Panda
Theme URI: https://www.bolalittlepanda.com
Author: Bola Little Panda
Description: Thème sur mesure pour la boutique Bola Little Panda
Version: 1.0.0
WC requires at least: 7.0
WC tested up to: 9.0
Text Domain: bola-little-panda
Domain Path: /languages
*/

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

        :root {
            --primary-dark: #2c2018;
            --primary-accent: #b08060;
            --bg-main: #faf8f4;
            --text-dark: #5a4a3a;
            --text-light: #6a5548;
            --border-light: #e8dfd6;

            /* Collection colors */
            --authentik-bg: #f0ece6;
            --authentik-accent: #c0c0c0;
            --antik-bg: #1e1a16;
            --antik-text: #f0e8dc;
            --antik-accent: #b08060;
            --unik-bg: #faf5fc;
            --unik-accent1: #9a6aad;
            --unik-accent2: #c49ad4;
        }

        html, body {
            height: 100%;
            font-family: 'DM Sans', sans-serif;
            color: var(--text-dark);
            background-color: var(--bg-main);
            line-height: 1.6;
        }

        a {
            text-decoration: none;
            color: inherit;
            transition: all 0.3s ease;
        }

        h1, h2, h3 {
            font-family: 'Cormorant Garamond', serif;
            font-weight: 600;
        }

        h1 {
            font-size: 3.5rem;
            line-height: 1.2;
        }

        h2 {
            font-size: 2.5rem;
            margin-bottom: 1.5rem;
        }

        h3 {
            font-size: 1.8rem;
            margin-bottom: 1rem;
        }

        button {
            font-family: 'Montserrat', sans-serif;
            cursor: pointer;
            border: none;
            transition: all 0.3s ease;
        }

        /* Header */
        header {
            position: sticky;
            top: 0;
            background: white;
            border-bottom: 1px solid var(--border-light);
            z-index: 1000;
            padding: 1rem 0;
        }

        .header-container {
            max-width: 1400px;
            margin: 0 auto;
            padding: 0 2rem;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .logo img {
            height: 50px;
            display: block;
        }

        nav {
            display: flex;
            gap: 2.5rem;
            font-family: 'Montserrat', sans-serif;
            font-size: 0.95rem;
            font-weight: 500;
        }

        nav a {
            color: var(--text-dark);
            position: relative;
        }

        nav a:hover {
            color: var(--primary-accent);
        }

        nav a::after {
            content: '';
            position: absolute;
            bottom: -5px;
            left: 0;
            width: 0;
            height: 2px;
            background: var(--primary-accent);
            transition: width 0.3s ease;
        }

        nav a:hover::after {
            width: 100%;
        }

        .header-actions {
            display: flex;
            gap: 1.5rem;
            align-items: center;
        }

        .icon-btn {
            background: none;
            font-size: 1.3rem;
            color: var(--text-dark);
        }

        .icon-btn:hover {
            color: var(--primary-accent);
        }

        /* Main content */
        main {
            min-height: calc(100vh - 200px);
            opacity: 1;
        }

        @keyframes fadeIn {
            from { opacity: 0; }
            to { opacity: 1; }
        }

        .page {
            display: none;
        }

        .page.active {
            display: block;
        }

        /* Hero sections */
        .hero-split {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 3rem;
            align-items: center;
            padding: 4rem 2rem;
            max-width: 1400px;
            margin: 0 auto;
        }

        .hero-text h1 {
            margin-bottom: 1.5rem;
            color: var(--primary-dark);
        }

        .hero-text p {
            font-size: 1.1rem;
            color: var(--text-light);
            margin-bottom: 1rem;
        }

        .hero-image {
            width: 100%;
            height: auto;
            border-radius: 4px;
            object-fit: cover;
        }

        /* USP Bar */
        .usp-bar {
            background: var(--primary-dark);
            color: white;
            padding: 2rem;
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 2rem;
            text-align: center;
            max-width: 1400px;
            margin: 0 auto;
        }

        .usp-item {
            font-size: 0.95rem;
            line-height: 1.5;
        }

        .usp-item strong {
            display: block;
            font-weight: 700;
            margin-bottom: 0.5rem;
        }

        /* Collections section */
        .section {
            padding: 4rem 2rem;
            max-width: 1400px;
            margin: 0 auto;
        }

        .section-title {
            text-align: center;
            margin-bottom: 3rem;
            color: var(--primary-dark);
        }

        .collections-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2rem;
            margin-bottom: 3rem;
        }

        .collection-card {
            aspect-ratio: 4/3;
            border-radius: 4px;
            overflow: hidden;
            cursor: pointer;
            position: relative;
            group: hover;
            transition: transform 0.3s ease;
        }

        .collection-card:hover {
            transform: translateY(-8px);
        }

        .collection-card-image {
            width: 100%;
            height: 100%;
            object-fit: cover;
            position: absolute;
            top: 0;
            left: 0;
        }

        .collection-card-overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3);
            display: flex;
            flex-direction: column;
            justify-content: flex-end;
            padding: 2rem;
            color: white;
            transition: background 0.3s ease;
        }

        .collection-card:hover .collection-card-overlay {
            background: rgba(0, 0, 0, 0.5);
        }

        .collection-card h3 {
            color: white;
            margin-bottom: 0.5rem;
            font-size: 1.8rem;
        }

        .collection-card p {
            color: rgba(255, 255, 255, 0.9);
            font-size: 0.95rem;
        }

        /* Products grid */
        .products-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2rem;
            margin-top: 3rem;
        }

        .product-card {
            border-radius: 4px;
            overflow: hidden;
            cursor: pointer;
            transition: transform 0.3s ease;
        }

        .product-card:hover {
            transform: translateY(-6px);
        }

        .product-image-container {
            aspect-ratio: 1;
            background: var(--bg-main);
            overflow: hidden;
            position: relative;
        }

        .product-image {
            width: 100%;
            height: 100%;
            object-fit: contain;
            padding: 1rem;
        }

        .product-info {
            padding: 1.5rem;
            background: white;
            border: 1px solid var(--border-light);
            border-top: none;
        }

        .product-collection {
            font-family: 'Montserrat', sans-serif;
            font-size: 0.8rem;
            font-weight: 600;
            text-transform: uppercase;
            color: var(--primary-accent);
            margin-bottom: 0.5rem;
        }

        .product-name {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.4rem;
            color: var(--primary-dark);
            margin-bottom: 0.5rem;
        }

        .product-price {
            font-family: 'Montserrat', sans-serif;
            font-weight: 600;
            color: var(--primary-accent);
            font-size: 1.1rem;
        }

        /* Feature strip */
        .feature-strip {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 2rem;
            padding: 3rem 2rem;
            max-width: 1400px;
            margin: 0 auto;
            background: var(--bg-main);
        }

        .feature {
            text-align: center;
        }

        .feature-icon {
            font-size: 2.5rem;
            margin-bottom: 1rem;
        }

        .feature h4 {
            font-family: 'Montserrat', sans-serif;
            font-weight: 600;
            margin-bottom: 0.5rem;
            font-size: 1rem;
        }

        .feature p {
            font-size: 0.9rem;
            color: var(--text-light);
        }

        /* Stories section */
        .stories-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 3rem;
            align-items: center;
            padding: 3rem 2rem;
            max-width: 1400px;
            margin: 0 auto;
        }

        .stories-grid.reverse {
            grid-template-columns: 1fr 1fr;
        }

        .stories-grid.reverse > *:first-child {
            order: 2;
        }

        .stories-grid.reverse > *:last-child {
            order: 1;
        }

        .story-text h3 {
            color: var(--primary-dark);
        }

        .story-text p {
            margin-bottom: 1rem;
            color: var(--text-light);
        }

        .story-image {
            width: 100%;
            border-radius: 4px;
            object-fit: cover;
        }

        /* Testimonials */
        .testimonials {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2rem;
            margin-top: 3rem;
        }

        .testimonial {
            background: white;
            padding: 2rem;
            border: 1px solid var(--border-light);
            border-radius: 4px;
        }

        .testimonial p {
            font-style: italic;
            color: var(--text-dark);
            margin-bottom: 1rem;
        }

        .testimonial-author {
            font-family: 'Montserrat', sans-serif;
            font-weight: 600;
            font-size: 0.95rem;
            color: var(--primary-accent);
        }

        .testimonial-stars {
            color: var(--primary-accent);
            margin-bottom: 1rem;
            font-size: 1rem;
        }

        /* Assembly section */
        .assembly {
            background: var(--primary-dark);
            color: white;
            padding: 4rem 2rem;
            margin-top: 3rem;
        }

        .assembly-container {
            max-width: 1400px;
            margin: 0 auto;
            text-align: center;
        }

        .assembly-container h2 {
            color: white;
            margin-bottom: 3rem;
        }

        .assembly-steps {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2rem;
        }

        .assembly-step {
            text-align: center;
        }

        .assembly-step-number {
            font-family: 'Cormorant Garamond', serif;
            font-size: 3rem;
            font-weight: 700;
            color: var(--primary-accent);
            margin-bottom: 1rem;
        }

        .assembly-step p {
            font-size: 1.1rem;
            line-height: 1.6;
        }

        /* Shop page */
        .shop-hero {
            background: var(--primary-dark);
            color: white;
            padding: 3rem 2rem;
            text-align: center;
        }

        .shop-hero h1 {
            color: white;
        }

        .filters {
            display: flex;
            gap: 1rem;
            justify-content: center;
            padding: 2rem;
            flex-wrap: wrap;
        }

        .filter-btn {
            font-family: 'Montserrat', sans-serif;
            padding: 0.8rem 2rem;
            border: 2px solid var(--border-light);
            background: transparent;
            color: var(--text-dark);
            border-radius: 4px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
        }

        .filter-btn.active {
            background: var(--primary-dark);
            color: white;
            border-color: var(--primary-dark);
        }

        .filter-btn:hover {
            border-color: var(--primary-accent);
        }

        /* Collection-specific styles */
        .authentik-hero {
            background: var(--authentik-bg);
        }

        .authentik-hero h1 {
            color: var(--primary-dark);
        }

        .antik-hero {
            background: var(--antik-bg);
        }

        .antik-hero h1 {
            color: var(--antik-text);
        }

        .antik-hero p {
            color: var(--antik-text);
        }

        .unik-hero {
            background: var(--unik-bg);
        }

        .unik-hero h1 {
            color: var(--primary-dark);
        }

        /* Product detail */
        .product-detail {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 3rem;
            padding: 3rem 2rem;
            max-width: 1400px;
            margin: 0 auto;
        }

        .product-detail-image {
            aspect-ratio: 1;
            background: var(--bg-main);
            border-radius: 4px;
            overflow: hidden;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .product-detail-image img {
            width: 100%;
            height: 100%;
            object-fit: contain;
            padding: 2rem;
        }

        .product-detail-info h1 {
            color: var(--primary-dark);
            margin-bottom: 1rem;
        }

        .product-detail-collection {
            font-family: 'Montserrat', sans-serif;
            font-size: 0.85rem;
            text-transform: uppercase;
            font-weight: 700;
            color: var(--primary-accent);
            margin-bottom: 1rem;
            letter-spacing: 1px;
        }

        .product-detail-price {
            font-family: 'Montserrat', sans-serif;
            font-size: 1.8rem;
            font-weight: 700;
            color: var(--primary-accent);
            margin-bottom: 2rem;
        }

        .product-detail-description {
            color: var(--text-light);
            margin-bottom: 2rem;
            line-height: 1.8;
        }

        .product-features {
            margin-bottom: 2rem;
        }

        .product-features h4 {
            font-family: 'Montserrat', sans-serif;
            font-weight: 600;
            margin-bottom: 1rem;
            color: var(--primary-dark);
        }

        .product-features ul {
            list-style: none;
        }

        .product-features li {
            padding: 0.5rem 0;
            color: var(--text-light);
            padding-left: 1.5rem;
            position: relative;
        }

        .product-features li:before {
            content: '✓';
            position: absolute;
            left: 0;
            color: var(--primary-accent);
            font-weight: bold;
        }

        /* === DÉCLINAISONS CHAÎNE === */
        .product-variants {
            margin: 24px 0 28px;
        }
        .product-variants-label {
            font-family: 'Montserrat', sans-serif;
            font-size: 9px;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: #5a4a3a;
            margin-bottom: 14px;
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .product-variants-label span {
            color: #b08060;
            font-weight: 600;
        }
        .variant-options {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }
        .variant-option {
            display: flex;
            align-items: center;
            gap: 14px;
            padding: 14px 16px;
            border: 1.5px solid #d8cfc4;
            background: #fff;
            cursor: pointer;
            transition: all 0.2s;
            position: relative;
        }
        .variant-option:hover {
            border-color: #b08060;
        }
        .variant-option.selected {
            border-color: #2c2018;
            background: #faf8f4;
        }
        .variant-option.selected::after {
            content: '✓';
            position: absolute;
            right: 16px;
            font-size: 13px;
            color: #2c2018;
        }
        .variant-icon {
            width: 36px;
            height: 36px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }
        .variant-info { flex: 1; }
        .variant-name {
            font-family: 'Cormorant Garamond', serif;
            font-size: 16px;
            color: #2c2018;
            margin-bottom: 2px;
        }
        .variant-desc {
            font-family: 'DM Sans', sans-serif;
            font-size: 11px;
            color: #8a7a6a;
        }
        .variant-price {
            font-family: 'Montserrat', sans-serif;
            font-size: 10px;
            color: #b08060;
            letter-spacing: 1px;
        }

        .add-to-cart {
            padding: 1.2rem 2rem;
            background: var(--primary-dark);
            color: white;
            font-family: 'Montserrat', sans-serif;
            font-weight: 700;
            font-size: 1rem;
            border-radius: 0;
            width: 100%;
            margin-bottom: 2rem;
        }

        .add-to-cart:hover {
            background: var(--primary-accent);
        }

        .breadcrumb {
            max-width: 1400px;
            margin: 0 auto;
            padding: 1.5rem 2rem 0;
            font-family: 'Montserrat', sans-serif;
            font-size: 0.9rem;
            color: var(--text-light);
        }

        .breadcrumb a {
            color: var(--primary-accent);
            cursor: pointer;
        }

        .breadcrumb a:hover {
            text-decoration: underline;
        }

        /* Related products */
        .related-section {
            padding: 3rem 2rem;
            max-width: 1400px;
            margin: 0 auto;
        }

        .related-section h3 {
            margin-bottom: 2rem;
            color: var(--primary-dark);
        }

        /* Footer */
        footer {
            background: var(--primary-dark);
            color: white;
            padding: 3rem 2rem;
            margin-top: 4rem;
        }

        .footer-container {
            max-width: 1400px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 2rem;
        }

        .footer-section h4 {
            font-family: 'Montserrat', sans-serif;
            margin-bottom: 1.5rem;
            font-weight: 700;
        }

        .footer-section ul {
            list-style: none;
        }

        .footer-section ul li {
            margin-bottom: 0.8rem;
        }

        .footer-section a {
            color: rgba(255, 255, 255, 0.8);
            cursor: pointer;
        }

        .footer-section a:hover {
            color: var(--primary-accent);
        }

        .footer-bottom {
            border-top: 1px solid rgba(255, 255, 255, 0.2);
            margin-top: 2rem;
            padding-top: 2rem;
            text-align: center;
            font-size: 0.9rem;
            color: rgba(255, 255, 255, 0.7);
        }

        /* Cross-sell collections */
        .cross-sell {
            padding: 3rem 2rem;
            max-width: 1400px;
            margin: 0 auto;
        }

        .cross-sell h3 {
            margin-bottom: 2rem;
            color: var(--primary-dark);
            text-align: center;
        }

        .cross-sell-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 2rem;
        }

        .cross-sell-card {
            aspect-ratio: 16/9;
            border-radius: 4px;
            overflow: hidden;
            cursor: pointer;
            position: relative;
            transition: transform 0.3s ease;
        }

        .cross-sell-card:hover {
            transform: translateY(-8px);
        }

        .cross-sell-image {
            width: 100%;
            height: 100%;
            object-fit: cover;
            position: absolute;
            top: 0;
            left: 0;
        }

        .cross-sell-overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3);
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            font-size: 1.8rem;
            font-weight: 700;
            transition: background 0.3s ease;
        }

        .cross-sell-card:hover .cross-sell-overlay {
            background: rgba(0, 0, 0, 0.5);
        }

        /* ===== EDITORIAL NATUREL HOMEPAGE ===== */
        .en-hero {
            display: grid; grid-template-columns: 1fr 1fr;
            min-height: calc(100vh - 80px);
        }
        .en-hero-left {
            background: #e8ddd0;
            display: flex; flex-direction: column; justify-content: center;
            padding: 80px 72px; position: relative; overflow: hidden;
        }
        .en-hero-left::before {
            content: ''; position: absolute; top: -80px; left: -80px;
            width: 350px; height: 350px; border-radius: 50%;
            background: rgba(180,140,100,0.1);
        }
        .en-tag {
            font-family: 'Montserrat', sans-serif; font-size: 10px;
            letter-spacing: 4px; text-transform: uppercase;
            color: #b08060; margin-bottom: 28px; position: relative; z-index: 1;
        }
        .en-headline {
            font-family: 'Cormorant Garamond', serif;
            font-size: 62px; font-weight: 300; line-height: 1.08;
            color: #2c2018; margin-bottom: 28px; position: relative; z-index: 1;
        }
        .en-headline em { font-style: italic; color: #8b6040; }
        .en-sub {
            font-size: 15px; line-height: 1.75; color: #6a5548;
            max-width: 400px; margin-bottom: 40px; position: relative; z-index: 1;
        }
        .en-ctas { display: flex; gap: 20px; align-items: center; position: relative; z-index: 1; }
        .en-cta-primary {
            display: inline-flex; align-items: center; gap: 12px;
            background: #2c2018; color: #f5ede3;
            font-family: 'Montserrat', sans-serif; font-size: 11px;
            letter-spacing: 2px; text-transform: uppercase; padding: 16px 32px;
        }
        .en-cta-primary:hover { background: #3d3020; }
        .en-cta-secondary {
            font-family: 'Montserrat', sans-serif; font-size: 11px;
            letter-spacing: 2px; text-transform: uppercase;
            color: #8b6040; border-bottom: 1px solid #8b6040; padding-bottom: 2px;
        }
        .en-hero-right { position: relative; overflow: hidden; background: #d8c8b8; }
        .en-hero-right img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
        .en-badge {
            position: absolute; bottom: 40px; left: -20px;
            background: #fff; padding: 22px 28px;
            box-shadow: 0 12px 40px rgba(0,0,0,0.1);
        }
        .en-badge-num { font-family: 'Cormorant Garamond', serif; font-size: 38px; font-weight: 300; color: #2c2018; line-height: 1; }
        .en-badge-text { font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 1px; color: #8b6040; margin-top: 4px; }

        .en-usp {
            background: #2c2018; display: flex; justify-content: center;
            gap: 80px; padding: 22px 40px;
        }
        .en-usp-item {
            font-family: 'Montserrat', sans-serif; font-size: 10px;
            letter-spacing: 2px; text-transform: uppercase;
            color: rgba(255,255,255,0.6); display: flex; align-items: center; gap: 10px;
        }
        .en-usp-dot { width: 5px; height: 5px; border-radius: 50%; background: #b08060; }

        .en-section { padding: 100px 60px; }
        .en-section-header { text-align: center; margin-bottom: 60px; }
        .en-section-tag {
            font-family: 'Montserrat', sans-serif; font-size: 10px;
            letter-spacing: 4px; text-transform: uppercase;
            color: #b08060; margin-bottom: 16px;
        }
        .en-section-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: 48px; font-weight: 300; color: #2c2018;
        }
        .en-section-title em { font-style: italic; }

        .en-collections-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
        .en-col-card { position: relative; overflow: hidden; cursor: pointer; background: #f0ebe2; }
        .en-col-card:hover .en-col-img img { transform: scale(1.05); }
        .en-col-img { overflow: hidden; aspect-ratio: 3/4; position: relative; }
        .en-col-img img {
            width: 100%; height: 100%; object-fit: contain;
            background: #f5f2ec; padding: 30px; transition: transform 0.6s ease;
        }
        .en-col-overlay {
            position: absolute; bottom: 0; left: 0; right: 0;
            background: linear-gradient(to top, rgba(44,32,24,0.85) 0%, transparent 100%);
            padding: 40px 28px 28px;
        }
        .en-col-name { font-family: 'Cormorant Garamond', serif; font-size: 32px; color: #fff; margin-bottom: 6px; }
        .en-col-sub { font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.6); margin-bottom: 16px; }
        .en-col-cta { font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: #e8c49a; }

        .en-products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
        .en-p-card { background: #fff; overflow: hidden; cursor: pointer; transition: box-shadow 0.3s, transform 0.3s; }
        .en-p-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.08); }
        .en-p-img { overflow: hidden; aspect-ratio: 1; background: #f8f5f0; position: relative; }
        .en-p-img img { width: 100%; height: 100%; object-fit: contain; padding: 16px; transition: transform 0.5s ease; }
        .en-p-card:hover .en-p-img img { transform: scale(1.06); }
        .en-p-badge {
            position: absolute; top: 12px; left: 12px;
            background: #2c2018; color: #f5ede3;
            font-family: 'Montserrat', sans-serif; font-size: 8px;
            letter-spacing: 2px; text-transform: uppercase; padding: 5px 12px;
        }
        .en-p-info { padding: 18px 20px 22px; }
        .en-p-col { font-family: 'Montserrat', sans-serif; font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: #b08060; margin-bottom: 6px; }
        .en-p-name { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 400; color: #2c2018; margin-bottom: 8px; }
        .en-p-price { font-size: 15px; color: #5a4a3a; }

        .en-story { display: grid; grid-template-columns: 1fr 1fr; min-height: 550px; }
        .en-story-img { overflow: hidden; }
        .en-story-img img { width: 100%; height: 100%; object-fit: cover; }
        .en-story-content { background: #e8ddd0; display: flex; flex-direction: column; justify-content: center; padding: 80px; }
        .en-story-content h2 { font-family: 'Cormorant Garamond', serif; font-size: 48px; font-weight: 300; line-height: 1.15; color: #2c2018; margin-bottom: 28px; }
        .en-story-content h2 em { font-style: italic; color: #8b6040; }
        .en-story-content p { font-size: 15px; line-height: 1.8; color: #6a5548; margin-bottom: 16px; }
        .en-story-link { font-family: 'Montserrat', sans-serif; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: #2c2018; margin-top: 20px; display: inline-flex; align-items: center; gap: 12px; }

        .en-reviews { padding: 100px 60px; background: #faf8f4; }
        .en-reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
        .en-review { background: #f0ebe2; padding: 36px; border-top: 2px solid #b08060; }
        .en-review-stars { color: #b08060; font-size: 13px; margin-bottom: 20px; letter-spacing: 2px; }
        .en-review-text { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-style: italic; color: #3a2e22; line-height: 1.6; margin-bottom: 24px; }
        .en-review-author { font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: #b08060; }

        .en-assembler { background: #2c2018; padding: 100px 60px; text-align: center; }
        .en-assembler-title { font-family: 'Cormorant Garamond', serif; font-size: 52px; font-weight: 300; color: #f5ede3; margin: 16px 0 20px; }
        .en-assembler-title em { font-style: italic; color: #e8c49a; }
        .en-assembler-desc { font-size: 15px; color: rgba(245,237,227,0.5); max-width: 520px; margin: 0 auto 40px; line-height: 1.7; }
        .en-steps { display: flex; justify-content: center; gap: 60px; margin-bottom: 50px; }
        .en-step-num { font-family: 'Cormorant Garamond', serif; font-size: 48px; font-weight: 300; color: #b08060; margin-bottom: 8px; }
        .en-step-label { font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(245,237,227,0.55); }
        .en-assembler-cta {
            display: inline-flex; align-items: center; gap: 12px;
            border: 1.5px solid #b08060; color: #e8c49a;
            font-family: 'Montserrat', sans-serif; font-size: 11px;
            letter-spacing: 2px; text-transform: uppercase; padding: 16px 36px;
        }
        .en-assembler-cta:hover { background: #b08060; color: #2c2018; }

    
/* === V2 HOMEPAGE CSS (scoped to #accueil) === */

  * { margin: 0; padding: 0; box-sizing: border-box; }
  body { font-family: 'DM Sans', sans-serif; background: #faf8f4; color: #2c2018; }
  a { text-decoration: none; color: inherit; }
  img { display: block; max-width: 100%; }

  

  /* ===== HEADER ===== */
    #accueil .header {
    position: fixed;
    top: 36px; left: 0; right: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 60px;
    background: rgba(250,248,244,0.96);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(0,0,0,0.05);
    transition: all 0.3s;
  }
    #accueil .nav { display: flex; gap: 36px; }
    #accueil .nav a {
    font-family: 'Montserrat', sans-serif; font-size: 10px;
    letter-spacing: 2.5px; text-transform: uppercase; color: #5a4a3a;
    transition: color 0.2s;
  }
    #accueil .nav a:hover { color: #2c2018; }
    #accueil .logo-wrap { text-align: center; position: absolute; left: 50%; transform: translateX(-50%); }
    #accueil .logo-img { height: 42px; }
    #accueil .header-icons { display: flex; gap: 20px; align-items: center; }
    #accueil .header-icons svg { width: 20px; height: 20px; stroke: #5a4a3a; fill: none; stroke-width: 1.5; cursor: pointer; }

  /* ===== HERO – Split Screen ===== */
    #accueil .hero {
    margin-top: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 85vh;
  }
    #accueil .hero-left {
    background: #e8ddd0;
    position: relative;
    overflow: hidden;
  }
    #accueil .hero-left-inner {
    position: absolute;
    top: 38%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    width: 85%;
    max-width: 480px;
  }
    #accueil .hero-logo-stamp {
    position: relative; z-index: 1;
    margin-bottom: 20px;
  }
    #accueil .hero-left::before {
    content: '';
    position: absolute;
    top: -80px; left: -80px;
    width: 350px; height: 350px;
    border-radius: 50%;
    background: rgba(180,140,100,0.1);
  }
    #accueil .hero-tag {
    font-family: 'Montserrat', sans-serif; font-size: 13px;
    letter-spacing: 4px; text-transform: uppercase;
    color: #b08060; margin-bottom: 24px;
    position: relative; z-index: 1;
  }
    #accueil .hero-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 64px; font-weight: 300;
    line-height: 1.08; color: #2c2018;
    margin-bottom: 28px;
    position: relative; z-index: 1;
  }
    #accueil .hero-title em { font-style: italic; color: #8b6040; }
    #accueil .hero-desc {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px; line-height: 1.75;
    color: #6a5548; max-width: 420px;
    margin-bottom: 40px;
    position: relative; z-index: 1;
    text-align: center;
  }
    #accueil .hero-ctas { display: flex; gap: 20px; align-items: center; justify-content: center; position: relative; z-index: 1; }
    #accueil .cta-primary {
    display: inline-flex; align-items: center; gap: 12px;
    background: #2c2018; color: #f5ede3;
    font-family: 'Montserrat', sans-serif; font-size: 11px;
    letter-spacing: 2px; text-transform: uppercase;
    padding: 16px 32px;
    transition: background 0.3s;
  }
    #accueil .cta-primary:hover { background: #3d3020; }
    #accueil .cta-secondary {
    font-family: 'Montserrat', sans-serif; font-size: 11px;
    letter-spacing: 2px; text-transform: uppercase;
    color: #8b6040; border-bottom: 1px solid #8b6040;
    padding-bottom: 2px;
  }
    #accueil .hero-right {
    position: relative;
    overflow: hidden;
    background: #d8c8b8;
  }
    #accueil .hero-right img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center top;
  }
    #accueil .hero-badge {
    position: absolute;
    bottom: 40px; left: -20px;
    background: #fff;
    padding: 22px 28px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.1);
  }
    #accueil .hero-badge-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 38px; font-weight: 300;
    color: #2c2018; line-height: 1;
  }
    #accueil .hero-badge-text {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 1px;
    color: #8b6040; margin-top: 4px;
  }

  /* ===== USP BAR ===== */
    #accueil .usp-bar {
    background: #2c2018;
    display: flex; justify-content: center;
    gap: 80px; padding: 22px 40px;
  }
    #accueil .usp-item {
    font-family: 'Montserrat', sans-serif; font-size: 10px;
    letter-spacing: 2px; text-transform: uppercase;
    color: rgba(255,255,255,0.6);
    display: flex; align-items: center; gap: 10px;
  }
    #accueil .usp-dot { width: 5px; height: 5px; border-radius: 50%; background: #b08060; }

  /* ===== COLLECTIONS – 3 colonnes éditorial ===== */
    #accueil .collections { padding: 100px 60px; }
    #accueil .section-header { text-align: center; margin-bottom: 60px; }
    #accueil .section-tag {
    font-family: 'Montserrat', sans-serif; font-size: 10px;
    letter-spacing: 4px; text-transform: uppercase;
    color: #b08060; margin-bottom: 16px;
  }
    #accueil .section-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 48px; font-weight: 300;
    color: #2c2018;
  }
    #accueil .section-title em { font-style: italic; }

    #accueil .collections-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
  }
    #accueil .collection-card {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    background: #f0ebe2;
  }
    #accueil .collection-card:hover .collection-img img { transform: scale(1.05); }
    #accueil .collection-img {
    overflow: hidden;
    aspect-ratio: 3/4;
    position: relative;
  }
    #accueil .collection-img img {
    width: 100%; height: 100%;
    object-fit: contain;
    background: #f5f2ec;
    padding: 30px;
    transition: transform 0.6s ease;
  }
    #accueil .collection-overlay {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    background: linear-gradient(to top, rgba(44,32,24,0.85) 0%, transparent 100%);
    padding: 40px 28px 28px;
  }
    #accueil .collection-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 32px; font-weight: 400;
    color: #fff;
    margin-bottom: 6px;
  }
    #accueil .collection-sub {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.6);
    margin-bottom: 16px;
  }
    #accueil .collection-cta {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 2px;
    text-transform: uppercase;
    color: #e8c49a;
    display: inline-flex; align-items: center; gap: 8px;
  }

  /* ===== PRODUCTS GRID ===== */
    #accueil .products { padding: 80px 60px 100px; background: #f5f0e8; }
    #accueil .products-header {
    display: flex; justify-content: space-between;
    align-items: flex-end; margin-bottom: 50px;
  }
    #accueil .products-link {
    font-family: 'Montserrat', sans-serif; font-size: 10px;
    letter-spacing: 2px; text-transform: uppercase;
    color: #8b6040; border-bottom: 1px solid #c8a878;
    padding-bottom: 3px;
  }
    #accueil .products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }
    #accueil .product-card {
    background: #fff;
    overflow: hidden;
    cursor: pointer;
    transition: box-shadow 0.3s, transform 0.3s;
  }
    #accueil .product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(0,0,0,0.08);
  }
    #accueil .product-img-wrap {
    overflow: hidden;
    aspect-ratio: 1;
    background: #f8f5f0;
    position: relative;
  }
    #accueil .product-img-wrap img {
    width: 100%; height: 100%;
    object-fit: contain;
    padding: 16px;
    transition: transform 0.5s ease;
  }
    #accueil .product-card:hover .product-img-wrap img { transform: scale(1.06); }
    #accueil .product-badge {
    position: absolute;
    top: 12px; left: 12px;
    background: #2c2018;
    color: #f5ede3;
    font-family: 'Montserrat', sans-serif;
    font-size: 8px;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 5px 12px;
  }
    #accueil .product-info { padding: 18px 20px 22px; }
    #accueil .product-collection {
    font-family: 'Montserrat', sans-serif;
    font-size: 9px; letter-spacing: 2px;
    text-transform: uppercase;
    color: #b08060; margin-bottom: 6px;
  }
    #accueil .product-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 20px; font-weight: 400;
    color: #2c2018; margin-bottom: 8px;
  }
    #accueil .product-price {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px; color: #5a4a3a;
  }

  /* ===== STORY SECTION ===== */
    #accueil .story {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 550px;
  }
    #accueil .story-img {
    overflow: hidden;
    position: relative;
  }
    #accueil .story-img img {
    width: 100%; height: 100%;
    object-fit: cover;
  }
    #accueil .story-content {
    background: #e8ddd0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 80px;
  }
    #accueil .story-content .section-tag { margin-bottom: 20px; }
    #accueil .story-content h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 48px; font-weight: 300;
    line-height: 1.15; color: #2c2018;
    margin-bottom: 28px;
  }
    #accueil .story-content h2 em { font-style: italic; color: #8b6040; }
    #accueil .story-content p {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px; line-height: 1.8;
    color: #6a5548; margin-bottom: 16px;
  }
    #accueil .story-link {
    font-family: 'Montserrat', sans-serif;
    font-size: 11px; letter-spacing: 2px;
    text-transform: uppercase;
    color: #2c2018; display: inline-flex;
    align-items: center; gap: 12px;
    margin-top: 20px;
  }

  /* ===== ASSEMBLER (Customize your bola) ===== */
    #accueil .assembler {
    background: #2c2018;
    padding: 100px 60px;
    text-align: center;
  }
    #accueil .assembler .section-tag { color: #b08060; }
    #accueil .assembler-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 52px; font-weight: 300;
    color: #f5ede3; margin-bottom: 20px;
    margin-top: 16px;
  }
    #accueil .assembler-title em { font-style: italic; color: #e8c49a; }
    #accueil .assembler-desc {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px; color: rgba(245,237,227,0.5);
    max-width: 520px; margin: 0 auto 40px; line-height: 1.7;
  }
    #accueil .assembler-steps {
    display: flex;
    justify-content: center;
    gap: 60px;
    margin-bottom: 50px;
  }
    #accueil .assembler-step {
    text-align: center;
  }
    #accueil .step-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 48px; font-weight: 300;
    color: #b08060;
    margin-bottom: 8px;
  }
    #accueil .step-label {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(245,237,227,0.55);
  }
    #accueil .assembler-imgs {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-bottom: 50px;
  }
    #accueil .assembler-img {
    width: 200px; height: 200px;
    border-radius: 50%;
    overflow: hidden;
    border: 3px solid rgba(176,128,96,0.3);
    flex-shrink: 0;
    position: relative;
  }
    #accueil .assembler-img .chain-mask {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 28%;
    background: #ffffff;
    z-index: 2;
    pointer-events: none;
  }
    #accueil .assembler-img img {
    width: 100%; height: 100%;
    object-fit: contain;
    background: #f5f2ec;
    padding: 14px;
  }
    #accueil .assembler-img-chains {
    width: 200px; height: 200px;
    border-radius: 50%;
    overflow: hidden;
    border: 3px solid rgba(176,128,96,0.6);
    flex-shrink: 0;
    display: flex;
    align-items: stretch;
  }
    #accueil .assembler-img-chains > div {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #f5f2ec;
    gap: 4px;
    padding: 8px 2px;
  }
    #accueil .assembler-img-chains > div + div {
    border-left: 1px solid rgba(176,128,96,0.2);
  }
    #accueil .assembler-img-chains img {
    width: 44px; height: 80px;
    object-fit: contain;
  }
    #accueil .assembler-img-chains p {
    font-family: 'Montserrat', sans-serif;
    font-size: 7px; letter-spacing: 1px;
    text-transform: uppercase; color: #8b6040;
  }
    #accueil .assembler-cta {
    display: inline-flex; align-items: center; gap: 12px;
    background: transparent;
    border: 1.5px solid #b08060;
    color: #e8c49a;
    font-family: 'Montserrat', sans-serif; font-size: 11px;
    letter-spacing: 2px; text-transform: uppercase;
    padding: 16px 36px;
    transition: all 0.3s;
  }
    #accueil .assembler-cta:hover { background: #b08060; color: #2c2018; }

  /* ===== REVIEWS ===== */
    #accueil .reviews { padding: 100px 60px; background: #faf8f4; }
    #accueil .reviews .section-header { margin-bottom: 60px; }
    #accueil .reviews-stars {
    font-family: 'Cormorant Garamond', serif;
    font-size: 28px; color: #b08060;
    margin-bottom: 8px;
  }
    #accueil .reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
    #accueil .review-card {
    background: #f0ebe2;
    padding: 36px;
    border-top: 2px solid #b08060;
  }
    #accueil .review-stars {
    color: #b08060;
    font-size: 13px; margin-bottom: 20px;
    letter-spacing: 2px;
  }
    #accueil .review-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 20px; font-style: italic;
    color: #3a2e22; line-height: 1.6;
    margin-bottom: 24px;
  }
    #accueil .review-author {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 2px;
    text-transform: uppercase; color: #b08060;
  }

  /* ===== INSTAGRAM / SOCIAL ===== */
    #accueil .social {
    background: #f5f0e8;
    padding: 80px 60px;
    text-align: center;
  }
    #accueil .social .section-tag { margin-bottom: 16px; }
    #accueil .social-handle {
    font-family: 'Cormorant Garamond', serif;
    font-size: 36px; font-weight: 300;
    color: #2c2018;
    margin-bottom: 40px;
  }
    #accueil .social-handle a { color: #8b6040; border-bottom: 1px solid #c8a878; }

  /* ===== FOOTER ===== */
    #accueil .footer {
    background: #1a120c;
    padding: 70px 60px 40px;
  }
    #accueil .footer-top {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 60px;
    margin-bottom: 60px;
  }
    #accueil .footer-brand-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 26px; font-weight: 300;
    color: #f5ede3; margin-bottom: 6px;
  }
    #accueil .footer-brand-sub {
    font-family: 'Montserrat', sans-serif;
    font-size: 8px; letter-spacing: 4px;
    text-transform: uppercase; color: #b08060;
    margin-bottom: 16px;
  }
    #accueil .footer-desc {
    font-family: 'DM Sans', sans-serif;
    font-size: 13px; color: rgba(245,237,227,0.35);
    line-height: 1.7;
  }
    #accueil .footer-col-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 3px;
    text-transform: uppercase; color: #b08060;
    margin-bottom: 20px;
  }
    #accueil .footer-links { list-style: none; }
    #accueil .footer-links li { margin-bottom: 12px; }
    #accueil .footer-links a {
    font-family: 'DM Sans', sans-serif;
    font-size: 13px; color: rgba(245,237,227,0.4);
  }
    #accueil .footer-links a:hover { color: rgba(245,237,227,0.7); }
    #accueil .footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.06);
    padding-top: 28px;
    display: flex;
    justify-content: space-between;
  }
    #accueil .footer-copy {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; color: rgba(245,237,227,0.2);
    letter-spacing: 1px;
  }

  

/* === FIN V2 HOMEPAGE CSS === */

/* === OVERRIDES: reset global styles inside #accueil === */
#accueil .collection-card {
    aspect-ratio: auto !important;
    border-radius: 0 !important;
    group: initial;
}
#accueil .collection-card:hover {
    transform: none !important;
}
#accueil .collections-grid {
    margin-bottom: 0 !important;
}
#accueil .products-grid {
    grid-template-columns: repeat(4, 1fr) !important;
    margin-top: 0 !important;
    gap: 24px !important;
}
#accueil .product-card {
    border-radius: 0 !important;
}
#accueil .product-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.08) !important;
}
#accueil .collection-img {
    overflow: hidden;
    aspect-ratio: 3/4;
    position: relative;
}
#accueil .collection-img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: #f5f2ec;
    padding: 30px;
    transition: transform 0.6s ease;
}
#accueil .product-img-wrap {
    overflow: hidden;
    aspect-ratio: 1;
    background: #f8f5f0;
    position: relative;
}
#accueil .product-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 16px;
    transition: transform 0.5s ease;
}
#accueil .product-info {
    padding: 18px 20px 22px;
}
#accueil .product-collection {
    font-family: 'Montserrat', sans-serif;
    font-size: 9px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #b08060;
    margin-bottom: 6px;
}
#accueil .product-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 20px;
    font-weight: 400;
    color: #2c2018;
    margin-bottom: 8px;
}
#accueil .product-price {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    color: #5a4a3a;
}
#accueil .product-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: #2c2018;
    color: #f5ede3;
    font-family: 'Montserrat', sans-serif;
    font-size: 8px;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 5px 12px;
}
#accueil .section-header {
    text-align: center;
    margin-bottom: 60px;
}
#accueil .section-tag {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: #b08060;
    margin-bottom: 16px;
}
#accueil .section-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 48px;
    font-weight: 300;
    color: #2c2018;
    text-align: center;
}
/* === BOUTIQUE PAGE — Editorial Naturel Style === */
#boutique { background: #f5f0e8; }
#boutique .shop-hero {
    background: transparent;
    color: #2c2018;
    padding: 60px 60px 20px;
    text-align: center;
}
#boutique .shop-hero h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 48px;
    font-weight: 300;
    color: #2c2018;
    margin-bottom: 10px;
}
#boutique .shop-hero p {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    color: #6a5548;
}
#boutique .filters {
    padding: 30px 60px 10px;
    gap: 12px;
}
#boutique .filter-btn {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 10px 24px;
    border: 1.5px solid #c8a878;
    background: transparent;
    color: #5a4a3a;
    border-radius: 0;
    font-weight: 500;
    transition: all 0.3s;
}
#boutique .filter-btn.active {
    background: #2c2018;
    color: #f5ede3;
    border-color: #2c2018;
}
#boutique .filter-btn:hover {
    border-color: #8b6040;
    color: #2c2018;
}
#boutique .products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-top: 0;
}
#boutique .product-card {
    background: #fff;
    overflow: hidden;
    cursor: pointer;
    border-radius: 0;
    transition: box-shadow 0.3s, transform 0.3s;
}
#boutique .product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(0,0,0,0.08);
}
#boutique .product-img-wrap {
    overflow: visible;
    aspect-ratio: 1;
    background: #f8f5f0;
    position: relative;
}
#boutique .product-img-wrap img {
    overflow: hidden;
}
#boutique .product-card {
    overflow: hidden;
}
#boutique .product-img-wrap img {
    width: 100%; height: 100%;
    object-fit: contain;
    padding: 16px;
    transition: transform 0.5s ease;
}
#boutique .product-card:hover .product-img-wrap img { transform: scale(1.06); }
#boutique .product-badge {
    position: absolute;
    top: 12px; left: 12px;
    background: #2c2018;
    color: #f5ede3;
    font-family: 'Montserrat', sans-serif;
    font-size: 8px;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 5px 12px;
}
#boutique .product-info { padding: 18px 20px 22px; }
#boutique .product-collection {
    font-family: 'Montserrat', sans-serif;
    font-size: 9px; letter-spacing: 2px;
    text-transform: uppercase;
    color: #b08060; margin-bottom: 6px;
}
#boutique .product-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 20px; font-weight: 400;
    color: #2c2018; margin-bottom: 8px;
}
#boutique .product-price {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px; color: #5a4a3a;
}
/* === MINI ICONES VARIANTES SUR CARTES BOUTIQUE === */
.card-variants {
    display: flex;
    gap: 5px;
    align-items: center;
}
.card-variant {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    overflow: hidden;
    cursor: pointer;
    border: 1.5px solid transparent;
    transition: border-color 0.2s, transform 0.2s;
    flex-shrink: 0;
}
.card-variant img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}
.card-variant:hover { transform: scale(1.15); border-color: #b08060; }
.card-variant.active { border-color: #2c2018; transform: scale(1.1); }

/* ==================================================
   RESPONSIVE MOBILE — VERSION COMPLÈTE
   ================================================== */

/* Hamburger */
.hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 4px;
    background: none;
    border: none;
    z-index: 1100;
}
.hamburger span {
    display: block;
    width: 24px;
    height: 2px;
    background: #2c2018;
    transition: all 0.3s ease;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav overlay */
.mobile-nav {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: #faf8f4;
    z-index: 1050;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2.5rem;
}
.mobile-nav.open { display: flex; }
.mobile-nav a {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.2rem;
    font-weight: 300;
    color: #2c2018;
    letter-spacing: 2px;
}
.mobile-nav a:hover { color: #8b6040; }
.mobile-nav-close {
    position: absolute;
    top: 24px; right: 24px;
    font-size: 28px;
    background: none;
    border: none;
    cursor: pointer;
    color: #2c2018;
}

/* ========== @media 768px ========== */
@media (max-width: 768px) {

    /* --- HEADER --- */
    nav { display: none !important; }
    .hamburger { display: flex !important; }
    .header-container { padding: 0 14px !important; }
    .logo svg { width: 110px; height: auto; }

    /* --- CLASSES UTILITAIRES MOBILE --- */
    .mob-grid { grid-template-columns: 1fr !important; gap: 20px !important; }
    .mob-grid-2 { grid-template-columns: 1fr !important; }
    .mob-tunnel { grid-template-columns: 1fr !important; gap: 20px !important; }
    .mob-pad-lg { padding: 32px 16px 50px !important; }
    .mob-pad-md { padding: 0 14px 40px !important; }
    .mob-pad-sm { padding: 32px 16px 24px !important; }
    .mob-title-lg { font-size: 28px !important; }
    .mob-btns { flex-direction: column !important; }
    .mob-btns button { width: 100% !important; flex: unset !important; }
    .mob-sticky { position: static !important; }
    .mob-collections { grid-template-columns: 1fr !important; grid-template-rows: auto !important; }

    /* --- HERO ACCUEIL --- */
    #accueil .hero {
        min-height: 70vh !important;
    }
    #accueil .hero-left-inner {
        width: 92% !important;
        max-width: 100% !important;
        top: 50% !important;
        padding: 0 8px !important;
    }
    #accueil .hero-logo-stamp svg {
        width: 50px !important; height: 50px !important;
    }
    #accueil .hero-title {
        font-size: 18px !important;
        margin-bottom: 10px !important;
        line-height: 1.15 !important;
    }
    #accueil .hero-tag {
        font-size: 8px !important;
        letter-spacing: 2px !important;
        margin-bottom: 8px !important;
    }
    #accueil .hero-desc {
        font-size: 10px !important;
        line-height: 1.4 !important;
        margin-bottom: 14px !important;
        max-width: 100% !important;
    }
    #accueil .hero-ctas {
        flex-direction: column !important;
        gap: 6px !important;
        width: 100%;
    }
    #accueil .cta-primary,
    #accueil .cta-secondary {
        font-size: 8px !important;
        letter-spacing: 1px !important;
        padding: 9px 10px !important;
        width: 100%;
        justify-content: center;
    }
    #accueil .hero-badge {
        left: 8px !important; bottom: 8px !important;
        padding: 8px 10px !important;
    }
    #accueil .hero-badge-num { font-size: 16px !important; }
    /* --- USP BAR --- */
    #accueil .usp-bar {
        flex-direction: column !important;
        gap: 10px !important;
        padding: 18px 16px !important;
        align-items: flex-start !important;
    }
    #accueil .usp-item { font-size: 9px !important; }

    /* --- COLLECTIONS ACCUEIL --- */
    #accueil .collections { padding: 40px 6px !important; }
    #accueil .section-title { font-size: 28px !important; }
    #accueil .section-header { margin-bottom: 24px !important; }
    .collections .mob-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 4px !important; }
    .collections .mob-grid > a { padding: 0 !important; }
    .collections .mob-grid > a h3 { font-size: 13px !important; letter-spacing: 0.5px !important; margin: 6px 0 2px !important; }
    .collections .mob-grid > a p { font-size: 9px !important; line-height: 1.3 !important; margin: 0 !important; }
    .collections .mob-grid > a span { font-size: 8px !important; letter-spacing: 1px !important; margin-top: 4px !important; }
    /* Image plein cadre + numéro 01/02/03 masqué (mobile uniquement) */
    .collections .mob-grid > a > div:first-child > img { width: 100% !important; height: 100% !important; object-fit: cover !important; object-position: center !important; }
    .collections .mob-grid > a > div:first-child > div { display: none !important; }
    .collections .mob-grid > a > div:first-child { aspect-ratio: 2 / 3 !important; }
    /* --- PRODUITS ACCUEIL --- */
    #accueil .products { padding: 40px 14px 50px !important; }
    #accueil .products-header {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 10px !important;
        margin-bottom: 24px !important;
    }
    #accueil .products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
    }
    #accueil .product-info { padding: 10px 12px 14px !important; }
    #accueil .product-name { font-size: 14px !important; }
    #accueil .product-collection { font-size: 8px !important; }
    .card-variants { gap: 3px !important; }
    .card-variant { width: 20px !important; height: 20px !important; }

    /* --- STORY / ABOUT --- */
    #accueil .story { grid-template-columns: 1fr !important; }
    #accueil .story-img { height: 55vw; }
    #accueil .story-content {
        padding: 36px 20px !important;
    }
    #accueil .story-content h2 { font-size: 28px !important; }
    #accueil .story-content p { font-size: 14px !important; }

    /* --- ASSEMBLER --- */
    #accueil .assembler { padding: 40px 16px !important; }
    #accueil .assembler-title { font-size: 28px !important; }
    #accueil .assembler-desc { font-size: 13px !important; max-width: 100% !important; }
    #accueil .assembler-steps {
        gap: 16px !important;
        flex-wrap: wrap !important;
    }
    #accueil .step-num { font-size: 36px !important; }
    #accueil .assembler-imgs {
        flex-direction: column !important;
        align-items: center !important;
        gap: 14px !important;
    }
    #accueil .assembler-img { width: 150px !important; height: 150px !important; }
    #accueil .assembler-img-chains { width: 150px !important; height: 150px !important; }

    /* --- REVIEWS --- */
    #accueil .reviews { padding: 40px 16px !important; }
    #accueil .reviews-grid { grid-template-columns: 1fr !important; }

    /* --- FOOTER --- */
    footer { padding: 32px 16px 20px !important; }
    .footer-container { grid-template-columns: 1fr !important; gap: 24px !important; }

    /* --- PAGE BOUTIQUE --- */
#boutique section:not(.shop-hero) { padding-top: 12px !important; }
#boutique .products-grid { margin-top: 0 !important; }

/* --- HERO --- */
#boutique .shop-hero { padding: 20px 16px 8px !important; }
#boutique .shop-hero h1 { font-size: 1.5rem !important; }
#boutique .shop-hero p { font-size: 13px !important; }

/* --- FILTRES --- */
#boutique .filters { padding: 8px 16px !important; gap: 6px !important; justify-content: center !important; flex-wrap: wrap !important; }
.filter-btn { font-size: 10px !important; padding: 5px 10px !important; }

/* --- GRILLE 2 COLONNES --- */
#boutique .products-grid,
#shop-products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
    padding: 0 12px 24px !important;
}

/* --- CARTE : image carrée pleine largeur --- */
#boutique .products-grid li.product { overflow: hidden !important; background: #fff !important; }
#boutique .products-grid li.product img.attachment-woocommerce_thumbnail {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    display: block !important;
}

/* --- COLLECTION LABEL --- */
#boutique .products-grid li.product .blp-product-collection {
    font-size: 8px !important;
    padding: 5px 8px 1px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

/* --- TITRE --- */
#boutique .products-grid li.product .woocommerce-loop-product__title {
    font-size: 12px !important;
    line-height: 1.3 !important;
    padding: 2px 8px 3px !important;
    display: block !important;
    overflow: hidden !important;
    max-height: 2.6em !important;
}

/* --- PRIX --- */
#boutique .products-grid li.product .price { padding: 0 8px 6px !important; }
#boutique .products-grid li.product .blp-from-label { font-size: 7px !important; }
#boutique .products-grid li.product .blp-from-price { font-size: 13px !important; }

/* --- VARIANTES masquées sur mobile --- */
#boutique .products-grid li.product .blp-card-variants { display: none !important; }

/* --- BOUTON PANIER --- */
#boutique .products-grid li.product .blp-add-to-cart-btn {
    width: 28px !important;
    height: 28px !important;
    bottom: 6px !important;
    right: 6px !important;
}
}
.hc-btn:hover { background: #2c2018; color: #fff; }
.hc-btn.prev { left: -18px; }
.hc-btn.next { right: -18px; }
.hc-btn.hidden { opacity: 0; pointer-events: none; }

/* Hero layout with carousel */
.collection-hero-inner {
    display: grid;
    grid-template-columns: 1fr 2.5fr;
    gap: 40px;
    align-items: center;
    max-width: 1200px;
    position: relative;
    z-index: 1;
}
@media (max-width: 768px) {
    .collection-hero-inner { grid-template-columns: 1fr !important; gap: 32px !important; }
    .hero-carousel-card { flex: 0 0 calc((100% - 14px) / 2) !important; }
    .collection-hero-inner { grid-template-columns: 1fr !important; gap: 24px !important; }
    .hc-btn.prev { left: 0 !important; }
    .hc-btn.next { right: 0 !important; }
}

        
/* ── Badges hero carousel ─────────────────────────────── */
.hc-badge {
    position: absolute;
    top: 10px; left: 10px;
    display: flex; align-items: center; gap: 5px;
    padding: 4px 9px 4px 7px;
    border-radius: 20px;
    font-family: 'Montserrat', sans-serif;
    font-size: 8.5px; font-weight: 700;
    letter-spacing: 0.6px; text-transform: uppercase;
    white-space: nowrap; z-index: 3;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}
.hc-badge svg { flex-shrink: 0; }
.hc-badge-plusVendu   { background:#2c2018; color:#e8d5b0; }
.hc-badge-retourStock { background:#4a7c5c; color:#d6f0e2; }
.hc-badge-mieuxNote   { background:#c47d2a; color:#fff8ec; }
.hc-badge-bolaDuMois  { background:#9b2335; color:#ffe8ed; }

/* Sticker "-10%" sur image bola du mois */
.hc-discount-sticker {
    position: absolute;
    bottom: 10px; right: 10px;
    width: 44px; height: 44px;
    background: #9b2335;
    border-radius: 50%;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    z-index: 3;
    box-shadow: 0 2px 8px rgba(155,35,53,0.35);
    transform: rotate(10deg);
}
.hc-discount-sticker span:first-child {
    font-family: 'Montserrat', sans-serif;
    font-size: 13px; font-weight: 800;
    color: #fff; line-height: 1;
}
.hc-discount-sticker span:last-child {
    font-family: 'Montserrat', sans-serif;
    font-size: 7px; font-weight: 600;
    color: #ffccd3; line-height: 1; letter-spacing: 0.3px;
}
/* Prix barré */
.hc-price-original {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px; color: #aaa;
    text-decoration: line-through;
    margin-right: 5px;
}
.hc-price-reduced { color: #9b2335 !important; font-weight: 700 !important; }


/* ── Bouton panier icône sur les cartes produit ───────── */
.card-atc-btn {
    position: absolute;
    bottom: 10px; right: 10px;
    width: 34px; height: 34px;
    border-radius: 50%;
    background: #2c2018;
    color: #e8d5b0;
    border: none;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.25s, transform 0.25s, background 0.2s;
    z-index: 4;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
}
.card-atc-btn svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 1.8; }
.card-atc-btn:hover { background: #b08060; }
.card-atc-btn:active { transform: translateY(6px) scale(0.92); }
.card-atc-btn.added { background: #4a7c5c; opacity: 1 !important; transform: translateY(0) !important; }
.hero-carousel-card:hover .card-atc-btn,
.product-card:hover .card-atc-btn,
a.product-card:hover .card-atc-btn { opacity: 1; transform: translateY(0); }

/* Tooltip panier */
.card-atc-btn::after {
    content: 'Ajouter au panier';
    position: absolute;
    bottom: calc(100% + 7px);
    right: 0;
    background: #2c2018;
    color: #e8d5b0;
    font-family: 'Montserrat', sans-serif;
    font-size: 9px; font-weight: 600;
    letter-spacing: 0.8px;
    white-space: nowrap;
    padding: 5px 9px;
    pointer-events: none;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.2s, transform 0.2s;
}
.card-atc-btn:hover::after {
    opacity: 1;
    transform: translateY(0);
}
.card-atc-btn.added::after { content: '✓ Ajouté !'; }


/* ── Overlay recherche ────────────────────────────────── */
#search-overlay {
    position: fixed; inset: 0;
    background: rgba(20, 14, 10, 0.85);
    backdrop-filter: blur(8px);
    z-index: 10000;
    display: none;
    flex-direction: column;
    align-items: center;
    padding-top: 120px;
    animation: fadeIn 0.2s ease;
}
#search-overlay.open { display: flex; }
#search-box {
    width: 100%; max-width: 640px;
    position: relative;
}
#search-input {
    width: 100%; padding: 18px 52px 18px 24px;
    background: transparent;
    border: none; border-bottom: 2px solid rgba(200,168,120,0.6);
    color: #f5ede3;
    font-family: 'Cormorant Garamond', serif;
    font-size: 32px; font-weight: 300;
    outline: none;
    caret-color: #c8a878;
}
#search-input::placeholder { color: rgba(245,237,227,0.25); }
#search-input:focus { border-color: #c8a878; }
#search-close {
    position: absolute; right: 0; top: 50%; transform: translateY(-50%);
    background: none; border: none; color: rgba(245,237,227,0.4);
    font-size: 28px; cursor: pointer; padding: 8px;
    transition: color 0.2s;
}
#search-close:hover { color: #c8a878; }
#search-hint {
    font-family: 'Montserrat', sans-serif;
    font-size: 9px; letter-spacing: 2px; text-transform: uppercase;
    color: rgba(200,168,120,0.4); margin-top: 14px; text-align: left;
    width: 100%; max-width: 640px;
}
#search-results {
    width: 100%; max-width: 640px;
    margin-top: 32px;
    display: flex; flex-direction: column; gap: 2px;
    max-height: 55vh; overflow-y: auto;
}
.search-result-item {
    display: flex; align-items: center; gap: 16px;
    background: rgba(255,255,255,0.05);
    padding: 14px 18px;
    cursor: pointer;
    transition: background 0.15s;
    text-decoration: none;
}
.search-result-item:hover { background: rgba(200,168,120,0.15); }
.search-result-item img {
    width: 52px; height: 52px;
    object-fit: contain; background: #f8f5f0;
    flex-shrink: 0; padding: 4px;
}
.search-result-info { flex: 1; }
.search-result-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 19px; font-weight: 400; color: #f5ede3;
    margin-bottom: 3px;
}
.search-result-col {
    font-family: 'Montserrat', sans-serif;
    font-size: 8px; letter-spacing: 1.5px; text-transform: uppercase;
    color: rgba(200,168,120,0.6);
}
.search-result-price {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px; color: #c8a878; font-weight: 500;
}
#search-empty {
    font-family: 'Cormorant Garamond', serif;
    font-size: 22px; font-weight: 300; color: rgba(245,237,227,0.3);
    text-align: center; margin-top: 48px; display: none;
}

/* === FIN OVERRIDES === */


/* FIX: WordPress ajoute class "page" au body, ce qui le cache via .page{display:none} */
body.page { display: block !important; }
</style>
/* Collection name bold */
#boutique .blp-product-collection { font-weight: 700 !important; }




/* ====== FICHE PRODUIT - COMPLETE ====== */

/* Background */
.blp-wc-page { background: #f5f0e8 !important; }
.blp-wc-hero { background: #f5f0e8 !important; border-bottom: 1px solid #e8e0d4 !important; padding: 12px 4rem !important; }
.blp-wc-hero .hero-tag { font-family: 'Montserrat', sans-serif !important; font-size: 9px !important; letter-spacing: 3px !important; text-transform: uppercase !important; color: #b08060 !important; }
.blp-wc-hero .blp-steps { font-family: 'Montserrat', sans-serif !important; font-size: 9px !important; color: #8a7a6a !important; letter-spacing: 1px !important; }

/* Masquer éléments parasites */
.blp-wc-content .ppcp-messages,
.blp-wc-content .ppc-button-wrapper,
.blp-wc-content .product_meta,
.blp-wc-content .woocommerce-variation-description,
.blp-wc-content .quantity,
.blp-wc-content .rp_wcdpd_pricing_table_variation_container,
.blp-wc-content a.reset_variations,
.blp-wc-content .reset_variations_alert { display: none !important; }

/* Layout 2 colonnes */
.blp-wc-content .product.type-product {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 3rem !important;
    padding: 3rem 2rem !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    align-items: start !important;
    background: transparent !important;
}

/* Galerie colonne gauche */
.blp-wc-content .woocommerce-product-gallery {
    grid-area: gallery !important;
    background: #faf8f4 !important;
    border-radius: 4px !important;
    width: 100% !important;
    overflow: hidden !important;
    border-radius: 2px !important;
}
.blp-wc-content .woocommerce-product-gallery__trigger,
.blp-wc-content ol.flex-control-nav { display: none !important; }
.blp-wc-content .woocommerce-product-gallery .flex-viewport { width: 100% !important; }
/* .woocommerce-product-gallery__wrapper width : gérée par FlexSlider JS, ne pas forcer */
.blp-wc-content .woocommerce-product-gallery__image img {
    width: 100% !important;
    object-fit: contain !important;
    padding: 1rem !important;
    display: block !important;
}

/* Summary colonne droite */
.blp-wc-content .summary.entry-summary {
    padding-top: 0 !important;
}

/* Pleine largeur pour tabs et liés */
.blp-wc-content .woocommerce-tabs,
.blp-wc-content section.related,
.blp-wc-content section.upsells { grid-column: 1 / -1 !important; }

/* Titre */
.blp-wc-content h1.product_title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 2.2rem !important;
    font-weight: 400 !important;
    color: #2c2018 !important;
    margin-bottom: 0.3rem !important;
    line-height: 1.15 !important;
}

/* Label collection (injecté par PHP) */
.blp-wc-content .blp-single-collection {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 9px !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    color: #b08060 !important;
    font-weight: 700 !important;
    margin-bottom: 1rem !important;
    display: block !important;
}

/* Prix */
.blp-wc-content .summary .price {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 1.6rem !important;
    font-weight: 700 !important;
    color: #b08060 !important;
    margin: 0.8rem 0 1.5rem !important;
    display: flex !important;
    flex-direction: column !important;
    background: none !important;
    line-height: 1.3 !important;
}
.blp-wc-content .summary .price .blp-from-label {
    font-size: 8px !important;
    font-weight: 400 !important;
    letter-spacing: 1.5px !important;
    color: #a08878 !important;
    margin-bottom: 4px !important;
}
.blp-wc-content .summary .price .woocommerce-Price-amount { color: #b08060 !important; }
.blp-wc-content .summary .price del,
.blp-wc-content .summary .price .screen-reader-text { display: none !important; }
/* Masquer tiret et 2e prix pour variable */
.blp-wc-content .summary .price ins { text-decoration: none !important; }
.blp-wc-content .woocommerce-variation-price .price { font-size: 1.4rem !important; margin: 0.5rem 0 !important; }

/* Description courte */
.blp-wc-content .woocommerce-product-details__short-description {
    font-family: 'DM Sans', sans-serif !important;
    font-size: 14px !important;
    color: #6a5548 !important;
    line-height: 1.85 !important;
    margin-bottom: 1.5rem !important;
    border-top: 1px solid #e8e0d4 !important;
    padding-top: 1.2rem !important;
}
.blp-wc-content .woocommerce-product-details__short-description p { margin-bottom: 0.8rem !important; }

/* Variations form */
.blp-wc-content .variations_form { margin-bottom: 0 !important; }
.blp-wc-content table.variations { display: none !important; }

/* Cards déclinaisons JS (créées dynamiquement) */
.blp-variant-cards { display: flex; flex-direction: column; gap: 10px; margin: 0 0 1.5rem 0; }
.blp-variant-cards-label {
    font-family: 'Montserrat', sans-serif;
    font-size: 9px; letter-spacing: 2px;
    text-transform: uppercase; color: #5a4a3a;
    margin-bottom: 12px; font-weight: 600;
}
.blp-variant-card {
    display: flex; align-items: center; gap: 14px;
    padding: 13px 16px;
    border: 1.5px solid #d8cfc4;
    background: #fff; cursor: pointer;
    transition: all 0.2s; position: relative;
}
.blp-variant-card:hover { border-color: #b08060; }
.blp-variant-card.selected { border-color: #2c2018; background: #faf8f4; }
.blp-variant-card.selected::after { content: '✓'; position: absolute; right: 16px; font-size: 13px; color: #2c2018; }
.blp-vc-icon { width: 38px; height: 38px; border-radius: 50%; overflow: hidden; flex-shrink: 0; background: #f0ece6; }
.blp-vc-icon img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blp-vc-info { flex: 1; }
.blp-vc-name { font-family: 'Cormorant Garamond', serif; font-size: 16px; color: #2c2018; margin: 0 0 2px 0; }
.blp-vc-desc { font-family: 'DM Sans', sans-serif; font-size: 11px; color: #8a7a6a; margin: 0; }
.blp-vc-price { font-family: 'Montserrat', sans-serif; font-size: 10px; color: #b08060; letter-spacing: 1px; }

/* Bouton panier */
.blp-wc-content .single_add_to_cart_button,
.blp-wc-content button.single_add_to_cart_button {
    background: #2c2018 !important;
    color: #f5ede3 !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 10px !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    padding: 18px 2rem !important;
    border: none !important;
    border-radius: 0 !important;
    width: 100% !important;
    cursor: pointer !important;
    transition: background 0.25s !important;
    margin-top: 0 !important;
    display: block !important;
}
.blp-wc-content .single_add_to_cart_button:hover { background: #b08060 !important; }

/* Onglets description */
.blp-wc-content .woocommerce-tabs { padding: 2rem 4rem !important; border-top: 1px solid #e8e0d4 !important; }
.blp-wc-content .woocommerce-tabs ul.tabs { list-style: none !important; display: flex !important; gap: 2rem !important; padding: 0 0 1rem !important; border-bottom: 1px solid #e8e0d4 !important; margin: 0 !important; }
.blp-wc-content .woocommerce-tabs ul.tabs li { background: none !important; border: none !important; }
.blp-wc-content .woocommerce-tabs ul.tabs li a { font-family: 'Montserrat', sans-serif !important; font-size: 10px !important; letter-spacing: 2px !important; text-transform: uppercase !important; color: #8a7a6a !important; text-decoration: none !important; }
.blp-wc-content .woocommerce-tabs ul.tabs li.active a { color: #2c2018 !important; font-weight: 700 !important; }
.blp-wc-content .woocommerce-tabs .woocommerce-Tabs-panel { padding: 1.5rem 0 0 !important; font-family: 'DM Sans', sans-serif !important; font-size: 14px !important; color: #6a5548 !important; line-height: 1.8 !important; }

/* Produits liés */
.blp-wc-content section.related { padding: 3rem 4rem !important; border-top: 1px solid #e8e0d4 !important; }
.blp-wc-content section.related h2 { font-family: 'Cormorant Garamond', serif !important; font-size: 1.8rem !important; font-weight: 400 !important; color: #2c2018 !important; margin-bottom: 1.5rem !important; }


/* ====== FICHE PRODUIT - FIXES CRITIQUES ====== */

/* Annuler float et width WooCommerce par défaut sur galerie et summary */
.blp-wc-content div.product div.images,
.blp-wc-content .woocommerce-product-gallery {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    clear: none !important;
    background: #faf8f4 !important;
    border-radius: 4px !important;
}
.blp-wc-content div.product div.summary,
.blp-wc-content .summary.entry-summary {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    clear: none !important;
    padding-top: 0 !important;
}

/* Laisser FlexSlider gérer son viewport — ne pas casser overflow ni transform */
.blp-wc-content .flex-viewport { overflow: hidden !important; width: 100% !important; }
/* .woocommerce-product-gallery__wrapper : width gérée par FlexSlider, ne pas forcer */

/* Image produit */
.blp-wc-content .woocommerce-product-gallery/* __image img padding : géré dans la règle principale ci-dessus */

/* Masquer nav thumbnails et trigger zoom */
.blp-wc-content ol.flex-control-nav,
.blp-wc-content .woocommerce-product-gallery__trigger,
.blp-wc-content .zoomImg { display: none !important; }

/* Cards déclinaisons : largeur complète et style mockup */
.blp-variant-cards {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    margin: 0 0 1.5rem 0 !important;
}
.blp-variant-card {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 16px 20px !important;
    border: 1.5px solid #d8cfc4 !important;
    background: #fff !important;
    cursor: pointer !important;
    position: relative !important;
    transition: border-color 0.2s !important;
    box-sizing: border-box !important;
    width: 100% !important;
}
.blp-variant-card:hover { border-color: #b08060 !important; }
.blp-variant-card.selected { border-color: #2c2018 !important; background: #faf8f4 !important; }
.blp-variant-card.selected::after { content: '✓' !important; position: absolute !important; right: 20px !important; font-size: 14px !important; color: #2c2018 !important; }
.blp-vc-icon { width: 44px !important; height: 44px !important; border-radius: 50% !important; overflow: hidden !important; flex-shrink: 0 !important; background: #f0ece6 !important; }
.blp-vc-icon img { width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; }
.blp-vc-info { flex: 1 !important; min-width: 0 !important; }
.blp-vc-name { font-family: 'Cormorant Garamond', serif !important; font-size: 17px !important; color: #2c2018 !important; margin: 0 0 3px !important; font-weight: 400 !important; }
.blp-vc-desc { font-family: 'DM Sans', sans-serif !important; font-size: 11px !important; color: #8a7a6a !important; margin: 0 !important; }
.blp-vc-price { font-family: 'Montserrat', sans-serif !important; font-size: 11px !important; color: #b08060 !important; letter-spacing: 1px !important; flex-shrink: 0 !important; font-weight: 600 !important; }
.blp-variant-cards-label { font-family: 'Montserrat', sans-serif !important; font-size: 9px !important; letter-spacing: 2px !important; text-transform: uppercase !important; color: #5a4a3a !important; margin: 0 0 12px !important; font-weight: 600 !important; }


/* ====== FICHE PRODUIT - LAYOUT 2 COLONNES ====== */
/* Photo gauche, résumé droite (titre en haut, déclinaisons, description) */
.blp-wc-content .product.type-product {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-areas: "gallery summary" !important;
    column-gap: 3rem !important;
    padding: 3rem 2rem !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    align-items: start !important;
}

.blp-wc-content .woocommerce-product-gallery {
    grid-area: gallery !important;
    float: none !important;
    width: 100% !important;
}

.blp-wc-content .summary.entry-summary {
    grid-area: summary !important;
    float: none !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    padding-top: 0 !important;
}

/* Masquer collection et prix — on garde juste le titre + déclinaisons + desc */
.blp-wc-content .summary.entry-summary .blp-single-collection,
.blp-wc-content .summary.entry-summary p.price { display: none !important; }

/* Tabs et sections full-width */
.blp-wc-content .woocommerce-tabs,
.blp-wc-content section.related,
.blp-wc-content section.upsells { grid-column: 1 / -1 !important; }

/* Masquer premier prix (variation) et "En stock" */
.blp-wc-content .woocommerce-variation-price { display: none !important; }
.blp-wc-content .woocommerce-variation-availability,
.blp-wc-content .stock { display: none !important; }

/* Masquer bandeau étapes panier/commande/confirmation */
.blp-steps { display: none !important; }

/* Réduire écart prix → bouton panier */
.blp-wc-content .rightpress_product_price_live_update { margin-top: 6px !important; margin-bottom: 6px !important; }

/* Cadre élégant autour de la photo - option B : ombre intérieure */
.blp-wc-content .woocommerce-product-gallery {
    border: none !important;
    box-shadow: inset 0 0 18px rgba(90, 60, 30, 0.10) !important;
}

/* Resserrer espacements déclinaisons → prix → bouton */
.blp-wc-content .blp-variant-cards { margin-bottom: 8px !important; }

/* ====== PRODUITS SIMILAIRES ====== */
.blp-wc-content section.related {
    padding: 3rem 2rem !important;
    border-top: 1px solid #e8e0d5 !important;
    grid-column: 1 / -1 !important;
}
.blp-wc-content section.related h2 {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.6rem !important;
    font-weight: 400 !important;
    color: #3a2a1a !important;
    letter-spacing: 1px !important;
    margin-bottom: 2rem !important;
    text-align: center !important;
}
.blp-wc-content section.related ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 1.5rem !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.blp-wc-content section.related ul.products li.product {
    float: none !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
    border: 1px solid #e8e0d5 !important;
    transition: box-shadow 0.3s !important;
}
.blp-wc-content section.related ul.products li.product:hover {
    box-shadow: 0 4px 16px rgba(90,60,30,0.10) !important;
}
/* Image carrée */
.blp-wc-content section.related ul.products li.product a.woocommerce-LoopProduct-link {
    display: block !important;
    width: 100% !important;
    text-decoration: none !important;
}
.blp-wc-content section.related ul.products li.product img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 !important;
    object-fit: contain !important;
    background: #faf8f4 !important;
    padding: 1rem !important;
}
/* Titre et prix */
.blp-wc-content section.related ul.products li.product .woocommerce-loop-product__title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    color: #3a2a1a !important;
    padding: 0.75rem 1rem 0.25rem !important;
    margin: 0 !important;
}
.blp-wc-content section.related ul.products li.product .price {
    display: block !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 0.75rem !important;
    color: #b08060 !important;
    letter-spacing: 1px !important;
    padding: 0 1rem 1rem !important;
    margin: 0 !important;
}
/* Masquer le bouton ajout panier sur les cartes */
.blp-wc-content section.related ul.products li.product .button {
    display: none !important;
}

/* Masquer les variant cards dans les produits similaires */
.blp-wc-content section.related .blp-card-variants,
.blp-wc-content section.related .blp-card-label { display: none !important; }

/* FORCE largeur images produits similaires */
.blp-wc-content section.related ul.products li.product > a,
.blp-wc-content section.related ul.products li.product a.woocommerce-LoopProduct-link {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
.blp-wc-content section.related ul.products li.product > a > img,
.blp-wc-content section.related ul.products li.product a img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 !important;
    object-fit: contain !important;
    background: #faf8f4 !important;
    padding: 1rem !important;
    box-sizing: border-box !important;
}

/* Forcer li.product en block pour que le lien s'étende correctement */
.blp-wc-content section.related ul.products li.product {
    display: block !important;
}

/* Fix: box-sizing pour que le border ne fasse pas déborder la grille */
.blp-wc-content section.related ul.products li.product {
    box-sizing: border-box !important;
}

/* Fix grille produits similaires - gap explicite en px */
.blp-wc-content section.related ul.products {
    gap: 16px !important;
    grid-template-columns: repeat(4, 1fr) !important;
}

/* Fix définitif : empêcher le wrap du 4e produit */
.blp-wc-content section.related ul.products {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    overflow: hidden !important;
}
.blp-wc-content section.related ul.products li.product {
    min-width: 0 !important;
    overflow: hidden !important;
}

/* Placement explicite de chaque carte - fix définitif */
.blp-wc-content section.related ul.products li.product:nth-child(1) { grid-column: 1 !important; grid-row: 1 !important; }
.blp-wc-content section.related ul.products li.product:nth-child(2) { grid-column: 2 !important; grid-row: 1 !important; }
.blp-wc-content section.related ul.products li.product:nth-child(3) { grid-column: 3 !important; grid-row: 1 !important; }
.blp-wc-content section.related ul.products li.product:nth-child(4) { grid-column: 4 !important; grid-row: 1 !important; }




/* ===== Bouton Ajouter au panier — design compact ===== */

/* --- Positionnement : accueil --- */
.product-card .blp-add-to-cart-btn {
    position: static;
    flex-shrink: 0;
    align-self: center;
}

/* --- Positionnement : boutique / collections --- */
li.product {
    position: relative !important;
}
li.product > .blp-add-to-cart-btn {
    position: absolute;
    right: 8px;
    bottom: 8px;
    z-index: 3;
}

/* --- Style du bouton (commun) --- */
.blp-add-to-cart-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    margin: 0;
    background: #1a1a1a;
    color: #fff;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.blp-add-to-cart-btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Hover : le cercle s'étend en pill et affiche le texte */
.blp-add-to-cart-btn:hover {
    width: auto;
    padding: 0 18px;
    border-radius: 25px;
    gap: 7px;
    background: #333;
    box-shadow: 0 4px 14px rgba(0,0,0,0.22);
    transform: translateY(-1px);
}

/* Désactivé (chargement / succès / erreur) : toujours en pill */
.blp-add-to-cart-btn:disabled {
    width: auto;
    padding: 0 16px;
    border-radius: 25px;
    gap: 7px;
    cursor: default;
    pointer-events: none;
}

/* Succès */
.blp-add-to-cart-btn.blp-success {
    background: #2d7d46;
    box-shadow: 0 2px 10px rgba(45,125,70,0.3);
}

/* Erreur / Rupture */
.blp-add-to-cart-btn.blp-error {
    background: #8b5e3c;
    box-shadow: 0 2px 10px rgba(139,94,60,0.3);
}
/* Label hover du bouton panier */
.blp-add-to-cart-btn .blp-label {
    display: none;
    margin-left: 6px;
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    white-space: nowrap;
}
.blp-add-to-cart-btn:hover .blp-label {
    display: inline;
}
.blp-add-to-cart-btn:disabled .blp-label {
    display: inline;
}


/* ============================================
   PAGE ACTUALITÉS — BLOG LISTING
   ============================================ */

.blp-blog-page {
    background: #fff;
    min-height: 60vh;
}

/* En-tête */
.blp-blog-hero {
    padding: 80px 60px 60px;
    max-width: 1200px;
    margin: 0 auto;
}

.blp-blog-tag {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: #b08060;
    margin-bottom: 14px;
}

.blp-blog-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 44px;
    font-weight: 300;
    color: #2c2018;
    line-height: 1.15;
    margin: 0;
}

.blp-blog-title em {
    font-style: italic;
    color: #8b6040;
}

/* Grille */
.blp-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 60px 80px;
}

/* Carte article */
.blp-blog-card {
    text-decoration: none;
    color: inherit;
    display: block;
}

.blp-blog-card-img-wrap {
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: #f0ebe2;
    margin-bottom: 24px;
}

.blp-blog-card-img-placeholder {
    background: #e8ddd0;
}

.blp-blog-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    display: block;
}

.blp-blog-card:hover .blp-blog-card-img {
    transform: scale(1.04);
}

.blp-blog-card-body {
    padding: 0;
}

.blp-blog-card-meta {
    font-family: 'Montserrat', sans-serif;
    font-size: 9px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #b08060;
    margin-bottom: 10px;
}

.blp-blog-card-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 24px;
    font-weight: 400;
    color: #2c2018;
    line-height: 1.3;
    margin-bottom: 12px;
}

.blp-blog-card-excerpt {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    color: #6a5548;
    line-height: 1.7;
    margin: 0;
}

/* Pagination */
.blp-blog-pagination {
    display: flex;
    justify-content: center;
    gap: 12px;
    padding: 0 60px 80px;
}

.blp-blog-pagination .page-numbers {
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #2c2018;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    padding-bottom: 2px;
    transition: border-color 0.2s;
}

.blp-blog-pagination .page-numbers:hover,
.blp-blog-pagination .page-numbers.current {
    border-color: #c8a878;
    color: #8b6040;
}

/* Responsive */
@media (max-width: 900px) {
    .blp-blog-grid {
        grid-template-columns: repeat(2, 1fr);
        padding: 0 24px 60px;
    }
    .blp-blog-hero {
        padding: 60px 24px 40px;
    }
    .blp-blog-title {
        font-size: 32px;
    }
}

@media (max-width: 600px) {
    .blp-blog-grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }
}




/* =============================================
   PAGE PANIER — template BLP custom
   ============================================= */

/* Wrapper */
.blp-cart-page { max-width: 1140px; margin: 0 auto; padding: 48px 24px 80px; }
.blp-cart-page .entry-header { display: none; }
.blp-cart-heading { font-size: 1.5rem; font-weight: 700; color: #2c2018; margin: 0 0 28px; }

/* Panier vide */
.blp-cart-empty { text-align: center; padding: 80px 20px; }
.blp-cart-empty p { font-size: 1.1rem; color: #888; margin-bottom: 24px; }
.blp-continue-link {
  display: inline-block; background: #2c2018; color: #fff;
  padding: 14px 36px; border-radius: 40px; text-decoration: none;
  font-size: 0.9rem; letter-spacing: 0.08em; text-transform: uppercase;
  transition: background 0.2s;
}
.blp-continue-link:hover { background: #4a3728; color: #fff; }

/* Layout flex */
.blp-cart-inner { display: flex; gap: 40px; align-items: flex-start; }
.blp-cart-products { flex: 1 1 0; min-width: 0; }
.blp-cart-summary { width: 320px; flex-shrink: 0; }

/* En-tete colonnes */
.blp-cart-cols-head {
  display: grid;
  grid-template-columns: 80px 1fr 110px 90px 36px;
  padding: 0 0 12px; gap: 0;
  border-bottom: 2px solid #2c2018;
  font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase; color: #2c2018;
}
.blp-cart-cols-head span { padding: 0 4px; }

/* Ligne produit */
.blp-cart-row {
  display: grid;
  grid-template-columns: 80px 1fr 110px 90px 36px;
  align-items: center; gap: 0;
  padding: 18px 0; border-bottom: 1px solid #e8ddd0;
}
.blp-row-img img { width: 68px; height: 68px; object-fit: cover; border-radius: 8px; display: block; }
.blp-row-info { padding: 0 12px; }
.blp-row-name { font-size: 0.9rem; color: #2c2018; font-weight: 500; text-decoration: none; display: block; }
.blp-row-name:hover { text-decoration: underline; }
.blp-row-variant { font-size: 0.78rem; color: #888; margin-top: 3px; }
.blp-row-unit-price { font-size: 0.82rem; color: #888; margin-top: 4px; }
.blp-row-sub { font-size: 0.9rem; font-weight: 600; color: #2c2018; text-align: center; }
.blp-row-rm { display: flex; align-items: center; justify-content: center; }

/* Stepper quantite */
.blp-qty { display: flex; align-items: center; justify-content: center; gap: 6px; }
.blp-q-btn {
  width: 28px; height: 28px; border: 1px solid #ccc; background: #fff;
  border-radius: 50%; cursor: pointer; font-size: 1rem; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: border-color 0.15s, background 0.15s; padding: 0;
}
.blp-q-btn:hover { border-color: #2c2018; background: #fdf8f0; }
.blp-q-input {
  width: 36px; text-align: center; border: 1px solid #ddd;
  border-radius: 6px; padding: 4px 0; font-size: 0.88rem; color: #2c2018;
  -moz-appearance: textfield;
}
.blp-q-input::-webkit-outer-spin-button,
.blp-q-input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Bouton supprimer */
.blp-rm {
  width: 28px; height: 28px; border: none; background: none; cursor: pointer;
  color: #bbb; font-size: 1.1rem; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  text-decoration: none; transition: color 0.15s, background 0.15s;
}
.blp-rm:hover { color: #c0392b; background: #fef0f0; }

/* Footer panier */
.blp-cart-footer {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 16px; padding-top: 20px;
}
.blp-coupon-wrap { display: flex; gap: 10px; align-items: center; }
.blp-coupon-wrap input[type='text'] {
  border: 1px solid #ddd; border-radius: 8px; padding: 10px 14px;
  font-size: 0.85rem; width: 180px; color: #2c2018; outline: none;
  transition: border-color 0.15s;
}
.blp-coupon-wrap input[type='text']:focus { border-color: #2c2018; }
.blp-cart-btn, .blp-update-btn, .blp-search-btn {
  border: 1px solid #2c2018; background: transparent; color: #2c2018;
  padding: 10px 20px; border-radius: 8px; font-size: 0.8rem;
  letter-spacing: 0.06em; text-transform: uppercase;
  cursor: pointer; transition: background 0.15s, color 0.15s; white-space: nowrap;
}
.blp-cart-btn:hover, .blp-update-btn:hover, .blp-search-btn:hover { background: #2c2018; color: #fff; }

/* Recapitulatif */
.blp-summary-box {
  background: #fdf8f0; border: 1px solid #e8ddd0;
  border-radius: 12px; padding: 28px 24px; position: sticky; top: 100px;
}
.blp-summary-tag {
  font-size: 1rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: #2c2018; margin: 0 0 20px; display: block;
}
.blp-summary-lines { margin-bottom: 8px; }
.blp-sum-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0; border-bottom: 1px solid #e8ddd0;
  font-size: 0.88rem; color: #555;
}
.blp-sum-row span:last-child { font-weight: 600; color: #2c2018; }
.blp-sum-total {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0 0; font-size: 1.05rem; font-weight: 700; color: #2c2018;
  border-top: 2px solid #2c2018; margin-top: 8px;
}
.blp-checkout-cta {
  display: block; width: 100%; background: #2c2018; color: #fff;
  text-align: center; padding: 16px 20px; border-radius: 40px;
  text-decoration: none; font-size: 0.9rem; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  margin-top: 18px; transition: background 0.2s; border: none; cursor: pointer;
}
.blp-checkout-cta:hover { background: #4a3728; color: #fff; }
.blp-reassurance {
  margin-top: 18px; padding-top: 14px;
  border-top: 1px solid #e8ddd0;
  font-size: 0.78rem; color: #888; line-height: 1.8;
}
.blp-reassurance p { margin: 0; display: flex; align-items: center; gap: 8px; }
.blp-reassurance p + p { margin-top: 4px; }

/* Charms cross-sells */
.blp-charm-section {
  margin-top: 56px; padding-top: 40px;
  border-top: 1px solid #e8ddd0; text-align: center;
}
.blp-charm-tag {
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: #888; margin: 0 0 8px; display: block;
}
.blp-charm-title { font-size: 1.3rem; font-weight: 700; color: #2c2018; margin: 0 0 32px; }
.blp-charm-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; text-align: left; }
.blp-charm-card {
  background: #fff; border: 1px solid #e8ddd0; border-radius: 12px;
  overflow: hidden; transition: box-shadow 0.2s, transform 0.2s;
}
.blp-charm-card:hover { box-shadow: 0 8px 24px rgba(44,32,24,0.1); transform: translateY(-2px); }
.blp-charm-img-box { width: 100%; aspect-ratio: 1/1; overflow: hidden; background: #fdf8f0; }
.blp-charm-img-box img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s; }
.blp-charm-card:hover .blp-charm-img-box img { transform: scale(1.04); }
.blp-charm-inner { padding: 14px 16px 16px; }
.blp-charm-name { font-size: 0.88rem; font-weight: 600; color: #2c2018; margin: 0 0 4px; }
.blp-charm-price { font-size: 0.85rem; color: #888; margin: 0 0 12px; }
.blp-charm-card a.button {
  display: block; text-align: center;
  border: 1px solid #2c2018 !important; color: #2c2018 !important;
  padding: 8px 14px; border-radius: 20px;
  font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase;
  text-decoration: none;
  background: transparent !important;
  transition: background 0.15s, color 0.15s;
}
.blp-charm-card a.button:hover { background: #2c2018 !important; color: #fff !important; }

/* Responsive */
/* === Titre panier === */
.blp-cart-heading {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.6rem;
  font-weight: 400;
  font-style: italic;
  color: #2c2018;
  margin: 0 0 28px;
  line-height: 1.1;
  letter-spacing: -0.01em;
}

/* === Récapitulatif — version douce === */
.blp-summary-box {
  background: #f7f0e6;
  border: 1px solid #dfd0bc;
  border-radius: 16px;
  padding: 32px 28px;
  position: sticky;
  top: 100px;
  box-shadow: 0 4px 20px rgba(44,32,24,0.07);
}
.blp-summary-tag {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.35rem;
  font-weight: 400;
  font-style: italic;
  color: #2c2018;
  letter-spacing: 0.01em;
  margin: 0 0 20px;
  display: block;
  border-bottom: 1px solid #dfd0bc;
  padding-bottom: 14px;
}
.blp-sum-row {
  border-bottom: 1px solid #e8ddd0;
  color: #6b5547;
}
.blp-sum-row span:last-child {
  color: #2c2018;
  font-weight: 600;
}
.blp-sum-total {
  border-top: 1.5px solid #2c2018;
  color: #2c2018;
  font-size: 1.1rem;
  margin-top: 10px;
  padding-top: 14px;
}
/* Livraison */
.blp-summary-box .woocommerce-shipping-methods { list-style: none; margin: 0; padding: 0; }
.blp-summary-box .woocommerce-shipping-methods li {
  font-size: 0.8rem; color: #6b5547;
  padding: 4px 0; display: flex; align-items: center; gap: 8px;
}
.blp-summary-box .woocommerce-shipping-methods li label { color: #6b5547; font-size: 0.8rem; cursor: pointer; }
.blp-summary-box .shipping-calculator-button {
  color: #9e8070; font-size: 0.75rem; text-decoration: underline;
  cursor: pointer; background: none; border: none; padding: 6px 0 0; display: inline-block;
}
.blp-summary-box .shipping-calculator-button:hover { color: #2c2018; }
.blp-summary-box .shipping-calculator-form { margin-top: 12px; }
.blp-summary-box .shipping-calculator-form input,
.blp-summary-box .shipping-calculator-form select {
  background: #fff; border: 1px solid #dfd0bc; color: #2c2018;
  border-radius: 8px; padding: 8px 12px; font-size: 0.82rem; width: 100%; margin-bottom: 8px;
}
.blp-summary-box .shipping-calculator-form .button {
  background: #2c2018; color: #fff; border: none;
  border-radius: 8px; padding: 9px 16px; font-size: 0.8rem;
  cursor: pointer; transition: background 0.15s;
}
.blp-summary-box .shipping-calculator-form .button:hover { background: #4a3728; }
/* Bouton commander */
.blp-checkout-cta {
  background: #2c2018; color: #fff;
  border-radius: 40px; font-size: 0.88rem; font-weight: 700;
  letter-spacing: 0.1em; transition: background 0.2s; margin-top: 20px;
}
.blp-checkout-cta:hover { background: #4a3728; color: #fff; }
/* Lien continuer */
.blp-continue-link {
  display: block; text-align: center; color: #9e8070;
  font-size: 0.75rem; letter-spacing: 0.08em; text-transform: uppercase;
  text-decoration: none; margin-top: 12px; transition: color 0.15s;
}
.blp-continue-link:hover { color: #2c2018; }
/* Réassurance */
.blp-reassurance {
  border-top: 1px solid #dfd0bc; margin-top: 16px; padding-top: 14px;
  font-size: 0.76rem; color: #9e8070;
}
.blp-reassurance p { margin: 0; display: flex; align-items: center; gap: 8px; }
.blp-reassurance p + p { margin-top: 5px; }

@media (max-width: 768px) {
  .blp-cart-inner { flex-direction: column; }
  .blp-cart-summary { width: 100%; }
  .blp-cart-cols-head { display: none; }
  .blp-cart-row {
    grid-template-columns: 68px 1fr 36px;
    grid-template-rows: auto auto; padding: 14px 0;
  }
  .blp-row-qty, .blp-row-sub { grid-column: 2; padding-left: 12px; }
  .blp-row-unit-price { display: none; }
  .blp-row-rm { grid-column: 3; grid-row: 1; }
  .blp-charm-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .blp-charm-grid { grid-template-columns: 1fr; }
}
/* Masquer le titre de page WordPress sur la page panier */
.woocommerce-cart .entry-header { display: none !important; }


/* BLP CARD ALIGN — hauteur uniforme et alignement prix/declinaisons/panier */
#boutique .products-grid li.product {
  display: flex !important;
  flex-direction: column !important;
  height: auto !important;
}
#boutique .products-grid li.product > a.woocommerce-LoopProduct-link {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  height: auto !important;
}
#boutique .products-grid li.product .woocommerce-loop-product__title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 2.6em !important;
  max-height: 2.6em !important;
  line-height: 1.3 !important;
}
#boutique .products-grid li.product > a.woocommerce-LoopProduct-link .price {
  margin-top: auto !important;
}
