﻿.festival-banner {
    background-color: #000;
    /*padding: 40px 0 60px 0;*/
    position: relative;
}

.banner-img {
    max-width: 100%;
    height: auto;
}

.banner-cta {
    margin-top: -80px; 
}

    .banner-cta .btn {
        background-color: #ffd400;
        border: none;
        color: #000;
        font-weight: bold;
        padding: 12px 30px;
        border-radius: 25px;
    }

        .banner-cta .btn:hover {
            background-color: #e6be00;
        }

.festival-mostra {
    padding: 60px 0;
    text-align: center;
}

.titulo-mostra {
    color: #fff;
    font-size: 28px;
    font-weight: 600;
}

/* Botões padrão */
.btn-mostra {
    display: inline-block;
    padding: 14px 25px;
    border-radius: 30px;
    font-weight: 600;
    text-decoration: none;
    min-width: 220px;
    transition: 0.2s;
    margin: 10px;
    color: #000;
}

    .btn-mostra:hover {
        transform: translateY(-2px);
        color: #000;
    }

    .btn-mostra:visited {
        color: #000 !important;
    }

/* Cores */
.btn-amarelo-producao {
    background: #ffd400;
}

.btn-roxo-producao {
    background: linear-gradient(90deg, #7b4dff, #6a5cff);
}

.btn-rosa-producao {
    background: linear-gradient(90deg, #ff4dc4, #e94ab8);
}

.btn-verde-producao {
    background: linear-gradient(90deg, #9cff4d, #7ee64d);
}

.festival-votacao {
    color: #fff;
    padding: 60px 0;
}

    .festival-votacao .titulo {
        font-size: 30px;
        font-weight: 600;
        margin-bottom: 20px;
    }

    .festival-votacao .descricao {
        font-size: 18px;
        color: #fff;
        margin-bottom: 40px;
    }

.box-votacao {
    background-color: #000;
    border-radius: 20px;
    padding: 30px;
    margin: 0 auto;
    height: 180px;
    width: 700px;
}

.texto-menor {
    font-size: 16px;
    color: #fff;
}

    .texto-menor.destaque {
        margin-top: 10px;
        font-size: 13px;
        color: #9aa3b2;
    }

.seta span {
    font-size: 28px;
    display: inline-block;
    margin-top: 30px;
}

.texto-direita {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
}

.estrelas-gif {
    max-width: 180px;
}

/*carrossel*/

.carousel {
    display: flex;
    overflow-x: auto;
    scroll-behavior: smooth;
    gap: 16px; /* Espaço entre os cards */
    padding: 10px 0;
}

    .carousel::-webkit-scrollbar {
        display: none; /* Opcional: esconde a barra de rolagem */
    }

.carousel-item {
    min-width: 250px;
    max-width: 250px;
    background-color: #1f1f1f;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    position: relative;
}

    .carousel-item img {
        width: 100%;
        height: 140px;
        object-fit: cover;
    }

.item-info {
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 10px;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
    color: white;
}

.item-title {
    font-weight: bold;
    font-size: 14px;
    color: white;
}

.item-meta {
    font-size: 12px;
    color: #aaa;
}

.stars {
    color: gold;
    font-size: 14px;
    margin-bottom: 5px;
}


.carousel.dragging {
    cursor: grabbing;
    cursor: -webkit-grabbing;
}

.carousel {
    cursor: grab;
    padding: 10px 0;
}

.row-equal {
    display: flex;
    flex-wrap: wrap;
}

    .row-equal > [class*='col-'] {
        display: flex;
        flex-direction: column;
    }

.skeleton {
    background: #333;
    border-radius: 8px;
    animation: pulse 1.5s infinite;
    margin-bottom: 15px;
}

.skeleton-img {
    width: 100%;
    height: 200px;
}

.skeleton-title {
    width: 70%;
    height: 24px;
}

.skeleton-date {
    width: 40%;
    height: 16px;
}

.skeleton-line {
    width: 100%;
    height: 60px;
    margin-bottom: 20px;
}

@keyframes pulse {
    0% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }

    100% {
        opacity: 1;
    }
}



.carousel-skeleton-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 32px 0;
}

.carousel-skeleton {
    display: flex;
    gap: 16px;
    overflow: hidden;
}

.card-skeleton {
    width: 250px;
    min-width: 250px;
    max-width: 250px;
    height: 140px;
    border-radius: 12px;
    background: linear-gradient( 90deg, #2b2b2b 25%, #3a3a3a 50%, #2b2b2b 75% );
    background-size: 200% 100%;
    animation: shimmer 1.4s infinite;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.arrow {
    background: #111;
    color: white;
    border: none;
    font-size: 24px;
    padding: 10px;
    cursor: pointer;
    z-index: 10;
    border-radius: 8px;
}

    .arrow.left {
        margin-right: 10px;
    }

    .arrow.right {
        margin-left: 10px;
    }

.skeleton-box {
    display: block;
    background: linear-gradient(90deg, #2a2a2a 25%, #3a3a3a 37%, #2a2a2a 63%);
    background-size: 400% 100%;
    animation: shimmer 1.4s infinite;
    border-radius: 8px;
}

/* Título "MAIS ASSISTIDOS" */
.titulo-skeleton {
    width: 100px;
    height: 20px;
    margin-bottom: 20px;
    margin-top: 30px;
}

/* Botão */
.btn-skeleton {
    width: 100px;
    height: 38px;
    border-radius: 50px;
}

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }

    100% {
        background-position: 200% 0;
    }
}

@media (max-width: 961px) {
    .carousel-skeleton {
        overflow: hidden;
        justify-content: center;
    }

    .card-skeleton {
        flex: 0 0 100%; /* ou 100% se quiser ocupar toda a largura */
    }

    .carousel-skeleton > .card-skeleton:not(:first-child) {
        display: none;
    }
}

@media (max-width: 961px) {
    .box-titulo,
    .box-texto {
        width: 100%;
    }

    .container-carrossel .btn-assistidos,
    .container-carrossel .box-titulo,
    .btn-skeleton {
        margin-left: 36px;
    }



    .container-carrossel .btn-mostra {
        margin-left: 39px;
    }

    .container-carrossel .assistir-box {
        margin-left: 27px;
    }

    .box-texto {
        margin-top: 10px;
        padding: 0 20px 0 20px;
    }
}




.premios-img {
    max-width: 100%;
}

.festival-noticias-box {
    background: #000;
    border-radius: 25px;
    padding: 40px;
    color: #fff;
}

.noticias-subtitulo {
    color: #fff;
    font-size: 30px;
}

.noticias-titulo {
    color: #ffd400;
    font-size: 32px;
}

.btn-amarelo {
    background: #ffd400;
    color: #000 !important;
    border-radius: 25px;
    padding: 10px 22px;
    font-weight: bold;
    border: none;
}

.img-destaque {
    border-radius: 15px;
}

.conteudo-destaque h2 {
    font-size: 18px;
    margin-top: 15px;
}

.noticia-data {
    font-size: 13px;
    color: #ffd400;
    display: block;
    margin-top: 5px;
}

.card-noticia {
    background: #111;
    border-radius: 15px;
    padding: 10px;
    margin-bottom: 15px;
}

    .card-noticia .thumb {
        border-radius: 10px;
    }

.titulo-card {
    font-size: 14px;
    color: #fff;
    font-weight: 600;
}

.header-noticias {
    display: flex;
    align-items: center;
}

.ler-noticias {
    text-align: right;
}

@media (max-width: 469px) {
    .header-noticias {
        display: block;
        margin-bottom: 20px;
    }

    .ler-noticias {
        text-align: left;
        margin-top: 10px;
    }
}

.box-destaque {
    position: relative;
    display: block;
    border-radius: 20px;
    overflow: hidden;
}

.img-destaque {
    width: 100%;
    height: 320px;
    object-fit: cover;
}

.imagem-wrapper {
    position: relative;
    height: 260px;
    overflow: hidden;
    border-radius: 20px 20px 0 0;
}

@media (max-width: 469px) {
    .imagem-wrapper {
        height: auto;
    }
}

.img-destaque {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.noticia-overlay {
    position: absolute;
    inset: 0;
    border-radius: 20px 20px 0 0; /* importante */

    background: linear-gradient( to bottom, rgba(20, 30, 45, 0) 40%, /* topo transparente */
    rgba(20, 30, 45, 0.4) 60%, /* meio acinzentado */
    rgba(20, 30, 45, 0.8) 75%, /* transição */
    #1b2433 100% /* mesma cor do card */
    );
}

.conteudo-destaque {
    padding: 15px 20px 20px;
    border-radius: 0 0 20px 20px;
}

.box-destaque {
    border-radius: 20px;
    overflow: hidden; /* isso garante que o overlay respeite o corte */
    background: #1b2433;
}

.titulo-card-destaque {
    font-size: 20px;
    color: #fff;
    font-weight: 600;
}

.conteudo-destaque h2 {
    font-size: 18px;
    font-weight: 500;
}

.card-noticia {
    background: linear-gradient(135deg, #0f1724, #1b2433);
    border-radius: 15px;
    padding: 12px;
    margin-bottom: 15px;
    transition: 0.2s;
}

    .card-noticia:hover {
        transform: translateY(-2px);
    }

    .card-noticia .thumb {
        border-radius: 10px;
        height: 80px;
        object-fit: cover;
    }

@media (max-width: 469px) {
    .card-noticia .thumb {
        height: auto;
        margin-bottom: 10px;
    }
}

.festival-noticias-box {
    background: #000;
    border-radius: 30px;
    padding: 30px 40px;
}

@media (max-width: 992px) {
    .coluna-esquerda {
        margin-bottom: 15px;
    }
}

@media (min-width: 992px) {

    .row-flex {
        display: flex;
        align-items: stretch;
    }

    .coluna-esquerda,
    .coluna-direita {
        display: flex;
        flex-direction: column;
    }

    .coluna-direita {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

        .coluna-direita .card-noticia {
            display: flex;
            align-items: center;
        }
}

@media (max-width: 1200px) and (min-width: 992px) {

    .row-flex {
        display: flex;
    }

    .coluna-direita {
        gap: 10px;
    }

    .titulo-card {
        font-size: 13px;
    }
}

.festival-premios {
    margin-bottom: 60px;
}