/**
 * Theme Name: Homes in Asia Basic
 * Theme URI: https://ruviouscreative.com
 * Author: Alex Tham
 * Author URI: https://ruviouscreative.com
 * Description: A clean, minimalist WordPress theme with Bootstrap 5
 * Text Domain: homesinasia
 * Tags: bootstrap, clean, minimal, responsivee
 */

 body {
    /* font-family: "Muller regular", "Helvetica Neue", Arial, sans-serif; */
    /* font-family: "Roboto", sans-serif; */
	/* font-family: "TikTok Sans", sans-serif; */
	font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-variation-settings:
    "slnt" 0,
    "wdth" 100;
    line-height: 1.5;
    letter-spacing: -0.6px;
    color: #767D7F;
    background-color:#f3eee8;
    font-size: 20px;
}

/* Blog Minimal Styles */
.blog-archive-hero{padding:60px 0 20px;}
.blog-archive-list .date-text{font-size: 14px;}
.blog-archive-list h2{font-size: 18px;}
.blog-archive-list p{font-size: 14px;}
.blog-archive-list{padding:10px 0 40px;}
.blog-archive-list .row{justify-content:start;align-items:stretch}
.blog-archive-list .col-lg-3,.blog-archive-list .col-md-6{display:flex}
.single-post .breadcrumb {margin-left: 15px;}
.single-post .site-content > .container {padding: 0px;}
.archive-card{background:#f3eee8;border:1px solid #cecece;border-radius:8px;overflow:hidden;transition:transform .25s ease, box-shadow .25s ease;display:flex;flex-direction:column;height:100%}
.archive-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,.12)}
.archive-card-media img{display:block;height:320px;object-fit:cover}
.archive-card-body{padding:20px;display:flex;flex-direction:column;flex:1}
.archive-card .h3{color:#212121}
.archive-card .stretched-link{text-decoration:none;position:static}
.archive-card{position:relative;height:100%;}
.archive-card .stretched-link:hover{text-decoration:underline}
.single-post-minimal .blog-hero{padding:0px 0 20px}
.blog-hero{margin-top:10px}
.blog-hero-title{font-family:"Inter", sans-serif;font-size:3rem;font-weight:400;color:#212121;margin-bottom:6px}
.blog-hero-rule{border:0;border-top:2px solid #b7b1aa;width:60%}
.blog-archive-hero .container{text-align:center}
.featured-image-minimal{background:#000}
.featured-image-minimal img{display:block;filter:none;opacity:1}
.blog-square-image{width:100%;max-width:560px;aspect-ratio:1/1;overflow:hidden;border-radius:6px}
.blog-square-image img{object-fit:cover}
.blog-body .col-lg-5 .blog-square-image{margin-top:12%}
@media (max-width: 991.98px){.blog-body .col-lg-5 .blog-square-image{margin-top:0}}
@media (min-width: 992px){
    .blog-body .col-lg-5 .sticky-image-wrap,
    .blog-body .col-lg-5 .featured-image-minimal.blog-square-image{position: static; top: auto}
    .blog-body .col-lg-5 .sticky-image-wrap.sticky,
    .blog-body .col-lg-5 .featured-image-minimal.blog-square-image.sticky{position: fixed; top: 90px; margin-top:0; left: auto}
    .blog-body .col-lg-5 .featured-image-minimal.blog-square-image.sticky.at-footer{position: fixed}
}

/* moved into media query with higher specificity */
.minimal-content p{color:#333}
.minimal-content p.hia-spacer{height:1.2em}
.blog-taxonomy{margin-top:30px}
.blog-body{padding:20px 0 60px;border-bottom:1px solid #cecece}
.grecaptcha-badge {
	display:none !important;
}
/* Related posts hover effects */
.related-posts a .ratio img{transition:opacity .2s ease-in-out}
.related-posts a:hover .ratio img,
.related-posts a:focus .ratio img{opacity:.6}
.related-posts a:hover .fw-semibold,
.related-posts a:focus .fw-semibold{text-decoration:underline}
/* .vc_custom_heading.vc_do_custom_heading {
    font-family: "Muller medium", "Helvetica Neue", Arial, sans-serif;
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    line-height: 1.25;
    color: #212121;
} */
h1, h2, h3 {
    /* font-family: "Muller bold", "Helvetica Neue", Arial, sans-serif; */
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    line-height: 1.16;
    color: #212121;
    letter-spacing: -1.2px;
}
h4, h5, h6 {
    /* font-family: "Muller medium", "Helvetica Neue", Arial, sans-serif; */
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    line-height: 1.16;
    color: #212121;
    letter-spacing: -1.2px;
}
.fw-300 {
    font-weight: 300;
}
.fw-400 {
    font-weight: 400;
}
.fw-600 {
    font-weight: 600;
}
.fw-700 {
    font-weight: 700;
}
a, .toggle-link {
    color: #981B2B;
    text-decoration: none;
}
.vc_btn3.vc_btn3-color-danger.vc_btn3-style-outline {
    background-color: transparent !important;
    border: 1px solid #981B2B !important;
    color: #981B2B !important;
}
.vc_btn3.vc_btn3-color-danger:hover {
    background-color: #981B2B !important;
    color: #fff !important;
}
a:hover, .toggle-link:hover {
    color: #981B2B;
    text-decoration: underline;
}
.navbar > .container {
    position: relative;
}
.navbar-nav .nav-link.active, .navbar-nav .nav-link.show, #primary-menu .current-page-ancestor .nav-link {
    color: #981B2B;
    font-weight: 700;
}

.site {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    overflow-x: hidden;
}

.admin-bar .site {
    min-height: calc(100vh - 32px);
}

@media screen and (max-width: 782px) {
    .admin-bar .site {
        min-height: calc(100vh - 46px);
    }
}

.site-header {
    padding: 0rem 0;
    border-bottom: 1px solid #e9ecef;
    transition: all 0.3s ease-in-out;
    position: relative;
    z-index: 10;
}

.site-header.sticky {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1000;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    background-color: #f3eee8;
}

.admin-bar .site-header.sticky {
    top: 32px;
}

@media screen and (max-width: 782px) {
    .admin-bar .site-header.sticky {
        top: 46px;
    }
}

.site-footer {
    padding: 60px 0 15px;
    border-top: 1px solid #cecece;
}
.site-footer p {
    font-size: 14px;
}
.site-footer h4 {
    font-size: 18px;
}
.site-footer .widget.widget_nav_menu ul {
    padding-left:0px;
}
.site-footer .widget.widget_nav_menu ul li {
    display: block;
    font-size: 14px;
    margin-bottom: 10px;
    list-style: none;
}

.site-footer .widget.widget_nav_menu ul li ul {
    margin-top: 5px;
    margin-bottom: 10px;
}

.site-footer .widget.widget_nav_menu ul li ul li {
    margin-bottom: 5px;
    padding-left: 20px;
    position: relative;
}

.site-footer .widget.widget_nav_menu ul li ul li::before {
    content: "›";
    position: absolute;
    left: 0;
    color: #981B2B;
    font-weight: bold;
}
.site-footer .footer-wa img {
    max-width:200px;
    height: auto;
}
.site-footer .wp-block-social-link {
    background-color: transparent !important;
}
.site-footer .wp-block-social-links .wp-block-social-link.wp-social-link .wp-block-social-link-anchor svg {
    fill: #212121 !important;
}
.site-footer .wp-block-social-links .wp-block-social-link.wp-social-link .wp-block-social-link-anchor svg:hover {
    fill: #981B2B !important;
}
.copyright.small {
    font-size: 13px;
}
.site-content {
    flex: 1;
    padding: 0 0;
}

.entry-title {
    margin-bottom: 1rem;
}

.entry-meta {
    margin-bottom: 1rem;
    color: #6c757d;
}

.entry-content {
    margin-bottom: 1.5rem;
}

.widget-title {
    margin-bottom: 1rem;
}
#header-logo a img {
    width:200px !important;
    height: auto !important;
}
#footer-logo {
    display: inline-block;
    vertical-align: middle;
}
#footer-logo a img {
    width:150px !important;
    height: auto !important;
}
#property-styles .vc_tta.vc_general .vc_tta-tab>a {
    padding: 5px 20px !important;
    border-radius: 20px !important;
    background-color: transparent !important;
    border: 1px solid #fff !important;
}
#property-styles .vc_tta-color-black.vc_tta-style-classic .vc_tta-tab.vc_active>a {
    background-color: #fff !important;
}
.dark-bg .vc_parallax-inner.skrollable {
    opacity: 0.4;
}
.text-white a, .text-white a:hover, .text-white a:focus {
    color:#fff;
    text-decoration: underline;
}
#destinations .wpb_column.vc_column_container {
    min-height: 80vh;
}
#destinations .vc_tta-panel-body {
    padding: 0 0;
}
#ultimate-guides .wpb_wrapper.vc_figure a {
    position: relative;
    background: #000;
    overflow: hidden;
}
#ultimate-guides .wpb_heading.wpb_singleimage_heading {
	min-height:60px;
	position: absolute;
    bottom: -49px;
    left: 0;
    right: 0;
}
#ultimate-guides .wpb_wrapper.vc_figure a::before {
    content:'More info';
    position: absolute;
    top:60%;
    width: 100%;
    left: 0;
    right: 0;
    text-align: center;
    transform: translateY(-50%);
    opacity: 0;
    color: #fff;
    transition: 0.3s ease-in-out;
}
#ultimate-guides .wpb_wrapper.vc_figure:hover a::before {
    top:50%;
    opacity: 1;
    color: #fff;
    transition: 0.3s ease-in-out;
}
#ultimate-guides .wpb_wrapper.vc_figure a img {
    opacity: 1;
    transition: 0.3s ease-in-out;
    scale: 1;
}
#ultimate-guides .wpb_wrapper.vc_figure:hover a img {
    opacity: 0.5;
    transition: 0.3s ease-in-out;
    scale: 1.1;
}
#ultimate-guides .wpb_singleimage_heading {
    font-family: "Inter", sans-serif;
    font-size: 16px;
    font-weight: 700;
}

