/**
 * CSS pour les miniatures d'ingrédients dans les étapes de préparation
 * Version 2.0.0 - Décembre 2025
 * 
 * Miniatures rondes avec texte à droite et tooltip image agrandie
 */

/* ============================================
   MODIFICATION DU CONTENEUR PARENT
   Pour afficher les ingrédients sous le texte
   ============================================ */
.recette-preparation-section .sous-etape-content {
    flex-direction: column !important;
    align-items: flex-start !important;
}

.recette-preparation-section .sous-etape-text-wrapper {
    width: 100%;
}

/* ============================================
   CONTENEUR DES INGRÉDIENTS PAR ÉTAPE
   ============================================ */
.etape-ingredients {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 8px;
    padding-top: 0;
    width: 100%;
}

/* ============================================
   MINIATURE D'INGRÉDIENT - IMAGE + TEXTE
   ============================================ */
.etape-ingredient-thumb {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    overflow: visible;
}

/* Wrapper de l'image (pour le tooltip) */
.etape-ingredient-thumb .etape-thumb-image-wrapper {
    position: relative;
    display: inline-block;
    cursor: pointer;
    transition: transform 0.2s ease;
    flex-shrink: 0;
    z-index: 1001;
}

.etape-ingredient-thumb .etape-thumb-image-wrapper:hover,
.etape-ingredient-thumb .etape-thumb-image-wrapper:focus,
.etape-ingredient-thumb .etape-thumb-image-wrapper.tooltip-visible {
    transform: scale(1.15);
}

.etape-ingredient-thumb .etape-thumb-image-wrapper:focus {
    outline: none;
}

/* Image de l'ingrédient (petite, ronde) */
.etape-ingredient-thumb .etape-thumb-image {
    width: 52px;
    height: 52px;
    object-fit: contain;
    border-radius: 50%;
    background-color: #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    transition: box-shadow 0.2s ease;
    display: block;
}

.etape-ingredient-thumb .etape-thumb-image-wrapper:hover .etape-thumb-image,
.etape-ingredient-thumb .etape-thumb-image-wrapper.tooltip-visible .etape-thumb-image {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
}

/* Texte de l'ingrédient (à droite de l'image, centré verticalement) */
.etape-ingredient-thumb .etape-thumb-text {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--text-color, #fff);
    white-space: nowrap;
    line-height: 52px;
}

/* ============================================
   TOOLTIP - IMAGE AGRANDIE (POSITION DROITE)
   ============================================ */
.etape-ingredient-thumb .etape-thumb-tooltip {
    position: absolute;
    left: calc(100% + 12px);
    top: 50%;
    transform: translateY(-50%);
    background-color: #fff;
    padding: 8px;
    border-radius: 12px;
    border: 2px solid var(--savoor-coral, #FF6B6B);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease, visibility 0.2s ease;
    z-index: 9999;
    pointer-events: none;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

.etape-ingredient-thumb .etape-thumb-tooltip img {
    width: 150px;
    height: 150px;
    object-fit: contain;
    border-radius: 8px;
    display: block;
    background-color: #fff;
}

/* Flèche du tooltip (pointe vers la gauche) */
.etape-ingredient-thumb .etape-thumb-tooltip::after {
    content: '';
    position: absolute;
    right: 100%;
    top: 50%;
    transform: translateY(-50%);
    border: 10px solid transparent;
    border-right-color: var(--savoor-coral, #FF6B6B);
}

/* Affichage au hover ou via classe JS */
.etape-ingredient-thumb .etape-thumb-image-wrapper:hover .etape-thumb-tooltip,
.etape-ingredient-thumb .etape-thumb-image-wrapper.tooltip-visible .etape-thumb-tooltip {
    opacity: 1;
    visibility: visible;
}

/* Focus pour accessibilité - pas de bordure visible */
.etape-ingredient-thumb:focus {
    outline: none;
}

/* ============================================
   MODE CLAIR
   ============================================ */
body.light-mode .etape-ingredients {
    border-top-color: rgba(0, 0, 0, 0.1);
}

body.light-mode .etape-ingredient-thumb .etape-thumb-image {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

body.light-mode .etape-ingredient-thumb .etape-thumb-image-wrapper:hover .etape-thumb-image {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.18);
}

body.light-mode .etape-ingredient-thumb .etape-thumb-text {
    color: var(--text-color, #333);
}

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

/* Tablette */
@media (max-width: 1024px) {
    .etape-ingredient-thumb .etape-thumb-image {
        width: 48px;
        height: 48px;
    }
    
    .etape-ingredients {
        gap: 8px;
    }
    
    .etape-ingredient-thumb .etape-thumb-text {
        font-size: 0.9rem;
        line-height: 48px;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .etape-ingredients {
        gap: 8px;
        margin-top: 8px;
    }
    
    .etape-ingredient-thumb .etape-thumb-image {
        width: 44px;
        height: 44px;
    }
    
    .etape-ingredient-thumb .etape-thumb-text {
        font-size: 0.85rem;
        line-height: 44px;
    }
    
    .etape-ingredient-thumb .etape-thumb-tooltip img {
        width: 100px;
        height: 100px;
    }
}

/* Petit mobile */
@media (max-width: 480px) {
    .etape-ingredient-thumb .etape-thumb-image {
        width: 40px;
        height: 40px;
    }
    
    .etape-ingredients {
        gap: 6px;
    }
    
    .etape-ingredient-thumb .etape-thumb-text {
        font-size: 0.8rem;
        line-height: 40px;
    }
    
    .etape-ingredient-thumb .etape-thumb-tooltip img {
        width: 80px;
        height: 80px;
    }
}

/* ============================================
   ANIMATION AU CHARGEMENT
   ============================================ */
@keyframes fadeInScale {
    from {
        opacity: 0;
        transform: scale(0.7);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.etape-ingredient-thumb {
    animation: fadeInScale 0.3s ease forwards;
}

.etape-ingredient-thumb:nth-child(2) { animation-delay: 0.05s; }
.etape-ingredient-thumb:nth-child(3) { animation-delay: 0.1s; }
.etape-ingredient-thumb:nth-child(4) { animation-delay: 0.15s; }
.etape-ingredient-thumb:nth-child(5) { animation-delay: 0.2s; }
.etape-ingredient-thumb:nth-child(6) { animation-delay: 0.25s; }
.etape-ingredient-thumb:nth-child(7) { animation-delay: 0.3s; }
.etape-ingredient-thumb:nth-child(8) { animation-delay: 0.35s; }

/* ============================================
   SUPPORT TOUCH (MOBILE)
   ============================================ */
@media (hover: none) and (pointer: coarse) {
    /* Sur mobile, désactiver l'effet hover par défaut */
    .etape-ingredient-thumb .etape-thumb-image-wrapper:hover {
        transform: none;
    }
    
    .etape-ingredient-thumb .etape-thumb-image-wrapper:hover .etape-thumb-image {
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    }
    
    .etape-ingredient-thumb .etape-thumb-image-wrapper:active {
        transform: scale(1.1);
    }
    
    /* Le tooltip sera géré par JS avec la classe .tooltip-visible */
}

/* ============================================
   PRÉFÉRENCE DE MOUVEMENT RÉDUIT
   ============================================ */
@media (prefers-reduced-motion: reduce) {
    .etape-ingredient-thumb {
        animation: none;
        transition: none;
    }
    
    .etape-ingredient-thumb .etape-thumb-tooltip {
        transition: none;
    }
}
