/* Remove o shape/fundo do logo (se existir no tema) */
html #header .header-logo.custom-header-logo:before {
    background: transparent !important;
}

/* Permite o overlap */
#header .header-body,
#header .header-container {
    overflow: visible !important;
}



/* Tamanho no topo */
#header .custom-header-logo img.logo,
#header .custom-header-logo img.logo-sticky {
    width: auto;
    height: 85px !important;     /* topo */
    transition: all 0.3s ease;
}

/* Por defeito: mostra normal, esconde sticky */
#header .custom-header-logo img.logo {
    display: block;
}
#header .custom-header-logo img.logo-sticky {
    display: none;
}

/* Sticky (Porto usa html.sticky-header-active) */
html.sticky-header-active #header .custom-header-logo {
    top: 0;             /* sobe no sticky */
}

html.sticky-header-active #header .custom-header-logo img.logo {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
}




/* 1) Esconde qualquer logo "logo-dark.png" do demo (se existir em algum clone) */
#header img.logo[src*="demos/construction/logo"] {
    display: none !important;
}



/* 3) Mas mantém o teu logo normal visível quando NÃO está sticky */
html:not(.sticky-header-active) #header .custom-header-logo img.logo {
    display: block !important;
}

/* 4) Mostra o teu logo-sticky quando sticky */
html.sticky-header-active #header .custom-header-logo img.logo-sticky {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
}

/* 5) Esconde o teu logo normal quando sticky */
html.sticky-header-active #header .custom-header-logo img.logo {
    display: none !important;
}
/* Reduz a altura do header (zona cinzenta) */
#header .header-body {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    min-height: 0 !important;
}

/* Reduz o espaço interno do container do header */
#header .header-container {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Se houver row/col com altura/padding */
#header .header-row,
#header .header-column {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
/* Força layout horizontal */
.header-social-icons {
    display: flex !important;
    align-items: center;
    gap: 12px; /* espaço entre ícones */
    padding: 0;
    margin: 0;
}

.header-social-icons li {
    list-style: none;
    display: inline-block;
    margin: 0 !important;
}

/* Tamanho mais pequeno dos ícones */
.header-social-icons li a {
    font-size: 10px;     /* reduz tamanho (experimentar 12px–16px) */
    width: 28px;
    height: 28px;
    line-height: 28px;
    text-align: center;
    color: #333;
}

/* Hover */
.header-social-icons li a:hover {
    color: #9c1d23;
}

/* Remove qualquer border que o tema possa adicionar */
.header-nav-features {
    border-left: none !important;
}
@media (min-width: 992px) {

    /* Estado normal */
    #header .header-nav-main nav > ul.nav > li > a,
    #header .header-nav-main nav > ul.nav-pills > li > a {
        color: #333 !important;
        background: transparent !important;
        transition: all 0.3s ease;
    }

    /* Hover individual */
    #header .header-nav-main nav > ul.nav > li:hover > a,
    #header .header-nav-main nav > ul.nav-pills > li:hover > a {
        background-color: #9c1c2d !important;
        color: #fff !important;
    }

    /* Quando nenhum item está em hover, destaca o item ativo (não o primeiro) */
    #header .header-nav-main nav > ul.nav:not(:hover) > li > a.current-page-active,
    #header .header-nav-main nav > ul.nav-pills:not(:hover) > li > a.current-page-active,
    #header .header-nav-main nav > ul.nav:not(:hover) > li > a.active,
    #header .header-nav-main nav > ul.nav-pills:not(:hover) > li > a.active {
        background-color: #9c1c2d !important;
        color: #fff !important;
    }

}
/* ===== COR PRIMÁRIA MOLDIFLEX ===== */

:root {
    --primary: #9c1c2d;
}

/* Textos */
.text-color-primary {
    color: #9c1c2d !important;
}

/* Fundos */
.bg-primary {
    background-color: #9c1c2d !important;
}

/* Botões */
.btn-primary {
    background-color: #9c1c2d !important;
    border-color: #9c1c2d !important;
}

