
[class*="col-"] {
    /* margin-bottom: 10px !important; */
}

input,
select {
}

input:active,
input:focus {
    outline: 0;
}

.no_display {
    display: none !important;
}

.cursor_hand {
    cursor: pointer;
}

.cursor_arrow,
.cursor_default {
    cursor: default;
}

.page-wrapper {
    border: 0 !important;
}

.block.imoveis {
    margin-top: 160px;
}

.block.sobre {
    margin-top: 50px;
    padding-top: 15px !important;
}

.block.sobre .blockquote {
    display: flex;
    flex-flow: row nowrap;
    justify-content: center;
}

.block.sobre #sobre_quadro {
    width: 70%;
    font-size: 17px;
    line-height: 2em;
}

.block.colaboradores {
    margin-top: 60px !important;
}

.block.contato {
    margin-top: 0 !important;
    font-size: 1.4rem !important;
    line-height: 2.4rem !important;
}

.block__wrapper {
    width: 100% !important;
}

.container {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    max-width: 100%;
    padding-left: 2.5rem;
    padding-right: 2.5rem;
}

.container_rodape {
    display: flex;
    flex-wrap: wrap;
}

.container_rodape .informacoes {
    display: flex;
    flex-direction: column;
    flex: 1 0 50%;
    padding-left: 30px;
}

.coluna_rodape {
    flex: 1 0 40%;
}

@media (max-width: 400px) {
    .coluna_rodape {
        flex: 1 0 100%;
    }
}

@media (max-width: 980px) {
    .container_rodape {
        flex-direction: column;
    }
    .contato_1, .contato_2 {
        flex: 1 0 100%;
    }
}

@media (max-width: 940px) {
    .coluna_rodape.icon {
        display: flex;
        flex-direction: row !important;
        flex: 1 0 100%;
    }
}

.coluna_rodape.icon {
    display: flex;
    flex-direction: column;
    flex: 1 0 20%;
}

.coluna_rodape.icon I {
    margin-left: 0 !important;
    margin-right: 1rem !important;
}

.coluna_rodape_email {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    flex: 1 0 100%;
    align-items: center;
    max-width: 100%;
    max-height: 35px;
    margin-bottom: 50px !important;
}

.coluna_rodape_email .contact-tile {
    margin-right: 20px;
     margin-bottom: auto;
}

.coluna_rodape_email .descricao2 {
    margin-bottom: 13px !important;
}

.coluna_rodape_email .descricao2 .link_texto {
    padding-right: 20px !important;
}

@media (max-width: 437px) {
    .coluna_rodape_email .descricao2 {
        margin-left: 0;
        padding-right: 50px !important;
        font-size: 1.6rem !important;
    }

    #contato .contato_2 {
        padding-top: 30px;
    }
}

header {
    height: 80px !important;
    margin-bottom: 0;
}

.navbar {
    padding: 0 3rem 0 3rem;
    border-bottom: 2px solid red;
    box-shadow: rgba(0,0,0,0.3) 5px 5px 5px;
}

.navbar-brand {
    margin-top: 3px;
    margin-bottom: 3px;
}

.nav-item {
    color: black;
}

.navbar .nav-link:after {
    background-color: transparent;
}

.nav-item.nav-link.pesquisar,
.nav-item.nav-link.filtrar {
    width: 40px;
    font-size: 1.4rem !important;
    line-height: 2.4rem !important;
}

/* Menu Horizontal */
.navbar .divider {
    display: none;
    width: 133px;
    height: auto;
    margin: 15px 0;
    border-top: none;
    border-left: 2px solid black;
    opacity: 1;
}

.navbar .logotipo_unidade {
    display: flex;
    flex-direction: row;
    align-content: start;
    align-items: center;
    cursor: pointer;
}

.navbar .logotipo_unidade .texto_unidade {
    margin-left: 5px;
    padding: 0;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    font-style: italic;
    line-height: 20px;
}

@media (max-width: 523px) {
    .navbar .logotipo_unidade .texto_unidade {
        font-size: 16px;
    }
}

