@font-face {
    font-family: eicons;
    src: url(../fonts/eicons.woff);
    src: url(../fonts/eicons.eot) format("embedded-opentype"), url(../fonts/eicons.woff2) format("woff2"), url(../fonts/eicons.woff) format("woff"), url(../fonts/eicons.ttf) format("truetype");
    font-weight: 400;
    font-style: normal
}

[class*=" eicon-"],
[class^=eicon] {
    display: inline-block;
    font-family: eicons;
    font-size: inherit;
    font-weight: 400;
    font-style: normal;
    font-variant: normal;
    line-height: 1;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

:root {
    --primary-color: #000;
    --secondory-color: #7e9e8f, serif;
}

html {
    scroll-behavior: smooth
}

[data-toggle="modal"] {
    cursor: pointer;
}

body {
    font-family: "Outfit", sans-serif;
}

img {
    max-width: 100%
}

.ptb {
    padding: 70px 0
}

.ptb-40 {
    padding: 40px 0;
}

/* header section start here */

header {
    position: absolute;
    top: 0;
    z-index: 99;
    background-color: transparent;
    width: 100%
}

header .container {
    max-width: 90%
}

header .navbar-brand img {
    width: 100%;
    max-width: 140px;
    filter: invert(1) brightness(100);
}

header .header-wrapper {
    display: flex;
    width: 100%;
    position: relative;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
}

header .navbar-nav {
    flex-direction: row
}

header ul li {
    padding: 0 14px
}

header ul li a {
    color: #fff;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 1px;
}

header .header_button {
    padding: 12px 30px;
    border: none;
    background: var(--primary-color);
    color: #fbe486;
    border-radius: 10px;
}

header .navbar-nav .nav-link:hover {
    color: var(--primary-color)
}

header.fixed-header {
    position: fixed;
    background-color: #FFFCF5
}

header.fixed-header .navbar-brand img {
    filter: unset;
}

header.fixed-header .navbar-nav .nav-link {
    color: var(--primary-color)
}

/* header section ends here */

/* banner section start here */

.banner_section .banner_content {
    position: absolute;
    top: 20%;
    left: 7%;
    color: #fff;
    z-index: 9;
}

.banner_section .carousel-inner::before {
    position: absolute;
    width: 100%;
    height: 100%;
    background: #000;
    top: 0;
    left: 0;
    opacity: 1%;
    transition: background .3s ease 0s, border-radius .3s ease 0s, opacity .3s ease 0;
    content: "";
    z-index: 1
}

.banner_section .side_content {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: #00000054;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    writing-mode: vertical-rl;
    z-index: 9
}

.banner_section .my-box {
    height: 100%;
    width: 100%
}

.banner_section .my-box ul {
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    list-style: none;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0 18px
}

.banner_section .my-box ul li {
    transform: rotate(180deg);
    display: flex;
    align-items: center
}

.banner_section .location {
    transform: rotate(268deg)
}

.banner_section h1.title {
    font-size: 55px;
    /* font-family:var(--secondory-font); */
    padding: 5px 0;
    margin-bottom: 0;
    font-weight: 400;
}

.banner_section .icon_img {
    transform: rotate(90deg);
    width: 100%
}

.banner_section .call_img {
    filter: invert(1)
}

.banner_section .my-box ul li a {
    color: #fff
}

.banner_section .my-box ul li span {
    padding-top: 10px
}

.banner_section h5.small_title {
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 8px
}

.banner_section .bottom_content {
    position: absolute;
    bottom: 3%;
    width: 52%;
    left: 7%;
    z-index: 9
}

.banner_section .bottom_content .item_box {
    display: flex;
    width: 100%;
    align-items: center;
    line-height: normal;
    margin-left: 350px;
    padding: 0
}

.banner_section .bottom_content .item .inner {
    background: #000000ba;
    padding: 15px 40px;
    border-radius: 20px;
    border: 1px solid #55A630;
    color: #55A630;
}

.banner_section .bottom_content .item {
    padding: 5px;
    border-radius: 20px;
    border: 1px solid #55A630;
    margin: 0 5px
}

.banner_section .bottom_content .item .inner p {
    font-size: 20px;
    text-align: center;
    /* font-family:var(--secondory-font); */
    letter-spacing: 1px;
    margin-bottom: 0;
    font-weight: 600
}

.banner_section .right_form {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 22%;
    height: auto;
    z-index: 9;
    border-radius: 10px;
    border: 0;
}

.banner_section .form_sec {
    padding: 15px 15px;
    background: #ffffff8a;
    /* opacity:.95; */
    backdrop-filter: blur(25px);
}

.banner_section h2.typo {
    /* letter-spacing:2px; */
    font-weight: 500;
    font-size: 30px;
}

.banner_section ul.key_high {
    margin: 15px 0 0;
    padding: 10px 0 0
}

.banner_section ul.key_high li {
    list-style: none;
    padding: 5px 0;
    /* letter-spacing:1.1px; */
    font-size: 18px;
    /*text-transform: capitalize;*/
    position: relative;
    margin-bottom: 14px;
}

.banner_section ul.key_high li img {
    padding-right: 8px;
    left: 12px;
    /* position:absolute; */
    filter: brightness(5.5);
}

/* Force specific words inside key_high list to stay lowercase (e.g. 'to') */
.banner_section ul.key_high li .lowercase-text {
    text-transform: none;
}

/* Make the '12 to 45 Feet Road in Society' text sit in a single flex row */
.banner_section ul.key_high li .key-flex-row {
    display: inline-flex;
    align-items: center;
    gap: 0;
    /* default: no extra gap on desktop */
}

@media (max-width: 767px) {
    .banner_section ul.key_high li .key-flex-row {
        gap: 4px;
        /* small gap only on mobile */
    }
}

.banner_section.banner_btn {
    margin-top: 30px
}

.banner_btn {
    text-align: center;
}

/* Left-align banner button when used inside side_content (Get Detailed Pricing) */
.side_content .banner_btn {
    text-align: left;
}

/* Left-align banner button in overview section (Download Brochure under text) */
.overview .banner_btn {
    text-align: left;
}

.banner_btn button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 13px 30px;
    border: none;
    background-color: #ffffffa8;
    color: #fff;
    /* text-transform:uppercase; */
    letter-spacing: 1px;
    font-size: 18px;
    position: relative;
    border-radius: 10px;
    backdrop-filter: blur(25px);
    background-color: #bc8c2c;
}

/* Anchor version of banner button (e.g. Download Brochure link) */
.banner_btn .download-brochure-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 13px 30px;
    border: none;
    background-color: #bc8c2c;
    color: #fff;
    letter-spacing: 1px;
    font-size: 18px;
    position: relative;
    border-radius: 10px;
    backdrop-filter: blur(25px);
    text-decoration: none;
}

/* Align arrow icon nicely within the download brochure button */
.banner_btn .download-brochure-btn .icon-next {
    top: 0;
}

/* Align arrow icon for regular banner buttons (e.g. Get Detailed Pricing) */
.banner_btn button .icon-next {
    top: 0;
}

.icon-next {
    position: relative;
    top: -.1em;
    margin-left: .6em;
    vertical-align: middle;
    display: inline-block;
    width: .94em;
    height: .75em;
    background: url(../images/icon/next.png) 0 0 / .94em .75em no-repeat;
    filter: brightness(100%);
}

.banner_section ul.key_high li span {
    background: #000000a6;
    /* padding:8px 15px 8px 45px; */
    /* border-radius:10px; */
    color: #ffffff;
    /* backdrop-filter: blur(25px); */
    padding: 1px 7px;
}

.banner_section .bottom_content .item .inner p span.key {
    font-size: 30px;
    padding-bottom: 10px;
    margin-bottom: 15px;
    display: inline-block;
    border-bottom: 2px dotted #55A630;
}

.banner_section h2.form_title {
    font-size: 36px;
    color: #000000;
    margin-bottom: 15px;
    text-align: center;
}

.banner_section .right_form .form-control {
    border-radius: 0;
    background-color: rgba(255, 255, 255, 0.85);
    padding: 12px 15px;
    border: none;
    background: transparent;
    border: 1px solid #000000;
    color: #000000;
    border-radius: 8px;
}

.banner_section button.btn.main_button {
    color: #fff;
    background: #000;
}

