/* home.css — overrides finales */

:root {
    --ui-pad-x: clamp(24px, 4vw, 54px) !important;
    --hero-synopsis-maxw: clamp(320px, 66vw, 720px) !important;
}

.home-hero-inner {
    padding: 0 clamp(1em, 2vw, 2em) !important;
    width: 100% !important;
    transform: scale(1.3) !important;
    transform-origin: left bottom !important;
}

/* HEADER RESPONSIVE */
.topnav .nav-inner {
    display: grid !important;
    grid-template-columns: auto minmax(220px, 386px) auto !important;
    align-items: center !important;
    gap: clamp(10px, 1.4vw, 18px) !important;
    width: 100% !important;
}

.nav-left,
.nav-center,
.nav-right {
    min-width: 0 !important;
}

.nav-left {
    display: flex !important;
    align-items: center !important;
    gap: clamp(8px, 1vw, 14px) !important;
    flex-wrap: nowrap !important;
}

.nav-center {
    display: flex !important;
    justify-content: center !important;
    min-width: 0 !important;
}

.nav-right {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: clamp(8px, 1vw, 10px) !important;
    min-width: 0 !important;
}

.topnav-search-wrap {
    width: 100% !important;
    max-width: 386px !important;
    min-width: 0 !important;
}

.topnav-search,
.topnav-search-input {
    width: 100% !important;
    min-width: 0 !important;
}

/* HEADER + HERO FLOW */
.topnav {
    position: absolute !important;
}

main.container {
    padding-top: 0 !important;
}

/* TABLET */
@media (max-width: 980px) {
    .topnav {
        position: relative !important;
    }

    .topnav .nav-inner {
        grid-template-columns: 1fr auto !important;
        grid-template-areas:
            "left right"
            "center center" !important;
    }

    .nav-left {
        grid-area: left !important;
        flex-wrap: wrap !important;
    }

    .nav-center {
        grid-area: center !important;
        width: 100% !important;
        justify-content: stretch !important;
    }

    .nav-right {
        grid-area: right !important;
    }

    .topnav-search-wrap {
        max-width: none !important;
    }

    .hero {
        margin-top: 0 !important;
    }

    .carousel {
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: calc(50% - 50vw) !important;
        margin-right: calc(50% - 50vw) !important;
    }

    .section {
        margin-top: 18px !important;
    }
}

/* MOBILE */
@media (max-width: 640px) {
    .topnav .nav-inner {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "left"
            "center"
            "right" !important;
        align-items: stretch !important;
    }

    .nav-left,
    .nav-right {
        width: 100% !important;
        justify-content: flex-start !important;
        flex-wrap: wrap !important;
    }

    .nav-center {
        width: 100% !important;
    }

    .topnav-search {
        height: 42px !important;
    }

    .topnav-search-input {
        font-size: 14px !important;
    }

    .brand-logo {
        width: clamp(110px, 42vw, 180px) !important;
    }

    .navlink,
    .pill,
    .btn {
        font-size: 13px !important;
    }

    .hero {
        margin-top: 0 !important;
        height: clamp(360px, 86vw, 520px) !important;
        min-height: clamp(360px, 86vw, 520px) !important;
        padding-top: 18px !important;
    }

    .home-hero-inner {
        transform: scale(1) !important;
        zoom: 1 !important;
        padding: 0 1em !important;
    }

    .home-hero-layout {
        align-items: flex-end !important;
    }

    .home-hero-left,
    .home-hero-synopsis {
        max-width: 100% !important;
    }

    :root {
        --hero-synopsis-maxw: 100% !important;
    }
}

/* EXTRA CHICO */
@media (max-width: 380px) {

    .nav-left,
    .nav-right {
        gap: 6px !important;
    }

    .topnav-search {
        padding: 0 10px !important;
    }

    .topnav-search-input::placeholder {
        font-size: 12px !important;
    }
}

/* =========================================================
   QUICK MODAL — TITLE ROW + (+) MYLIST + "Mas info"
========================================================= */

#card-quick-modal-root .card-quick-modal-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 0 0 10px 0;
}