.navbar-toggler {
    position: absolute;
    top: 25px;
    right: 30px;
    border: 1px solid black !important;
    cursor: pointer;
}
.navbar-toggler:hover {
    border: 1px solid red !important;
}

.navbar-toggler .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}
.navbar-toggler:hover .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 0, 0, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

.navbar-light .navbar-nav .nav-link {
    opacity: 1 !important;
}

.navbar-light .navbar-nav .nav-link:hover {
    color: red !important;
    opacity: 1 !important;
}

.navbar-expand-lg .navbar-nav {
    align-items: end;
}

.nav-item.nav-link {
    width: 133px;
    text-align: left;
}

.menu {
    height: 75px;
    background-color: white;
}

.dropdown .dropdown-menu {
    display: block;
}

.dropdown-toggle {
    text-decoration: none !important; /* Remove o sublinhado */
}

.collapse.show {
    margin: 0 !important;
    padding-bottom: 15px;
    transition: height 0.35s ease;
}

.collapsing {
    transition: height 0.05s ease;
}

.filtro {
    z-index: 2;
    position: fixed;
    top: 70px;
    width: 100%;
    height: auto;
    margin: 0 !important;
    padding: 20px 0 10px 0 !important;
    border-bottom: 1px solid black !important;
    background-color: rgba(255, 255, 255, 0.9);
    transition: transform 0.3s;
}

.filtro_esconder {
    transform: translateY(-100%);
}

.filtro_texto {
    margin: 15px 0;
    font-size: 25px;
    font-weight: bold;
    /* text-shadow: -1px 0 black, 0 1px black, 1px 0 black, 0 -1px black; */
    color: black;
}

.filtro_container .pesquisar,
.filtro_container .filtrar {
    margin-left: 10px;
}

#filtros {
    z-index: 1000;
    display: block !important;
    position: relative;
    top: 0px;
    padding-top: 0;
}

.filtro_label {
    display: block !important;
    max-width: 200px;
    margin: 0 !important;
    padding: 0 10px !important;
    opacity: 0.5;
}

.filtro_item {
    position: relative;
    bottom: 0;
    width: 200px;
    max-width: 200px;
    height: 40px;
    min-height: 40px;
    margin: 0 20px;
    border: 1px solid black;
    border-radius: 5px;
    font-size: 1.6rem;
    color: black !important;
    background-color: white;
}

.filtro_item:active,
.filtro_item:focus {
    border: 1px solid black;
    outline: 1px solid black;
}

.filtro_input {
    display: block;
    position: relative;
    width: 200px;
    max-width: 200px;
    height: 40px;
    min-height: 40px;
    margin: 0;
    padding: 0 5px;
    border: 1px solid black;
    border-radius: 3px;
    font-size: 1.6rem;
    color: black !important;
    background-color: white;
}

.filtro_input:active,
.filtro_input:focus {
    border: 1px solid black;
    outline: 1px solid black;
}

.form-group.valor {
    position: relative;
    bottom: 0;
    max-width: 300px !important;
}

.form-group .value-min,
.form-group .value-max {
    height: 15px;
    cursor: default;
}

.form-group .ui-slider {
    padding: 0 10px !important;
}

.form-group-filtros {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: center;
    gap: 10px;
}

.form-group-filtros .form-group {
    margin: 0 !important;
}

.form-group-filtros SELECT,
.form-group-filtros SELECT {
    margin: 0px;
}

.form-group-botoes {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    width: 120px;
    margin: 10px 0;
}

.limpar_filtro {
    position: absolute;
    bottom: -11px;
    right: 10px;
    font-size: 12px;
    font-weight: bold;
    color: black !important;
    cursor: default;
}
.limpar_filtro:hover {
    color: red !important;
}

#hero .hero__background {
    height: 690px !important;
    background-color: transparent;
}

.block {
    padding-top: 0;
    padding-bottom: 0;
}

.block .block__wrapper {
    position: relative;
    padding-top: 1rem;
    padding-bottom: 0;
}