.btn-primary:hover {
    background-color: #7f1825 !important;
    border-color: #7f1825 !important;
}

/* Dots do carousel */
.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span {
    background: #9c1c2d !important;
}

/* Setas do carousel */
.owl-theme .owl-nav [class*="owl-"]:hover {
    background: #9c1c2d !important;
}
/* ===== AJUSTE LOGO HEADER ===== */

#header .custom-header-logo {
    position: absolute;
    left: -10px;
    top: -0px;   /* aproxima do menu */
    z-index: 1001;
}

/* Tamanho no topo */
#header .custom-header-logo img.logo {
    
    width: auto;
}



html.sticky-header-active #header .custom-header-logo img.logo-sticky {
    height: 85px;
}


@media (min-width: 992px) {

    /* 1) Evita quebra de linha no menu */
    #header .header-nav-main nav > ul {
        display: flex !important;
        flex-wrap: nowrap !important;
        white-space: nowrap;
    }

    /* 2) Dá um pouco menos de espaço ao logo (ajusta fino) */
    #header .header-nav-main {
        padding-left: 165px !important; /* em vez de 190 */
    }

    /* 3) Aperta um pouco o espaçamento entre itens */
    #header .header-nav-main nav > ul > li > a {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

}
/* ===== TEXTO DO CARROSSEL ===== */

.slide-caption {
    position: absolute;
    bottom: 90px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: #9c1c2d;
    color: #fff;
    padding: 14px 40px;
    font-weight: 600;
    font-size: 20px;
    opacity: 0;
    transition: all 0.5s ease;
    clip-path: polygon(8% 0, 100% 0, 92% 100%, 0 100%);
}

/* Quando o slide está ativo */
.owl-item.active .slide-caption {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}
/* ===== HERO 3 LINHAS (igual ao exemplo) ===== */

.hero-captions{
    position: absolute;
    left: 11%;
    bottom: 18%;
    z-index: 5;
}

/* estilo base */
.hero-captions .cap{
    display: block;
    width:fit-content;
    position: relative;
    background: #9c1c2d;
    color: #fff;
    font-weight: 700;
    line-height: 1.1;

    opacity: 0;
    transform: translateY(18px);
    transition: opacity .45s ease, transform .45s ease;
}

/* 1ª linha (pequena) */
.hero-captions .cap-1{
    padding: 12px 22px;
    font-size: 18px;
    margin-bottom: 14px;
}
.hero-captions .cap-1::after{
    content:"";
    position:absolute;
    top:0;
    right:-22px;
    width:0;
    height:0;
    border-top: 24px solid transparent;
    border-bottom: 24px solid transparent;
    border-left: 22px solid #9c1c2d;
}

/* 2ª linha (grande, “Moldiflex”) */
.hero-captions .cap-2{
    background: transparent;
    color: #9c1c2d;
    font-size: 78px;
    font-weight: 900;
    margin: 0 0 14px 0;
    padding: 0;
    text-shadow: 0 3px 0 rgba(0,0,0,.22);
}

/* 3ª linha (média) */
.hero-captions .cap-3{
    padding: 12px 22px;
    font-size: 18px;
}
.hero-captions .cap-3::after{
    content:"";
    position:absolute;
    top:0;
    right:-22px;
    width:0;
    height:0;
    border-top: 24px solid transparent;
    border-bottom: 24px solid transparent;
    border-left: 22px solid #9c1c2d;
}

/* ===== APARECER 1 A 1 SÓ NO SLIDE ATIVO ===== */
.owl-item.active .hero-captions .cap{
    opacity: 1;
    transform: translateY(0);
}

.owl-item.active .hero-captions .cap-1{
    transition-delay: .20s;
}
.owl-item.active .hero-captions .cap-2{
    transition-delay: .55s;
}
.owl-item.active .hero-captions .cap-3{
    transition-delay: .90s;
}

