@font-face {
    font-family: 'Assistant';
    src: url('../fonts/Assistant-Bold.woff2') format('woff2'),
        url('../fonts/Assistant-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Assistant';
    src: url('../fonts/Assistant-Regular.woff2') format('woff2'),
        url('../fonts/Assistant-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Light.woff2') format('woff2'),
        url('../fonts/Poppins-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Medium.woff2') format('woff2'),
        url('../fonts/Poppins-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Bold.woff2') format('woff2'),
        url('../fonts/Poppins-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Regular.woff2') format('woff2'),
        url('../fonts/Poppins-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'OldStandardTT';
    src: url('../fonts/OldStandardTT-Regular.woff2') format('woff2'),
        url('../fonts/OldStandardTT-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Prossima Moda PERSONAL USE';
    src: url('../fonts/ProssimaModaPERSONALUSE-Regular.woff2') format('woff2'),
        url('../fonts/ProssimaModaPERSONALUSE-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

html,
body {
    color: #222222;
}

h1 {
    font-family: "Poppins", system-ui;
    font-weight: 300;
    font-style: normal;
    font-size: 32px;
    line-height: 1.4;
}

h2 {
    font-family: "OldStandardTT", system-ui;
    font-weight: 300;
    font-style: normal;
    font-size: 30px;
    line-height: 1.2;
}

h3 {
    font-family: "OldStandardTT", system-ui;
    font-weight: 400;
    font-style: normal;
    font-size: 28px;
    line-height: 1.2;
}

h4 {
    font-family: "Poppins", system-ui;
    font-weight: 300;
    font-style: normal;
    font-size: 24px;
}

h5 {
    font-family: "Krub", system-ui;
    font-weight: 400;
    font-style: normal;
    font-size: 16px;
}

p,
li {
    font-family: "Poppins", system-ui;
    font-weight: 300;
    font-style: normal;
    font-size: 15px;
    line-height: 1.8;
}

span {
    font-family: inherit;
    font-weight: inherit;
    font-style: inherit;
    font-size: inherit;
    line-height: inherit;
}

strong {
    font-weight: 700;
}

.artist-impression p{
    font-family: 'Assistant', system-ui;
    position: absolute;
    color: #FFFFFF;
    font-size: 12px;
    margin-bottom: 0;
    left: 10px;
    bottom: 10px;

}

.owl-carousel .owl-nav .owl-prev {
    left: -30px;
}

.owl-carousel .owl-nav .owl-next {
    right: -30px;
}

.owl-carousel .owl-nav .owl-prev svg,
.owl-carousel .owl-nav .owl-next svg {
    transform: scale(1.4);
}

.owl-carousel .owl-nav .owl-next,
.owl-carousel .owl-nav .owl-prev {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
}

#float-icon {
    position: fixed;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
}

#float-register,
#float-whatsapp,
#float-waze {
    display: block;
}

#float-register img {
    border-radius: 100%;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
    -moz-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
}

#float-whatsapp img {
    border-radius: 100%;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
    -moz-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
}

#float-waze img {
    border-radius: 100%;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
    -moz-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.45);
}

.modal-dialog {
    max-width: 90vw;
    margin: 0 auto;
}

@keyframes animatedBackground {
    from {
        background-size: 120% auto;
    }

    to {
        background-size: 140% auto;
    }
}

@keyframes animatedDesignBackground {
    from {
        background-size: 140% auto;
    }

    to {
        background-size: 160% auto;
    }
}

.navbar .nav-item>.nav-link {
    text-transform: uppercase;
    font-family: "Poppins", system-ui;
    font-weight: 300;
}

.navbar .nav-item:not(:last-child)>.nav-link {
    padding: 0.5rem 1rem;
}

.navbar .nav-item>.nav-link.active,
.navbar .nav-item>.nav-link:hover {
    color: #2B432F;
}

.navbar .nav-item>.nav-link.active {
    font-weight: 700;
}