.block .block__title {
    margin-bottom: 4rem;
    color: red  /* brown burlywood crimson chocolate darkorange darkred */;
}

.block .block__title h2 {
    font-size: 3.6rem;
}

.box.box--pricing .box__header {
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 20px 20px 0 20px;
}

.box.box--pricing .box__header .header_top {
    display: flex;
    justify-content: space-between;
}

.box.box--pricing .box__header .header_top .imovel_descricao {
    font-size: 18px !important;
}

.box.box--pricing .box__header .header_top .imovel_preco {
    font-size: 20px !important;
}

.box.box--pricing .box__header .imovel_endereco {
    width: 100%; /* Ocupa a largura inteira */
    margin-top: 5px;
    font-size: 14px !important;
    text-align: justify;
    line-height: 1.5;
}

.box.box--pricing .box__header I {
    margin-left: 10px;
    font-size: 20px;
    color: lightgray;
}

.box.box--pricing .box__header I.favoritado {
    color: red;
}

.mostrar_mais {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
}

.mostrar_mais DIV {
    margin: 20px 0 50px 0;
    padding: 10px 30px;
    border-radius: 10px;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 1px;
    color: white;
    background-color: rgba(0, 0, 0, 1);
    cursor: pointer;
    transition: background-color 0.5s;
}

#imoveis .box__content {
    display: flex;
    flex-flow: row nowrap !important;
    padding: 20px 5px;
    align-content: center;
    border-radius: 0 0 1.3rem 1.3rem !important;
    background-color: transparent;
}

#imoveis .box__content .descricao {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    max-height: 53px;
}

#imoveis .box__content .item {
    display: flex; /* Adicionado aqui */
    justify-content: center; /* Adicionado aqui */
    align-items: center; /* Adicionado aqui */
    height: 30px;
    padding: 2px 7.5px;
    border-radius: 6px;
    text-align: center;
    color: black;
}

#imoveis .box__content .item I {
    margin: 0 !important;
    margin-right: 2px !important;
    padding: 0 !important;
    border: none !important;
    outline: none !important;
    color: red;
}

#imoveis .box__content .no_display {
    display: none !important;
}

#imoveis .imovel {
    border-radius: 1.3rem !important;
    cursor: pointer;
}

#imoveis .descricao {
    display: inline;
    margin: 0 auto;
}

#imoveis ul {
    display: inline;
    margin: 0 auto;
    font-size: 16px !important;
    text-align: left;
}

#imoveis i {
    width: 25px;
}

.imovel_descricao {
    font-size: 22px !important;
}

.imovel_preco {
    font-size: 22px !important;
}

.background-wrapper {
    background-color: rgb(248, 239, 234);
}

#sobre h2 {
    padding-top: 2rem !important;
    margin-bottom: -3rem !important;
    font-size: 3.6rem !important;
}

#sobre .blockquote-footer {
    padding-bottom: 2rem !important;
}

#colaboradores {
    padding: 0 0;
    background: #fff;
}

#colaboradores .row {
    margin-right: 0px;
    margin-left: -20px;
}

#colaboradores .quadro {
    margin: 0 !important;
    padding: 0 !important;
}

#colaboradores li .team {
    border: 1px solid #AAAAAA;
    border-radius: 10px;
}

#colaboradores li .img-responsive {
    width: 100%;
    height: 270px;
    object-fit: cover;
    object-position: top;
}

#colaboradores li .team-detail {
    border: unset !important;
}

#colaboradores li .team-detail p {
    margin: 0 0 15px 0 !important;
}

#contato {
    padding: 4rem 0 60px 0;
    color: white;
    background: #3C3C3C;
    background-size: contain ;
}

#contato header {
    height: auto !important;
}

#contato h3 {
    margin-bottom: 30px;
    font-size: 3.6rem;
    color: #FFCACA;
}

#contato iframe {
    width: 100%;
    height: 300px;
    border: 0;;
}