/* Botón "+" dentro del modal (mismo ícono) */
#card-quick-modal-root .card-quick-modal-mylist-btn {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .18);
    background: rgba(14, 20, 32, .55);
    backdrop-filter: blur(8px);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    touch-action: manipulation;
    transition: background .18s ease, border-color .18s ease, transform .18s ease;
}

#card-quick-modal-root .card-quick-modal-mylist-btn:hover {
    background: rgba(14, 20, 32, .88);
    border-color: #fff;
    transform: scale(1.06);
}

#card-quick-modal-root .card-quick-modal-mylist-btn:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 2px;
}

/* Estado activo (en Mi Lista) */
#card-quick-modal-root .card-quick-modal-mylist-btn.is-active,
.card-mylist-plus-btn.is-active {
    border: 1px solid rgba(255, 255, 255, .18);
    background: rgba(14, 20, 32, .55);
    color: #fff;
}

/* evita click "caído" en el path */
#card-quick-modal-root .card-quick-modal-mylist-btn svg,
#card-quick-modal-root .card-quick-modal-mylist-btn path {
    pointer-events: none;
}

/* "Mas info" — recuadro blanco SIN fondo */
#card-quick-modal-root .card-quick-modal-more-info {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    margin-top: 14px;
    padding: 10px 16px;

    border-radius: var(--ep-radius);
    border: 2px solid #fff;
    background: transparent;

    color: #fff;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;

    min-height: var(--control-h);
    line-height: 1;

    transition: background .18s ease, transform .18s ease, opacity .18s ease;
}

#card-quick-modal-root .card-quick-modal-more-info:hover {
    background: rgba(255, 255, 255, .10);
    /* sigue siendo "sin fondo" (solo tinta suave) */
    transform: scale(1.02);
}

#card-quick-modal-root .card-quick-modal-more-info:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 2px;
}

/* Mobile tuning */
@media (max-width: 768px) {
    #card-quick-modal-root .card-quick-modal-mylist-btn {
        width: 40px;
        height: 40px;
    }

    #card-quick-modal-root .card-quick-modal-more-info {
        width: 100%;
        justify-content: center;
    }
}

#card-quick-modal-root .card-quick-modal-mylist-float,
#card-quick-modal-root .card-quick-modal-mylist-float svg,
#card-quick-modal-root .card-quick-modal-mylist-float path {
    color: #fff !important;
    fill: #fff !important;
}

/* =========================================================
   ✅ CARD: Botón "Mas info" (al lado del título) — bien estilizado
   (sin fondo, borde blanco, pill, hover suave)
========================================================= */

.card .card-title .card-more-info-btn {
    /* reset button */
    appearance: none;
    -webkit-appearance: none;
    border: 2px solid #fff !important;
    background: transparent !important;
    color: #fff !important;

    /* look */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 2px 5px;
    border-radius: .25em;
    /* pill */
    font-weight: 800;
    font-size: 12px;
    line-height: 1;
    letter-spacing: .02em;

    /* comportamiento */
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
    flex: 0 0 auto;

    /* feel */
    opacity: .92;
    transform: translateZ(0);
    transition: transform .18s ease, background .18s ease, opacity .18s ease;
    top: 62% !important;
    right: 4px !important;
}

.card-more-info-btn {
    display: none !important;
}

.card-more-info-btn span {
    margin-top: 0.1em;
}

.card .card-title .card-more-info-btn:hover {
    background: #fff !important;
    /* sigue "sin fondo", solo tinta suave */
    opacity: 1;
    transform: scale(1.03);
    color: #000 !important;
}

.card .card-title .card-more-info-btn:active {
    transform: scale(.98);
}

.card .card-title .card-more-info-btn:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 2px;
}

/* Mobile tuning */
@media (max-width: 768px) {
    .card .card-title .card-more-info-btn {
        padding: 6px 10px;
        font-size: 11px;
    }
}

/* =========================================================
   QUICK MODAL — MYLIST FLOAT (+ / -) ARRIBA DEL VOLUMEN
   (JS crea: .card-quick-modal-mylist-float)
========================================================= */

/* Aseguramos que el contenedor sea referencia para absolute */
#card-quick-modal-root .card-quick-modal-media-wrap {
    position: relative !important;
}

