body{
    font-family:'Poppins',sans-serif;
    background-color:#faf7ff;
    color:#111;
}

/* PRODUCTO SELECCIONADO */
.productoCard.selected{
    border-color:#6A0DAD!important;
    background-color:#F5E8FF!important;
    box-shadow:0 0 0 2px #D8B4FE inset
}

/* MODALES */
.modal-zalu{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.8);
    display:none;
    z-index:9999;
    justify-content:center;
    align-items:center;
    padding:20px
}
.modal-content-zalu{
    width:100%;
    max-width:1100px;
    background:#fff;
    border-radius:20px;
    overflow:hidden;
    display:flex;
    animation:zoomIn .35s cubic-bezier(.16,1,.3,1)
}
.modal-left{
    width:50%;
    background-size:cover;
    background-position:center
}
.modal-right{
    width:50%;
    padding:40px;
    display:flex;
    flex-direction:column;
    justify-content:center
}
.close-modal{
    position:absolute;
    top:30px;
    right:40px;
    font-size:40px;
    cursor:pointer;
    color:#fff
}
@keyframes zoomIn{
    from{opacity:0;transform:scale(.75)}
    to{opacity:1;transform:scale(1)}
}


.popup-box{
    background:#fff;
    width:95%;
    max-width:520px;
    border-radius:22px;
    padding:32px;
    box-shadow:0 10px 40px rgba(106,0,173,.25);
    animation:scaleUp .25s ease-out
}
@keyframes scaleUp{
    from{transform:scale(.85);opacity:0}
    to{transform:scale(1);opacity:1}
}
.input-zalu{background:#fff}

/* REELS */
.reels-carousel{position:relative;max-width:100%;margin:0 auto}
.reels-viewport{overflow:hidden;border-radius:16px;border:1px solid #ddd;background:#000}
.reels-track{display:flex;margin:0;padding:0;list-style:none;transition:transform .45s ease;will-change:transform}
.reel-slide{flex:0 0 100%;padding:8px;display:flex;justify-content:center}
.reel-slide video{width:100%;aspect-ratio:9/16;max-height:500px;object-fit:cover;border-radius:12px;background:#000}

@media (min-width:768px){
    .reel-slide{flex:0 0 25%}
}

/* HEADER */
.header-solid{
    background:rgba(72,12,116,.84);
    backdrop-filter:blur(6px);
    box-shadow:0 2px 10px rgba(0,0,0,.15)
}
#mobileMenu{
    position:fixed;
    top:74px;
    left:0;
    width:100%;
    z-index:9999
}
.header-open{
    background:rgba(72,12,116,.84)!important;
    backdrop-filter:blur(6px)
}
/*#mainHeader{top:38px!important}*/
#mainHeader{
    top: 38px !important;
}
/* TICKER */
.ticker{
    width:100%;
    overflow:hidden;
    background:#230750;
    color:#fff;
    padding:8px 0;
    position:fixed;
    top:0;
    left:0;
    z-index:99999
}
.ticker .track{
    display:flex;
    width:max-content;
    white-space:nowrap;
    animation:tickerMove 35s linear infinite
}
.ticker:hover .track{animation-play-state:paused}
.ticker .group{display:flex}
.ticker .item{
    margin:0 32px;
    font-weight:600;
    font-size:15px
}
@keyframes tickerMove{
    0%{transform:translateX(0)}
    100%{transform:translateX(-50%)}
}

/* ANIMACIONES */
@keyframes pulseSoft{
    0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(126,34,206,.4)}
    50%{transform:scale(1.03);box-shadow:0 0 0 12px rgba(126,34,206,0)}
}
.animate-pulse-soft{animation:pulseSoft 2.5s infinite}

/* SCROLL TESTIMONIOS */
.testimonios-scroll::-webkit-scrollbar{display:none}
.testimonios-scroll{-ms-overflow-style:none;scrollbar-width:none}
.snap-center:active{transform:scale(.97);transition:transform .15s ease}

