/* Import separate CSS */
/*@import url("cari-properti-mobile.css?update1");*/
/*@import url("cari-properti-tablet.css?update1");*/
/*@import url("cari-properti-desktop.css?update1");*/
.home-secondary-rel-content {
    margin-top: 1rem;
}

/* Filter and Search */
.filter-and-search,
.explore-properties {
    height: max-content;
    position: relative;
}

.search-properti {
    background-color: #fdd314;
}

.bootstrap-select .dropdown-menu.show,
.bootstrap-select .dropdown-menu.show .inner.show {
    max-height: 20rem !important;
}

.dropdown-item.sortRadio,
.dropdown-item.sortRadio:focus {
    border: none;
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(0, 0, 0, 0);
}

/* Explore Properties */
.wrapper-explore-properties,
.wrapper-btn-filter-segment {
    display: grid;
}

.custom-info-text {
    font-size: 1em;
    line-height: 1.3;
    font-weight: 400;
}

/* Breadcrumbs */
.crumbs,
.crumbs-list {
    position: relative;
}

.crumbs {
    background-color: #fff;
    border-radius: 10px;
}

.crumbs-list {
    padding: 0 0 1rem 0;
    width: 100%;
    white-space: wrap;
}

.crumbs-list li {
    display: inline-block;
}

.crumbs-list li::after {
    content: "/";
    padding: 0 0.25em 0 0.5em;
    color: #000;
}

.crumbs-list li.active:before,
.crumbs-list li.active:after {
    content: "";
}

.crumbs-list li a,
.crumbs-list li.active a {
    color: #000;
}

.crumbs-list li.active a {
    font-weight: 700;
}

/* Loading Card */
.card-img-maps-loading {
    position: relative;
    width: inherit;
    background-color: #c9c9c9;
    padding: 0;
    background-size: 100% 250px, 100% 15rem, 100px 100px, 225px 30px;
}

.text-half-card-loading {
    width: 30%;
}
.loading-spinner {
    width: 40px; /* ukuran lingkaran */
    height: 40px;
    border: 4px solid #f3f3f3; /* warna dasar */
    border-top: 4px solid #fffc2f; /* warna bagian animasi */
    border-radius: 50%; /* membuat lingkaran */
    animation: spin 1s linear infinite;
    margin: auto; /* center horizontal */
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

.text-card-loading {
    width: 100%;
}

.text-half-card-loading,
.text-card-loading,
.text-rekomendasi-loading {
    max-height: 1.25rem;
    border-radius: 12px;
    background-size: 100% 250px, 100% 13rem, 100px 100px, 225px 30px;
}

.text-half-card-loading,
.text-card-loading,
.card-img-maps-loading,
.text-rekomendasi-loading {
    background: linear-gradient(0.25turn, transparent, #fff, transparent),
        linear-gradient(#c9c9c9, #c9c9c9);
    background-repeat: no-repeat;
    background-position: -315px 0, 0 0, 0 190px, 50px 195px;
    animation: loading 1.5s infinite;
}

@keyframes loading {
    to {
        background-position: 315px 0, 0 0, 0 190px, 50px 195px;
    }
}

/* Card */
.card-body-properti-maps,
.card-body-properti-maps-non-label,
.card-list-properti-maps,
.card-list-properti-maps-non-label {
    border-radius: 1.25rem;
}

.card-list-properti-maps,
.card-list-properti-maps-non-label {
    border: none;
}

.card-list-properti-maps-non-label {
    -webkit-box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.2),
        0 0 10px 0 rgba(0, 0, 0, 0.19);
    -moz-box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.2),
        0 0 10px 0 rgba(0, 0, 0, 0.19);
    box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.2), 0 0 10px 0 rgba(0, 0, 0, 0.19);
}

.card-img-maps,
.card-img-maps-non-label {
    position: relative;
    width: 100%;
    object-fit: cover;
    overflow: hidden;
    display: block;
}

.label-properti-maps {
    position: absolute;
    top: 0;
    background-color: #fdd314;
    z-index: 10;
    border-radius: 18px 0 10px 0;
    font-size: 15px;
    font-weight: 600;
}

.jenis-properti,
.lokasi-properti {
    color: #747579;
    font-weight: 600;
}

