html {
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-text-size-adjust: 100%
}

html.height-100 {
    height: 100%
}

body {
    position: relative;
    text-rendering: optimizeLegibility;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0)
}

.height-100 body {
    height: 100%
}

body.no-scroll {
    overflow-y: hidden
}

*,
*:before,
*:after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit
}

@font-face {
    font-family: "Prelom";
    src: url(fonts/prelom_250_regular-webfont.woff2) format("woff2"), url(fonts/prelom_250_regular-webfont.woff) format("woff");
    font-weight: 400;
    font-style: normal;
    font-stretch: normal
}

@font-face {
    font-family: "Basis Grotesque";
    src: url(fonts/BasisGrotesqueLight.woff2) format("woff2"), url(fonts/BasisGrotesqueLight.woff) format("woff");
    font-weight: 300;
    font-style: normal;
    font-stretch: normal
}

@font-face {
    font-family: "Basis Grotesque";
    src: url(fonts/BasisGrotesqueRegular.woff2) format("woff2"), url(fonts/BasisGrotesqueRegular.woff) format("woff");
    font-weight: 400;
    font-style: normal;
    font-stretch: normal
}

@font-face {
    font-family: "Basis Grotesque";
    src: url(fonts/BasisGrotesqueItalic.woff2) format("woff2"), url(fonts/BasisGrotesqueItalic.woff) format("woff");
    font-weight: 400;
    font-style: italic;
    font-stretch: normal
}

@font-face {
    font-family: "Basis Grotesque";
    src: url(fonts/BasisGrotesqueMedium.woff2) format("woff2"), url(fonts/BasisGrotesqueMedium.woff) format("woff");
    font-weight: 500;
    font-style: normal;
    font-stretch: normal
}

@font-face {
    font-family: "Basis Grotesque";
    src: url(fonts/BasisGrotesqueBold.woff2) format("woff2"), url(fonts/BasisGrotesqueBold.woff) format("woff");
    font-weight: 700;
    font-style: normal;
    font-stretch: normal
}

@font-face {
    font-family: "Basis Grotesque";
    src: url(fonts/BasisGrotesqueBlack.woff2) format("woff2"), url(fonts/BasisGrotesqueBlack.woff) format("woff");
    font-weight: 900;
    font-style: normal;
    font-stretch: normal
}

@font-face {
    font-family: "Font Awesome 6 Free";
    src: url(fonts/fa-solid-900.woff2) format("woff2");
    font-weight: 900;
    font-style: normal
}

.app {
    position: relative;
    width: 100%;
    padding-top: 119px;
    background-color: #fff
}

.height-100 .app {
    height: 100%
}

@media only screen and (max-width: 1024px) {
    .app {
        padding-top: 120px
    }
}

@media only screen and (max-width: 640px) {
    .app {
        padding-top: 100px
    }
}

.section {
    position: relative;
    width: 100%
}

.column {
    padding-right: 40px;
    padding-left: 40px
}

@media only screen and (max-width: 768px) {
    .column {
        padding-right: 30px;
        padding-left: 30px
    }
}

@media only screen and (max-width: 640px) {
    .column {
        padding-right: 20px;
        padding-left: 20px
    }
}

.column-1,
.column-1b,
.column-1c,
.column-2,
.column-2b,
.column-3,
.column-4,
.column-5,
.column-6,
.column-7 {
    position: relative;
    width: 100%;
    margin-right: auto;
    margin-left: auto
}

.column-1 {
    max-width: 470px
}

.column-1b {
    max-width: 550px
}

.column-1c {
    max-width: 630px
}

.column-2 {
    max-width: 675px
}

.section-intro .column-2 p {
    position: relative;
    width: 100%;
    max-width: 520px;
    margin-right: auto;
    margin-left: auto
}

.column-2b {
    max-width: 950px
}

.column-3 {
    max-width: 1045px
}

.column-4 {
    max-width: 1200px
}

.column-5 {
    max-width: 1220px
}

.column-6 {
    max-width: 1560px
}

.column-7 {
    max-width: 1920px
}

.img-blk img {
    display: block;
    width: 100%;
    height: auto
}

.img-inl img {
    display: inline-block;
    max-width: 100%;
    height: auto
}

.the-content .column-2 img {
    max-width: 100%;
    height: auto
}

.img-svg {
    position: relative
}

.img-svg img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.bk-b {
    background-color: #f8f6f1
}

.is-mobile,
.img-blk .is-mobile {
    display: none
}

@media only screen and (max-width: 640px) {

    .is-desktop,
    .img-blk .is-desktop {
        display: none
    }

    .is-mobile,
    .img-blk .is-mobile {
        display: block
    }
}

.section-video {
    overflow: hidden
}

.section-video .hero-video {
    position: relative;
    z-index: 0;
    width: 100%;
    padding-bottom: 41.875%;
    overflow: hidden
}