/* FAQ EXPRESS BASE */
.faq-express-mobile{display:block}

/* OVERLAY */
.popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(4px);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 999999;
    padding: 20px;
}

.popup-overlay-mob {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(4px);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 999999;
    padding: 0px;
    padding-top: 10px;
}
/* CAJA DEL POPUP */
.popup-box {
    background: #fff;
    width: 100%;
    max-width: 460px;
    border-radius: 22px;
    padding: 28px;
    box-shadow: 0 20px 60px rgba(0,0,0,.35);
    animation: scaleUp .25s ease-out;
    margin: auto;   /* 🔥 ESTO ES CLAVE */
}

/* ANIMACIÓN */
@keyframes scaleUp {
    from { transform: scale(.9); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}

/* MOBILE AJUSTE FINO */
@media (max-width: 640px) {
    .popup-box {
        max-width: 100%;
        padding: 22px;
    }
}
.productoCard {
    cursor: pointer;
    transition: all 0.2s ease;
}

.productoCard:hover {
    transform: scale(1.01);
}

.productoCard.selected {
    border: 2px solid #7e22ce !important;
    background-color: #f5ebff !important;
    box-shadow: 0 0 0 2px rgba(126, 34, 206, 0.25);
}

.select2-selection__clear {
    position: absolute !important;
    right: 1px;
    top: 32%;
    transform: translateY(-50%);
    color: #7e22ce;              /* morado Zalú */
    font-size: 18px;
    font-weight: bold;
    cursor: pointer;
    background: #f3e8ff;        /* fondo suave */
    border-radius: 50%;
    width: 22px;
    height: 22px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: all 0.2s ease;
}

.select2-selection__clear:hover {
    background: #7e22ce;
    color: #fff;
}

.select2-selection--single{
    height: 50px !important;
}

.input-zalu.error,
input.error,
select.error {
    border: 2px solid #dc2626 !important;
    background: #fff5f5;
}

.error-message {
    font-size: 12px;
    color: #dc2626;
    display: block;
    margin-top: 4px;
}

.select2-container--default .select2-selection--single {

    border: 1px solid #eeeaea !important;

}

.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background-color: #7e22ce  !important;
    color: white !important;
}
.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable


.price-card {
    transition: all 0.25s ease;
}

.price-card.card-hover-active {
    background-color: rgb(126 34 206 / var(--tw-bg-opacity, 1)) !important; /* azul */
    color: white !important;
    border-color: #2563eb !important;
}

.price-card.card-hover-active h3,
.price-card.card-hover-active p,
.price-card.card-hover-active span,
.price-card.card-hover-active b {
    color: white !important;
}

.price-card.card-hover-active button {
    background-color: white !important;
    color: #2563eb !important;
}



/* ============================
   CARRUSEL REELS — ESTRUCTURA
   ============================ */

.reels-carousel {
    position: relative;
    width: 100%;
}

.reels-viewport {
    overflow: hidden;
    width: 100%;
}

.reels-track {
    display: flex;
    transition: transform 0.5s ease-in-out;
    width: 100%;
}

.reels-item {
    flex: 0 0 100%; /* Móvil: 1 item visible */
    padding: 10px;
}

.reels-img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    border-radius: 18px;
}

/* ============================
   DESKTOP — 4 ITEMS
   ============================ */
@media (min-width: 1024px) {
    .reels-item {
        flex: 0 0 25%; /* 4 items visibles */
    }
    .reels-img {
        height: 220px;
    }
}

/* ============================
   BOTONES DE NAVEGACIÓN
   ============================ */

.reels-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255,255,255,0.8);
    border: none;
    padding: 10px 14px;
    font-size: 24px;
    cursor: pointer;
    border-radius: 50%;
    z-index: 10;
}

.reels-nav.prev { left: -10px; }
.reels-nav.next { right: -10px; }

@media (max-width: 768px) {
    .reels-nav.prev { left: 5px; }
    .reels-nav.next { right: 5px; }
}

