/* =========================================================
   MobyUP - correção da barra de filtros da página do mapa
   Mantém os filtros em linha no desktop e evita empurrar o mapa
   ========================================================= */

.up_map_page .up_container {
    width: min(1280px, calc(100% - 36px));
    margin: 0 auto;
}

.up_map_filterbar {
    background: #f5f9fc;
    border-bottom: 1px solid #e5edf5;
    padding: 10px 0 12px;
    position: relative;
    z-index: 20;
}

.up_map_filterbar .up_container {
    width: min(1460px, calc(100% - 40px));
}

/* Desktop: tudo na mesma linha, sem quebrar */
.up_map_filter_form {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    margin: 0 auto !important;
}

.up_map_filter_form .up_field {
    min-width: 0 !important;
    flex: 1 1 0 !important;
    height: 54px !important;
    margin: 0 !important;
    padding: 7px 13px 6px !important;
    border: 1px solid #d8e5f1 !important;
    background: #fff !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.up_map_filter_form .up_field span {
    display: block !important;
    margin: 0 0 3px !important;
    color: #65758a !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
}

.up_map_filter_form .up_field select,
.up_map_filter_form .up_field input {
    width: 100% !important;
    height: 24px !important;
    min-height: 24px !important;
    padding: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    color: #0d2a47 !important;
    font-size: 13px !important;
    line-height: 24px !important;
    font-weight: 800 !important;
    box-shadow: none !important;
    appearance: auto !important;
}

.up_map_filter_form .up_field input::placeholder {
    color: #5f7891 !important;
    font-weight: 500 !important;
}

/* Ajuste de larguras para caber em uma linha */
.up_map_filter_form .up_field:nth-of-type(1) { flex-basis: 135px !important; max-width: 150px !important; }
.up_map_filter_form .up_field:nth-of-type(2) { flex-basis: 150px !important; max-width: 175px !important; }
.up_map_filter_form .up_field:nth-of-type(3) { flex-basis: 155px !important; max-width: 185px !important; }
.up_map_filter_form .up_field:nth-of-type(4) { flex-basis: 130px !important; max-width: 145px !important; }
.up_map_filter_form .up_field:nth-of-type(5) { flex-basis: 140px !important; max-width: 155px !important; }
.up_map_filter_form .up_field:nth-of-type(6) { flex-basis: 110px !important; max-width: 125px !important; }
.up_map_filter_form .up_field:nth-of-type(7) { flex-basis: 135px !important; max-width: 150px !important; }
.up_map_filter_form .up_field:nth-of-type(8) { flex: 1.25 1 190px !important; max-width: 240px !important; }

.up_map_filter_actions {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
}

.up_map_filter_actions .up_btn_search {
    min-height: 46px !important;
    height: 46px !important;
    padding: 0 20px !important;
    border: 0 !important;
    border-radius: 14px !important;
    background: linear-gradient(135deg, #16c2f3, #0e86d8) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
    box-shadow: 0 10px 22px rgba(14,134,216,.18) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    text-decoration: none !important;
}

.up_map_filter_actions .up_aux_link {
    min-height: 46px !important;
    height: 46px !important;
    padding: 0 18px !important;
    border: 1px solid #d8e5f1 !important;
    border-radius: 14px !important;
    background: #fff !important;
    color: #0d2a47 !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.up_map_topbar {
    background: #fff;
    border-bottom: 1px solid #e5edf5;
    padding: 14px 0;
}

.up_map_topbar_inner_clean {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
}

.up_map_location_title {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.up_map_location_icon {
    width: 42px !important;
    height: 42px !important;
    border-radius: 14px !important;
    background: #eef8fd !important;
    color: #0e86d8 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.up_map_location_title h1 {
    margin: 0 !important;
    color: #0d2a47 !important;
    font-size: 28px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
}

.up_map_live_count {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 42px !important;
    padding: 0 18px !important;
    border: 1px solid #d8e5f1 !important;
    border-radius: 999px !important;
    background: #f8fbfe !important;
    color: #5a6b7d !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
}

/* Telas médias: mantém linha única, compactando mais */
@media (max-width: 1280px) {
    .up_map_filterbar .up_container {
        width: min(100% - 24px, 100%);
    }

    .up_map_filter_form {
        gap: 7px !important;
    }

    .up_map_filter_form .up_field {
        padding-left: 10px !important;
        padding-right: 10px !important;
        height: 50px !important;
    }

    .up_map_filter_form .up_field span {
        font-size: 10px !important;
    }

    .up_map_filter_form .up_field select,
    .up_map_filter_form .up_field input {
        font-size: 12px !important;
    }

    .up_map_filter_actions .up_btn_search,
    .up_map_filter_actions .up_aux_link {
        height: 42px !important;
        min-height: 42px !important;
        padding-left: 13px !important;
        padding-right: 13px !important;
        font-size: 12px !important;
    }
}

/* Mobile/tablet: vira trilho horizontal, sem quebrar vertical gigante */
@media (max-width: 980px) {
    .up_map_filterbar {
        padding: 9px 0;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .up_map_filter_form {
        width: max-content !important;
        min-width: 980px !important;
        padding-bottom: 4px !important;
    }

    .up_map_filter_form .up_field {
        flex: 0 0 140px !important;
        max-width: 170px !important;
    }

    .up_map_filter_form .up_field:nth-of-type(8) {
        flex-basis: 210px !important;
        max-width: 240px !important;
    }

    .up_map_topbar_inner_clean {
        align-items: flex-start !important;
        flex-direction: column !important;
    }
}

/* Mobile pequeno: topbar mais compacta */
@media (max-width: 640px) {
    .up_map_page .up_container,
    .up_map_filterbar .up_container {
        width: calc(100% - 20px);
    }

    .up_map_location_title h1 {
        font-size: 23px !important;
    }
}


/* =========================================================
   Página do mapa usando header oficial global
   Remove dependência do header escuro antigo desta tela
   ========================================================= */

.up_map_page {
    margin-top: 0 !important;
}

.up_map_page_airbnb {
    padding-top: 0 !important;
}

/* Garante que a barra de filtros venha logo abaixo do header oficial */
.up_header_global + .up_map_page .up_map_filterbar,
.up_header_viva + .up_map_page .up_map_filterbar {
    margin-top: 0 !important;
}

/* Segurança contra estilos antigos de .up_header dentro do mapa */
.up_page > .up_header:not(.up_header_global):not(.up_header_viva) {
    display: none !important;
}
