/* ============================================
   NUTRAGILE - Fiche Produit
   ============================================ */

/* ---- Titre ---- */
.nt-product__title {
    font-family: var(--nutragile-font) !important;
    font-weight: 400 !important;
    font-size: 50px !important;
    color: var(--nutragile-link-dark) !important;
    text-transform: none !important;
    margin: 0 0 8px !important;
    line-height: 1.2 !important;
}

#product .product-actions {
    max-width: 400px;
}

#product .nt-reviews {
    padding-top: 8px !important;
}

/* ---- Prix ---- */
#product .product-prices {
    margin: 0 0 12px !important;
}

#product .product-prices .current-price {
    display: flex !important;
    align-items: baseline !important;
    gap: 8px !important;
}

#product .product-prices .current-price-value {
    font-family: var(--nutragile-font) !important;
    font-weight: 400 !important;
    font-size: 34px !important;
    color: var(--nutragile-link-dark) !important;
}

#product .images-container .thumb:hover,
#product .images-container .thumb:focus,
#product .images-container .thumb.selected,
#product-modal .thumb:hover,
#product-modal .thumb:focus,
#product-modal .thumb.selected {
    border: 2px solid var(--nutragile-green-bright) !important;
    outline: none !important;
}

#product .images-container .thumb, #product-modal .thumb {
    border: 2px solid transparent !important;
    outline: none !important;
    cursor: pointer !important;
}

#product-modal .image-caption {
    display: none !important;
}

/* Cacher TTC, tax, conditions */
#product .product-prices .tax-shipping-delivery-label,
#product .product-prices .product-without-taxes,
#product .product-prices .product-unit-price {
    display: none !important;
}

/* ---- Description courte ---- */
.nt-product__desc-short {
    font-family: var(--nutragile-font-link) !important;
    font-size: 13px !important;
    line-height: 0.8 !important;
    margin: 0 0 20px !important;
    font-weight: 400 !important;
}

.nt-product__desc-short p {
    color: var(--nutragile-link-dark) !important;
}

.nt-product__desc-short strong {
    font-weight: 700 !important;
}

.nt-product__desc-short ul {
    padding-left: 12px !important;
    margin: 4px 0 !important;
    color: var(--nutragile-link-dark) !important;
}

.nt-product__desc-short li {
    margin-bottom: 2.4px !important;
    list-style: disc !important;
    line-height: 1.6 !important;
    color: var(--nutragile-link-dark) !important;
}

/* ---- Avis ---- */
.nt-product__reviews {
    margin: 8px 0 16px !important;
}

/* ---- Sélecteurs : quantité + variante ---- */
.nt-product__selectors {
    display: flex !important;
    align-items: center !important;
    gap: 9.6px !important;
    margin: 16px 0 12px !important;
}

/* Cacher le sélecteur de variante natif de classic */
#product .product-variants {
    display: none !important;
}

/* Cacher le add-to-cart natif de classic */
#product .product-add-to-cart {
    display: none !important;
}

/* Quantité +/- */
.nt-product__qty {
    display: flex !important;
    align-items: center !important;
    border: 1px solid var(--nutragile-text-bright) !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    height: 35.2px !important;
    background: var(--nutragile-white) !important;
}

.nt-product__qty-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 100% !important;
    border: none !important;
    background: var(--nutragile-white) !important;
    cursor: pointer !important;
    color: var(--nutragile-text-dark) !important;
    transition: background 0.2s ease !important;
    padding: 0 !important;
}

.input-group-btn-vertical{
    display: none !important;
}

.nt-product__qty-btn:hover {
    background: var(--nutragile-text-bright) !important;
}

.nt-product__qty-btn .material-icons {
    font-size: 14px !important;
}

.nt-product__qty-input {
    width: 36px !important;
    text-align: center !important;
    border: none !important;
    border-left: 1px solid var(--nutragile-text-bright) !important;
    border-right: 1px solid var(--nutragile-text-bright) !important;
    font-family: var(--nutragile-font-link) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: var(--nutragile-link-dark) !important;
    height: 100% !important;
    -moz-appearance: textfield !important;
    outline: none !important;
    padding: 0 !important;
}

.nt-product__qty-input::-webkit-outer-spin-button,
.nt-product__qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

/* Variante dropdown */
.nt-product__variant-select {
    flex: 1 !important;
}