.navbar-toggler {
    width: 20px;
    height: 20px;
    position: relative;
    transition: .5s ease-in-out;
}

.navbar-toggler,
.navbar-toggler:focus,
.navbar-toggler:active,
.navbar-toggler-icon:focus {
    outline: none;
    box-shadow: none;
    border: 0;
    position: relative;
}

.navbar-toggler span {
    margin: 0;
    padding: 0;
}

.toggler-icon {
    display: block;
    position: absolute;
    height: 2px;
    width: 100%;
    background: #222222;
    border-radius: 1px;
    opacity: 1;
    left: 0;
    transform: rotate(0deg);
    transition: .25s ease-in-out;
}

.middle-bar {
    margin-top: 0px;
}

/* State when the navbar is collapsed */

.navbar-toggler.collapsed .top-bar {
    position: absolute;
    top: 0px;
    transform: rotate(0deg);
}

.navbar-toggler.collapsed .middle-bar {
    opacity: 1;
    position: absolute;
    top: 10px;
    filter: alpha(opacity=100);
}

.navbar-toggler.collapsed .bottom-bar {
    position: absolute;
    top: 20px;
    transform: rotate(0deg);
}

/* when navigation is clicked */

.navbar-toggler .top-bar {
    top: inherit;
    transform: rotate(135deg);
}

.navbar-toggler .middle-bar {
    opacity: 0;
    top: inherit;
    filter: alpha(opacity=0);
}

.navbar-toggler .bottom-bar {
    top: inherit;
    transform: rotate(-135deg);
}

/* Color of 3 lines */

.navbar-toggler.collapsed .toggler-icon {
    background: #222222;
}

#banner {
    background-color: #2B432F;
    overflow: hidden;
}

#banner #logo-container {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}

#banner #ijm-logo {
    max-width: 140px;
}

#banner .background {
    position: relative;
    background-image: url('../images/banner.webp');
    background-size: 120% auto;
    background-repeat: no-repeat;
    background-position: center;
    animation: animatedBackground 15s linear infinite alternate;
}

#banner .background:after {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    content: '';
    width: 100%;
    height: 100%;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0) 100%);
}

#banner .background #title {
    position: relative;
    z-index: 1;
    padding: 55vh 0 5vh;
}

#banner .background #title h1 {
    letter-spacing: 4px;
}

#experience {
    overflow: hidden;
    position: relative;
}

#experience:before {
    background-image: url('../images/experience-texture.webp');
    background-size: 60px 60px;
    opacity: 0.2;
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
}

#experience .wrapper {
    margin: 120px auto;
}

#features{
    overflow: hidden;
}

#features .content {
    padding: 80px 0;
}

#features .content h4 {
    color: #78A2B8;
}

#features .content .aos-init.aos-animate .box {
    border: 1px solid #78A2B8;
    border-radius: 15px;
    position: relative;
    clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
    animation: .65s cubic-bezier(1, -0.01, .12, .8) 0s 1 reveal forwards;
}

#features .content .aos-init.aos-animate .box::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #78A2B8;
    padding: inherit;
    animation: .65s cubic-bezier(1, -0.01, .12, .8) 0.75s 1 hideBlack forwards;
    border-radius: 10px;
}

@keyframes reveal {
    from {
        clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
    }

    to {
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    }
}

@keyframes hideBlack {
    from {
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    }

    to {
        clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
    }
}

#features .content .box ul {
    list-style: none;
    padding-left: 0;
    margin-bottom: 0;
}

#features .content .box ul li {
    color: #78A2B8;
}

#facilities{
    overflow: hidden;
}

#facilities #facilities-slider {
    margin: 0 0 120px;
    position: relative;
}

#facilities #facilities-slider #card {
    background-color: #E2E1DC;
    max-width: 35%;
    position: absolute;
    top: 10%;
    transform: translateY(-10%);
    left: 35px;
    z-index: 2;
}