.banner_section .right_form .form-control::placeholder {
    color: #000000;
}

button.btn.main_button {
    background: transparent;
    border-radius: 9px;
    border: 1px solid #fff;
    color: #fff;
    display: inline-block;
    width: 100%
}

.form-control::placeholder {
    color: var(--primary-color)
}

.banner_section .carousel_btns {
    position: relative;
    height: 100%;
    z-index: 9
}

.banner_section .carousel_btns button {
    width: 80px;
    height: 80px;
    background: #000000c7;
    opacity: 1;
    border-radius: 10px;
}

.banner_section .carousel_btns img {
    max-width: 35px;
}

.banner_section .carousel-control-prev {
    left: 66%;
    top: unset
}

.banner_section .carousel-control-next {
    left: unset;
    top: unset;
    right: 25%
}

/* .carousel-item img {height: 100vh;} */

.banner-img {
    height: 100vh;
    width: 100vw;
    /*object-fit: cover;*/
}

.banner_section .bottom_content .item .inner p {
    display: flex;
    flex-direction: column;
}

/* banner section end here */

.item_wrap {
    padding: 20px;
    background-color: #fff;
}

.item_wrap:hover {
    background-color: #55A630;
    transition: 0.50s;
}

.price_section .banner_btn button {
    background-color: #bc8c2c;
    color: #ffffff;
}

.price_section .icon-next {
    filter: unset;
}

.modal-header .close {
    position: absolute;
    right: 18px;
    top: 14px;
}

/* overview section start here */

.overview {
    position: relative;
    background-image: url(../images/download.png);
    background-position: center center;
    background-size: 100%;
    overflow: hidden;
}

.overview::after {
    content: attr(data-name);
    font-size: 80px;
    position: absolute;
    line-height: 100px;
    color: #6d6d6d;
    font-weight: 600;
    opacity: .1;
    text-transform: uppercase;
    right: 24px;
    writing-mode: tb-rl;
    top: 50%;
    transform: translateY(-50%);
    height: 100%;
    text-align: center;
}

.overview .container {
    position: relative;
    z-index: 1;
    padding-left: 16px;
    padding-right: 16px;
}

.overview .overview_bg {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 0;
    pointer-events: none;
}

.overview .overview_bg img {
    width: 100%;
    height: auto;
    display: block;
    opacity: 0.25;
}

.overview .row {
    align-items: center;
    position: relative;
    z-index: 1;
}

.overview .img_section {
    position: relative;
    overflow: unset;
    padding-top: 60px;
    padding-bottom: 60px
}

.overview .first_img {
    padding: 5px;
    margin-right: 0;
    z-index: 1;
    position: absolute;
    top: 0;
    left: -49px;
    width: 60%;
    height: 180px;
    object-fit: cover;
    background-color: #fff
}

.overview .second_img {
    margin-left: 150px;
    margin-top: 20px;
    position: relative
}

.overview .second_img::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    right: 60px;
    top: 60px;
    border: 5px solid #f8f8f8;
    z-index: -1
}

.overview .content_section p {
    line-height: 1.6;
    color: #777
}

.overview .title_section h3.title {
    font-weight: 600
}

.overview .title_section h3.title span {
    font-size: 18px;
}

.title_section h4.pro_title {
    position: relative;
    display: inline-block;
    padding-bottom: 10px;
    color: #ddae58;
}

.title_section .pro_title::before {
    content: "";
    position: absolute;
    top: 15px;
    right: -70px;
    height: 1px;
    width: 60px;
    background-color: #bc8c2c;
}

.overview .banner_btn button {
    font-size: 18px;
    font-family: 'Outfit';
    text-transform: capitalize;
    letter-spacing: 1px;
}

.overview .image_section img {
    width: 100%;
    max-width: 100%;
    width: 100%;
    max-width: 100%
}

/* overview section ends here */

/* heighlight section start here */

