:root{
    --orange:#f18d3e;
    --black:#000000;
    --white:#ffffff;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    background:#fff;
    color:#111;
    font-family:'Poppins',sans-serif;
    overflow-x:hidden;
}
/* =========================
   botao-ocohost-esquerda-direita
========================= */
.botao-ocohost {
    opacity: 0;
    transform: translateX(-80px);
    transition:
        opacity .8s ease,
        transform 1s cubic-bezier(.22,.61,.36,1);
}

.botao-ocohost.animar {
    opacity: 1;
    transform: translateX(0);
}

.botao-ocohost .wp-block-button__link {
    transition: all .3s ease;
}

.botao-ocohost .wp-block-button__link:hover {
    transform: translateY(-3px);
}

/* =========================
   botao-ocohost-direita-esquerda
========================= */
.botao-ocohost-d-e {
    opacity: 0;
    transform: translateX(80px);
    transition:
        opacity .8s ease,
        transform 1s cubic-bezier(.22,.61,.36,1);
}

.botao-ocohost-d-e.animar {
    opacity: 1;
    transform: translateX(0);
}

.botao-ocohost-d-e .wp-block-button__link {
    transition: all .3s ease;
}

.botao-ocohost-d-e .wp-block-button__link:hover {
    transform: translateY(-3px);
}


.logos-slider {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: center !important;

    width: max-content !important;
    max-width: none !important;

    gap: 80px !important;
}

.logos-slider .wp-block-image {
    flex: 0 0 auto !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
}

.logos-slider .wp-block-image img {
    display: block;
    height: 80px;
    width: auto;
    max-width: none !important;
}
.logos-slider .wp-block-image img {
    height: 55px !important;
    width: auto !important;
}
.logos-container{
    overflow:hidden;
    width:100%;
    position:relative;
}
.logos-container::before,
.logos-container::after{
    content:"";
    position:absolute;
    top:0;
    width:100px;
    height:100%;
    z-index:10;
    pointer-events:none;
}

.logos-container::before{
    left:0;
    background:linear-gradient(to right,#fff,transparent);
}

.logos-container::after{
    right:0;
    background:linear-gradient(to left,#fff,transparent);
}

#site-intro{

    position:fixed;

    inset:0;

    background:#000;

    z-index:9999999;

    display:flex;

    align-items:center;

    justify-content:center;
}

.intro-content{

    text-align:center;

    color:#fff;
}

.intro-content img{

    max-width:220px;

    filter:
    drop-shadow(
        0 0 20px
        rgba(241,141,62,.35)
    );
}

/* =========================
   CONTAINER PADRÃO
========================= */
.container{
    width:100%;
    max-width:1200px;
    margin:0 auto;
    padding:0 20px;
}
.container_p{
    width:100%;
    margin:0 0px;
    padding:0 0px;
}
/* =========================
   HEADER
========================= */
.site-header{
    position:fixed;
    top:0;
    width:100%;
    z-index:999;
    background:rgba(0,0,0,.4);
    backdrop-filter:blur(12px);
}

/* =========================
   HERO / HOME
========================= */
.hero{
    height:100vh;
    position:relative;
    overflow:hidden;
}

.hero video{
    width:100%;
    height:100%;
    object-fit:cover;
}

.overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.65);
}

.hero-content{
    position:absolute;
    top:50%;
    left:10%;
    transform:translateY(-50%);
    max-width:700px;
}

.hero h1{
    font-size:72px;
    line-height:1;
    margin:25px 0;
    text-transform:uppercase;
    color:#fff;
}

.hero p{
    font-size:20px;
    opacity:.85;
    color:#fff;
}

/* =========================
   SERVICES
========================= */
.services{
    padding:120px 0;
    background:#050505;
    color:#fff;
}

.services-grid{
    margin-top:60px;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
}

/* =========================
   PAGE BANNER
========================= */
.page-banner{
    position:relative;
    width:100%;
    height:60vh;
    background-size:cover;
    background-position:center;
    display:flex;
    align-items:center;
}

.page-overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.6);
}

.page-banner-content{
    position:relative;
    z-index:2;
    color:#fff;
}

/* =========================
   TÍTULO SEM BANNER
   Exibido quando não há imagem destaque
   ou quando a imagem está oculta mas o título não.
========================= */
.page-title-plain{
    padding:40px 0 32px;
    border-bottom:1px solid rgba(0,0,0,.08);
}