#facilities #facilities-slider #card #facilities-name .owl-stage {
    display: flex;
}

#facilities #facilities-slider #card #facilities-name .owl-stage .owl-item {
    display: flex;
    flex: 1 0 auto;
}

#facilities #facilities-slider #card #facilities-name .owl-dots .owl-dot {
    width: 15px;
    height: 15px;
    background-color: #A1988B;
    border-radius: 15px;
    margin-right: 10px;
    opacity: 0.5;
}

#facilities #facilities-slider #card #facilities-name .owl-dots .owl-dot:last-child {
    margin-right: 0;
}

#facilities #facilities-slider #card #facilities-name .owl-dots .owl-dot.active {
    opacity: 1;
}

#hotspot {
    background-color: #78A2B8;
    overflow: hidden;
    position: relative;
}

#hotspot:before {
    background-image: url('../images/hotspot-texture.webp');
    background-size: 100px 100px;
    opacity: 0.4;
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
}

#hotspot .wrapper {
    margin: 120px auto;
}

#hotspot #hotspots .image h3 {
    position: absolute;
    top: 25px;
    left: 25px;
}

#hotspot #hotspots .image #greenre-logo {
    position: absolute;
    top: 100px;
    left: 25px;
}

#hotspot #hotspots #hotspot-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

#hotspot #hotspots h5 {
    color: #45719E;
}

#hotspot #hotspots #hotspot-container .hotspot {
    width: 130px;
    height: 130px;
    display: block;
    background-color: #FFFFFF;
    border-radius: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transition: all 0.4s ease;
    transform: translate(-50%, -50%) scale(0.2);
    opacity: 1;
}

#hotspot #hotspots #hotspot-container .hotspot:before {
    content: "";
    position: relative;
    display: block;
    width: 300%;
    height: 300%;
    box-sizing: border-box;
    margin-left: -100%;
    margin-top: -100%;
    border-radius: 100%;
    background-color: #FFFFFF;
    -webkit-animation: pulse-ring 1.25s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
    animation: pulse-ring 1.25s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
    pointer-events: none;
}

#hotspot #hotspots #hotspot-container .hotspot:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    width: 100%;
    height: 100%;
    background-color: #FFFFFF;
    border-radius: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
    -webkit-animation: pulse-dot 1.25s cubic-bezier(0.455, 0.03, 0.515, 0.955) -0.4s infinite;
    animation: pulse-dot 1.25s cubic-bezier(0.455, 0.03, 0.515, 0.955) -0.4s infinite;
    pointer-events: none;
}

#hotspot #hotspots #hotspot-container .hotspot.pause:before,
#hotspot #hotspots #hotspot-container .hotspot.pause:after {
    animation-play-state: none;
}

#hotspot #hotspots #hotspot-container .hotspot.active {
    transform: translate(-50%, -50%) scale(1);
}

#hotspot #hotspots #hotspot-container .hotspot.active span.desktop {
    display: block !important;
    color: #222222;
    padding: 0.5rem;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 100%;
    text-align: center;
    z-index: 1;
}

#hotspot #hotspots #hotspot-container .hotspot.active:before {
    opacity: 0;
}

#hotspot #hotspots #hotspot-container .hotspot.active:after {
    opacity: 0;
}

#hotspot .hotspot-legends {
    color: #FFFFFF;
    list-style-type: none;
}

#hotspot .hotspot-legends li {
    position: relative;
    padding-left: 0.5rem;
    margin-bottom: 1rem;
}

#hotspot .hotspot-legends li h5 {
    font-size: 14px;
}

#hotspot .hotspot-legends li .number {
    position: absolute;
    left: -2rem;
    top: -3px;
    width: 24px;
    height: 24px;
    text-align: center;
    background-color: #FFFFFF;
    border-radius: 100%;
    line-height: 1.6;
    color: #222222;
}