.section-video .video-abs {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.section-video .video-abs .video {
    position: relative;
    padding-bottom: 56.25%
}

.section-video iframe,
.section-video .poster {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.section-video .video-controls {
    position: absolute;
    left: 30px;
    bottom: 30px
}

.section-video .video-controls span {
    display: inline-block;
    cursor: pointer
}

.section-video .video-controls span:first-child {
    width: 12px;
    margin-right: 10px
}

.section-video .video-controls span.fa-pause:before {
    content: "ïŒ"
}

.section-video .video-controls span.fa-volume-off:before {
    content: "ï€¦"
}

.section-video .video-controls.paused span.fa-pause:before {
    content: "ï‹"
}

.section-video .video-controls.unmuted span.fa-volume-off:before {
    content: "ï€¨"
}

.section-video .poster {
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat;
    pointer-events: none
}

@media only screen and (max-width: 640px) {
    .section-video .hero-video {
        padding-bottom: 120%
    }

    .section-video .video-controls {
        left: 15px;
        bottom: 10px
    }
}

.section-hero .img-blk {
    position: relative;
    padding-bottom: 41.875%;
    overflow: hidden
}

.section-hero .img-blk img {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -webkit-transform: translatey(-50%);
    transform: translatey(-50%)
}

.home-video-logo {
    display: none
}

.page-template-page-home .home-video-logo {
    display: block;
    position: absolute;
    z-index: 1;
    top: 50%;
    left: 50%;
    width: 30%;
    max-width: 430px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

@media only screen and (max-width: 640px) {
    .page-template-page-home .home-video-logo {
        width: 50%
    }
}

.section-parallax-1 .images {
    position: relative;
    padding-right: 100px;
    padding-bottom: 60px;
    padding-left: 130px
}

.section-parallax-1 .images .image-1 {
    position: relative;
    z-index: 1
}

.section-parallax-1 .images .image-1 .has-image {
    position: relative;
    padding-bottom: 61.1924686192%;
    overflow: hidden
}

.section-parallax-1 .images .image-1 .has-image .image {
    position: absolute;
    top: 0;
    Left: 0;
    width: 100%;
    height: auto
}

.section-parallax-1 .images .image-2 {
    position: absolute;
    z-index: 2;
    top: 28%;
    left: 0;
    width: 22.5%
}

.section-parallax-1 .images .image-3 {
    position: absolute;
    z-index: 0;
    bottom: -2%;
    left: 4.1666666%;
    width: 36%
}

.section-parallax-1 .images .image-4 {
    position: absolute;
    z-index: 0;
    top: 15%;
    right: 0;
    width: 20%
}

.section-parallax-1 .text {
    padding-right: 100px;
    padding-left: 130px
}

.section-parallax-1 .text .column-1 {
    margin-right: 50px
}

@media only screen and (max-width: 1200px) {
    .section-parallax-1 .text .column-1 {
        margin-right: 0
    }
}

@media only screen and (max-width: 768px) {
    .section-parallax-1 .images .image-2 {
        top: 33%
    }

    .section-parallax-1 .images .image-3 {
        bottom: -7%
    }

    .section-parallax-1 .images .image-4 {
        top: 20%
    }
}

@media only screen and (max-width: 640px) {
    .section-parallax-1 .images {
        position: relative;
        padding-right: 0;
        padding-bottom: 30px;
        padding-left: 0
    }

    .section-parallax-1 .images .image-2,
    .section-parallax-1 .images .image-3,
    .section-parallax-1 .images .image-4 {
        display: none
    }

    .section-parallax-1 .text {
        padding-right: 0;
        padding-left: 0
    }

    .section-parallax-1 .text .column-1 {
        margin-right: auto
    }
}

.page-template-page-location .section-parallax-1 .images .image-1 .has-image,
.page-template-page-experiences .section-parallax-1 .images .image-1 .has-image,
.page-template-page-fundacion .section-parallax-1 .images .image-1 .has-image {
    padding-bottom: 57%
}

.section-parallax-2 .images {
    position: relative;
    padding-top: 125px;
    padding-right: 90px;
    padding-bottom: 130px;
    padding-left: 90px
}

.section-parallax-2 .images .image-1 {
    position: relative;
    z-index: 1
}

.section-parallax-2 .images .image-1 .has-image {
    position: relative;
    padding-bottom: 49.6296296296%;
    overflow: hidden
}

.section-parallax-2 .images .image-1 .has-image .image {
    position: absolute;
    top: 0;
    Left: 0;
    width: 100%;
    height: auto
}

.section-parallax-2 .images .image-2 {
    position: absolute;
    z-index: 2;
    bottom: 0;
    left: 0;
    width: 36%
}

.section-parallax-2 .images .image-3 {
    position: absolute;
    z-index: 2;
    bottom: 5%;
    right: 0;
    width: 20%
}

.section-parallax-2 .images .image-4 {
    position: absolute;
    z-index: 0;
    top: 10%;
    right: 3%;
    width: 31%
}

.section-parallax-2 .text {
    padding-right: 90px;
    padding-left: 90px
}

.section-parallax-2 .text .column-1b {
    margin-right: 50px
}

@media only screen and (max-width: 1200px) {
    .section-parallax-2 .text .column-1b {
        margin-right: 0
    }
}

@media only screen and (max-width: 768px) {
    .section-parallax-2 .images .image-4 {
        top: 25%
    }
}

@media only screen and (max-width: 640px) {
    .section-parallax-2 .images {
        position: relative;
        padding-top: 50px;
        padding-right: 0;
        padding-bottom: 30px;
        padding-left: 0
    }

    .section-parallax-2 .images .image-2,
    .section-parallax-2 .images .image-3,
    .section-parallax-2 .images .image-4 {
        display: none
    }

    .section-parallax-2 .text {
        padding-right: 0;
        padding-left: 0
    }

    .section-parallax-2 .text .column-1b {
        margin-right: auto
    }
}

.page-template-page-location .images .image-4 {
    z-index: 1
}

.page-template-page-experiences .images .image-3,
.page-template-page-experiences .images .image-4,
.page-template-page-fundacion .images .image-3,
.page-template-page-fundacion .images .image-4 {
    z-index: 1
}

.page-template-page-experiences .section-parallax-2 .images,
.page-template-page-fundacion .section-parallax-2 .images {
    padding-top: 0
}

.flex.has-cols {
    margin-right: -10px;
    margin-left: -10px
}

.flex.has-cols .col-4,
.flex.has-cols .col-6 {
    padding-right: 10px;
    padding-left: 10px
}

.flex.has-cols .col-6 .text {
    padding-top: 40px;
    padding-right: 40px;
    padding-left: 40px
}

.flex.has-cols .col-4 .text {
    padding-top: 40px;
    padding-right: 20px;
    padding-left: 20px
}

@media only screen and (max-width: 1024px) {

    .flex.has-cols .col-4:not(:last-child),
    .flex.has-cols .col-6:not(:last-child) {
        margin-bottom: 75px
    }

    .flex.has-cols .col-4 .text,
    .flex.has-cols .col-6 .text {
        width: 100%;
        max-width: 570px;
        margin-right: auto;
        margin-left: auto;
        padding-right: 0;
        padding-left: 0
    }
}

@media only screen and (max-width: 640px) {

    .flex.has-cols .col-4:not(:last-child),
    .flex.has-cols .col-6:not(:last-child) {
        margin-bottom: 50px
    }
}

.section-standard.has-rows .flex.has-cols .col-4,
.section-standard.has-rows .flex.has-cols .col-6 {
    margin-bottom: 75px
}

@media only screen and (max-width: 640px) {

    .section-standard.has-rows .flex.has-cols .col-4,
    .section-standard.has-rows .flex.has-cols .col-6 {
        margin-bottom: 50px
    }
}

.section-standard.has-faq {
    padding-bottom: 75px
}

.section-standard.has-faq .flex.has-cols .col-4,
.section-standard.has-faq .flex.has-cols .col-6 {
    margin-bottom: 75px
}

@media only screen and (max-width: 990px) {
    .section-standard.has-faq {
        padding-bottom: 25px
    }
}

@media only screen and (max-width: 1024px) {
    .section-standard.has-faq {
        padding-bottom: 100px
    }

    .section-standard.has-faq .flex.has-cols .col-4,
    .section-standard.has-faq .flex.has-cols .col-6 {
        margin-bottom: 0
    }

    .section-standard.has-faq .flex.has-cols .col-4:not(:last-child),
    .section-standard.has-faq .flex.has-cols .col-6:not(:last-child) {
        margin-bottom: 75px
    }
}

@media only screen and (max-width: 768px) {
    .section-standard.has-faq {
        padding-bottom: 75px
    }
}

@media only screen and (max-width: 640px) {
    .section-standard.has-faq {
        padding-bottom: 50px
    }

    .section-standard.has-faq .flex.has-cols .col-4:not(:last-child),
    .section-standard.has-faq .flex.has-cols .col-6:not(:last-child) {
        margin-bottom: 50px
    }
}

.section-quote {
    padding-top: 120px;
    padding-bottom: 110px;
    background-position: 50% 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: url(images/production/wp-content/themes/costapalmas/src/images/graphics/AdobeStock_356682085.jpg)
}

@media only screen and (max-width: 640px) {
    .section-quote {
        padding-top: 75px;
        padding-bottom: 75px
    }
}

.cards-image {
    margin-right: -12px;
    margin-left: -12px
}

.cards-image .col-4 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 24px;
    padding-right: 12px;
    padding-left: 12px
}

.cards-image .card {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    border-radius: 50px;
    overflow: hidden
}

.cards-image .image {
    padding-bottom: 83.3333333333%;
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat
}

.cards-image .text {
    padding-top: 50px;
    padding-right: 50px;
    padding-bottom: 50px;
    padding-left: 50px
}

.cards-image .text.is-flex {
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 0;
    -ms-flex: 1 1 0px;
    flex: 1 1 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
}

.cards-image .text.is-flex p:last-child {
    margin-top: auto
}

@media only screen and (max-width: 1200px) {
    .cards-image .text {
        padding-right: 30px;
        padding-left: 30px
    }
}

@media only screen and (max-width: 1024px) {
    .cards-image .text {
        padding-right: 50px;
        padding-left: 50px
    }
}

@media only screen and (max-width: 900px) {
    .cards-image .text {
        padding-right: 30px;
        padding-left: 30px
    }
}

@media only screen and (max-width: 640px) {
    .cards-image .col-4 {
        margin-bottom: 0;
        display: block
    }

    .cards-image .col-4:not(:last-child) {
        margin-bottom: 24px
    }
}

.alternating-rows {
    position: relative
}

.alternating-rows:before {
    content: "";
    display: block;
    position: absolute;
    z-index: 9;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 1px;
    background-color: #4d2a15
}

.alternating-rows .flex {
    border-bottom: 1px solid #4d2a15
}

.alternating-rows .flex:first-child {
    border-top: 1px solid #4d2a15
}

.alternating-rows .flex:nth-child(2n) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

.alternating-rows .has-image,
.alternating-rows .has-tileimage {
    -webkit-align-self: center;
    -ms-flex-item-align: center;
    align-self: center;
    padding-top: 75px;
    padding-right: 75px;
    padding-bottom: 75px;
    padding-left: 75px
}

.alternating-rows .has-fullimage {
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat
}

.alternating-rows .has-fullimage .img-blk {
    padding-bottom: 64.75% img;
    padding-bottom-display: none
}

.alternating-rows .has-text {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding-top: 75px;
    padding-right: 40px;
    padding-bottom: 75px;
    padding-left: 40px;
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat
}

.alternating-rows .has-text.has-marble {
    background-image: url(images/production/wp-content/themes/costapalmas/src/images/graphics/texture-marble.jpg)
}

.alternating-rows .has-text.has-sand {
    background-image: url(images/production/wp-content/themes/costapalmas/src/images/graphics/texture-sand.jpg)
}

.alternating-rows .text {
    -webkit-align-self: center;
    -ms-flex-item-align: center;
    align-self: center;
    width: 100%;
    max-width: 520px;
    margin-right: auto;
    margin-left: auto
}

@media only screen and (max-width: 1024px) {
    .alternating-rows:before {
        content: none
    }

    .alternating-rows .flex:nth-child(2n) {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row
    }

    .alternating-rows .has-image,
    .alternating-rows .has-tileimage {
        padding-top: 50px;
        padding-right: 50px;
        padding-bottom: 0;
        padding-left: 50px
    }
}

@media only screen and (max-width: 640px) {

    .alternating-rows .has-image,
    .alternating-rows .has-tileimage {
        padding-top: 20px;
        padding-right: 20px;
        padding-left: 20px
    }

    .alternating-rows .has-text {
        padding-top: 50px;
        padding-right: 20px;
        padding-bottom: 50px;
        padding-left: 20px
    }

    .alternating-rows .text {
        max-width: 100%
    }
}

@media only screen and (max-width: 1024px) {
    .section-standard.has-rows .tiles-101-things .flex.has-cols .col-4:last-child {
        margin-bottom: 0
    }
}

.list-101-things {
    position: relative;
    max-height: 0;
    overflow: hidden;
    -webkit-transition: max-height 1s linear;
    transition: max-height 1s linear
}

.list-101-things ol {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 50px;
    border-top: 1px solid #4d2a15;
    border-right: 1px solid #4d2a15;
    border-bottom: 1px solid #4d2a15;
    border-left: 1px solid #4d2a15;
    counter-reset: pois 9
}

.list-101-things ol:before {
    content: "";
    display: block;
    position: absolute;
    z-index: 9;
    top: 0;
    bottom: 0;
    left: 33.333333%;
    width: 1px;
    background-color: #4d2a15
}

.list-101-things ol:after {
    content: "";
    display: block;
    position: absolute;
    z-index: 9;
    top: 0;
    bottom: 0;
    right: 33.333333%;
    width: 1px;
    background-color: #4d2a15
}

.list-101-things ol li {
    width: 33.333333%;
    padding-top: 40px;
    padding-right: 20px;
    padding-bottom: 40px;
    padding-left: 20px;
    counter-increment: pois
}

.list-101-things ol li:not(:last-child):not(:nth-last-child(2)) {
    border-bottom: 1px solid #4d2a15
}

.list-101-things ol li:before {
    content: counter(pois, decimal-leading-zero);
    display: block;
    margin-bottom: 15px;
    color: #1b2a33;
    font-weight: 500;
    font-size: 14px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase
}

@media only screen and (max-width: 1024px) {
    .list-101-things ol {
        margin-top: 75px
    }

    .list-101-things ol:before {
        left: 50%
    }

    .list-101-things ol:after {
        content: none
    }

    .list-101-things ol li {
        width: 50%
    }
}

@media only screen and (max-width: 640px) {
    .list-101-things ol {
        margin-top: 50px
    }

    .list-101-things ol:before {
        content: none
    }

    .list-101-things ol:after {
        content: none
    }

    .list-101-things ol li {
        width: 100%
    }

    .list-101-things ol li:not(:last-child) {
        border-bottom: 1px solid #4d2a15
    }
}

.section-tile-gallery {
    overflow: hidden
}

.section-tile-gallery .tile-gallery-nav {
    position: relative;
    overflow: hidden
}

.section-tile-gallery .tile-gallery {
    width: 139.375%;
    -webkit-transform: translateX(-25%);
    transform: translateX(-25%)
}

.section-tile-gallery .tile-gallery .img-blk {
    width: 33.3333%;
    padding-right: 10px;
    padding-left: 10px
}

.section-tile-gallery .tile-gallery .img-blk .link {
    margin-top: 30px
}

.section-tile-gallery .text {
    width: 139.375%;
    -webkit-transform: translateX(-25%);
    transform: translateX(-25%)
}

.section-tile-gallery .column-1c {
    margin-left: calc(33.3333% + 10px)
}

@media only screen and (max-width: 768px) {
    .section-tile-gallery .tile-gallery .img-blk .link {
        margin-top: 10px
    }

    .section-tile-gallery .text {
        width: 100%;
        padding-right: 20px;
        padding-left: 20px;
        -webkit-transform: translateX(0%);
        transform: translateX(0%)
    }

    .section-tile-gallery .column-1c {
        margin-left: auto
    }
}

@media only screen and (max-width: 640px) {
    .section-tile-gallery .tile-gallery {
        /* margin-left: calc(-50% + 10px); */
        margin: 0 auto;
        width: 200%;
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    .section-tile-gallery .tile-gallery .img-blk {
        width: 50%
    }
}

.highlight {
    position: absolute;
    width: 31px;
    height: 31px;
    background-color: #4d2a15;
    border-radius: 100%;
    cursor: pointer;
    -webkit-transition: background-color .2s linear;
    transition: background-color .2s linear
}

.highlight:before,
.highlight:after {
    content: "";
    display: block;
    position: absolute;
    z-index: 1;
    top: 15px;
    left: 11px;
    width: 9px;
    height: 1px;
    background-color: #fff
}

.highlight:after {
    opacity: 1;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    -webkit-transition: opacity .2s linear;
    transition: opacity .2s linear
}

.highlight.close:before {
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg)
}

.highlight.close:after {
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg)
}

.highlight .hover {
    opacity: 0;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: 31px;
    height: 31px;
    border-radius: 100%;
    pointer-events: none;
    -webkit-transition: opacity .2s linear;
    transition: opacity .2s linear
}

.highlight .hover:before {
    content: "";
    opacity: .55;
    display: block;
    position: absolute;
    z-index: 1;
    top: -17px;
    left: -17px;
    width: 65px;
    height: 65px;
    border-radius: 100%;
    background-color: #fdfcfb
}

.highlight .hover:after {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: 31px;
    height: 31px;
    border-radius: 100%;
    border: 2px solid #4d2a15
}

.highlight.is-active {
    background-color: #f8f6f1
}

.highlight.is-active:before {
    background-color: #4d2a15
}

.highlight.is-active:after {
    opacity: 0
}

.highlight.is-active .hover {
    opacity: 1
}

.draggable {
    position: relative;
    overflow: hidden;
    z-index: 0
}

.draggable .drag {
    position: relative
}

@media only screen and (max-width: 640px) {
    .draggable .drag {
        width: 750px
    }
}

@media only screen and (max-width: 1250px) {
    .masterplan-map.draggable .drag {
        width: 1250px
    }
}

.page-template-page-home .section-featured-listing,
.page-template-page-real-estate .section-featured-listing,
.page-template-page-getting-here .section-featured-listing {
    background-color: #fff
}

.page-id-107 .section-featured-listing,
.page-id-109 .section-featured-listing {
    border-top: 1px solid #4d2a15
}

.featured-listing {
    padding-top: 50px;
    padding-right: 50px;
    padding-bottom: 50px;
    padding-left: 50px;
    border: 1px solid #4d2a15
}

.featured-listing .has-text {
    padding-top: 40px;
    padding-right: 40px;
    padding-bottom: 40px;
    padding-left: 90px
}

.featured-listing .has-text h2 {
    margin-bottom: 5px
}

.featured-listing .has-text span {
    white-space: nowrap
}

@media only screen and (max-width: 1024px) {
    .featured-listing .has-text {
        padding-left: 40px
    }
}

@media only screen and (max-width: 990px) {
    .featured-listing .has-text {
        padding-right: 0;
        padding-bottom: 20px;
        padding-left: 0;
        text-align: center
    }

    .featured-listing .has-text .text {
        display: inline-block;
        text-align: left
    }
}

@media only screen and (max-width: 640px) {
    .featured-listing {
        padding-top: 20px;
        padding-right: 20px;
        padding-bottom: 20px;
        padding-left: 20px
    }
}

.available-residence {
    padding-top: 50px;
    padding-right: 50px;
    padding-bottom: 50px;
    padding-left: 50px;
    background-color: #f8f6f1
}

.available-residence:not(:last-child) {
    margin-bottom: 20px
}

.available-residence .image {
    padding-bottom: 65%;
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat
}

.available-residence .has-text {
    padding-top: 40px;
    padding-right: 0;
    padding-bottom: 40px;
    padding-left: 90px
}

.available-residence .has-text h1 {
    margin-bottom: 7px
}

.available-residence .has-text .upper.accent {
    letter-spacing: .05em
}

.available-residence .has-text span {
    white-space: nowrap
}

.available-residence .has-text .lnk-blk:first-child {
    margin-right: 15px
}

@media only screen and (max-width: 1024px) {
    .available-residence .has-text {
        padding-left: 40px
    }
}

@media only screen and (max-width: 990px) {
    .available-residence .has-text {
        padding-right: 0;
        padding-bottom: 10px;
        padding-left: 0;
        text-align: center
    }

    .available-residence .has-text .text {
        display: inline-block;
        text-align: left
    }

    .available-residence .has-text .lnk-blk {
        margin-bottom: 10px
    }

    .available-residence .has-text .lnk-blk:first-child {
        margin-right: 10px
    }
}

@media only screen and (max-width: 640px) {
    .available-residence {
        padding-top: 20px;
        padding-right: 20px;
        padding-bottom: 20px;
        padding-left: 20px
    }

    .available-residence .has-text {
        padding-top: 30px;
        padding-bottom: 0
    }
}

.section-featured-listing .available-residence {
    background-color: rgba(0, 0, 0, 0);
    border: 1px solid #4d2a15
}

.news-tiles .img-blk {
    position: relative;
    padding-bottom: 60.8333333333%;
    overflow: hidden
}

.news-tiles .img-blk img {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -webkit-transform: translatey(-50%);
    transform: translatey(-50%)
}

.news-tiles .img-blk a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

@media only screen and (max-width: 640px) {
    .news-tiles .flex.has-cols .col-4 .text {
        padding-top: 30px
    }
}

.media-gallery {
    opacity: 0;
    visibility: hidden;
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding-right: 20px;
    padding-left: 20px;
    background-color: rgba(0, 0, 0, .7)
}

.media-gallery .flex {
    position: relative;
    width: 100%;
    height: 100%
}

.media-gallery .flex .col {
    width: 100%;
    max-width: 1220px
}

.media-gallery .media {
    position: relative;
    width: 100%;
    max-width: 177.778vh;
    margin-right: auto;
    margin-left: auto;
    padding-bottom: 56.25%
}

.media-gallery .media div,
.media-gallery .media iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.media-gallery .highlight.close {
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 0
}

.content-gallery .image {
    background-position: 50% 100%;
    background-size: cover;
    background-repeat: no-repeat;
    padding-bottom: 56.25%
}

.column-gallery .image {
    background-position: 50% 100%;
    background-size: cover;
    background-repeat: no-repeat;
    padding-bottom: 120%
}

.video-container {
    position: relative;
    padding-bottom: 56.25%
}

.video-container:not(:last-child) {
    margin-bottom: 30px
}

.video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.flex.flex-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

.flex.flex-wrap {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.flex.flex-justify-center {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center
}

.flex.flex-space-between {
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.flex.flex-align-center {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center
}

.flex.flex-align-end {
    -webkit-box-align: end;
    -webkit-align-items: end;
    -ms-flex-align: end;
    align-items: end
}

.flex.flex-cols {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
}

.flex .cen-h {
    -webkit-align-self: center;
    -ms-flex-item-align: center;
    align-self: center
}

.flex .col-fx {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 auto;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto
}

.flex .col-fl {
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 auto;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto
}

.flex .col-12 {
    position: relative;
    width: 100%
}

.flex .col-7 {
    position: relative;
    width: 58.333333%
}

.flex .col-6 {
    position: relative;
    width: 50%
}

.flex .col-5 {
    position: relative;
    width: 41.666666%
}

.flex .col-4 {
    position: relative;
    width: 33.333333%
}

@media only screen and (max-width: 1200px) {
    .flex .col-wd-6 {
        width: 50%
    }
}

@media only screen and (max-width: 1024px) {
    .flex .col-sd-12 {
        width: 100%
    }

    .flex .col-sd-6 {
        width: 50%
    }
}

@media only screen and (max-width: 990px) {
    .flex .col-rg-12 {
        width: 100%
    }
}

@media only screen and (max-width: 900px) {
    .flex .col-sr-12 {
        width: 100%
    }
}

@media only screen and (max-width: 768px) {
    .flex .col-md-12 {
        width: 100%
    }

    .flex .col-md-6 {
        width: 50%
    }
}

@media only screen and (max-width: 640px) {
    .flex.flex-reverse {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row
    }

    .flex .col-sm-12 {
        width: 100%
    }

    .flex .col-sm-6 {
        width: 50%
    }
}

.slick-slider {
    position: relative;
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0)
}

.slick-list {
    position: relative;
    overflow: hidden;
    display: block;
    margin: 0;
    padding: 0
}

.slick-list:focus {
    outline: none
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand
}

.slick-slider .slick-track,
.slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
}

.slick-track {
    position: relative;
    left: 0;
    top: 0;
    display: block;
    margin-left: auto;
    margin-right: auto
}

.slick-track:before,
.slick-track:after {
    content: "";
    display: table
}

.slick-track:after {
    clear: both
}

.slick-loading .slick-track {
    visibility: hidden
}

.slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
    display: none
}

