/**
 * Neon Promotions — Styles
 * Grid, slider y detalle de promociones
 */

/* ── Programación: ocultas hasta que el JS las revele ─────────────────────── */
/* Se aplica antes del JS para evitar flash de contenido no publicado */
.neon-promo-card--pending,
.neon-promos-slide:has(.neon-promo-card--pending) {
    display: none !important;
}

/* ── Card base ─────────────────────────────────────────────────────────────── */
.neon-promo-card {
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0, 0, 0, .08);
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: box-shadow .25s ease, transform .25s ease;
}

.neon-promo-card:hover {
    box-shadow: 0 6px 24px rgba(0, 0, 0, .14);
    transform: translateY(-3px);
}

/* ── Card image ────────────────────────────────────────────────────────────── */
.neon-promo-card__img {
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: #f1f5f9;
}

.neon-promo-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}

.neon-promo-card__img-link {
    display: block;
    width: 100%;
    height: 100%;
}

.neon-promo-card:hover .neon-promo-card__img img {
    transform: scale(1.04);
}

/* ── Card body ─────────────────────────────────────────────────────────────── */
.neon-promo-card__body {
    padding: 1.1rem 1.2rem 1.4rem;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: .5rem;
}

.neon-promo-card__title {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0;
    line-height: 1.3;
}

.neon-promo-card__title a {
    color: inherit;
    text-decoration: none;
}

.neon-promo-card__title a:hover {
    color: var(--nc-primary);
}

.neon-promo-card__excerpt {
    font-size: .88rem;
    color: #555;
    margin: 0;
    line-height: 1.5;
    flex: 1;
}

.neon-promo-card__btn {
    display: inline-block;
    margin-top: auto;
    padding: .45rem 1.2rem;
    background: var(--nc-primary);
    color: #fff;
    border-radius: 6px;
    font-size: .85rem;
    font-weight: 600;
    text-decoration: none;
    align-self: flex-start;
    transition: background .2s ease;
}

.neon-promo-card__btn:hover {
    background: var(--nc-primary-dk);
    color: #fff;
}

/* ── Grid container ────────────────────────────────────────────────────────── */
.neon-promos-grid {
    display: grid;
    grid-template-columns: repeat(var(--neon-promo-cols, 3), 1fr);
    gap: 1.5rem;
}

@media (max-width: 767px) {
    .neon-promos-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 479px) {
    .neon-promos-grid {
        grid-template-columns: 1fr;
    }
}

/* ── Slider container ──────────────────────────────────────────────────────── */
.neon-promos-slider {
    --neon-slider-cols: 3;
    position: relative;
    overflow: hidden;
    width: 100%;
}

.neon-promos-track {
    display: flex;
    gap: 1.25rem;
    transition: transform .4s ease;
    will-change: transform;
}

/* El ancho de cada slide lo gestiona JS vía --neon-slider-cols */
.neon-promos-slide {
    flex: 0 0 calc((100% - (var(--neon-slider-cols) - 1) * 1.25rem) / var(--neon-slider-cols));
    min-width: 200px;
}

/* Slider nav buttons */
.neon-promos-prev,
.neon-promos-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, .5);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
}

.neon-promos-prev { left: 6px; }
.neon-promos-next { right: 6px; }

.neon-promos-prev:hover,
.neon-promos-next:hover {
    background: rgba(0, 0, 0, .75);
}
/* ── Card layout variants ───────────────────────────────────────────────────── */

/* layout-1: clásico vertical (default, no changes needed) */

/* layout-2: imagen full con texto en overlay degradado inferior */
.neon-promo-card--layout-2 {
    position: relative;
    aspect-ratio: 4 / 3;
}
.neon-promo-card--layout-2 .neon-promo-card__img {
    position: absolute;
    inset: 0;
    aspect-ratio: unset;
    width: 100%;
    height: 100%;
}
.neon-promo-card--layout-2 .neon-promo-card__body {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2;
    background: linear-gradient(to top, rgba(0,0,0,.78) 0%, rgba(0,0,0,0) 100%);
    color: #fff;
    padding: 3rem 1.2rem 1.2rem;
    gap: .4rem;
}
.neon-promo-card--layout-2 .neon-promo-card__title a {
    color: #fff;
}
.neon-promo-card--layout-2 .neon-promo-card__btn {
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.5);
    color: #fff;
}
.neon-promo-card--layout-2 .neon-promo-card__btn:hover {
    background: rgba(255,255,255,.3);
    color: #fff;
}
.neon-promo-card--layout-2:hover { transform: none; }

/* layout-3: horizontal — imagen izquierda, texto derecho */
.neon-promo-card--layout-3 {
    flex-direction: row;
}
.neon-promo-card--layout-3 .neon-promo-card__img {
    width: 38%;
    flex-shrink: 0;
    aspect-ratio: unset;
    align-self: stretch;
}
.neon-promo-card--layout-3 .neon-promo-card__img img {
    height: 100%;
}

/* layout-4: horizontal inverso — texto izquierdo, imagen derecha */
.neon-promo-card--layout-4 {
    flex-direction: row-reverse;
}
.neon-promo-card--layout-4 .neon-promo-card__img {
    width: 38%;
    flex-shrink: 0;
    aspect-ratio: unset;
    align-self: stretch;
}
.neon-promo-card--layout-4 .neon-promo-card__img img {
    height: 100%;
}

/* layout-5: centrado — imagen cuadrada, título y botón centrados */
.neon-promo-card--layout-5 .neon-promo-card__img {
    aspect-ratio: 1 / 1;
}
.neon-promo-card--layout-5 .neon-promo-card__body {
    text-align: center;
    align-items: center;
}