@keyframes pulse-ring {
    0% {
        transform: scale(0.33);
    }

    80%,
    100% {
        opacity: 0;
    }
}

@keyframes pulse-dot {
    0% {
        transform: scale(0.8);
    }

    50% {
        transform: scale(1);
    }

    100% {
        transform: scale(0.8);
    }
}

#overview {
    background-color: #E2E0DD;
    padding: 120px 0;
    overflow: hidden;
}

#overview .nav-pills .nav-link {
    background-color: #FFFFFF;
    color: #78A2B8;
    border-radius: 20px;
}

#overview .nav-pills .nav-link.active {
    background-color: #78A2B8;
    color: #FFFFFF;
    border-radius: 20px;
}

#overview .owl-dots{
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    text-align: center;
}

#overview .owl-dots .owl-dot {
    width: 15px;
    height: 15px;
    background-color: #FFFFFF;
    border-radius: 15px;
    margin-right: 10px;
    opacity: 1;
}

#overview .owl-dots .owl-dot.active {
    background-color: #78A2B8;
}

#sitemap {
    padding: 120px 0 40px;
    overflow: hidden;
}

#sitemap .zoom p {
    color: #222222;
}

#sitemap #residents p {
    color: #F05A28;
}

#sitemap #residents span {
    width: 20px;
    height: 20px;
    border-radius: 20px;
    background-color: #F05A28;
}

#sitemap #residents h5 {
    background-color: #F05A28;
    color: #FFFFFF;
    padding: 0.5rem 1rem;
}

#sitemap #residents ol {
    padding-left: 1.5rem;
}

#sitemap #residents ol li.active {
    font-weight: 500;
}

#sitemap #public p {
    color: #6D474B;
}

#sitemap #public span {
    width: 20px;
    height: 20px;
    border-radius: 20px;
    background-color: #6D474B;
}

#sitemap #public h5 {
    background-color: #6D474B;
    color: #FFFFFF;
    padding: 0.5rem 1rem;
}

#sitemap #public ol {
    padding-left: 1.5rem;
}

#sitemap #public ol li.active {
    font-weight: 500;
}

#sitemap sup{
    line-height: 1.6;
    display: block;
}

#floorplan {
    padding: 120px 0;
    overflow: hidden;
}

#floorplan h5 {
    background-color: #dde5e1;
    font-size: 12px;
    width: 100%;
    text-align: center;
    padding: 0.5rem 1rem;
}

iframe {
    display: block;
}

footer {
    background-color: #E2E0DD;
    overflow: hidden;
    position: relative;
}

footer:before {
    background-image: url('../images/hotspot-texture.webp');
    background-size: 100px 100px;
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
}

footer .wrapper {
    margin: 120px auto;
}

footer h5{
    font-size: 14px;
}

footer p sup {
    font-size: 10px;
    line-height: 1.3;
    display: block;
}

footer #terms a{
    font-size: 12px;
    color: #222222;
    text-decoration: none;
}

#introduction #all-facilities #facilities .owl-stage {
    display: flex;
    flex-wrap: wrap;
}

#introduction #all-facilities #facilities .item {
    height: 100%;
    display: flex;
    flex-direction: column;
}

#introduction #all-facilities #facilities .item .content {
    border: 1px solid #004155;
    background-color: transparent;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

#introduction #all-facilities #facilities .item .content h4 {
    font-size: 20px;
    color: #004155;
}

#introduction #all-facilities #facilities .item .content p {
    color: #004155;
}

#introduction #all-facilities #facilities .item .content:hover {
    border: 1px solid #FFFFFF;
    background-color: #FFFFFF;
}

#introduction #all-facilities #facilities .owl-dots {
    text-align: center;
    margin-top: 40px;
}

#introduction #all-facilities #facilities .owl-dots .owl-dot {
    width: 15px;
    height: 15px;
    background-color: #A1988B;
    border-radius: 15px;
    margin-right: 10px;
    opacity: 0.5;
}