[dir=rtl] .slick-slide {
    float: right
}

.slick-slide img {
    display: block;
    
}

.slick-slide.slick-loading img {
    display: none
}

.slick-slide.dragging img {
    pointer-events: none
}

.slick-initialized .slick-slide {
    display: block
}

.slick-loading .slick-slide {
    visibility: hidden
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid rgba(0, 0, 0, 0)
}

.slick-arrow.slick-hidden {
    display: none
}

.slick-prev,
.slick-next,
.tile-gallery-prev,
.tile-gallery-next {
    position: absolute;
    z-index: 9;
    display: block;
    height: 18px;
    width: 18px;
    line-height: 0px;
    font-size: 0px;
    cursor: pointer;
    background: rgba(0, 0, 0, 0);
    color: rgba(0, 0, 0, 0);
    top: 50%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    padding: 0;
    border: none;
    outline: none
}

.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus,
.tile-gallery-prev:hover,
.tile-gallery-prev:focus,
.tile-gallery-next:hover,
.tile-gallery-next:focus {
    outline: none;
    background: rgba(0, 0, 0, 0);
    color: rgba(0, 0, 0, 0)
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before,
.tile-gallery-prev.slick-disabled:before,
.tile-gallery-next.slick-disabled:before {
    opacity: .25
}

.slick-prev:before,
.slick-next:before,
.tile-gallery-prev:before,
.tile-gallery-next:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 18px;
    height: 18px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff
}

.has-captions .slick-prev,
.has-captions .slick-next,
.has-captions .tile-gallery-prev,
.has-captions .tile-gallery-next {
    top: calc(50% - 28px)
}

@media only screen and (max-width: 768px) {

    .has-captions .slick-prev,
    .has-captions .slick-next,
    .has-captions .tile-gallery-prev,
    .has-captions .tile-gallery-next {
        top: calc(50% - 18px)
    }
}

.slick-prev,
.tile-gallery-prev {
    left: 25px
}

.slick-prev:before,
.tile-gallery-prev:before {
    -webkit-transform: scaleY(0.7) rotate(-135deg);
    transform: scaleY(0.7) rotate(-135deg)
}

@media only screen and (max-width: 640px) {

    .slick-prev,
    .tile-gallery-prev {
        left: 20px
    }
}

.slick-next,
.tile-gallery-next {
    right: 25px
}

.slick-next:before,
.tile-gallery-next:before {
    -webkit-transform: scaleY(0.7) rotate(45deg);
    transform: scaleY(0.7) rotate(45deg)
}

@media only screen and (max-width: 640px) {

    .slick-next,
    .tile-gallery-next {
        right: 20px
    }
}

.masterplan-prev,
.masterplan-next {
    position: absolute;
    bottom: 40px;
    background-color: #fff;
    cursor: pointer;
    color: #1b2a33;
    font-weight: 500;
    font-size: 11px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase
}

.masterplan-prev:before,
.masterplan-next:before {
    content: "";
    display: block;
    position: absolute;
    top: 3px;
    width: 5px;
    height: 5px;
    border-top: 1px solid #707070;
    border-right: 1px solid #707070
}

@media only screen and (max-width: 640px) {

    .masterplan-prev,
    .masterplan-next {
        bottom: 30px
    }
}

.masterplan-prev {
    left: 30px;
    padding-left: 15px
}

.masterplan-prev:before {
    left: 0;
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg)
}

@media only screen and (max-width: 640px) {
    .masterplan-prev {
        left: 20px
    }
}

.masterplan-next {
    right: 30px;
    padding-right: 15px
}

.masterplan-next:before {
    right: 0;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
}

@media only screen and (max-width: 640px) {
    .masterplan-next {
        right: 20px
    }
}

.slick-dots {
    position: absolute;
    bottom: 15px;
    list-style: none;
    display: block;
    text-align: center;
    padding: 0;
    margin: 0;
    width: 100%
}

.slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    padding: 0;
    cursor: pointer
}

.slick-dots li button {
    border: 0;
    background: rgba(0, 0, 0, 0);
    display: block;
    height: 18px;
    width: 18px;
    outline: none;
    line-height: 0px;
    font-size: 0px;
    color: rgba(0, 0, 0, 0);
    cursor: pointer
}

.slick-dots li button:hover,
.slick-dots li button:focus {
    outline: none
}

.slick-dots li button:before {
    position: absolute;
    top: 6px;
    left: 6px;
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    background-color: #fff;
    border-radius: 100%
}

.slick-dots li.slick-active button:before {
    background-color: #4d2a15
}

@media only screen and (max-width: 640px) {
    .slick-dots {
        bottom: 5px
    }
}

.floorplan-gallery .slick-dots li button:before {
    background-color: #dfbca8
}

.floorplan-gallery .slick-dots li.slick-active button:before {
    background-color: #4d2a15
}

.residence-arrow {
    cursor: pointer
}

.select-column {
    width: 100%;
    max-width: 650px;
    margin-right: auto;
    margin-left: auto
}

#register-form {
    -webkit-transition: opacity .2s linear;
    transition: opacity .2s linear
}

#register-form.is-active {
    opacity: .5
}

#register-form .col-6:nth-child(2n-1) {
    padding-right: 10px
}