.navbar-nav {
    align-items: center;
    height: 100%;
}

.navbar-nav .nav-item {
    display: flex;
    align-items: center;
    height: 100%;
    margin: 0 0.5rem;
}

.navbar-nav .nav-link {
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0.5rem 2rem;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.5px;
}

.navbar .navbar-collapse {
    align-items: center;
    transition: height 0.3s ease-in-out;
}

.navbar-nav .nav-link:focus,
.navbar-nav .dropdown-toggle:focus {
    outline: none;
    box-shadow: none;
}

.dropdown-toggle:focus {
    outline: none;
    box-shadow: none;
}

.dropdown-menu {
    right: 0;
    left: auto;
    text-align: right;
}

.dropdown-menu .dropdown-item {
    text-align: right;
    padding-right: 1rem;
    padding-left: 1rem;
}

.dropdown-menu-end {
    right: 0;
    left: auto;
}

.navbar-nav .dropdown-menu {
    right: 0;
    left: auto !important;
    text-align: right;
    min-width: 120px;
    padding: 0px 0;
}
.navbar-nav .dropdown-menu .menu-item {
    margin: 0px 0;
}
.navbar-nav .dropdown-menu .dropdown-item {
    text-align: center !important;
    padding: 8px 14px;
    display: block;
    width: 100%;
    justify-content: flex-end;
}

.navbar-nav .dropdown-menu a {
    text-align: right !important;
    display: block;
    width: 100%;
}

.navbar-nav .dropdown-menu .dropdown-item:first-child {
    padding-top: 0.75rem;
}

.navbar-nav .dropdown-menu .dropdown-item:last-child {
    padding-bottom: 0.75rem;
}

