/* Fontes */

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Bold.eot');
    src: url('../fonts/Montserrat-Bold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Montserrat-Bold.woff2') format('woff2'),
        url('../fonts/Montserrat-Bold.woff') format('woff'),
        url('../fonts/Montserrat-Bold.svg#Montserrat-Bold') format('svg');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-SemiBold.eot');
    src: url('../fonts/Montserrat-SemiBold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Montserrat-SemiBold.woff2') format('woff2'),
        url('../fonts/Montserrat-SemiBold.woff') format('woff'),
        url('../fonts/Montserrat-SemiBold.svg#Montserrat-SemiBold') format('svg');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Thin.eot');
    src: url('../fonts/Montserrat-Thin.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Montserrat-Thin.woff2') format('woff2'),
        url('../fonts/Montserrat-Thin.woff') format('woff'),
        url('../fonts/Montserrat-Thin.svg#Montserrat-Thin') format('svg');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Light.eot');
    src: url('../fonts/Montserrat-Light.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Montserrat-Light.woff2') format('woff2'),
        url('../fonts/Montserrat-Light.woff') format('woff'),
        url('../fonts/Montserrat-Light.svg#Montserrat-Light') format('svg');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Medium.eot');
    src: url('../fonts/Montserrat-Medium.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Montserrat-Medium.woff2') format('woff2'),
        url('../fonts/Montserrat-Medium.woff') format('woff'),
        url('../fonts/Montserrat-Medium.svg#Montserrat-Medium') format('svg');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-ExtraLight.eot');
    src: url('../fonts/Montserrat-ExtraLight.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Montserrat-ExtraLight.woff2') format('woff2'),
        url('../fonts/Montserrat-ExtraLight.woff') format('woff'),
        url('../fonts/Montserrat-ExtraLight.svg#Montserrat-ExtraLight') format('svg');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Regular.eot');
    src: url('../fonts/Montserrat-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Montserrat-Regular.woff2') format('woff2'),
        url('../fonts/Montserrat-Regular.woff') format('woff'),
        url('../fonts/Montserrat-Regular.svg#Montserrat-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

/* Cores */

:root {
    --color-primary: #bf0811;
    --color-secondary: #fcc24b;
    --color-white: #fff;
    --color-black: #000;
    --color-gray: #595858;
    --color-light-gray: #efefef;
    --color-gray-bg: #e4e5e6;
}

/* Geral */

body{
    background: var(--color-light-gray);
    font: 16px 'Montserrat', sans-serif;
}

img{
    height: auto;
    max-width: 100%;
}

a{
    text-decoration: none;
}


.shadow-inset {
    box-shadow: inset 0 4px 6px rgba(0, 0, 0, 0.2);
}

/* Header */

.site-header{
    background-color: var(--color-primary);
}

.site-header .brand{
    max-height: 180px;
}

.site-header .header-title h1{
    color: var(--color-white);
    font-size: 33px;
    font-weight: 500;
    text-align: center;
    text-transform: uppercase;
}

.site-header .logo-parceria{
    margin: 5px;
    max-height: 70px;
    width: auto;
}

/* Menu */

.menu-superior{
    background-color: var(--color-secondary);
    color: var(--color-primary);
}

.menu-superior .navbar-nav{
    flex-direction: row;
    justify-content: space-between;
    margin-right: 50px;
    width: 100%;
}

.menu-superior ul{
    margin: 0;
    padding: 0;
}

.menu-superior li{
    display: inline-block;
    list-style: none;
}

.menu-superior a{
    color: var(--color-primary);
    font-size: 18px;
    font-weight: 500;
    text-decoration: none;
    text-transform: uppercase;
}

.menu-superior a:hover{
    color: var(--color-black);
}

/* Menu Hamburguer */

.hamburger-menu{
    display: block;
    height: 35px;
    position: relative;
    transition: all .75s cubic-bezier(.77,0,.175,1);
    width: 86px;
    z-index: 4;
}

.hamburger-menu .inner{
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translate(0%,-50%);
}

.hamburger-menu span:first-child {
    transform-origin: 0 0;
    margin-bottom: 5px;
}

.hamburger-menu span:nth-last-child(2) {
    transform-origin: 0 100%;    
    margin-bottom: 5px;
    transition: all .6s ease;
}

.hamburger-menu span{
    background: var(--color-primary);
    display: block;
    height: 3px;
    opacity: .88;
    position: relative;
    transform-origin: 4px 0;
    transition: transform .5s cubic-bezier(.77,.2,.05,1),background .5s cubic-bezier(.77,.2,.05,1),opacity .55s ease;
    width: 30px;
    z-index: 1;
}

.hamburger-menu:hover span{
    width: 30px;
}

.hamburger-menu.is-active span{
    opacity: 1;
    transform: rotate(45deg);
}

.hamburger-menu.is-active span:first-child {
    transform-origin: 1px 3px;
    margin-bottom: 8px;
    transition: transform .5s cubic-bezier(.77,.2,.05,1),background .5s cubic-bezier(.77,.2,.05,1),opacity .55s ease;
}

.hamburger-menu.is-active span:nth-last-child(2) {
    opacity:0;
    transform:rotate(0deg) scale(.2);
}

.hamburger-menu.is-active span:last-child {
    transform:rotate(-45deg) translateY(-1px)
}

/* Fullscreen Menu */

.full-screen-menu {
    align-items: center;
    background: var(--color-secondary);
    color: #110e0d;
    height: 100vh;
    min-height: 600px;
    overflow: hidden;

    position: fixed;
    text-align: center;
    top: 0;
    transform: translateY(-120%);
    transition: all .4s cubic-bezier(.47,0,.745,.715);
    width: 100%;
    z-index: 3;
}

.full-screen-menu.is-active{
    transform: translateY(0);
    transition: all .4s cubic-bezier(.39,.575,.565,1);
}

.full-screen-menu ul{
    padding: 0;
}

.full-screen-menu li{
    list-style: none;
}

.full-screen-menu li:before{
    content: "" !important;
    margin: 0;
    width: 0;
}

.full-screen-menu .menu-principal a{
    color: var(--color-primary);
    font-weight: 500;
    line-height: 1.5;
    text-transform: uppercase;
    text-decoration: none;
}

.full-screen-menu .info-linha{
    margin-bottom: 15px;
}

.full-screen-menu .info-linha a{
    align-items: center;
    color: #000;
    display: flex;
    text-decoration: none;
}

.full-screen-menu .menu-principal a:hover{
    color: var(--color-black);
}

.full-screen-menu .menu-principal .destaque a{
    color: var(--bs-white);
    padding-left: 10px;
    padding-right: 10px;
    text-decoration: none;
    text-transform: uppercase;
}

.full-screen-menu .menu-principal .destaque:hover{
    background: var(--color-primary);
}

.full-screen-menu .ativo + .sub-menu{
    display: block;
    position: relative;
}

/* Menu Inferior */

.menu-footer a{
    color: var(--color-white);
    font-size: 18px;
    text-decoration: none;
}

.menu-footer a:hover{
    text-decoration: underline;
}

/* Destaque */

.destaque{
    background: url('../img/bg-grid.png') no-repeat center bottom;
}

.destaque .esquerda{
    border-right: 1px solid var(--color-gray);
    padding-right: 30px;
}

.destaque .esquerda .thumbnail img{
    height: 400px;
    object-fit: cover;
}

.destaque .noticia h2{
    color: var(--color-gray);
    font-weight: 700;    
}

.destaque .noticia .link-noticia{
    text-decoration: none;
}

.destaque .noticia .descricao p{
    color: var(--color-gray);
    font-size: 18px;
}

.leia-mais{
    color: var(--color-gray);
    font-size: 20px;
    font-weight: 700;   
    text-decoration: underline; 
}

.destaque .noticia h2:hover,
.leia-mais:hover{
    color: var(--color-primary);
}

.destaque .direita{
    padding-left: 30px;
}

.destaque .direita .noticia,
.destaque .esquerda .noticia{
    margin: 30px 0;
}

.thumbnail img{
    aspect-ratio: 16 / 9;
    transition: transform 0.3s ease;
}

/* CSSB em Ação */

.thumbnail{
    margin-bottom: 15px;
}

.em-acao h2.titulo-em-acao{
    background: var(--color-gray-bg) url('../img/bg-em-acao.jpg') no-repeat center bottom;
    color: var(--color-primary);
    font-weight: 700;
    padding: 40px 0;
    position: relative;
    text-align: center;
    text-transform: uppercase;
    width: 100%;
}

.em-acao .selo-acao{
    bottom: 30px;
    max-height: 60px;
    position: absolute;
    right: 50px;
}

.conquistas h2.titulo-conquistas{
    color: var(--color-primary);
    font-weight: 700;
    margin: 15px auto;
    padding: 15px 0;
    text-align: center;
    text-transform: uppercase;
}

.conquistas .conquista{
    margin-bottom: 30px;
}

.conquistas .link-conquistas{
    color: var(--color-gray);
    text-decoration: none;
}

.conquistas .link-conquistas:hover{
    color: var(--color-primary);
}

.conquistas .link-conquistas h3{
    font-size: 20px;
    font-weight: 700; 
}

.conquistas .thumbnail img{
    height: 250px;
    object-fit: cover;
}

.selo-amarelo h2.titulo-sindicatos{
    background: var(--color-secondary);
    color: var(--color-primary);
    font-weight: 700;
    padding: 15px 0;
    position: relative;
    text-align: center;
    text-transform: uppercase;
    width: 100%;
}

.selo-amarelo .selo-sindicato{
    bottom: 10px;
    max-height: 50px;
    position: absolute;
    right: 50px;
}

/* Vídeos e Fotos */

.videos-e-fotos h2.titulo-videos-e-fotos{
    color: var(--color-primary);
    font-weight: 700;
    margin: 15px auto;
    padding: 15px 0;
    text-align: center;
    text-transform: uppercase;
}

.video-post-item {
    margin-bottom: 30px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.thumbnail {
    position: relative;
    overflow: hidden;
}

.video-post-item .thumbnail img {
    width: 100%;
    aspect-ratio: 235 / 197;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.thumbnail:hover img {
    transform: scale(1.05);
}

.play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0,0,0,0.7);
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    opacity: 0.9;
    transition: opacity 0.3s ease;
}

.video-post-item:hover .play-icon {
    opacity: 1;
}

.video-title {
    font-size: 16px;
    font-weight: 700;
}

.video-title a {
    color: var(--color-gray);
    text-decoration: none;
}

.video-title a:hover {
    color: var(--color-primary);
}

.video-meta {
    font-size: 0.9em;
    color: #666;
    margin-bottom: 10px;
}

.video-excerpt {
    font-size: 0.95em;
    line-height: 1.5;
    color: #555;
    margin-bottom: 15px;
}

.watch-button {
    display: inline-block;
    background: #0073aa;
    color: white;
    padding: 8px 16px;
    border-radius: 4px;
    text-decoration: none;
    font-weight: bold;
    transition: background 0.3s ease;
}

.watch-button:hover {
    background: #005a87;
}

.video-posts-pagination {
    text-align: center;
    margin-top: 40px;
}

.page-numbers {
    display: inline-block;
    padding: 8px 16px;
    margin: 0 5px;
    border: 1px solid #ddd;
    text-decoration: none;
    color: #333;
    border-radius: 4px;
}

.page-numbers.current {
    background: #0073aa;
    color: white;
    border-color: #0073aa;
}

.page-numbers:hover {
    background: #f0f0f0;
}

.no-thumbnail {
    display: block;
    background: var(--color-black);
    height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.video-placeholder {
    color: var(--color-black);
    text-align: center;
}

.video-duration {
    background: rgba(0,0,0,0.8);
    color: white;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 0.8em;
    position: absolute;
    bottom: 10px;
    right: 10px;
}

.galeria-fotos .thumbnail{
    aspect-ratio: 16 / 9;
}

.galeria-fotos .link-galeria h3{
    font-size: 16px;
    font-weight: 700;
}

.galeria-fotos .link-galeria{
    color: var(--color-gray);
}

.galeria-fotos .link-galeria:hover{
    color: var(--color-primary);
}

/* Paginação */

.pagination .page-item.active .page-link {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-white);
}

.pagination .page-link {
    color: var(--color-primary);
}

.pagination .page-link:hover {
    color: var(--color-primary);
}

.news-item {
    padding: 20px 0;
    border-bottom: 1px solid #eee;
}

.news-item:last-child {
    border-bottom: none;
}

/* Responsivo vídeos */
@media (max-width: 768px) {
    .video-posts-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: 20px;
    }
}