.highlight_section {
    background-image: linear-gradient(180deg, #f8f8f8 0%, #f4f6f8 100%);
    position: relative;
    background-repeat: no-repeat;
    background-position: left center;
    background-color: #f8f8f8;
    z-index: 1
}

.highlight_section ul {
    padding: 0;
    list-style: none;
    margin: 0
}

.highlight_section ul li {
    margin-bottom: 10px;
    display: flex;
    align-items: center;
}

.highlight_section span.number {
    box-shadow: #e2e2e3 0 0 0 5px inset;
    font-size: 20px;
    font-weight: 700;
    color: #212529;
    display: inline-block;
    text-align: center;
    border-radius: 3px;
    /* width:70px; */
    /* height:70px; */
    /* line-height:70px; */
    padding: 10px 16px;
    /* margin-left: 10px; */
    /* margin-right: 10px; */
}

.highlight_section .highlight_point {
    padding-left: 8px;
    text-transform: uppercase;
}

.highlight_section .content_section ul {
    padding: 0;
    margin: 0;
    list-style: none;
    margin-top: 30px
}

.highlight_section .row {
    align-items: center
}

.highlight_section .highlight_img_wrap {
    position: relative;
    display: inline-block;
    overflow: visible;
}

.highlight_section .highlight_img_wrap img {
    display: block;
    max-width: 100%;
    height: auto;
}

.highlight_section .highlight_img_wrap::before,
.highlight_section .highlight_img_wrap::after {
    content: "";
    position: absolute;
    width: 120px;
    height: 120px;
    border-color: #c41e3a;
    border-style: solid;
    border-width: 0;
    z-index: 1;
}

.highlight_section .highlight_img_wrap::before {
    top: -4px;
    left: -4px;
    border-top-width: 5px;
    border-left-width: 5px;
}

.highlight_section .highlight_img_wrap::after {
    bottom: -4px;
    right: -4px;
    border-bottom-width: 5px;
    border-right-width: 5px;
}

.highlight_section::after {
    content: attr(data-name);
    font-size: 80px;
    position: absolute;
    line-height: 100px;
    color: #6d6d6d;
    font-weight: 600;
    z-index: -1;
    opacity: .1;
    text-transform: uppercase;
    left: 25px;
    writing-mode: tb-rl;
    top: 50%;
    transform: rotate(180deg) translateY(50%);
    height: 100%;
    text-align: center;
}

/* heighlight section ends here */

/* amenities section start here */

.amenities_section::after {
    content: attr(data-name);
    font-size: 80px;
    position: absolute;
    line-height: 100px;
    color: #6d6d6d;
    font-weight: 600;
    opacity: .1;
    text-transform: uppercase;
    right: 25px;
    /* writing-mode:tb-rl; */
    top: 3%;
    /* transform:translateY(-50%); */
    /* height:100%; */
    text-align: center;
}

.amenities_section {
    background-color: #FFFCF5;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.amenities_section .amenities_wrapper {
    display: flex;
    align-items: normal;
    justify-content: center;
    padding-top: 50px;
    position: relative;
    left: -11%
}

.amenities_section .wrap {
    display: flex
}

.amenities_section .amenities_wrapper .title {
    background: #000;
    padding: 50px;
    color: #bc8c2c;
    position: relative;
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.amenities_section .amenities_wrapper .title P {
    color: #fff;
}

.amenities_section .amenities_wrapper .title:before {
    content: "";
    border: 4px solid #fff;
    display: block;
    width: 100%;
    height: 100%;
    top: -10px;
    left: 10px;
    position: absolute
}

.amenities_section .amenities_wrapper .title h2 {
    font-weight: 600;
    letter-spacing: 1px
}

.amenities_section .row {
    align-items: center;
    height: 100%
}

.amenities_section .image_wrapper {
    width: 50%
}

.amenities_section .image_wrapper img {
    width: 100%;
    min-width: 500px;
    height: 350px;
    min-height: 350px;
    object-fit: cover;
    object-position: top;
}

ul.slick-dots {
    position: absolute;
    bottom: -25px;
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    text-align: center;
    line-height: 1
}

ul.slick-dots li {
    position: relative;
    display: inline-block;
    width: 20px;
    height: 20px;
    margin: 0;
    padding: 0;
    cursor: pointer
}

ul.slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 20px;
    height: 20px;
    padding: 5px;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: none;
    background: transparent
}

ul.slick-dots li button:before {
    font-family: eicons;
    font-size: 6px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    content: '\e914';
    text-align: center;
    opacity: .25;
    color: #000;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

ul.slick-dots li.slick-active button:before {
    font-size: 14px;
    opacity: .75;
    color: #000
}

/* amenities section ends here */

/* price section start here */

.price_section .item_wrap {
    padding: 30px 15px;
    color: #000;
    box-shadow: rgba(0, 0, 0, 0.06) 0 2px 8px, rgba(0, 0, 0, 0.03) 0 4px 12px;
    text-align: center;
    border-radius: 14px;
    background-color: #FFFCF5
}

.price_section .item_wrap .title h3 {
    font-size: 24px;
    font-family: var(--primary-font);
    padding: 10px;
    margin-bottom: 0px
}

.price_section .item_wrap .price {
    border-bottom: 1px dashed var(--primary-color);
    margin-bottom: 20px;
    padding-bottom: 10px
}

.price_section .item_wrap .size p {
    font-size: 22px;
    font-weight: 500
}

.price_section .price_inner {
    margin-top: 40px
}

.price_section .item_wrap .title h3 {
    background: var(--primary-color);
    color: #fff;
    width: 100%
}

.price_section .item_wrap .price span {
    font-size: 20px
}

.price_btn button {
    font-size: 16px;
    letter-spacing: 1.4px;
    padding: 12px 24px
}

.price_section .item_wrap .title {
    border: 1px solid #000;
    padding: 2px;
    margin-bottom: 20px;
}

.price_section .price_inner .col-lg-4 {
    margin-bottom: 15px
}

.price_section {
    position: relative;
    overflow: hidden;
}

.price_section .container {
    position: relative;
}

.price_section .container>.title_section,
.price_section .container>.row {
    position: relative;
    z-index: 2;
}

.price_section .price_section_bg {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 1;
    pointer-events: none;
}

.price_section .price_section_bg img {
    width: 100%;
    height: auto;
    display: block;
    opacity: 0.25;
}

.price_section::after {
    content: attr(data-name);
    font-size: 80px;
    position: absolute;
    line-height: 100px;
    color: #6d6d6d;
    font-weight: 600;
    z-index: -1;
    opacity: .1;
    text-transform: uppercase;
    left: 25px;
    writing-mode: tb-rl;
    top: 50%;
    transform: rotate(180deg) translateY(50%);
    height: 100%;
    text-align: center
}

/* price section ends here */

/* floorplan start here */

.floor_plan .item_wrap .title {
    background-color: var(--primary-color);
    color: #55A630;
    text-align: center;
    margin-top: 20px;
    padding: 10px;
    margin-bottom: 0;
    border-radius: 10px
}

.floor_plan .img_sec {
    border: 1px solid var(--primary-color);
    padding: 8px;
    border-radius: 14px;
    object-fit: contain;
}

.floor_plan .img_sec img {
    cursor: pointer;
    filter: blur(4px);
}

.floor_plan.ptb .title_section {
    margin-bottom: 40px
}

.floor_plan {
    position: relative;
    background-color: #f8f8f8
}

.floor_plan::after {
    content: attr(data-name);
    font-size: 80px;
    position: absolute;
    line-height: 100px;
    color: #6d6d6d;
    font-weight: 600;
    opacity: .1;
    text-transform: uppercase;
    right: 24px;
    writing-mode: tb-rl;
    top: 50%;
    transform: translateY(-50%);
    height: 100%;
    text-align: center
}

.floor_plan .row .col-lg-4 {
    margin-bottom: 15px
}

.inp-box {
    display: flex;
    align-items: baseline;
    padding-top: 0;
}

.inp-box p.inp-txt {
    font-size: 9px;
    margin-bottom: 0;
}

.location_section .card-header {
    background-color: transparent;
    border: none;
    border-radius: 0;
    border-bottom: 1px solid #c8b4b4;
    padding: 20px 14px 20px 0
}

.location_section .card-body span.time {
    font-weight: 600
}

.location_section .card {
    border: none;
    background-color: initial
}

.location_section .card-header h5 {
    margin-bottom: 0;
    font-weight: 600;
    text-transform: capitalize;
    font-size: 18px;
    cursor: pointer;
}

.location_section .card-body {
    padding: 10px 0
}

.location_section .title_section {
    padding-bottom: 5px
}

.location_section {
    position: relative;
    background-color: #FFFCF5
}

.location_section .card-body p {
    display: flex;
    justify-content: space-between;
    background-color: #FFFCF5;
    color: #020202;
    padding: 8px 10px;
    align-items: center;
    margin-bottom: 0;
    font-weight: 500
}

.location_section .row {
    align-items: center
}

.location_section .content_wrap {
    padding: 0 90px 0 40px
}

.location_section .card-header h5 img {
    padding-right: 10px
}

.location_section .image_section {
    position: relative;
}

.location_section .image_section .title {
    background-color: var(--primary-color);
    color: #fbe486;
    text-align: center;
    margin-top: 20px;
    padding: 10px;
    margin-bottom: 0;
    border-radius: 10px;
}

.location_section .get_direction {
    margin-top: 15px;
}

.location_section .get-direction-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 24px;
    border-radius: 10px;
    background-color: #bc8c2c;
    color: #fff;
    font-size: 16px;
    letter-spacing: 1px;
    text-decoration: none;
}

.location_section .get-direction-btn .icon-next {
    margin-left: .6em;
    top: 0;
}

/* gallery-section */
#gallery {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.gallery_section .galler_item {
    padding-bottom: 30px;
}

.gallery_section .title_section {
    padding-bottom: 40px;
}

/* Gallery highlights – featured cards carousel (one-by-one) */
.gallery-highlights-wrap {
    position: relative;
}

.gallery-highlights-slider {
    overflow: hidden;
}

.gallery-highlights-slider .slick-list {
    margin: 0 -8px;
}

.gallery-highlights-slider .slick-slide {
    padding: 0;
}

.gallery-highlights-slider .slick-slide>div {
    margin: 0;
    width: 100%;
    box-sizing: border-box;
}

.gallery-highlights-slider .gallery-highlight-card {
    margin: 0 8px;
    width: calc(100% - 16px);
    max-width: calc(100% - 16px);
    box-sizing: border-box;
}

.gallery-highlight-card {
    position: relative;
    border-radius: 0;
    overflow: hidden;
    box-sizing: border-box;
    background: #FFFCF5;
    aspect-ratio: 3 / 4;
    min-height: 280px;
    will-change: transform;
    transform: translateZ(0);
}

.gallery-highlight-card__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    will-change: transform;
    /* background: #FFFCF5; */
}

.gallery-highlight-card:hover .gallery-highlight-card__img {
    transform: scale(1.04);
}

.gallery-highlight-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(26, 26, 46, 0.55) 0%, rgba(26, 26, 46, 0.18) 45%, transparent 72%);
    pointer-events: none;
}

.gallery-highlight-card__label {
    position: absolute;
    top: 16px;
    right: 16px;
    font-size: 20px;
    font-weight: 300;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.9);
}

.gallery-highlight-card__content {
    position: absolute;
    inset: auto 0 0 0;
    padding: 24px 20px;
    color: #fff;
    box-sizing: border-box;
}

.gallery-highlights-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-top: 28px;
}

.gallery-highlights-prev,
.gallery-highlights-next {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1.5px solid #555;
    background: transparent;
    color: #333;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
    flex-shrink: 0;
}

.gallery-highlights-prev:hover,
.gallery-highlights-next:hover {
    background: #222;
    border-color: #222;
}

.gallery-highlights-prev:hover .icon-next,
.gallery-highlights-next:hover .icon-next {
    filter: brightness(0) invert(1);
}

.gallery-highlights-prev .icon-next {
    display: inline-block;
    transform: rotate(180deg);
    margin-left: 0;
    top: 0;
}

.gallery-highlights-next .icon-next {
    margin-left: 0;
    top: 0;
}

.gallery-highlights-view-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 32px;
    background: #222;
    color: #fff;
    border: none;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s ease;
}

.gallery-highlights-view-more:hover {
    background: #000;
}

.gallery-highlights-dots {
    text-align: center;
    margin-top: 20px;
}

.gallery-highlights-dots .slick-dots {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: center;
    gap: 8px;
}

.gallery-highlights-dots .slick-dots li {
    margin: 0;
}