#contato .contato_1 {
    display: flex;
    flex-wrap: wrap;
}

#contato .contato_1 a {
    color: inherit;
}

#contato .contato_2 {
    flex: 1 0 50%;
    align-self: flex-start;
    width: 100%;
    min-height: 50px;
    padding-left: 1rem;
    padding-right: 1rem;
}

.contact-box {
    margin-bottom: 35px;
    padding: 0;
}

.contact-box.icon {
    flex-direction: column;
    margin-bottom: 35px;
    padding: 0;
}

.contact-box I {
    width: 45px;
    height: 45px;
    margin-bottom: 10px;
    border: solid 1px white;
    border-radius: 50%;
    font-size: 24px;
    text-align: center;
    line-height: 45px;
    color: white;
}

.contact-box .icon {
    border: none;
}

.contact-box .descricao1 {
    margin-bottom: 5px;
    padding: 0;
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 1.75rem;
}

.contact-box .descricao2 {
    margin-bottom: 5px;
    padding: 0;
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 1.75rem;
    font-style: italic;
    opacity: 0.65;
}

.contact-tile {
    padding-left: 0;
    font-family: handmade;
    font-size: 20px;
    font-weight: bold;
    color: #010215;
}

.separador_vertical {
    margin-bottom: 35px !important;
}

.icone_menu {
    opacity: 1 !important;
    margin: 9px 0 0 0 !important;
    font-size: 1.75em !important;
    color: red !important;
    cursor: pointer;
}
.icone_menu:hover {
    color: black !important;
    transition: .3s ease;
}

.icone_menu.fa-facebook-f {
    font-size: 1.7em !important;
}

figure {
    margin: 0 !important;
    padding: 0 20px !important;
}

.empresa {
    z-index: 1000;
    position: relative;
    display: flex;
    flex-flow: row wrap;
    justify-content: center !important;
    bottom: -30px;
    padding-bottom: 0;
    font-size: 14px;
    text-align: center;
    color: white;
}

.whatsapp {
    z-index: 1000;
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 20px;
    right: 20px;
    border-radius: 50px;
    box-shadow: 1px 1px 2px #888;
    font-size: 30px;
    text-align: center;
    color: #FFF;
    background-color: rgba(37, 211, 102, 0.6);   /* #25d366; */
}
.whatsapp:hover {
    background-color: rgba(37, 211, 102, 1);   /* #25d366; */
}

.link_texto {
    padding-right: 4rem;
    word-wrap: break-word;
    overflow-wrap: break-word;
    color: white;
}
.link_texto:hover {
    font-width: bold;
}

.comunicado_imagem {
    z-index: 20000;
    position: fixed;
    display: flex;
    justify-content: center;
    align-items: center;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 10px !important;
    background-color: rgba(255, 255, 255, 1);
}

.comunicado_imagem DIV {
    position: relative;
    width: 100%;
}

.comunicado_imagem IMG  {
    z-index: 1000;
    position: fixed;
    top: 50%;
    left: 50%;
    width: 99%;
    height: 99%;
    max-width: 99%;
    max-height: 99%;
    margin: 0 !important;
    padding: 0 !important;
    border: 3px solid black;
    border-radius: 10px;
    object-fit: contain;
    transform: translate(-50%, -50%);
    cursor: default !important;
}

.comunicado_imagem .botao_f {
    z-index: 3000;
    position: absolute;
    top: 30px;
    right: 30px;
    width: 32px !important;;
    height: 32px !important;;
    max-width: 32px !important;;
    max-height: 32px !important;;
    padding: 0 !important;
    border: 2px solid white;
    border-radius: 50%;
    font-size: 20px;
    color: white;
    background-color: black;
    transition: background-color 0.5s;
    cursor: pointer;
}
.comunicado_imagem .botao_f:hover {
    background-color: red;
}

.resolucao {
    z-index: 10000;
    position: fixed;
    display: none;
    left: 0;
    bottom: 0;
    margin: 0;
    padding: 15px 15px;
    font-size: 10px;
    line-height: 0;
    color: black;
    background: rgba(255, 0, 0, 0.5);
    cursor: pointer;
}