.navbar-nav .dropdown {
    position: relative;
}

.navbar-nav .dropdown-menu-end {
    right: 0;
    left: auto !important;
}
.dropdown-item.active, .dropdown-item:active {
    background-color: #981B2B;
    color: #fff;
}

.site-footer .widget.widget_nav_menu ul li a[href="#"] {
    color: #212121 !important;
    text-decoration: none;
    pointer-events: none;
    cursor: default;
}

.site-footer .widget.widget_nav_menu ul li a[href="#"]:hover {
    color: #212121 !important;
    text-decoration: none;
}

.navbar-nav .nav-link[href="#"] {
    color: #767D7F !important;
    text-decoration: none;
    pointer-events: auto;
    cursor: default;
}

.navbar-nav .nav-link[href="#"]:hover {
    color: #767D7F !important;
    text-decoration: none;
}

.navbar-nav .nav-link[href="#"]:focus {
    color: #767D7F !important;
    text-decoration: none;
}

.navbar-nav .nav-link.active[href="#"],
.navbar-nav .nav-link.show[href="#"] {
    color: #981B2B !important;
    font-weight: 700;
    pointer-events: auto;
    cursor: pointer;
}

.navbar-nav .nav-link.active[href="#"]:hover,
.navbar-nav .nav-link.show[href="#"]:hover {
    color: #981B2B !important;
    font-weight: 700;
    text-decoration: none;
}

.navbar-cta {
    margin-left: 1rem;
}

.navbar-cta-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
}

.navbar-cta-menu li {
    margin: 0;
}

.navbar-cta-menu a {
    display: inline-block;
    padding: 0.8rem 1.5rem;
    background-color: transparent;
    border: 1px solid #981B2B;
    color: #981B2B !important;
    text-decoration: none;
    border-radius: 25px;
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
}

.navbar-cta-menu a:hover {
    background-color: #7a1522;
    color: #fff !important;
    text-decoration: none;
    transform: translateY(-1px);
}

@media (max-width: 991.98px) {
    .navbar-collapse {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        z-index: 1000;
        background-color: #f3eee8;
        padding: 1rem;
        border-bottom: 1px solid #32383d;
        box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        text-align: center;
    }

    .navbar-nav {
        align-items: flex-start;
        width: 100%;
    }

    .navbar-nav .nav-item {
        width: 96%;
    }

    .navbar-nav .nav-link {
        padding: 0.75rem 0;
        width: 100%;
    }

    .navbar-cta {
        margin-left: 0;
        margin-top: 1rem;
        width: 100%;
    }
    .navbar-nav .nav-link {
        display: block;
    }
    .navbar-cta-menu {
        justify-content: flex-start;
        width: 100%;
    }

    .navbar-nav .dropdown-menu {
        display: none;
        position: static;
        float: none;
        width: 100% !important;
        margin-top: 0;
        background-color: transparent;
        border: 0;
        box-shadow: none;
        padding-left: 0;
        margin-left: 0;
        right: auto !important;
        left: 0 !important;
        opacity: 1;
        visibility: visible;
        height: auto;
        overflow: visible;
    }

    .navbar-nav .dropdown-menu.show {
        display: block !important;
    }

    .navbar-nav .dropdown-menu .dropdown-item {
        text-align: center !important;
        padding: 0.5rem 0;
        width: 100%;
        margin-left: 0;
        display: block !important;
        color: #767D7F !important;
        background-color: transparent !important;
        border: none !important;
    }

    .navbar-nav .dropdown-menu .dropdown-item:hover {
        background-color: rgba(152, 27, 43, 0.1) !important;
        color: #981B2B !important;
    }

    .navbar-nav .dropdown-menu a {
        text-align: left !important;
    }
    .navbar-cta-menu li, .navbar-cta-menu a {
        width: 100%;
    }
    .site-footer .widget.widget_nav_menu ul li ul li {
        padding-left: 0px;
    }
    
    .site-footer .widget.widget_nav_menu ul li ul li::before {
        display: none;
    }
}

.properties-grid {
    margin-bottom: 2rem;
}

.property-title {
    font-family: "Inter", sans-serif;
}

.property-card {
    border: none;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    overflow: hidden;
    height: 100%;
}

.draft .property-card {
    opacity: 0.6;
    position: relative;
}

.draft .property-card::before {
    content: "DRAFT";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
    font-size: 2rem;
    font-weight: 700;
    color: #981B2B;
    z-index: 10;
    pointer-events: none;
    text-shadow: 2px 2px 4px rgba(255, 255, 255, 0.8);
    letter-spacing: 0.2em;
}

.property-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}

