/* ------------------------------ INICIO DA BIBLIOTECA DE ESTILOS #madreideia ------------------------------ */

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

html {
    scroll-behavior: smooth;
}

body::-webkit-scrollbar {
    width: 10px;
    /* width of the entire scrollbar */
}

body::-webkit-scrollbar-track {
    background: var(--green-lfc-second);
    /* color of the tracking area */
}

body::-webkit-scrollbar-thumb {
    background-color: var(--grey-lfc-dark);
    /* color of the scroll thumb */
    border-radius: 10px;
    /* roundness of the scroll thumb */
}

body {
    padding: 0px;
    margin: 0px;
    font-family: "Ubuntu", sans-serif !important;
    scroll-behavior: smooth;
    overflow-x: hidden;
}

ul {
    list-style: none;
}

h1,
h2,
h3,
h4 {
    margin: 0px;
    padding: 0px;
    font-weight: 900;
    line-height: initial !important;
    font-size: initial;
    line-height: initial;
}

a {
    text-decoration: none !important;
}

ul {
    margin: 0px !important;
    padding: 0px !important;
}

input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
    display: none;
}

.center {
    text-align: center;
}

.left {
    text-align: left;
}

.right {
    text-align: right;
}

/* 
  ----- Styles that are being used for the hole content -----
*/

/* Spaces */

.space-of-10 {
    height: 10px;
    width: 100%;
}

.space-of-20 {
    height: 20px;
    width: 100%;
}

.space-of-30 {
    height: 30px;
    width: 100%;
}

.space-of-50 {
    height: 50px;
    width: 100%;
}

.space-of-100 {
    height: 100px;
    width: 100%;
}

.space-of-150 {
    height: 150px;
    width: 100%;
}

.right-padding-of-100 {
    padding-right: 100px;
}

.right-padding-of-50 {
    padding-right: 50px;
}

.whole-site-wrap {
    max-width: 1920px;
    margin: auto;
}

/* Mobile Spacing */

@media (max-width: 1024px) {

    .space-of-100 {
        height: 50px;
    }

    .space-of-150 {
        height: 100px;
    }

    .right-padding-of-100 {
        padding: 0px;
    }

    .right-padding-of-50 {
        padding: 0px;
    }
}

/* Defyning Colors */

:root {
    --main-green-lfc: #76C142;
    --green-lfc-first: #A1D47C;
    --green-lfc-second: #BCE0A2;
    --green-lfc-third: #EFF8E8;
    --grey-lfc-dark: #737574;
    --grey-lfc-light: #949A9A;
    --purple-lfc: #430093;
    --yellow-lfc-light: #FDEFC8;
    --whatsapp-color: #128C7E;
    --all-transition: all 0.1s ease-in-out;
}

/* Font Styles */

.size-14 {
    font-size: 14px;
    line-height: 21px;
    font-weight: 300;
}

.size-16 {
    font-size: 16px;
    line-height: 24px;
    font-weight: 300;
}

.size-18 {
    font-size: 18px;
    line-height: 28px;
    font-weight: 300;
}

.size-21 {
    font-size: 21px;
    line-height: 28px;
    font-weight: 300;
}

.size-24 {
    font-size: 24px;
    line-height: 35px;
    font-weight: 300;
}

.size-28 {
    font-size: 28px;
    line-height: 35px;
    font-weight: 300;
}

.size-35 {
    font-size: 35px;
    line-height: 44px;
    font-weight: 300;
}

.italic-styled {
    font-style: italic;
}

.color-white {
    color: #fff;
}

.color-green-third {
    color: var(--green-lfc-third);
}

.color-grey-dark {
    color: var(--grey-lfc-dark);
}

.color-purple {
    color: var(--purple-lfc);
}

.color-main-green {
    color: var(--main-green-lfc);
}

/* Images and Backgrounds and Elements*/

.light-grey-patterned {
    background: #f9f9f9 url(../Images/NovoSite/pattern-60.png) no-repeat center top;
    background-size: cover;
}

/* Home - bloco "Apoio técnico" (evita sobreposição/corte de texto) */
#apoio-tecnico {
    position: relative;
    padding-bottom: 215px; /* reserva espaço para o CTA com fundo */
}

.third-green-bg-patterned {
    background: var(--green-lfc-third) url(../Images/NovoSite/pattern-60.png) no-repeat center top;
    background-size: cover;
}

.main-green-bg {
    background-color: var(--main-green-lfc);
}

.dark-grey-bg {
    background-color: var(--grey-lfc-dark);
}

.items-svg-and-h3 li {
    text-align: center;
}

    .items-svg-and-h3 li h3 {
        color: #fff;
        font-weight: 300;
        font-size: 16px;
        line-height: 24px;
    }

.list-img-and-h3 {
    grid-column-gap: 20px;
}

    .list-img-and-h3 li img {
        width: 100%;
        height: auto;
    }

    .list-img-and-h3 li h3 {
        color: var(--grey-lfc-dark);
        font-weight: 300;
        font-size: 16px;
        line-height: 24px;
        padding-top: 20px;
    }

.cta-grey {
    display: inline-block;
    padding: 15px 30px;
    border-radius: 5px;
    font-size: 18px;
    font-weight: 700;
    color: var(--green-lfc-third);
    background: var(--grey-lfc-dark);
}

.buyer-steps {
    margin-top: 20px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-column-gap: 20px;
}

    .buyer-steps div {
        height: 50px;
        width: 50px;
        border-radius: 25px;
        border: 1px solid var(--main-green-lfc);
        background: var(--green-lfc-first);
        display: grid;
        align-content: center;
        justify-content: center;
        margin: auto;
        margin-bottom: 20px;
    }

        .buyer-steps div label {
            font-size: 28px;
            font-weight: 700;
            color: #fff;
        }

    .buyer-steps h3 {
        font-size: 16px;
        font-weight: 300;
        color: var(--grey-lfc-dark);
        text-align: center;
        line-height: 24px;
    }

.step-number-and-text {
    grid-gap: 50px;
}

    .step-number-and-text div {
        height: 60px;
        width: 60px;
        border-radius: 6px 0px 6px 0px;
        background: var(--green-lfc-third);
        display: grid;
        align-content: center;
        justify-content: center;
        margin-bottom: 20px;
    }

        .step-number-and-text div label {
            font-size: 28px;
            font-weight: 700;
            color: var(--main-green-lfc);
        }

    .step-number-and-text p {
        font-size: 16px;
        font-weight: 300;
        color: var(--grey-lfc-dark);
        line-height: 24px;
    }

/* CSS Grid - Defyning the Grid */

.full-width-div .container-width {
    width: 100%;
}

.container-width {
    margin: auto;
    width: 100%;
    max-width: 1400px;
}

.divided-on-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.divided-on-2-gap {
    grid-column-gap: 50px;
}

.divided-on-4 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}

.limited-content-600 {
    max-width: 600px;
    margin: auto;
}

.top-align {
    display: grid;
    align-content: start;
}

.center-align {
    display: grid;
    align-content: center;
}

.bottom-align {
    display: grid;
    align-content: end;
}

.justify-end {
    display: grid;
    justify-content: end;
}

.justify-center {
    display: grid;
    justify-content: center;
}

.justify-start {
    display: grid;
    justify-content: start;
}

.sidebar-and-list {
    display: grid;
    grid-template-columns: 1fr 3fr;
}

/* Desktop: filtros à esquerda, conteúdo+catálogo à direita (legado .corpo .conteudo usa float) */
@media (min-width: 1024px) {
    .sidebar-and-list {
        grid-template-columns: minmax(260px, 1fr) 3fr;
        align-items: start;
    }

    .sidebar-and-list > .sidebar {
        grid-column: 1;
        grid-row: 1;
        order: 0;
    }

    .sidebar-and-list > .main-content {
        grid-column: 2;
        grid-row: 1;
        order: 0;
        min-width: 0;
        display: flow-root;
    }
}

.list-6-columns {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
}

.list-5-columns {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
}

.list-4-columns {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}

.list-3-columns {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}

.hide-on-desktop {
    display: none;
}

@media (max-width: 1450px) {

    .hide-on-big-screen {
        display: block;
    }

    .container-width {
        width: 90vw;
    }
}

@media (max-width: 1023px) {

    .divided-on-2 {
        grid-template-columns: 1fr;
    }

    .list-6-columns {
        grid-template-columns: repeat(2, 1fr);
        grid-gap: 20px;
    }

    .list-5-columns {
        grid-template-columns: repeat(2, 1fr);
        grid-gap: 20px;
    }

    .list-4-columns {
        grid-template-columns: repeat(1, 1fr);
        grid-gap: 50px;
    }

    .list-3-columns {
        grid-template-columns: repeat(1, 1fr);
        grid-gap: 50px;
    }

    .img-full-width {
        max-width: 100%;
    }

    .hide-on-desktop {
        display: block;
    }

    .buyer-steps {
        grid-template-columns: 1fr;
        grid-gap: 20px;
    }

    .container-width {
        width: 94vw;
    }
}

/* Itens usados em vários lugares */

/* Heaader top */

.grey-top-bar {
    height: 40px;
    background-color: var(--grey-lfc-dark);
}

    .grey-top-bar .container-width {
        display: grid;
        grid-template-columns: 400px 1fr;
        align-content: center;
        height: 40px;
    }

.contacts-on-topbar {
    display: grid;
    grid-auto-flow: column;
    justify-content: end;
    grid-column-gap: 20px;
    align-content: center;
}

    .contacts-on-topbar li {
        display: grid;
        align-content: center;
    }

        .contacts-on-topbar li a {
            display: grid;
            grid-auto-flow: column;
            grid-column-gap: 10px;
            align-content: center;
            color: var(--green-lfc-third);
        }

            .contacts-on-topbar li a:hover {
                color: var(--green-lfc-second);
            }


/* Logo composto (logo1 + complemento) – mesmo tamanho do original (SVG 200×60) */
.logo-lfc-composed {
    display: inline-flex !important;
    align-items: center;
    gap: 0.35em;
}
.top-bar .logo-lfc-composed img:first-child {
    height: 48px;
    width: auto;
    max-height: 48px;
    object-fit: contain;
}
.top-bar .logo-lfc-composed .logo-complemento {
    max-height: 38px;
    height: auto;
    width: auto;
    object-fit: contain;
}
.search-bar-on-footer .logo-lfc-composed img:first-child {
    height: 40px;
    max-height: 40px;
}
.search-bar-on-footer .logo-lfc-composed .logo-complemento {
    max-height: 32px;
}

.adesao-sucesso-div .logo-lfc-composed {
    margin-bottom: 30px;
}
.adesao-sucesso-div .logo-lfc-composed img:first-child {
    max-width: 176px;
    height: auto;
    width: auto;
}
.adesao-sucesso-div .logo-lfc-composed .logo-complemento {
    max-width: 144px;
    max-height: 64px;
    height: auto;
    width: auto;
}

.top-bar {
    height: 80px;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-column-gap: 50px;
}

    .top-bar ul {
        display: grid;
        grid-auto-flow: column;
        grid-column-gap: 20px;
        align-content: center;
    }

.search-input {
    display: grid;
    grid-auto-flow: column;
    justify-content: start;
    grid-column-gap: 0px !important;
    padding: 0px;
}

    .search-input li .textbox_menu {
        height: 51px !important;
        border-radius: 5px 0px 0px 5px;
        border: 1px solid var(--main-green-lfc);
        padding: 0px 30px 0px 10px;
        font-size: 16px;
        color: var(--main-green-lfc);
        font-weight: 700;
        background-color: #f9f9f9;
        width: 280px;
    }

    .search-input li .botaoBusca {
        height: 51px;
        border-radius: 0px 5px 5px 0px;
        border: 1px solid var(--main-green-lfc);
        border-bottom: 2px solid var(--main-green-lfc);
        padding: 0px 20px;
        width: 100%;
        font-size: 18px;
        font-weight: 700;
        background-color: var(--main-green-lfc);
        color: var(--green-lfc-third);
    }

    .search-input svg {
        position: absolute;
        margin-left: -40px;
        margin-top: 15px;
        height: 20px;
        width: 20px;
        cursor: pointer;
    }

.cta-top-whatsapp {
    display: grid;
    grid-auto-flow: column;
    grid-column-gap: 10px;
    align-content: center;
    justify-content: center;
    padding: 0px 20px;
    border: 2px solid var(--whatsapp-color);
    height: 50px;
    border-radius: 5px;
    transition: var(--all-transition);
}

.cta-duvidas-actions {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: nowrap;
}

.cta-top-contato {
    /* Mantém o mesmo "formato" do botão do Whats (classe compartilhada),
       e aqui apenas customizamos as cores/tipografia para o botão Contato. */
    border-color: var(--purple-lfc) !important;
    background-color: var(--purple-lfc) !important;
    box-shadow: 0 8px 18px rgba(67, 0, 147, 0.18) !important;
    color: var(--green-lfc-third) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
}

    .cta-top-contato:hover {
        background-color: #2f0068 !important;
        border-color: #2f0068 !important;
        color: var(--green-lfc-third) !important;
    }

    .cta-top-whatsapp:hover {
        background-color: var(--whatsapp-color);
    }

        .cta-top-whatsapp:hover svg {
            fill: var(--green-lfc-third);
        }

        .cta-top-whatsapp:hover p {
            color: var(--green-lfc-third);
        }


    .cta-top-whatsapp svg {
        fill: var(--whatsapp-color);
    }

    .cta-top-whatsapp p {
        font-size: 14px;
        color: var(--whatsapp-color);
    }

        .cta-top-whatsapp p span {
            font-size: 18px;
            color: var(--main-green-lfc);
        }

.link-on-nav {
    font-size: 16px;
    color: var(--grey-lfc-dark);
    font-weight: 300;
}

.main-bar {
    border-top: 1px solid #f1f1f1;
    /* Acima da .category-navbar (z-index 9998), senão o dropdown do menu superior fica coberto pela barra verde. */
    position: relative;
    z-index: 10001;
    margin-bottom: 12px;
}

    .main-bar .container-width {
        display: grid;
        grid-template-columns: 1fr 300px;
        height: 60px;
    }