/* Cores */



.back_black {
    background-color: black;
}

.color_maroon {
    color: maroon;
}



/* MEDIA */



@media (min-width: 576px) {
    .filtro_container {
        max-width: unset !important;
    }
}

@media (max-width: 634px) {
    #contato {
        /* background-size: unset; */
    }

    #contato iframe {
        height: 300px !important;
    }
}

@media (max-width: 685px) {
    .empresa {
        font-size: 13px;
    }

    .empresa figure {
        padding: 0 8px !important;
    }

    .filtro_item {
        margin: 0;
    }

    .filtro_input {
        margin: 0;
    }
}

@media (max-width: 767px) {
    header {
        margin-bottom: -14rem;
    }

    #contato iframe {
        height: 564px;
    }

    .empresa {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    #hero .hero__background {
        height: 600px !important;
        top: -162px !important;
    }

    .block.imoveis {
        margin-top: 305px;
    }

    .block.sobre #sobre_quadro {
        width: 100%;
        font-size: 15px;
    }
}

@media (max-width: 709px) {
    .block.imoveis {
        margin-top: 345px;
    }
}

@media (max-width: 589px) {
    .block.imoveis {
        margin-top: 395px;
    }
}

@media (max-width: 329px) {
    .block.imoveis {
        margin-top: 495px;
    }
}

@media (max-width: 305px) {
    .block.imoveis {
        margin-top: 525px;
    }
}

@media (min-width: 768px) and (max-width: 992px) {
    #contato .contato_1 {
        padding-left: 1rem;
    }

    #contato .contato_2 {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .coluna_rodape_email {
        margin-left: 10px;
    }

    .empresa {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

@media (max-width: 910px) {
    .filtro_item,
    .filtro_input {
        width: 120px;
        max-width: 120px;
    }

    .contact-box .descricao1,
    .contact-box .descricao2 {
        font-size: 1.5rem;
    }
}

@media (min-width: 992px) {
    .navbar-expand-lg .navbar-nav {
        align-items: center;
    }

    .nav-item.nav-link  {
        width: auto;
        text-align: center;
    }

    /* Menu Horizontal */
    .navbar .divider {
        display: block;
        width: auto;
        height: 15px;
        margin: 0 10px;
        border-top: none;
        border-left: 2px solid black;
        opacity: 1;
    }

    .navbar .nav-button {
        margin: 0 0 0 15px;
    }

    .dropdown .dropdown-menu {
        display: none;
        padding: 10px 5px;
    }
    .dropdown:hover .dropdown-menu {
        display: block;
        margin-top: 0; /* Garante que o submenu apareça logo abaixo do item do menu */
    }
}

@media (max-width: 400px) {
    .navbar {
        margin-left: -20px;
    }

    .navbar-toggler {
        right: 12px;
    }
}



/* ----------------------------------------- */



.icone_menu {
    opacity: 1 !important;
    margin: 0 !important;
    font-size: 2.5em !important;
    color: black !important;
    cursor: pointer;
}
.icone_menu:hover {
    color: red !important;
    transition: .3s ease;
}

#filterBar {
    z-index: 999; /* Fica por cima de outros elementos */
    overflow-y: auto;
    position: fixed;
    top: 75px;
    left: -360px; /* Inicialmente escondido */
    width: 360px;
    height: 100vh;
    padding: 25px 25px 100px 25px;
    border-right: 2px solid red;
    box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.3);
    background-color: #BBBBBB;
    transition: left 0.5s ease; /* Animação */
}

#filterBar H5 {
    margin: 0 0 10px 0;
}

#filterBar .bexecutar_filtro {
    position: absolute;
    top: 26px;
    right: 60px;
    padding: 8px 8px;
    border-radius: 20px;
    color: white;
    background-color: black;
    cursor: pointer;
    transition: background-color 0.5s;
}
#filterBar .bexecutar_filtro:hover {
    background-color: red;
}

