/* =============================
   catalogo.css — versão consolidada
   Mantém #barradefiltrosOK funcionalidade
============================= */

/* LAYOUT BASE */
#catalogo-wrapper {
    display: flex;
    width: 100%;
    height: auto;
    gap: 0;
    align-items: flex-start;
    box-sizing: border-box;
}

/* SIDEBAR — ABERTA */
.col-filtro {
    width: 260px;
    min-width: 260px;
    background: #FBFCFD;
    padding: 15px;
    transition: width .25s ease, padding .25s ease;
    overflow-y: auto;
    box-sizing: border-box;
    position: sticky;
    top: 54px;
    height: calc(100vh - 70px);
    z-index: 5;
}
@media (max-width: 768px) {
    .col-filtro {
        width:100% !important;
        min-width:100% !important;
    }
}

/* SIDEBAR — COLAPSADA (funcional) */
.col-filtro.colapsado {
    width: 60px !important;
    min-width: 60px !important;
    padding: 10px !important;
}

/* escondem conteúdo quando colapsada */
.col-filtro.colapsado #filtro-conteudo,
.col-filtro.colapsado .texto-filtro,
.col-filtro.colapsado #btn-limpar-filtros {
    display: none !important;
}
.col-filtro.colapsado #filtro-header {
    justify-content: center !important;
}

/* ÁREA PRINCIPAL (cards) */
.main-area {
    flex: 1;
    padding: 15px;
    transition: width .25s ease, margin-left .25s ease;
    box-sizing: border-box;
}

/* Header do filtro */
#filtro-header {
    cursor: pointer;
    font-weight: 600;
    display: flex;
    align-items: center;
    font-size: 0.95rem;
    justify-content: space-between;
}

/* Botão limpar */
#btn-limpar-filtros {
    cursor: pointer;
}

/* SEÇÕES */
.filtro-secao {
    border-bottom: 1px solid #eee;
    padding-bottom: 12px;
    margin-bottom: 15px;
}
.filtro-secao:last-child { border-bottom: none; }
.filtro-titulo {
    font-weight: 500;
    font-size: 0.7rem;
    color: #444;
    text-transform: uppercase;
}