#register-form .col-6:nth-child(2n) {
    padding-left: 10px
}

@media only screen and (max-width: 640px) {
    #register-form .col-6:nth-child(2n-1) {
        padding-right: 0
    }

    #register-form .col-6:nth-child(2n) {
        padding-left: 0
    }
}

.register-questions {
    margin-bottom: 20px
}

.register-question {
    margin-bottom: 20px
}

.register-interests {
    padding-bottom: 50px
}

.register-broker {
    padding-bottom: 50px
}

.register-consent {
    padding-bottom: 50px
}

.register-consent a {
    text-decoration: underline
}

.register-2 {
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    -webkit-transition: all .4s ease-in-out;
    transition: all .4s ease-in-out
}

.register-2.is-active {
    opacity: 1
}

.page-template-page-inquire .register-2,
.single-blog .register-2 {
    opacity: 1;
    max-height: none
}

input,
select,
textarea,
button.submit {
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    -o-appearance: none;
    appearance: none;
    border-radius: 0;
    outline: none;
    border: 0
}

textarea {
    resize: none
}

input[type=text],
input[type=email],
textarea {
    display: block;
    width: 100%;
    height: 40px;
    padding-right: 10px;
    padding-left: 10px;
    background-color: rgba(0, 0, 0, 0);
    border: 1px solid #fff;
    color: #fff;
    font-size: 16px;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    font-weight: 400;
    line-height: normal
}

input[type=text].error,
input[type=email].error,
textarea.error {
    border-color: #4d2a15
}

textarea {
    height: 140px;
    padding-top: 8px
}

button.submit {
    position: relative;
    display: inline-block;
    padding-top: 12px;
    padding-right: 25px;
    padding-bottom: 12px;
    padding-left: 25px;
    background-color: rgba(0, 0, 0, 0);
    border: 1px solid #fff;
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase;
    white-space: nowrap
}

::-webkit-input-placeholder {
    color: #fff;
    font-size: 16px
}

:-moz-placeholder {
    color: #fff;
    font-size: 16px
}

::-moz-placeholder {
    color: #fff;
    font-size: 16px
}

:-ms-input-placeholder {
    color: #fff;
    font-size: 16px
}

::-ms-input-placeholder {
    color: #fff;
    font-size: 16px
}

:-moz-placeholder-shown {
    color: #fff;
    font-size: 16px
}

:-ms-input-placeholder {
    color: #fff;
    font-size: 16px
}

:placeholder-shown {
    color: #fff;
    font-size: 16px
}

.register-select-hidden {
    position: relative;
    height: 0;
    overflow: hidden
}

.register-select {
    position: relative;
    white-space: nowrap
}

.register-select .is-reg-mobile {
    display: none
}

@media only screen and (max-width: 390px) {
    .register-select .no-reg-mobile {
        display: none
    }

    .register-select .is-reg-mobile {
        display: inline
    }
}

.register-select-field {
    position: relative;
    width: 100%;
    height: 50px;
    border: 1px solid #4d2a15;
    background-color: rgba(0, 0, 0, 0);
    cursor: pointer
}

.register-select-field .sub-menu-icon {
    position: absolute;
    top: 19px;
    right: 20px;
    width: 11px;
    height: 11px
}

.register-select-field .sub-menu-icon:before {
    content: "";
    display: block;
    position: absolute;
    top: 5px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #4d2a15
}

.register-select-field .sub-menu-icon:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 5px;
    width: 1px;
    height: 100%;
    background-color: #4d2a15;
    opacity: 1;
    -webkit-transition: opacity .2s ease-in-out;
    transition: opacity .2s ease-in-out
}

.register-select-field.is-active .sub-menu-icon:after {
    opacity: 0
}

.register-select-field.error {
    border-bottom-color: #4d2a15
}

.register-select-field.error:after {
    border-color: #4d2a15 rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0)
}

.register-select-label {
    position: absolute;
    top: 0;
    left: 0
}

.has-value .register-select-label {
    opacity: 0
}

.register-select-menu {
    display: none;
    position: absolute;
    z-index: 99;
    top: 49px;
    left: 0;
    width: 100%;
    max-height: 202px;
    background-color: #f8f6f1;
    border: 1px solid #4d2a15;
    overflow: auto;
    -webkit-box-shadow: 0 2px 4px 0px rgba(0, 0, 0, .2);
    box-shadow: 0 2px 4px 0px rgba(0, 0, 0, .2)
}

.page-template-page-available-residences .register-select-menu {
    max-height: 252px
}

.register-select-item {
    height: 50px;
    padding-right: 10px;
    padding-left: 20px;
    background-color: #f8f6f1;
    cursor: pointer
}

.register-select-item.is-selected {
    color: #4d2a15
}

.register-select-label,
.register-select-item,
.register-select-detail {
    height: 48px;
    padding-right: 20px;
    padding-left: 20px;
    color: #4d2a15;
    font-weight: 700;
    font-size: 14px;
    line-height: 48px;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase
}

.error .register-select-label,
.error .register-select-item,
.error .register-select-detail {
    color: #4d2a15
}

@media only screen and (max-width: 640px) {

    .register-select-label,
    .register-select-item,
    .register-select-detail {
        font-size: 13px
    }
}

.register-select-item {
    height: 50px;
    color: #1b2a33;
    font-weight: 400;
    line-height: 50px
}

.page-template-page-available-residences .register-select-menu,
.page-template-page-available-residences .register-select-item,
.page-template-page-real-estate .register-select-menu,
.page-template-page-real-estate .register-select-item {
    background-color: #fff
}