.navbar-first ul {
    height: 60px;
    display: grid;
    grid-auto-flow: column;
    grid-column-gap: 20px;
    justify-content: start;
    align-content: center;
}

    .navbar-first ul li a {
        height: 60px;
        display: inline-block;
        line-height: 60px;
        vertical-align: middle;
        color: var(--grey-lfc-dark);
        font-weight: 300;
        font-size: 16px;
    }

        .navbar-first ul li a:hover {
            background: url(../Images/NovoSite/arrow-top-hover.svg) no-repeat center bottom;
        }

/* Marcadores de área no menu principal — alinhados às identidades Soluções TI (neutro) e Pesquisa & HPC (técnico / azul) */
.navbar-first .nav-area-link {
    display: inline-block;
    white-space: nowrap;
}

.navbar-first ul li a.nav-area-link:hover {
    background: url(../Images/NovoSite/arrow-top-hover.svg) no-repeat center bottom;
}

.active-item-on-nav {
    background: url(../Images/NovoSite/arrow-top-hover.svg) no-repeat center bottom;
}

.special-link {
    color: var(--purple-lfc) !important;
    font-weight: 700 !important;
}

.btn-cart {
    height: 60px;
    background-color: var(--grey-lfc-dark);
    display: grid;
    grid-auto-flow: column;
    grid-column-gap: 10px;
    padding: 0px 20px !important;
    align-content: center;
}

    .btn-cart li {
        display: grid;
        align-content: center;
    }

        .btn-cart li h3 {
            font-size: 14px;
            font-weight: 300;
            color: var(--green-lfc-third);
        }

            .btn-cart li h3 b {
                font-size: 18px;
            }

    .btn-cart svg {
        height: 40px;
        align-content: center;
    }


.products-on-cart-number {
    height: 40px;
    width: 40px;
    background: var(--green-lfc-third);
    border-radius: 20px;
    text-align: center;
    display: grid;
    align-content: center;
}

    .products-on-cart-number p {
        color: var(--grey-lfc-dark);
        font-size: 21px;
        line-height: 18px;
    }

.category-navbar {
    height: 60px;
    background-color: var(--main-green-lfc);
    position: relative;
    z-index: 9998;
}

    /* Somente o UL principal (linha verde). Não aplicar no UL do dropdown. */
    .category-navbar #divMenuTop {
        display: grid;
        grid-auto-flow: column;
        height: 60px;
        align-content: center;
        justify-content: stretch;
        margin: 0;
        padding: 0;
        list-style: none;
    }

        /* Somente itens do 1º nível (categorias). */
        .category-navbar #divMenuTop > li {
            text-align: center;
            position: relative;
        }

            /* Apenas os links de 1º nível (categorias). Evita afetar links do dropdown. */
            .category-navbar #divMenuTop > li > a {
                font-size: 15px;
                font-weight: 700;
                color: var(--green-lfc-third);
                transition: var(--all-transition);
                display: inline-block;
                text-align: center;
                padding: 15px 12px;
                text-decoration: none;
            }

                .category-navbar #divMenuTop > li > a:hover {
                    transform: translateY(-3px);
                }

/* Banner topo (home / passos): estilos atuais na secção 5 — bloco legado removido para evitar grid fixo + altura 290px */

/* SIDEBAR */

.banner-duvidas {
    border-radius: 5px;
    padding: 20px;
    background: var(--purple-lfc) url(../Images/NovoSite/bg-banner-duvidas.png) no-repeat center center;
    background-size: cover;
    height: 340px;
    display: grid;
    grid-auto-flow: row;
}

    .banner-duvidas ul {
        display: grid;
        grid-template-columns: 80px 1fr;
    }

        .banner-duvidas ul li h3 {
            font-size: 21px;
            font-weight: 300;
            text-align: right;
            color: var(--green-lfc-third);
        }

.cta-on-banner-duvidas {
    background-color: var(--main-green-lfc);
    color: var(--green-lfc-third);
    display: inline-block;
    width: 100%;
    text-align: center;
    height: 50px;
    line-height: 50px;
    vertical-align: center;
    margin-top: 10px;
    border-radius: 5px;
    font-size: 18px;
    font-weight: 300;
    transition: var(--all-transition);
}

    .cta-on-banner-duvidas:hover {
        transform: translateY(-5px);
    }

.cta-main {
    background-color: var(--main-green-lfc);
    color: var(--green-lfc-third);
    padding: 0px 50px;
    text-align: center;
    height: 50px;
    line-height: 50px;
    vertical-align: center;
    border-radius: 5px;
    font-size: 24px;
    font-weight: 300;
    transition: var(--all-transition);
    display: inline-block;
}

    .cta-main:hover {
        transform: translateY(-5px);
    }

.sidebar {
    padding-right: 20px;
}

/* Newsletter na sidebar: estilos em secção 8 (.banner-cadastrar-newsletter) */

/* Section Formulário */

.specialist-form {
    background: var(--purple-lfc) url(../Images/NovoSite/pattern-60.png) no-repeat center left;
    background-size: auto 100%;
}

    .specialist-form .container-width {
        grid-template-columns: 1fr;
        display: grid;
    }

.specialist-form-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.specialist-texts {
    padding-right: 100px;
}


    .specialist-texts h3 {
        color: var(--green-lfc-third);
        font-size: 28px;
        font-weight: 300;
    }

    .specialist-texts p {
        color: var(--green-lfc-third);
        font-size: 18px;
        font-weight: 300;
        line-height: 24px;
        margin-top: 20px;
    }

.specialist-form-content ul {
    display: grid;
    grid-row-gap: 15px;
}

    .specialist-form-content ul li {
        margin-bottom: 20px;
    }

        .specialist-form-content ul li p {
            font-size: 16px !important;
            font-weight: 300 !important;
            color: var(--green-lfc-third) !important;
            margin-bottom: 10px !important;
        }

.if-orgao-publico {
    display: grid;
    grid-auto-flow: column;
    justify-content: start;
    grid-column-gap: 20px;
}

    .if-orgao-publico div {
        padding: 10px 20px;
        background-color: var(--green-lfc-third);
        border-radius: 5px;
        color: var(--grey-lfc-dark);
    }

    .if-orgao-publico input {
        height: 15px;
        width: 15px;
        border-radius: 15px;
    }

.campo-formulario-specialist {
    height: 50px !important;
    border-radius: 5px !important;
    border: 0px !important;
    background: #fff !important;
    font-size: 18px !important;
    padding-left: 10px !important;
    width: 100% !important;
    color: var(--grey-lfc-dark) !important;
}

.textarea-formulario-specialist {
    height: 100px !important;
    border-radius: 5px !important;
    border: 0px !important;
    background: #fff !important;
    font-size: 18px !important;
    padding-left: 10px !important;
    width: 100% !important;
    padding-right: 10px !important;
    padding-top: 10px !important;
    color: var(--grey-lfc-dark) !important;
    margin-bottom: 0px !important;
}

.btn-formulario-specialist {
    height: 50px !important;
    border-radius: 5px !important;
    border: 0px !important;
    background: var(--grey-lfc-dark) !important;
    font-size: 18px !important;
    text-align: center !important;
    width: 100% !important;
    color: var(--green-lfc-third) !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

    .btn-formulario-specialist:hover {
        background: var(--main-green-lfc);
        color: var(--green-lfc-third);
    }


.partners-form {
    background: var(--grey-lfc-dark) url(../Images/NovoSite/pattern-60.png) no-repeat center left;
    background-size: auto 100%;
}

    .partners-form .container-width {
        grid-template-columns: 1fr;
        display: grid;
    }

.btn-formulario-partners {
    height: 50px;
    border-radius: 5px;
    border: 0px;
    background: var(--main-green-lfc);
    font-size: 18px;
    text-align: center;
    width: 100% !important;
    color: var(--green-lfc-third);
    font-weight: 700;
    cursor: pointer;
}

    .btn-formulario-partners:hover {
        background: var(--green-lfc-third);
        color: var(--main-green-lfc);
    }


/* Lista de clientes */

.list-of-clients {
    display: grid;
    grid-template-columns: 1fr 3fr;
    align-content: center;
    padding: 20px;
}

.inner-list-of-clients {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 15px;
    align-items: center;
}

    .inner-list-of-clients li {
        text-align: center;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 10px;
    }

    .inner-list-of-clients li img {
        width: 90px;
        height: 70px;
        object-fit: contain;
    }

/* Lista de produtos */

.order-by-cta {
    display: grid;
    justify-content: end;
    grid-auto-flow: column;
    grid-column-gap: 10px;
    margin-top: 20px;
    align-content: center;
}

    .order-by-cta DropDownList {
        display: grid;
        grid-auto-flow: column;
        align-content: center;
        height: 30px;
        border-radius: 3px;
        border: 1px solid var(--grey-lfc-dark);
        padding: 0px 20px;
        grid-column-gap: 10px;
    }

.products-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-row-gap: 50px;
}

    .products-list li {
        padding: 20px;
    }

        .products-list li .product-image {
            height: 200px;
            background-size: cover;
            background-position: center center;
        }

        .products-list li .product-type {
            font-size: 14px;
            color: var(--grey-lfc-dark);
            font-weight: 700;
        }

        .products-list li .product-title {
            font-size: 16px;
            color: var(--grey-lfc-dark);
            font-weight: 300;
            margin-top: 10px;
        }

        .products-list li .product-price {
            font-size: 18px;
            color: var(--main-green-lfc);
            font-weight: 700;
            margin-top: 10px;
        }

        .products-list li .product-cta {
            display: inline-block;
            padding: 15px;
            width: 100%;
            text-align: center;
            background-color: var(--main-green-lfc);
            margin-top: 20px;
            font-size: 18px;
            color: var(--green-lfc-third);
            border-radius: 5px;
        }

            .products-list li .product-cta:hover {
                background-color: var(--grey-lfc-dark);
            }

/* Footer */

.search-bar-on-footer {
    background-color: var(--green-lfc-third);
    padding: 20px;
}

    .search-bar-on-footer .container-width {
        display: grid;
        grid-template-columns: 1fr 3fr;
    }

.footer {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    background: none !important;
}

.icon-and-link {
    color: var(--grey-lfc-dark);
    font-weight: 700;
    display: grid;
    grid-auto-flow: column;
    justify-content: start;
    grid-column-gap: 10px;
    align-content: center;
    white-space: nowrap;
}

.social-media-list {
    display: grid;
    grid-auto-flow: column;
    justify-content: start;
    grid-column-gap: 10px;
}

.site-map-on-footer {
    padding-left: 50px;
}

    .site-map-on-footer h4 {
        font-weight: 700;
        padding-bottom: 30px;
        color: var(--grey-lfc-dark);
        font-size: 16px;
    }

.links-on-footer {
    display: grid;
    grid-row-gap: 10px;
}

    .links-on-footer li a {
        font-weight: 300;
        color: var(--grey-lfc-dark);
    }

        .links-on-footer li a:hover {
            font-weight: 300;
            color: var(--green-lfc-first);
        }

.links-on-foooter-2-columns {
    grid-template-columns: 1fr 1fr;
}

/* Estilos da página de projetos */

.cta-on-bottom-with-bg {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin-top: 0;
    height: 215px;
    background: url(../Images/NovoSite/lines-on-bottom-bg.svg) no-repeat bottom center;
    background-size: cover;
}

.cta-on-bg-bottom {
    height: 100%;
    display: grid;
    align-content: center;
    justify-content: start;
}

    .cta-on-bg-bottom a {
        padding: 15px 30px;
        background: var(--green-lfc-third);
        color: var(--purple-lfc);
        border-radius: 5px;
        border: 1px solid var(--main-green-lfc);
        font-size: 18px;
        font-weight: 700;
    }

.decreto_link {
    color: var(--green-lfc-second);
    text-decoration: underline !important;
}

    .decreto_link:hover {
        color: #fff;
    }

@media (max-width: 1023px) {
    .full-width-div {
        padding: 0px 10px;
        border-radius: 5px;
        border: 1px solid red;
    }

    .hide-on-mobile {
        display: none;
    }

    .container-width {
        width: 92vw;
        overflow: auto;
    }

    .justify-end {
        justify-content: start;
    }

    /* Heaader top */

    .navbar-first ul {
        white-space: nowrap;
    }

    .cta-top-whatsapp {
        width: 100%;
    }

    .cta-duvidas-actions {
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
    }

    .cta-top-contato {
        width: 100%;
    }

    .top-bar-left {
        padding-right: 0px;
        justify-content: initial;
    }

    .top-bar-right {
        width: 100%;
        justify-content: initial;
    }

    .logo-lfc {
        text-align: center;
    }

    .top-bar {
        height: auto;
        grid-template-columns: 1fr;
        grid-row-gap: 10px;
        padding: 10px 0px;
    }

        .top-bar ul {
            grid-auto-flow: row;
            grid-row-gap: 10px;
        }

    .search-input {
        grid-auto-flow: column !important;
        max-width: 100%;
    }

    .search-input {
        display: grid;
        grid-auto-flow: initial;
        justify-content: center;
        grid-template-columns: 1fr 100px;
        grid-column-gap: 0px !important;
        padding: 0px;
    }

        .search-input li .textbox_menu {
            height: 50px;
            border-radius: 5px 0px 0px 5px;
            border: 1px solid var(--main-green-lfc);
            padding: 0px 10px 0px 10px;
            width: 100%;
        }

        .search-input li .botaoBusca {
            padding: 0px;
            width: 100%;
        }

    .main-bar {
        justify-content: start;
        overflow-x: scroll;
    }

        .main-bar .container-width {
            grid-template-columns: 1fr 200px;
            grid-column-gap: 20px;
        }

    .category-navbar #divMenuTop {
        display: grid;
        grid-auto-flow: column;
        justify-content: start;
        grid-column-gap: 20px;
        overflow-x: auto;
        white-space: nowrap;
    }

        .category-navbar #divMenuTop > li > a {
            width: auto;
            display: inline-block;
        }

    /* No mobile, priorizar a listagem/conteúdo antes da sidebar (banner/form/menu) */
    .sidebar-and-list {
        display: flex;
        flex-direction: column;
    }

    .sidebar-and-list .main-content {
        order: 1;
    }

    .sidebar-and-list .sidebar {
        order: 2;
    }

    .specialist-form {
        min-height: auto;
        background: var(--purple-lfc);
    }

        .specialist-form .container-width {
            grid-template-columns: 1fr;
        }

    .partners-form {
        min-height: auto;
        background: var(--purple-lfc);
    }

        .partners-form .container-width {
            grid-template-columns: 1fr;
        }

    .specialist-form-content {
        grid-template-columns: 1fr;
    }

    .specialist-texts {
        padding-right: 0px;
        padding-bottom: 50px;
    }

    .list-of-clients {
        grid-template-columns: 1fr;
    }

    .inner-list-of-clients {
        grid-template-columns: repeat(2, 1fr);
        grid-gap: 20px;
    }

    .list-of-clients h1 {
        text-align: center;
        padding: 30px 0px;
    }

    .search-bar-on-footer .container-width {
        grid-template-columns: 1fr;
        grid-row-gap: 20px;
    }

    .footer {
        grid-template-columns: 1fr;
        grid-row-gap: 50px;
    }

    .site-map-on-footer {
        padding-left: 0px;
    }


    .cta-on-bottom-with-bg {
        margin-top: 0;
    }

    /* Banner on top */

    .banner-top {
        grid-template-columns: 1fr;
    }

    .divided-part-on-banner {
        grid-template-columns: 1fr;
    }

    .banner-top-wrap {
        background-image: linear-gradient(45deg, var(--grey-lfc-dark), var(--grey-lfc-dark));
        background-position: center center;
        background-size: auto 100%;
    }

    .banner-green-side {
        border-radius: 30px 0px 0px 0px;
    }

    .banner-purple-side {
        border-radius: 0px 0px 30px 0px;
    }

    .sidebar {
        padding-right: 0px;
    }

    .products-list {
        grid-template-columns: 1fr;
    }
}


