/*******************************************************
* Escolher qual o slider de cartões a mostrar, de
* acordo com as dimensões do ecrã.
*
* (Nos sliders de cards na página inicial)
*******************************************************/
.slide-imoveis-desktop { display: block; }
.slide-imoveis-tablet { display: none; }
.slide-imoveis-phone { display: none; }
@media (max-width:1250px) {
    .slide-imoveis-desktop { display: none; }
    .slide-imoveis-tablet { display: block; }
}
@media (max-width:850px) {
    .slide-imoveis-tablet { display: none; }
    .slide-imoveis-phone { display: block; }
}

/*******************************************************
* Controlos dos sliders de cartões.
*
* - Mostrar controlos de lado, nos sliders de desktop
*   e tablet.
* - Mostrar os controlos por baixo, no slider de phone.
*******************************************************/
.slide-imoveis-desktop .carousel-control,
.slide-imoveis-tablet .carousel-control { top: 300px; position: relative; }
.slide-imoveis-phone .carousel-control { display: inline-block; margin: 10px 60px; }
@media (max-width:450px) {
    .slide-imoveis-phone .carousel-control i { font-size: 2em !important; }
    .slide-imoveis-phone .carousel-control { margin: 15px 40px; }
}
@media (max-height:800px) {
    .slide-imoveis-desktop .carousel-control i { font-size: 3em !important; }
    .slide-imoveis-tablet .carousel-control i { font-size: 3em !important; }
}

/*******************************************************
* Formatação dos sliders/carousel.
*******************************************************/
.carousel-item { margin: auto; }

/* espaçamento do slider */
.cards-carousel { margin: 60px 0; }
@media (max-height:900px) {
    .cards-carousel { margin-top: 30px; }
}
@media (max-height:700px) {
    .cards-carousel { margin-top: 20px; }
}

/* indicadores (setas de próximo e anterior) */
.carousel-indicators { position: relative; bottom: 0; margin: 30px 20px; }
.carousel-indicators li { height: 20px; width: 20px; max-width: 20px; border-radius: 150px; margin: 5px; }
@media (max-height:845px) {
    .carousel-indicators { margin: 10px 20px; }
    .carousel-indicators li { height: 15px; width: 15px; max-width: 15px; margin: 4px; }
}
@media (max-width:850px) {
    .carousel-indicators { display: none; }
}

/* cartões da mesma altura dentro dos sliders */
.carousel-inner>.row-equal.active,
.carousel-inner>.row-equal.next,
.carousel-inner>.row-equal.prev { display: flex; }

/* prevenir 'flickers' durante a transição */
.carousel-inner>.row-equal.active.left,
.carousel-inner>.row-equal.active.right { opacity: 0.5; display: flex; }

/*******************************************************
* Responsividade dos Sliders
*******************************************************/

/* responsividade do slider em desktop */
@media (max-width:1600px) {
    .slide-imoveis-desktop .card-wrapper { margin-left: 25px; }
    .slide-imoveis-desktop .card-block { padding: 25px 25px 10px 25px; }
    .slide-imoveis-desktop .card-icon-container { padding-top: 10px; }
    .slide-imoveis-desktop .card-photo { height: 220px; }
    .slide-imoveis-desktop .card-price { font-size: 18px; }
    .slide-imoveis-desktop .card-title { font-size: 22px; }
    .slide-imoveis-desktop .card-location,
    .slide-imoveis-desktop .card-ref { font-size: 16px; }
    .slide-imoveis-desktop .card-fav { font-size: 26px; }
    .slide-imoveis-desktop .card-icon { width: 25px; height: auto; margin-right: 6px; font-size: 22px; }
    
    .slide-imoveis-desktop .card-icon.cert-energetico-icon { height: 28px; width: 31px; margin-right: 6px; }

    .slide-imoveis-desktop .card-icon-info-not-available { font-size: 13px; }

    /* flags */
    .slide-imoveis-desktop .card-top-flag,
    .slide-imoveis-desktop .card-bottom-flag { min-width: 150px; padding: 5px 30px; left: -20px; font-size: 16px; }
}
@media (max-width:1400px) {
    .slide-imoveis-desktop .card-icon { margin-right: 0; }
    /*.slide-imoveis-desktop .card .icon-part-text { font-size: 14px; }*/
    .slide-imoveis-desktop .card-icon-info-not-available { font-size: 10.5px !important; }
}
@media (max-width:1300px) {
    .slide-imoveis-desktop .card-block { padding: 20px 17px 5px 17px; }
}

