/* product.css — Page Produit — MediProvital */


    /* Product Detail Section */
    .product-detail-section {
        background: var(--color-neutral);
        padding: 60px 0;
    }

    /* Product Gallery */
    .product-gallery {
        position: sticky;
        top: 100px;
    }

    .main-image-wrapper {
        position: relative;
        background: white;
        border-radius: var(--border-radius);
        padding: 20px;
        margin-bottom: 20px;
        box-shadow: var(--box-shadow);
    }

    .main-product-image {
        width: 100%;
        height: 500px;
        object-fit: cover;
        border-radius: var(--border-radius);
    }

    .product-badge {
        position: absolute;
        top: 30px;
        right: 30px;
        padding: 8px 16px;
        border-radius: 25px;
        font-size: 14px;
        font-weight: 600;
        color: white;
    }

    .product-badge.in-stock {
        background: #27ae60;
    }

    .product-badge.out-stock {
        background: #e74c3c;
    }

    .thumbnail-wrapper {
        display: flex;
        gap: 10px;
        overflow-x: auto;
    }

    .thumbnail-item {
        flex-shrink: 0;
        width: 80px;
        height: 80px;
        background: white;
        border-radius: var(--border-radius);
        padding: 5px;
        cursor: pointer;
        border: 2px solid transparent;
        transition: var(--transition);
    }

    .thumbnail-item:hover,
    .thumbnail-item.active {
        border-color: var(--color-primary);
    }

    .thumbnail-item img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 4px;
    }

    /* Product Details */
    .product-details {
        background: white;
        border-radius: var(--border-radius);
        padding: 40px;
        box-shadow: var(--box-shadow);
    }

    .product-category-badge {
        display: inline-block;
        background: var(--color-wood-light);
        color: var(--color-secondary);
        padding: 6px 16px;
        border-radius: 25px;
        font-size: 14px;
        font-weight: 600;
        margin-bottom: 15px;
    }

    .product-title {
        font-size: 2rem;
        color: var(--color-secondary);
        margin-bottom: 15px;
        font-weight: 700;
    }

    .product-rating-wrapper {
        display: flex;
        align-items: center;
        gap: 10px;
        margin-bottom: 20px;
    }

    .product-stars {
        display: flex;
        gap: 4px;
    }

    .product-stars i {
        width: 20px;
        height: 20px;
        color: #ddd;
    }

    .product-stars i.star-filled {
        color: #ffc107;
        fill: #ffc107;
    }

    .rating-text {
        font-size: 14px;
        color: var(--color-text-light);
    }

    .product-price-section {
        background: var(--color-neutral);
        padding: 20px;
        border-radius: var(--border-radius);
        margin-bottom: 25px;
    }

    .price-wrapper {
        display: flex;
        align-items: center;
        gap: 15px;
        margin-bottom: 5px;
    }

    .current-price {
        font-size: 2.5rem;
        font-weight: 700;
        color: var(--color-primary);
    }

    .old-price {
        font-size: 1.5rem;
        color: var(--color-text-light);
        text-decoration: line-through;
    }

    .discount-badge {
        background: var(--color-primary);
        color: white;
        padding: 4px 12px;
        border-radius: 25px;
        font-size: 14px;
        font-weight: 600;
    }

    .tax-info {
        font-size: 14px;
        color: var(--color-text-light);
        margin: 0;
    }

    .product-short-description {
        margin-bottom: 25px;
        color: var(--color-text);
        line-height: 1.8;
    }

    .product-features {
        margin-bottom: 30px;
    }

    .feature-item {
        display: flex;
        align-items: center;
        gap: 10px;
        margin-bottom: 12px;
        color: var(--color-text);
    }

    .feature-item i {
        width: 20px;
        height: 20px;
        color: var(--color-primary);
    }

    /* Stock status */
    .stock-status {
        display: flex;
        align-items: center;
        gap: 8px;
        margin-bottom: 16px;
    }
    .stock-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        background: #27ae60;
        flex-shrink: 0;
        box-shadow: 0 0 0 3px rgba(39,174,96,0.2);
        animation: pulse-green 2s infinite;
    }
    @keyframes pulse-green {
        0%, 100% { box-shadow: 0 0 0 3px rgba(39,174,96,0.2); }
        50%       { box-shadow: 0 0 0 6px rgba(39,174,96,0.08); }
    }
    .stock-label {
        font-size: 14px;
        font-weight: 600;
        color: #27ae60;
    }

    /* CTA reassurance block */
    .cta-reassurance {
        display: flex;
        flex-direction: column;
        gap: 8px;
        margin-bottom: 25px;
        padding: 12px 16px;
        background: #f9f6f0;
        border-radius: var(--border-radius);
        border-left: 3px solid var(--color-primary);
    }
    .cta-social-proof {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 14px;
        color: var(--color-text);
    }
    .stars-mini {
        color: #ffc107;
        font-size: 15px;
        letter-spacing: 1px;
    }
    .cta-risk-reversal {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 13px;
        color: #555;
    }
    .cta-risk-reversal i {
        width: 15px;
        height: 15px;
        color: var(--color-primary);
        flex-shrink: 0;
    }

    /* Product Actions */
    .product-actions {
        display: flex;
        gap: 15px;
        margin-bottom: 30px;
    }

    .quantity-selector {
        display: flex;
        align-items: center;
        border: 2px solid var(--color-neutral);
        border-radius: var(--border-radius);
        overflow: hidden;
    }

    .qty-btn {
        background: var(--color-neutral);
        border: none;
        padding: 12px 16px;
        cursor: pointer;
        transition: var(--transition);
    }

    .qty-btn:hover {
        background: var(--color-wood-light);
    }

    .qty-btn i {
        width: 18px;
        height: 18px;
        color: var(--color-secondary);
    }

    .quantity-selector input {
        width: 60px;
        border: none;
        text-align: center;
        font-size: 16px;
        font-weight: 600;
    }

    .btn-add-to-cart {
        flex: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        padding: 12px 30px;
        font-size: 16px;
        font-weight: 600;
    }

    .btn-add-to-cart i {
        width: 20px;
        height: 20px;
    }

    /* Product Meta */
    .product-meta {
        border-top: 1px solid var(--color-neutral);
        border-bottom: 1px solid var(--color-neutral);
        padding: 20px 0;
        margin-bottom: 25px;
    }

    .meta-item {
        display: flex;
        gap: 10px;
        margin-bottom: 10px;
        font-size: 14px;
    }

    .meta-item:last-child {
        margin-bottom: 0;
    }

    .meta-item strong {
        color: var(--color-secondary);
    }

    .meta-item a {
        color: var(--color-primary);
        text-decoration: none;
    }

    .meta-item a:hover {
        text-decoration: underline;
    }

    /* Product Guarantees */
    .product-guarantees {
        display: flex;
        flex-direction: column;
        gap: 15px;
    }

    .guarantee-item {
        display: flex;
        align-items: center;
        gap: 15px;
        padding: 15px;
        background: var(--color-neutral);
        border-radius: var(--border-radius);
    }

    .guarantee-item i {
        width: 30px;
        height: 30px;
        color: var(--color-primary);
        flex-shrink: 0;
    }

    .guarantee-item strong {
        display: block;
        color: var(--color-secondary);
        font-size: 15px;
        margin-bottom: 3px;
    }

    .guarantee-item span {
        display: block;
        color: var(--color-text-light);
        font-size: 13px;
    }

    /* Product Tabs */
    .product-tabs-section {
        margin-top: 60px;
        background: white;
        border-radius: var(--border-radius);
        box-shadow: var(--box-shadow);
        overflow: hidden;
    }

    .product-tabs {
        border-bottom: 2px solid var(--color-neutral);
    }

    .product-tabs .nav-link {
        color: var(--color-text);
        padding: 20px 30px;
        border: none;
        background: transparent;
        font-weight: 600;
        transition: var(--transition);
    }

    .product-tabs .nav-link:hover {
        color: var(--color-primary);
        background: var(--color-neutral);
    }

    .product-tabs .nav-link.active {
        color: var(--color-primary);
        background: transparent;
        border-bottom: 3px solid var(--color-primary);
    }

    .tab-content-inner {
        padding: 40px;
        color: var(--color-text);
        line-height: 1.8;
    }

    /* Specifications Table */
    .specifications-table {
        width: 100%;
        border-collapse: collapse;
    }

    .specifications-table tr {
        border-bottom: 1px solid var(--color-neutral);
    }

    .specifications-table td {
        padding: 15px 0;
    }

    .specifications-table td:first-child {
        width: 200px;
        color: var(--color-secondary);
    }

    /* Reviews */
    .review-item {
        padding: 25px 0;
        border-bottom: 1px solid var(--color-neutral);
    }

    .review-item:last-child {
        border-bottom: none;
    }

    .review-header {
        display: flex;
        align-items: center;
        gap: 15px;
        margin-bottom: 10px;
    }

    .review-stars {
        display: flex;
        gap: 3px;
    }

    .review-stars i {
        width: 16px;
        height: 16px;
        color: #ddd;
    }

    .review-stars i.star-filled {
        color: #ffc107;
        fill: #ffc107;
    }

    .review-author {
        font-weight: 600;
        color: var(--color-secondary);
    }

    .review-date {
        color: var(--color-text-light);
        font-size: 14px;
    }

    .review-text {
        color: var(--color-text);
        margin: 0;
    }

    /* Related Products */
    .related-products-section {
        margin-top: 60px;
    }

    .section-title {
        font-size: 2rem;
        color: var(--color-secondary);
        margin-bottom: 30px;
        font-weight: 700;
        text-align: center;
    }

    /* Responsive */
    @media (max-width: 991px) {
        .product-gallery {
            position: relative;
            top: 0;
            margin-bottom: 30px;
        }

        .main-product-image {
            height: 400px;
        }
    }

    @media (max-width: 768px) {
        .product-details {
            padding: 25px;
        }

        .product-title {
            font-size: 1.5rem;
        }

        .current-price {
            font-size: 2rem;
        }

        .product-actions {
            flex-direction: column;
        }

        .quantity-selector {
            width: 100%;
            justify-content: center;
        }

        .product-tabs .nav-link {
            padding: 15px 20px;
            font-size: 14px;
        }

        .tab-content-inner {
            padding: 25px;
        }

        .main-product-image {
            height: 300px;
        }
    }