/* Estilos de limpeza */

#divMenuTop li a i {
    display: none !important;
}

p {
    margin: 0px !important;
}

input {
    margin: 0px !important;
}

/* Dropdown do menu de categorias (desktop). No mobile ele permanece oculto (ver media abaixo). */
#divMenuTop > li {
    position: relative;
}

.dropdown-content {
    display: none !important;
    position: absolute;
    left: 0;
    top: 100%;
    margin-top: 6px;
    min-width: 280px;
    max-width: min(520px, calc(100vw - 24px));
    max-height: calc(100vh - 180px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 12px 8px;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 12px 30px rgba(0,0,0,0.18);
    z-index: 10000;
    white-space: normal;
    text-align: left;
}

/* Remove width:100% do primeiro dropdown */
.dropdown-content[style*="width:100%"] {
    width: auto !important;
    min-width: 280px;
    max-width: 400px;
}

#divMenuTop > li:hover > .dropdown-content {
    display: block !important;
}

.dropdown-content-li {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dropdown-content-li a {
    display: block;
    padding: 10px 12px;
    border-radius: 6px;
    color: var(--grey-lfc-dark);
    text-decoration: none;
    white-space: normal;
    word-wrap: break-word;
    line-height: 1.4;
    transition: background-color 0.2s ease;
    text-align: left;
}

/* Garante contraste mesmo com regras genéricas do menu */
#divMenuTop .dropdown-content .dropdown-content-li > a {
    color: var(--grey-lfc-dark);
}

.dropdown-content-li a:hover,
.dropdown-content-li a:focus {
    background: rgba(118, 193, 66, 0.12);
    outline: none;
}

/* Scrollbar personalizada para os dropdowns */
.dropdown-content::-webkit-scrollbar {
    width: 8px;
}

.dropdown-content::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

.dropdown-content::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 4px;
}

.dropdown-content::-webkit-scrollbar-thumb:hover {
    background: #555;
}

@media (max-width: 1023px) {
    /* Evita dropdown flutuante em touch/smartphone (o acesso fica pelo menu lateral + rodapé). */
    .dropdown-content {
        display: none !important;
    }
}

.full-width-div {
    padding: 0px 50px;
    border-radius: 5px;
}

@media (max-width: 1023px) {
    .full-width-div {
        width: 100%;
        padding: 0px 5px;
        border-radius: 5px;
    }
}

.confirmation-message-page {
    text-align: center;
    max-width: 300px;
    margin: auto;
}

    .confirmation-message-page h2 {
        font-size: 35px;
        color: var(--green-lfc-first);
        line-height: 44px;
    }

    .confirmation-message-page h4 {
        font-size: 18px;
        color: var(--grey-lfc-dark);
        padding-top: 0px;
        padding-bottom: 20px;
        line-height: 28px;
    }

.align-center-popup {
    display: grid;
    grid-auto-flow: column;
    column-gap: 10px;
    justify-content: center;
    margin-top: 20px;
}

.parent {
    display: flex;
}

.child {
    width: 100px;
    margin: auto;
}

/* Responsividade para lista de clientes */

@media (max-width: 1200px) {
    .inner-list-of-clients {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .list-of-clients {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .inner-list-of-clients {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 600px) {
    .inner-list-of-clients {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .inner-list-of-clients li img {
        width: 70px;
        height: 55px;
    }
}


/* ============================================================
   LFC GOVERNO — PATCH IDENTIDADE VISUAL HOME (ADESÕES)
   Adicionar ao final de public/site/Styles/styleNew.css
   Não remove nem altera regras existentes — apenas sobrescreve
   via especificidade e ordem de cascata.
   ============================================================ */

/* ── 1. TOPBAR ──────────────────────────────────────────── */
.grey-top-bar {
    background: #3D3D3D;
    border-bottom: none;
}
.grey-top-bar p,
.grey-top-bar .contacts-on-topbar a {
    font-size: 11px;
    color: #EFF8E8;
}

/* ── 2. NAVBAR PRINCIPAL ────────────────────────────────── */
.top-bar {
    padding: 10px 0;
    align-items: center;
    gap: 12px;
}

/* Search input — borda verde sólida, sem arredondamento */
.search-input {
    border: 1.5px solid var(--main-green-lfc);
    border-radius: 0;
    overflow: hidden;
}
.textbox_menu {
    border: none;
    border-radius: 0;
    font-size: 12px;
    color: #222;
    padding: 7px 10px;
}
.textbox_menu:focus {
    outline: none;
    border: none;
}
.botaoBusca {
    background: var(--main-green-lfc);
    color: white;
    border: none;
    border-radius: 0;
    font-size: 12px;
    font-weight: 600;
    padding: 7px 16px;
    cursor: pointer;
    font-family: 'Ubuntu', sans-serif;
    white-space: nowrap;
}
.botaoBusca:hover {
    background: var(--green-lfc-first);
}

/* WhatsApp CTA */
.cta-top-whatsapp {
    border-radius: 0;
    font-size: 11px;
}
.cta-top-contato {
    border-radius: 0;
    font-size: 11px;
    font-weight: 600;
}

/* Carrinho */
.btn-cart {
    background: var(--grey-lfc-dark);
    border-radius: 0;
    padding: 6px 12px;
    gap: 6px;
}
.btn-cart h3 {
    font-size: 11px;
    color: var(--green-lfc-third);
    line-height: 1.3;
}

/* ── 3. MENU PRINCIPAL ──────────────────────────────────── */
.main-bar {
    border-bottom: 2px solid var(--main-green-lfc);
    background: white;
}
.navbar-first ul li a {
    padding: 9px 14px;
    font-size: 12px;
    font-weight: 500;
    color: #333;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color 0.15s, border-color 0.15s;
}
.navbar-first ul li a:hover,
.navbar-first ul li a.active {
    color: var(--main-green-lfc);
    border-bottom-color: var(--main-green-lfc);
}

/* Convite a fornecedores (slug parcerias): leve contraste, sem competir com o CTA teal */
.navbar-first ul li a.nav-link-fornecedor-ata {
    color: #3a6b20;
    font-weight: 600;
    background: rgba(118, 193, 66, 0.1);
    border-radius: 6px;
    border-bottom-color: transparent;
    box-shadow: inset 0 0 0 1px rgba(118, 193, 66, 0.2);
}

.navbar-first ul li a.nav-link-fornecedor-ata:hover,
.navbar-first ul li a.nav-link-fornecedor-ata:focus-visible {
    color: #264715;
    background: rgba(118, 193, 66, 0.16);
    border-bottom-color: var(--main-green-lfc);
    box-shadow: inset 0 0 0 1px rgba(118, 193, 66, 0.28);
}

.navbar-first ul li a.nav-link-fornecedor-ata:focus-visible {
    outline: 2px solid var(--main-green-lfc);
    outline-offset: 2px;
}

/* ── 4. BARRA DE CATEGORIAS ─────────────────────────────── */
.category-navbar {
    background: white;
    border-bottom: 1px solid #E0E0E0;
    padding: 0 0;
    /* Sobrescreve legado (altura fixa 60px) para não interferir no dropdown */
    height: auto;
    min-height: 0;
}
.category-navbar #divMenuTop {
    display: flex;
    flex-wrap: nowrap;
    gap: 0;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
/* overflow-x:auto no UL faz o eixo Y computar como auto e recorta position:absolute do dropdown */
@media (min-width: 1024px) {
    .category-navbar #divMenuTop {
        overflow-x: visible;
        overflow-y: visible;
    }
}
@media (max-width: 1023px) {
    .category-navbar #divMenuTop {
        overflow-x: auto;
    }
}
.category-navbar #divMenuTop::-webkit-scrollbar {
    display: none;
}
/* Apenas links do 1.º nível — não aplicar ao painel .dropdown-content */
.category-navbar #divMenuTop > li > a {
    padding: 7px 14px;
    font-size: 11px;
    color: #666;
    white-space: nowrap;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    transition: color 0.15s, border-color 0.15s;
}
.category-navbar #divMenuTop > li > a:hover,
.category-navbar #divMenuTop > li.ativo > a,
.category-navbar #divMenuTop > li.active > a {
    color: var(--main-green-lfc);
    border-bottom-color: var(--main-green-lfc);
    font-weight: 500;
}
/* Hierarquia no dropdown (alinhada ao menu lateral) */
.category-navbar .dropdown-content .dropdown-content-li--depth-1 > a {
    font-weight: 600;
    font-size: 10px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #555;
}
.category-navbar .dropdown-content .dropdown-content-li--depth-2 > a {
    padding-left: 24px;
    font-weight: 400;
    font-size: 11px;
    text-transform: none;
    color: var(--grey-lfc-dark);
}
.category-navbar .dropdown-content .dropdown-content-li--depth-3 > a,
.category-navbar .dropdown-content .dropdown-content-li--depth-4 > a {
    padding-left: 32px;
    font-weight: 400;
    font-size: 11px;
    text-transform: none;
    color: var(--grey-lfc-dark);
}

/* ── 4b. HOME — BANNER STI + PESQUISA (identidade clara, destaque) ── */
/* Respiro entre barra de categorias e banner da home: 10px + 0.625rem (~20px total) */
.home-top-banner-wrap {
    padding-top: 0.625rem;
}

.home-crosssell {
    margin: 0 0 14px;
    padding: 0;
    font-family: 'Ubuntu', sans-serif;
}
.home-crosssell__eyebrow {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 10px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #73b843;
}
h1.home-crosssell__eyebrow {
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
}
.home-crosssell__eyebrow-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #73b843;
    flex-shrink: 0;
}
.home-crosssell__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border: 1px solid #dfe6dc;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.04);
}

/* Home — três jornadas (Atas + STI + HPC) no mesmo padrão de painéis */
.home-crosssell__grid--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Adesões / TI / HPC — paleta alinhada ao mockup (fundos sólidos, linha #dfe6dc) */
.home-crosssell__panel--adesoes {
    background: #faf5eb;
    border-right: 1px solid #dfe6dc;
}
.home-crosssell__panel--adesoes .home-crosssell__panel-kicker {
    color: #7a4b00;
}
.home-crosssell__panel--adesoes .home-crosssell__lead {
    color: #6b7280;
}
.home-crosssell__tag--adesoes {
    color: #4b5563;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid #d4dccd;
}
.home-crosssell__tag--adesoes:hover {
    background: rgba(255, 255, 255, 0.95);
    border-color: #c8dcbc;
    color: #374151;
}
.home-crosssell__note--adesoes {
    color: #6b7280;
}
.home-crosssell__panel {
    padding: 14px 16px 16px;
    box-sizing: border-box;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}
/* Soluções TI */
.home-crosssell__panel--sti {
    background: #f8faf7;
    border-right: 1px solid #dfe6dc;
}
.home-crosssell__panel--sti .home-crosssell__panel-kicker {
    color: #4e8d24;
}
.home-crosssell__panel--sti .home-crosssell__lead {
    color: #6b7280;
}

/* Pesquisa & HPC */
.home-crosssell__panel--hpc {
    background: #eef5fb;
    border-right: none;
}
.home-crosssell__panel--hpc .home-crosssell__lead {
    color: #6b7280;
}
.home-crosssell__panel-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 2px;
}
.home-crosssell__panel-kicker {
    font-size: 11px;
    font-weight: 700;
    color: #3d3d3d;
    letter-spacing: 0.02em;
}
.home-crosssell__panel--hpc .home-crosssell__panel-kicker {
    color: #235d99;
}
.home-crosssell__title {
    margin: 0;
    font-size: 15px;
    line-height: 1.3;
    font-weight: 700;
    color: #1f2937;
}
.home-crosssell__title-link {
    color: inherit;
    text-decoration: none;
}
.home-crosssell__title-link:hover,
.home-crosssell__title-link:focus-visible {
    text-decoration: underline;
    text-underline-offset: 2px;
}
.home-crosssell__lead {
    margin: 0;
    font-size: 12px;
    line-height: 1.5;
    font-weight: 400;
    color: #6b7280;
}
.home-crosssell__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
}
.home-crosssell__tag {
    font-size: 10px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 999px;
    text-decoration: none;
    transition: background-color 0.15s, border-color 0.15s, color 0.15s;
}
.home-crosssell__tag--sti {
    color: #4b5563;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid #d4dccd;
}
.home-crosssell__tag--sti:hover {
    background: rgba(255, 255, 255, 0.95);
    border-color: #c8dcbc;
    color: #374151;
}
.home-crosssell__tag--hpc {
    color: #4b5563;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid #d4dccd;
}
.home-crosssell__tag--hpc:hover {
    background: rgba(255, 255, 255, 0.95);
    border-color: #c8dcbc;
    color: #374151;
}
.home-crosssell__brands {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
}
.home-crosssell__brands-label {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #999;
    margin-right: 2px;
}
.home-crosssell__brand {
    font-size: 10px;
    font-weight: 800;
    padding: 3px 8px;
    border-radius: 4px;
}
.home-crosssell__brand--dell {
    color: #0c4a6e;
    background: rgba(14, 116, 144, 0.12);
    border: 1px solid rgba(14, 116, 144, 0.35);
}
.home-crosssell__brand--nvidia {
    color: #3b6d11;
    background: rgba(118, 193, 66, 0.18);
    border: 1px solid rgba(118, 193, 66, 0.5);
}
.home-crosssell__brand--muted {
    font-weight: 600;
    color: #666;
    background: #f3f4f6;
    border: 1px solid #e5e7eb;
}
.home-crosssell__note {
    margin: 4px 0 0;
    font-size: 11px;
    line-height: 1.45;
    color: #6b7280;
    font-style: italic;
}
@media (max-width: 767px) {
    .home-crosssell__grid {
        grid-template-columns: 1fr;
    }
    .home-crosssell__grid--three .home-crosssell__panel--adesoes,
    .home-crosssell__grid--three .home-crosssell__panel--sti {
        border-right: none;
        border-bottom: 1px solid #dfe6dc;
    }
    .home-crosssell__grid--three .home-crosssell__panel--adesoes {
        border-bottom-color: #dfe6dc;
    }
    .home-crosssell__panel--sti {
        border-right: none;
        border-bottom: 1px solid #dfe6dc;
    }
}

