@import url('https://fonts.googleapis.com/css2?family=Afacad+Flux:wght@100..1000&family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Alex+Brush&display=swap');

:root{
    --oe-dark-blue: #00204b;
    --oe-green: #0d452e;
    --oe-granite: #424141;
    --oe-gold: #efbf04;
}

body{
    padding: 0;
    margin: 0;
    height: 100%;
    width: 100%;
    font-family: 'Afacad Flux', sans-serif;
    font-size: 16px;
    color: #FFF;
}

#oceansedgeTeaser {
    object-fit: cover;
    object-position: center;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100%;
}

.logo_splash {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    z-index: 1;
}

.logo_splash img{
    filter: drop-shadow(2px 4px 6px black);
    width: 90%;
    max-width: 500px;
}

#splash_text {
    color: #FFF;
    text-shadow: 2px 4px 6px black;
    margin-top: 5vh;
    line-height: 1.25;
    opacity: 0;
    text-align: center;
    display: flex;
    flex-direction: column;
}

#splashMain {
    font-size: 6rem;
    font-family: 'Playfair Display', serif;
    font-weight: 100;
    margin-bottom: 0;
}

#splashTagline {
    font-size: 2rem;
    font-weight: 100;
    text-transform: uppercase;
}

@media (max-width:768px){
    #splashMain {
        font-size: 4rem;
    }
    #splashTagline {
        font-size: 1.5rem;
    }
}

.animation_complete{
    margin-top: 0 !important;
    opacity: 1 !important;
    left: 0 !important;
    margin-left: 0 !important;
}

.navbar{
    color: #FFF;
    height: 100px;
    padding: 20px;
    border-bottom: 1px solid #FFF;
    transition: .3s background-color;
    background-color: rgba(0, 32, 75, 0.6);
}

.home .navbar{
    background-color: transparent;
}

.opaque{
    background-color: var(--oe-dark-blue) !important;
    transition: .3s background-color;
}

.navbar .container-fluid{
    width: max-content;
}

.nav-item{
    margin: 0 20px;
}

.nav-link{
    color: #FFF;
    display: inline-block;
    position: relative;
    text-transform: uppercase;
}

.navbar-nav{
    align-items: center;
}

.navbar-nav .nav-link.active{
    color: #FFF;
}

.navigation__mobile_hamburger{
    display: none;
}

#nav-icon3 {
    width: 35px;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    -o-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
    cursor: pointer;
}
  
#nav-icon3 span {
    display: block;
    position: absolute;
    height: 3px;
    width: 100%;
    background: #FFF;
    opacity: 1;
    left: 0;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: .25s ease-in-out;
    -moz-transition: .25s ease-in-out;
    -o-transition: .25s ease-in-out;
    transition: .25s ease-in-out;
}
  

#nav-icon3 span:nth-child(1) {
    top: 0px;
}

#nav-icon3 span:nth-child(2),#nav-icon3 span:nth-child(3) {
    top: 12px;
}

#nav-icon3 span:nth-child(4) {
    top: 24px;
}

#nav-icon3.open span:nth-child(1) {
    top: 12px;
    width: 0%;
    left: 50%;
}

#nav-icon3.open span:nth-child(2) {
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
}

#nav-icon3.open span:nth-child(3) {
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

#nav-icon3.open span:nth-child(4) {
    top: 18px;
    width: 0%;
    left: 50%;
}

#mobileNav{
    display: none;
}

@media (max-width:991px){
    .navbar-brand{
        margin-right: 0;
    }

    .navigation__mobile_hamburger {
        position: absolute;
        right: 1.5rem;
        top: 50%;
        transform: translateY(-50%);
        font-size: 35px;
        display: block;
        width: max-content;
        cursor: pointer;
        height: calc(50% - 24px);
        z-index: 999;
    }

    #mobileNav {
        position: fixed;
        display: block;
        top: 0;
        right: -100%;
        width: 100%;
        height: 100vh;
        background-color: var(--oe-dark-blue);
        transition: .4s all;
        padding-top: 3rem;
        z-index: 3;
    }

    #mobileNav:before{
        content: '';
        background-image: url('../img/oceansedge_o_light.svg');
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        position: absolute;
        opacity: .07;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        z-index: 0;
    }

    .mobile_open {
        right: 0 !important;
        transition: .4s all;
    }

    .mobile_nav__container{
        height: 100%;
        position: relative;
    }

    #mobileNav ul{
        list-style: none;
    }

    #mobileNav li{
        margin-bottom: 2rem;
        font-size: 1.5rem;
    }

    .mobile_social{
        position: absolute;
        bottom: 4.8rem;
        left: 50%;
        transform: translateX(-50%);
        font-size: 2rem;
    }
}

.ad_container{
    background-color: #5b8baf;
}

.ad_banner{
    font-weight: bold;
    color: #FFF;
    border-top: 1px solid #FFF;
    border-bottom: 1px solid #FFF;
}