.interests {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.interests .interest {
    display: inline-block;
    vertical-align: middle
}

.interests .interest:not(:last-child) {
    margin-right: 40px
}

.interests label {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    cursor: pointer
}

.interests label .title {
    display: inline-block;
    vertical-align: middle;
    color: #fff;
    font-weight: 500;
    font-size: 16px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif
}

@media only screen and (max-width: 475px) {
    .interests {
        text-align: left
    }

    .interests .interest {
        display: block;
        width: 100%;
        max-width: 130px;
        margin-right: auto;
        margin-left: auto
    }

    .interests .interest:not(:last-child) {
        margin-bottom: 20px;
        margin-right: auto
    }
}

.custom-check {
    position: relative;
    display: inline-block;
    width: 18px;
    height: 18px;
    margin-right: 10px;
    border: 1px solid #fff;
    vertical-align: middle
}

.custom-check .check {
    position: absolute;
    top: 0;
    left: 0;
    width: 16px;
    height: 16px
}

.custom-check .check:after {
    content: "";
    display: block;
    position: absolute;
    top: 3px;
    left: 3px;
    width: 10px;
    height: 10px;
    background-color: #fff;
    opacity: 0
}

.custom-check input[type=checkbox] {
    visibility: hidden
}

.custom-check input[type=checkbox]:checked+.check:after {
    opacity: 1
}

.consent {
    max-width: 550px;
    margin-right: auto;
    margin-left: auto
}

.consent label {
    display: block;
    position: relative;
    padding-left: 28px;
    cursor: pointer
}

.consent label .title {
    display: inline
}

.consent .custom-check {
    position: absolute;
    top: 2px;
    left: 0
}

.interests.error label .title {
    color: #4d2a15
}

.interests.error .custom-check {
    border: 1px solid #4d2a15
}

.section-register input[type=text].error,
.section-register input[type=email].error,
.section-register textarea.error {
    border-color: #ffbe00
}

.section-register .interests.error label .title {
    color: #ffbe00
}

.section-register .interests.error .custom-check {
    border: 1px solid #ffbe00
}

.no-touchevents .register-select-item {
    -webkit-transition: background-color .2s linear;
    transition: background-color .2s linear
}

.no-touchevents .register-select-item:hover:not(.is-selected) {
    background-color: #fff
}

.no-touchevents .page-template-page-available-residences .register-select-item:hover:not(.is-selected),
.no-touchevents .page-template-page-real-estate .register-select-item:hover:not(.is-selected) {
    background-color: #f8f6f1
}

.no-touchevents button.submit {
    -webkit-transition: all .2s linear;
    transition: all .2s linear
}

.no-touchevents button.submit:hover {
    background-color: #fff;
    color: #4d2a15
}

#recaptcha,
.grecaptcha-badge {
    visibility: hidden
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: #4d2a15;
    font-weight: 400;
    font-family: "Prelom", Times, Georgia, serif;
    text-transform: uppercase
}

h1 {
    font-size: 40px;
    line-height: 1.1em
}

@media only screen and (max-width: 735px) {
    h1 br {
        display: none
    }
}

@media only screen and (max-width: 640px) {
    h1 {
        font-size: 30px
    }
}

h2,
.available-residence h1 {
    font-size: 30px;
    line-height: 1.26em
}

@media only screen and (max-width: 735px) {

    h2 br,
    .available-residence h1 br {
        display: none
    }
}

@media only screen and (max-width: 640px) {

    h2,
    .available-residence h1 {
        font-size: 24px
    }
}

h3 {
    font-size: 24px;
    line-height: 1.26em
}

@media only screen and (max-width: 640px) {
    h3 {
        font-size: 20px
    }
}

h4 {
    font-size: 20px;
    line-height: 1.26em
}

@media only screen and (max-width: 640px) {
    h4 {
        font-size: 18px
    }
}

h5 {
    font-size: 18px;
    line-height: 1.26em
}

h6 {
    font-size: 17px;
    line-height: 1.26em
}

.brow {
    color: #4d2a15;
    font-weight: 400;
    font-family: "Prelom", Times, Georgia, serif;
    font-size: 16px;
    line-height: 1em;
    letter-spacing: .05em;
    text-transform: uppercase
}

p,
.the-content ul,
.alternating-rows ul {
    color: #1b2a33;
    font-weight: 400;
    font-size: 17px;
    line-height: 1.88em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif
}

@media only screen and (max-width: 640px) {

    p,
    .the-content ul,
    .alternating-rows ul {
        font-size: 16px
    }
}

.masterplan-popup p {
    font-size: 15px
}

p.sub {
    color: #4d2a15;
    font-weight: 500;
    font-size: 14px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase
}

.tiles-101-things p.sub {
    margin-bottom: 15px;
    color: #1b2a33
}

p.quote {
    color: #4d2a15;
    font-weight: 400;
    font-size: 30px;
    line-height: 1.26em;
    font-family: "Prelom", Times, Georgia, serif;
    text-transform: uppercase
}

@media only screen and (max-width: 640px) {
    p.quote {
        font-size: 24px
    }
}

p.credit {
    color: #4d2a15;
    font-weight: 700;
    font-size: 12px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase
}

p.disclaimer {
    font-weight: 400;
    font-size: 12px
}

p.residence-stats {
    line-height: 1.45em;
    text-transform: uppercase
}

p.residence-disclaimer {
    font-weight: 400;
    font-size: 10px;
    line-height: 1.2em
}

.map-text p {
    font-size: 14px;
    line-height: 1.2em
}

.the-content ul:not(.slick-dots) li {
    padding-left: 20px;
    margin-bottom: 10px
}

.the-content ul:not(.slick-dots) li:last-child {
    margin-bottom: 0
}

.the-content ul:not(.slick-dots) li:before {
    position: relative;
    content: "â– ";
    display: inline-block;
    width: 20px;
    margin-left: -20px;
    color: #4d2a15
}

.alternating-rows ul:not(.slick-dots) li {
    padding-left: 20px;
    margin-bottom: 10px
}

.alternating-rows ul:not(.slick-dots) li:last-child {
    margin-bottom: 0
}

.alternating-rows ul:not(.slick-dots) li:before {
    position: relative;
    content: "â€“";
    display: inline-block;
    width: 20px;
    margin-left: -20px;
    color: #1b2a33
}

a.lnk-rle {
    position: relative;
    display: inline-block;
    padding-bottom: 10px;
    border-bottom: 1px solid #1b2a33;
    color: #1b2a33;
    font-weight: 500;
    font-size: 12px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase
}

.lnk-blk {
    display: inline-block;
    padding-top: 10px;
    padding-right: 20px;
    padding-bottom: 10px;
    padding-left: 20px;
    background-color: rgba(0, 0, 0, 0);
    border: 1px solid #4d2a15;
    cursor: pointer;
    color: #4d2a15;
    font-weight: 500;
    font-size: 12px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .04em;
    text-transform: uppercase
}

.lnk-blk.is-done {
    opacity: .5;
    cursor: default
}

a {
    color: inherit;
    text-decoration: none
}

b,
strong {
    font-weight: 700
}

.black {
    font-weight: 900
}

i,
em {
    font-style: italic
}

p.text-color {
    color: #1b2a33
}

.accent {
    color: #4d2a15
}

.upper {
    text-transform: uppercase
}

.text-cen {
    text-align: center
}

.nowrap {
    white-space: nowrap
}

.intro.text-cen .brow:not(:last-child) {
    margin-bottom: 30px
}

.intro.text-cen h1:not(:last-child) {
    margin-bottom: 30px
}

.intro.text-cen p:not(:last-child) {
    margin-bottom: 1.88em
}

@media only screen and (max-width: 640px) {
    .intro.text-cen .brow:not(:last-child) {
        margin-bottom: 20px
    }

    .intro.text-cen h1:not(:last-child) {
        margin-bottom: 20px
    }
}

p.sub+h1:not(:last-child),
p.sub+h2:not(:last-child) {
    margin-top: 30px
}

@media only screen and (max-width: 640px) {

    p.sub+h1:not(:last-child),
    p.sub+h2:not(:last-child) {
        margin-top: 20px
    }
}

.page-template-page-food-nightlife p.sub {
    color: #1b2a33
}

.p-m p:not(:last-child) {
    margin-bottom: 1.88em
}

.section-text h1,
.alternating-rows h1,
.section-parallax h1,
.has-cols h1,
.list-101-things h1,
.has-contact h1,
.section-thank-you h1 {
    margin-bottom: 30px
}

.section-text h2,
.alternating-rows h2,
.section-parallax h2,
.has-cols h2,
.list-101-things h2,
.has-contact h2,
.section-thank-you h2 {
    margin-bottom: 20px
}

.section-text h4,
.alternating-rows h4,
.section-parallax h4,
.has-cols h4,
.list-101-things h4,
.has-contact h4,
.section-thank-you h4 {
    margin-bottom: 5px
}

.section-text p:not(:last-child):not(.sub),
.alternating-rows p:not(:last-child):not(.sub),
.section-parallax p:not(:last-child):not(.sub),
.has-cols p:not(:last-child):not(.sub),
.list-101-things p:not(:last-child):not(.sub),
.has-contact p:not(:last-child):not(.sub),
.section-thank-you p:not(:last-child):not(.sub) {
    margin-bottom: 1em
}

@media only screen and (max-width: 640px) {

    .section-text h1,
    .alternating-rows h1,
    .section-parallax h1,
    .has-cols h1,
    .list-101-things h1,
    .has-contact h1,
    .section-thank-you h1 {
        margin-bottom: 20px
    }
}

.section-available-residence-hero .residence-price {
    padding-top: 15px;
    padding-right: 20px;
    padding-bottom: 14px;
    padding-left: 20px;
    background-color: #4d2a15;
    color: #fff;
    font-weight: 400;
    font-size: 30px;
    line-height: 1em;
    font-family: "Prelom", Times, Georgia, serif;
    text-transform: uppercase
}

@media only screen and (max-width: 768px) {
    .section-available-residence-hero .residence-price {
        padding-top: 10px;
        padding-right: 15px;
        padding-bottom: 9px;
        padding-left: 15px;
        font-size: 24px
    }
}

@media only screen and (max-width: 640px) {
    .section-available-residence-hero .residence-price {
        padding-top: 10px;
        padding-right: 12px;
        padding-bottom: 8px;
        padding-left: 12px;
        font-size: 14px
    }
}

.section-available-residence .brow {
    margin-bottom: 30px
}

.section-available-residence h1 {
    margin-bottom: 30px
}

.section-available-residence p.upper {
    margin-bottom: 5px
}

.section-available-residence p:not(.upper):not(:last-child) {
    margin-bottom: 30px
}

@media only screen and (max-width: 640px) {
    .section-available-residence .brow {
        margin-bottom: 20px
    }

    .section-available-residence h1 {
        margin-bottom: 20px
    }
}

.is-dark h1,
.is-dark h2,
.is-dark h3,
.is-dark h4,
.is-dark h5,
.is-dark h6,
.is-dark p,
.is-dark .the-content ul {
    color: #ffffff
}

.is-dark p.disclaimer {
    color: #ffffff
}

.is-dark a.lnk-rle {
    color: #625757;
    border-bottom-color: #625757
}

.is-dark .lnk-blk {
    border-color: #625757;
    color: #625757
}

.the-content h1:not(:last-child),
.the-content h2:not(:last-child),
.the-content h3:not(:last-child),
.the-content h4:not(:last-child),
.the-content h5:not(:last-child),
.the-content h6:not(:last-child) {
    margin-bottom: 30px
}

.the-content .section-content:first-child h1 {
    margin-bottom: 30px
}

.the-content p:not(:last-child),
.the-content ul:not(.slick-dots):not(:last-child) {
    margin-bottom: 30px
}

.the-content p:not(.sub)+h1,
.the-content p:not(.sub)+h2,
.the-content p:not(.sub)+h3,
.the-content p:not(.sub)+h4,
.the-content p:not(.sub)+h5,
.the-content p:not(.sub)+h6,
.the-content ul:not(.slick-dots)+h1,
.the-content ul:not(.slick-dots)+h2,
.the-content ul:not(.slick-dots)+h3,
.the-content ul:not(.slick-dots)+h4,
.the-content ul:not(.slick-dots)+h5,
.the-content ul:not(.slick-dots)+h6 {
    margin-top: 50px
}

.the-content ul.list-unstyled,
.the-content ol.list-unstyled {
    list-style: none;
    padding-left: 0
}

.the-content ul.list-unstyled:not(.slick-dots)>li,
.the-content ol.list-unstyled:not(.slick-dots)>li {
    padding-left: 0;
    margin-top: 3rem;
    margin-bottom: 3rem
}

.the-content ul.list-unstyled:not(.slick-dots)>li::before,
.the-content ol.list-unstyled:not(.slick-dots)>li::before {
    content: "";
    display: none
}

@media only screen and (max-width: 640px) {

    .the-content h1:not(:last-child),
    .the-content h2:not(:last-child),
    .the-content h3:not(:last-child),
    .the-content h4:not(:last-child),
    .the-content h5:not(:last-child),
    .the-content h6:not(:last-child) {
        margin-bottom: 20px
    }

    .the-content .section-content:first-child h1 {
        margin-bottom: 20px
    }

    .the-content p:not(:last-child),
    .the-content ul:not(.slick-dots):not(:last-child) {
        margin-bottom: 20px
    }

    .the-content p:not(.sub)+h1,
    .the-content p:not(.sub)+h2,
    .the-content p:not(.sub)+h3,
    .the-content p:not(.sub)+h4,
    .the-content p:not(.sub)+h5,
    .the-content p:not(.sub)+h6,
    .the-content ul:not(.slick-dots)+h1,
    .the-content ul:not(.slick-dots)+h2,
    .the-content ul:not(.slick-dots)+h3,
    .the-content ul:not(.slick-dots)+h4,
    .the-content ul:not(.slick-dots)+h5,
    .the-content ul:not(.slick-dots)+h6 {
        margin-top: 30px
    }
}

.mb-10 {
    margin-bottom: 10px
}

.mb-20 {
    margin-bottom: 20px
}

.mb-25 {
    margin-bottom: 25px
}

.mb-30 {
    margin-bottom: 30px !important
}

@media only screen and (max-width: 640px) {
    p.sub.mb-30 {
        margin-bottom: 20px !important
    }
}

.mb-40 {
    margin-bottom: 40px
}

@media only screen and (max-width: 640px) {
    .mb-40 {
        margin-bottom: 30px
    }
}

.mt-50 {
    margin-top: 50px !important
}

.mb-50 {
    margin-bottom: 50px !important
}

.mb-60 {
    margin-bottom: 60px !important
}

@media only screen and (max-width: 640px) {
    .mb-60 {
        margin-bottom: 40px !important
    }
}

.mb-70 {
    margin-bottom: 70px
}

@media only screen and (max-width: 640px) {
    .mb-70 {
        margin-bottom: 50px
    }
}

.mb-100 {
    margin-bottom: 100px
}

@media only screen and (max-width: 1024px) {
    .mb-100 {
        margin-bottom: 70px
    }
}

@media only screen and (max-width: 640px) {
    .mb-100 {
        margin-bottom: 50px
    }
}

.mb-150 {
    margin-bottom: 150px
}

@media only screen and (max-width: 640px) {
    .mb-150 {
        margin-bottom: 50px
    }
}

.fa-solid {
    color: #fff;
    font-size: 15px;
    font-family: "Font Awesome 6 Free"
}

.no-touchevents a.lnk-rle {
    -webkit-transition: border-color .2s linear, color .2s linear;
    transition: border-color .2s linear, color .2s linear
}

.no-touchevents a.lnk-rle:hover {
    border-bottom-color: #4d2a15;
    color: #4d2a15
}

.no-touchevents .is-dark a.lnk-rle:hover {
    border-bottom-color: #fff;
    color: #fff
}

.no-touchevents .lnk-blk:not(.is-done) {
    -webkit-transition: background-color .2s linear, color .2s linear;
    transition: background-color .2s linear, color .2s linear
}

.no-touchevents .lnk-blk:not(.is-done):hover {
    background-color: #4d2a15;
    color: #fff
}

.no-touchevents .is-dark .lnk-blk:hover {
    background-color: #fff;
    color: #4d2a15
}

.section-standard {
    padding-top: 150px;
    padding-bottom: 150px
}

@media only screen and (max-width: 990px) {
    .section-standard {
        padding-top: 100px;
        padding-bottom: 100px
    }
}

@media only screen and (max-width: 768px) {
    .section-standard {
        padding-top: 75px;
        padding-bottom: 75px
    }
}

@media only screen and (max-width: 640px) {
    .section-standard {
        padding-top: 50px;
        padding-bottom: 50px
    }
}

.section-quote+.section-standard {
    padding-top: 110px
}

@media only screen and (max-width: 990px) {
    .section-quote+.section-standard {
        padding-top: 100px
    }
}

@media only screen and (max-width: 768px) {
    .section-quote+.section-standard {
        padding-top: 75px
    }
}

@media only screen and (max-width: 640px) {
    .section-quote+.section-standard {
        padding-top: 50px
    }
}

.no-top {
    padding-top: 0 !important
}

.no-bottom {
    padding-bottom: 0 !important
}

.section-standard.no-hero {
    padding-top: 110px
}

@media only screen and (max-width: 990px) {
    .section-standard.no-hero {
        padding-top: 100px
    }
}

@media only screen and (max-width: 768px) {
    .section-standard.no-hero {
        padding-top: 75px
    }
}

@media only screen and (max-width: 640px) {
    .section-standard.no-hero {
        padding-top: 50px
    }
}

.b-top {
    border-top: 1px solid #4d2a15
}

.section-intro {
    padding-bottom: 110px
}

.section-intro .text {
    padding-top: 110px
}

@media only screen and (max-width: 768px) {
    .section-intro {
        padding-bottom: 75px
    }

    .section-intro .text {
        padding-top: 75px
    }
}

@media only screen and (max-width: 640px) {
    .section-intro {
        padding-bottom: 50px
    }

    .section-intro .text {
        padding-top: 50px
    }
}

.section-text .text,
.section-available-residence .text {
    padding-top: 60px
}

@media only screen and (max-width: 640px) {

    .section-text .text,
    .section-available-residence .text {
        padding-top: 40px
    }
}

.section-content {
    padding-top: 150px;
    padding-bottom: 150px
}

@media only screen and (max-width: 990px) {
    .section-content {
        padding-top: 100px;
        padding-bottom: 100px
    }
}

@media only screen and (max-width: 768px) {
    .section-content {
        padding-top: 75px;
        padding-bottom: 75px
    }
}

@media only screen and (max-width: 640px) {
    .section-content {
        padding-top: 50px;
        padding-bottom: 50px
    }
}

.section-content:first-child {
    padding-bottom: 0
}

.section-content:first-child+.content-text {
    padding-top: 0
}

.content-text+.content-gallery,
.content-gallery+.content-text {
    margin-top: -75px;
    padding-top: 0
}

@media only screen and (max-width: 990px) {

    .content-text+.content-gallery,
    .content-gallery+.content-text {
        margin-top: -50px
    }
}

@media only screen and (max-width: 768px) {

    .content-text+.content-gallery,
    .content-gallery+.content-text {
        margin-top: -25px
    }
}

@media only screen and (max-width: 640px) {

    .content-text+.content-gallery,
    .content-gallery+.content-text {
        margin-top: 0px
    }
}

.legal-links h2 {
    display: inline-block;
    margin-right: 20px;
    margin-bottom: 20px;
    margin-left: 20px
}

.section-marina {
    padding-top: 120px;
    padding-bottom: 100px;
    background-position: 50% 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: url(images/production/wp-content/themes/costapalmas/src/images/graphics/marina-banner.jpg)
}

.section-marina p {
    line-height: 1.2em
}

.section-marina .marina-contact {
    display: inline-block;
    margin-right: 40px;
    margin-left: 40px
}

.section-marina .marina-links {
    margin-top: 10px
}

.section-marina .marina-links .lnk-blk {
    min-width: 160px;
    margin-right: 20px;
    margin-bottom: 20px;
    margin-left: 20px
}

@media only screen and (max-width: 900px) {
    .section-marina .marina-contact {
        margin-right: 25px;
        margin-left: 25px
    }
}

@media only screen and (max-width: 640px) {
    .section-marina {
        padding-top: 75px;
        padding-bottom: 55px
    }

    .section-marina .marina-links .lnk-blk {
        min-width: 110px;
        margin-right: 10px;
        margin-left: 10px
    }
}

nav.nav-site {
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #fff
}

nav.nav-site .nav-masterplan {
    position: relative;
    z-index: 1;
    height: 37px;
    padding-top: 10px;
    padding-bottom: 9px;
    border-bottom: 1px solid #4d2a15;
    background-color: #fff;
    text-align: right
}

nav.nav-site .nav-masterplan a {
    color: #1b2a33;
    font-weight: 400;
    font-size: 11px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .05em;
    text-transform: uppercase
}

nav.nav-site .nav-bar {
    position: relative;
    z-index: 1;
    height: 121px;
    background-color: #fff;
    border-bottom: 1px solid #e6e6e6
}

nav.nav-site .nav-bar .flex {
    height: 120px
}

nav.nav-site .nav-logo {
    width: 235px;
    height: 60px
}

nav.nav-site .nav-logo a {
    display: inline-block;
    width: 60px;
    height: 60px
}

nav.nav-site .nav-items {
    height: 120px
}

nav.nav-site .nav-items .nav-item {
    position: relative;
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    height: 120px;
    margin-right: 45px;
    margin-left: 45px
}

nav.nav-site .nav-items .nav-item:first-child {
    width: 210px;
    margin-left: 0
}

nav.nav-site .nav-items .nav-item:last-child {
    margin-right: 0;
    margin-left: 69px
}

nav.nav-site .nav-items .nav-item>span {
    position: relative;
    height: 120px;
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center
}

nav.nav-site .nav-items .nav-item>span:after {
    opacity: 0;
    content: "";
    display: block;
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #4d2a15;
    -webkit-transition: opacity .2s linear;
    transition: opacity .2s linear
}

nav.nav-site .nav-items .nav-item.is-active>span:after {
    opacity: 1
}

nav.nav-site .nav-items .nav-item span span {
    display: inline-block;
    padding-top: 2px;
    cursor: pointer;
    color: #1b2a33;
    font-weight: 400;
    font-size: 14px;
    line-height: 1em;
    font-family: "Prelom", Times, Georgia, serif;
    text-transform: uppercase
}

nav.nav-site .nav-inquire {
    margin-left: auto
}

nav.nav-site .nav-inquire a {
    display: inline-block;
    padding-top: 10px;
    padding-right: 35px;
    padding-bottom: 7px;
    padding-left: 35px;
    /* background-color: #4d2a15; */
    border: 1px solid #4d2a15;
    color: #4d2a15;
    font-weight: 400;
    font-size: 14px;
    line-height: 1em;
    font-family: "Prelom", Times, Georgia, serif;
    text-transform: uppercase
}

nav.nav-site .nav-drawer {
    position: absolute;
    z-index: 0;
    left: 0;
    bottom: 0;
    width: 100%;
    padding-bottom: 40px;
    background-color: #fff;
    border-bottom: 1px solid #e6e6e6
}

nav.nav-site .nav-drawer .column-5 {
    padding-top: 40px
}

nav.nav-site .nav-drawer .drawer {
    position: absolute;
    opacity: 0;
    visibility: hidden;
    top: 40px;
    left: 0;
    width: 100%
}

nav.nav-site .nav-drawer .drawer * {
    pointer-events: none
}

nav.nav-site .nav-drawer .drawer.is-rel {
    position: relative;
    display: block;
    top: 0
}

nav.nav-site .nav-drawer .drawer.is-active * {
    pointer-events: auto
}

nav.nav-site .nav-drawer .col-logo {
    width: 235px
}

nav.nav-site .nav-drawer .col-1 {
    width: 210px;
    margin-right: 45px
}

nav.nav-site .nav-drawer .col-2 {
    margin-left: 45px
}

nav.nav-site .nav-drawer .col-featured {
    width: 280px;
    margin-left: auto
}

nav.nav-site .nav-drawer .col-featured .img-blk {
    margin-bottom: 5px
}

nav.nav-site .nav-drawer a {
    color: #1b2a33;
    font-weight: 300;
    font-size: 14px;
    line-height: 2em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif
}

nav.nav-site .nav-drawer a.title {
    font-weight: 500;
    letter-spacing: .025em;
    text-transform: uppercase
}

nav.nav-site .nav-drawer a.lnk-rul {
    padding-bottom: 4px;
    border-bottom: 1px solid #4d2a15;
    color: #4d2a15;
    font-weight: 500;
    font-size: 10px;
    letter-spacing: .04em;
    text-transform: uppercase
}

nav.nav-site .nav-drawer a.is-active {
    color: #4d2a15
}

@media only screen and (max-width: 1250px) {
    nav.nav-site .nav-logo {
        width: 200px
    }

    nav.nav-site .nav-drawer .col-logo {
        width: 200px
    }
}

@media only screen and (max-width: 1150px) {
    nav.nav-site .nav-logo {
        width: 150px
    }

    nav.nav-site .nav-drawer .col-logo {
        width: 150px
    }
}

@media only screen and (max-width: 1100px) {
    nav.nav-site .nav-items .nav-item {
        margin-right: 30px;
        margin-left: 30px
    }

    nav.nav-site .nav-items .nav-item:first-child {
        width: 200px;
        margin-left: 0
    }

    nav.nav-site .nav-items .nav-item:last-child {
        margin-right: 0;
        margin-left: 44px
    }

    nav.nav-site .nav-drawer .col-1 {
        width: 200px;
        margin-right: 30px
    }
}

@media only screen and (max-width: 1024px) {
    nav.nav-site .nav-masterplan {
        display: none
    }

    nav.nav-site .nav-items {
        display: none
    }

    nav.nav-site .nav-drawer {
        display: none
    }

    nav.nav-site .nav-logo {
        width: 60px
    }
}

@media only screen and (max-width: 640px) {
    nav.nav-site .nav-bar {
        height: 101px
    }

    nav.nav-site .nav-bar .flex {
        height: 100px
    }
}

.nav-icon {
    display: none;
    position: relative;
    width: 25px;
    height: 18px;
    margin-left: 20px;
    cursor: pointer
}

.nav-icon .line {
    position: absolute;
    right: 0;
    width: 100%;
    height: 2px;
    background-color: #4d2a15;
    -webkit-transition: all .2s linear;
    transition: all .2s linear
}

.nav-icon .line:nth-child(1) {
    top: 0
}

.nav-icon .line:nth-child(2) {
    top: 8px
}

.nav-icon .line:nth-child(3) {
    top: 16px;
    width: 75%
}

.js-menu .nav-icon .line:nth-child(1) {
    top: 7px;
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg)
}

