/* =====================================================================
 * Cartelera Cines ABC - estilos
 * ===================================================================== */

.cartelera-cines,
.cartelera-cines * {
    box-sizing: border-box;
}

.cartelera-cines {
    --cc-brand:       #20CAA5;
    --cc-brand-dark:  #189F82;
    --cc-mint:        #BCE9DD;
    --cc-mint-text:   #1F5B52;
    --cc-green-dark:  #2F5C56;
    --cc-blue:        #5C7B91;
    --cc-blue-hover:  #4A6679;
    --cc-text:        #1C2A39;
    --cc-text-soft:   #6B7280;
    --cc-border:      #D8DDE2;
    --cc-border-soft: #ECEFF2;
    --cc-bg-soft:     #F6F7F8;
    --cc-bg-card:     #FFFFFF;

    font-family: GatterSans, "Helvetica Neue", Arial, sans-serif;
    color: var(--cc-text);
    max-width: 1080px;
    margin: 0 auto;
    padding: 40px 24px 80px;
    background: transparent;
}

/* ---------- Cabecera ------------------------------------------------- */
.cartelera-cines__header {
    margin-bottom: 24px;
}

.cartelera-cines__title {
    font-family: GatterSans, sans-serif;
    font-size: 28px;
    line-height: 1.2;
    font-weight: 700;
    color: var(--cc-text);
    margin: 0 0 6px;
}

.cartelera-cines__subtitle {
    font-size: 14px;
    color: var(--cc-text-soft);
    margin: 0;
}

/* ---------- Barra de fechas ----------------------------------------- */
.cartelera-cines__dates {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 0 24px;
    border: 0;
    border-bottom: 1px solid var(--cc-border-soft);
    background: transparent;
    margin-bottom: 32px;
    min-height: 56px;
}

.cartelera-cines__dates-label {
    font-size: 14px;
    font-weight: 500;
    color: var(--cc-brand);
    padding: 0 4px;
    flex-shrink: 0;
}

/* ----- flechas: cuadradas redondeadas, fondo blanco con borde sutil ----- */
.cartelera-cines__dates-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 56px;
    border-radius: 10px;
    border: 1px solid var(--cc-border);
    background: var(--cc-bg-card);
    color: var(--cc-brand);
    cursor: pointer;
    flex-shrink: 0;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}

.cartelera-cines__dates-arrow:hover {
    background: #F6FCFB;
    border-color: var(--cc-brand);
    color: var(--cc-brand-dark);
}

.cartelera-cines__dates-arrow[disabled] {
    opacity: .35;
    cursor: not-allowed;
}

.cartelera-cines__dates-arrow[disabled]:hover {
    background: var(--cc-bg-card);
    border-color: var(--cc-border);
    color: var(--cc-brand);
}

/* ----- botón calendario: cuadrado verde sólido con icono blanco ----- */
.cartelera-cines__dates-calendar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 10px;
    border: 0;
    background: var(--cc-brand);
    color: #fff;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .15s ease, transform .1s ease;
}

.cartelera-cines__dates-calendar:hover {
    background: var(--cc-brand-dark);
}

.cartelera-cines__dates-calendar:active {
    transform: scale(.97);
}

/* Iconos SVG dentro de los botones: a prueba de CSS global del tema.
 * Algunos resets de WP/Bootstrap colapsan el width/height del svg dentro
 * de <button>, así que forzamos tamaño con min-width/min-height y !important.
 */
.cartelera-cines__dates-arrow svg,
.cartelera-cines__dates-calendar svg {
    display: inline-block !important;
    vertical-align: middle !important;
    pointer-events: none;
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    min-height: 16px !important;
    flex-shrink: 0;
}

.cartelera-cines__dates-calendar svg {
    width: 22px !important;
    height: 22px !important;
    min-width: 22px !important;
    min-height: 22px !important;
}

.cartelera-cines__dates-arrow svg path,
.cartelera-cines__dates-calendar svg path {
    fill: currentColor !important;
}