.nt-product__variant-dropdown {
    font-family: var(--nutragile-font-link) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: var(--nutragile-link-dark) !important;
    border: 1px solid var(--nutragile-text-bright) !important;
    border-radius: 6px !important;
    padding: 8px 28px 8px 9.6px !important;
    height: 35.2px !important;
    width: 100% !important;
    background: var(--nutragile-white) !important;
    cursor: pointer !important;
    outline: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpolyline points='1 1 6 6 11 1' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 9.6px center !important;
}

/* ---- Bouton Ajouter + Wishlist ---- */
.nt-product__add-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 12px 0 !important;
}

.nt-product__add-btn {
    flex: 1 !important;
    font-family: var(--nutragile-font) !important;
    font-weight: 400 !important;
    font-size: 14px !important;
    color: var(--nutragile-white) !important;
    background: var(--nutragile-green-bright) !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 9.6px 16px !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
    text-align: center !important;
    height: 38.4px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nt-product__add-btn:hover {
    background: var(--nutragile-text-light) !important;
}

.nt-product__add-btn:disabled {
    background: var(--nutragile-text-light) !important;
    cursor: not-allowed !important;
}

.nt-product__wishlist {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38.4px !important;
    height: 38.4px !important;
    border: 1px solid var(--nutragile-green-bright) !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
}

/* Wishlist sur fiche produit : coeur seul */
.nt-product__wishlist .an_wishlist-btn-product {
    font-size: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38.4px !important;
    height: 38.4px !important;
    margin-left: 1.6px;
}

.nt-product__wishlist .an_wishlist-btn-product svg {
    width: 17.6px !important;
    height: 17.6px !important;
}

.nt-product__wishlist .an_wishlist-btn-product .js-an_wishlist-product-count {
    display: none !important;
}

/* Coeur vide par défaut : contour vert */
.nt-product__wishlist .an_wishlist-btn-product svg path {
    fill: none !important;
    stroke: var(--nutragile-green-bright) !important;
    stroke-width: 1.5 !important;
}

/* Coeur plein vert quand dans la wishlist */
.nt-product__wishlist .an_wishlist-btn-product.an_wishlist-in svg path {
    fill: var(--nutragile-green-bright) !important;
    stroke: var(--nutragile-green-bright) !important;
}

/* ---- Ligne dispo + paiement ---- */
.nt-product__info-line {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
    margin: 8px 0 16px !important;
}

.nt-product__availability {
    font-family: var(--nutragile-font-link);
    font-size: 10px;
    color: var(--nutragile-green-bright) !important;
    font-weight: 500 !important;
    min-width: 156.8px;
    padding-top: 2.4px;
}

.nt-product__avail-dot {
    font-size: 8px !important;
}

.nt-product__payment-secure {
    font-family: var(--nutragile-font-link) !important;
    font-weight: 300;
    font-size: 10px;
    display: flex !important;
    align-items: center !important;
    gap: 7.2px !important;
    color: var(--nutragile-text-dark) !important;
}

.nt-product__payment-secure .material-icons {
    font-size: 11px !important;
}

.nt-product__payment-secure img {
    height: 14.4px !important;
    width: auto !important;
}

/* ---- Bloc contact ---- */
.nt-product__contact {
    background: var(--nutragile-white) !important;
    border: 1px solid #eee !important;
    border-radius: 8px !important;
    padding: 14.4px 16px !important;
    margin: 12px 0 0 !important;
    max-width: 400px;
}

.nt-product__contact-title {
    font-family: var(--nutragile-font-link) !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    color: var(--nutragile-link-dark) !important;
    margin: 0 0 4px !important;
}

.nt-product__contact-text {
    font-family: var(--nutragile-font-link) !important;
    font-weight: 300 !important;
    font-size: 11px !important;
    color: var(--nutragile-link-dark) !important;
    margin: 0 !important;
}

.nt-product__contact-text a {
    color: var(--nutragile-green-bright) !important;
    text-decoration: underline !important;
}

/* ---- Cacher réassurance dans la colonne droite ---- */
#product .blockreassurance {
    display: none !important;
}

/* ---- Cacher additional info inutile ---- */
#product .product-additional-info {
    display: none !important;
}

/* ============================================
   ONGLETS PLEINE LARGEUR
   ============================================ */

.nt-product__tabs {
    background: var(--nutragile-cream) !important;
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    padding: 0 !important;
    margin-top: 32px !important;
    border-top: none !important;
}