#introduction #all-facilities #facilities .owl-dots .owl-dot:last-child {
    margin-right: 0;
}

#introduction #all-facilities #facilities .owl-dots .owl-dot.active {
    opacity: 1;
}

#introduction #all-facilities #view-all {
    margin-top: 30px;
    color: #004155;
    display: inline-block;
    width: 100%;
    text-align: center;
    font-size: 18px;
}

#living {
    background-color: #C1B59A;
    padding: 120px 0;
    overflow: hidden;
}

#living .living-image #living-image-1 {
    position: absolute;
    top: 30%;
    left: -3%;
    max-width: 60%;
    transition: all 0.7s ease;
}

#living .living-image #living-image-2 {
    position: absolute;
    top: -20%;
    right: 0%;
    max-width: 48%;
    transition: all 0.7s ease;
}

#living .living-image.active #living-image-1 {
    top: 15%;
}

#living .living-image.active #living-image-2 {
    top: 0%;
}

#living .plan {
    border: 1px solid #FFFFFF;
    background-color: transparent;
    color: #222222;
    padding: 1rem 2.5rem;
    width: 100%;
    max-width: 200px;
    display: block;
    margin: 0 auto;
    text-align: center;
    text-decoration: none;
}

#living .plan:hover {
    border: 1px solid #FFFFFF;
    background-color: #FFFFFF;
}

#living #view-floorplan,
#living #view-aerial {
    color: #FFFFFF;
    font-size: 18px;
}

#living #living-gallery {
    position: relative;
}

#living #living-gallery-tag {
    background-color: rgba(0, 0, 0, 0.2);
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 10%;
    border: 1px solid #FFFFFF;
    padding: 1rem 2rem;
    width: 100%;
    max-width: 70%;
    z-index: 2;
    text-align: center;
}

#living #living-gallery #living-gallery-image {
    position: relative;
    z-index: 1;
}

#living #living-gallery:before {
    content: '';
    display: block;
    background-image: url('../images/living-1.webp');
    background-size: 264px 595px;
    background-repeat: no-repeat;
    position: absolute;
    right: -55%;
    top: -18%;
    height: 595px;
    width: 100%;
    z-index: 0;
}

#living #living-gallery:after {
    content: '';
    display: block;
    background-image: url('../images/living-2.webp');
    background-size: 217px 490px;
    background-repeat: no-repeat;
    position: absolute;
    left: -15%;
    bottom: -20%;
    height: 490px;
    width: 100%;
    z-index: 0;
}

#living #living-content {
    position: relative;
    z-index: 1;
}

#living #living-content #view-gallery {
    font-size: 18px;
}

#living .accordion {
    width: 220px;
}

#living .accordion .accordion-item {
    background-color: transparent;
    border: 0;
}

#living .accordion .accordion-item,
#living .accordion .accordion-item button {
    border-radius: 0;
}

#living .accordion .accordion-item .accordion-button {
    border-top: 1px solid #004155;
    box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 #004155;
}

#living .accordion .accordion-item .accordion-button.collapsed {
    background-color: transparent;
    color: #004155;
    border-top: 1px solid #FFFFFF;
    box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 #FFFFFF;
}

#living .accordion .accordion-item:not(:last-child) .accordion-button.collapsed {
    box-shadow: none;
}

#living .accordion .accordion-item .accordion-button {
    background-color: #004155;
    color: #FFFFFF;
}

#living .accordion .accordion-item a {
    text-decoration: none;
}

#living .accordion .accordion-item a p {
    color: #004155;
}

#living .accordion .accordion-item .accordion-button::after {
    -webkit-mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23aaaaaa'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23aaaaaa'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    background: #004155;
}

#living .accordion .accordion-item .accordion-button:not(.collapsed)::after {
    -webkit-mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23aaaaaa'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23aaaaaa'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    background: #FFFFFF;
}