@media (max-width: 480px) {
    .video-posts-grid {
        grid-template-columns: 1fr;
    }
}

/* Palavra do Presidente */

.presidente{
    background: var(--color-gray-bg) url('../img/bg-grid.png') no-repeat center bottom;
    padding: 30px 0 0;
}

.presidente .asterisco{
    display: block;
    margin: 10px auto;
}

.palavra-do-presidente p{
    font-size: 16px;
}

.imagem-presidente{
    align-items: flex-end;
    display: flex;
}

.imagem-presidente img{
    height: auto;
    width: 100%;
}

.instagram-feed h3{
    color: var(--color-primary);
    font-weight: 800;
    padding: 30px 0 0;
    text-transform: uppercase;
}

.instagram-feed .feed-placeholder{
    align-items: center;
    background: var(--color-white);
    display: flex;
    height: 340px;
    justify-content: center;
}

/* Páginas e Posts */

.titulo-pagina{
    color: var(--color-primary);
    font-weight: 700;
    margin-bottom: 30px;
    text-transform: uppercase;
}

.post-meta{
    font-size: 14px;
    margin-bottom: 15px;
}

.post-meta .post-author{
    font-weight: 600;
}

.wp-block-video video{
    max-height: 85vh !important;
}

/* Sidebar */

.sidebar h3{
    color: var(--color-primary);
    font-size: 24px;
    font-weight: 700;
    text-transform: uppercase;
}

