.catalogo-wrapper{
    max-width:1400px;
    margin:auto;
}

.catalogo-topo{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:20px;
}

.catalogo-topo select,
.catalogo-topo input{
    padding:12px;
    min-width:180px;
}

.catalogo-topo button{
    padding:12px 20px;
    cursor:pointer;
}

.catalogo-contador{
    margin-bottom:20px;
    color:#666;
}

#catalogo-resultados{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}

.catalogo-item-wrapper{
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:10px;
    padding:20px;
    transition:.2s;
}

.catalogo-item-wrapper:hover{
    transform:translateY(-3px);
}

.catalogo-codigo{
    font-size:22px;
    font-weight:700;
    color:#002855;
    margin-bottom:10px;
}

.catalogo-sub{
    font-size:14px;
    color:#666;
    margin-bottom:15px;
    text-transform:uppercase;
}

.catalogo-desc{
    margin-bottom:15px;
    line-height:1.6;
}

.catalogo-hidden{
    display:none;
}

.catalogo-sem-resultados{
    grid-column:1/-1;
    text-align:center;
    padding:40px;
    font-size:18px;
    font-weight:600;
}

.catalogo-loading{
    grid-column:1/-1;
    text-align:center;
    padding:40px;
}

.catalogo-detalhes{
    width:100%;
    padding:12px;
    cursor:pointer;
}

#catalogo-loadmore{
    display:block;
    margin:30px auto;
    padding:14px 30px;
    cursor:pointer;
}

/* MODAL */

#catalogo-modal{
    display:none;
    position:fixed;
    z-index:99999;
    left:0;
    top:0;
    width:100%;
    height:100%;
    background:rgba(0,0,0,.7);
}

.catalogo-modal-box{
    background:#fff;
    width:90%;
    max-width:700px;
    margin:50px auto;
    padding:25px;
    border-radius:10px;
    position:relative;
    max-height:85vh;
    overflow:auto;
}

.catalogo-fechar-modal{
    position:absolute;
    right:15px;
    top:10px;
    font-size:28px;
    cursor:pointer;
}

#catalogo-modal img{
    width:100%;
    height:auto;
    margin-bottom:20px;
    border-radius:8px;
}

.catalogo-modal-descricao{
    line-height:1.8;
}

/* RESPONSIVO */

@media(max-width:1024px){

    #catalogo-resultados{
        grid-template-columns:repeat(3,1fr);
    }

}

@media(max-width:768px){

    #catalogo-resultados{
        grid-template-columns:1fr;
    }

    .catalogo-topo{
        flex-direction:column;
    }

    .catalogo-topo select,
    .catalogo-topo input,
    .catalogo-topo button{
        width:100%;
    }

}


.catalogo-modal-ficha p{
    margin:8px 0;
    padding-bottom:8px;
    border-bottom:1px solid #eee;
}

.catalogo-modal-img{
    text-align:center;
    margin-bottom:20px;
}

.catalogo-modal-img img{
    width:auto !important;
    max-width:180px !important;
    height:auto !important;
    display:inline-block !important;
}


.catalogo-item-wrapper{
    text-align:center;
}

.catalogo-sub{
    margin-top:10px;
    font-size:20px;
    font-weight:600;
}

.catalogo-desc{
    margin-top:15px;
}


.catalogo-imagem{
    height:180px;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:15px;
}

.catalogo-imagem img{
    max-width:100%;
    max-height:180px;
    object-fit:contain;
}


.catalogo-item-wrapper{
    display:flex;
    flex-direction:column;
    height:100%;
}


.catalogo-sub{
    font-size:18px;
    font-weight:600;
    line-height:1.5;
}

.catalogo-desc{
    margin-top:10px;
}