/* BOTÕES DE GRUPO */
.filtro-btn-group { display: flex; gap: .5rem; }
.filtro-btn-group .filtro-btn {
    flex: 1 1 0;
    min-width: 0;
    padding: 10px 14px;
    font-weight: 500;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    transition: background .15s ease;
}
.filtro-btn-group .filtro-btn:hover { background-color: #f8f9fb; }
.btn-outline-secondary  { background-color: #fff !important; color: #000000 !important; border-color: 0045a5;}
.btn-outline-secondary:hover { background-color: #0045a5 !important; color: #fff !important; }
.btn-outline-primary:hover { background-color: #0045a5 !important; color: #fff !important; }
.btn-outline-finalidade {color: #0045a5; border-color: #0d6efd; border-width: 2px;}
.btn-outline-finalidade:hover {color: #fff; background-color: #0045a5!important; border-color: #0045a5;}
/* INPUTS */
.filtro-input { position: relative; height: auto; }
.filtro-input .form-control {
    padding: 10px 10px; font-size: 0.7rem; border: 1px solid #ddd;
    box-shadow: none; border-radius: 10px 0 0 10px;
}

.filtro-input .input-icon {
    position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
    pointer-events: none; font-size: 0.7rem; color: #0c0c0c;
}
.filtro-input-icon { padding-left: 30px !important; }

.filtro-input .form-control:focus {
    border-color: #0d6efd; box-shadow: 0 0 0 .25rem rgba(13,110,253,.15);
}
.filtro-btn-search {
    padding: 10px 14px; border-radius: 0 10px 10px 0 !important; border: 1px solid #ddd;
}

/* LOCALIZAÇÃO */
.filtro-localizacao .form-select { padding-top:10px !important; padding-bottom:10px !important; border-radius:5px !important;font-size: 0.7rem; }

.filtro-uf { width:70px !important; flex:0 0 auto !important; min-width:70px !important;   padding-left: 0px!important; }

.filtro-cidade { flex:1 1 auto !important; }

/* TIPO (pills) */
.filtro-tipo-btn { border:1px solid #dee2e6; background:#f8f9fa; border-radius:999px; padding:.25rem .75rem; display:inline-flex; gap:.35rem; white-space:nowrap; }
.filtro-tipo-btn:hover { background:#e9ecef; border-color:#ced4da; }
.filtro-tipo-btn.active { background:#0d6efd; color:#fff; box-shadow:0 0 0 .15rem rgba(13,110,253,.2); }
.filtro-tipo-badge { display:inline-flex; min-width:1.5rem; padding:0 .3rem; font-size:.6rem; border-radius:999px; background:#0f3883b9; color:#fff; justify-content:center; align-items:center; }

/* campos preço */
#filtro-preco-min, #filtro-preco-max { width:100%; }

/* RESPONSIVO: mobile mantém comportamento A (cards ao lado),
   porém sidebar inicia colapsada por padrão. */
@media (max-width: 768px) {
    #catalogo-wrapper { flex-direction: row; }
    /* por padrão assumimos sidebar colapsada (60px) — JS vai garantir o estado inicial */
    .main-area { width: calc(100% - 60px); }
    .col-filtro.colapsado + .main-area { width: calc(100% - 60px); }
    .col-filtro:not(.colapsado) + .main-area { width: calc(100% - 260px); }

    /* sticky menor no mobile */
    .col-filtro { position: sticky; top: 60px; height: calc(100vh - 60px); z-index: 30; }
}

/* ensure no accidental overlaps */
#catalogo-wrapper, .col-filtro, .main-area { -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
/* BOTÃO MOBILE DE FILTROS */
#btn-mobile-filtros {
    display: none;
}
#icone-filtro {
    font-size: 1.2rem;
}
@media (max-width: 768px) {
    #icone-filtro {font-size: 1.5rem;}
}
.texto-filtro {
    font-size: 0.95rem;
    font-weight: 600;
}
/* Ícone do botão de filtro (estado fechado -> aberto) */
/* Ícone normal (filtro fechado) */
#icone-filtro {
    transition: color .2s ease, opacity .2s ease;
    color: #374151;      /* cinza dark */
    opacity: 0.7;
}

/* Filtro aberto (sidebar expandida) */
#icone-filtro.filtro-aberto {
    color: #0d6efd;      /* azul destaque */
    opacity: 1;
}

/* Badge com número de filtros ativos */
.filtro-badge {
    background: #0d6efd;
    color: #fff;
    border-radius: 999px;
    padding: 2px 7px;
    font-size: 0.65rem;
    font-weight: 600;
    display: inline-block;
    line-height: 1;
    transform: translateY(-2px);
}

/* Some completamente quando não há filtros */
.filtro-badge.d-none {
    display: none !important;
}

/* Wrapper para poder posicionar o badge */
.filtro-icon-wrapper {
    position: relative;
    display: inline-block;
    margin-right: 8px; /* espaçamento entre ícone e texto */
}

/* Badge estilo notificação */
.filtro-badge {
    position: absolute;
    top: -6px;
    right: -6px;
    color: #fff;
    border-radius: 999px;
    padding: 2px 6px;
    font-size: 0.60rem;
    font-weight: 600;
    line-height: 1;
    display: inline-block;
}
/* --- NOVAS REGRAS ---- */
.btn-anunciantes {
    background: #0d6efd;
    color: #fff;
    border-radius: 10px;
    font-weight: 600;
    border: none;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transition: 0.2s ease;
}

.btn-anunciantes:hover {
    background: #0b5bd5;
    transform: translateY(-2px);
}

.card-minianunciante {
    display: flex;
    align-items: center;
    padding: 12px;
    border-radius: 12px;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    cursor: pointer;
    transition: 0.25s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.card-minianunciante:hover {
    box-shadow: 0 4px 14px rgba(0,0,0,0.10);
    transform: translateY(-1px);
}

.mini-avatar img {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    object-fit: cover;
}

.mini-info {
    flex: 1;
    margin-left: 12px;
}

.mini-info strong {
    font-size: 0.93rem;
    color: #1f2937;
}

.mini-info span {
    font-size: 0.8rem;
    color: #6b7280;
}

.mini-arrow {
    color: #9ca3af;
    font-size: 1rem;
}
.anunciante-card img {
    object-fit: cover;
}

.anunciante-card .badge {
    font-size: 0.55rem;
    padding: 3px 6px;
    border-radius: 6px;
}
.loading-trigger {
    opacity: 0;
    height: 1px;
    pointer-events: none;
}

/* acordions de filtros */
/* CONTAINER DA SEÇÃO */
.filtro-secao-accordion {
    padding: 0;
    margin-bottom: 22px;
}

.filtro-secao-accordion .divider {
    height: 1px;
    background: #eee;
    margin: 6px 0 14px;
}

/* HEADER – minimalista, tipo Notion/Linear */
.accordion-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    padding: 6px 2px;
    font-size: 0.92rem;
    font-weight: 600;
    color: #2e2e2e;
    transition: color .20s ease;
}

.accordion-header:hover {
    color: #000;
}

/* SETA FININHA – estilo SaaS */
.seta-accordion {
    font-size: 0.95rem;
    transition: transform .20s ease, opacity .2s ease;
    opacity: .6;
}

.seta-accordion.active {
    transform: rotate(180deg);
    opacity: 1;
}

/* CONTEÚDO – clean + animação*/
.filtro-secao-accordion .collapse {
    transition: all .25s ease;
}

.filtro-secao-accordion .collapse.show {
    padding-top: 4px;
}

/* Inputs dentro do accordion ficam com visual premium */
.filtro-secao-accordion input.form-control,
.filtro-secao-accordion select.form-select {
    border-radius: 10px !important;
    border: 1px solid #ddd !important;
    padding: 10px 12px !important;
    font-size: 0.82rem !important;
    transition: border-color .2s ease, box-shadow .2s ease;
}

.filtro-secao-accordion input.form-control:focus,
.filtro-secao-accordion select.form-select:focus {
    border-color: #4d77ff !important;        /* Roxo premium */
    box-shadow: 0 0 0 2px rgba(124,77,255,.15) !important;
}
.anunciante-nome-fone {
    font-size: 0.6rem;
}
@media  (max-width: 576px) {
    .anunciante-nome-fone {
        font-size: 0.85rem;
    }  
}

.det-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 10px 10px;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    transition: all .25s ease;
    cursor: pointer;
}

.det-inner {
    display: flex;
    align-items: center;
    gap: 4px;
}

.det-label {
    font-size: 11px;
    color: #6b7280;
    margin-top: -2px;
}

.det-card:hover {
    border-color: #3b82f6;
    box-shadow: 0 3px 10px rgba(59, 130, 246, 0.15);
}

/* Estado selecionado */
.det-card.active {
    border-color: #2563eb !important;
}

.det-card.active .icon {
    color: #2563eb !important;
}

.det-card.active .det-label {
    color: #2563eb !important;
    font-weight: 400;
}

.det-card .icon {
    font-size: 14px;
    color: #3b82f6;
}

.det-input {
    border: none;
    width: 28px;
    font-size: 14px;
    text-align: center;
    padding: 0;
    outline: none;
    background: transparent;
}

@media (max-width:768px) {
    .det-card .icon {
        font-size: 18px; 
    }
    .det-input {
        border: none;
        width: 40px;
        font-size: 18px; 
    }
    
    .det-card {
        gap: 3px;
        padding: 10px 20px!important;
    }
}
/* cardXcat 
    card horizontal de lista do catalogo

    /////////////////////////////////////////////*/
.cardXcat {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    overflow: hidden;
}

.cardXcat-horizontal {
    display: flex;
    width: 50%;
}
.cardXcat-thumb {
    position: relative;
    flex: 0 0 180px;   /* largura fixa */
    height: 150px;     /* altura fixa */
    overflow: hidden;
    border-radius: 8px;
    background: #f1f1f1; /* fallback elegante */
}
.cardXcat-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;   /* corta, não distorce */
    display: block;
}
.cardXcat-badge-top {
    position: absolute;
    top: 6px;
    left: 6px;
    font-size: .65rem;
}
.cardXcat-badge-bottom {
    position: absolute;
    bottom: 6px;
    left: 6px;
    font-size: .65rem;
}
.cardXcat-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 10px;
}
.cardXcat-info {
    flex: 1; /* ocupa todo o espaço acima do botão */
}

.cardXcat-title {
    font-size: .95rem;
    font-weight: 600;
    margin: 0 0 4px;
}

.cardXcat-location {
    font-size: .75rem;
    color: #6c757d;
    margin-bottom: 6px;
}
.cardXcat-price {
    display: flex;
    align-items: baseline;
    gap: 8px;
    flex-wrap: wrap;
}

.cardXcat-price .price-promocional {
    font-size: 1rem;
    font-weight: 700;
    color: #0d6efd; /* primary */
}

.cardXcat-price .price-original {
    font-size: .75rem;
    color: #999;
    text-decoration: line-through;
}

.cardXcat-price .price-sufixo {
    font-size: .7rem;
    color: #6c757d;
    margin-left: 2px;
}

.cardXcat-features {
    display: flex;
    gap: 10px;
    font-size: .7rem;
    color: #444;
}
.cardXcat-features i {
    margin-right: 4px;
}
.cardXcat-actions {
    border-top: 1px solid #eee;
    padding-top: 8px;
}

/* MOBILE */
@media (max-width: 768px) {
    .cardXcat-horizontal {
        width: 100%;
    }

    .cardXcat-thumb {
        flex: 0 0 110px;
        height: 90%;
    }

    .cardXcat-title {
        font-size: .85rem;
    }

    .cardXcat-location {
        font-size: .7rem;
    }

    .cardXcat-features {
        font-size: .65rem;
        gap: 6px;
    }

    .cardXcat-actions {
        padding-top: 6px;
    }
}

#catalogo-mapa {
    width: 100%;
    height: calc(100vh - 200px);
    min-height: 400px;
}
.map-popup {
    width: 200px;
    font-size: .8rem;
}

.map-popup img {
    width: 100%;
    height: 110px;
    object-fit: cover;
    border-radius: 6px;
}

.map-popup-body {
    padding-top: 6px;
}


/* badges fixas */
.cardx-badge-top {
    position:absolute;
    top:6px;
    left:6px;
    font-size:0.65rem;
    padding:3px 6px;
}
.cardx-badge-bottom {
    position:absolute;
    bottom:6px;
    left:6px;
    font-size:0.65rem;
    padding:3px 6px;
}