/* ============================================
   SECTION INTRO - "Deux univers..."
   ============================================ */

.nutragile-featured-products {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    overflow: hidden;
    background: var(--nutragile-light-cream);
}

.nutragile-intro {
    text-align: center;
    padding: 56px 32px 40px;
    max-width: 720px;
    margin: 0 auto;
}

.nutragile-intro__title {
    font-family: var(--nutragile-font);
    font-size: 26px;
    font-weight: 400;
    line-height: 1.3;
    color: var(--nutragile-link-dark);
    margin: 0 0 16px 0;
    text-underline-offset: 4.8px;
    text-decoration-thickness: 0.8px;
}

.nutragile-intro__desc {
    font-family: var(--nutragile-font-link);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.6;
    color: var(--nutragile-link-dark);
    margin: 0 0 24px 0;
}

.nutragile-intro__ctas {
    display: flex;
    gap: 11.2px;
    justify-content: center;
    flex-wrap: wrap;
}


/* ============================================
   SECTION PRODUITS POPULAIRES
   ============================================ */

.nutragile-products {
    display: flex;
    gap: 0;
    padding: 0 0 48px 0;
    max-width: 1616px;
    margin: 0 auto;
}

/* --- Sidebar gauche (CMS) --- */
.nutragile-products__sidebar {
    flex: 0 0 320px;
    max-width: 320px;
    background: var(--nutragile-cream);
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    overflow: hidden;
    border-radius: 6px;
    margin-left: 58px;
}

/* Contenu texte au-dessus des décorations */
.nutragile-products__sidebar #custom-text,
.nutragile-products__sidebar > * {
    position: relative;
    z-index: 1;
}

#custom-text {
    background: transparent !important;
    text-align: justify !important;
    font-family: var(--nutragile-font-link) !important;
    padding: 0 48px;
    line-height: 1.3 !important;
}

#custom-text .nutragile-products__sidebar-title{
    font-weight: 600 !important;
    font-size: 16px !important;
}

#custom-text p{
    font-weight: 300 !important;
    font-size: 14px !important;
    color: var(--nutragile-link-dark) !important;
    margin-top: 40px;
}


/* Libellule — haut gauche */
.nutragile-products__sidebar::before {
    content: '';
    position: absolute;
    top: -2.4px;
    left: -21.6px;
    width: 96px;
    height: 96px;
    background-color: var(--nutragile-light-cream);
    mask: url('../img/libellule.svg') no-repeat center / contain;
    -webkit-mask: url('../img/libellule.svg') no-repeat center / contain;
    pointer-events: none;
    z-index: 0;
}

/* Patte — bas droite */
.nutragile-products__sidebar::after {
    content: '';
    position: absolute;
    bottom: -4px;
    right: -2.4px;
    width: 80px;
    height: 80px;
    background-color: var(--nutragile-light-cream);
    mask: url('../img/patte.svg') no-repeat center / contain;
    -webkit-mask: url('../img/patte.svg') no-repeat center / contain;
    pointer-events: none;
    z-index: 0;
}

.nutragile-products__sidebar h3,
.nutragile-products__sidebar .custom-text-title {
    font-family: var(--nutragile-font);
    font-size: 16px;
    font-weight: 600;
    color: var(--nutragile-link-dark);
    margin: 0 0 12.8px 0;
    line-height: 1.3;
}

.nutragile-products__sidebar p {
    font-family: var(--nutragile-font-link);
    font-size: 11px;
    font-weight: 300;
    line-height: 1.6;
    color: var(--nutragile-link-dark);
    margin: 0 0 9.6px 0;
}

/* --- Grille 4 produits --- */
.nutragile-products__grid {
    flex: 1;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    padding: 0 24px;
    align-content: start;
}

/* Miniatures dans la grille homepage */
.nutragile-products__grid > article.product-miniature {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    flex: none !important;
}


/* ============================================
   RESPONSIVE - INTRO + PRODUITS
   ============================================ */

@media (max-width: 1200px) {
    .nutragile-products__grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .nutragile-intro__title {
        font-size: 27px;
    }
}

@media (max-width: 1024px) {
    .nutragile-products {
        flex-direction: column;
    }

    .nutragile-products__sidebar {
        flex: none;
        max-width: 100%;
        padding: 24px 19.2px;
        text-align: center;
        margin: 0 18px;
    }

    .nutragile-products__grid {
        grid-template-columns: repeat(2, 1fr);
        padding: 16px 19.2px;
    }

    .nutragile-intro__title {
        font-size: 22px;
    }

    .nutragile-intro {
        padding: 40px 19.2px 32px;
    }
}

@media (max-width: 768px) {
    .nutragile-intro {
        padding: 32px 16px 24px;
    }

    .nutragile-intro__title {
        font-size: 19px;
    }

    .nutragile-intro__desc {
        font-size: 11px;
    }

    .nutragile-products__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12.8px;
        padding: 12.8px 16px;
    }
}

@media (max-width: 480px) {
    .nutragile-intro__title {
        font-size: 16px;
    }

    .nutragile-intro__ctas {
        flex-direction: column;
        align-items: center;
    }

    .nutragile-products__grid {
        grid-template-columns: 1fr;
        gap: 19.2px;
    }
}