.gallery-highlights-dots .slick-dots li button {
    width: 10px;
    height: 10px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: #ccc;
    font-size: 0;
    cursor: pointer;
    transition: background 0.2s;
}

.gallery-highlights-dots .slick-dots li.slick-active button {
    background: #000;
}

/* Gallery highlights – responsive */
@media (max-width: 991px) {
    .gallery-highlight-card {
        min-height: 260px;
    }
}

@media (max-width: 767px) {
    .gallery-highlights-controls {
        gap: 12px;
        margin-top: 20px;
    }
    .floor_plan::after{
        content: none !important;
    }

    .gallery-highlights-prev,
    .gallery-highlights-next {
        width: 34px;
        height: 34px;
    }

    .gallery-highlights-view-more {
        padding: 9px 24px;
        font-size: 12px;
    }

    .gallery-highlight-card {
        aspect-ratio: 3 / 4;
        min-height: 220px;
    }

    .gallery-highlight-card__content {
        padding: 16px 14px;
    }

    .gallery-highlight-card__stat {
        font-size: clamp(1.6rem, 8vw, 2.2rem);
    }

    .gallery-highlight-card__stat-label {
        font-size: 10px;
        letter-spacing: 0.1em;
    }

    .gallery-highlight-card__desc {
        font-size: 10px;
        margin-top: 4px;
    }

    .gallery-highlight-card__label {
        top: 12px;
        right: 12px;
        font-size: 16px;
    }
}

footer.footer {
    background-color: #FFFCF5;
    text-align: center;
    position: relative;
    overflow: hidden;
    background-image: url(../images/rerea.webp);
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: 100% 100%;
    min-height: 200px;
}

.gallery_section .galler_item img {
    border: 1px solid #FFFCF5;
    padding: 5px;
    border-radius: 15px;
    box-shadow: rgba(17, 17, 26, 0.1) 0 4px 16px, rgba(17, 17, 26, 0.05) 0 8px 32px;
    height: 200px;
    width: 100%;
    object-fit: cover;
}

footer .inner-footer-bottom p {
    margin-bottom: 10px;
}

/* form css */

.right_form {
    position: absolute;
    bottom: 0;
    right: 0;
    /* width:22%; */
    border: 8px solid var(--primary-color);
    height: auto;
    z-index: 9
}

.form_sec {
    padding: 30px 15px;
    background: var(--primary-color);
    /* opacity:.95; */
}

h2.form_title {
    font-size: 36px;
    color: #fff;
    margin-bottom: 15px
}

.right_form .form-control {
    border-radius: 0;
    background-color: transparent;
    padding: 12px 15px;
    border: none;
    color: #fff;
    border: 1px solid #fff;
    border-radius: 8px;
}

.right_form .form-control::placeholder {
    color: #fff;
}

button.btn.main_button {
    background: white;
    border-radius: 9px;
    border: 1px solid #4d4b43;
    color: #000000;
    display: inline-block;
    width: 100%
}

.form-control::placeholder {
    color: var(--primary-color)
}

.contact_section .footer_form {
    position: relative;
    border: none;
    width: 100%;
    max-width: 42%
}

.contact_section .row {
    justify-content: space-between;
    align-items: center
}

.footer_form .form_sec {
    padding: 30px;
    border-radius: 10px;
    opacity: 1
}

.footer_form h2.form_title {
    text-align: center;
    padding-bottom: 4px;
    color: #bc8c2c;
}

/* mobile-trigger */

.mobile-trigger {
    cursor: pointer;
    display: block;
    height: auto;
    line-height: normal;
    padding: 0;
    position: relative;
    right: 15px;
    width: auto;
    z-index: 99999
}

.mobile-trigger i,
.mobile-trigger i:after,
.mobile-trigger i:before {
    background-color: #283b5c;
    border-radius: 1px;
    display: inline-block;
    height: 3px;
    width: 24px;
    position: relative;
    top: 0;
    background-color: #000;
    -webkit-border-radius: 1px;
    -moz-border-radius: 1px;
    border-radius: 1px;
    display: inline-block;
    height: 3px;
    width: 24px
}

.mobile-trigger i:after,
.mobile-trigger i:before {
    content: "";
    position: absolute
}

.mobile-trigger i:before {
    top: -6px
}

.mobile-trigger i:after {
    top: 6px
}

.mobile-open .mobile-trigger i:before {
    background-color: #fff;
    bottom: 0;
    top: 0;
    transform: rotate(-45deg);
    transition: bottom .3s cubic-bezier(.23, 1, .32, 1), transform .3s cubic-bezier(.23, 1, .32, 1) .3s
}

.mobile-open .mobile-trigger i:after {
    background-color: #fff;
    top: 0;
    transform: rotate(45deg);
    transition: top .3s cubic-bezier(.23, 1, .32, 1), transform .3s cubic-bezier(.23, 1, .32, 1) .3s
}

.mobile-open .mobile-trigger i {
    background-color: transparent
}

.mobile-open .mobile_overlay {
    background-color: #000000a1;
    opacity: 1;
    pointer-events: all
}

.mobile-open .navbar-collapse {
    left: 0;
}

.footer p.btm-foot a {
    color: var(--primary-color);
    font-weight: 600
}

.footer h6.moreless-button {

    cursor: pointer
}

.footer .inner-footer-bottom p b {
    color: var(--primary-color)
}

.contact_section {
    background-image: url(../images/bg-map-footer.png)
}

header .header_button img {
    padding-right: 10px
}

.modal-body button.btn.main_button {
    background-color: var(--primary-color);
    margin: 10px 0;
    color: #fff;
    text-transform: capitalize;
}

html,
body {
    background-color: #fff
}

.container {
    width: 100%;
    height: 100%;
    margin: 0 auto
}

.pulse-button span {
    width: 30px;
    height: 30px;
    position: absolute;
    right: 15px;
    top: 15px;
    color: #333;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    float: right
}

.pulse-button img {
    -webkit-animation: wiggle 2s infinite;
    -moz-animation: wiggle 2s infinite;
    animation: wiggle 2s infinite
}

.pulse-button {
    color: #333;
    font-weight: 500;
    position: relative;
    text-align: left;
    border: none;
    box-shadow: 0 0 0 0 #435f54;
    border-radius: 40px;
    background-size: cover;
    background-repeat: no-repeat;
    cursor: pointer;
    -webkit-animation: pulse 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
    -moz-animation: pulse 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
    -ms-animation: pulse 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
    animation: pulse 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
    font-size: 18px;
}

.pulse-button:hover {
    -webkit-animation: none;
    -moz-animation: none;
    -ms-animation: none;
    animation: none
}

.light-logo {
    display: block;
}

.dark-logo {
    display: none;
}

.fixed-header .light-logo {
    display: none;
}

.fixed-header .dark-logo {
    display: block;
}

@-webkit-keyframes pulse {
    to {
        box-shadow: 0 0 0 20px rgba(255, 232, 160, 0);
    }
}

@-moz-keyframes pulse {
    to {
        box-shadow: 0 0 0 20px rgba(255, 232, 160, 0);
    }
}

@-ms-keyframes pulse {
    to {
        box-shadow: 0 0 0 20px rgba(255, 232, 160, 0);
    }
}

@keyframes pulse {
    to {
        box-shadow: 0 0 0 20px rgba(255, 232, 160, 0);
    }
}

/* safari and chrome */

@-webkit-keyframes wiggle {
    0% {
        -webkit-transform: rotate(15deg);
    }

    50% {
        -webkit-transform: rotate(-15deg);
    }

    100% {
        -webkit-transform: rotate(15deg);
    }
}

/* firefox */

@-moz-keyframes wiggle {
    0% {
        -moz-transform: rotate(15deg);
    }

    50% {
        -moz-transform: rotate(-15deg);
    }

    100% {
        -moz-transform: rotate(15deg);
    }
}

/* anyone brave enough to implement the ideal method */

@keyframes wiggle {
    0% {
        transform: rotate(15deg);
    }

    50% {
        transform: rotate(-15deg);
    }

    100% {
        transform: rotate(15deg);
    }
}

.mobile-section {
    position: fixed;
    bottom: 0;
    background-color: var(--primary-color);
    color: #fff;
    z-index: 99;
    width: 100%;
    display: none;
}