.page-title-plain h1{
    margin:0;
    font-size:clamp(26px, 4vw, 40px);
    font-weight:800;
    line-height:1.2;
    color:var(--text-color, #111);
}

/* =========================
   DEFAULT PAGE WRAPPER
========================= */
.default-page-wrapper{
    width:100%;
}

/* =========================
   DEFAULT PAGE CONTENT
========================= */
.default-page-content{
    background:#fff;
    color:#111;
}

/* ---- LAYOUT: COLUNAS NO CONTAINER (padrão) ---- */
.page-layout-container-columns .default-page-content{
    padding:0px 0;
}

.page-content-container-columns{
    width:100%;
    max-width:1200px;
    margin:0 auto;
    padding:0 20px;
}

/* alignwide sai um pouco do container */
.page-content-container-columns .alignwide{
    width:calc(100% + 80px);
    max-width:calc(100% + 80px);
    margin-left:-40px;
    margin-right:-40px;
}

/* alignfull ultrapassa e vai a tela cheia */
.page-content-container-columns .alignfull{
    width:100vw;
    max-width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
}


/* ---- LAYOUT: TODA LARGURA DA PÁGINA (full) ---- */
.page-layout-full .default-page-content{
    padding:0;
    width:100%;
    max-width:none;
}

.page-content-full{
    width:100%;
    max-width:none;
    margin:0;
    padding:0;
}

.page-content-full > *,
.page-content-full .wp-block-columns,
.page-content-full .alignwide,
.page-content-full .alignfull{
    width:100%;
    max-width:none;
    margin-left:0;
    margin-right:0;
    padding-left:0;
    padding-right:0;
}


/* ---- LAYOUT: TELA CHEIA COM CONTEÚDO CENTRADO (full-contained) ---- */
.page-layout-full-contained .default-page-content{
    padding:0;
    width:100%;
    max-width:none;
}

.page-content-full-contained{
    width:100%;
    max-width:none;
    margin:0;
    padding:0;
}

/* Blocos normais ficam no container */
.page-content-full-contained > *{
    max-width:1200px;
    margin-left:auto;
    margin-right:auto;
    padding-left:20px;
    padding-right:20px;
    box-sizing:border-box;
}

/* alignwide sai um pouco do container */
.page-content-full-contained > .alignwide,
.page-content-full-contained > .wp-block-columns.alignwide{
    max-width:1400px;
    margin-left:auto;
    margin-right:auto;
    padding-left:20px;
    padding-right:20px;
}

/* alignfull vai a tela cheia */
.page-content-full-contained > .alignfull,
.page-content-full-contained > .wp-block-cover.alignfull,
.page-content-full-contained > .wp-block-group.alignfull,
.page-content-full-contained > .wp-block-image.alignfull,
.page-content-full-contained > .wp-block-columns.alignfull{
    width:100%;
    max-width:none;
    margin-left:0;
    margin-right:0;
    padding-left:0;
    padding-right:0;
}

/* Conteúdo interno de blocos alignfull volta ao container */
.page-content-full-contained > .alignfull > .wp-block-group__inner-container,
.page-content-full-contained > .alignfull > .wp-container-core-group-inner,
.page-content-full-contained > .alignfull .wp-block-columns:not(.alignfull){
    max-width:1200px;
    margin-left:auto;
    margin-right:auto;
    padding-left:20px;
    padding-right:20px;
}

/* =========================
   PORTAL SINGLE
========================= */
.portal-single{
    background:#fff;
    color:#111;
}

/* HERO EDITORIAL */
.portal-hero{

    position:relative;

    min-height:75vh;

    display:flex;

    align-items:flex-end;

    overflow:hidden;

    color:#fff;
}

.portal-hero img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
}

.portal-hero .overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.85), transparent);
}

.portal-hero .hero-content{
    position:relative;
    padding:60px 20px;
    max-width:1100px;
    margin:0 auto;
}

.portal-hero .category{
    display:inline-block;
    background:#f18d3e;
    padding:6px 14px;
    border-radius:20px;
    font-size:12px;
    text-transform:uppercase;
    margin-bottom:10px;
}


.featured-post{
    position:relative;
    overflow:hidden;
}