/* responsividade do slider em tablet */
@media (max-width:1100px) {
    .slide-imoveis-tablet .card-wrapper { margin-left: 25px; }
    .slide-imoveis-tablet .card-block { padding: 20px 25px 10px 25px; }
    .slide-imoveis-tablet .card-ref-fav-container { padding-top: 20px; padding-bottom: 30px; }
    .slide-imoveis-tablet .card-icon-container { padding-top: 10px; }
    .slide-imoveis-tablet .card-photo { height: 220px; }
    .slide-imoveis-tablet .card-price { font-size: 18px; }
    .slide-imoveis-tablet .card-title { font-size: 22px; }
    .slide-imoveis-tablet .card-location,
    .slide-imoveis-tablet .card-ref { font-size: 16px; }
    /*.slide-imoveis-tablet .card-fav { font-size: 26px; }*/
    .slide-imoveis-tablet .card-icon { width: 25px; margin-right: 6px; font-size: 22px; }
    .slide-imoveis-tablet .card-icon-info-not-available { font-size: 13px; }

    /* flags */
    .slide-imoveis--tablet .card-top-flag,
    .slide-imoveis--tablet .card-bottom-flag { min-width: 150px; padding: 5px 30px; left: -20px; font-size: 16px; }
}
@media (max-width:950px) {
    .slide-imoveis-tablet .card-icon { margin-right: 5px; }
    .slide-imoveis-tablet .card .icon-part-text { font-size: 14px; }
    .slide-imoveis-tablet .card-icon-info-not-available { font-size: 10.5px !important; }
}
@media (max-width:900px) {
    .slide-imoveis-tablet .card-block { padding: 20px 17px 5px 17px; }
    .slide-imoveis-tablet .card-photo { height: 200px; }
    .slide-imoveis-tablet .card-price { font-size: 16px; }
    .slide-imoveis-tablet .card-title { font-size: 20px; }
    .slide-imoveis-tablet .card-location,
    .slide-imoveis-tablet .card-ref { font-size: 14px; }
    /*.slide-imoveis-tablet .card-fav { font-size: 24px; }*/
}

/* telemoveis */
@media (max-width:450px) {
    .no-spacing-450 { margin: 0; padding: 0; }
    .slide-imoveis-phone .card-container { padding: 0 5px; margin: 5px 0; }
    .slide-imoveis-phone .card-wrapper { margin-left: 25px; margin-right: 25px; }
}