.cartelera-cines__dates-track {
    display: flex;
    flex: 1 1 auto;
    gap: 8px;
    overflow: hidden;
    scroll-behavior: smooth;
}

/* ----- chips de día: tarjeta rectangular blanca con borde ----- */
.cartelera-cines__date-chip {
    flex: 1 0 0;
    min-width: 0;
    padding: 8px 6px;
    height: 56px;
    border-radius: 10px;
    border: 1px solid var(--cc-border);
    background: var(--cc-bg-card);
    text-align: center;
    cursor: pointer;
    line-height: 1.15;
    color: var(--cc-text);
    font-family: inherit;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.cartelera-cines__date-chip strong,
.cartelera-cines__date-chip span {
    display: block;
}

.cartelera-cines__date-chip strong {
    font-size: 13px;
    font-weight: 400;
    text-transform: capitalize;
}

.cartelera-cines__date-chip span {
    font-size: 13px;
    font-weight: 700;
    color: var(--cc-text);
    margin-top: 3px;
}

/* Etiqueta usada sólo en mobile (oculta en desktop) */
.cartelera-cines__date-chip-mobile {
    display: none;
    font-style: normal;
    font-size: 14px;
    font-weight: 600;
    color: var(--cc-text);
}

/* Hover defensivo: el tema/Bootstrap pone fondo oscuro a button:hover, lo
 * neutralizamos para mantener el chip en blanco con borde verde. */
.cartelera-cines__date-chip:hover,
.cartelera-cines__date-chip:focus,
.cartelera-cines__date-chip:focus-visible {
    background: var(--cc-bg-card) !important;
    color: var(--cc-text) !important;
    border-color: var(--cc-brand) !important;
    outline: none;
}

.cartelera-cines__date-chip:hover strong,
.cartelera-cines__date-chip:hover span {
    color: var(--cc-text) !important;
}

.cartelera-cines__date-chip.is-active,
.cartelera-cines__date-chip.is-active:hover,
.cartelera-cines__date-chip.is-active:focus {
    background: var(--cc-brand) !important;
    color: #fff !important;
    border-color: var(--cc-brand) !important;
    box-shadow: 0 4px 12px rgba(32, 202, 165, .25);
}

.cartelera-cines__date-chip.is-active strong,
.cartelera-cines__date-chip.is-active span,
.cartelera-cines__date-chip.is-active:hover strong,
.cartelera-cines__date-chip.is-active:hover span {
    color: #fff !important;
    opacity: .95;
}

.cartelera-cines__date-chip.is-empty:not(.is-active) {
    opacity: .45;
}

/* En móvil mostramos sólo el chip activo con texto largo */
.cartelera-cines__date-chip--single {
    flex: 1 1 auto;
    text-align: center;
    padding: 8px 14px;
}

.cartelera-cines__date-chip--single strong {
    font-size: 13px;
    text-transform: none;
}

.cartelera-cines__date-chip--single span {
    display: none;
}

/* ---------- Tarjetas de película ----------------------------------- */
.cartelera-cines__list {
    display: flex;
    flex-direction: column;
    gap: 36px;
}

.cc-movie {
    display: grid;
    grid-template-columns: 160px 1fr;
    grid-template-areas:
        "poster   info"
        "cta      cta"
        "syntitle syntitle"
        "synopsis synopsis";
    column-gap: 24px;
    row-gap: 16px;
    align-items: start;
    padding-bottom: 28px;
    border-bottom: 1px solid var(--cc-border-soft);
}

.cc-movie:last-child {
    border-bottom: 0;
}

.cc-movie__poster {
    grid-area: poster;
    width: 160px;
    height: 240px;
    border-radius: 8px;
    object-fit: cover;
    background: var(--cc-bg-soft);
}

/* Columna derecha: título, clasificación y sesiones apilados sin huecos */
.cc-movie__info {
    grid-area: info;
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
}

.cc-movie__body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
}

.cc-movie__cta {
    grid-area: cta;
}