/* ── 5. BANNER TOP (passos — infográfico legado, flat) ──── */
.banner-top {
    background: transparent;
    border: none;
    margin: 0 0 16px;
    min-height: 0;
    border-radius: 0;
}
.banner-top-green-part {
    background: var(--green-lfc-third);
    border: 1px solid var(--green-lfc-second);
    border-radius: 0 0 6px 6px;
    padding: 20px 18px 22px;
    height: auto;
    min-height: 0;
    display: block;
    box-sizing: border-box;
}
.banner-atas-heading {
    font-family: 'Ubuntu', sans-serif;
    font-size: 17px;
    line-height: 1.35;
    font-weight: 700;
    color: #2d5016;
    text-align: center;
    margin: 0 0 14px;
}
.banner-atas-sub {
    font-family: 'Ubuntu', sans-serif;
    font-size: 13px;
    line-height: 1.45;
    font-weight: 400;
    color: #5a5a5a;
    text-align: center;
    margin: 0 auto 16px;
    max-width: 52em;
}
/* Círculos + linha contínua (estética legado, sem sombra/gradiente) */
.banner-atas-steps,
.steps-to-acquire {
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 6px;
    list-style: none;
    margin: 0;
    padding: 12px 10px 14px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    border: 1px solid #c5dcb0;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.65);
    overflow: visible;
}
.banner-atas-steps::before,
.steps-to-acquire::before {
    content: '';
    position: absolute;
    left: 12%;
    right: 12%;
    top: 32px;
    height: 2px;
    background: var(--main-green-lfc);
    z-index: 0;
    pointer-events: none;
}
.banner-atas-step,
.steps-to-acquire li {
    position: relative;
    z-index: 1;
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
    padding: 4px 8px 10px;
    margin: 0;
    border: none;
    box-sizing: border-box;
}
.banner-atas-step__num,
.steps-to-acquire li > div:first-child {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    line-height: 32px;
    text-align: center;
    font-family: 'Ubuntu', sans-serif;
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    background: var(--main-green-lfc);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
}
.banner-atas-step__text,
.steps-to-acquire li h3 {
    flex: 1 1 auto;
    min-width: 0;
    font-family: 'Ubuntu', sans-serif;
    font-size: 12px;
    line-height: 1.45;
    font-weight: 400;
    color: #5a5a5a;
    margin: 0;
    text-align: center;
    max-width: 22em;
}
.steps-to-acquire li h3 b {
    font-weight: 500;
}

/* ── 6. FILTRO TIPO DE ATA ──────────────────────────────── */
.order-by-cta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    padding: 8px 12px;
    background: white;
    border: 1px solid #E0E0E0;
}
.order-by-cta p {
    font-size: 10px;
    font-weight: 700;
    color: #666;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0;
    white-space: nowrap;
}
.select-cta {
    border: 1px solid #E0E0E0;
    border-radius: 0;
    padding: 5px 8px;
    font-size: 11px;
    color: #222;
    font-family: 'Ubuntu', sans-serif;
    outline: none;
    min-width: 160px;
}
.select-cta:focus {
    border-color: var(--main-green-lfc);
}