.sidebar h4{
    font-size: 18px;
    font-weight: 700;
}

.sidebar .link-relacionados{
    color: var(--color-gray);
}

/* Notícias */

.todas-noticias .noticia .thumbnail img{
    height: 250px;
    object-fit: cover;
}

.todas-noticias .noticia h3{
    font-size: 20px;
    font-weight: 700;     
}

.todas-noticias .noticia a{
    color: var(--color-gray);
    text-decoration: none;
}

.todas-noticias .noticia a:hover{
    color: var(--color-primary);
}

/* Footer */

.site-footer{
    background: var(--color-primary);
    color: var(--color-white);
}

.site-footer .newsletter{
    background: var(--color-secondary);
    color: var(--color-primary);
    padding: 10px 0;
}

.site-footer .newsletter h4{
    font-size: 20px;
    font-weight: 800;
    margin: 0;
}

.site-footer .informacoes{
    padding: 15px 0;
}

.site-footer .informacoes h5{
    font-weight: 700;
    text-transform: uppercase;
}

.site-footer .logo-footer{
    height: auto;
    max-width: 100px;
}

.site-footer .logo-psb{
    height: auto;
    max-width: 120px;
}

.site-footer .footer-parcerias .logo-parceria{
    max-height: 50px;
    margin: 10px;
}