.mobile-section a {
    color: #fff;
    box-shadow: 4px 4px 10px rgb(0 0 0 / 10%) !important;
}

footer .inner-footer-bottom p a {

    font-weight: 500;
}

@media (min-width:768px) {
    .mobile-trigger {
        display: none;
    }

    header ul li.nav-item.call_btn {
        display: none;
    }
}

@media (max-width:1480px) {
    header .header-wrapper {
        justify-content: space-around;
    }

    header .navbar-brand img {
        /* max-width: 257px; */
        vertical-align: middle;
        padding: 5px 0 0 0;
    }

    .banner_section ul.key_high li {
        padding: 0px 0;
        font-size: 20px;
        margin-bottom: 13px;
    }

    .banner_section ul.key_high li img {
        max-width: 24px;
    }

    header ul li {
        padding: 0 6px;
    }

    header .header_button {
        padding: 12px 18px
    }

    .banner_section h1.title {
        font-size: 37px
    }

    .banner_section h2.typo {
        font-size: 23px
    }

    .banner_section .bottom_content .item .inner {
        padding: 10px 5px;
        border: none
    }

    .banner_section .carousel_btns button {
        width: 70px;
        height: 70px
    }

    .banner_section .carousel-control-prev {
        left: 64%
    }

    .amenities_section .amenities_wrapper .title {
        padding: 28px
    }

    .banner_section .bottom_content .item .inner p span.key {
        /* margin-bottom:0; */
        font-size: 22px;
        /* padding-bottom:0; */
        /* border:none; */
        margin-left: 0px;
    }

    .banner_btn button {
        font-size: 16px;
        padding: 12px 20px
    }

    .amenities_section .amenities_wrapper .title h2 {
        font-size: 26px
    }

    .amenities_section .amenities_wrapper .title {
        padding: 20px
    }

    .highlight_section span.number {
        padding: 6px 12px;
    }

    .banner_section h2.form_title {
        font-size: 28px
    }

    .banner_section .form_sec {
        padding: 10px
    }

    header .container {
        max-width: 95%
    }

    .location_section .card-header {
        padding: 14px 14px 14px 0;
    }

    .location_section .card-header h5 {
        font-size: 14px;
    }
}

@media (max-width:1367px) {
    header .container {
        max-width: 100%
    }

    header .navbar-brand img {
        vertical-align: middle;
        padding: 5px 0 0 0;
        margin-left: 50px;
    }

    header ul li {
        padding: 0 7px;
    }

    .banner_section .banner_content {
        top: 17%;
    }
}

@media (max-width:1281px) {
    header .container {
        max-width: 100%
    }

    header .navbar-brand img {
        max-width: 220px;
        vertical-align: middle;
        padding: 5px 0 0 0;
    }
}