/*******************************************************
* Filtros do slider de 'Imóveis Recentes'
*******************************************************/
.slider-filtering * { -webkit-transition: all 2.5s ease; -moz-transition: all 2.5s ease; -ms-transition: all 2.5s ease; -o-transition: all 2.5s ease; transition: all 2.5s ease; }
.slider-filtering { font-size: 24px; margin-top: 60px; margin-bottom: -30px; }
.slider-filtering li { display: inline-block; margin-top: 5px; margin-bottom: 5px; }
.slider-filtering a { color: #494949; padding-left: 0; padding-right: 0; margin-left: 24px; margin-right: 24px; }
.slider-filtering a:hover { text-decoration: none; }
@media (max-height:900px) {
    .slider-filtering { font-size: 20px; margin-top: 30px; margin-bottom: -20px; }
}
@media (max-width:1400px) {
    .slider-filtering { font-size: 17px; }
}
@media (max-width:1300px) {
    .slider-filtering { font-size: 16px; }
}
@media (max-width:800px) {
    .slider-filtering li { display: block; padding-bottom: 15px; }
}




/* carousel indicators */
.carousel-indicators li { background-color: transparent; border: 1px solid; }
.carousel-indicators { margin: 10px 20px; }
.slider-filtering a.active { border-bottom: 1px solid; }

@media (max-width: 850px) {
    /* imoveis recentes, imoveis destacados */
    h2.centered-section-heading {
        margin-bottom: 10px;
        margin-top: 10px;
    }
}

.slide-imoveis-phone .card-wrapper {
    margin-left: 35px;
    margin-right: 35px;
    width: 100%;
}



/* mostrar carousel de acordo com a categoria escolhida */
.cat-carousel-container { display: none; }
.cat-carousel-container.active { display: block; }



.slide-imoveis-phone .card-imovel .card-block {
    padding: 10px 10px;
}




/* manter o ratio da foto do imovel
width: 1100px;
height: 800px;*/

/* desktop */
@media (min-width: 1650px) {
    .slide-imoveis-desktop .card { max-width: 345px }
    .slide-imoveis-desktop .card-photo { height: 251px }
}
@media (min-width: 1420px) and (max-width: 1650px) {
    .slide-imoveis-desktop .card { max-width: 300px }
    .slide-imoveis-desktop .card-photo { height: 218px }
}
@media (min-width: 1250px) and (max-width: 1420px) {
    .slide-imoveis-desktop .card { max-width: 270px }
    .slide-imoveis-desktop .card-photo { height: 196px }
}
/* tablet */
@media (min-width: 1050px) and (max-width: 1250px) {
    .slide-imoveis-tablet .card { max-width: 340px }
    .slide-imoveis-tablet .card-photo { height: 247px }
}
@media (min-width: 950px) and (max-width: 1050px) {
    .slide-imoveis-tablet .card { max-width: 310px }
    .slide-imoveis-tablet .card-photo { height: 225px }
}
@media (min-width: 850px) and (max-width: 950px) {
    .slide-imoveis-tablet .card { max-width: 255px }
    .slide-imoveis-tablet .card-photo { height: 185px }
}
/* phone */
@media (min-width: 650px) and (max-width: 850px) {
    .slide-imoveis-phone .card { max-width: 345px }
    .slide-imoveis-phone .card-photo { height: 251px }
}
@media (min-width: 420px) and (max-width: 650px) {
    .slide-imoveis-phone .card { max-width: 305px }
    .slide-imoveis-phone .card-photo { height: 222px }
}
@media (min-width: 360px) and (max-width: 420px) {
    .slide-imoveis-phone .card { max-width: 245px }
    .slide-imoveis-phone .card-photo { height: 178px }
}
@media (min-width: 340px) and (max-width: 360px) {
    .slide-imoveis-phone .card { max-width: 230px }
    .slide-imoveis-phone .card-photo { height: 166px }
}
@media (min-width: 320px) and (max-width: 340px) {
    .slide-imoveis-phone .card { max-width: 240px }
    .slide-imoveis-phone .card-photo { height: 175px }
}

/* espaço por causa da sombra das areas destacadas na foto do card
(sombra fica cortada sem uma margem) */
.slide-imoveis-desktop.carousel .card-wrapper { margin-left: 25px; }













.slide-imoveis-desktop .card { min-height: 602px }
@media (min-width: 1420px) and (max-width: 1650px) {
    .slide-imoveis-desktop .card { min-height: 569px }
}
@media (max-width: 1420px) {
    .slide-imoveis-desktop .card { min-height: 536px }
}
@media (max-width: 1300px) {
    .slide-imoveis-desktop .card { min-height: 526px }
}

@media (max-height: 845px) {
    .slide-imoveis-desktop .card { min-height: 500px }
}



.slide-imoveis-tablet .card { min-height: 550px }
@media (max-width: 1100px) {
    .slide-imoveis-tablet .card { min-height: 591px }
}
@media (max-width: 1050px) {
    .slide-imoveis-tablet .card { min-height: 569px }
}
@media (max-width: 991px) {
    .slide-imoveis-tablet .card { min-height: 619px }
}
@media (max-width: 950px) {
    .slide-imoveis-tablet .card { min-height: 577px }
}
@media (max-width: 900px) {
    .slide-imoveis-tablet .card { min-height: 567px }
}

@media (max-height: 845px) {
    .slide-imoveis-tablet .card { min-height: 500px }
}

.slide-imoveis-phone .card { min-height: 588px }
@media (max-width: 650px) {
    .slide-imoveis-phone .card { min-height: 557px }
}
@media (max-width: 450px) {
    .slide-imoveis-phone .card { min-height: 555px }
}
@media (max-width: 420px) {
    .slide-imoveis-phone .card { min-height: 517px }
}
@media (max-width: 360px) {
    .slide-imoveis-phone .card { min-height: 500px }
}



@media (max-height: 845px) {
    .slide-imoveis-phone .card { min-height: 540px }
}
@media (max-width: 650px) and (max-height: 845px) {
    .slide-imoveis-phone .card { min-height: 510px }
}
@media (max-width: 450px) and (max-height: 845px) {
    .slide-imoveis-phone .card { min-height: 508px }
}
@media (max-width: 420px) and (max-height: 850px) {
    .slide-imoveis-phone .card { min-height: 465px }
}
@media (max-width: 360px) and (max-height: 845px) {
    .slide-imoveis-phone .card { min-height: 450px }
}
@media (max-width: 320px) and (max-height: 845px) {
    .slide-imoveis-phone .card { min-height: 455px }
}


@media (max-width: 470px) {
    .icon-part-text { font-size: 14px !important; }
}
@media (max-width: 400px) {
    .icon-part-text { font-size: 13px !important; }
}
@media (max-width: 330px) {
    .slide-imoveis-phone .card-imovel .card-block { padding-bottom: 5px; }
    .slide-imoveis-phone .card-imovel .card-icon-container > div { margin-bottom: -35px; }
}

.slide-imoveis-phone .card-title,
.slide-imoveis-phone .card-location { -webkit-line-clamp: 1; }