/* layout-6: banner cinemático — imagen ancha con texto en overlay lateral */
.neon-promo-card--layout-6 {
    position: relative;
    aspect-ratio: 16 / 7;
}
.neon-promo-card--layout-6 .neon-promo-card__img {
    position: absolute;
    inset: 0;
    aspect-ratio: unset;
    width: 100%;
    height: 100%;
}
.neon-promo-card--layout-6 .neon-promo-card__body {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2;
    background: linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,0) 100%);
    color: #fff;
    padding: 2.5rem 1.5rem 1.2rem;
    flex-direction: row;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: .75rem;
}
.neon-promo-card--layout-6 .neon-promo-card__title {
    flex: 1 1 60%;
    font-size: 1.2rem;
}
.neon-promo-card--layout-6 .neon-promo-card__title a {
    color: #fff;
}
.neon-promo-card--layout-6 .neon-promo-card__btn {
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.5);
    color: #fff;
    margin-top: 0;
    white-space: nowrap;
}
.neon-promo-card--layout-6 .neon-promo-card__btn:hover {
    background: rgba(255,255,255,.3);
    color: #fff;
}
.neon-promo-card--layout-6:hover { transform: none; }
/* ── Detail view ───────────────────────────────────────────────────────────── */
.neon-promo-detail {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
    padding: 1rem 0;
}

.neon-promo-detail__img {
    flex: 0 0 auto;
    width: 100%;
    max-width: 420px;
    border-radius: 10px;
    overflow: hidden;
    background: #f1f5f9;
}

.neon-promo-detail__img img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.neon-promo-detail__content {
    flex: 1 1 280px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.neon-promo-detail__title {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.25;
    margin: 0;
}

.neon-promo-detail__body {
    font-size: .98rem;
    line-height: 1.7;
    color: #333;
}

.neon-promo-detail__btn {
    display: inline-block;
    padding: .6rem 1.8rem;
    background: var(--nc-primary);
    color: #fff;
    border-radius: 7px;
    font-weight: 600;
    text-decoration: none;
    align-self: flex-start;
    transition: background .2s ease;
}

.neon-promo-detail__btn:hover {
    background: var(--nc-primary-dk);
    color: #fff;
}

.neon-promo-detail__back {
    font-size: .88rem;
    color: #888;
    text-decoration: none;
    align-self: flex-start;
}

.neon-promo-detail__back:hover {
    color: #444;
}

/* ── Detail layout variants ────────────────────────────────────────────── */

/* layout-1: clásico — imagen izquierda, texto derecho (default) */
/* hereda .neon-promo-detail sin cambios */

/* layout-2 (overlay) — en el single: imagen hero ancho completo, texto bajo */
.neon-promo-detail--layout-2 {
    flex-direction: column;
}
.neon-promo-detail--layout-2 .neon-promo-detail__img {
    max-width: 100%;
    width: 100%;
    max-height: 420px;
    overflow: hidden;
}
.neon-promo-detail--layout-2 .neon-promo-detail__img img {
    width: 100%;
    height: 100%;
    max-height: 420px;
    object-fit: cover;
}
.neon-promo-detail--layout-2 .neon-promo-detail__content {
    max-width: 680px;
}

/* layout-3 (horiz. img-izq) — imagen izquierda 45%, texto derecho */
.neon-promo-detail--layout-3 {
    flex-direction: row;
    align-items: flex-start;
    flex-wrap: nowrap;
}
.neon-promo-detail--layout-3 .neon-promo-detail__img {
    flex: 0 0 45%;
    max-width: 45%;
}
.neon-promo-detail--layout-3 .neon-promo-detail__content {
    flex: 1 1 0;
}

/* layout-4 (horiz. img-der) — texto izquierdo, imagen derecha 45% */
.neon-promo-detail--layout-4 {
    flex-direction: row-reverse;
    align-items: flex-start;
    flex-wrap: nowrap;
}
.neon-promo-detail--layout-4 .neon-promo-detail__img {
    flex: 0 0 45%;
    max-width: 45%;
}
.neon-promo-detail--layout-4 .neon-promo-detail__content {
    flex: 1 1 0;
}

/* layout-5 (centrado) — todo centrado, imagen cuadrada */
.neon-promo-detail--layout-5 {
    flex-direction: column;
    align-items: center;
    text-align: center;
}
.neon-promo-detail--layout-5 .neon-promo-detail__img {
    max-width: 420px;
    aspect-ratio: 1 / 1;
    overflow: hidden;
}
.neon-promo-detail--layout-5 .neon-promo-detail__img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.neon-promo-detail--layout-5 .neon-promo-detail__content {
    align-items: center;
}
.neon-promo-detail--layout-5 .neon-promo-detail__btn,
.neon-promo-detail--layout-5 .neon-promo-detail__back {
    align-self: center;
}

/* layout-6 (banner) — imagen hero 16:7 de ancho completo al inicio */
.neon-promo-detail--layout-6 {
    flex-direction: column;
}
.neon-promo-detail--layout-6 .neon-promo-detail__img {
    max-width: 100%;
    width: 100%;
    aspect-ratio: 16 / 7;
    overflow: hidden;
}
.neon-promo-detail--layout-6 .neon-promo-detail__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.neon-promo-detail--layout-6 .neon-promo-detail__content {
    max-width: 780px;
}

/* Responsive: layouts horizontales colapsan en móvil */
@media (max-width: 600px) {
    .neon-promo-detail--layout-3,
    .neon-promo-detail--layout-4 {
        flex-direction: column;
        flex-wrap: wrap;
    }
    .neon-promo-detail--layout-3 .neon-promo-detail__img,
    .neon-promo-detail--layout-4 .neon-promo-detail__img {
        flex: unset;
        max-width: 100%;
        width: 100%;
    }
}