#oasis {
    background-color: #F2F2F2;
    padding: 120px 0;
    overflow: hidden;
}

#oasis #oasis-image {
    border-top: 40px solid #FFFFFF;
    border-bottom: 40px solid #FFFFFF;
    border-left: 15px solid #FFFFFF;
    border-right: 15px solid #FFFFFF;
}

#oasis #oasis-image-title {
    letter-spacing: 1rem;
    margin-right: -1rem;
    position: absolute;
    top: 30%;
    left: 50%;
    transform: translateX(-50%);
    transition: all 0.7s ease;
}

#oasis #oasis-image-title.active {
    letter-spacing: 0.4rem;
    margin-right: -0.4rem;
}

#usp {
    background-color: #004155;
    padding: 120px 0;
}

#register {
    background-color: #568aa4;
    padding: 120px 0 60px;
    overflow: hidden;
}

#register h3 {
    font-family: 'Poppins', system-ui;
    font-weight: 300;
}

#register video{
    width: 100%;
    height: auto;
}

#register #required {
    color: #222222;
}

#register form{
    background-color: #78A2B8;
}

#register #form-container form label {
    color: #222222;
    transform: scale(.85) translateY(-.5rem) translateX(.15rem)
}

#register #form-container form input {
    border-radius: 0;
    background-color: #E6E6E6;
    color: #333333;
    padding: 2.35rem .75rem 1.15rem;
    height: 100%;
}

#register #form-container form select {
    border-radius: 0;
    background-color: #E6E6E6;
    color: #333333;
    padding: 2.25rem .75rem 1rem;
}

#register #form-container form label[for="country-code"] {
    position: absolute;
    top: 0.75rem;
    left: 0.45rem;
}

#register #form-container form input~label {
    color: #222222;
}

#register #form-container form input~label:after {
    background-color: transparent;
}

#register #form-container form .form-check input {
    padding: 5px;
    width: 30px;
    height: 30px;
    display: inline-block;
    float: none;
}

#register #form-container form .form-check input:checked[type="checkbox"] {
    --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%2360B6C6' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e") !important;
}

#register #form-container form .form-check label {
    left: -20px;
    top: -33px;
    position: relative;
}

#register #form-container form button[type="submit"] {
    outline: 0;
    appearance: none;
    background: 0;
    border: none;
    background-color: #E6E6E6;
    color: #222222;
    padding: 1rem 2.25rem;
}

#register #form-container form button[type="submit"]:hover {
    background-color: #97673e;
}


#register #contact {
    color: #278AA7;
}

#register a {
    color: #d3d3d3;
}

#register a:hover {
    color: #bfbfbf;
}

.beacon,
.beacon-two,
.beacon-three {
    position: absolute;
    background-color: transparent;
    height: 1.2vw;
    width: 1.2vw;
    border-radius: 50%;
    opacity: 0;
}

.beacon.active,
.beacon-two.active,
.beacon-three.active {
    -webkit-animation: grow .4s 1 linear;
    animation: grow .4s 1 linear;
    opacity: 1;
}

.beacon:before,
.beacon-two:before,
.beacon-three:before {
    position: absolute;
    content: "";
    height: 1.2vw;
    width: 1.2vw;
    background-color: transparent;
    border-radius: 50%;
    top: 0%;
    left: 0%;
}

.beacon.residents:before,
.beacon-two.residents:before,
.beacon-three.residents:before {
    box-shadow: 0px 0px 10px 10px #F7941D;
}

.beacon.public:before,
.beacon-two.public:before,
.beacon-three.public:before{
    box-shadow: 0px 0px 10px 10px #6D474B;
}

.beacon.active:before,
.beacon-two.active:before,
.beacon-three.active:before {
    -webkit-animation: active 2s infinite linear;
    animation: active 2s infinite linear;
}