/* ── 7. SIDEBAR — ATAS (SRP + filtro + menu) ─────────────── */
.sidebar-atas-intro {
    padding: 8px 10px;
    margin-bottom: 10px;
    border: 1px solid #dce9d0;
    background: #fafcf7;
    font-family: 'Ubuntu', sans-serif;
}
.sidebar-atas-intro__text {
    margin: 0;
    font-size: 10px;
    line-height: 1.45;
    color: #555;
}
.sidebar-atas-filter {
    margin-bottom: 12px;
    font-family: 'Ubuntu', sans-serif;
}
.sidebar-atas-filter__label {
    margin: 0 0 6px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #666;
}
.sidebar-atas-filter__select {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* Filtro no conteúdo: só mobile/tablet (desktop usa sidebar) */
@media (min-width: 1024px) {
    .order-by-cta--atas.hide-on-desktop {
        display: none !important;
    }
}

/* Menu lateral — sobrepõe style.css (.menulateral ul li verde !important, texto branco, acc-menu legado) */
.menulateral {
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 0;
    padding: 0;
}
.menulateral .acc-menu {
    margin-left: 0 !important;
}
.menulateral .acc-menu > li.menulateral_titulo > input[type="checkbox"] {
    display: none;
}
.menulateral .acc-menu label {
    float: none !important;
    width: auto !important;
    margin: 0;
    font-weight: inherit;
    color: inherit;
    cursor: pointer;
}
/* Grupos (categoria pai) */
.menulateral ul.acc-menu > li.menulateral_titulo {
    background: transparent !important;
    border-bottom: 1px solid #e8e8e8;
}
.menulateral ul.acc-menu > li.menulateral_titulo:last-child {
    border-bottom: none;
}
.menulateral .acc-menu > li.menulateral_titulo > a {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 0 !important;
    padding: 10px 12px !important;
    margin: 0;
    background: #fff !important;
    color: #444 !important;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    text-transform: none;
    border: none;
    transition: background 0.12s, color 0.12s;
}
.menulateral .acc-menu > li.menulateral_titulo > a label {
    flex: 1;
    text-align: left;
    line-height: 1.35;
}
/* Chevron (expandido / fechado) */
.menulateral .acc-menu > li.menulateral_titulo > input:not(:checked) ~ a::after {
    content: "›";
    flex-shrink: 0;
    font-size: 16px;
    font-weight: 400;
    color: #999;
    line-height: 1;
}
.menulateral .acc-menu > li.menulateral_titulo > input:checked ~ a::after {
    content: "▾";
    flex-shrink: 0;
    font-size: 11px;
    color: var(--main-green-lfc);
    line-height: 1;
}
.menulateral .acc-menu > li.menulateral_titulo > a:hover,
.menulateral .acc-menu > li.menulateral_titulo > a:focus-visible {
    background: #f3f8ed !important;
    color: #2d5a0c !important;
}
/* Sublista */
.menulateral .acc-menu > li.menulateral_titulo > ul {
    margin: 0 !important;
    padding: 4px 0 8px !important;
    width: 100% !important;
    max-width: none !important;
    background: #fafafa;
    border-top: 1px solid #efefef;
    border-radius: 0;
    overflow: visible !important;
}
/* Acordeão (mesma lógica do legado .acc-menu, com especificidade maior) */
.menulateral .acc-menu > li.menulateral_titulo > input:not(:checked) ~ ul > li {
    height: 0 !important;
    overflow: hidden !important;
    transition: height 0.2s ease-in;
    border: none !important;
}
.menulateral .acc-menu > li.menulateral_titulo > input:checked ~ ul > li,
.menulateral .acc-menu > li.menulateral_titulo > input.current ~ ul > li {
    height: auto !important;
    overflow: visible !important;
}
.menulateral .acc-menu > li.menulateral_titulo > ul > li.menulateral_subitem {
    background: transparent !important;
}
.menulateral .acc-menu > li.menulateral_titulo > ul > li.menulateral_subitem > a {
    display: block !important;
    padding: 6px 12px 6px 16px !important;
    min-height: 0 !important;
    margin: 0;
    background: transparent !important;
    color: #555 !important;
    font-size: 11px;
    font-weight: 400;
    text-decoration: none;
    line-height: 1.4;
    border-left: 3px solid transparent;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.menulateral .acc-menu > li.menulateral_titulo > ul > li.menulateral_subitem--depth-2 > a {
    padding-left: 24px !important;
}
.menulateral .acc-menu > li.menulateral_titulo > ul > li.menulateral_subitem--depth-3 > a {
    padding-left: 32px !important;
}
.menulateral .acc-menu > li.menulateral_titulo > ul > li.menulateral_subitem > a:hover {
    background: #f0f5ea !important;
    color: var(--main-green-lfc) !important;
}
/* Ativo — contraste legível (substitui amarelo sobre verde escuro do legado) */
/* Sobrepõe style.css (.corpo .menulateral … amarelo/verde escuro) */
.corpo .menulateral ul li a.categoria-ativa,
.corpo .menulateral .acc-menu ul li a.categoria-ativa,
.menulateral ul li a.categoria-ativa,
.menulateral .acc-menu ul li a.categoria-ativa,
.menulateral .acc-menu > li.menulateral_titulo > a.categoria-ativa {
    background-color: #eef7e3 !important;
    background: #eef7e3 !important;
    color: #2d5a0c !important;
    font-weight: 600 !important;
    border-left: 3px solid var(--main-green-lfc) !important;
    border-left-color: var(--main-green-lfc) !important;
    padding-left: 13px !important;
}
.menulateral .acc-menu > li.menulateral_titulo > ul > li.menulateral_subitem--depth-2 > a.categoria-ativa {
    padding-left: 21px !important;
}
.menulateral .acc-menu > li.menulateral_titulo > ul > li.menulateral_subitem--depth-3 > a.categoria-ativa {
    padding-left: 29px !important;
}

/* ── 8. NEWSLETTER SIDEBAR (alinhado ao menu / filtro: claro, compacto) ── */
.banner-cadastrar-newsletter {
    border-radius: 0;
    overflow: hidden;
    border: 1px solid #e0e0e0;
    margin-top: 10px;
    background: #fff;
}
.banner-cadastrar-newsletter .top-banner-newsletter {
    background: #f4faf0;
    border-bottom: 1px solid #dce9d0;
    padding: 8px 10px;
}
.banner-cadastrar-newsletter .top-banner-newsletter h3 {
    margin: 0;
    font-size: 11px;
    line-height: 1.4;
    font-weight: 600;
    color: #2d5016;
}
.banner-cadastrar-newsletter .bottom-banner-newsletter {
    background: #fff;
    padding: 8px 10px 10px;
}
.banner-cadastrar-newsletter .bottom-banner-newsletter > p {
    margin: 0 0 6px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #666;
}
.banner-cadastrar-newsletter .bottom-banner-newsletter .g-recaptcha {
    margin: 8px 0;
    transform-origin: 0 0;
    transform: scale(0.85);
}
/* Só na sidebar: inputs compactos (o legado .bottom-banner-newsletter .input-news-form foi removido) */
.banner-cadastrar-newsletter input.input-news-form {
    box-sizing: border-box;
    width: 100%;
    height: auto;
    min-height: 0;
    padding: 5px 8px;
    margin: 0 0 6px;
    border: 1px solid #e0e0e0;
    border-radius: 0;
    background: #fff;
    color: #333;
    font-size: 11px;
    font-weight: 400;
    line-height: 1.35;
    font-family: 'Ubuntu', sans-serif;
}
.banner-cadastrar-newsletter input.input-news-form::placeholder {
    color: #999;
}
.banner-cadastrar-newsletter input.input-news-form:focus {
    outline: none;
    border-color: var(--main-green-lfc);
}
.banner-cadastrar-newsletter .newsletter-optin-label {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 10px;
    line-height: 1.4;
    color: #555;
    margin: 2px 0 8px;
    cursor: pointer;
    font-family: 'Ubuntu', sans-serif;
}
.banner-cadastrar-newsletter .newsletter-optin-label input[type="checkbox"] {
    margin: 2px 0 0;
    flex-shrink: 0;
    width: 14px;
    height: 14px;
}
.banner-cadastrar-newsletter .newsletter-optin-label a {
    color: #3b6d11;
    text-decoration: underline;
}
.banner-cadastrar-newsletter .newsletter-optin-label a:hover {
    color: var(--main-green-lfc);
}
.banner-cadastrar-newsletter .button-news-form {
    display: block;
    width: 100%;
    box-sizing: border-box;
    margin-top: 2px;
    padding: 7px 10px;
    border: 1px solid #5a9c32;
    background: var(--main-green-lfc);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.3;
    cursor: pointer;
    border-radius: 0;
    font-family: 'Ubuntu', sans-serif;
}
.banner-cadastrar-newsletter .button-news-form:hover {
    background: #69b038;
    border-color: #528d2d;
}

/* ── 9. CARDS DE PRODUTO ────────────────────────────────── */
.produtosDestaque {
    margin-bottom: 0;
    padding-bottom: 24px;
    border-bottom: 1px solid #dedede;
}
/* Catálogo geral (atas, categorias): colunas fixas por breakpoint.
   Home “curados” usa .home-curated-atas__grid — excluído aqui para não conflitar. */
.produtosDestaque:not(.home-curated-atas__grid) ul {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    list-style: none;
    padding: 0;
    margin: 0;
}
/* ul em grid: style.css ainda define ul li { width: calc((100%-gaps)/4) } para flex —
   com grid, 100% = largura da célula; esse calc vira ~1/16 do contentor (colunas finíssimas). */
.produtosDestaque ul li {
    background: white;
    border: 1px solid #E0E0E0;
    display: flex;
    flex-direction: column;
    transition: border-color 0.15s;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}
.produtosDestaque ul li:hover {
    border-color: var(--main-green-lfc);
}
.produtosDestaque ul li a {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    color: inherit;
    /* Mesmo recuo horizontal para título, badge, qty e preço (legado usa justify em todos os p). */
    --pd-card-x: 10px;
    padding: 0 var(--pd-card-x);
    box-sizing: border-box;
    align-items: stretch;
}

/* Container da imagem — fundo uniforme, largura total do card (compensa padding do link) */
.produtosDestaque ul li .imagem {
    background: #FAFAFA;
    border-bottom: 1px solid #EFEFEF;
    width: calc(100% + 2 * var(--pd-card-x));
    max-width: none;
    margin-left: calc(-1 * var(--pd-card-x));
    margin-right: calc(-1 * var(--pd-card-x));
    height: 140px;
    object-fit: contain;
    padding: 10px;
    display: block;
    box-sizing: border-box;
}

/* Título do produto */
.produtosDestaque ul li .detalhes {
    font-size: 11px;
    font-weight: 500;
    color: #222;
    line-height: 1.4;
    padding: 10px 0 6px;
    margin: 0;
    min-height: calc(1.4em * 4);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    overflow: hidden;
    text-align: left;
}

/* Tipo de ata — destaque legível (sem caixa); respiro em relação ao título e à qty */
.produtosDestaque ul li a > p:nth-child(3),
.produtosDestaque ul li .produto-ata-badge {
    font-size: 11px;
    font-weight: 700;
    color: #2d5016;
    background: none;
    border: none;
    display: block;
    width: auto;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0;
    margin: 2px 0 0;
    min-height: 0;
    line-height: 1.45;
    text-align: left;
}

/* Quantidade disponível */
.produtosDestaque ul li a > p:nth-child(4),
.produtosDestaque ul li .produto-qty {
    font-size: 10px;
    color: #666;
    padding: 8px 0 0;
    margin: 0;
    min-height: 18px;
    line-height: 1.45;
    text-align: left;
}
.produtosDestaque ul li a > p:nth-child(4) b,
.produtosDestaque ul li .produto-qty b {
    color: #222;
}

/* Preço — saiu do vermelho, agora preto com separador */
.produtosDestaque ul li .preco {
    font-size: 13px;
    font-weight: 700;
    color: #222;
    padding: 10px 0 0;
    margin: auto 0 0;
    border-top: 1px solid #EFEFEF;
    text-align: left;
}

/* Botão "Mais detalhes" — full-bleed no card; só dentro do link (herda --pd-card-x) */
.produtosDestaque ul li a .btn-mais-detalhes {
    background: var(--main-green-lfc);
    color: white;
    border: none;
    border-radius: 0;
    font-size: 10px;
    font-weight: 700;
    padding: 7px 10px;
    margin: 8px calc(-1 * var(--pd-card-x)) 10px;
    width: calc(100% + 2 * var(--pd-card-x));
    max-width: none;
    box-sizing: border-box;
    cursor: pointer;
    text-align: center;
    display: block;
    transition: background 0.15s;
}
.produtosDestaque ul li a .btn-mais-detalhes:hover {
    background: var(--green-lfc-first);
    color: white;
}

/* ── 10. PAGINADOR ──────────────────────────────────────── */
/* Legado style.css: height:35px + float — faixa cinza ficava menor que os botões (28px+borda). */
.paginador {
    margin-top: 16px;
    margin-bottom: 0;
    padding: 12px 0;
    border-top: 1px solid #E0E0E0;
    border-bottom: 1px solid #d6d6d6;
    float: none !important;
    clear: both;
    width: 100%;
    height: auto !important;
    min-height: 3rem;
    box-sizing: border-box;
    background-color: #eaeaea;
    background-image: none;
    display: block;
    overflow: visible;
}

.paginador .paginas.paginas--compact {
    margin: 0;
}

.paginas {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
    gap: 4px;
}
.paginas > div:first-child {
    display: flex;
    gap: 4px;
    align-items: center;
}
.paginas a,
.numeropaginas {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #E0E0E0;
    font-size: 11px;
    color: #666;
    text-decoration: none;
    transition: background 0.12s, border-color 0.12s;
}
.paginas a:hover,
.numeropaginas:hover {
    border-color: var(--main-green-lfc);
    color: var(--main-green-lfc);
}
.paginacorrente {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--main-green-lfc);
    color: white;
    border: 1px solid var(--main-green-lfc);
    font-size: 11px;
    font-weight: 700;
}
.disabled {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #E0E0E0;
    font-size: 11px;
    color: #CCC;
    cursor: not-allowed;
}

/* Paginação compacta (catálogo /atas — evita listar dezenas de páginas) */
.paginas.paginas--compact {
    flex-wrap: wrap;
    gap: 10px 16px;
    padding: 0 12px;
    align-items: center;
    justify-content: space-between;
    min-height: 2.75rem;
}

.paginas--compact .paginas__nav {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1 1 auto;
    min-width: 0;
    justify-content: center;
    align-self: center;
}

.paginas--compact .paginas__numbers {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 4px;
    max-width: min(100%, 36rem);
}

.paginacao-ellipsis {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1rem;
    padding: 0 2px;
    font-size: 11px;
    font-weight: 600;
    color: #94a3b8;
    user-select: none;
}

.paginas__summary {
    font-size: 11px;
    color: #555;
    line-height: 1.35;
    text-align: right;
    flex: 0 1 18rem;
    max-width: 100%;
    align-self: center;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.15rem 0.35rem;
}

.paginas__page-of {
    color: #64748b;
    white-space: nowrap;
}

@media (max-width: 640px) {
    .paginas.paginas--compact {
        flex-direction: column;
        align-items: stretch;
    }

    .paginas--compact .paginas__nav {
        justify-content: center;
    }

    .paginas__summary {
        text-align: center;
        flex-basis: auto;
        justify-content: center;
    }
}

/* ── 11. FOOTER CTA (faixa verde) ───────────────────────── */
.main-green-bg {
    background: var(--main-green-lfc);
    margin-top: 28px;
    padding: 20px 0 32px;
    border-top: 3px solid rgba(45, 83, 22, 0.45);
    box-shadow: 0 -8px 22px rgba(0, 0, 0, 0.08);
}
.main-green-bg h2 {
    font-size: 15px;
    font-weight: 700;
    color: white;
    margin-bottom: 4px;
}
.list-5-columns.items-svg-and-h3 {
    display: flex;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
}
.list-5-columns.items-svg-and-h3 li {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    width: 100px;
}
.list-5-columns.items-svg-and-h3 li svg,
.list-5-columns.items-svg-and-h3 li img {
    width: 40px;
    height: 40px;
    opacity: 0.9;
    filter: brightness(0) invert(1);
}
.list-5-columns.items-svg-and-h3 li h3 {
    font-size: 10px;
    color: rgba(255,255,255,0.9);
    text-align: center;
    line-height: 1.4;
    font-weight: 400;
}

/* ── 12. SEARCH BAR NO FOOTER ───────────────────────────── */
.search-bar-on-footer {
    background: white;
    border-top: 1px solid #E0E0E0;
    border-bottom: 1px solid #E0E0E0;
    padding: 12px 0;
}
.search-bar-on-footer .container-width {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

/* Faixa escura do rodapé em largura total da viewport (mesmo padrão da .grey-top-bar) */
.site-footer-dark-band {
    width: 100%;
    background: #222;
    box-sizing: border-box;
}
.site-footer-dark-band .footer {
    background: transparent !important;
}

/* ── 13. FOOTER PRINCIPAL ───────────────────────────────── */
.footer {
    background: #222 !important;
    padding: 16px clamp(12px, 2.5vw, 24px) 18px !important;
    display: flex !important;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 16px clamp(16px, 2.5vw, 28px);
    list-style: none;
    box-sizing: border-box;
}
.footer > li:first-child {
    flex: 1 1 min(320px, 100%);
    max-width: min(480px, 100%);
    /* Sobrescreve .justify-start (display:grid): coluna de contato em coluna flexível */
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
}
/* Contato em duas colunas: WhatsApp + botão Contato | e-mail, telefone, redes */
.footer > li:first-child .footer-col-contato__body {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    gap: 12px 20px;
    align-items: start;
    width: 100%;
}
.footer > li:first-child .footer-col-contato__body--channels-only {
    grid-template-columns: 1fr;
}
.footer .footer-col-contato__channels {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}
.footer .footer-col-contato__channels .icon-and-link {
    white-space: normal;
    word-break: break-word;
}
.footer .footer-col-contato__channels .social-media-list {
    margin-top: 2px;
}
@media (max-width: 640px) {
    .footer > li:first-child .footer-col-contato__body:not(.footer-col-contato__body--channels-only) {
        grid-template-columns: 1fr;
    }
}
/* Título da 1.ª coluna — mesma régua visual que Mapa / Categorias */
.footer > li:first-child > h4.footer-col-heading {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255, 255, 255, 0.4);
    margin: 0 0 6px 0;
    padding-bottom: 4px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.footer .cta-duvidas-actions {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 0;
    justify-content: flex-start;
    align-items: stretch;
}
.footer .cta-top-whatsapp,
.footer .cta-top-contato {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.7);
    font-size: 11px;
    padding: 7px 12px;
    border-radius: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: none !important;
}
.footer .cta-top-whatsapp {
    flex: 1 1 auto;
    min-width: 0;
}
.footer .cta-top-contato {
    flex: 0 0 auto;
    justify-content: center;
    font-size: 12px !important;
    font-weight: 700 !important;
}
.footer .cta-top-whatsapp:hover,
.footer .cta-top-contato:hover {
    background: rgba(255,255,255,0.14);
    color: white;
    box-shadow: none !important;
}
.footer .icon-and-link {
    font-size: 11px;
    color: rgba(255,255,255,0.45);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
.footer .icon-and-link:hover {
    color: rgba(255,255,255,0.8);
}
.footer .social-media-list {
    display: flex;
    gap: 6px;
    list-style: none;
    padding: 0;
    margin-top: 12px;
}
.footer .social-media-list li a {
    width: 28px;
    height: 28px;
    background: rgba(255,255,255,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0;
    transition: background 0.12s;
}
.footer .social-media-list li a:hover {
    background: var(--main-green-lfc);
}
.footer .social-media-list li a svg path {
    fill: rgba(255,255,255,0.5);
}
.footer .social-media-list li a:hover svg path {
    fill: white;
}

/* Colunas do footer — Mapa do site + Categorias */
/* padding-left:50px legado (linha ~1216) não se aplica aqui — evita coluna Contato “colada” vs Mapa */
.footer .site-map-on-footer {
    flex: 1;
    min-width: 140px;
    padding-left: 0 !important;
}
.footer .site-map-on-footer h4 {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255,255,255,0.4);
    margin: 0 0 6px 0;
    padding-bottom: 4px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.links-on-footer {
    list-style: none;
    padding: 0;
    margin: 0;
}
.links-on-footer li a {
    font-size: 11px;
    color: rgba(255,255,255,0.4);
    text-decoration: none;
    display: block;
    padding: 1px 0;
    line-height: 1.35;
    transition: color 0.12s;
}
.links-on-footer li a:hover {
    color: rgba(255,255,255,0.8);
}
/* Mapa do site / categorias em múltiplas colunas (menos altura no rodapé) */
.links-on-foooter-2-columns {
    columns: 2;
    column-gap: 18px;
}
.links-on-foooter-2-columns li {
    break-inside: avoid;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
}
@media (min-width: 900px) {
    .footer .site-map-on-footer--principal .links-on-foooter-2-columns {
        columns: 3;
        column-gap: 20px;
    }
}

/* Evita o breakpoint global (.container-width { overflow: auto }) a partir de 1023px,
   que comprimia o rodapé e sobreponha WhatsApp / e-mail / mapa (ex.: layout Soluções + styleNew). */
/* Mesma caixa útil que .container-width (max 1400px) — alinha com "Alguns de nossos clientes" */
.container-width--lfc-footer {
    overflow: visible !important;
    max-width: 1400px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}
@media (max-width: 1023px) {
    .container-width--lfc-footer {
        /* Mantém a mesma largura que o .container-width da secção de clientes (92vw no legado). */
        overflow: visible !important;
    }
}

/* Lista do mapa: regra legado .links-on-footer { display:grid } conflita com columns — só multicol no rodapé escuro */
.footer ul.links-on-footer.links-on-foooter-2-columns {
    display: block !important;
    grid-template-columns: unset !important;
    grid-row-gap: unset !important;
}

/* WhatsApp no rodapé: neutraliza tipografia “hero” (.cta-top-whatsapp p span 18px) e evita texto a esmagar */
.footer .cta-top-whatsapp {
    flex-wrap: wrap;
    align-items: flex-start;
}
.footer .cta-top-whatsapp .center-align {
    flex-shrink: 0;
    line-height: 0;
}
.footer .cta-top-whatsapp p {
    margin: 0;
    min-width: 0;
    line-height: 1.35;
    font-size: 11px !important;
    color: rgba(255, 255, 255, 0.82) !important;
}
.footer .cta-top-whatsapp p span {
    display: block;
    margin-top: 3px;
    font-size: 11px !important;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.95) !important;
}
@media (max-width: 900px) {
    .footer .cta-duvidas-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .footer .cta-top-whatsapp,
    .footer .cta-top-contato {
        flex: 1 1 auto !important;
        width: 100%;
        max-width: 100%;
    }
}

/* Último item (carrinho) do footer */
.footer > li.justify-end {
    flex: 0 0 auto;
    align-self: flex-start;
}
.footer > li.justify-end .btn-cart {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
}
.footer > li.justify-end .btn-cart h3 {
    color: rgba(255,255,255,0.5);
    font-size: 11px;
}

/* ── 14. LISTA DE CLIENTES ──────────────────────────────── */
/* Sobrescreve o layout antigo (grid 1fr + 3fr): título em cima, grelha 5×2 em largura total. */
.list-of-clients {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    margin-top: 14px;
    padding: 26px 0 20px;
    border-top: 1px solid rgba(0, 0, 0, 0.14);
    border-bottom: 1px solid #E0E0E0;
    box-shadow: 0 -3px 14px rgba(0, 0, 0, 0.06);
}
.list-of-clients h2 {
    font-size: 12px;
    color: #666;
    margin-bottom: 14px;
    font-weight: 400;
}
.list-of-clients .center-align {
    padding-inline: 20px;
}
.list-of-clients > div {
    width: 100%;
    min-width: 0;
}
.inner-list-of-clients {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 16px;
    align-items: center;
    justify-items: center;
    list-style: none;
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
@media (max-width: 1200px) {
    .inner-list-of-clients {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}
@media (max-width: 900px) {
    .inner-list-of-clients {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 600px) {
    .inner-list-of-clients {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
.list-of-clients .inner-list-of-clients li.parent img.child,
.inner-list-of-clients .parent img {
    opacity: 1;
    filter: none;
    -webkit-filter: none;
    transition: transform 0.2s ease, filter 0.2s ease;
}
.inner-list-of-clients .parent:hover img {
    transform: scale(1.06);
    filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.14)) drop-shadow(0 2px 8px rgba(118, 193, 66, 0.22));
    -webkit-filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.14)) drop-shadow(0 2px 8px rgba(118, 193, 66, 0.22));
}

/* ── 15. RESPONSIVO ─────────────────────────────────────── */
@media (max-width: 1400px) {
    .produtosDestaque:not(.home-curated-atas__grid) ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 1170px) {
    .produtosDestaque:not(.home-curated-atas__grid) ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 728px) {
    .produtosDestaque:not(.home-curated-atas__grid) ul {
        grid-template-columns: 1fr;
    }
    .footer {
        flex-direction: column;
        gap: 24px;
    }
    .links-on-foooter-2-columns {
        columns: 1;
    }
}

/* Coluna principal estreita: infográfico vira lista vertical */
@media (max-width: 900px) {
    .banner-atas-steps::before,
    .steps-to-acquire::before {
        display: none;
    }
    .banner-atas-steps,
    .steps-to-acquire {
        flex-wrap: wrap;
        padding: 10px 12px 12px;
    }
    .banner-atas-step,
    .steps-to-acquire li {
        flex: 1 1 100%;
        max-width: 100%;
        flex-direction: row;
        align-items: flex-start;
        text-align: left;
        gap: 14px;
        padding: 12px 4px;
        border-bottom: 1px solid rgba(197, 220, 176, 0.85);
    }
    .banner-atas-step:last-child,
    .steps-to-acquire li:last-child {
        border-bottom: none;
    }
    .banner-atas-step__text,
    .steps-to-acquire li h3 {
        text-align: left;
        max-width: none;
    }
    .banner-top-green-part {
        padding: 14px 12px 16px;
    }
}

/* ── 16. PÁGINA DE BUSCA (/buscar) ──────────────────────── */
.description {
    font-size: 14px;
    font-weight: 700;
    color: #222;
    margin-bottom: 4px;
    padding-bottom: 8px;
    border-bottom: 1px solid #E0E0E0;
}
.description-text {
    font-size: 12px;
    color: #666;
    line-height: 1.6;
    margin-bottom: 12px;
}

/* ── 17. CLASSES DE CARD (home.blade.php ajustado) ──────── */
.produto-ata-badge {
    font-size: 11px;
    font-weight: 700;
    color: #2d5016;
    background: none;
    border: none;
    display: block;
    padding: 0;
    margin: 2px 0 0;
    line-height: 1.45;
    text-align: left;
}
.produto-qty {
    font-size: 10px;
    color: #666;
    padding: 8px 0 0;
    margin: 0;
    line-height: 1.45;
}
.produto-qty b {
    color: #222;
    font-weight: 600;
}

/* ── 18. LOGOS CLIENTES — cor explícita (cascata final; carrega após Theme/bootstrap async) ── */
#dvClientes img.child {
    opacity: 1 !important;
    filter: none !important;
    -webkit-filter: none !important;
}
#dvClientes .parent:hover img.child {
    transform: scale(1.06);
    filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.14)) drop-shadow(0 2px 8px rgba(118, 193, 66, 0.22)) !important;
    -webkit-filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.14)) drop-shadow(0 2px 8px rgba(118, 193, 66, 0.22)) !important;
}