.featured-content{
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    padding:28px;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;

    background:linear-gradient(
        to top,
        rgba(0,0,0,.75),
        rgba(0,0,0,.35),
        transparent
    );
}

.featured-content h2{
    margin:0 0 12px;
    line-height:1.2;
}
/* =========================
   LAYOUT PORTAL
========================= */
.portal-body{
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:40px;
    max-width:1200px;
    margin:0 auto;
    padding:80px 20px;
}

/* COLUNA PRINCIPAL */
.content-column{
    max-width:800px;
}

/* TEXTO EDITORIAL */
.post-content{
    font-size:19px;
    line-height:1.95;
}

.post-content p{
    margin-bottom:22px;
}

.post-content h2,
.post-content h3{
    margin-top:40px;
    margin-bottom:15px;
}

/* SIDEBAR */
.sidebar-column{
    position:sticky;
    top:110px;
    align-self:start;
}

.widget-box{
    background:#f7f7f7;
    padding:20px;
    border-radius:12px;
}

/* RELACIONADOS */
.related-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:15px;
    margin-top:20px;
}

.related-item img{
    width:100%;
    height:120px;
    object-fit:cover;
    border-radius:10px;
}

/* =========================
   SHARE BOX
========================= */
.share-box{
    margin-top:50px;
    display:flex;
    gap:15px;
    align-items:center;
    font-size:14px;
}

.share-box a{
    background:#111;
    color:#fff;
    padding:10px 16px;
    border-radius:30px;
    text-decoration:none;
    transition:.3s;
}

.share-box a:hover{
    background:#f18d3e;
}

/* =========================
   FOOTER
========================= */
.site-footer{
    background:#050505;
    text-align:center;
    padding:50px 0;
    color:#fff;
}

/* =========================
   RESPONSIVO
========================= */
@media(max-width:991px){

    .hero h1{
        font-size:42px;
    }

    .services-grid{
        grid-template-columns:1fr;
    }

    .hero-buttons{
        flex-direction:column;
    }

    .portal-body{

    display:grid;

    grid-template-columns:minmax(0,820px) 320px;

    justify-content:center;

    gap:50px;

    max-width:1400px;
}

    .content-column{
        max-width:100%;
    }
}

@media(max-width:768px){

    .page-banner{
        height:40vh;
    }

    .page-banner-content h1{
        font-size:38px;
    }

    .portal-hero{
        height:55vh;
    }
}

/* =========================
   HERO EDITORIAL MODERNO
========================= */

.hero-content{

    position:relative;

    z-index:10;

    max-width:650px;

    padding-bottom:70px;
}

.hero-category{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    padding:8px 16px;

    border-radius:50px;

    background:var(--cat-color);

    color:#fff;

    font-size:12px;

    font-weight:700;

    text-transform:uppercase;

    letter-spacing:1px;

    margin-bottom:24px;
}

.hero-title{

    font-size:clamp(42px,5vw,72px);

    line-height:1.05;

    font-weight:800;

    color:#fff;

    margin:0 0 25px;

    letter-spacing:-2px;
}

.hero-subtitle{

    max-width:760px;

    font-size:22px;

    line-height:1.6;

    color:rgba(255,255,255,.92);

    margin-bottom:25px;
}

.hero-meta{

    display:block;

    flex-wrap:wrap;

    gap:15px;

    font-size:9px;

    color:rgba(255,255,255,.75);
}

/* =========================
   ANIMAÇÃO
========================= */
@keyframes pulse{
    0%{ transform:scale(1); }
    50%{ transform:scale(1.08); }
    100%{ transform:scale(1); }
}

/* =========================
   SEARCH PAGE
========================= */

.search-page{

    background:#0b0b0b;

    min-height:100vh;
}


/* HERO */

.search-hero{

    position:relative;

    padding:180px 0 90px;

    overflow:hidden;

    background:
    linear-gradient(
        135deg,
        #111,
        #1b1b1b
    );
}

.search-hero-overlay{

    position:absolute;

    inset:0;

    background:
    radial-gradient(
        circle at top right,
        rgba(255,255,255,.06),
        transparent
    );
}
.hero-overlay{
    justify-content:flex-end;
    padding:28px;
}


/* CONTAINER */

.search-container{

    width:min(1400px, 94vw);

    margin:0 auto;

    position:relative;

    z-index:2;
}