.nt-product__tabs .nav-tabs {
    max-width: 1536px !important;
    margin: 0 auto !important;
    padding: 0 12px !important;
}

.nt-product__tabs .tab-content {
    max-width: 1536px !important;
    margin: 0 auto !important;
    padding: 24px 12px !important;
}

.nt-product__tabs .nav-item {
    flex: 1 !important;
}

.nt-product__tabs .nav-link {
    font-family: var(--nutragile-font) !important;
    font-weight: 400 !important;
    font-size: 16px !important;
    color: var(--nutragile-link-dark) !important;
    padding: 14.4px 8px !important;
    text-align: center !important;
    border: none !important;
    border-bottom: 2px solid transparent !important;
    background: transparent !important;
    transition: all 0.2s ease !important;
    display: block !important;
    text-decoration: none !important;
}

.nt-product__tabs .nav-link:hover {
    color: var(--nutragile-text-dark) !important;
}

.nt-product__tabs .nav-link.active {
    color: var(--nutragile-text-dark) !important;
    font-weight: 500 !important;
    border-bottom-color: var(--nutragile-text-dark) !important;
}

.nt-product__tabs .tab-content .product-description {
    font-family: var(--nutragile-font-link) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: var(--nutragile-link-dark) !important;
    line-height: 1.3 !important;
}

.nt-product__tabs .tab-content .product-description h2,
.nt-product__tabs .tab-content .product-description h3,
.nt-product__tabs .tab-content .product-description strong {
    font-weight: 600 !important;
}

/* Cross-selling carousel */
#product .product-accessories {
    max-width: 1536px !important;
    margin: 32px auto !important;
    padding: 0 12px !important;
}

#product .product-accessories .h5 {
    font-family: var(--nutragile-font) !important;
    font-weight: 400 !important;
    font-size: 26px !important;
    text-transform: none !important;
    color: var(--nutragile-text-dark) !important;
    margin: 0 0 28px !important;
}

#product .product-accessories .h5::first-letter {
    text-transform: uppercase !important;
}

.nt-carousel {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}

.nt-carousel__track {
    display: flex !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    gap: 16px !important;
    scroll-behavior: smooth !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 4px 0 8px !important;
    flex: 1 !important;
    justify-content: center !important;
}

/* Quand ça déborde : alignement à gauche pour que le scroll marche */
.nt-carousel__track.is-scrollable {
    justify-content: flex-start !important;
}

#product .product-accessories .nt-carousel__track.products {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    gap: 16px !important;
    scroll-behavior: smooth !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 4px 0 8px !important;
    justify-content: center !important;
}

#product .product-accessories .nt-carousel__track.products > article {
    flex: 0 0 269.6px !important;
    max-width: 269.6px !important;
    min-width: 269.6px !important;
    scroll-snap-align: start !important;
}

/* Cacher scrollbar */
.nt-carousel__track::-webkit-scrollbar {
    display: none !important;
}
.nt-carousel__track {
    -ms-overflow-style: none !important;
    scrollbar-width: none !important;
}

/* Flèches */
.nt-carousel__arrow {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    border: 1px solid var(--nutragile-text-bright) !important;
    background: var(--nutragile-white) !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    z-index: 2 !important;
    transition: all 0.2s ease !important;
    color: #333 !important;
}

.nt-carousel__arrow:hover {
    border-color: var(--nutragile-green-bright) !important;
    color: var(--nutragile-green-bright) !important;
}

.nt-carousel__arrow .material-icons {
    font-size: 19px !important;
}

.nt-carousel__arrow--left {
    margin-right: 8px !important;
}

.nt-carousel__arrow--right {
    margin-left: 8px !important;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 992px) {
    .nt-product__title {
        font-size: 21px !important;
    }

    .nt-product__selectors {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .nt-product__add-row {
        flex-direction: column !important;
    }

    .nt-product__wishlist {
        width: 100% !important;
    }

    .nt-product__info-line {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    #product .product-accessories .products {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 768px) {
    .nt-carousel__track > article {
        flex: 0 0 224px !important;
        max-width: 224px !important;
    }

    .nt-carousel__arrow {
        width: 25.6px !important;
        height: 25.6px !important;
    }
}

@media (max-width: 600px) {
    .nt-product__title {
        font-size: 18px !important;
    }

    .nt-product__tabs .nav-link {
        font-size: 10px !important;
        padding: 9.6px 4px !important;
    }

    #product .product-accessories .products {
        grid-template-columns: 1fr !important;
    }
}