/* =============================================================================
   LFC — Páginas institucionais (contato, carrinho, sucesso, detalhe produto)
   Tokens alinhados à home / Soluções TI / HPC
   ============================================================================= */
:root {
    --lfc-page-max: 1200px;
    --lfc-navy: #0d1b2a;
    --lfc-navy-mid: #1a3a5c;
    --lfc-green: #76c142;
    --lfc-sti: #73b843;
    --lfc-slate-50: #f8fafc;
    --lfc-slate-200: #e2e8f0;
    --lfc-slate-500: #64748b;
    --lfc-slate-600: #475569;
    --lfc-slate-700: #334155;
    --lfc-radius-card: 14px;
    --lfc-radius-btn: 6px;
}

/* Layout: páginas full-width (carrinho, contato, sucesso…)
   O @yield('content') fica DENTRO de .main-content; .sidebar-and-list é ANCESTRAL.
   Por isso :has() no pai — o seletor antigo (.lfc-site-page--no-sidebar .sidebar-and-list) nunca casava. */
.sidebar-and-list:has(.lfc-site-page--no-sidebar) {
    grid-template-columns: 1fr !important;
    display: block !important;
}
.sidebar-and-list:has(.lfc-site-page--no-sidebar) > .sidebar {
    display: none !important;
}
/* Fallback redundante se algum dia o markup inverter */
.lfc-site-page--no-sidebar .sidebar-and-list {
    grid-template-columns: 1fr;
    display: block;
}
.lfc-site-page--no-sidebar .sidebar-and-list .sidebar {
    display: none !important;
}

/* ---------- Contato (ctc-*) ---------- */
.ctc-hero {
    background: linear-gradient(135deg, #0d1b2a 0%, #0f2744 60%, #1a3a5c 100%);
    padding: 72px 0 0;
}
.ctc-hero-inner {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    padding: 0 2rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: end;
}
.ctc-hero-text {
    padding-bottom: 3rem;
}
.ctc-badge {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--lfc-green);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 1rem;
}
.ctc-hero h1 {
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
    margin: 0 0 1rem;
}
.ctc-hero p {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.75;
    margin: 0 0 2rem;
}
.ctc-hero-img {
    width: 100%;
    border-radius: 12px 12px 0 0;
    display: block;
    object-fit: cover;
    max-height: 360px;
}
.ctc-chips {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
}
.ctc-chip {
    font-size: 0.78rem;
    padding: 0.35rem 0.9rem;
    border-radius: 20px;
    font-weight: 600;
}
.ctc-chip-green {
    background: rgba(118, 193, 66, 0.12);
    border: 1px solid rgba(118, 193, 66, 0.25);
    color: var(--lfc-green);
}
.ctc-chip-sti {
    background: rgba(115, 184, 67, 0.12);
    border: 1px solid rgba(115, 184, 67, 0.25);
    color: var(--lfc-sti);
}
.ctc-chip-neutral {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.72rem;
    line-height: 1.45;
    text-align: left;
    white-space: normal;
    max-width: 20rem;
}
.ctc-services-header {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    padding: 0 2rem 2rem;
}
.ctc-services-kicker {
    font-size: 0.75rem;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 0.5rem;
}
.ctc-services-heading {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--lfc-navy);
    margin: 0;
}
.ctc-services {
    background: var(--lfc-slate-50);
    padding: 4rem 0;
}
.ctc-services-inner {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    padding: 0 2rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}
.ctc-service-card {
    background: #fff;
    border-radius: var(--lfc-radius-card);
    border: 1px solid var(--lfc-slate-200);
    padding: 2rem;
    border-top: 3px solid;
    transition: box-shadow 0.2s;
}
.ctc-service-card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}
.ctc-service-card h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--lfc-navy);
    margin: 0.75rem 0 0.5rem;
}
.ctc-service-card p {
    font-size: 0.88rem;
    color: var(--lfc-slate-500);
    line-height: 1.65;
    margin: 0 0 1.25rem;
}
.ctc-service-link {
    font-size: 0.85rem;
    font-weight: 700;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}
.ctc-icon-box {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ctc-icon-box--green {
    background: #f0fdf4;
}
.ctc-icon-box--sti {
    background: #fff7ed;
}
.ctc-info {
    background: #fff;
    padding: 4rem 0;
}
.ctc-info-inner {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    padding: 0 2rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
}
.ctc-section-label {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--lfc-green);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 0.75rem;
}
.ctc-section-title {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--lfc-navy);
    margin: 0 0 1.5rem;
    line-height: 1.25;
}
.ctc-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.ctc-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.9rem;
    color: #374151;
    line-height: 1.55;
}
.ctc-list li::before {
    content: '';
    width: 7px;
    height: 7px;
    background: var(--lfc-green);
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 6px;
}
.ctc-contact-items {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.ctc-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: var(--lfc-slate-50);
    border-radius: 10px;
    border-left: 3px solid;
}
.ctc-hours {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--lfc-navy);
    line-height: 1.55;
    display: block;
}
.ctc-contact-item a {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--lfc-navy);
    text-decoration: none;
}
.ctc-contact-item a:hover {
    color: var(--lfc-green);
}
.ctc-contact-label {
    font-size: 0.7rem;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    display: block;
    margin-bottom: 0.15rem;
}
.ctc-b2g-note {
    margin-top: 1.5rem;
    padding: 1.25rem;
    background: #f0fdf4;
    border-radius: 10px;
    border: 1px solid rgba(118, 193, 66, 0.2);
}
.ctc-b2g-note-title {
    font-size: 0.8rem;
    font-weight: 700;
    color: #166534;
    margin: 0 0 0.25rem;
}
.ctc-b2g-note p {
    font-size: 0.82rem;
    color: #4b5563;
    margin: 0;
    line-height: 1.55;
}
.ctc-form-section {
    background: var(--lfc-navy);
    padding: 5rem 0;
}
.ctc-form-inner {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    padding: 0 2rem;
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 5rem;
    align-items: start;
}
.ctc-form-intro h2 {
    font-size: 1.6rem;
    font-weight: 800;
    color: #fff;
    line-height: 1.25;
    margin: 0 0 1rem;
}
.ctc-form-intro p {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.7;
    margin: 0;
}
.ctc-form-kicker {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--lfc-green);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 0.75rem;
}
.ctc-checklist {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.ctc-checklist-row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}
.ctc-checklist-row span {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.55);
}
.specialist-form-content ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
}
.specialist-form-content ul li p {
    font-size: 0.82rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.5);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0 0 0.4rem;
}
.specialist-form-content ul li p b {
    color: rgba(255, 255, 255, 0.75);
    font-weight: 700;
}
.lfc-alert {
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
    border-radius: 8px;
    font-size: 0.9rem;
}
.lfc-alert--success {
    background: rgba(34, 197, 94, 0.15);
    border: 1px solid rgba(34, 197, 94, 0.3);
    color: #4ade80;
}
.lfc-alert--error {
    background: rgba(239, 68, 68, 0.15);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #f87171;
}
.ctc-optin-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(255, 255, 255, 0.92);
}
.ctc-optin-label a {
    color: rgba(255, 255, 255, 0.92);
    text-decoration: underline;
}
.ctc-footnote {
    color: rgba(255, 255, 255, 0.5);
    margin: 0;
}

@media (max-width: 860px) {
    .ctc-hero-inner,
    .ctc-services-inner,
    .ctc-info-inner,
    .ctc-form-inner {
        grid-template-columns: 1fr !important;
    }
    .ctc-hero-img {
        max-height: 220px;
        border-radius: 12px;
    }
    .ctc-form-inner {
        gap: 2.5rem;
    }
}