.site-footer .copyright{
    border-top: 1px solid var(--color-white);
    font-size: 12px;
    font-weight: 300;
    padding: 10px;
}

/* Redes Sociais */

.social-menu-footer,
.social-menu-header {
    display: flex;
    gap: 10px;
}

.social-icon {
    width: 40px;
    height: 40px;
    background: var(--color-white);
    border: 1px solid var(--color-white);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    position: relative;
}

.social-menu-header .social-icon{
    background: var(--color-primary);
    border: 1px solid var(--color-primary);
}

.social-icon:hover {
    background: 0;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

.social-icon i {
    font-size: 20px;
    transition: all 0.3s ease;
}

/* Instagram  */
.instagram i {
    color: var(--color-primary);
}

.instagram:hover i {
    color: var(--color-white);
}

.social-menu-header .instagram i {
    color: var(--color-secondary);
}

.social-menu-header .instagram:hover i {
    color: var(--color-primary);
}

/* Facebook */
.facebook i {
    color: var(--color-primary);
}

.facebook:hover i {
    color: var(--color-white);
}

.social-menu-header .facebook i {
    color: var(--color-secondary);
}

.social-menu-header .facebook:hover i {
    color: var(--color-primary);
}

/* TikTok */
.tiktok i {
    color: var(--color-primary);
}

.tiktok:hover i {
    color: var(--color-white);
}

.social-menu-header .tiktok i {
    color: var(--color-secondary);
}

.social-menu-header .tiktok:hover i {
    color: var(--color-primary);
}




@media (max-width: 768px){

    .site-header .header-title h1{
        font-size: 16px;
    }

    .site-header .col-3.justify-content-end{
        align-items: center;
        flex-direction: column !important;
    }

    .site-header .col-3.justify-content-end .logo-parceria{
        max-height: 40px;
        max-width: 100%;
    }

    .destaque .noticia .descricao p{
        font-size: 16px;
    }

    .destaque .esquerda .thumbnail img,
    .destaque .noticia .thumbnail{
        height: 250px;
    }

    .destaque .esquerda{
        padding-right: calc(var(--bs-gutter-x) * .5);
    }

    .destaque .direita{
        padding-left: calc(var(--bs-gutter-x) * .5);
    }

    .destaque .esquerda .noticia,
    .destaque .direita .noticia{
        margin-top: 0;
    }

    .em-acao h2.titulo-em-acao{

    }

    .em-acao .selo-acao{
        right: 30px;
    }

    .post .single-thumbnail{
        display: flex;
        margin-bottom: 20px;
        order: 0;
    }

    .post .single-conteudo{
        order: 1;
    }

    .site-footer .brand-footer,
    .site-footer .logo-parceiros{
        text-align: left !important;
    }

    .site-footer .footer-parcerias{
        justify-content: flex-start !important;

    }

    .site-footer .informacoes{
        padding: 15px calc(var(--bs-gutter-x) * .5);
    }

}