.js-menu .nav-icon .line:nth-child(2) {
    opacity: 0
}

.js-menu .nav-icon .line:nth-child(3) {
    top: 7px;
    width: 100%;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg)
}

@media only screen and (max-width: 1024px) {
    .nav-icon {
        display: block
    }
}

.nav-menu {
    opacity: 0;
    visibility: hidden;
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding-top: 121px;
    padding-bottom: 50px;
    background-color: #fff;
    -webkit-transform: translate(100%, 0%);
    transform: translate(100%, 0%)
}

.nav-menu .nav-menus {
    padding-right: 20px;
    padding-left: 20px
}

.nav-menu .nav-menu-items {
    position: relative;
    padding-top: 20px;
    padding-bottom: 18px;
    border-bottom: 1px solid #e6e6e6
}

.nav-menu .nav-menu-items .sub-menu-icon {
    position: absolute;
    top: 19px;
    right: 0;
    width: 15px;
    height: 15px
}

.nav-menu .nav-menu-items .sub-menu-icon:before {
    content: "";
    position: absolute;
    top: 7px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #1b2a33
}

.nav-menu .nav-menu-items .sub-menu-icon:after {
    content: "";
    position: absolute;
    top: 0;
    left: 7px;
    width: 1px;
    height: 100%;
    background-color: #1b2a33;
    opacity: 1;
    -webkit-transition: opacity .2s ease-in-out;
    transition: opacity .2s ease-in-out
}

.nav-menu .nav-menu-items .nav-menu-item {
    position: relative;
    cursor: pointer;
    color: #1b2a33;
    font-weight: 400;
    font-size: 14px;
    line-height: 1em;
    font-family: "Prelom", Times, Georgia, serif;
    text-transform: uppercase;
    -webkit-transition: color .2s linear;
    transition: color .2s linear
}

.nav-menu .nav-menu-items .nav-menu-sub-menu {
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    -webkit-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out
}

.nav-menu .nav-menu-items.is-active .nav-menu-item {
    color: #4d2a15
}

.nav-menu .nav-menu-items.is-active .sub-menu-icon:after {
    opacity: 0
}

.nav-menu .nav-menu-items.is-active .nav-menu-sub-menu {
    opacity: 1
}

.nav-menu .sub-menus {
    padding-top: 20px
}

.nav-menu .sub-menu:first-child {
    margin-bottom: 20px
}

.nav-menu .sub-menu a {
    color: #1b2a33;
    font-weight: 300;
    font-size: 14px;
    line-height: 2em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif
}