/* ---------- Carrinho ---------- */
.lfc-cart-page {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    padding: 2rem 1.25rem 4rem;
    box-sizing: border-box;
    font-family: var(--lfc-font-primary, "Ubuntu", "DM Sans", system-ui, sans-serif);
    color: var(--lfc-navy);
}
/* Garantir que nenhum botão do miolo volte ao estilo nativo (especificidade + deploy atrasado) */
.lfc-cart-page button,
.lfc-cart-page input[type="submit"] {
    font-family: inherit;
}
.lfc-cart-page .lfc-btn {
    -webkit-appearance: none;
    appearance: none;
}
.lfc-cart-hero {
    margin-bottom: 1.5rem;
}
.lfc-breadcrumb {
    font-size: 0.85rem;
    color: var(--lfc-slate-600);
    margin-bottom: 0.75rem;
}
.lfc-breadcrumb a {
    color: var(--lfc-slate-700);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.lfc-breadcrumb a:hover {
    color: var(--lfc-green);
}
.lfc-breadcrumb-sep {
    margin: 0 0.35rem;
    color: #94a3b8;
}
.lfc-page-title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 800;
    color: var(--lfc-navy);
    margin: 0 0 0.5rem;
    line-height: 1.2;
}
.lfc-page-lead {
    font-size: 0.95rem;
    color: var(--lfc-slate-600);
    line-height: 1.6;
    margin: 0 0 1.25rem;
    max-width: 42rem;
}
.lfc-cart-hints {
    background: var(--lfc-slate-50);
    border: 1px solid var(--lfc-slate-200);
    border-radius: var(--lfc-radius-card);
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.5rem;
}
.lfc-cart-hints p {
    font-size: 0.88rem;
    color: var(--lfc-slate-700);
    margin: 0 0 0.5rem;
    line-height: 1.55;
}
.lfc-cart-hints p:last-child {
    margin-bottom: 0;
}
.lfc-cart-hints a {
    color: var(--lfc-green);
    font-weight: 600;
    text-decoration: underline;
}
.lfc-cart-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}
.lfc-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 1.25rem;
    font-size: 0.9rem;
    font-weight: 700;
    border-radius: var(--lfc-radius-btn);
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
    font-family: inherit;
}
.lfc-btn:focus-visible {
    outline: 2px solid var(--lfc-green);
    outline-offset: 2px;
}
.lfc-btn--secondary {
    background: #fff;
    color: var(--lfc-navy);
    border: 1px solid var(--lfc-slate-200);
}
.lfc-btn--secondary:hover {
    background: var(--lfc-slate-50);
}
.lfc-btn--primary {
    background: var(--lfc-green);
    color: #fff;
}
.lfc-btn--primary:hover {
    background: #5fa336;
    color: #fff;
}
.lfc-btn--ghost {
    background: transparent;
    color: #b91c1c;
    padding: 0.25rem;
    min-height: auto;
}
.lfc-btn--ghost:hover {
    color: #991b1b;
}
.lfc-cart-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.lfc-cart-item {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 1rem;
    align-items: start;
    padding: 1.25rem;
    background: #fff;
    border: 1px solid var(--lfc-slate-200);
    border-radius: var(--lfc-radius-card);
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}
@media (min-width: 720px) {
    .lfc-cart-item {
        grid-template-columns: 120px 1fr auto auto auto;
        align-items: center;
    }
}
.lfc-cart-item__img {
    width: 100%;
    max-width: 120px;
    height: auto;
    aspect-ratio: 1;
    object-fit: contain;
    border-radius: 8px;
    background: var(--lfc-slate-50);
}
.lfc-cart-item__title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--lfc-navy);
    margin: 0 0 0.5rem;
    line-height: 1.35;
}
.lfc-cart-item__meta {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    font-size: 0.85rem;
    color: var(--lfc-slate-600);
}
.lfc-cart-item__meta span {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--lfc-slate-500);
}
.lfc-cart-item__meta strong {
    display: block;
    font-size: 1rem;
    color: var(--lfc-navy);
    margin-top: 0.15rem;
}
#miniaturasDetalhes img {
    cursor: pointer;
}
.lfc-cart-item__qty input {
    width: 5rem;
    padding: 0.5rem;
    border: 1px solid var(--lfc-slate-200);
    border-radius: 6px;
    font-size: 0.9rem;
}
.lfc-cart-item__price {
    font-weight: 700;
    color: var(--lfc-navy);
    white-space: nowrap;
}
.lfc-cart-summary {
    text-align: right;
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--lfc-navy);
    margin-bottom: 2rem;
    padding: 1rem 0;
    border-top: 2px solid var(--lfc-slate-200);
}
.lfc-cart-form-wrap {
    background: var(--lfc-slate-50);
    border: 1px solid var(--lfc-slate-200);
    border-radius: var(--lfc-radius-card);
    padding: 2rem;
    margin-bottom: 2rem;
}
.lfc-cart-form-wrap h2 {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--lfc-navy);
    margin: 0 0 1.25rem;
}
.lfc-form-stack {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.lfc-form-stack label {
    display: block;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--lfc-slate-700);
    margin-bottom: 0.35rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.lfc-form-stack input[type='text'],
.lfc-form-stack input[type='email'],
.lfc-form-stack input[type='number'],
.lfc-form-stack textarea {
    width: 100%;
    max-width: 100%;
    padding: 0.65rem 0.85rem;
    border: 1px solid var(--lfc-slate-200);
    border-radius: 6px;
    font-size: 0.95rem;
    box-sizing: border-box;
    font-family: inherit;
    background: #fff;
    color: var(--lfc-navy);
    transition: border-color 0.15s, box-shadow 0.15s;
}
.lfc-form-stack input:focus-visible,
.lfc-form-stack textarea:focus-visible {
    outline: none;
    border-color: var(--lfc-green);
    box-shadow: 0 0 0 3px rgba(118, 193, 66, 0.2);
}
.lfc-form-stack textarea {
    min-height: 120px;
    resize: vertical;
}
.lfc-form-stack .lfc-optin {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.88rem;
    color: var(--lfc-slate-700);
    text-transform: none;
    font-weight: 500;
}
.lfc-form-stack .lfc-optin a {
    color: var(--lfc-green);
    font-weight: 600;
}
.lfc-cart-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--lfc-slate-600);
    font-size: 1.05rem;
}

/* Modal carrinho (painel; posição via modalpopup.js) */
#dvPopup.lfc-modal-cart,
.lfc-modal-cart {
    width: min(520px, 92vw) !important;
    max-width: calc(100vw - 2rem) !important;
    padding: 1.5rem !important;
    background-color: #fff !important;
    background: #fff !important;
    border: 1px solid var(--lfc-slate-200) !important;
    border-radius: var(--lfc-radius-card) !important;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.25) !important;
    position: fixed !important;
    z-index: 10060 !important;
    isolation: isolate;
    color: var(--lfc-navy) !important;
    box-sizing: border-box !important;
}
.lfc-modal-cart__close {
    float: right;
    font-size: 1.5rem;
    font-weight: 700;
    color: #64748b;
    line-height: 1;
    text-decoration: none;
    margin: -0.25rem 0 0.5rem;
    border-radius: 6px;
    padding: 0.15rem 0.35rem;
}
.lfc-modal-cart__close:hover,
.lfc-modal-cart__close:focus-visible {
    background: var(--lfc-slate-50);
    color: var(--lfc-navy);
    outline: none;
}
.lfc-modal-cart__title {
    text-align: center;
    font-size: 1.25rem;
    font-weight: 800;
    margin: 0 0 1rem;
    clear: both;
    color: var(--lfc-navy);
}
.lfc-modal-cart__body p {
    text-align: center;
    font-size: 0.9rem;
    color: var(--lfc-slate-600);
    margin: 0 0 0.75rem;
    line-height: 1.5;
}
.lfc-modal-cart__actions {
    text-align: center;
    margin-top: 1.25rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
}

/* ---------- Telas de sucesso unificadas ---------- */
.lfc-success-page {
    min-height: 55vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem 1.5rem 4rem;
    background: linear-gradient(180deg, var(--lfc-slate-50) 0%, #fff 45%);
    box-sizing: border-box;
}
.lfc-success-card {
    max-width: 520px;
    width: 100%;
    background: #fff;
    border: 1px solid var(--lfc-slate-200);
    border-radius: var(--lfc-radius-card);
    padding: 2.5rem 2rem;
    text-align: center;
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
}
.lfc-success-card .logo-lfc-composed {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.25rem;
}
.lfc-success-badge {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--lfc-green);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 0.75rem;
}
.lfc-success-title {
    font-size: clamp(1.35rem, 3vw, 1.75rem);
    font-weight: 800;
    color: var(--lfc-navy);
    margin: 0 0 0.75rem;
    line-height: 1.25;
}
.lfc-success-sub {
    font-size: 1rem;
    color: var(--lfc-slate-600);
    line-height: 1.55;
    margin: 0 0 1.25rem;
}
.lfc-success-msg {
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    color: #065f46;
    padding: 0.85rem 1rem;
    border-radius: 8px;
    font-size: 0.9rem;
    margin-bottom: 1.25rem;
    text-align: left;
}
.lfc-success-code {
    font-size: 0.9rem;
    color: var(--lfc-slate-600);
    margin: 0 0 1.5rem;
}
.lfc-success-code strong {
    color: var(--lfc-navy);
}
.lfc-success-actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
    margin-top: 1.5rem;
}
.lfc-success-actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    justify-content: center;
    font-size: 0.9rem;
}
.lfc-success-actions-row a {
    color: var(--lfc-sti);
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.lfc-success-actions-row a:hover {
    color: var(--lfc-green);
}
.lfc-whatsapp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.85rem 1.5rem;
    border-radius: var(--lfc-radius-btn);
    border: 2px solid #128c7e;
    color: #128c7e;
    font-weight: 700;
    font-size: 0.95rem;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}
.lfc-whatsapp-btn:hover {
    background: #128c7e;
    color: #fff;
}

/* ---------- PDP (detalhe ata) ---------- */
.lfc-pdp {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    padding: 1.5rem 2rem 3rem;
    box-sizing: border-box;
}
.lfc-pdp-eyebrow {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--lfc-sti);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 0.5rem;
}
.lfc-pdp .produto.lfc-pdp-product {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
    margin-top: 0.5rem;
}
.lfc-pdp-title-row {
    grid-column: 1 / -1;
}
.lfc-pdp-title-row .descricao h1 {
    font-size: clamp(1.35rem, 2.5vw, 1.85rem);
    font-weight: 800;
    color: var(--lfc-navy);
    line-height: 1.25;
    margin: 0 0 0.25rem;
}
.lfc-pdp-col-full {
    grid-column: 1 / -1;
}
.lfc-pdp .detalhes_esquerda .imagemProdutoDestaque {
    width: 100%;
    height: auto;
    object-fit: contain;
    min-height: 280px;
    display: block;
    aspect-ratio: 4 / 3;
    background: var(--lfc-slate-50);
    border-radius: 12px;
    border: 1px solid var(--lfc-slate-200);
}
.lfc-pdp .detalhes_direita {
    background: #fff;
    border: 1px solid var(--lfc-slate-200);
    border-radius: var(--lfc-radius-card);
    padding: 1.5rem;
    box-shadow: 0 4px 20px rgba(15, 23, 42, 0.06);
}
.lfc-pdp .detalhes_direita #pDetalhe {
    font-size: 0.95rem;
    color: var(--lfc-slate-700);
    line-height: 1.65;
    margin-bottom: 1rem;
}
.lfc-pdp .detalhes_direita .titulo_especificacoes {
    display: block;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--lfc-slate-500);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 1rem 0 0.5rem;
}
.lfc-pdp .detalhes_direita ul {
    list-style: none;
    padding: 0;
    margin: 0 0 1rem;
    font-size: 0.88rem;
    color: var(--lfc-slate-700);
}
.lfc-pdp .detalhes_direita ul li {
    padding: 0.35rem 0;
    border-bottom: 1px solid var(--lfc-slate-200);
}
.lfc-pdp .detalhes_direita .valor {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--lfc-navy);
    margin: 1rem 0;
}
.lfc-pdp .detalhes_direita .valor span {
    color: var(--lfc-green);
}
.lfc-pdp .detalhes_direita .btn-success {
    border-radius: var(--lfc-radius-btn);
    font-weight: 700;
    padding: 0.65rem 1.5rem;
}
.lfc-pdp .detalhes_direita .lnkmarca {
    display: inline-block;
    margin-top: 0.75rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--lfc-sti);
    text-decoration: underline;
}

/* PDP — anula legado style.css (.produto .detalhes_direita ul li { height:30px }, float+table) que sobrepõe texto */
.lfc-pdp .produto .detalhes_esquerda {
    float: none !important;
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    height: auto !important;
}
.lfc-pdp .produto .detalhes_direita {
    float: none !important;
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    margin-top: 0 !important;
}
.lfc-pdp .produto .detalhes_direita ul {
    display: block !important;
    height: auto !important;
    margin-bottom: 1rem !important;
}
.lfc-pdp .produto .detalhes_direita ul li {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    line-height: 1.45 !important;
    white-space: normal !important;
    word-break: break-word;
}
.lfc-pdp .produto .detalhes_direita > p {
    margin: 0.65rem 0 !important;
    line-height: 1.5 !important;
    clear: both;
}
.lfc-pdp .produto .detalhes_direita input.texto,
.lfc-pdp .produto .detalhes_direita #txtQuantidade {
    float: none !important;
    display: block !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 14rem !important;
    height: auto !important;
    min-height: 2.75rem !important;
    margin: 0.35rem 0 1rem !important;
    padding: 0.5rem 0.75rem !important;
    background: #fff !important;
    background-image: none !important;
    border: 1px solid var(--lfc-slate-200, #e2e8f0) !important;
    border-radius: 8px !important;
    font-size: 1rem !important;
    color: var(--lfc-navy) !important;
}
.lfc-pdp-about {
    margin-top: 1.5rem;
    padding: 1.5rem;
    background: var(--lfc-slate-50);
    border-radius: var(--lfc-radius-card);
    border: 1px solid var(--lfc-slate-200);
}
.lfc-pdp-about h2 {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--lfc-navy);
    margin: 0 0 0.75rem;
}
.lfc-pdp-about h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--lfc-navy);
    margin: 1rem 0 0.5rem;
}
.lfc-pdp-about p {
    font-size: 0.9rem;
    color: var(--lfc-slate-600);
    line-height: 1.65;
    margin: 0 0 0.75rem;
}
.lfc-pdp-about a {
    color: var(--lfc-green);
    font-weight: 700;
}
.lfc-pdp-institutional {
    margin: 2.5rem 0 1.5rem;
    padding: 1.5rem 2rem;
    background: linear-gradient(135deg, rgba(115, 184, 67, 0.08) 0%, rgba(13, 27, 42, 0.04) 100%);
    border: 1px solid var(--lfc-slate-200);
    border-radius: var(--lfc-radius-card);
}
.lfc-pdp-institutional-inner {
    max-width: var(--lfc-page-max);
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 2rem;
    align-items: center;
    justify-content: space-between;
}
.lfc-pdp-institutional-text {
    font-size: 0.9rem;
    color: var(--lfc-slate-700);
    line-height: 1.55;
    max-width: 36rem;
    margin: 0;
}
.lfc-pdp-institutional-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}
.lfc-pdp-institutional-links a {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 1rem;
    font-size: 0.85rem;
    font-weight: 700;
    border-radius: var(--lfc-radius-btn);
    text-decoration: none;
}
.lfc-pdp-institutional-links a:first-child {
    background: var(--lfc-sti);
    color: #fff;
}
.lfc-pdp-institutional-links a:last-child {
    background: #fff;
    color: var(--lfc-navy);
    border: 1px solid var(--lfc-slate-200);
}
.lfc-pdp .linhacinza h3 {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--lfc-navy);
}

/* Galeria / quantidade — PDP */
#txtQuantidade.erro-quantidade {
    border: 2px solid #d9534f !important;
    background-color: #fff5f5 !important;
}
#miniaturasDetalhes img.is-active {
    outline: 2px solid var(--lfc-green);
    outline-offset: 2px;
    border-radius: 4px;
}
.lfc-pdp .imagemProdutoDestaque {
    cursor: zoom-in;
}