.cc-movie__synopsis-title {
    grid-area: syntitle;
}

.cc-movie__synopsis {
    grid-area: synopsis;
}

.cc-movie__title {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: var(--cc-text);
    line-height: 1.25;
}

.cc-movie__meta {
    color: var(--cc-text-soft);
    font-size: 14px;
    font-weight: 400;
    margin-left: 6px;
}

.cc-movie__age {
    display: inline-flex;
    align-items: center;
    background: var(--cc-mint);
    color: var(--cc-mint-text);
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    width: fit-content;
}

.cc-movie__sessions {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* Cada grupo (idioma/formato) ocupa dos líneas: label arriba, chips debajo */
.cc-session-group {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
}

.cc-session-group__label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--cc-text);
    font-weight: 500;
}

.cc-session-group__label .cc-flag {
    width: 18px;
    height: 12px;
    border-radius: 2px;
    overflow: hidden;
    flex-shrink: 0;
}

.cc-session-group__label .cc-flag--es {
    background: linear-gradient(to bottom, #C60B1E 33%, #FFC400 33%, #FFC400 66%, #C60B1E 66%);
}

.cc-session-group__label .cc-flag--val {
    background: repeating-linear-gradient(
        to bottom,
        #FFD800 0,
        #FFD800 2px,
        #C60B1E 2px,
        #C60B1E 4px
    );
    border-left: 3px solid #0033A0;
}

.cc-session-group__label .cc-cc {
    font-size: 14px;
}

/* Fila de chips de hora: rectángulos con borde, distribuidos uniformemente */
.cc-session-group__row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cc-session-chip {
    flex: 0 0 auto;
    min-width: 96px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
    border-radius: 8px;
    border: 1px solid var(--cc-border);
    background: var(--cc-bg-card);
    font-size: 14px;
    color: var(--cc-text);
    cursor: pointer;
    font-family: inherit;
    text-decoration: none;
    transition: background .15s ease, border-color .15s ease;
}

.cc-session-chip:hover,
.cc-session-chip:focus,
.cc-session-chip:focus-visible {
    background: var(--cc-brand) !important;
    color: #fff !important;
    border-color: var(--cc-brand) !important;
    outline: none;
    box-shadow: 0 4px 12px rgba(32, 202, 165, .22);
}

.cc-movie__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--cc-blue);
    color: #fff;
    padding: 14px 26px;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    border: 0;
    cursor: pointer;
    text-decoration: none;
    width: fit-content;
    margin-top: 10px;
    transition: background .15s ease;
}

.cc-movie__cta:hover {
    background: var(--cc-blue-hover);
    color: #fff;
}

.cc-movie__synopsis-title {
    margin: 4px 0 4px;
    font-size: 14px;
    font-weight: 600;
    color: var(--cc-text);
}

.cc-movie__synopsis {
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
    color: var(--cc-text-soft);
}

/* Botón "Leer más" / "Leer menos": solo visible en mobile */
.cc-movie__synopsis-toggle {
    display: none;
    align-self: flex-start;
    margin: 4px 0 0;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--cc-brand);
    font-family: inherit;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: underline;
}

.cc-movie__synopsis-toggle:hover,
.cc-movie__synopsis-toggle:focus {
    color: var(--cc-brand-dark) !important;
    background: transparent !important;
    outline: none;
}

/* ---------- Empty / error ------------------------------------------ */
.cartelera-cines__empty {
    padding: 40px 16px;
    text-align: center;
    color: var(--cc-text-soft);
    font-size: 14px;
    background: var(--cc-bg-soft);
    border-radius: 12px;
}

.cartelera-error {
    padding: 16px 20px;
    background: #FDECEC;
    color: #8A1F1F;
    border-radius: 8px;
    font-family: GatterSans, sans-serif;
    font-size: 14px;
    margin: 24px auto;
    max-width: 720px;
    text-align: center;
}