/* quando sai do slide, remove delays (para não “prender”) */
.owl-item:not(.active) .hero-captions .cap{
    transition-delay: 0s !important;
}

/* responsivo */
@media (max-width: 991px){
    .hero-captions{
        left: 7%;
        bottom: 14%;
    }
    .hero-captions .cap-2{
        font-size: 52px;
    }
}
@media (max-width: 575px){
    .hero-captions .cap-1,
    .hero-captions .cap-3{
        font-size: 15px;
        padding: 10px 16px;
    }
    .hero-captions .cap-1::after,
    .hero-captions .cap-3::after{
        right:-18px;
        border-left-width:18px;
        border-top-width:22px;
        border-bottom-width:22px;
    }
    .hero-captions .cap-2{
        font-size: 40px;
    }
}
/* garante contexto do slide */
.owl-carousel .position-relative{
    position: relative;
}

/* fundo (imagem) sempre atrás */
.owl-carousel .position-relative > .position-absolute{
    z-index: 1;
}

/* captions sempre à frente do fundo */
.owl-carousel .slide-caption,
.owl-carousel .hero-captions{
    z-index: 10;
}

/* (opcional) evita que o texto bloqueie cliques/arrasto do owl */
.owl-carousel .hero-captions,
.owl-carousel .slide-caption{
    pointer-events: none;
}
.hero-captions{
    z-index: 10; /* em vez de 5 */
}

/* garante que o slide é o contexto */
.mf-slide{
    position: relative !important;
    overflow: hidden; /* normal em hero */
}

/* fundo sempre atrás */
.mf-slide-bg{
    position: absolute;
    inset: 0;
    z-index: 1;
    background-size: cover;
    background-position: center;
}

/* captions sempre à frente e em posição visível */
.mf-slide .hero-captions{
    position: absolute;
    left: 80px;
    bottom: 140px;
    z-index: 20;
    pointer-events: none;
}

/* estado base escondido */
.mf-slide .hero-captions .cap{
    opacity: 0;
    transform: translateY(18px);
    transition: opacity .45s ease, transform .45s ease;
}

/* ativa no slide visível */
.owl-carousel .owl-item.active .mf-slide .hero-captions .cap{
    opacity: 1;
    transform: translateY(0);
}

.owl-carousel .owl-item.active .mf-slide .cap-1{
    transition-delay: .20s;
}
.owl-carousel .owl-item.active .mf-slide .cap-2{
    transition-delay: .55s;
}
.owl-carousel .owl-item.active .mf-slide .cap-3{
    transition-delay: .90s;
}

.owl-carousel .owl-item:not(.active) .mf-slide .hero-captions .cap{
    transition-delay: 0s !important;
}
/* container do ícone (o círculo externo) */
.feature-icon-circle{
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 4px solid #9c1c2d;  /* anel exterior */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 48px;             /* não encolhe */
}

/* o "bullseye" (anel interior + ponto) */
.feature-icon-circle .bullseye-icon{
    display: block;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 4px solid #9c1c2d;   /* anel interior */
    position: relative;
    box-sizing: border-box;
}

.feature-icon-circle .bullseye-icon::after{
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    width: 6px;
    height: 6px;
    background: #9c1c2d;         /* ponto central */
    border-radius: 50%;
    transform: translate(-50%, -50%);
}
.product-card{
    display:block;
    background:#fff;
    border-radius:4px;
    overflow:hidden;
    box-shadow:0 10px 30px rgba(0,0,0,.06);
    transition:transform .2s ease, box-shadow .2s ease;
    height:100%;
    color:inherit;
}

.product-card:hover{
    transform:translateY(-3px);
    box-shadow:0 14px 36px rgba(0,0,0,.10);
}

.product-card__img{
    background:#f4f4f4;
}

.product-card__img img{
    width:100%;
    height:220px;          /* ajusta se precisares */
    object-fit:cover;      /* mantém “formato” consistente */
    display:block;
}

.product-card__body{
    padding:18px 18px 22px 18px;
}