/* Modal PDP — painel sólido acima do overlay e do header sticky (painel pode ser movido para body via modalpopup.js) */
#dvPopup.lfc-modal-pdp,
.lfc-modal-pdp {
    box-sizing: border-box;
    width: min(450px, 92vw) !important;
    max-width: 92vw !important;
    padding: 1.5rem 1.5rem 1.25rem !important;
    margin: 0 !important;
    background-color: #ffffff !important;
    background: #ffffff !important;
    background-clip: padding-box !important;
    -webkit-background-clip: padding-box !important;
    color: var(--lfc-navy) !important;
    border-radius: 12px !important;
    border: 1px solid var(--lfc-slate-200, #e2e8f0) !important;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.25), 0 0 0 1px rgba(255, 255, 255, 0.06) inset !important;
    position: fixed !important;
    z-index: 10060 !important;
    overflow: hidden;
    opacity: 1 !important;
}
.lfc-modal-pdp__close {
    position: absolute;
    top: 0.65rem;
    right: 0.75rem;
    z-index: 2;
    float: none;
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    color: var(--lfc-slate-500);
    text-decoration: none;
    border-radius: 6px;
    transition: background 0.15s, color 0.15s;
}
.lfc-modal-pdp__close:hover,
.lfc-modal-pdp__close:focus-visible {
    background: var(--lfc-slate-50);
    color: var(--lfc-navy);
    outline: none;
}
#dvPopup.lfc-modal-pdp {
    position: fixed !important;
}
.lfc-modal-pdp__title {
    text-align: center;
    font-size: 1.35rem;
    font-weight: 800;
    margin: 0 2rem 1rem 0;
    padding-right: 0.5rem;
    clear: none;
    color: var(--lfc-navy);
}
.lfc-modal-pdp__err {
    display: none;
    margin-bottom: 1rem;
    padding: 0.85rem 1rem;
    background: #fef2f2;
    border-radius: 8px;
    border-left: 4px solid #b91c1c;
}
.lfc-modal-pdp__err p {
    margin: 0;
    color: #7f1d1d;
    font-weight: 700;
    font-size: 0.9rem;
}
.lfc-modal-pdp__box {
    margin-bottom: 1rem;
    padding: 1rem;
    background: var(--lfc-slate-50);
    border-radius: 8px;
    border-left: 4px solid var(--lfc-green);
}
.lfc-modal-pdp__box-label {
    margin: 0 0 0.5rem;
    font-weight: 700;
    color: var(--lfc-navy);
    font-size: 0.9rem;
}
.lfc-modal-pdp__box-title {
    margin: 0 0 1rem;
    color: var(--lfc-slate-700);
    line-height: 1.4;
    font-size: 0.95rem;
}
.lfc-modal-pdp__row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
    font-size: 0.88rem;
}
.lfc-modal-pdp__row--total {
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 2px solid var(--lfc-slate-200);
    font-size: 1rem;
}
.lfc-modal-pdp__total-val {
    font-weight: 800;
    color: var(--lfc-green);
    font-size: 1.15rem;
}
.lfc-modal-pdp__question {
    text-align: center;
    margin: 1rem 0;
    color: var(--lfc-slate-600);
    font-size: 0.92rem;
    line-height: 1.45;
}
.lfc-modal-pdp__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    justify-content: center;
    margin-top: 1.25rem;
}
.lfc-modal-pdp__actions .lfc-btn {
    min-width: 8.5rem;
}
.lfc-modal-img {
    width: 90vw !important;
    max-width: 1100px !important;
    padding: 12px !important;
    background: #fff !important;
    border-radius: 12px !important;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.25) !important;
    z-index: 10060 !important;
    position: fixed !important;
    isolation: isolate;
}
.lfc-modal-img__close {
    float: right;
    font-size: 1.75rem;
    font-weight: 700;
    color: #64748b;
    line-height: 1;
    text-decoration: none;
}
.lfc-modal-img__wrap {
    clear: both;
    text-align: center;
}
.lfc-modal-img__wrap img {
    max-width: 100%;
    max-height: 80vh;
    width: auto;
    height: auto;
    object-fit: contain;
    display: inline-block;
}

@media (max-width: 900px) {
    .lfc-pdp .produto.lfc-pdp-product {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   LFC — correções auditoria visual (abr/2026)
   ============================================================ */

/* Repaint / scroll: evita conteúdo em branco após rolagem (overflow em html/body + .corpo legado) */
html {
    overflow-x: clip;
}

body {
    overflow-x: clip;
}

.corpo {
    overflow-y: visible !important;
    overflow-x: hidden;
    min-height: 0;
}

/* Legado style.css: .corpo .conteudo tinha overflow-y:hidden — “prendia” a rolagem no detalhe da ata */
.corpo .conteudo {
    overflow-y: visible !important;
    overflow-x: hidden;
    min-height: 0;
}

.conteudo {
    overflow: visible;
}

.produtosDestaque ul {
    transform: translateZ(0);
}

/* Header sticky + compacto após scroll */
.whole-site-header {
    position: sticky;
    top: 0;
    z-index: 10050;
    background: #fff;
    transition: box-shadow 0.2s ease;
}

.whole-site-header.scrolled {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
}

/* Menu de categorias fica fora do sticky (site.blade.php); ao rolar, mesmo comportamento de ocultar no desktop */
.whole-site-header.scrolled ~ .site-nav-categorias .category-navbar {
    display: none !important;
}

@media (max-width: 900px) {
    .whole-site-header.scrolled ~ .site-nav-categorias .category-navbar {
        display: block !important;
    }
}

/* Hero contato — coluna da imagem */
.ctc-hero-media {
    align-self: stretch;
    display: flex;
    align-items: flex-end;
    min-height: 0;
}

.ctc-hero-media .ctc-hero-img {
    width: 100%;
    height: auto;
    max-height: 400px;
    object-fit: contain;
}

/* CTA Contato no header — alinhar ao verde institucional */
a.cta-top-contato,
.cta-top-contato {
    background-color: var(--lfc-accent, var(--main-green-lfc)) !important;
    color: #fff !important;
    border: 1px solid var(--lfc-accent, var(--main-green-lfc)) !important;
}

a.cta-top-contato:hover,
.cta-top-contato:hover {
    background-color: var(--green-lfc-first, #2d5f22) !important;
    color: #fff !important;
}

/* Desktop: menu e categorias sem scroll horizontal */
@media (min-width: 1024px) {
    .main-bar {
        overflow-x: visible !important;
    }

    .navbar-first ul {
        display: flex !important;
        flex-wrap: wrap !important;
        overflow-x: visible !important;
        white-space: normal !important;
    }

    .category-navbar {
        overflow-x: visible !important;
    }

    .category-navbar #divMenuTop {
        display: flex !important;
        flex-wrap: wrap !important;
        overflow-x: visible !important;
        white-space: normal !important;
    }
}

/* Menu lateral: em desktop não usar posicionamento absoluto do legado mobile */
@media (min-width: 993px) {
    #divMenu.menulateral {
        position: relative !important;
        left: auto !important;
        top: auto !important;
        width: 100% !important;
        max-width: none !important;
        z-index: auto !important;
    }

    .sidebar-and-list .sidebar {
        min-width: 260px;
    }
}

/* Cross-sell home — container visual */
.home-crosssell.lfc-partnership-banner {
    background: #f4f7f1;
    border: 1px solid #cddbc6;
    border-radius: 16px;
    padding: 1.375rem 1.375rem 1.5rem;
    margin-bottom: 1rem;
}

.content-filter-bar {
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    padding: 0.75rem 1rem;
    margin-bottom: 1.25rem;
}

/* Home canônica: passos 1–3 + bloco editorial na largura do container (acima sidebar | catálogo), mais compacto */
.home-catalog-preamble {
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 0.85rem;
}

.home-catalog-preamble .banner-top {
    margin-bottom: 10px;
}

.home-catalog-preamble .banner-top-green-part {
    padding: 12px 14px 14px;
    border-radius: 8px;
}

.home-catalog-preamble .banner-atas-heading {
    font-size: 16px;
    line-height: 1.3;
    margin: 0 0 8px;
}

.home-catalog-preamble .banner-atas-sub {
    margin-bottom: 10px;
}

.home-catalog-preamble .banner-atas-steps {
    padding: 8px 8px 10px;
}

.home-catalog-preamble .banner-atas-steps::before {
    top: 28px;
}

.home-catalog-preamble .banner-atas-step {
    gap: 6px;
    padding: 2px 6px 6px;
}

.home-catalog-preamble .banner-atas-step__num {
    width: 28px;
    height: 28px;
    line-height: 28px;
    font-size: 14px;
}

.home-catalog-preamble .banner-atas-step__text {
    font-size: 11px;
    line-height: 1.4;
    max-width: none;
}

.home-catalog-preamble__intro.content-filter-bar {
    margin-bottom: 1rem;
    padding: 0.65rem 0.85rem;
}

.home-catalog-preamble__intro .description:first-child {
    margin-top: 0;
}

.sidebar-atas-filter {
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    padding: 0.75rem 1rem;
}

/* Acessibilidade: título só para leitores de tela */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Faixa hero: jornada + credibilidade antes do menu de categorias */
.home-journey-hero-band {
    width: 100%;
    background: linear-gradient(165deg, #f4f9f1 0%, #ffffff 42%, #f8fafc 100%);
    border-bottom: 1px solid rgba(58, 122, 42, 0.12);
    padding: 1.75rem 0 2rem;
    margin: 0;
}

.home-journey-hero-inner {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.is-home-journey-first .category-navbar--after-journey {
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

/* === Jornadas na home — título + grid estilo cross-sell (pills / parceiros) === */
.home-journey.home-crosssell.lfc-partnership-banner {
    margin-top: 0;
    margin-bottom: 0;
}

.home-journey__eyebrow {
    margin-bottom: 0.5rem;
}

.home-journey__intro {
    max-width: 44rem;
    margin-bottom: 1rem;
}

.home-journey__lead {
    font-size: 0.95rem;
    color: #6b7280;
    line-height: 1.5;
    margin: 0;
    max-width: 42rem;
}

@media (min-width: 1100px) {
    .home-journey.home-crosssell .home-journey__intro {
        max-width: none;
    }

    .home-journey.home-crosssell .home-journey__lead {
        max-width: none;
        white-space: nowrap;
    }
}

.home-credibility {
    margin: 0;
    padding: 1rem 0 0;
    background: transparent;
    border-radius: 0;
    border: none;
    border-top: 1px dashed rgba(58, 122, 42, 0.2);
}

.home-credibility__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.65rem 1.25rem;
    font-size: 0.88rem;
    color: #475569;
    line-height: 1.45;
}

@media (min-width: 640px) {
    .home-credibility__list {
        grid-template-columns: repeat(2, 1fr);
    }
}

.home-credibility__list li {
    position: relative;
    padding-left: 0.85rem;
}

.home-credibility__list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--main-green-lfc, #3a7a2a);
}

/* Catálogo rebaixado — título de seção explícito */
.home-catalogo-atas {
    scroll-margin-top: 1rem;
}

.home-catalogo-atas__heading {
    font-size: 1.15rem;
    font-weight: 800;
    color: #0f172a;
    margin: 0 0 0.75rem;
    letter-spacing: -0.02em;
}

.home-catalogo-atas__head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.home-catalogo-atas__head .home-catalogo-atas__heading {
    margin-bottom: 0;
}

.home-crosssell--after-journey {
    margin-top: 0;
    margin-bottom: 1.5rem;
}

/* Abertura objetiva (direct answer) — páginas e hubs */
.lfc-direct-answer {
    padding: 1rem 1.1rem;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    margin: 0;
}

.lfc-direct-answer__q {
    font-size: 1rem;
    font-weight: 700;
    color: #111827;
    margin: 0 0 0.5rem;
    line-height: 1.3;
}

.lfc-direct-answer__a {
    font-size: 0.95rem;
    color: #4b5563;
    line-height: 1.6;
    margin: 0 0 0.65rem;
}

.lfc-direct-answer__bullets {
    margin: 0;
    padding-left: 1.15rem;
    font-size: 0.9rem;
    color: #374151;
    line-height: 1.55;
}

.lfc-direct-answer__bullets li {
    margin-bottom: 0.35rem;
}

.lfc-direct-answer__bullets li:last-child {
    margin-bottom: 0;
}

/* Variante escura — hub HPC */
.lfc-direct-answer.lfc-direct-answer--hpc {
    background: rgba(15, 23, 42, 0.85);
    border-color: rgba(59, 130, 246, 0.25);
}

.lfc-direct-answer--hpc .lfc-direct-answer__q {
    color: #f1f5f9;
}

.lfc-direct-answer--hpc .lfc-direct-answer__a {
    color: #cbd5e1;
}

.lfc-direct-answer--hpc .lfc-direct-answer__bullets {
    color: #e2e8f0;
}

/* Cross-sell após atas — leve destaque de continuidade */
.home-crosssell--complement {
    margin-top: 1.5rem;
}

/* === Home orientacional (/) vs catálogo operacional (/atas, /buscar) === */
.contPage--home-orientational {
    padding-bottom: 3rem;
}

/* Mesma caixa útil do hero (jornada + credibilidade): #contPage já é .container-width (max 1400px). */
.contPage--home-orientational .home-orientational-main .conteudo {
    max-width: none;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
}

.home-process-band {
    margin: 2rem 0;
}

.home-process-band__banner.banner-top {
    margin-top: 0;
}

.home-curated-atas {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid #e5e7eb;
}

.home-curated-atas__head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.home-curated-atas__title {
    font-size: 1.15rem;
    color: #111827;
    margin: 0;
}

.home-curated-atas__link-all {
    font-weight: 600;
    color: #166534;
    text-decoration: none;
    white-space: nowrap;
}

.home-curated-atas__link-all:hover {
    text-decoration: underline;
}

/* 10 itens: colunas conforme largura (2→5), sem herdar o grid fixo do catálogo legado. */
.home-curated-atas__grid ul {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(0.65rem, 1.5vw, 1rem);
    list-style: none;
    padding: 0;
    margin: 0;
}

@media (min-width: 520px) {
    .home-curated-atas__grid ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 780px) {
    .home-curated-atas__grid ul {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (min-width: 1100px) {
    .home-curated-atas__grid ul {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}

.home-curated-atas__empty {
    grid-column: 1 / -1;
    padding: 1rem;
    color: #4b5563;
}

.catalog-operational-preamble {
    margin-bottom: 0.5rem;
}

.sidebar-and-list--catalog-operational .main-content .conteudo {
    min-height: 320px;
}