.nama-properti,
.harga-properti {
    color: #000;
    font-weight: 700;
}

.jenis-properti,
.lokasi-properti {
    font-size: 14px;
}

.lokasi-properti,
.nama-properti {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.5;
}

.lokasi-properti {
    -webkit-line-clamp: 2;
}

.nama-properti {
    font-size: 16px;
    -webkit-line-clamp: 1;
}

.harga-properti {
    font-size: 20px;
}

.harga-per-meter-persegi {
    font-weight: 600;
    color: #000;
}

.ic-favorite-properti {
    display: block;
    margin-left: auto;
    width: 2rem;
}

.col-favorite-properti {
    align-self: center;
}

.horizontal-line {
    border-top: 1px solid #707070;
    margin: 0;
}

.btn-hubungi-agen,
.btn-whatsapp-agen {
    background-color: #fdd314;
    width: 100%;
    border-radius: 1.25rem;
}

.text-contact-agen {
    font-size: 0.9rem;
}

.col-profil-agen {
    align-self: center;
}

.lokasi-list-maps,
.container-card-map,
.swiperCardListOnMap {
    width: 100%;
}

.container-card-map {
    overflow: scroll;
}

.swiperCardListOnMap {
    height: 100%;
}

.card-footer-properti-maps,
.card-footer-properti-maps-no-label {
    border-top: #949494 1px solid;
    padding: 0.5rem 0.5rem 0.75rem !important;
}

.card-footer-properti-maps {
    margin: 0 4px !important;
}

.card-footer--info-agen {
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 0.5rem;
}

/* Slide Bottom Kontak Agen */
.contact-agen {
    height: max-content;
    width: 100%;
    background-color: whitesmoke;
    z-index: 10;
    border-radius: 1.25rem 1.25rem 0 0;
    position: fixed;
    bottom: 0;
    transition: transform 0.4s;
}

.scroll-down .contact-agen {
    transform: translate3d(0, 100%, 0);
}

.scroll-up .contact-agen {
    transform: none;
}

.img-agen-detail {
    border-radius: 50%;
    object-fit: cover;
}

.agen-nama {
    font-weight: 700;
    color: #000;
}

.agen-kantor {
    color: #6e6f73;
    line-height: 1.25;
}

.row-agen-detail {
    border-bottom: 1px #b6b6b6 solid;
}

.reset-borra {
    border-radius: 0 !important;
}

.btn-report-prop {
    cursor: pointer;
    width: 2rem;
    height: 2rem;
    margin-top: -25px;
    margin-left: 0.25rem;
}

/* Properti Lain */
.pilihan-title {
    font-weight: 800;
}

.btn-lihat-semua-pilihan {
    font-weight: 600;
    padding: 0.25rem 1.5rem;
    border-radius: 1.25rem;
    background-color: #3cc0fe;
    border: none;
    color: #fff;
}

.pagination-new li a,
.pagination-new li span {
    line-height: 20px !important;
    margin: 0.5rem;
    position: relative;
    margin-left: -1px;
    color: #000;
    font-weight: 700;
}

.pagination-new li.page-icon-attr a {
    border: 0 !important;
    background: none;
}

.pagination-new li:not(.page-icon-attr).active a,
.pagination-new li:not(.page-icon-attr).active span,
.pagination-new li:not(.page-icon-attr) a:hover,
.pagination-new li:not(.page-icon-attr) span:hover {
    background-color: #ffd300;
    color: black !important;
}

.pagination-new li:not(.page-icon-attr) a,
.pagination-new li:not(.page-icon-attr) span {
    text-align: center;
    border-radius: 5px !important;
    text-decoration: none;
    background-color: #fff;
    border: 1px solid #ffd300;
    width: auto;
}

/* Konten CMS */
.section-content-cms h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

.section-content-cms h2 {
    font-size: 1.5em;
    margin: 0.83em 0;
}

.section-content-cms h3 {
    font-size: 1.17em;
    margin: 1em 0;
}

.section-content-cms h4 {
    font-size: 1em;
    margin: 1.33em 0;
}

.section-content-cms h5 {
    font-size: 0.83em;
    margin: 1.67em 0;
}

.section-content-cms h6 {
    font-size: 0.67em;
    margin: 2.33em 0;
}