.product-card__title{
    margin:0 0 10px 0;
    font-size:18px;
    font-weight:700;
    color:#111;
}

.product-card__text{
    margin:0;
    font-size:14px;
    line-height:1.5;
    color:#666;
}
.hide-until-visible{
    opacity: 0;
    transform: translateY(25px);
    pointer-events: none;
    transition: opacity .35s ease, transform .35s ease;
}

.hide-until-visible.is-visible{
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
#btnSaberMaisProdutos{
    color:#fff !important;
    opacity:1 !important;
}

#btnSaberMaisProdutos:hover{
    color:#fff !important;
}
.right-labels {
    position: absolute;
    right: 40px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.label-item {
    background: #b3202a;
    color: #fff;
    padding: 12px 30px;
    font-weight: 600;
    opacity: 0;
    transform: translateX(40px);
    transition: all 0.6s ease;
}

.label-item.active {
    opacity: 1;
    transform: translateX(0);
}
/* Garante que os labels aparecem por cima da imagem */
.sistema-media {
    position: relative;
}

.parceiros-carousel .parceiro-item{
    height: 80px;              /* ajusta se precisares */
    display: flex;
    align-items: center;
    justify-content: center;
}

.parceiros-carousel .parceiro-item img{
    max-height: 55px;          /* ajusta para ficar parecido à 2ª imagem */
    width: auto;
    max-width: 100%;
    opacity: 0.9;
    transition: opacity 0.2s ease;
}

.parceiros-carousel .parceiro-item img:hover{
    opacity: 1;
}

/* remove “padding” extra do owl */
.parceiros-carousel .owl-stage{
    display: flex;
    align-items: center;

}


#footer .footer-brand {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

@media (min-width: 992px) {
    #footer .footer-brand {
        align-items: center;   /* mantém centrado também em desktop */
    }
}
#footer .footer-fundo-logo {

    width: 100%;
    max-width: 1100px;
    display: block;
    margin: 0 auto;
}
#footer {
    padding-bottom: 80px;   /* aumenta este valor */
}
#footer .footer-logo {
    max-height: 60px;   /* antes estava ~60 */
    width: auto;
}
#footer .footer-copy {
    font-size: 13px;   /* reduz tamanho */
}
/* FIX: Word Rotator a sobrepor palavras */
.word-rotator {
    position: relative;
    display: inline-block;
}

.word-rotator-words {
    position: relative;
    display: inline-block;
    overflow: hidden;
    vertical-align: bottom;
}

.word-rotator-words b {
    position: absolute;
    left: 0;
    top: 0;
    white-space: nowrap;
    opacity: 0;
}

.word-rotator-words b.is-visible {
    position: relative;
    opacity: 1;
}
/* Aumenta a altura do slider */
.consultoria-slider .owl-stage-outer {
    height: 420px;
}

/* Faz cada slide ocupar a altura toda */
.consultoria-slider .owl-item > div {
    height: 420px;
}

/* Faz a imagem preencher totalmente */
.consultoria-slider img {
    width: 100%;
    height: 420px;
    object-fit: cover;
}
/* Faz as colunas esticarem e o slider ocupar a altura disponível */
.consultoria-row > [class*="col-"] {
    display: flex;
    flex-direction: column;
}

.consultoria-row .consultoria-slider {
    flex: 1 1 auto;
    min-height: 320px; /* segurança: evita ficar pequeno demais */
}

/* Faz o Owl respeitar a altura do container */
.consultoria-row .consultoria-slider,
.consultoria-row .consultoria-slider .owl-stage-outer,
.consultoria-row .consultoria-slider .owl-stage,
.consultoria-row .consultoria-slider .owl-item,
.consultoria-row .consultoria-slider .owl-item > div {
    height: 100%;
}

/* Imagem preenche sem distorcer */
.consultoria-row .consultoria-slider img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.consultoria-slider .owl-nav button.owl-prev,
.consultoria-slider .owl-nav button.owl-next {
    display: inline-block;
    position: absolute;
    top: 50%;
    width: 30px;
    height: 30px;
    transform: translate3d(0,-50%,0);
    background: transparent;
    border: none;
}