#filterBar .bfechar_filtro {
    position: absolute;
    top: 26px;
    right: 20px;
    padding: 8px 11px;
    border-radius: 20px;
    color: white;
    background-color: black;
    cursor: pointer;
    transition: background-color 0.5s;
}
#filterBar .bfechar_filtro:hover {
    background-color: red;
}

#filterBar LABEL {
    display: block;
    margin: 10px 0 0 0;
    padding: 0;
}

#filterBar .listagem {
    padding-left: 10px;
}

#filterBar .botao {
    flex: 1 0 auto;
    align-content: center;
    text-align: center;
}

#filterBar .grupo_selecao {
    margin: 0 0 15px 0;
    padding: 0;
}

#filterBar .selecao {
    display: flex;
    flex-direction: row;
    align-items: center;
    margin: -5px 0 0 0;
    font-style: italic;
}

#filterBar .selecao INPUT[type=checkbox] {
    display: none;
}

#filterBar .selecao LABEL {
    position: relative;
    padding-left: 30px;
    line-height: 20px;
    cursor: pointer;
}

#filterBar .selecao LABEL:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    border: 2px solid gray;
    background-color: white;
}

#filterBar .selecao input[type="checkbox"]:checked + label:before {
    background-color: rgba(255, 0, 0, 0.7);
}

#filterBar .listagem,
#filterBar .campo,
#filterBar .botao {
    height: 40px;
    min-height: 40px;
    border: 2px solid gray;
    border-radius: 5px;
    font-size: 1.6rem;
    color: black;
    background-color: white;
    cursor: default;
}
#filterBar .listagem:hover,
#filterBar .campo:hover,
#filterBar .botao:hover {
    border: 2px solid black;
}

#filterBar .grupo_campo,
#filterBar .grupo_botao {
    display: flex;
    justify-content: space-between;
}

#filterBar .grupo_campo > #filterBar .campo,
#filterBar .grupo_botao > #filterBar .botao {
    margin-right: 10px;
}

#filterBar .grupo_campo > #filterBar .campo:last-child,
#filterBar .grupo_botao > #filterBar .botao:last-child {
    margin-right: 0;
}

#filterBar .grupo_campo_texto {
    display: flex;
    flex-direction: column;
    justify-content: start;
}

#filterBar .botao[selecionado=S] {
    color: white;
    background-color: rgba(255, 0, 0, 0.7);
}

#filterBar .texto {
    font-size: 1.4rem;
    color: gray;
    margin: -4px 0 -3px 0;
}

.colunas_superiores {
    display: flex;
    flex-direction: column;
}

.coluna_imagem {
    padding: 0 10px
}

.sobre,
.docs,
.seg {
    z-index: 20000;
    position: fixed;
    display: none;
    justify-content: center;
    align-items: center;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 0 !important;
    box-sizing: border-box;
    background-color: rgba(0, 0, 0, 0.8);
}

.sobre BUTTON,
.docs BUTTON,
.seg BUTTON,
.mapa BUTTON {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 32px !important;;
    height: 32px !important;;
    max-width: 32px !important;;
    max-height: 32px !important;;
    padding: 0 !important;
    border: 2px solid white;
    border-radius: 50%;
    font-size: 20px;
    color: white;
    background-color: black;
    transition: background-color 0.5s;
    cursor: pointer;
}
.sobre BUTTON:hover,
.docs BUTTON:hover,
.seg BUTTON:hover,
.mapa BUTTON:hover {
    background-color: red;
}