@media (max-width:767px) {
    .amenities_section .image_wrapper img {
        height: 300px;
        min-height: 300px;
        width: 100%;
        max-width: 500px;
        min-width: 200px;
    }

    .light-logo {
        display: none;
    }

    .dark-logo {
        display: block;
    }

    .mobile-section {
        display: flex;
        justify-content: space-between;
    }

    .overview::after {
        font-size: 40px;
        right: 0;
        line-height: normal;
        top: 11%;
        height: auto;
        content: none
    }

    .highlight_section::after {
        line-height: normal;
        font-size: 40px;
        writing-mode: rl;
        top: 0;
        transform: none;
        height: auto;
        right: 0;
        left: 0;
        content: none
    }

    .highlight_section span.number {
        font-size: 20px;
        /* width:68px; */
        /* height:50px; */
        /* line-height:50px; */
    }

    .amenities_section::after {
        font-size: 40px;
        top: 0;
        line-height: normal
    }

    .amenities_section .amenities_wrapper {
        left: 0
    }

    .amenities_section .wrap>div {
        width: 100%
    }

    .amenities_section .wrap {
        flex-direction: column-reverse
    }

    .amenities_section .amenities_wrapper .title {
        width: 100%;
        padding: 10px;
        background: var(--primary-color);
    }

    .amenities_section .amenities_wrapper .title p {
        display: none
    }

    .amenities_section .amenities_wrapper .title:before {
        content: none
    }

    .amenities_section .amenities_wrapper .title h2 {
        margin-bottom: 0;
        text-align: center
    }

    .floor_plan .item_wrap .title {
        font-size: 20px
    }

    .location_section .content_wrap {
        padding: 30px 0 0
    }

    .contact_section .footer_form {
        max-width: 100%
    }

    .banner_section .banner_content {
        position: relative;
        top: 0;
        left: 0;
        color: #1a1a2e;
        padding: 28px 20px 24px;
        /* Light premium background (brand-friendly) */
        background: linear-gradient(180deg, #faf2e2 0%, #faf2e2 70%);
        border-bottom: 1px solid rgba(0, 0, 0, 0.06);
        box-shadow: 0 12px 26px rgba(0, 0, 0, 0.10);
        border-radius: 0 0 22px 22px;
    }

    .banner_section .banner_content::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 4px;
        background: linear-gradient(90deg, #ddae58 0%, #bc8c2c 55%, #8a5f14 100%);
        opacity: 0.9;
    }

    .banner_section .bottom_content {
        position: relative;
        width: 100%;
        left: auto;
        bottom: auto
    }

    .banner_section .right_form {
        position: relative;
        width: 100%;
        border-radius: 0;
    }

    .banner_section h1.title {
        font-size: 34px;
        padding: 0 0 6px;
        color: #1a1a2e;
        letter-spacing: 0.02em;
        text-shadow: none;
    }

    .banner_section h2.typo {
        font-size: 15px;
        color: rgba(26, 26, 46, 0.72);
        font-weight: 500;
        letter-spacing: 0.04em;
        margin-bottom: 20px;
    }

    .banner_section ul.key_high {
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding: 0;
        margin-bottom: 24px;
    }

    .banner_section ul.key_high li {
        font-size: 14px;
        letter-spacing: normal;
        color: #1a1a2e;
        display: flex;
        align-items: flex-start;
        background: rgba(255, 255, 255, 0.92);
        border: 1px solid rgba(188, 140, 44, 0.25);
        padding: 12px 14px;
        border-radius: 14px;
        gap: 12px;
        box-shadow: 0 10px 24px rgba(0, 0, 0, 0.06);
    }

    .banner_section ul.key_high li span {
        color: rgba(26, 26, 46, 0.92);
    }

    .banner_section ul.key_high li img {
        padding-right: 0;
        left: 0;
        filter: none;
        width: 28px;
        height: 28px;
        padding: 6px;
        border-radius: 999px;
        background: rgba(188, 140, 44, 0.18);
        border: 1px solid rgba(188, 140, 44, 0.28);
        flex-shrink: 0;
        margin-top: 1px;
    }

    .banner_section ul.key_high li span {
        color: rgba(26, 26, 46, 0.92);
        display: block;
        background: none;
        padding: 0;
        line-height: 1.45;
    }

    .banner_section .banner_btn {
        margin-top: 6px;
    }

    .banner_section .banner_content .banner_btn button {
        border-radius: 999px;
        padding: 14px 20px;
        background: linear-gradient(90deg, #ddae58 0%, #bc8c2c 55%, #8a5f14 100%);
        box-shadow: 0 14px 30px rgba(188, 140, 44, 0.28);
    }

    .banner_section .banner_content .banner_btn button:hover {
        background: linear-gradient(90deg, #d9a64a 0%, #b78322 55%, #7a520e 100%);
    }

    .banner_section .banner_content .banner_btn button .icon-next {
        filter: brightness(0) invert(1);
    }

    .banner_section .carousel_btns button {
        bottom: auto;
        top: 16%;
        width: 40px;
        height: 40px
    }

    .banner_section .carousel_btns {
        position: static
    }

    .banner-img {
        min-height: 250px;
        object-fit: cover;
        height: auto
    }

    .banner_section .carousel-control-prev {
        left: auto;
        right: 18%
    }

    .banner_section .carousel-control-next {
        right: 4%
    }

    .banner_section .carousel_btns img {
        max-width: 25px
    }

    header .navbar-brand img {
        max-width: 150px;
        filter: unset;
        padding: 10px 0 5px;
        margin: 0;
    }

    .header-right {
        display: none
    }

    header .navbar-nav {
        flex-direction: column;
        width: 100%;
        height: 100%;
        margin-top: 60px;
        align-items: center
    }

    .menu-wrapper {
        position: fixed;
        width: 100%;
        top: 0;
        bottom: 0;
        left: -100%;
        right: 0;
        z-index: 9;
        background: var(--primary-color);
        transition: .3s ease-in-out;
        height: 100%
    }

    .mobile-open .menu-wrapper {
        left: 0
    }

    header ul li a {
        color: #fff
    }

    .banner_section {
        position: relative
    }

    header .container {
        max-width: 100%
    }

    header {
        position: relative;
        background-color: #FFFCF5
    }

    .overview .first_img {
        left: -10px;
        padding: 10px
    }

    .overview .row {
        flex-direction: column-reverse
    }

    .overview .row .col-lg-6,
    .highlight_section .row .col-lg-6 {
        padding-bottom: 20px
    }

    .amenities_section::after {
        content: none
    }

    .amenities_section .image_section {
        display: none
    }

    .gallery_section .row {
        justify-content: center
    }

    .banner_section .my-box ul li {
        transform: none;
        padding: 10px 16px;
        gap: 10px;
    }

    .banner_section .icon_img {
        transform: none;
        width: 18px;
        flex-shrink: 0;
    }

    .banner_section .my-box ul li:nth-child(2) {
        display: none
    }

    .banner_section .my-box ul li span {
        padding: 0;
        padding-left: 0;
        font-size: 13px;
        color: rgba(26, 26, 46, 0.92);
        letter-spacing: 0.02em;
    }

    .banner_section .side_content {
        position: relative;
        writing-mode: unset;
        background: linear-gradient(180deg, #FFFCF5 0%, #faf2e2 100%);
        margin-bottom: 10px;
        border-top: 1px solid rgba(0, 0, 0, 0.06);
        border-bottom: 2px solid rgba(188, 140, 44, 0.30);
    }

    .banner_section .icon_img {
        filter: brightness(0) saturate(100%);
        opacity: 0.95;
    }

    /* Mobile CTA button */
    .banner_section .banner_content .banner_btn button {
        background: #fff;
        color: #1a1a2e;
        border: none;
        padding: 13px 28px;
        border-radius: 6px;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 0.04em;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        box-shadow: 0 4px 18px rgba(0, 0, 0, 0.3);
        cursor: pointer;
        transition: background 0.2s ease, color 0.2s ease;
    }

    .banner_section .banner_content .banner_btn button:hover {
        background: #f0f0f0;
    }

    .banner_section .banner_content .banner_btn button .icon-next {
        filter: brightness(0);
        margin: 0;
        top: 0;
    }

    .highlight_section ul li {
        display: flex
    }

    /* Highlight section (mobile-only redesign) */
    .highlight_section .row {
        flex-direction: column;
        gap: 18px;
    }

    .highlight_section .row .col-lg-6 {
        padding-bottom: 0;
    }

    /* Keep highlight image same as desktop on mobile */
    .highlight_section .highlight_img_wrap {
        width: 100%;
        display: inline-block;
        border-radius: 0;
        overflow: visible;
        box-shadow: none;
        background: transparent;
        margin-bottom: 0;
    }

    .highlight_section .highlight_img_wrap img {
        width: 100%;
        max-height: 400px;
        height: 400px;
        object-fit: cover;
        object-position: center;
        display: block;
    }

    /* Restore desktop corner frame */
    .highlight_section .highlight_img_wrap::before,
    .highlight_section .highlight_img_wrap::after {
        content: "";
        position: absolute;
        width: 120px;
        height: 120px;
        border-color: #c41e3a;
        border-style: solid;
        border-width: 0;
        z-index: 1;
    }

    .highlight_section .highlight_img_wrap::before {
        top: -4px;
        left: -4px;
        border-top-width: 5px;
        border-left-width: 5px;
    }

    .highlight_section .highlight_img_wrap::after {
        bottom: -4px;
        right: -4px;
        border-bottom-width: 5px;
        border-right-width: 5px;
    }

    .highlight_section .content_section ul {
        margin-top: 16px;
        display: grid;
        gap: 10px;
    }

    .highlight_section ul li {
        align-items: flex-start;
        gap: 10px;
        padding: 12px 12px;
        background: #fff;
        border: 1px solid rgba(0, 0, 0, 0.06);
        border-radius: 14px;
        box-shadow: 0 10px 24px rgba(0, 0, 0, 0.06);
    }

    .highlight_section span.number {
        box-shadow: none;
        padding: 0;
        width: 40px;
        height: 40px;
        border-radius: 999px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 14px;
        color: #1a1a2e;
        background: linear-gradient(180deg, rgba(221, 174, 88, 0.40) 0%, rgba(188, 140, 44, 0.28) 100%);
        border: 1px solid rgba(188, 140, 44, 0.35);
        flex: 0 0 auto;
    }

    .highlight_section .highlight_point {
        padding-left: 0;
        text-transform: none;
        letter-spacing: 0.01em;
        font-size: 13px;
        line-height: 1.5;
        color: #444;
    }

    .overview .title_section h3.title {
        font-size: 24px
    }

    .footer_form .form_sec {
        padding: 15px
    }

    .banner_section .bottom_content .item_box {
        flex-wrap: wrap;

    }

    .banner_section .bottom_content .item {
        margin: unset;
        margin-bottom: 7px;
        border: none;
        border-bottom: 1px solid #ccc;
        background-color: #FFFCF5;
    }

    .banner_section .bottom_content .item_box {
        padding: 10px;
        margin: 0px !important;
    }

    .overview .img_section {
        padding-bottom: 0
    }

    /* Overview (mobile-only redesign: hero image + clean content) */
    .overview .container.ptb {
        padding-top: 44px;
        padding-bottom: 44px;
    }

    .overview .img_section {
        padding-top: 0;
        padding-bottom: 0;
        margin-top: 6px;
        margin-bottom: 18px;
        position: relative;
        overflow: visible;
    }

    /* Make the first image a hero on mobile */
    .overview .first_img {
        position: relative;
        top: 0;
        left: 0;
        width: 100%;
        height: 230px;
        padding: 0;
        border-radius: 18px;
        box-shadow: 0 14px 36px rgba(0, 0, 0, 0.14);
        background-color: transparent;
        display: block;
        object-fit: cover;
        object-position: center;
        z-index: 1;
    }

    .overview .second_img {
        display: block;
        position: relative;
        margin-left: 14%;
        margin-top: -56px;
        width: 86%;
        z-index: 2;
    }

    .overview .second_img img {
        width: 100%;
        height: 170px;
        object-fit: cover;
        border-radius: 16px;
        border: 6px solid #fff;
        box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
        display: block;
    }

    /* Add a subtle gradient overlay for better contrast (on hero) */
    .overview .img_section::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        height: 230px;
        background: linear-gradient(180deg, rgba(0, 0, 0, 0.00) 35%, rgba(0, 0, 0, 0.38) 100%);
        pointer-events: none;
        border-radius: 18px;
        z-index: 1;
    }

    /*
      Overview image layout variants (mobile only)
      Usage (in index.html): <div class="overview mob-layout-stack" ...>
      Available: mob-layout-collage (default), mob-layout-stack, mob-layout-split, mob-layout-reverse
    */

    /* Variant 1: STACK (two images, no overlap) */
    .overview.mob-layout-stack .img_section {
        overflow: hidden;
        border-radius: 18px;
        box-shadow: 0 14px 36px rgba(0, 0, 0, 0.14);
        background: #fff;
    }

    .overview.mob-layout-stack .first_img {
        position: relative;
        width: 100%;
        height: 210px;
        border-radius: 0;
        box-shadow: none;
        z-index: 1;
    }

    .overview.mob-layout-stack .second_img {
        margin-left: 0;
        margin-top: 0;
        width: 100%;
        z-index: 1;
    }

    .overview.mob-layout-stack .second_img img {
        height: 190px;
        border-radius: 0;
        border: 0;
        box-shadow: none;
    }

    .overview.mob-layout-stack .second_img::after {
        content: none;
    }

    .overview.mob-layout-stack .img_section::after {
        content: none;
    }

    /* Variant 2: SPLIT (60/40 grid, modern) */
    .overview.mob-layout-split .img_section {
        display: grid;
        grid-template-columns: 1.4fr 1fr;
        gap: 10px;
        overflow: visible;
    }

    .overview.mob-layout-split .first_img,
    .overview.mob-layout-split .second_img img {
        border-radius: 16px;
        box-shadow: 0 14px 32px rgba(0, 0, 0, 0.14);
    }

    .overview.mob-layout-split .first_img {
        position: relative;
        height: 220px;
        width: 100%;
        z-index: 1;
    }

    .overview.mob-layout-split .second_img {
        margin: 0;
        width: 100%;
        z-index: 1;
        position: relative;
    }

    .overview.mob-layout-split .second_img img {
        height: 220px;
        width: 100%;
        border: 0;
    }

    .overview.mob-layout-split .second_img::after,
    .overview.mob-layout-split .img_section::after {
        content: none;
    }

    /* Variant 3: REVERSE COLLAGE (big bottom + small top-left like your sample) */
    .overview.mob-layout-reverse .img_section {
        overflow: visible;
        position: relative;
    }

    .overview.mob-layout-reverse .first_img {
        position: absolute;
        top: -10px;
        left: 12px;
        width: 78%;
        height: 165px;
        border-radius: 14px;
        border: 6px solid #fff;
        box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
        background: #fff;
        z-index: 3;
    }

    .overview.mob-layout-reverse .second_img {
        margin: 74px 0 0 0;
        width: 100%;
        position: relative;
        z-index: 1;
    }

    .overview.mob-layout-reverse .second_img img {
        height: 255px;
        border-radius: 18px;
        border: 0;
        box-shadow: 0 14px 36px rgba(0, 0, 0, 0.14);
    }

    .overview.mob-layout-reverse .second_img::after,
    .overview.mob-layout-reverse .img_section::after {
        content: none;
    }

    /* Content: flatter layout with accent border */
    .overview .content_section {
        background: #ffffff;
        border: 1px solid rgba(0, 0, 0, 0.06);
        border-left: 4px solid #bc8c2c;
        border-radius: 14px;
        padding: 16px 14px;
        box-shadow: 0 10px 26px rgba(0, 0, 0, 0.06);
    }

    .overview .title_section h4.pro_title {
        margin-bottom: 8px;
    }

    .overview .title_section h3.title {
        line-height: 1.18;
        margin-bottom: 10px;
        font-size: 22px;
    }

    .overview .sm-text {
        display: inline-block;
        margin-top: 10px;
        font-size: 13px !important;
        line-height: 1.45;
        color: #333 !important;
        font-weight: 400 !important;
    }

    .overview .title_section h3.title span {
        display: inline-block;
        margin-top: 6px;
        font-size: 13px;
        color: #555;
    }

    .overview .content_section p {
        margin-bottom: 14px;
        color: #666;
    }

    /* CTA: pill button */
    .overview .banner_btn .download-brochure-btn {
        width: 100%;
        justify-content: center;
        font-size: 15px;
        padding: 13px 18px;
        border-radius: 999px;
        box-shadow: 0 12px 26px rgba(188, 140, 44, 0.26);
    }

    /* .banner_section .bottom_content .item .inner p{flex-direction:initial;justify-content:center} */
    .banner_section .bottom_content .item .inner p {
        flex-direction: row;
        gap: 20px;
        justify-content: center;
        color: #000;
        align-items: center;
    }

    .banner_section .bottom_content .item .inner p span.key {
        border-bottom: none;
        padding: 0px;
        margin: 0px 0 7px 0;
    }

    .overview .content_section p {
        text-align: justify
    }

    header.fixed-header .navbar-nav .nav-link {
        color: #fff
    }

    .gallery_section .galler_item {
        padding-bottom: 15px
    }

    .contact_section p {
        text-align: justify
    }

    .ptb {
        padding: 50px 0;
    }

    .banner_section .bottom_content .item .inner {
        border-radius: 0;
        background: var(--primary-color);
        background: none;
        padding: 0;
    }

    header .header-wrapper {
        padding: 0px 0;
        justify-content: space-between;
    }

    .banner_section .carousel-inner {
        display: none;
    }

    div.mobBanner {
        display: block;
    }

    /* Mobile: hero carousel images (no stretch, keep aspect ratio) */
    .banner_section .carousel-item img.banner-img {
        width: 100%;
        height: auto;
        max-height: 300px;
        min-height: 0;
        object-fit: contain;
        display: block;
    }

    .banner_section .carousel-item {
        min-height: 0;
    }

    div.mobBanner img {
        width: 100%;
        height: auto;
        max-height: 300px;
        object-fit: contain;
        object-position: center;
        display: block;
    }

    .banner_section .carousel_btns {
        display: none;
    }

    .img_div.col-md-6 {
        display: none;
    }

    .gallery_section .galler_item img {
        min-height: 150px;
        max-height: 150px;
    }

    /* Development site carousel: increase height on mobile */
    #development-site-image .galler_item img {
        min-height: 260px;
        max-height: 260px;
        height: 260px;
        object-fit: cover;
        object-position: center;
        border-radius: 16px;
    }

    #developmentSiteCarousel .carousel-item {
        min-height: 280px;
    }

    /* Actual site carousel: match development site height on mobile */
    #actual-site-image .galler_item img {
        min-height: 260px;
        max-height: 260px;
        height: 260px;
        object-fit: cover;
        object-position: center;
        border-radius: 16px;
    }

    #actualSiteCarousel .carousel-item {
        min-height: 280px;
    }

}