.consultoria-slider .owl-prev {
    left: 0;
}
.consultoria-slider .owl-next {
    right: 0;
}

.consultoria-slider .owl-nav [class*="owl-"] {
    color: #fff;
    font-size: 14px;
    background: #D6D6D6;
    border-radius: 3px;
    padding: 4px 7px;
}



/* garante que a coluna usa altura total */
.produtos-grid > [class*="col-"] {
    display: flex;
}

/* o link vira "container" do card e ocupa a altura toda */
.produtos-grid > [class*="col-"] > a {
    display: flex;
    width: 100%;
    height: 100%;
    text-decoration: none;
}

/* o card ocupa toda a altura e vira layout em coluna */
.produtos-grid .card {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}

/* imagem sempre com a mesma altura */
.produtos-grid .card img {
    width: 100%;
    height: 260px;      /* ajusta */
    object-fit: cover;
    display: block;
}

/* o corpo do card ocupa o resto */
.produtos-grid .card-body {
    padding: 1.25rem;   /* equivalente a p-4 aprox */
    flex: 1;
}





.produtos-grid .card {
    transition: transform .25s ease, box-shadow .25s ease;
}

.produtos-grid .card:hover {
    transform: scale(1.04);
    box-shadow: 0 15px 35px rgba(0,0,0,0.15);
    z-index: 2;
}





/* Grid */
.portfolio-grid > [class*="col-"]{
    display: flex;
}

/* Link ocupa o item todo */
.portfolio-item{
    display: block;
    width: 100%;
    text-decoration: none;
}

/* Thumb com altura consistente */
.portfolio-thumb{
    width: 100%;
    height: 240px;           /* ajusta se quiseres */
    overflow: hidden;
    background: #f5f5f5;
}

.portfolio-thumb img{
    width: 100%;
    height: 100%;
    object-fit: contain;     /* mantém a imagem inteira (como na tua 2ª imagem) */
    display: block;
    transition: transform .25s ease;
}

/* Hover: aumenta ligeiramente a imagem */
.portfolio-item:hover .portfolio-thumb img{
    transform: scale(1.05);
}

/* Título */
.portfolio-title{
    margin: 12px 0 0;
    font-size: 18px;
    font-weight: 500;
    color: #222;
}


.svg-fill-color-dark {
    fill: #9c1f2d !important;
}



/* =========================================================
   FIX: não forçar o 1º item (Home) a vermelho
   ========================================================= */

/* Anula o "Home sempre ativo" quando NÃO há hover no menu */
html body .header .header-nav-main nav > ul.nav-pills:not(:hover) > li:first-child > a.nav-link,
html body .header .header-nav-main nav > ul.nav-pills:not(:hover) > li:first-child > a {
    background-color: transparent !important;
    color: #444 !important; /* ajusta se quiseres */
}

/* Garante que o ativo (o que o teu JS marca) é que fica vermelho */
html body .header .header-nav-main nav > ul.nav-pills > li > a.nav-link.active,
html body .header .header-nav-main nav > ul.nav-pills > li > a.nav-link.current-page-active {
    background-color: #9c1f2d !important; /* o teu vermelho */
    color: #fff !important;
}

/* necessário para posicionar os ribbons */
.sistema-slide{
    position: relative;
}

/* container dos ribbons */
.sistema-ribbons{
    position: absolute;
    right: 70px;
    top: 20%;
    transform: translateY(-50%);
    z-index: 3;
    display: flex;
    flex-direction: column;
    gap: 14px;
}


/* ribbon */
.sistema-ribbons .ribbon{
    position: relative;
    display: inline-block;
    background: #9c1f2d;
    color: #fff;
    font-weight: 700;
    padding: 14px 34px;
    transform: skewX(-18deg);
    min-width: 200px;
    text-align: center;
}