.sobre .sobre_texto,
.docs .docs_texto,
.seg .seg_texto {
    display: flex;
    flex-direction: column;
    justify-content: start;
    width: 90%;
    height: 80%;
    padding: 10px 15px !important;
    box-sizing: border-box;
    border-radius: 10px;
    background-color: white;
    background-image: url("../img/logo-alpha.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.sobre .sobre_conteudo,
.docs .docs_conteudo,
.seg .seg_conteudo {
    overflow-y: auto;
    height: 99%;
    font-size: 2rem;
    text-align: justify;
    line-height: 1.5;
    hyphens: auto;
    color: black;
    cursor: default;
}

.sobre .sobre_conteudo H4,
.docs .docs_conteudo H4,
.seg .seg_conteudo H4 {
    color: red;
}

.docs .docs_conteudo P {
    margin: 20px 0 5px 0;
    padding: 0;
    font-size: inherit;
    line-height: inherit;
    font-weight: bold;
    font-style: italic;
    color: black;
    opacity: 1;
}

.docs .docs_conteudo UL,
.seg .seg_conteudo UL {
    padding-left: 0 !important;
}

.docs .docs_conteudo LI,
.seg .seg_conteudo LI {
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: inherit;
    line-height: inherit;
    color: black;
}

.docs .docs_conteudo A,
.seg .seg_conteudo A {
    font-size: inherit;
    line-height: inherit;
    font-style: italic;
    color: red;
}

.docs .docs_conteudo I {
    margin-left: 10px;
}

.docs .docs_conteudo LI::before {
    position: relative;
    display: inline-block;
    top: -5px;
    margin-right: 10px;
    content: "\f00c";
    content: "\f111";
    font-family: "Font Awesome 6 Free";
    font-size: 8px;
}

.docs .info1,
.docs .info2 {
    position: relative;
    display: inline-block;
    cursor: pointer;
}

.docs .info1:active::after,
.docs .info2:active::after {
    z-index: 100;
    position: fixed;
    top: 50%;
    left: 50%;
    width: 322px;
    padding: 10px 15px;
    border: 1px solid black;
    border-radius: 6px;
    box-shadow: 0px 0px 10px rgba(0,0,0,0.8);
    font-family: "Open Sans", sans-serif;
    font-size: 14px;
    font-weight: normal;
    text-align: justify;
    text-transform: none;
    line-height: 1.5;
    white-space: pre-wrap;
    hyphens: auto;
    color: black;
    background-color: #EEEEEE;
    opacity: 1;
    transform: translate(-50%, -50%);
}

.docs .info1:active::after {
    content: "Inclui cônjuge ou companheiro(a)";
}

.docs .info2:active::after {
    /*
    A identação cria espaços múltiplos antes da linha
    Caracteres especiais:
        \  = utilizado para escrever várias linhas
        \A = utilizado para "quebrar a linha" (como um <br/>)
    */
    content: "\
Instituída pela Resolução CFC nº 872, de 23-03-2000, é o documento contábil destinado a \
fazer prova de informação sobre percepção de rendimentos, em favor de pessoas físicas. \
Nada mais é do que uma declaração, cuja emissão é privativa de contabilista e que visa \
a comprovação dos rendimentos recebidos em determinado período por pessoas físicas. \
Para que a mesma tenha validade é necessário que na primeira via seja aposta a etiqueta \
auto-adesiva de Declaração de Habilitação Profissional (DHP), conforme dispõe o artigo \
2º, § 2º da mencionada resolução.\
    ";
}

.seg .seg_conteudo P {
    margin: 20px 0 5px 0;
    padding: 0;
    font-size: inherit;
    line-height: inherit;
    color: black;
    opacity: 1;
}

.mapa {
    z-index: 20000;
    position: fixed;
    display: none;
    justify-content: center;
    align-items: center;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 0 !important;
    box-sizing: border-box;
    background-color: rgba(0, 0, 0, 0.8);
}

.mapa_quadro {
    width: 90%;
    height: 80%;
}

.mapa_quadro IFRAME {
    width: 100%;
    height: 100%;
}

@media (min-width: 10px) {
    .coluna_imagem {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
}

@media (min-width: 710px) {
    .coluna_imagem {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .sobre {
        padding: 10px !important;
    }

    .sobre .sobre_texto {
        width: 80%;
        padding: 30px !important;
    }
}

@media (min-width: 1100px) {
    .coluna_imagem {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
}

@media (min-width: 1500px) {
    .coluna_imagem {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }
}