/* LABEL */

.search-label{

    display:inline-flex;

    align-items:center;
    justify-content:center;

    padding:8px 18px;

    border-radius:60px;

    background:var(--cat-color);

    color:#fff;

    font-size:11px;

    font-weight:700;

    letter-spacing:1px;

    text-transform:uppercase;

    margin-bottom:24px;
}


/* TITLE */

.search-hero h1{

    font-size:clamp(42px, 6vw, 82px);

    line-height:1;

    color:#fff;

    margin-bottom:20px;

    letter-spacing:-3px;
}

.search-hero h1 span{

    color:var(--cat-color);
}

.search-hero p{

    color:
    rgba(255,255,255,.65);

    font-size:18px;
}


/* =========================
   RESULTS
========================= */

.search-results-section{

    padding:70px 0 120px;
}


/* GRID */

.search-grid{

    display:grid;

    grid-template-columns:
    repeat(3, 1fr);

    gap:28px;
}


/* CARD */

.search-card{

    background:
    rgba(255,255,255,.03);

    border:
    1px solid rgba(255,255,255,.06);

    border-radius:26px;

    overflow:hidden;

    transition:.35s ease;
}

.search-card:hover{

    transform:
    translateY(-8px);

    border-color:
    rgba(255,255,255,.14);
}


/* LINK */

.search-card a{

    display:block;

    text-decoration:none;
}


/* THUMB */

.search-thumb{

    overflow:hidden;
}

.search-thumb img{

    width:100%;

    height:260px;

    object-fit:cover;

    transition:.4s ease;
}

.search-card:hover img{

    transform:scale(1.04);
}


/* CONTENT */

.search-card-content{

    padding:28px;
}


/* CATEGORY */

.search-category{

    display:inline-flex;

    margin-bottom:18px;

    font-size:11px;

    font-weight:700;

    text-transform:uppercase;

    letter-spacing:1px;

    color:var(--cat-color);
}


/* TITLE */

.search-card h2{

    font-size:30px;

    line-height:1.15;

    color:#fff;

    margin-bottom:18px;
}


/* TEXT */

.search-card p{

    color:
    rgba(255,255,255,.7);

    line-height:1.8;

    margin-bottom:25px;
}


/* META */

.search-meta{

    display:flex;

    align-items:center;

    gap:12px;

    color:
    rgba(255,255,255,.45);

    font-size:13px;
}


/* PAGINATION */

.search-pagination{

    margin-top:70px;

    display:flex;

    justify-content:center;
}

.search-pagination .page-numbers{

    display:flex;

    align-items:center;
    justify-content:center;

    width:48px;
    height:48px;

    margin:0 6px;

    border-radius:50%;

    background:
    rgba(255,255,255,.05);

    color:#fff;

    text-decoration:none;

    transition:.3s ease;
}

.search-pagination .current,
.search-pagination a:hover{

    background:var(--cat-color);
}


/* EMPTY */

.search-empty{

    text-align:center;

    padding:120px 0;
}

.search-empty h2{

    color:#fff;

    font-size:52px;

    margin-bottom:20px;
}

.search-empty p{

    color:
    rgba(255,255,255,.6);

    margin-bottom:35px;
}


/* FORM */

.search-empty-form{

    max-width:520px;

    margin:0 auto;

    display:flex;

    gap:14px;
}

.search-empty-form input{

    flex:1;

    height:58px;

    border:none;

    border-radius:60px;

    padding:0 24px;

    background:
    rgba(255,255,255,.06);

    color:#fff;
}

.search-empty-form button{

    height:58px;

    border:none;

    padding:0 28px;

    border-radius:60px;

    background:var(--cat-color);

    color:#fff;

    cursor:pointer;
}


/* MOBILE */

@media(max-width:991px){

    .search-grid{

        grid-template-columns:1fr;
    }

}


/* ============================================================
   OCOHOST REVOLUTION SLIDER
   O tema não interfere no layout do slider.
   O slider ocupa 100% da largura do seu container pai,
   seja ele o container da página ou a tela cheia.
   Use o shortcode [ocohost_revolution id="X"] para
   inserir o slider onde quiser no conteúdo.
   ============================================================ */

/* Garante que o slider ocupe 100% do espaço disponível */
.cenatres-revolution {
    width: 100%;
    display: block;
}