.nav-menu .sub-menu a.title {
    font-weight: 500;
    letter-spacing: .025em;
    text-transform: uppercase
}

.nav-menu .sub-menu a.is-active {
    color: #4d2a15
}

.nav-menu .nav-menu-masterplan {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 37px;
    padding-top: 10px;
    padding-right: 20px;
    padding-bottom: 9px;
    padding-left: 20px;
    background-color: #4d2a15
}

.nav-menu .nav-menu-masterplan a {
    color: #fff;
    font-weight: 400;
    font-size: 11px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    letter-spacing: .05em;
    text-transform: uppercase
}

@media only screen and (max-width: 640px) {
    .nav-menu {
        padding-top: 101px
    }
}

.no-touchevents .nav-masterplan a,
.no-touchevents .nav-site .nav-items span,
.no-touchevents .drawer a,
.no-touchevents .menu-items a {
    -webkit-transition: color .2s linear;
    transition: color .2s linear
}

.no-touchevents .nav-masterplan a:hover,
.no-touchevents .nav-site .nav-items span:hover,
.no-touchevents .drawer a:hover,
.no-touchevents .menu-items a:hover {
    color: #4d2a15
}

.no-touchevents .nav-inquire a {
    -webkit-transition: background-color .2s linear, color .2s linear;
    transition: background-color .2s linear, color .2s linear
}

.no-touchevents .nav-inquire a:hover {
    background-color: #fff;
    color: #4d2a15
}

.page-template-page-resorts-home a[href="/resorts/"],
.page-id-101 a[href="/resorts/four-seasons/"],
.page-id-103 a[href="/resorts/aman/"],
.page-template-page-real-estate-home a[href="/real-estate/"],
.page-id-107 a[href="/real-estate/four-seasons/"],
.page-id-109 a[href="/real-estate/aman/"],
.page-id-111 a[href="/real-estate/casa-blake/"],
.page-template-page-costa-palmas-club a[href="/real-estate/costa-palmas-club/"],
.page-template-page-available-residences-home a[href="/homes-for-sale/"],
.page-template-page-location a[href="/location/"],
.page-template-page-the-east-cape a[href="/location/the-east-cape/"],
.page-template-page-masterplan a[href="/location/masterplan/"],
.page-template-page-getting-here a[href="/location/getting-here/"],
.page-template-page-experiences a[href="/experiences/"],
.page-id-125 a[href="/experiences/golf-club/"],
.page-id-3509 a[href="/experiences/marina/"],
.page-id-127 a[href="/experiences/marina-village/"],
.page-template-page-food-nightlife a[href="/experiences/food-nightlife/"],
.page-id-131 a[href="/experiences/aventura/"],
.page-id-2576 a[href="/experiences/retail/"],
.page-template-page-irongate a[href="/irongate-group/"],
.page-template-page-faq a[href="/faq/"],
.page-template-page-contact a[href="/contact/"],
.page-template-page-fundacion a[href="/fundacion/"],
.page-template-page-news a[href="/news/"],
.page-template-page-stories a[href="/stories/"],
.page-template-page-press a[href="/press/"],
.page-template-page-media-gallery a[href="/media-gallery/"] {
    color: #4d2a15 !important
}

.footer-nav .flex a {
    color: #fff !important
}

.section-register {
    background-color: #1b2a33;
    background-image: url(images/production/wp-content/themes/costapalmas/src/images/footer/blog-register.jpg);
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat
}

@media only screen and (max-width: 1366px) {
    .section-register {
        background-image: url(images/production/wp-content/themes/costapalmas/src/images/footer/1366/blog-register.jpg)
    }
}

.footer {
    padding-top: 150px;
    background-color: #1b2a33;
    background-image: url(https://amaaragrovegoa.com/images/skyyyy.png);
    background-size: cover;
    background-position: 50% 100%;
    background-repeat: no-repeat
}

.footer.no-reg {
    padding-top: 0
}

.footer .register-column {
    padding-bottom: 120px
}

.footer .footer-logo {
    padding-top: 0px;
    padding-bottom: 0px;
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff
}

.footer .footer-logo .column {
    font-size: 0
}

.footer .footer-logo a,
.footer .footer-logo img {
    display: inline-block
}

.footer.no-reg .footer-logo {
    border-top: 0
}

.footer .footers {
    position: relative;
    border-bottom: 1px solid #fff
}

.footer .footers:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 1px;
    background-color: #fff
}

.footer .footers .col-6 {
    padding-top: 90px;
    padding-right: 40px;
    padding-bottom: 120px;
    padding-left: 40px
}

.footer .footers .footer-cta .text {
    width: 100%;
    max-width: 470px;
    margin-right: auto;
    margin-left: auto
}

.footer .footers .footer-nav {
    width: 100%;
    max-width: 470px;
    margin-right: auto;
    margin-left: auto
}

.footer .footers .footer-nav .flex,
.footer .footers .footer-nav .footer-external {
    width: 100%;
    margin-bottom: 30px
}

.footer .footers .footer-nav .flex a,
.footer .footers .footer-nav .footer-external a {
    display: inline-block;
    color: #fff;
    font-weight: 400;
    font-size: 14px;
    line-height: 1em;
    font-family: "Basis Grotesque", Helvetica, Arial, sans-serif;
    text-transform: uppercase
}

.footer .footers .footer-nav .flex a:not(:last-child),
.footer .footers .footer-nav .footer-external a:not(:last-child) {
    margin-bottom: 20px
}

.footer .footers .footer-nav .footer-social a {
    display: inline-block;
    vertical-align: middle
}

.footer .footers .footer-nav .footer-social a:not(:last-child) {
    margin-right: 25px
}

.footer .footer-disclaimer {
    padding-top: 30px;
    padding-bottom: 30px
}

.footer .footer-disclaimer .col:first-child {
    padding-right: 30px
}

.footer .footer-disclaimer a {
    white-space: nowrap
}