/* ---------- Modal calendario --------------------------------------- */
.cartelera-cal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(20, 32, 48, .45);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    z-index: 999999;
    padding: 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s ease, visibility 0s linear .25s, background-color .25s ease;
}

.cartelera-cal-overlay.is-open {
    opacity: 1;
    visibility: visible;
    transition: opacity .25s ease, visibility 0s linear 0s, background-color .25s ease;
}

.cartelera-cal-overlay[hidden] {
    display: none;
}

/* Bottom-sheet en mobile: desliza desde abajo */
.cartelera-cal-overlay .cartelera-cal {
    transform: translateY(100%);
    transition: transform .32s cubic-bezier(.16, .68, .4, 1);
    will-change: transform;
}

.cartelera-cal-overlay.is-open .cartelera-cal {
    transform: translateY(0);
}

/* Modo popover (desktop): el overlay no oscurece y el calendario se posiciona
 * en absoluto por el JS junto al botón del calendario. */
.cartelera-cal-overlay.is-popover {
    background: transparent;
    pointer-events: none;
}

.cartelera-cal-overlay.is-popover .cartelera-cal {
    pointer-events: auto;
    width: 360px;
    max-width: calc(100vw - 16px);
    border-radius: 16px;
    padding: 20px 18px 22px;
    box-shadow: 0 12px 32px rgba(0,0,0,.18), 0 0 0 1px rgba(0,0,0,.05);
    transform: translateY(-6px);
    opacity: 0;
    transition: transform .18s ease, opacity .18s ease;
    will-change: transform, opacity;
}

.cartelera-cal-overlay.is-popover.is-open .cartelera-cal {
    transform: translateY(0);
    opacity: 1;
}

.cartelera-cal {
    background: #fff;
    width: 100%;
    max-width: 420px;
    border-radius: 24px 24px 0 0;
    padding: 24px 22px 28px;
    font-family: GatterSans, sans-serif;
    color: var(--cc-text, #1C2A39);
    box-shadow: 0 -10px 40px rgba(0,0,0,.18);
    max-height: 90vh;
    display: flex;
    flex-direction: column;
}

.cartelera-cal__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 18px;
}

.cartelera-cal__title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
}

.cartelera-cal__close {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 0;
    background: transparent;
    color: var(--cc-text, #1C2A39);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.cartelera-cal__close:hover {
    background: #F2F2F2;
}

.cartelera-cal__close svg {
    display: inline-block !important;
    width: 14px;
    height: 14px;
    pointer-events: none;
}

.cartelera-cal__close svg path {
    stroke: currentColor !important;
    fill: none !important;
}

.cartelera-cal__weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
    color: #1C2A39;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 12px;
}

.cartelera-cal__weekdays span {
    text-align: center;
    padding: 4px 0;
}

.cartelera-cal__months {
    overflow-y: auto;
    flex: 1 1 auto;
    padding-right: 4px;
}

.cc-cal-month {
    margin-bottom: 22px;
}

.cc-cal-month__title {
    margin: 0 0 10px;
    font-size: 14px;
    font-weight: 500;
    color: #1C2A39;
}

.cc-cal-month__grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
    text-align: center;
}

.cc-cal-day {
    height: 34px;
    width: 34px;
    margin: 0 auto;
    border-radius: 50%;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-size: 14px;
    color: #1C2A39;
    font-family: inherit;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background .15s ease, color .15s ease;
}

.cc-cal-day.is-empty {
    cursor: default;
    visibility: hidden;
}

.cc-cal-day.is-past {
    color: #C7CDD3;
    cursor: not-allowed;
}