.booknow{
    padding: 10px 20px;
    border: 2px solid #FFF;
    background-color: transparent;
    color: #FFF;
    transition: .2s all;
    width: max-content;
}

.booknow:hover{
    color: #333;
    background-color: #FFF;
    transition: .2s all;
}

main{
    min-height: 100vh;
}

footer{
    background-color: var(--oe-dark-blue);
    padding: 2.4rem 0;
    font-size: 1.2rem;
}   

.footer_left{
    text-align: right;
    padding-right: 2.4rem;
    border-right: 1px solid #FFF;
    display: flex;
    align-items: center;
}

.footer_logo{
    width: 100%;
    max-width: 220px;
}

.footer_center{
    padding-left: 2.4rem;
    display: flex;
    justify-content: center;
    flex-direction: column;

}

.footer_right{
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.footer_links{
    width: max-content;
    color: white;
    text-decoration: none;
    display: inline-block;
    position: relative;
}

@media (max-width: 991px){
    .footer_left{
        justify-content: center;
        padding-right: 0;
        border-right: none;
    }
    
    .footer_center{
        margin-top: 5vh;
        text-align: center;
        padding-left: 0;
    }

    .footer_right{
        margin-top: 5vh;
        align-items: center;
    }
}

.callout_component__container{
    margin: 10vh auto;
    position: relative;
}

.callout_component__container::before {
    z-index: -1;
    content: '';
    background-image: url('../img/oceansedge_o_dark.svg');
    background-size: auto 100%;
    background-position: 85% center;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    opacity: .05;
}

.callout_component{
    min-height: 60vh;
    height: 100%;
}

.callout_component__image{
    display: flex;
    align-items: center;
}

.callout_component__image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    max-height: 60vh;
}

.callout_component__info{
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: var(--oe-granite);
}

.callout_component__container.reverse:before{
    background-position: 15% center;
}

@media (max-width: 991px){
    .callout_component__container:before, .callout_component__container.reverse:before {
        background-position: center;
        background-size: 100%;
    }
}

h1{
    font-size: 1.2rem;
    text-transform: uppercase;
}

h2{
    font-size: 3rem;
    font-family: 'Playfair Display', serif;
    color: #FFF;
    line-height: 1;
}

.slide_text h2{
    font-size: 2.5rem;
    font-family: 'Playfair Display', serif;
    color: #FFF;
    letter-spacing: -1px;
}

.callout_component h2, .swal2-title h2{
    color: var(--oe-granite) !important;
}

h3{
    font-size: 2rem; 
    font-weight: 100;
    text-transform: uppercase;
}

p:not(.testimonial_card p){
    margin-top: 2rem;
    margin-bottom: 2rem;
    font-size: 1.2rem;
}

.callout_component .booknow, .sanctuary__container .booknow, .attractions_card__overlay .booknow, .contact__form .booknow, .poi_card .booknow, .button__container .booknow{
    padding: 10px 20px;
    border: 2px solid var(--oe-granite);
    background-color: transparent;
    color: var(--oe-granite);
    transition: .2s all;
}

.callout_component .booknow:hover, .sanctuary__container .booknow:hover,  .attractions_card__overlay .booknow:hover, .contact__form .booknow:hover, .poi_card .booknow:hover, .button__container .booknow:hover{
    color: #FFF;
    background-color: var(--oe-granite);
    transition: .2s all;
}

.attractions_headline{
    text-align: center;
    margin: 5vh 0 10vh;
}

.attractions_headline p{
    max-width: 60%; 
    margin: 1rem auto 0;
}

.home_slider__container{ 
    margin: 20vh 0;
    position: relative;
}

.home_slider{
    margin: 0 auto;
    max-width: 1024px;
}

.home_slide{
    display: flex !important;
}