.property-image {
    height: 250px;
    object-fit: cover;
    transition: transform 0.5s ease;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

.property-image img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    transition: transform 0.5s ease;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

.property-card:hover .property-image {
    transform: scale(1.05);
}

.property-card:hover .property-image img {
    transform: scale(1.05);
}

.property-status {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    color: white;
}

.property-status.for-sale {
    background-color: #28a745;
}

.property-status.for-rent {
    background-color: #007bff;
}

.property-status.sold {
    background-color: #dc3545;
}

.property-status.rented {
    background-color: #6c757d;
}

.property-location {
    color: var(--secondary-color);
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.property-title {
    font-weight: 600;
    margin: 0.5rem 0;
}

.property-details {
    font-size: 0.875rem;
    color: var(--secondary-color);
    margin-bottom: 1rem;
}

.property-price {
    font-size: 1.25rem;
    font-weight: 700;
    color: #981B2B;
    margin-bottom: 0.5rem;
}

.property-features {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.property-features .feature {
    font-size: 0.85rem;
    color: #6c757d;
    background-color: #f8f9fa;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
}

/* Language Switcher Styles */
.homesinasia-language-switcher {
    display: inline-block;
}

.navbar-language-switcher .homesinasia-language-switcher {
    margin: 0;
}

.language-selector {
    padding: 6px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: #fff;
    font-size: 14px;
    min-width: 120px;
    cursor: pointer;
}

.language-selector:focus {
    border-color: #0073aa;
    outline: none;
    box-shadow: 0 0 0 1px #0073aa;
}

.language-flags {
    display: flex;
    gap: 5px;
    align-items: center;
}

.language-flag {
    display: inline-block;
    padding: 4px 8px;
    border: 1px solid #981B2B;
    border-radius: 4px;
    text-decoration: none;
    color: #981B2B;
    font-size: 11px;
    font-weight: bold;
    text-transform: uppercase;
    transition: all 0.2s ease;
    background: transparent;
    min-width: 30px;
    text-align: center;
}

.language-flag:hover {
    background: #eca0aa;
    text-decoration: none;
    color: #000;
    border-color: #981B2B;
}

.language-flag.active {
    background: #981B2B;
    color: #fff;
    border-color: #981B2B;
}

.homesinasia-language-switcher-widget {
    margin: 15px 0;
}

.homesinasia-language-switcher-widget .language-selector {
    width: 100%;
}

.homesinasia-language-switcher-widget .language-flags {
    flex-wrap: wrap;
    gap: 8px;
}

.homesinasia-language-switcher-widget .language-flag {
    flex: 1;
    min-width: 60px;
    padding: 8px 12px;
    font-size: 12px;
}

@media (max-width: 991.98px) {
    .navbar-language-switcher {
        margin-top: 15px;
        padding-top: 15px;
        border-top: 1px solid #dee2e6;
    }
    
    .navbar-language-switcher .language-flags {
        justify-content: center;
    }
}

body.lang-de .german-specific,
body.lang-nl .dutch-specific,
body.lang-en .english-specific {
    display: block !important;
}

body.lang-de .english-specific,
body.lang-de .dutch-specific,
body.lang-nl .english-specific,
body.lang-nl .german-specific,
body.lang-en .german-specific,
body.lang-en .dutch-specific {
    display: none !important;
}

.property-features .feature i {
    margin-right: 0.25rem;
}

.filter-section {
    border:2px solid #cecece !important;
    border-radius: 10px;
    padding: 1.5rem;
    /* box-shadow: 0 2px 10px rgba(0,0,0,0.05); */
    margin-bottom: 2rem;
}

.search-suggestion {
    background: #fff3cd;
    border: 1px solid #ffeaa7;
    padding: 0.75rem;
    border-radius: 5px;
    margin-bottom: 1rem;
    display: none;
}

.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,0.9);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.skeleton {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.skeleton-bar {
    height: 380px;
    border-radius: 10px;
    margin: 2rem 0;
}

.filter-badge {
    background: #000000;
    color: white;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.875rem;
    margin-right: 0.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.filter-badge .remove-filter {
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    color: white;
}

.recent-search-badge {
    background: #e9ecef;
    color: #495057;
    cursor: pointer;
    transition: background 0.2s;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.875rem;
    margin-right: 0.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.recent-search-badge:hover {
    background: #dee2e6;
}

.no-results-message {
    text-align: center;
    padding: 3rem 0;
}

.properties-pagination {
    text-align: center;
    margin-top: 2rem;
}

.properties-pagination .page-numbers {
    display: inline-block;
    padding: 0.5rem 0.75rem;
    margin: 0 0.25rem;
    border: 1px solid #dee2e6;
    border-radius: 4px;
    color: #981B2B;
    text-decoration: none;
    transition: all 0.3s ease;
}

.properties-pagination .page-numbers:hover,
.properties-pagination .page-numbers.current {
    background-color: #981B2B;
    color: white;
    border-color: #981B2B;
}
.property-card .card-body {
    background: #f3eee8;
}
@media (max-width: 768px) {
    .property-card {
        margin-bottom: 1rem;
    }
    
    .property-features {
        gap: 0.5rem;
    }
    
    .property-features .feature {
        font-size: 0.8rem;
        padding: 0.2rem 0.4rem;
    }
    
    .property-price {
        font-size: 1.1rem;
    }
}

/* Property Single Page Styles */

.property-single-wrapper {
    min-height: 100vh;
}

/* Header Section */
.property-header-section {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 3rem;
    padding: 0;
}

.header-left {
    flex: 1;
}

.header-content {
    flex: 1;
}

.property-title-main {
    font-size: 2.5rem;
    font-weight: 600;
    color: #000;
    margin: 0 0 0.75rem 0;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.property-price-line {
    font-size: 1.125rem;
    color: #333;
    margin-bottom: 0.5rem;
    font-weight: 400;
}

.property-price-line .price-amount {
    font-weight: 600;
}

.property-completion-line {
    color: #666;
    font-size: 0.875rem;
    margin-bottom: 0;
}

/* Property Details Card */
.property-details-card {
    background: #ffffff;
    border-radius: 12px;
    padding: 1.5rem;
    margin: 0 0 2rem 0;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(0, 0, 0, 0.05);
    width: 100%;
    border-bottom: 1px solid #ddd;
    position: relative;
}

.property-details-card::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 0;
    height: 0;
    border-left: 35px solid transparent;
    border-top: 35px solid #d0d0d0;
    border-top-right-radius: 12px;
    z-index: 2;
}

.property-detail-row {
    display: flex;
    margin-bottom: 0.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.property-detail-row:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.property-detail-label {
    flex: 0 0 200px;
    font-size: 1rem;
    color: #000;
    font-weight: 700;
    line-height: 1.4;
}

.property-detail-value {
    flex: 1;
    font-size: 1rem;
    color: #636363;
    line-height: 1.4;
    white-space: pre-line;
}

.property-detail-value.price-amount {
    font-size: 1.125rem;
}

.property-detail-value.area-details {
    white-space: pre-line;
    line-height: 1.5;
}

.header-right {
    margin-left: 2rem;
}

.inquire-button {
    color: white;
    border: none;
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 400;
    cursor: pointer;
    transition: background-color 0.2s ease;
    border-radius: 4px;
    text-decoration: none !important;
}

.inquire-button:hover {
    text-decoration: underline !important;
}

/* Content Container */
.property-content-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1rem;
}

/* Main Content Grid */
.property-main-content {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 4rem;
    margin-bottom: 3rem;
}

/* Gallery Section */
.gallery-section {
    width: 100%;
}

.gallery-layout {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.main-image-container {
    width: 100%;
    height: 500px;
    border-radius: 8px;
    overflow: hidden;
}

.main-image-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    cursor: pointer;
}

.thumbnails-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}

.thumbnail-item {
    height: 160px;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
}

.thumbnail-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.2s ease;
}

.thumbnail-item:hover img {
    transform: scale(1.05);
}

/* Content Section */
.content-section {
    width: 100%;
    padding: 0;
}

.description-block {
    margin-bottom: 2.5rem;
}

.content-heading {
    font-size: 1.125rem;
    font-weight: 600;
    color: #000;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.description-text {
    color: #333;
    line-height: 1.7;
    font-size: 0.875rem;
}

.description-text p {
    margin-bottom: 1rem;
}

.prices-block {
    margin-bottom: 2.5rem;
}

.price-points {
    list-style: none;
    padding: 0;
    margin: 0;
}

.price-points li {
    position: relative;
    padding-left: 1.25rem;
    margin-bottom: 0.75rem;
    color: #333;
    font-size: 0.875rem;
    line-height: 1.6;
}

.price-points li::before {
    content: 'â€¢';
    position: absolute;
    left: 0;
    color: #666;
}

/* Map Section */
.map-section-full {
    margin-top: 3rem;
    margin-bottom: 4rem;
}

.map-embed {
    border-radius: 8px;
    overflow: hidden;
    height: 400px;
}

.map-embed iframe {
    width: 100%;
    height: 100%;
    border: none;
}

/* Dream Home Section */
.dream-home-section {
    padding: 4rem 0;
    margin-top: 30px;
}

.dream-home-container {
    margin: 0 auto;
    padding: 0 1rem;
}

.section-heading {
    font-family: "Inter", sans-serif;
    font-size: 2.25rem;
    font-weight: 400;
    color: #000;
    margin-bottom: 2.5rem;
    text-align: center;
}

.dream-home-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}

.dream-home-card {
    background: white;
    border-radius: 4px;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dream-home-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.dream-home-card .card-image {
    height: 180px;
    overflow: hidden;
}

.dream-home-card .card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.2s ease;
}

.dream-home-card:hover .card-image img {
    transform: scale(1.03);
}

.dream-home-card .card-content {
    padding: 1rem;
}

.dream-home-card .card-title {
    font-size: 1rem;
    font-weight: 400;
    color: #000;
    margin-bottom: 0.25rem;
}

.dream-home-card .card-location {
    font-size: 0.75rem;
    color: #666;
    margin-bottom: 0.5rem;
}

.dream-home-card .card-price {
    font-size: 0.875rem;
    font-weight: 500;
    color: #000;
    margin: 0;
}

.see-all-wrapper {
    text-align: center;
}

.see-all-btn {
    display: inline-block;
    padding: 0.5rem 1.5rem;
    border-radius: 0;
    color: #000;
    text-decoration: none !important;
    font-size: 0.875rem;
    font-weight: 400;
    transition: all 0.2s ease;
}

.see-all-btn:hover {
    text-decoration: underline !important;
}

/* Responsive Styles */
@media (max-width: 1024px) {
    .property-main-content {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    
    .content-section {
        max-width: 600px;
        margin: 0 auto;
    }
}

@media (max-width: 768px) {
    .property-title-main {
        font-size: 2rem;
    }
    
    .property-header-section {
        flex-direction: column;
        gap: 0rem;
    }
    .header-right {
        margin-left: 0;
        margin-bottom: 1rem;
    }
    
    .inquire-button {
        width: 100%;
        max-width: 300px;
    }
    
    .main-image-container {
        height: 300px;
    }
    
    .thumbnails-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .thumbnail-item {
        height: 120px;
    }
    
    .dream-home-grid {
        grid-template-columns: 1fr;
    }
    
    .dream-home-section {
        padding: 3rem 0;
    }
    
    .section-heading {
        font-size: 1.75rem;
    }
}




#galleryModal .modal-content {
    border-radius: 12px;
    border: none;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}

#galleryModal .modal-header {
    border-bottom: 1px solid #e9ecef;
    background: #f8f9fa;
    border-radius: 12px 12px 0 0;
}

#galleryModal .modal-title {
    font-weight: 600;
    color: #212121;
}