@media only screen and (max-width: 1366px) {
    .footer {
        background-image: url(https://www.amaaragrovegoa.com/images/skyyyy.png)
    }
}

@media only screen and (max-width: 990px) {
    .footer {
        padding-top: 100px
    }

    .footer .register-column {
        padding-bottom: 100px
    }

    .footer .footers .footer-nav {
        max-width: 185px
    }

    .footer .footers .footer-nav .flex {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }

    .footer .footers .footer-nav .flex .col {
        width: 100%
    }

    .footer .footers .footer-nav .flex .col:not(:last-child) {
        margin-bottom: 20px
    }
}

@media only screen and (max-width: 768px) {
    .footer {
        padding-top: 75px
    }

    .footer .register-column {
        padding-bottom: 75px
    }

    .footer .footer-disclaimer {
        text-align: center
    }

    .footer .footer-disclaimer .flex {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }

    .footer .footer-disclaimer .col {
        width: 100%
    }

    .footer .footer-disclaimer .col:first-child {
        padding-right: 0
    }
}

@media only screen and (max-width: 640px) {
    .footer {
        padding-top: 50px
    }

    .footer .register-column {
        padding-bottom: 50px
    }

    .footer .footers {
        padding-top: 50px;
        padding-bottom: 50px
    }

    .footer .footers:before {
        content: none
    }

    .footer .footers .col-6 {
        padding-top: 0;
        padding-right: 0;
        padding-bottom: 0;
        padding-left: 0
    }

    .footer .footers .col-6:first-child {
        margin-bottom: 50px
    }

    .footer .footers .footer-cta .text {
        max-width: 100%
    }

    .footer .footers .footer-nav {
        max-width: 100%
    }

    .footer .footer-disclaimer {
        text-align: left
    }
}

.page-template-page-thank-you .footer {
    padding-top: 0
}

.page-template-page-thank-you .footer .footer-register {
    display: none
}

.page-template-page-thank-you .footer .footer-logo {
    border-top: 0
}

.no-touchevents .footer-social a path {
    -webkit-transition: fill .2s linear;
    transition: fill .2s linear
}

.section-masterplan-getting-here .img-blk.draggable {
    width: 100%;
    max-width: 1220px;
    margin-right: auto;
    margin-left: auto
}

@media only screen and (max-width: 640px) {
    .section-masterplan-getting-here .img-blk.draggable {
        max-width: none
    }
}

.masterplan {
    position: relative;
    z-index: 9
}

.masterplan .masterplan-map {
    position: relative;
    z-index: 0
}

.masterplan .masterplan-map .highlights {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.masterplan .masterplan-map .highlight {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.masterplan .masterplan-map .highlight[data-masterplan=four-seasons-resort] {
    top: calc(22.8205128205% + 15px);
    left: calc(55.3125% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=four-seasons-beachfront-villas] {
    top: calc(24.2307692308% + 15px);
    left: calc(40.0625% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=four-seasons-beachfront-yacht-villas] {
    top: calc(26.9230769231% + 15px);
    left: calc(79% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=four-seasons-marina-residences] {
    top: calc(33.4615384615% + 15px);
    left: calc(59.6875% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=four-seasons-marina-villas] {
    top: calc(42.3076923077% + 15px);
    left: calc(76.1875% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=amanvari-resort] {
    top: calc(11.0256410256% + 15px);
    left: calc(16.6875% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=amanvari-residences] {
    top: calc(42.8205128205% + 15px);
    left: calc(16.9375% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=marina-marina-village] {
    top: calc(68.4615384615% + 15px);
    left: calc(70.75% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=casa-blake] {
    top: calc(58.3333333333% + 15px);
    left: calc(73.125% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=beach-club] {
    top: calc(18.5897435897% + 15px);
    left: calc(30.4375% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=golf-club] {
    top: calc(78.2051282051% + 15px);
    left: calc(20.3125% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=golf-practice-facility] {
    top: calc(66.9230769231% + 15px);
    left: calc(28.0625% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=four-seasons-marina-cove-residences] {
    top: calc(41.0256410256% + 15px);
    left: calc(64.6875% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=yacht-club] {
    top: calc(60.7692307692% + 15px);
    left: calc(65.75% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=lucha-libre] {
    top: calc(90.641025641% + 15px);
    left: calc(63.6875% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=sports-park] {
    top: calc(42.9487179487% + 15px);
    left: calc(34.125% + 15px)
}

.masterplan .masterplan-map .highlight[data-masterplan=delphine] {
    top: calc(43.5897435897% + 15px);
    left: calc(96.25% + 15px)
}

.masterplans {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    z-index: 9;
    top: 20px;
    right: 20px;
    width: 530px;
    max-width: calc(100% - 40px);
    background-color: #fff;
    -webkit-box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, .1);
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, .1)
}

.masterplans .highlight.close {
    top: -12px;
    right: -12px
}

.masterplans .masterplan-popups {
    padding-top: 15px;
    padding-right: 15px;
    padding-bottom: 15px;
    padding-left: 15px
}

.masterplans .masterplan-popups .slick-track {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.masterplans .masterplan-popup {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    height: auto;
    padding-top: 15px;
    padding-right: 15px;
    padding-bottom: 15px;
    padding-left: 15px
}

.masterplans .masterplan-popup .img-blk {
    margin-bottom: 25px
}

.masterplans .masterplan-popup .text {
    margin-bottom: 60px;
    padding-right: 10px;
    padding-left: 10px
}

.masterplans .masterplan-popup .text h2 {
    margin-bottom: 10px
}

.masterplans .masterplan-popup .link {
    margin-top: auto
}

.masterplans .masterplan-link {
    position: absolute;
    bottom: 29px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%)
}

@media only screen and (max-width: 640px) {
    .masterplans .masterplan-popups {
        padding-top: 10px;
        padding-right: 10px;
        padding-bottom: 10px;
        padding-left: 10px
    }

    .masterplans .masterplan-popup {
        padding-top: 10px;
        padding-right: 10px;
        padding-bottom: 10px;
        padding-left: 10px
    }

    .masterplans .masterplan-popup .text {
        padding-right: 0;
        padding-left: 0
    }
}

.map-icons {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none
}

.map-text {
    display: none;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    max-width: 180px;
    padding-right: 20px;
    padding-left: 20px;
    background-color: #fff;
    border: 1px solid #4d2a15;
    -webkit-box-shadow: 0 0 15px rgba(0, 0, 0, .4);
    box-shadow: 0 0 15px rgba(0, 0, 0, .4);
    text-align: center
}

.map-text.anchor-bottom {
    margin-top: -12px;
    padding-top: 10px;
    padding-bottom: 10px;
    -webkit-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%)
}

.map-text.anchor-bottom.anchor-right {
    -webkit-transform: translate(-25%, -100%);
    transform: translate(-25%, -100%)
}

.map-text.anchor-bottom:before {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    bottom: -12px;
    left: 50%;
    width: 0;
    height: 0;
    margin-left: -12px;
    border-style: solid;
    border-width: 12px 12px 0;
    border-color: #4d2a15 rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0)
}

.map-text.anchor-bottom:after {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    width: 15.556px;
    height: 15.556px;
    left: 50%;
    bottom: -7.278px;
    margin-left: -7.778px;
    background-color: #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
}

.map-text.anchor-bottom.anchor-right:before {
    left: 75%
}

.map-text.anchor-bottom.anchor-right:after {
    left: 75%
}

@media only screen and (max-width: 640px) {
    .map-text .map-text {
        width: 75%
    }
}

.residence-option:not(:first-child) {
    display: none
}

.residence-option .column-2:first-child {
    margin-bottom: 50px
}

.residence-stats {
    margin-top: 50px
}

@media only screen and (max-width: 640px) {
    .residence-stats {
        margin-top: 30px
    }
}

.residence-option .gallery .slick-track {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    align-items: stretch
}

.residence-option .gallery .img-blk {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    height: auto
}

.residence-option .gallery .img-blk img {
    -o-object-fit: cover;
    object-fit: cover
}

.available-residence-gallery.gallery .slick-track {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    align-items: stretch
}

.available-residence-gallery.gallery .img-blk {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    height: auto
}

.available-residence-gallery.gallery .img-blk img {
    -o-object-fit: cover;
    object-fit: cover
}

.available-residence-nav p {
    font-weight: 500
}

@media only screen and (max-width: 640px) {
    .available-residence-nav p {
        font-size: 14px
    }
}

.section-available-residence-hero.section-hero .residence-price {
    position: absolute;
    bottom: 0;
    left: 0
}

.residence-floorplans {
    width: 100%;
    max-width: 750px;
    margin-right: auto;
    margin-left: auto
}

.property-locations {
    margin-top: 150px;
    border-top: 1px solid #e6e6e6
}

.property-locations .img-blk {
    position: relative
}

.property-locations .img-blk:after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50%;
    background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 255, 255)), to(rgba(255, 255, 255, 0)));
    background: linear-gradient(0deg, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0) 100%)
}

@media only screen and (max-width: 990px) {
    .property-locations {
        margin-top: 100px
    }
}

@media only screen and (max-width: 768px) {
    .property-locations {
        margin-top: 75px
    }
}

@media only screen and (max-width: 640px) {
    .property-locations {
        margin-top: 50px
    }
}

.page-id-111 [data-residence=studio-residences] .floorplan-gallery img {
    max-width: 275px;
    margin-right: auto;
    margin-left: auto
}

.page-id-111 [data-residence=one-bedroom-residences] .floorplan-gallery img,
.page-id-111 [data-residence=two-bedroom-residences] .floorplan-gallery img {
    max-width: 550px;
    margin-right: auto;
    margin-left: auto
}

.property-views {
    border-top: 1px solid #e6e6e6
}

.virtual-tours .highlights .highlight {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.virtual-tours .highlights .highlight[data-map=west-2] {
    top: calc(28% + 15px);
    left: calc(39% + 15px)
}

.virtual-tours .highlights .highlight[data-map=west-5] {
    top: calc(28% - 30px);
    left: calc(41% + 15px)
}

.virtual-tours .highlights .highlight[data-map=north-g] {
    top: calc(13% + 15px);
    left: calc(57.5% + 15px)
}

.virtual-tours .highlights .highlight[data-map=north-2] {
    top: calc(12% + 15px);
    left: calc(57.5% + 60px)
}

.virtual-tours .highlights .highlight[data-map=north-5] {
    top: calc(11% + 15px);
    left: calc(57.5% + 105px)
}

.virtual-tours .highlights .highlight[data-map=east-g] {
    top: calc(27.5% + 15px);
    left: calc(73% + 15px)
}

.virtual-tours .highlights .highlight[data-map=east-2] {
    top: calc(27.5% - 30px);
    left: calc(75% + 15px)
}

.virtual-tours .highlights .highlight[data-map=east-5] {
    top: calc(27.5% - 75px);
    left: calc(77% + 15px)
}

.virtual-tours .highlights,
.virtual-tours iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.virtual-tours .tours {
    opacity: 0;
    visibility: hidden;
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .7)
}

.virtual-tours .tour {
    position: absolute;
    top: 100px;
    right: 100px;
    bottom: 100px;
    left: 100px
}

.virtual-tours .tours .highlight.close {
    position: absolute;
    bottom: 0;
    right: 0;
    border-radius: 0
}

@media only screen and (max-width: 1250px) {
    .virtual-tours .tour {
        position: absolute;
        top: 50px;
        right: 50px;
        bottom: 50px;
        left: 50px
    }
}

@media only screen and (max-width: 640px) {
    .virtual-tours .tour {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0
    }
}

.listing-video {
    position: relative;
    z-index: 0;
    width: 100%;
    padding-bottom: 56.25%;
    overflow: hidden
}

.listing-video .video-abs {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.listing-video .video-abs .video {
    position: relative;
    padding-bottom: 56.25%
}

.listing-video iframe,
.listing-video .poster {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.listing-video .video-controls {
    position: absolute;
    left: 30px;
    bottom: 30px
}

.listing-video .video-controls span {
    display: inline-block;
    cursor: pointer
}

.listing-video .video-controls span:first-child {
    width: 12px;
    margin-right: 10px
}

.listing-video .video-controls span.fa-pause:before {
    content: "ïŒ"
}

.listing-video .video-controls span.fa-volume-off:before {
    content: "ï€¦"
}

.listing-video .video-controls.paused span.fa-pause:before {
    content: "ï‹"
}

.listing-video .video-controls.unmuted span.fa-volume-off:before {
    content: "ï€¨"
}

.listing-video .poster {
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat
}

.listing-video .poster-play {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 94px;
    height: 94px;
    margin-top: -47px;
    margin-left: -47px;
    cursor: pointer
}

@media only screen and (max-width: 640px) {
    .listing-video .video-controls {
        left: 15px;
        bottom: 10px
    }

    .listing-video .poster-play {
        width: 74px;
        height: 74px;
        margin-top: -37px;
        margin-left: -37px
    }
}

.no-touchevents .listing-video .poster-play {
    -webkit-transition: -webkit-transform .4s ease-in-out;
    transition: -webkit-transform .4s ease-in-out;
    transition: transform .4s ease-in-out;
    transition: transform .4s ease-in-out, -webkit-transform .4s ease-in-out
}

.no-touchevents .listing-video .poster-play:hover {
    -webkit-transform: scale(1.2);
    transform: scale(1.2)
}

.register-column {
    position: relative;
    width: 100%;
    max-width: 830px;
    margin-right: auto;
    margin-left: auto
}

.section-background {
    padding-bottom: 75%;
    background-position: 50% 100%;
    background-size: cover;
    background-repeat: no-repeat
}

.section-background .logos a,
.section-background .logos img {
    display: inline-block;
    vertical-align: middle
}

.section-background .logos a {
    margin-right: 40px;
    margin-bottom: 30px;
    margin-left: 40px
}

@media only screen and (min-width: 769px) {
    .section-background {
        padding-bottom: 55%
    }
}

@media only screen and (max-width: 768px) {
    .section-background {
        padding-bottom: 65%;

        

    }
}

@media only screen and (max-width: 640px) {
    .section-background {
        padding-bottom: 75%
    }
}

@media only screen and (max-width: 470px) {
    .section-background {
        padding-bottom: 85%
    }
}

@media only screen and (max-width: 430px) {
    .section-background {
        padding-bottom: 450px
    }

    .section-background h1 {
        margin-bottom: 40px
    }

    .section-background .logos {
        margin-bottom: 10px
    }

    .section-background .logos a {
        margin-bottom: 40px
    }
}

.section-excellence .logo-tile {
    display: inline-block;
    vertical-align: middle;
    margin-bottom: 18px;
    padding-left: 9px;
    padding-right: 9px
}

.section-excellence .logo-tile .tile {
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 190px;
    height: 115px;
    padding-right: 10px;
    padding-left: 10px;
    background-color: #f2f2f2
}

.section-excellence .logo-tile .tile img {
    max-width: 100%;
    height: auto
}

@media only screen and (max-width: 475px) {
    .section-excellence .logo-tiles {
        margin-right: -9px;
        margin-left: -9px
    }

    .section-excellence .logo-tile {
        width: 50%
    }

    .section-excellence .logo-tile .tile {
        width: 100%
    }
}

.the-content .flex:not(.flex-reverse) .has-text {
    padding-left: 60px
}

.the-content .flex-reverse .has-text {
    padding-right: 60px
}

@media only screen and (max-width: 1024px) {
    .the-content .flex .col-6:first-child {
        margin-bottom: 50px
    }

    .the-content .flex:not(.flex-reverse) .has-text {
        padding-left: 0
    }

    .the-content .flex-reverse .has-text {
        padding-right: 0
    }
}

.page-template-page-contact .section-standard.section-contact {
    padding-bottom: 75px
}

@media only screen and (max-width: 990px) {
    .page-template-page-contact .section-standard.section-contact {
        padding-bottom: 25px
    }
}

@media only screen and (max-width: 768px) {
    .page-template-page-contact .section-standard.section-contact {
        padding-bottom: 0px
    }
}

@media only screen and (max-width: 640px) {
    .page-template-page-contact .section-standard.section-contact {
        padding-bottom: 0px
    }
}

.has-contact {
    margin-right: -20px;
    margin-left: -20px
}

.has-contact .col-4 {
    margin-bottom: 75px;
    padding-right: 20px;
    padding-left: 20px
}

@media only screen and (max-width: 640px) {
    .has-contact {
        margin-right: 0px;
        margin-left: 0px
    }

    .has-contact .col-4 {
        margin-bottom: 50px;
        padding-right: 0;
        padding-left: 0
    }
}

.section-thank-you {
    min-height: calc(100vh - 157px);
    background-image: url(images/production/wp-content/themes/costapalmas/src/images/thank-you/AdobeStock_514373049.jpg);
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat
}

.section-thank-you .column,
.section-thank-you .column-1b {
    min-height: calc(100vh - 157px)
}

.section-thank-you .column-1b {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    padding-top: 50px;
    padding-bottom: 50px
}

@media only screen and (max-width: 1024px) {
    .section-thank-you {
        min-height: calc(100vh - 120px);
        background-image: url(images/production/wp-content/themes/costapalmas/src/images/thank-you/1366/AdobeStock_514373049.jpg)
    }

    .section-thank-you .column,
    .section-thank-you .column-1b {
        min-height: calc(100vh - 120px)
    }
}

@media only screen and (max-width: 640px) {
    .section-thank-you {
        min-height: calc(100vh - 100px)
    }

    .section-thank-you .column,
    .section-thank-you .column-1b {
        min-height: calc(100vh - 100px)
    }
}