.mobBanner {
    display: none;
}

/* Mobile-only arrows for Actual/Development site carousels */
#actualSiteCarousel,
#developmentSiteCarousel {
    position: relative;
}

#actualSiteCarousel .carousel-control-prev,
#actualSiteCarousel .carousel-control-next,
#developmentSiteCarousel .carousel-control-prev,
#developmentSiteCarousel .carousel-control-next {
    display: none;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    border: 1.5px solid #555;
    background: transparent;
    opacity: 1;
    top: 50%;
    transform: translateY(-50%);
    align-items: center;
    justify-content: center;
    z-index: 10;
}

#actualSiteCarousel .carousel-control-prev,
#developmentSiteCarousel .carousel-control-prev {
    left: 12px;
}

#actualSiteCarousel .carousel-control-next,
#developmentSiteCarousel .carousel-control-next {
    right: 12px;
}

#actualSiteCarousel .carousel-control-prev .icon-next,
#developmentSiteCarousel .carousel-control-prev .icon-next {
    transform: rotate(180deg);
}

#actualSiteCarousel .carousel-control-prev .icon-next,
#actualSiteCarousel .carousel-control-next .icon-next,
#developmentSiteCarousel .carousel-control-prev .icon-next,
#developmentSiteCarousel .carousel-control-next .icon-next {
    margin-left: 0;
    top: 0;
}

#actualSiteCarousel .carousel-control-prev:hover,
#actualSiteCarousel .carousel-control-next:hover,
#developmentSiteCarousel .carousel-control-prev:hover,
#developmentSiteCarousel .carousel-control-next:hover {
    background: #222;
    border-color: #222;
}

#actualSiteCarousel .carousel-control-prev:hover .icon-next,
#actualSiteCarousel .carousel-control-next:hover .icon-next,
#developmentSiteCarousel .carousel-control-prev:hover .icon-next,
#developmentSiteCarousel .carousel-control-next:hover .icon-next {
    filter: brightness(0) invert(1);
}

@media (max-width: 991px) {
    #actualSiteCarousel .carousel-control-prev,
    #actualSiteCarousel .carousel-control-next,
    #developmentSiteCarousel .carousel-control-prev,
    #developmentSiteCarousel .carousel-control-next {
        display: flex !important;
    }
}

.imgPop {
    min-height: 400px;
    max-width: 100%;
    width: 100%;
    object-fit: cover;
    object-position: left !important;
}

.priceRqst {
    filter: blur(0px);
    white-space: nowrap;
}

b#frontPrice {
    filter: blur(2px);
}


#highlight .banner_btn {
    margin: 10px 0;
}

#highlight .banner_btn button {
    background-color: #bc8c2c;
    color: #fff;
}

#highlight .icon-next {
    filter: brightness(100%);
}

#amenities .banner_btn {
    margin: 10px 0;
}

#amenities .banner_btn button {
    background-color: #bc8c2c;
    color: #fff;
}