#galleryModal .modal-body {
    padding: 0;
    background: #000;
}

#galleryModal .modal-body img {
    max-height: 80vh;
    object-fit: contain;
    width: 100%;
}

#galleryModal .modal-footer {
    border-top: 1px solid #e9ecef;
    background: #f8f9fa;
    border-radius: 0 0 12px 12px;
}

#galleryModal .btn-close {
    background-size: 1.5em;
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

#galleryModal .btn-close:hover {
    opacity: 1;
}

@media (max-width: 768px) {
    #galleryModal .modal-dialog {
        margin: 0.5rem;
    }
    
    #galleryModal .modal-body img {
        max-height: 70vh;
    }
    

}

.property-image-container {
    position: relative;
    overflow: hidden;
}

.property-tags {
    position: absolute;
    top: 10px;
    right: 10px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    z-index: 2;
}

.property-tag {
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: white;
    letter-spacing: 0.5px;
    white-space: nowrap;
    background-color: #000000;
}

.property-status-tag {
    background-color: #000000;
}

.property-status-tag.for-rent {
    background-color: #000000;
}

.property-status-tag.sold {
    background-color: #000000;
}

.property-status-tag.rented {
    background-color: #000000;
}

.property-type-tag {
    background-color: #000000;
}

.property-title {
	font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 1.1rem;
    margin: 0.5rem 0;
    color: #212121;
    line-height: 1.3;
}