/* ponta direita */
.sistema-ribbons .ribbon::after{
    content: "";
    position: absolute;
    right: -28px;
    top: 0;
    border-top: 24px solid transparent;
    border-bottom: 24px solid transparent;
    border-left: 28px solid #9c1f2d;
}

/* Estado base: escondido */
.sistema-slide .sistema-ribbons .ribbon{
    opacity: 0;
    transform: translateX(40px) skewX(-18deg);
}

/* Quando o slide está ativo e marcado para animar */
.owl-item.active .sistema-slide.is-animating .sistema-ribbons .ribbon{
    animation: ribbonAppear .6s ease forwards;
}

@keyframes ribbonAppear{
    from{
        opacity: 0;
        transform: translateX(40px) skewX(-18deg);
    }
    to  {
        opacity: 1;
        transform: translateX(0)  skewX(-18deg);
    }
}

/* Delays (1 a 1) */
.owl-item.active .sistema-slide.is-animating .sistema-ribbons .ribbon:nth-child(1){
    animation-delay: .2s;
}
.owl-item.active .sistema-slide.is-animating .sistema-ribbons .ribbon:nth-child(2){
    animation-delay: .55s;
}
.owl-item.active .sistema-slide.is-animating .sistema-ribbons .ribbon:nth-child(3){
    animation-delay: .9s;
}
.owl-item.active .sistema-slide.is-animating .sistema-ribbons .ribbon:nth-child(4){
    animation-delay: 1.25s;
} /* se precisares */


/* área fixa para as imagens */
.sistema-media{
    height: 420px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

/* imagem adapta-se ao espaço */
.sistema-media .sistema-bg{
    max-height: 100%;
    max-width: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

/* slide organizado em coluna */
.sistema-slide{
    display: flex;
    flex-direction: column;
}

/* espaço fixo para o bloco de texto */
.sistema-overlay{
    min-height: 140px;   /* ajusta se necessário */
}
#languageDrop.dropdown-toggle::after {
    display: none !important;
}
.dropdown-submenu > a.dropdown-toggle::after{
    display:none;
}

.dropdown-submenu > a.dropdown-toggle::before{
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f054"; /* chevron-right */
    float:right;
}
.language-flag {
    width: 16px;
    height: 12px;
    object-fit: cover;
    vertical-align: middle;
}
/* Tirar qualquer margem/padding global que crie faixa branca */
body {
    margin: 0;
    padding: 0;
}

/* Corrigir header transparente do tema (sem espaço extra) */
html #header.header-transparent {
   
    padding: 0 !important;
    min-height: auto !important;
}

/* ESCONDER HAMBURGUER NO DESKTOP */
@media (min-width: 993px) {
    .mobile-toggle {
        display: none !important;
    }
}

/* MOSTRAR HAMBURGUER NO MOBILE */
@media (max-width: 992px) {
    .mobile-toggle {
        display: block !important;
    }
}

.lang-short {
    display: none;
}

@media (max-width: 1028px) {

    .lang-full {
        display: none;
    }

    .lang-short {
        display: inline;
        font-weight: 600;
    }

}
@media (max-width: 1155px) {
    #header .custom-header-logo img.logo,
    #header .custom-header-logo img.logo-sticky {
        height: 80px !important;
        width: 100px!important;
    }
}
@media (max-width: 575.98px) {
    #header .custom-header-logo img.logo,
    #header .custom-header-logo img.logo-sticky {
        height: 70px !important;
        width: 100px !important;
    }
}
@media (max-width: 575.98px) {
    .header-social-icons {
        display: none !important;
    }
}
@media (max-width: 1155px) {
    .header-social-icons {
        display: none !important;
    }
}
@media (max-width: 1155px) {
    .header-nav-features.header-nav-features-no-border {
        display: flex !important;
        align-items: center;
        flex-wrap: nowrap !important;
    }
}
#header .custom-header-logo img.logo {
    height: 85px !important;
}

.consultoria-row-distribuicao {
  min-height: 520px;
}