/* El float de Mi Lista */
#card-quick-modal-root .card-quick-modal-mylist-float {
    position: absolute !important;
    right: 14px !important;

    /* volumen está en bottom:14px y mide ~44px, lo subimos arriba */
    bottom: calc(14px + 44px + 10px) !important;

    z-index: 9 !important;
    /* arriba de video + shade + volumen */
    width: 44px !important;
    height: 44px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 255, 255, .18) !important;
    background: rgba(14, 20, 32, .55) !important;
    backdrop-filter: blur(6px) !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    touch-action: manipulation !important;

    color: #fff !important;
    pointer-events: auto !important;
}

/* Hover */
#card-quick-modal-root .card-quick-modal-mylist-float:hover {
    background: rgba(14, 20, 32, .88) !important;
    border-color: #fff !important;
}

/* Icono adentro */
#card-quick-modal-root .card-quick-modal-mylist-float svg {
    width: 18px !important;
    height: 18px !important;
    display: block !important;
    fill: currentColor !important;
}

/* Evita que el click "caiga" al path */
#card-quick-modal-root .card-quick-modal-mylist-float svg,
#card-quick-modal-root .card-quick-modal-mylist-float path {
    pointer-events: none !important;
}

/* Mobile tuning */
@media (max-width: 768px) {
    #card-quick-modal-root .card-quick-modal-mylist-float {
        width: 40px !important;
        height: 40px !important;
        bottom: calc(10px + 40px + 10px) !important;
        /* si tu volumen baja a 40 */
        right: 10px !important;
    }
}

/* =========================================================
   FIX CARD TOP RADIUS
   La card necesita overflow visible para el hover Prime,
   entonces el radio lo tienen que aplicar los hijos visuales.
========================================================= */

/* Card base */
.card {
    border-radius: var(--radius) !important;
}

/* Miniatura normal */
.card>.thumb {
    border-radius: var(--radius) var(--radius) 0 0 !important;
    overflow: hidden !important;
}

/* Si el background-image está en .thumb, esto ya alcanza.
   Pero si adentro hay overlays/badges/progress, también quedan recortados. */
.card>.thumb::before,
.card>.thumb::after {
    border-radius: inherit !important;
}

/* Overlay hover Prime */
.card-hover-overlay {
    border-radius: var(--radius) !important;
    overflow: hidden !important;
}

/* Parte superior del overlay */
.card-hover-overlay-inner {
    border-radius: inherit !important;
    overflow: hidden !important;
}

.card-hover-overlay-media {
    border-radius: var(--radius) var(--radius) 0 0 !important;
    overflow: hidden !important;
}

/* El wrapper que crea el JS para video/poster */
.card-hover-overlay-media .card-quick-modal-media,
.card-hover-overlay-media .card-quick-modal-poster {
    border-radius: inherit !important;
    overflow: hidden !important;
}

/* Video / poster */
.card-hover-overlay-media .card-quick-modal-video,
.card-hover-overlay-media .card-quick-modal-poster-img {
    border-radius: inherit !important;
    overflow: hidden !important;
}

/* Evita que el badge tape el borde superior derecho cuadrado */
.card .card-badge {
    border-top-right-radius: var(--radius) !important;
}

/* Evita que overlay de colección rompa visualmente el borde */
.card .card-collection-overlay {
    overflow: hidden !important;
}

/* =========================================================
   FIX CONTINUE WATCHING PROGRESSBAR
   El progressbar vive dentro de .thumb y sale hacia abajo.
   No puede estar recortado por overflow:hidden.
========================================================= */

/* La thumb mantiene bordes redondeados, pero deja salir la barra */
.card>.thumb {
    border-radius: var(--radius) var(--radius) 0 0 !important;
    overflow: visible !important;
}

/* El fondo de la thumb sigue respetando el radius aunque overflow sea visible */
.card>.thumb {
    background-clip: padding-box !important;
}

/* Progressbar visible sobre la card */
.card .progressbar {
    z-index: 8 !important;
    overflow: hidden !important;
}

/* En Continuar viendo, aseguramos que no quede detrás ni cortada */
#continue-row .card {
    overflow: visible !important;
}

#continue-row .thumb {
    overflow: visible !important;
}

#continue-row .progressbar {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 20 !important;
}