.property-location {
    color: #6c757d;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 500;
    margin-bottom: 0.5rem;
}

.property-details {
    font-size: 0.875rem;
    color: #6c757d;
    margin-bottom: 1rem;
}

.property-details p {
    margin-bottom: 0.5rem;
    font-size: 0.8rem;
    color: #6c757d;
}

.property-price {
    font-size: 1.1rem;
    font-weight: 700;
    color: #212121;
    margin-bottom: 0;
}

#viewAllProperties {
    background-color: #981B2B;
    border-color: #981B2B;
    color: white;
    padding: 0.5rem 1.5rem;
    border-radius: 4px;
    font-weight: 500;
    transition: all 0.3s ease;
}

#viewAllProperties:hover {
    background-color: #7a1622;
    border-color: #7a1622;
    color: white;
    transform: translateY(-1px);
}

.recent-search-badge .remove-filter {
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    color: #495057;
}

.property-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
    transition: transform 0.2s ease;
}

.property-card-link:hover {
    text-decoration: none;
    color: inherit;
    transform: translateY(-2px);
}

.property-card-link:hover .property-card {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.property-single-wrapper {
    padding: 0 0;
}

.property-main-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    max-width: 100%;
    margin: 0 auto;
    padding: 0 1rem;
}

.gallery-layout {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    gap: 1rem;
}

.main-image-container {
    grid-column: 1 / -1;
    height: auto;
}

.main-image-container img {
    width: 100%;
    height: auto;
    max-height: 600px;
    object-fit: cover;
}

.thumbnails-grid {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.thumbnail-item {
    height: 150px;
}

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

.content-section {
    padding-left: 2rem;
}

.property-header-section {
    border-bottom: 1px solid #ddd;
    margin-bottom: 1.5rem;
}

.property-title-main {
    font-family: "Inter", sans-serif;
    font-size: 3rem;
    font-weight: 400;
    margin-bottom: 1rem;
}

.property-price-line,
.property-completion-line {
    font-size: 1.1rem;
    color: #333;
    margin-bottom: 0.5rem;
}

.inquire-button {
    background: none;
    border: none;
    color: #981B2B;
    text-decoration: underline;
    font-size: 1rem;
    padding: 0;
    cursor: pointer;
}

.content-heading {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
    border-bottom: 1px solid #ddd;
    padding-bottom: 0.5rem;
}

.description-text,
.price-points {
    font-size: 1rem;
    line-height: 1.6;
}

.price-points {
    list-style-type: disc;
    padding-left: 1.5rem;
}

.map-section-full {
    max-width: 100%;
    margin: 3rem auto 0;
    padding: 0 1rem;
}

.dream-home-section {
    text-align: center;
    padding: 4rem 0;
}

.dream-home-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin: 0 auto 2rem;
    padding: 0 0;
}

.dream-home-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
    transition: transform 0.3s ease;
}

.dream-home-card-link:hover {
    text-decoration: none;
    color: inherit;
    transform: translateY(-5px);
}

.dream-home-card {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 15px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
    height: 100%;
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
}

.dream-home-card:hover {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.dream-home-image {
    position: relative;
    flex: 1;
    overflow: hidden;
}

.dream-home-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.dream-home-card:hover .dream-home-image img {
    transform: scale(1.05);
}

.dream-home-content {
    padding: 1.25rem;
    text-align: left;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 110px;
}

.dream-home-title {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.4rem;
    color: #212121;
    line-height: 1.3;
}

.dream-home-location {
    color: #6c757d;
    font-size: 0.85rem;
    margin-bottom: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dream-home-price {
    font-size: 1rem;
    font-weight: 700;
    color: #212121;
    margin-bottom: 0;
}

.see-all-btn {
    text-decoration: underline;
    color: #333;
    font-weight: 500;
    transition: color 0.3s ease;
}

.see-all-btn:hover {
    color: #981B2B;
    text-decoration: underline;
}

@media (max-width: 1200px) {
    .dream-home-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem;
    }
}

@media (max-width: 768px) {
    .dream-home-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.25rem;
    }
    
    .dream-home-content {
        padding: 1rem;
        min-height: 90px;
    }
    
    .dream-home-title {
        font-size: 1rem;
    }
    
    .dream-home-location {
        font-size: 0.8rem;
    }
    
    .dream-home-price {
        font-size: 0.95rem;
    }
}

@media (max-width: 480px) {
    .dream-home-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
}

.breadcrumb-nav {
    margin: 2rem 0;
    padding: 0;
}

.breadcrumb {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: wrap;
    gap: 0;
    align-items: center;
}

.breadcrumb-item {
    font-size: 14px;
    color: #666;
    gap: 0;
}

.breadcrumb-item a {
    color: #981B2B;
    text-decoration: none;
    transition: color 0.3s ease;
}

.breadcrumb-item a:hover {
    color: #981B2B;
    text-decoration: underline;
}

.breadcrumb-item.active {
    color: #333;
    font-weight: 500;
}

.breadcrumb-nav .breadcrumb-item:not(:last-child)::after {
    content: "›" !important;
    margin: 0 6px;
    color: #999;
    font-size: 14px;
    display: inline-block;
}