.slide_text{
    background-color: var(--oe-dark-blue);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.slide_image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.prev, .next{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 75px;
    cursor: pointer;
    z-index: 2;
}

.prev{
    left: calc((100vw - 1280px) / 2);
}

.next{
    right: calc((100vw - 1280px) / 2);
}

.prev img, .next img{
    width: 100%;
}


@media (max-width: 1280px){
    .prev{
        left: 0;
    }

    .next{
        right: 0;
    }
}

@media (max-width: 991px){
    .prev, .next{
        filter: brightness(10) drop-shadow(0 0 5px #000);
    }
}

.home_features__container{
    margin: 10vh 0;
    background-image: url('../img/oceansedge_home_features_bg.jpg');
    background-size: cover;
    background-position: center;
}

.home_features__right{
    min-height: 60vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
}



.testimonials__container{
    margin: 20vh 0 10vh;
    color: var(--oe-granite)
}

.testimonial_card__container{
    padding: 2.4rem;
    display: flex;
    flex-basis: 33%;
    height: 100%;
}

.testimonial_card{
    height: 100%;
    /*border-radius: 10px;
    padding: 2.4rem;
    box-shadow: 5px 5px 40px 0 rgba(0,0,0,.2);*/
    position: relative;
    text-align: left;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/*.testimonial_card:before{
    content: '\f10e';
    font-family: 'FontAwesome';
    position: absolute;
    top: -20px;
    left: 20px;
    height: 50px;
    width: 50px;
    font-size: 1.5rem;
    background-color: var(--oe-gold);
    color: #FFF;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
}*/

.testimonial_card p{
    font-size: 1.2rem;
}




.testimonials__row .slick-slide > div{
    height: 100%;
}

.testimonials_nav{
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.testimonials_nav__row{
    display: flex;
}

.testimonials_prev, .testimonials_next{
    cursor: pointer;
}

.testimonials_prev img, .testimonials_next img{
    width: 75px;
    height: 75px;
}


.testimonials_image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.testimonials_mobile_nav{
    display: none;
}

@media (max-width:991px){
    .testimonials_nav h2{
        text-align: center;
    }
    
    .testimonials_nav__row{
        display: none;
    }

    .testimonials_image{
        padding: 2.4rem;
    }

    .testimonials_mobile_nav{
        display: flex;
        justify-content: center;
    }
}

.sanctuary__container{
    margin: 10vh 0;
}

.sanctuary__slider .slick-slide{
    transition: .3s all;
}

.sanctuary__slider .slick-current{
    transform: scale(1.25);
    transition: .3s all;
}

.sanctuary__button{
    padding-top: 4rem;
    text-align: center;
}

.sanctuary__container .slick-dots{
    width: max-content;
    right: 2.4rem;
    bottom: 10px;
}

.sanctuary__slide img{
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    padding: 2.4rem;
}

.sanctuary__container .slick-dots li button:before{
    font-size: .75rem;
    content: '\f0c8';
    font-family: 'FontAwesome';
    transform: rotate(45deg);
}

@media (max-width:991px){
    .sanctuary__container .slick-dots{
        left: 50%;
        transform: translateX(-50%);
        bottom: -30px;
    }

    .sanctuary__slide img{
        width: 100%; 
        height: 100%; 
        object-fit: cover; 
        padding: 1.2rem;
    }
}


.island__container{
    position: relative; 
    height: 826px; 
    background: rgb(255,255,255); 
    background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(237,237,237,1) 16%);
}

.island__map{
    position: absolute; 
    top: 0; 
    left: 0; 
    width: 100%; 
    height: 100%; 
    background-image: url('../img/oceansedge_map2.png'); 
    background-position: left bottom; 
    background-size: contain; 
    background-repeat: no-repeat;
    z-index: 0;
}

.island__text{
    position: relative; 
    top: 0; 
    left: 0; 
    width: 100%; 
    height: 100%; 
    z-index: 1;
}

@media (max-width:991px){
    .island__container{
        background: none;
        height: auto;
    }

    .island__map{
        position: relative;
        height: 40vh;
        background-size: 185vw;
        background-image: url('../img/oceansedge_map2.png'), linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(237,237,237,1) 12%);
    }
}


.oceansedge__hero{
    height: 60vh;
    background-size: cover;
    background-position: center;
    position: relative;
}

#theoceansedge{
    background-image: url('../img/oceansedge_oceansedge.jpg');
}

#attractions{
    background-image: url('../img/attractions_hero.jpg');
}

#booknow{
    background-image: url('../img/booknow_hero.jpg');
}

.oceansedge__hero-text{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.underlay{
    height: 60vh;
    width: 100%; 
    position: absolute; 
    top: 0; 
    left: 0; 
    background-color: var(--oe-granite);
}

@media (max-width:991px){
    .oceansedge__hero-text{
        text-align: center;
    }
}

.fullwidth_callout_component__row{
    min-height: 60vh;
}

.fullwidth_callout_component__text{
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    min-height: 60vh;
}

a, a:hover, .nav-link:hover{
    color: #FFF;
    text-decoration: none;
}

a.nav-link::after, a.footer_links::after {
    content: '';
    position: absolute;
    width: 100%;
    transform: scaleX(0);
    height: 2px;
    bottom: 0;
    left: 0;
    background-color: #FFF;
    transition: transform 0.25s ease-out;
  }
  
a.nav-link:hover::after, a.footer_links:hover::after {
    transform: scaleX(1);
}
  
a.nav-link.center::after, a.footer_links:hover::after {
    transform-origin: bottom center;
}
  
a.nav-link.center:hover::after, a.footer_links:hover::after {
    transform-origin: bottom center;
}

.oegray{
    color: var(--oe-granite);
}

.oeblue{
    color: var(--oe-dark-blue);
}

a.oegray:hover{
    color: var(--oe-granite);
    text-decoration: underline;
}

.oegreen{
    color: var(--oe-green)
}

.fw700{
    font-weight: 700;
}

.font-weight-bold{
    font-weight: bold;
}

.font-italic{
    font-style: italic;
}

.noscroll{
    overflow: hidden;
}

.btn-close{
    --bs-btn-close-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23FFF'><path d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/></svg>");
}