@keyframes grow {
    0% {
        transform: scale(.1);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes active {
    0% {
        transform: scale(.1);
        opacity: 1;
    }

    70% {
        transform: scale(2.5);
        opacity: 0;
    }

    100% {
        opacity: 0;
    }
}

@media (max-width: 1399.98px) {

    @keyframes animatedBackground {
        from {
            background-size: 160% auto;
        }

        to {
            background-size: 180% auto;
        }
    }

}

@media (max-width: 1199.98px) {

    .navbar .nav-item>.nav-link {
        font-size: 13px;
    }

    .beacon,
    .beacon-two,
    .beacon-three {
        height: 1.6vw;
        width: 1.6vw;
    }

    .beacon:before,
    .beacon-two:before,
    .beacon-three:before {
        height: 1.6vw;
        width: 1.6vw;
    }
}


@media (max-width: 991.98px) {

    @keyframes animatedBackground {
        from {
            background-size: 160% auto;
        }

        to {
            background-size: 180% auto;
        }
    }

    h1 {
        font-size: 20px;
        line-height: 1.3;
    }

    h2 {
        font-size: 36px;
        line-height: 1.2;
    }

    .navbar .nav-item:first-child>.nav-link {
        padding-top: 1.5rem;
    }

    .navbar .nav-item>.nav-link {
        padding: 0.5rem 1rem;
        font-size: initial;
    }

    #banner .background {
        background-image: url('../images/banner-mobile.webp');
        background-size: 100% auto;
    }

    #banner .con

    #hotspot #hotspots .image h3 {
        position: relative;
        top: auto;
        left: auto;
    }

    #hotspot #hotspots .image #greenre-logo {
        position: relative;
        top: auto;
        left: auto;
        max-width: 80px;
    }

    #facilitie-slider h4 {
        font-size: 18px;
    }

    #facilities #facilities-slider #card {
        max-width: 100%;
        position: relative;
        left: auto;
        top: auto;
        transform: none;
        height: auto;
    }

    #introduction #effortless-title span#or {
        margin: 0 1rem 0 2.7rem;
    }

    #livingFloorplanModal .accordion {
        max-width: 100%;
    }

}

@media (max-width: 767.98px) {

    .owl-carousel .owl-nav .owl-prev {
        left: -25px;
    }

    .owl-carousel .owl-nav .owl-next {
        right: -25px;
    }

    #banner #ijm-logo {
        max-width: 90px;
    }

    #banner .background #title {
        padding: 38vh 0 2vh;
    }

    #banner .background #title img{
        max-width: 260px;
    } 

    #experience .wrapper {
        margin: 80px 0;
    }

    #hotspot .wrapper {
        margin: 80px 0
    }

    #hotspot #hotspots .image h3{
        position: relative;
        top: 0;
        left: 0;
    }

    #hotspot #hotspots #hotspot-container .hotspot {
        width: 70px;
        height: 70px;
        font-size: 10px;
    }

    #hotspot #hotspots #hotspot-container .hotspot.active span.desktop {
        display: none !important;
    }

    #hotspot #hotspots #hotspot-container .hotspot span.mobile {
        display: block !important;
        color: #222222;
        padding: 0.5rem;
        position: absolute;
        top: 50%;
        left: 0;
        transform: translateY(-50%) scale(4);
        width: 100%;
        text-align: center;
        z-index: 1;
    }

    #overview {
        padding: 80px 0 40px;
    }

    #overview .owl-dots{
        position: relative;
        bottom: 0;
        left: 0;
        transform: none;
    }

    #sitemap {
        padding: 80px 0;
    }

    #floorplan {
        padding: 0 0 80px;
    }

    #register {
        padding: 80px 0 40px;
    }

    #register img {
        max-width: 180px;
    }

    #register h3 {
        font-size: 22px;
    }

    #register #form-container form .form-check label{
        left: 0px;
    }

    footer .wrapper {
        margin: 80px 0;
    }

}