.breadcrumb-nav .breadcrumb-item + .breadcrumb-item::before {
    content: "";
    display: none;
}
.breadcrumb-item+.breadcrumb-item {
    padding-left: 0px !important;
}
#faq .vc_tta-panel-heading h4 .vc_tta-title-text {
    font-size: 20px !important;
    font-weight: normal !important;
    color: #212121 !important;
}
#faq .vc_tta-panel-body {
    padding-left:45px !important;
    padding-bottom:30px !important;
}
#faq .vc_tta-panel-body {
    font-size:16px !important;
    color: #4b4b4b !important;
}
#faq .vc_tta-color-grey.vc_tta-style-classic .vc_tta-panel .vc_tta-panel-heading, #faq .vc_tta-color-grey.vc_tta-style-classic .vc_tta-panel .vc_tta-panel-body {
    background-color: transparent !important;
    border-color: transparent !important;
}
.btn-blank a {
    color: #880522 !important;
    background-color: transparent !important;
    background-image: none !important;
}
.btn-blank a:hover {
    color: #AB072B !important;
    text-decoration: underline !important;
}
.dark-overlay {
    background-color: #000000 !important;
}
.dark-overlay .skrollable.skrollable-between {
    opacity: 0.4 !important;
}
@media (max-width: 768px) {
    .breadcrumb-nav {
        margin: 1rem 0;
        padding-left:6px !important;
    }
    .breadcrumb-item {
        font-size: 13px;
    }
    .p-sm-0 > div {
        padding-left:0px !important;
        padding-right:0px !important;
    }
    .p-sm-15 > div {
        padding-left:15px !important;
        padding-right:15px !important;
    }
    .p-sm-30 > div {
        padding-left:30px !important;
        padding-right:30px !important;
    }
    .fs-60,.fs-65,.fs-100 {
        line-height: 1.1 !important;
    }
    .fs-100 {
        font-size: 60px !important;
    }
    .fs-65 {
        font-size: 52px !important;
    }
    .fs-60 {
        font-size: 32px !important;
    }
    .fs-26 {
        font-size: 20px !important;
    }
    .video-fh {
        min-height: auto !important;
        margin-top:0px !important;
    }
    #ultimate-guides > div,
    .footer-col,
    .the-team > div > div,
    .vc_custom_1752422923189 {
        padding-left:30px !important;
        padding-right:30px !important;
    }
    .the-team > div > div > div .wpb_text_column.wpb_content_element {
        width:100% !important;
    }
    #ultimate-guides .wpb_single_image.vc_align_center {
        margin-bottom:90px !important;
    }
    #ultimate-guides .wpb_heading.wpb_singleimage_heading {
        min-height: 42px;
        bottom: 25px;
        padding:0 60px !important;
    }
    #home-header .wpb_wrapper h1,
    #home-header .wpb_wrapper div {
        text-align: center !important;
    }
    #home-header .wpb_wrapper h1 {
        margin-bottom: 30px;
    }
    #home-header .wpb_left-to-right .vc_column-inner {
        padding-right:0px !important;
    }
    #home-header {
        padding-top:30px !important;
        padding-bottom:30px !important;
    }
    .site-footer {
        text-align: center;
    }
    #block-5, #block-7 {
        margin-top:20px !important;
    }
    #block-8, #block-9 {
        float:left;
        width:50%;
    }
	#block-10 ul {
		display: block !important;
	}
    .site-footer #menu-top-menu .menu-item-has-children .sub-menu li:before {
        display: none;
    }
    .site-footer #menu-top-menu .menu-item-has-children .sub-menu li {
        padding-left:0px !important;
    }
    .site-footer #menu-top-menu .menu-item-has-children > a {
        font-weight: 700 !important;
    }
    #what-we-do > div > .vc_column-inner {
        padding:15px 30px !important;
    }
    .property-main-content {
        display: block;
    }
    .property-main-content .content-section {
        padding-left:0px !important;
        margin-top:30px !important;
    }
    .property-main-content .thumbnail-item {
        height: 60px;
    }
}

@media (min-width: 992px) {
    .navbar > .container {
        position: relative;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .navbar-expand-lg .navbar-nav {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }

    .navbar-expand-lg .navbar-collapse {
        flex-grow: 1;
    }

    .navbar-expand-lg .navbar-cta {
        margin-left: auto;
    }
}

/* Hamburger Icon Animation */
.navbar-toggler {
    border: none;
    padding: 0;
    outline: none !important;
    position: relative;
    width: 24px;
    height: 18px;
    transition: all 0.3s ease-in-out;
    background-color: transparent;
}

.navbar-toggler:focus {
    box-shadow: none;
}

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

.navbar-toggler .toggler-icon:nth-child(1) {
    top: 0px;
}

.navbar-toggler .toggler-icon:nth-child(2) {
    top: 8px;
}

.navbar-toggler .toggler-icon:nth-child(3) {
    top: 16px;
}

.navbar-toggler.is-active .toggler-icon:nth-child(1) {
    top: 8px;
    transform: rotate(135deg);
}

.navbar-toggler.is-active .toggler-icon:nth-child(2) {
    opacity: 0;
    transform: translateX(-100%);
}

.navbar-toggler.is-active .toggler-icon:nth-child(3) {
    top: 8px;
    transform: rotate(-135deg);
}

.navbar-toggler-icon {
    display: none !important;
}
@media (min-width: 1600px) {
    .container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
        max-width: 1650px !important;
    }
}

.whatsapp-float {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 1000;
}

.whatsapp-float a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background-color: #25D366;
    color: white;
    border-radius: 50%;
    text-decoration: none;
    font-size: 40px;
    box-shadow: 0 4px 12px rgba(37, 211, 102, 0.3);
    transition: all 0.3s ease;
}

.whatsapp-float a:hover {
    background-color: #20ba5a;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(37, 211, 102, 0.4);
    color: white;
    text-decoration: none;
}

.whatsapp-float a:focus {
    outline: 2px solid #25D366;
    outline-offset: 2px;
}

@media (max-width: 768px) {
    .whatsapp-float {
        bottom: 15px;
        right: 15px;
    }
    
    .whatsapp-float a {
        width: 50px;
        height: 50px;
        font-size: 24px;
    }
    .property-detail-row {
        flex-direction: column;
    }
    .property-detail-label {
        flex: 0 0 30px;
    }
    .property-title-main {
        font-size: 40px;
    }
}

.navbar-language-switcher-mobile {
    position: absolute;
    right: 60px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 1005;
}

