/*******************************************************
* 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: 10px !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: 10px !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 }