/* Konten CMS untuk penyesuaian SEO di halaman listing secondary (fix double H1) */
.section-content-cms.footer-listing h2 {
    font-size: 2em;
    margin: 0.67em 0;
    font-weight: 600;
}

.section-content-cms.footer-listing h3 {
    font-size: 1.5em;
    margin: 0.83em 0;
    font-weight: 500;
}

.section-content-cms.footer-listing h4 {
    font-size: 1.17em;
    margin: 1em 0;
    font-weight: 400;
}

.section-content-cms.footer-listing h5 {
    font-size: 1em;
    margin: 1.33em 0;
    font-weight: 400;
}

.section-content-cms.footer-listing h6 {
    font-size: 0.83em;
    margin: 1.67em 0;
    font-weight: 400;
}

.section-content-cms p {
    display: block;
    margin-block-start: 1em;
    margin-block-end: 1em;
    margin-inline-start: 0;
    margin-inline-end: 0;
}

.section-content-cms span {
    display: inline-block;
}

.section-content-cms ul {
    padding-inline-start: 0.9rem;
}

.section-content-cms ol {
    padding-inline-start: 1.1rem;
}

/* Section Rekomendasi Properti */
.section-rekomendasi-properti {
    background: #f4f4f4;
    height: max-content;
}

.text-rekomendasi-properti {
    font-weight: 600;
    color: #000;
    font-size: 1.25em;
    line-height: 1.3;
}

.borderrr-bottom {
    width: 5rem;
    margin-left: 1px;
    border-bottom: #fdd314 solid 2px;
}

.data-lokasi-properti {
    color: #000;
    font-weight: 400;
    line-height: 1.3;
}

.data-lokasi-properti:hover {
    text-decoration: none;
    color: #000;
}

/* Carousel Secondary Premier */
.carousel-secondary-premier {
    margin: 0;
}

.carousel-secondary-premier,
.carousel-inner,
.carousel-item,
.carousel-item.active {
    height: 15rem;
    max-height: 15rem;
}

.inner-secondary-premier[src=""] {
    display: none;
}