.language-mobile-toggle {
    position: relative;
}

.language-mobile-toggle.dropdown {
    position: relative;
}

.language-toggle-btn {
    background: none;
    border: 1px solid #3f3f3f;
    color: #3f3f3f;
    padding: 2px 10px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.3s 
ease;
}

/* .language-toggle-btn:hover {
    background: #d4a574;
    color: white;
} */

.language-toggle-btn i {
    font-size: 12px;
    transition: transform 0.3s ease;
}

.language-toggle-btn[aria-expanded="true"] i {
    transform: rotate(180deg);
}

.language-dropdown {
    min-width: 56px;
    border-radius: 0px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    padding: 0px 0;
}

.language-dropdown .dropdown-item {
    padding: 8px 16px;
    font-size: 14px;
    color: #333;
    text-decoration: none;
    transition: all 0.2s ease;
}

.language-dropdown .dropdown-item:hover {
    background: #981B2B;
    color: white;
}

.language-dropdown .dropdown-item.active {
    background: #981B2B;
    color: white;
}

.navbar-cta {
    display: flex;
    align-items: center;
    gap: 15px;
}

.navbar-language-switcher-desktop {
    display: inline-block !important;
    visibility: visible !important;
    margin: 0;
}

@media (max-width: 991.98px) {
    .navbar-language-switcher-desktop {
        display: none !important;
    }
}

.navbar-language-switcher-desktop .language-flags {
    display: inline;
}

.navbar-language-switcher-desktop .language-flag {
    text-decoration: none;
    color: #767D7F !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    padding: 0px 10px !important;
    transition: all 0.3s ease !important;
    border: none !important;
    border-radius: 0px !important;
    vertical-align: middle !important;
    border-right: 1px solid #c0c0c0 !important;
}
.navbar-language-switcher-desktop .language-flag:last-child {
    border-right: none !important;
}
.navbar-language-switcher-desktop .language-flag:hover {
    text-decoration: none !important;
    color: #981B2B !important;
    background-color: transparent !important;
}

.navbar-language-switcher-desktop .language-flag.active {
    color: #981B2B !important;
    font-weight: 700 !important;
    background-color: transparent !important;
}

.property-map-container{position:relative;margin:2rem 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.property-map-container #property-map{border-radius:8px}
.property-map-container .map-info{position:absolute;top:10px;left:10px;background:rgba(255,255,255,0.95);padding:8px 12px;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,0.1);z-index:10}
.property-map-info-window{max-width:300px;font-family:"Inter",sans-serif;background:#f3eee8;border-radius:8px;overflow:hidden}
.property-map-info-window .property-map-image{margin:40px 0 0 0}
.property-map-info-window .property-map-image img{display:block;width:100%;height:150px;border-radius:0;object-fit:cover}
.property-map-info-window .property-map-content{background:#f3eee8;border-radius:0;padding:15px}
.property-map-info-window{opacity:0;transform:translateY(-10px);transition:opacity .28s cubic-bezier(.22,.61,.36,1), transform .28s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
.property-map-info-window.animate-in{opacity:1;transform:translateY(0)}
.property-map-info-window.animate-out{opacity:0;transform:translateY(-10px)}
.property-map-info-window .property-map-nav{position:absolute;top:7px;z-index:2;width:28px;height:28px;border-radius:50%;border:0px;background:#f3eee8;color:#981B2B;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s ease; font-size: 20px !important;line-height:20px !important;}
.property-map-info-window .property-map-prev{left:8px}
.property-map-info-window .property-map-next{left:40px}
.property-map-info-window .property-map-nav:hover{background:#981B2B;color:#f3eee8}
.property-map-info-window .property-map-title{font-size:1rem;font-weight:600;color:#333;line-height:1.3;margin:0 0 8px 0}
.property-map-info-window .property-map-location{font-size:.9rem;color:#666;margin:0 0 12px 0}
.property-map-info-window .property-map-cta{display:block;width:100%;text-align:center;padding:.8rem 1.5rem;background-color:transparent;border:1px solid #981B2B;color:#981B2B !important;text-decoration:none;border-radius:25px;font-weight:500;font-size:14px;letter-spacing:.5px;transition:all .3s ease}
.property-map-info-window .property-map-cta:hover{background-color:#7a1522;color:#fff !important;text-decoration:none;transform:translateY(-1px)}
.gm-style .gm-style-iw-c{padding:0 !important;border-radius:8px !important;box-shadow:0 4px 12px rgba(0,0,0,0.15) !important;background:transparent !important}
.gm-style .gm-style-iw-d{overflow:hidden !important;padding:0 !important;background:transparent !important}
.gm-style .gm-style-iw-tc{display:none !important}

.gm-style .gm-ui-hover-effect{background:#f3eee8 !important;border-radius:50% !important;width:28px !important;height:28px !important;box-shadow:0 2px 6px rgba(0,0,0,0.15);}
.gm-style .gm-ui-hover-effect span{margin:6px !important}
/* Leaflet popup overrides for OpenStreetMap fallback */
.leaflet-popup-content-wrapper{background:#f3eee8;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.15);padding:0}
.leaflet-popup-content{margin:0 auto !important;padding:0;width:200px !important}
.leaflet-container .leaflet-popup-close-button{background:#f3eee8 !important;border-radius:0% !important;width:28px !important;height:28px !important;line-height:1.5 !important;color:#981B2B !important;text-align:center;top:7px !important;right:2px !important;}
.leaflet-container .leaflet-popup-close-button:hover{background:#981B2B !important;color:#f3eee8 !important; transition: 0.3s ease;}
.leaflet-popup-tip{background:#f3eee8}
@media (max-width:768px){.property-map-container{margin:1rem 0}.property-map-container .map-info{position:static;margin-bottom:10px;text-align:center}.property-map-info-window{max-width:280px}.property-map-info-window .property-map-image img{height:120px}}