/* ============================= */
/* SCROLL PROMOS */
/* ============================= */

.promos-scroll{
    display:flex;
    overflow-x:auto;
    gap:16px;
    padding:10px 16px;

    scroll-snap-type:x mandatory;
    scroll-padding-left:16px;
    scroll-padding-right:16px;

    -webkit-overflow-scrolling:touch;
}

.promos-scroll::-webkit-scrollbar{
    display:none;
}

/* Si hay una sola promo */

.promos-scroll:has(.promo-card:only-child){
    justify-content:center;
    overflow-x:hidden;
}

/* ============================= */
/* TARJETA PROMO */
/* ============================= */

.promo-card{
    flex:0 0 90%;
    max-width:90%;

    background:#fff;
    border-radius:12px;
    padding:12px;

    box-shadow:0 2px 8px rgba(0,0,0,0.1);

    display:flex;
    gap:12px;
    align-items:flex-start;

    scroll-snap-align:center;

    transition:transform .2s ease, box-shadow .2s ease;
}

.promo-card:hover{
    transform:translateY(-2px);
    box-shadow:0 4px 14px rgba(0,0,0,0.12);
}

/* ============================= */
/* COLUMNA IZQUIERDA */
/* ============================= */

.promo-img{
    position:relative;
    width:25%;
    height:auto;
    flex-shrink:0;
}

/* ============================= */
/* IMAGEN */
/* ============================= */

.promo-img img{
    padding-top: 25px;
    width:100%;
    height:100%;
    object-fit:cover;

    border-radius:8px;
    display:block;

    background:#f2f2f2;
}

/* ============================= */
/* RIBBON */
/* ============================= */

.promo-ribbon{
    position:absolute;

    top:-6px;
    left:-8px;

    background:#7fb100;
    color:#fff;

    font-weight:700;
    font-size:1,5en;
    padding:4px 10px;

    border-radius:6px;

    letter-spacing:.4px;
    white-space:nowrap;

    transform:rotate(-10deg);

    box-shadow:0 2px 6px rgba(0,0,0,.25);

    z-index:2;
}

/* ============================= */
/* CONTENIDO */
/* ============================= */

.promo-content{
    flex:1;
    min-width:0;
}

/* TITULO */

.promo-title{
    font-size:1rem;
    font-weight:600;
    margin:0;
    line-height:1.2;

    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

/* DESCRIPCION */

.promo-desc{
    font-size:.9rem;
    color:#555;
    margin:4px 0;

    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

/* PRECIO */

.promo-price{
    font-size:1.2rem;
    font-weight:bold;
    color:var(--color-primario);
    margin-bottom:6px;
}

/* ============================= */
/* BOTONES */
/* ============================= */

.promo-content .btn{
    font-size:.9rem;
    padding:8px;
    line-height:1.2;
}

.promo-content .btn + .btn{
    margin-top:6px;
}

/* ============================= */
/* ANIMACION */
/* ============================= */

.promo-anim{
    opacity:0;
    transform:translateY(20px);
    animation:promoFadeIn .6s ease-out forwards;
}

@keyframes promoFadeIn{
    to{
        opacity:1;
        transform:translateY(0);
    }
}

/* ============================= */
/* RESPONSIVE */
/* ============================= */

@media (max-width:480px){

    .promo-card{
        flex:0 0 92%;
        max-width:92%;
    }

    .promo-img{
        width:88px;
        height:88px;
    }

    .promo-price{
        font-size:1.1rem;
    }

}