.loading-inner-secondary-premier {
    background: linear-gradient(0.25turn, transparent, #fff, transparent),
        linear-gradient(#dddddd, #dfdfdf);
    background-repeat: no-repeat;
    background-position: -315px 0, 0 0, 0px 190px, 50px 195px;
    animation: loading 1.5s infinite;
    width: calc(100% - 8px);
    height: calc(100% - 4px);
    padding: 0 !important;
    margin: 4px 4px 0;
    display: block;
}

@keyframes loading {
    to {
        background-position: 315px 0, 0 0, 0 190px, 50px 195px;
    }
}

.carousel-indicators {
    cursor: default;
}

.carousel-indicators li,
.carousel-indicators li.active {
    border-radius: 50%;
    background-color: #fff;
    cursor: pointer;
}

.carousel-indicators li {
    width: 0.5rem;
    height: 0.5rem;
    margin-top: 1px;
}

.carousel-indicators li.active {
    width: 0.65rem;
    height: 0.65rem;
    margin-top: 0;
}

.btn-prev-carousel,
.btn-next-carousel {
    display: none;
    opacity: 00.7;
    position: absolute;
    z-index: 9;
    background-color: #fff;
    border-radius: 50%;
    padding: 0;
    width: 2rem;
    height: 2rem;
    max-width: 2rem;
    max-height: 2rem;
    color: #000;
    font-size: 00.875em;
    top: 50%;
    justify-content: center;
    align-items: center;
}

.btn-prev-carousel {
    left: 0.5rem;
    padding-right: 0;
}

.btn-next-carousel {
    right: 0.5rem;
    padding-left: 0;
}

.btn-prev-carousel:hover,
.btn-next-carousel:hover {
    opacity: 1;
}

.carousel:hover .btn-prev-carousel,
.carousel:hover .btn-next-carousel {
    /* display: block; */
    display: flex !important;
}

.area-next-carousel,
.area-prev-carousel {
    position: absolute;
    z-index: 9;
    top: 0;
    height: 100%;
    width: 2.5rem;
    background-color: transparent;
    cursor: default;
}

.area-next-carousel {
    right: 0;
}

.area-prev-carousel {
    left: 0;
}

/* Hubungi */
.bg-yellow {
    background-color: #fdd314;
}

.bg-grey {
    background-color: #e6e6e6;
}

.btn-register.new,
.btn-register.new:hover {
    background-color: #000;
    color: #fff;
    border-radius: 0.625rem;
    padding: 0.875rem 0.75rem;
}

/* End New Css Template */

/* New Max Page Design */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap");
.img-banner-maxpage {
    width: 100%;
    height: auto;
}

.txt-title-page {
    font-weight: 700;
    font-family: "Inter", sans-serif;
    line-height: 1.25;
}

.txt-list-info {
    line-height: 1.25;
}

.wrapper-list-info {
    width: 100%;
}

.btn-new-account {
    padding: 15px 20px;
    font-size: 1em;
    font-weight: 700;
    background-color: #fdd314;
    border-radius: 10px;
    line-height: 1.25;
}

.btn-lihat-semua-berita {
    background-color: #343a40 !important;
}

/* START MODAL POP UP */
body.modal-shortcut-open {
    overflow: hidden !important;
}

.modal.modal-master.shortcut-menu .modal-content {
    border: none;
    background-color: transparent !important;
}

.modal.modal-master.shortcut-menu .modal-body {
    background-color: #fff;
}

.btn-close-modal-shortcut-menu.mobile {
    background-color: #ececec;
    border-radius: 50%;
    width: 2rem;
    height: 2rem;
    font-size: 0.875rem;
    padding: 0;
    position: absolute;
    top: -4px;
    right: 17px;
    box-shadow: 0 2px 8px 0 #bbb;
    -webkit-box-shadow: 0 2px 8px 0 #bbb;
    -moz-box-shadow: 0 2px 8px 0 #bbb;
}

.btn-close-modal-shortcut-menu {
    font-size: 1.25rem;
    opacity: 1 !important;
}

.btn-close-modal-shortcut-menu:focus {
    outline: 0;
    border: none !important;
    box-shadow: 0 0 0 0.2rem transparent !important;
}

.modal-header-draggable {
    width: 100%;
    background-color: #fff0;
    height: 1.625rem;
    position: fixed;
    z-index: 2;
    border-bottom: none;
    border-radius: 0 !important;
}

.title-section-modal {
    font-weight: 700;
    font-size: 20px;
}

.wrapper-menu-shortcut {
    display: grid;
    margin-bottom: 20px;
}

.wrapper-menu-shortcut:last-of-type {
    margin-bottom: 0;
}

.wrapper-menu-shortcut .card-menu-shortcut {
    box-shadow: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    border-radius: 0;
    border: none;
}

.wrapper-menu-shortcut .title-shortcut-menu {
    font-size: 0.75em;
}

/* START SHARES PROEPRTY */
.bagikan {
    font-weight: 600;
    font-size: 14px;
    color: #000;
}

.sharebutton {
    width: 20px;
    background: 0 0;
    color: inherit;
    border: none;
    padding: 0;
    font: inherit;
    cursor: pointer;
    outline: inherit;
    display: inline-flex;
}

ul.sharemod {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

ul.sharemod li {
    list-style: none;
    border-bottom: 0.1px solid #aba8a8;
    padding: 10px 0;
}

ul.sharemod li:last-child {
    border-bottom: none;
}

ul.sharemod li a {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: #000;
}

ul.sharemod li a .svg {
    width: 32px;
    height: 32px;
    padding: 1px;
    object-fit: contain;
    display: flex;
    align-items: center;
    justify-content: center;
    fill: black !important;
}

ul.sharemod li a .svg img {
    width: 30px;
}

ul.sharemod li a .text {
    font-size: 14px;
    font-weight: 500;
}

/* START LOADER */
.card-proyek-baru-loading {
    height: 24.5rem;
}

.card-berita-loading,
.card-properti-secondary-loading {
    border-radius: 20px;
    width: 100%;
    -webkit-box-shadow: 0 0 5px 0 rgb(0 0 0 / 0.2), 0 0 10px 0 rgb(0 0 0 / 0.19);
    -moz-box-shadow: 0 0 5px 0 rgb(0 0 0 / 0.2), 0 0 10px 0 rgb(0 0 0 / 0.19);
    box-shadow: 0 0 5px 0 rgb(0 0 0 / 0.2), 0 0 10px 0 rgb(0 0 0 / 0.19);
    border: 0;
}

.card-properti-secondary-loading {
    height: auto;
}

.card-properti-secondary-loading .card-body-properti,
.card-properti-secondary-loading .card-footer-properti {
    padding: 15px 1.25rem;
}

.card-berita-loading {
    height: 22.5rem;
}

.card-img-top-news-loading,
.card-img-top-properti-secondary-loading,
.card-img-top-proyek-baru-loading {
    position: relative;
    border-radius: 19px 19px 0 0;
    width: inherit;
    background-color: #c9c9c9;
}

.card-img-top-news-loading,
.card-img-top-properti-secondary-loading {
    height: 15rem;
    max-height: 15rem;
    padding: 0;
}

.card-img-top-proyek-baru-loading {
    height: 13rem;
    max-height: 13rem;
}

.text-card-loading {
    width: 100%;
    max-height: 1.25rem;
    border-radius: 12px;
}

.card-img-top-news-loading,
.card-img-top-properti-secondary-loading,
.card-img-top-proyek-baru-loading,
.text-card-loading {
    background: linear-gradient(0.25turn, transparent, #fff, transparent),
        linear-gradient(#c9c9c9, #c9c9c9);
    background-repeat: no-repeat;
    background-position: -315px 0, 0 0, 0 190px, 50px 195px;
    animation: 1.5s infinite loading;
}

.card-img-top-proyek-baru-loading,
.text-card-loading {
    background-size: 100% 250px, 100% 13rem, 100px 100px, 225px 30px;
}

.card-img-top-news-loading,
.card-img-top-properti-secondary-loading {
    background-size: 100% 250px, 100% 15rem, 100px 100px, 225px 30px;
}

.container-loading-primary,
.container-loading-secondary,
.container-loading-secondary-recommendation,
.container-loading-secondary-related,
.wrapper-button-lokasi {
    display: grid;
}

.vvggyy {
    display: none;
}

@keyframes loading {
    to {
        background-position: 315px 0, 0 0, 0 190px, 50px 195px;
    }
}

@media only screen and (max-width: 345px) {
    .txt-title-page {
        font-size: 1.125em !important;
    }

    .btn-new-account {
        font-size: 0.875em !important;
    }

    .wrapper-list-info i {
        font-size: 1.625em !important;
        padding-top: 4px !important;
    }
}

@media only screen and (max-width: 575px) {
    .container-maxpage {
        max-width: 345px;
    }

    .wrapper-img-banner-maxpage {
        max-width: 80%;
    }

    .txt-title-page {
        font-size: 1.25em;
    }

    .txt-list-info {
        font-size: 0.875em;
    }

    .wrapper-list-info {
        max-width: 296px;
        gap: 13px;
    }

    .wrapper-list-info i {
        font-size: 1.875em;
        padding-top: 2px;
    }

    .property-image,
    .carousel-secondary-premier,
    .carousel-inner,
    .carousel-item,
    .carousel-item.active,
    .card-img-top,
    .card-img-top-non-label {
        height: 12rem !important;
        max-height: 12rem !important;
    }

    .carousel-indicators {
        bottom: 4% !important;
    }

    .carousel-indicators li,
    .carousel-indicators li.active {
        background-color: #fdd314;
    }
}

@media only screen and (min-width: 576px) {
    .container-maxpage {
        max-width: 410px;
    }

    .wrapper-img-banner-maxpage {
        max-width: 90%;
    }

    .txt-title-page {
        font-size: 1.5em;
    }

    .wrapper-list-info {
        max-width: 350px;
        gap: 1rem;
    }

    .wrapper-list-info i {
        font-size: 1.875em;
        padding-top: 2px;
    }
}

@media only screen and (min-width: 576px) {
    .carousel-secondary-premier.new-listing {
        height: 28rem;
        max-height: 28rem;
    }

    .new-listing,
    .card-properti2 .carousel-inner,
    .card-properti2 .carousel-item,
    .card-properti2 .carousel-item.active {
        height: 28rem;
        max-height: 28rem;
    }

    .card-properti2 .card-img-top,
    .card-properti2 .card-img-top-non-label {
        height: 28rem;
        max-height: 28rem;
    }
}

@media only screen and (min-width: 992px) {
    .container-maxpage {
        max-width: 640px;
    }

    .wrapper-img-banner-maxpage {
        max-width: 80%;
    }

    .txt-title-page {
        max-width: 480px;
    }

    .wrapper-list-info {
        max-width: 440px;
    }
}

@media only screen and (max-width: 360px) {
    .img-logo-white-circle {
        width: 5rem !important;
        max-width: 5rem !important;
        height: 19.24px !important;
    }
}

@media only screen and (min-width: 425px) {
    .shortcut-menu-wrapper {
        grid-template-columns: repeat(4, 1fr);
    }

    .card-menu-shortcut {
        box-shadow: none;
        -webkit-box-shadow: none;
        -moz-box-shadow: none;
        border-radius: 0;
        border: none;
    }

    .title-shortcut-menu {
        font-size: 0.75em;
    }

    .img-logo-white-circle {
        width: 5.8rem;
        max-width: 5.8rem;
        height: 22.32px;
    }

    .img-jelajah-1 {
        width: 35%;
    }

    .img-jelajah-2,
    .img-jelajah-3 {
        width: 38%;
    }

    .modal-brighton-ads {
        max-width: 90vw;
    }

    .modal-agen-nama {
        font-size: 1.3rem;
    }

    .wrapper-button-lokasi {
        grid-template-columns: 10rem 10rem;
    }

    .badge-online {
        bottom: 0.5rem;
        left: 3.4rem;
    }

    .download-desc {
        margin-right: 12rem;
    }

    .container-loading-primary,
    .container-loading-secondary,
    .container-loading-secondary-recommendation,
    .container-loading-secondary-related {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .modal.modal-master.shortcut-menu .modal-dialog {
        max-height: 70vh;
        width: 100%;
        overflow-y: scroll;
        position: fixed;
        bottom: 0;
        -webkit-animation-name: slideIn;
        -webkit-animation-duration: 0.4s;
        animation-name: slideIn;
        animation-duration: 0.4s;
    }

    .modal.modal-master.shortcut-menu .modal-body {
        height: 33vh;
        overflow-y: scroll;
    }

    @-webkit-keyframes slideIn {
        from {
            bottom: -300px;
            opacity: 0;
        }
        to {
            bottom: 0;
            opacity: 1;
        }
    }
    @keyframes slideIn {
        from {
            bottom: -300px;
            opacity: 0;
        }
        to {
            bottom: 0;
            opacity: 1;
        }
    }
    .wrapper-menu-shortcut {
        grid-template-columns: repeat(4, 1fr);
        gap: 1rem;
    }

    .modal-master .modal-dialog.modal-lg {
        max-width: 100%;
        margin: 0;
    }
}

@media only screen and (max-width: 575px) {
    .shortcut-menu-wrapper {
        grid-template-columns: repeat(4, 1fr);
    }

    .card-menu-shortcut {
        box-shadow: none;
        -webkit-box-shadow: none;
        -moz-box-shadow: none;
        border-radius: 0;
        border: none;
    }

    .title-shortcut-menu {
        font-size: 0.75em;
    }

    .img-logo-white-circle {
        width: 5.8rem;
        max-width: 5.8rem;
        height: 22.32px;
    }

    .img-jelajah-1 {
        width: 55%;
    }

    .img-jelajah-2,
    .img-jelajah-3 {
        width: 60%;
    }

    .download-desc {
        margin-right: 5rem;
    }

    .modal-brighton-ads {
        max-width: 100vw;
    }

    .modal-agen-nama {
        font-size: 1.2rem;
    }

    .wrapper-button-lokasi {
        grid-template-columns: 45% 45%;
    }

    .badge-online {
        bottom: 0.5rem;
        left: 3.25rem;
    }

    .container-loading-primary,
    .container-loading-secondary,
    .container-loading-secondary-recommendation,
    .container-loading-secondary-related {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .modal.modal-master.shortcut-menu .modal-dialog {
        max-height: 70vh;
        width: 100%;
        overflow-y: scroll;
        position: fixed;
        bottom: 0;
        -webkit-animation-name: slideIn;
        -webkit-animation-duration: 0.4s;
        animation-name: slideIn;
        animation-duration: 0.4s;
    }

    .modal.modal-master.shortcut-menu .modal-body {
        overflow-y: scroll;
    }

    @-webkit-keyframes slideIn {
        from {
            bottom: -300px;
            opacity: 0;
        }
        to {
            bottom: 0;
            opacity: 1;
        }
    }
    @keyframes slideIn {
        from {
            bottom: -300px;
            opacity: 0;
        }
        to {
            bottom: 0;
            opacity: 1;
        }
    }
    .wrapper-menu-shortcut {
        grid-template-columns: repeat(4, 1fr);
        gap: 1rem;
    }

    .modal-master .modal-dialog.modal-lg {
        margin: 0;
    }
}

@media only screen and (min-width: 576px) {
    .modal-brighton-ads {
        max-width: 90vw;
    }

    .container-loading-primary,
    .container-loading-secondary,
    .container-loading-secondary-recommendation,
    .container-loading-secondary-related {
        grid-template-columns: 1fr 1fr;
        gap: 15px;
    }

    .modal-master.shortcut-menu.loading {
        height: 100%;
    }

    .modal-master.shortcut-menu {
        max-height: 100%;
        overflow-y: auto;
        bottom: auto;
        top: 0;
    }

    .modal.modal-master.shortcut-menu .modal-dialog {
        max-height: 100%;
        width: 100%;
        overflow-y: auto;
        position: relative;
        -webkit-animation-name: none;
        -webkit-animation-duration: unset;
        animation-name: none;
        animation-duration: unset;
    }

    .modal.modal-master.shortcut-menu .modal-body {
        height: 100%;
        overflow-y: auto;
        border-radius: 0.3rem;
    }

    .modal-master .modal-dialog.modal-lg {
        max-width: 360px;
        margin: 1.75rem auto;
    }

    .vvggyy {
        display: inline-block;
    }

    .wrapper-menu-shortcut {
        grid-template-columns: repeat(8, 1fr);
        gap: 0;
    }
}

@media only screen and (min-width: 992px) {
    .shortcut-menu-wrapper {
        grid-template-columns: repeat(8, 1fr);
    }

    .nav-next-proyek {
        right: 1rem;
    }

    .img-jelajah-1 {
        width: 75%;
    }

    .img-jelajah-2,
    .img-jelajah-3 {
        width: 80%;
    }

    .jelajahi-desc {
        margin-top: 2rem;
    }

    .modal-brighton-ads {
        max-width: 50rem !important;
    }

    .modal-agen-nama {
        font-size: 1.4rem;
    }

    .wrapper-button-lokasi {
        grid-template-columns: 10rem 10rem;
    }

    .img-brighton-app {
        width: 100%;
        height: 303.1px;
        max-height: 303.1px;
    }

    .col-lokasi {
        border-left: 1px solid #000;
        padding-left: 3rem;
    }

    .download-desc {
        margin-right: 0;
    }

    .container-loading-secondary,
    .container-loading-secondary-recommendation,
    .container-loading-secondary-related {
        grid-template-columns: repeat(3, 1fr);
        gap: 15px;
    }

    .modal-master .modal-dialog.modal-lg {
        max-width: 434px;
    }
}

@media only screen and (min-width: 768px) {
    .nav-next-proyek {
        right: 2rem;
    }

    .title-shortcut-menu {
        font-size: 0.875em;
    }

    .img-brighton-app {
        width: 8rem;
        height: 317.15px;
        max-height: 317.15px;
    }

    .container-loading-primary {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 20px;
    }

    .container-loading-secondary,
    .container-loading-secondary-recommendation,
    .container-loading-secondary-related {
        gap: 30px;
    }
}

@media only screen and (min-width: 1200px) {
    .container-loading-secondary {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 25px;
    }

    .container-loading-secondary-recommendation,
    .container-loading-secondary-related {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 25px;
    }
}

/* split screen */
.gaping {
    margin-top: 20px;
}
@media (max-width: 767px) {
    .gaping {
        margin-top: 0px;
    }
}
.page-wrapper {
    padding: 0px 75px 0 0;
}

@media (max-width: 769px) {
    .page-wrapper {
        padding: 0px 0px 0 0;
    }
}

.page-wrapper.no-padding {
    padding: 0 !important;
    overflow: hidden !important;
}

.news-section {
    overflow: hidden !important;
}

.news-section section.container-fluid.p-0.px-3.px-sm-4.my-5.article-new {
    padding: 0px 10px 0px 10px !important;
    margin: 0px !important;
}

.hidden-overflow {
    overflow: hidden !important;
    padding-left: 3rem;
    padding-right: 3rem;
}

@media (max-width: 769px) {
    .hidden-overflow {
        overflow: hidden !important;
        padding-left: 0rem;
        padding-right: 0rem;
    }
}

.hidden-class {
    display: none !important;
}
/* .two-columns {
    display: flex;
    gap: 20px;
    justify-content: space-between;
}

.two-columns > *:first-child {
    flex: 0 0 35%;
}

.two-columns > *:last-child {
    flex: 0 0 65%;
}

@media (max-width: 767px) {
    .two-columns {
        flex-direction: column;
    }

    .two-columns > * {
        flex: 0 0 100%;
    }
} */

/* setting newsSection */
.width-0 {
    min-width: 0;
}

.two-columns {
    display: grid;
    grid-template-columns: 35% 65%;
    gap: 20px;
}

@media (max-width: 769px) {
    .two-columns {
        grid-template-columns: 1fr;
    }
}

.two-columns.single-column {
    grid-template-columns: 1fr; /* jadi satu kolom penuh */
}

/* accordion */
.h5-title {
    font-size: 1.2rem;
}
.accordion-container {
    width: 100%;
    margin: 0 auto 30px 0px;
    background: white;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.38);
    overflow: hidden;
    padding: 20px;
}
.parent-accordion {
    width: 100%;
    padding: 0px 0px 0px 80px;
    display: inline-block;
}

@media screen and (max-width: 769px) {
    .parent-accordion {
        padding: 10px 20px 0px 20px;
    }
}

.accordion-section {
    border-bottom: 1px solid #e9ecef;
}

.accordion-section:last-child {
    border-bottom: none;
}

.accordion-header {
    display: flex;
    align-items: center;
    padding: 20px 20px 20px 0px;
    cursor: pointer;
    background: white;
    transition: background-color 0.2s ease;
    user-select: none;
}

.accordion-header:hover {
    background-color: #f8f9fa;
}

.accordion-header.active {
    background-color: #f8f9fa;
}

.accordion-icon {
    width: 24px;
    height: 24px;
    margin-right: 12px;
    opacity: 0.7;
    object-fit: contain;
}

.accordion-icon-item {
    width: 100%;
    object-fit: contain;
    opacity: 0.7;
}

.icon-box {
    width: 24px;
    height: 24px;
    display: inline-block;
    margin: 0px 12px;
}

.accordion-title {
    font-size: 16px;
    font-weight: 600;
    color: #333;
    flex: 1;
}

.accordion-toggle {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease;
}

.accordion-toggle::after {
    content: "▼";
    font-size: 12px;
    color: #666;
}

.accordion-header.active .accordion-toggle {
    transform: rotate(180deg);
}

.accordion-content {
    display: none;
    padding: 0 20px 20px 0px;
}

.property-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 12px 0;
    border-bottom: 1px solid #f0f0f0;
}

.property-item:last-child {
    border-bottom: none;
}

.property-info {
    flex: 1;
}

.property-name {
    font-size: 15px;
    font-weight: 500;
    color: #333;
    margin-bottom: 4px;
}

.property-details {
    font-size: 13px;
    color: #666;
    margin-bottom: 4px;
}

.property-status {
    font-size: 12px;
    color: #007bff;
}

.property-price {
    font-size: 14px;
    font-weight: 600;
    color: #333;
    text-align: right;
}

.property-discount {
    font-size: 12px;
    color: #dc3545;
    margin-top: 2px;
}

.loading {
    padding: 20px;
    text-align: center;
    color: #666;
}

.error {
    padding: 20px;
    text-align: center;
    color: #dc3545;
}

.expand-btn {
    display: block;
    width: 100%;
    padding: 10px;
    border: none;
    background: #f8f9fa;
    color: #007bff;
    cursor: pointer;
    font-size: 13px;
    transition: background-color 0.2s ease;
}

.expand-btn:hover {
    background-color: #e9ecef;
}