/* Hoy: solo el número en verde de marca, sin fondo */
.cc-cal-day.is-today {
    background: transparent;
    color: var(--cc-brand, #20CAA5);
    font-weight: 600;
}

/* Día seleccionado por el usuario: círculo oscuro con número blanco */
.cc-cal-day.is-selected {
    background: var(--cc-blue, #5C7B91);
    color: #fff;
    font-weight: 600;
}

.cc-cal-day:not(.is-past):not(.is-today):not(.is-selected):hover {
    background: var(--cc-border-soft, #ECEFF2);
}

.cc-cal-day.has-sessions:not(.is-today):not(.is-selected) {
    position: relative;
    font-weight: 600;
}

.cc-cal-day.has-sessions:not(.is-today):not(.is-selected)::after {
    content: '';
    position: absolute;
    bottom: 3px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--cc-green-dark, #2F5C56);
}

.cartelera-cal__footer {
    margin-top: 16px;
}

.cartelera-cal__confirm {
    width: 100%;
    background: var(--cc-blue, #5C7B91);
    color: #fff;
    border: 0;
    border-radius: 999px;
    padding: 14px 20px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: background .15s ease;
}

.cartelera-cal__confirm:hover {
    background: var(--cc-blue-hover, #4A6679);
}

/* ---------- Responsive --------------------------------------------- */
@media (max-width: 767px) {
    .cartelera-cines {
        padding: 24px 16px 60px;
    }

    .cartelera-cines__title {
        font-size: 22px;
    }

    .cartelera-cines__dates {
        padding: 6px 8px;
        gap: 6px;
    }

    .cartelera-cines__dates-label {
        display: none;
    }

    /* En móvil ocultamos el track multi-fechas y mostramos sólo el chip único */
    .cartelera-cines__dates-track .cartelera-cines__date-chip:not(.is-active) {
        display: none;
    }

    .cartelera-cines__date-chip {
        flex: 1 1 auto;
    }

    /* Texto en una sola línea: ocultamos strong+span, mostramos la etiqueta mobile */
    .cartelera-cines__date-chip strong,
    .cartelera-cines__date-chip span {
        display: none !important;
    }

    .cartelera-cines__date-chip-mobile {
        display: block;
    }

    /* En mobile el chip activo NO es verde: solo borde gris y fondo blanco */
    .cartelera-cines__date-chip.is-active,
    .cartelera-cines__date-chip.is-active:hover,
    .cartelera-cines__date-chip.is-active:focus {
        background: var(--cc-bg-card) !important;
        color: var(--cc-text) !important;
        border-color: var(--cc-border) !important;
        box-shadow: none !important;
    }

    .cartelera-cines__date-chip.is-active .cartelera-cines__date-chip-mobile {
        color: var(--cc-text) !important;
    }

    /* display:contents hace que los hijos de info (body + sessions) se traten
     * como hijos directos del grid del card, para poder posicionarlos en
     * filas distintas en mobile. */
    .cc-movie__info {
        display: contents;
    }

    .cc-movie {
        grid-template-columns: 110px 1fr;
        grid-template-areas:
            "poster   head"
            "sessions sessions"
            "syntitle syntitle"
            "synopsis synopsis"
            "stoggle  stoggle"
            "cta      cta";
        column-gap: 14px;
        row-gap: 14px;
    }

    .cc-movie__body         { grid-area: head; }
    .cc-movie__sessions     { grid-area: sessions; }
    .cc-movie__synopsis-title { grid-area: syntitle; }
    .cc-movie__synopsis     { grid-area: synopsis; }
    .cc-movie__synopsis-toggle { grid-area: stoggle; }
    .cc-movie__cta          { grid-area: cta; }

    /* Mostrar botón "Leer más" en mobile y truncar la sinopsis cuando esté colapsada */
    .cc-movie__synopsis-toggle {
        display: inline-block;
    }

    .cc-movie__synopsis.is-collapsed {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        overflow: hidden;
    }

    .cc-movie__poster {
        width: 110px;
        height: 165px;
    }

    .cc-movie__title {
        font-size: 15px;
    }

    .cc-movie__meta {
        display: block;
        margin-left: 0;
        margin-top: 2px;
        font-size: 12px;
    }

    .cc-movie__cta {
        width: 100%;
    }

    .cc-session-group {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .cc-session-group__row {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 8px;
        width: 100%;
    }

    .cc-session-chip {
        width: 100%;
    }
}