#amenities .icon-next {
    filter: brightness(100%);
}

#floor-plan .banner_btn {
    margin: 10px 0;
}

#floor-plan .banner_btn button {
    background-color: #bc8c2c;
    color: #fff;
}

#floor-plan .icon-next {
    filter: brightness(100%);
}

#gallery .banner_btn {
    margin: 10px 0;
}

#gallery .banner_btn button {
    background-color: #bc8c2c;
    color: #fff;
}

#gallery .icon-next {
    filter: brightness(100%);
}

.redBrochure {
    color: red;
}

.image_section img {
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.5);
}

@media screen and (max-width:1300px) and (min-width:800px) {
    span#offerDiscountPrice {
        font-size: 10px;
    }

    .banner_section .bottom_content .item .inner p span.key {
        font-size: 15px;
    }

    #republic {
        font-size: 10px;
    }

    .PriceGet {
        font-size: 10px;
    }

    header .navbar-brand img {
        max-width: 70px;
    }

    .amenities_section .image_wrapper img {
        min-width: 100%;
        object-fit: contain;
        background-size: contain;
    }
}

/* Amenities section (Swiper) - base layout same as reference */
.bg-primary-half {
    background-color: #f8f8f8;
}

#amenities.amenities-section {
    background-color: #fffcf5;
    overflow: visible;
    padding-bottom: 3rem;
}

#amenities .amenities-head {
    padding-top: 2.5rem;
    padding-bottom: 2rem;
}

#amenities .amenities-head .row {
    margin-bottom: 0;
}

#amenities .section_title {
    margin-bottom: 0;
}

#amenities .section_title h4 {
    color: #b89c6f;
    letter-spacing: 2px;
    font-size: 1.5rem;
    margin-top: 0;
}

#amenities .section_title .h2,
#amenities .section_title h2 {
    color: #222;
    font-weight: 700;
    margin-top: 0;
    margin-bottom: 1.25rem;
    line-height: 1.3;
}

#amenities .amenities-intro {
    color: #555;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    line-height: 1.7;
    font-size: 1rem;
}

/* #amenities .amenities-swiper-wrap {
    padding-bottom: 2rem;
} */

#amenities .facilityBox .img-box {
    min-height: 280px;
    height: 320px;
}

#amenities .facilityBox .img-box img {
    width: 100%;
    height: 100%;
    min-height: 280px;
    display: block;
    aspect-ratio: 16/10;
    object-fit: cover;
}

@media (min-width: 768px) {
    #amenities .facilityBox .img-box {
        height: 340px;
        min-height: 340px;
    }

    #amenities .facilityBox .img-box img {
        min-height: 340px;
    }
}

@media (max-width: 575.9px) {
    #amenities .facilityBox .img-box {
        height: 260px;
        min-height: 260px;
    }

    #amenities .facilityBox .img-box img {
        min-height: 260px;
    }
}

.swiper-control.amenities-swiper-control {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    flex-wrap: wrap;
    margin-top: 1rem;
    margin-bottom: 0;
    padding: 1.25rem 1.5rem;
    border-radius: 0 0 12px 12px;
    width: 100%;
    box-sizing: border-box;
}

.amenities-swiper-control .swiper-button-prev,
.amenities-swiper-control .swiper-button-next {
    flex-shrink: 0;
}

.amenities-swiper-control .swiper-button-prev,
.amenities-swiper-control .swiper-button-next {
    cursor: pointer;
    width: 48px;
    height: 48px;
    margin: 0;
    background: #A6978C;
    color: #000;
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}

.amenities-swiper-control .swiper-button-prev:hover,
.amenities-swiper-control .swiper-button-next:hover {
    background: #938a7e;
}

.amenities-swiper-control .swiper-button-prev::after {
    content: "\2039" !important;
    font-size: 24px;
    font-weight: 600;
    color: #000;
    line-height: 1;
}

.amenities-swiper-control .swiper-button-next::after {
    content: "\203A" !important;
    font-size: 24px;
    font-weight: 600;
    color: #000;
    line-height: 1;
}

.amenities-swiper-control .cta .button {
    padding: 12px 28px;
    background: #000;
    color: #fff;
    text-decoration: none;
    border-radius: 50px;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.amenities-swiper-control .cta .button:hover {
    color: #fff;
    background: #333;
}

/* Amenities section layout - same as reference */
@media (min-width:1300px) {
    .container-lg {
        max-width: 1240px;
    }
}

@media (min-width:1860px) {
    .container-lg {
        max-width: 1600px;
    }
}

@media (min-width:1200px) and (max-width:1280px) {
    .brand_logo a {
        width: 180px;
    }

    header .menu {
        gap: .5rem;
    }

    header .menu a {
        letter-spacing: .5px;
    }
}

@media (max-width:1199.9px) {
    .section_title .h1 {
        font-size: 2.5rem;
    }

    .facilityBox .img-box video {
        aspect-ratio: 2/1;
    }
}

@media (max-width:991.9px) {
    .swiper-facility {
        --slide-width: 100%;
    }

    #amenities .facilityBox .inner {
        overflow: visible;
    }

    #amenities .facilityBox .box-title {
        left: 1rem !important;
        right: 1rem !important;
        top: 1rem;
        bottom: auto;
        width: auto !important;
        max-width: 100%;
        padding: 0;
        box-sizing: border-box;
        word-wrap: break-word;
        overflow-wrap: break-word;
    }

    #amenities .facilityBox .box-title h3,
    #amenities .facilityBox .box-title p {
        word-wrap: break-word;
        overflow-wrap: break-word;
        max-width: 100%;
    }

    #amenities .facilityBox.swiper-slide.swiper-slide-active .box-title {
        left: 1rem !important;
        right: 1rem !important;
    }

    #amenities .facilityBox .box-title h3 {
        font-size: 1.1rem;
        line-height: 1.3;
    }

    #amenities .facilityBox .img-box img {
        width: 100%;
        max-width: 100%;
        display: block;
        aspect-ratio: 16/10;
        object-fit: cover;
    }
}

@media (max-width:767.9px) {
    .container-lg {
        max-width: 660px;
    }

    #amenities.amenities-section {
        overflow: visible;
        padding-top: 2.5rem;
        padding-bottom: 2.5rem;
    }

    #amenities .amenities-head {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    #amenities .amenities-swiper-wrap {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    #amenities .section_title h2 {
        font-size: 1.5rem;
    }

    #amenities .amenities-intro {
        font-size: 0.9rem;
        line-height: 1.55;
    }

    #amenities .facilityBox .box-title {
        left: 0.75rem !important;
        right: 0.75rem !important;
        top: 0.75rem;
    }

    #amenities .facilityBox .box-title h3 {
        font-size: 1rem;
    }

    #amenities .facilityBox .box-title p {
        font-size: 0.8rem;
        line-height: 1.45;
    }

    #amenities .facilityBox .img-box img {
        aspect-ratio: 4/3;
    }

    .amenities-swiper-control {
        margin-top: 1.25rem;
        gap: 0.5rem;
        flex-wrap: wrap;
        justify-content: center;
        padding: 0 0.5rem;
    }

    .amenities-swiper-control .swiper-button-prev,
    .amenities-swiper-control .swiper-button-next {
        min-width: 44px;
        min-height: 44px;
    }

    .facilityBox .img-box video {
        aspect-ratio: 3/2;
    }
}

@media (max-width:575.9px) {
    #amenities.amenities-section {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }

    #amenities .amenities-head,
    #amenities .amenities-swiper-wrap {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    #amenities .section_title h2 {
        font-size: 1.35rem;
    }

    #amenities .amenities-intro {
        font-size: 0.85rem;
    }

    #amenities .facilityBox .box-title h3 {
        font-size: 1.1rem;
    }

    #amenities .facilityBox .box-title p {
        font-size: 0.75rem;
    }

    .amenities-swiper-control .cta .button {
        padding: 0.5rem 1rem;
        font-size: 0.875rem;
    }

    .facilityBox .img-box video {
        aspect-ratio: 1/1;
    }
}

@media (max-width:480px) {
    #amenities .section_title h2 {
        font-size: 1.25rem;
        margin-bottom: 0;
    }

    #amenities .amenities-intro {
        font-size: 0.8rem;
    }
}

