/*
Theme Name: MDS Child
Template: mds
Author: Modern Day Strategy
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 5.7
*/

/*------------------------------------------------
Global Styles
------------------------------------------------*/
:root {
	--wp--preset--font-size--h-3: clamp(
		1.5rem,
		1.6rem + ((1vw - 0.2rem) * 0.653),
		1.9rem
	);
	--header-color: var(--wp--preset--color--text);
	color-scheme: dark;
}

:root :where(.wp-block-heading),
:root :where(.wp-block-list),
:root :where(p) {
}

html,
body {
	background-color: var(--wp--preset--color--text) !important;
	color: var(--wp--preset--color--background);
}

.full-width-button,
.full-width-button a {
	width: 100%;
}

.wp-block-button a {
	border-radius: 3px;
	border: 1px solid var(--wp--preset--color--text-alt);
	background: var(--wp--preset--color--text);
	color: var(--wp--preset--color--background);
	transition: opacity 0.25s ease;
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--p-2);
	padding: 6px 10px;
	text-transform: uppercase;
}
.wp-block-button a:hover {
	opacity: 0.75;
}
.wp-block-button.text-button a {
	padding: 0;
	border: none;
}
.wp-block-button.is-style-outline .wp-block-button__link {
	color: var(--wp--preset--color--background) !important;
	border-color: var(--wp--preset--color--background);
	border-width: 1px;
	background-color: transparent !important;
}
.wp-block-button.is-style-outline.dark-outline .wp-block-button__link {
	color: var(--wp--preset--color--primary) !important;
	border-color: var(--wp--preset--color--primary);
	background-color: transparent !important;
}
.wp-block-button.underline-link {
	--_underline-color: var(--wp--preset--color--background);
	--_underline-width: 100%;
}
.wp-block-button.underline-link:hover {
	--_underline-width: 90%;
}
.wp-block-button.underline-link:hover a {
	opacity: 1;
}
.wp-block-button.underline-link a {
	padding: 0;
	background: transparent !important;
}
.wp-block-button.arrow-link .wp-block-button__link {
	padding: 0;
	background-color: transparent;
	color: var(--wp--preset--color--text);
	text-transform: uppercase;
	font-weight: 500;
	white-space: nowrap;
	font-size: var(--wp--preset--font-size--p-2);
}
.wp-block-button.arrow-link .wp-block-button__link::after {
	content: "";
	display: inline-block;
	background: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjYiIGhlaWdodD0iOCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMCA0aDI1TTIxLjUuNSAyNSA0bC0zLjUgMy41IiBzdHJva2U9IiMwMDNGM0UiLz48L3N2Zz4=");
	background-repeat: no-repeat;
	background-size: contain;
	width: 25px;
	height: 9px;
	margin-left: 7px;
	transition: translate 0.2s ease;
}
.wp-block-button.arrow-link .wp-block-button__link:hover::after {
	translate: 4px 0;
}

.wp-block-cover {
	margin-top: 0;
}

.wp-block-cover .wp-block-cover__background {
	background-color: #090d1d !important;
}

.heading-secondary {
	font-family: "Bebas Neue";
	text-transform: uppercase;
}
.centered-image {
	display: flex;
	justify-content: center;
	align-items: center;
}

/*------------------------------------------------
404
------------------------------------------------*/
.section-404 {
	height: 100svh;
}
.section-404 :is(figure, img) {
	height: 100%;
	object-fit: cover;
}

/*------------------------------------------------
accordions
------------------------------------------------*/
.wp-block-tn-accordions {
	--_padding-inline: 0;
	--_padding-block: 1.5rem;
	--_border-radius: 0px;
	--_accordion-spacing: 0;
	--_outer-divider-color: #1e244633;
}
.wp-block-tn-accordion {
	border: none;
}

.post-filter .wp-block-tn-accordion .content {
	padding-top: 0;
	display: grid;
	grid-template-columns: auto 1fr;
}

.wp-block-tn-accordion h3 {
	font-size: var(--wp--preset--font-size--h-5);
	padding-top: 4px;
}

/*------------------------------------------------
Contact Form 7
------------------------------------------------*/
.wpcf7 {
	--_input-inline-padding: 0.8rem;
	--_input-block-padding: 0.7rem;
	--_select-arrow-size: 8px;
	--_input-color: var(--wp--preset--color--background);
	--_placeholder-color: var(--wp--preset--color--background-alt);
	--_input-border-color: var(--wp--preset--color--text-alt);
	--_submit-button-color: #666666;
	--_submit-button-text-color: var(--wp--preset--color--background);
	--_submit-button-padding: 0.5rem 1rem;
}
.wpcf7 label {
	font-size: var(--wp--preset--font-size--p-2);
}
.wpcf7 form p {
	margin-block: 0.5rem;
}
.wpcf7 form p:first-of-type {
	margin-top: 0;
}
.wpcf7 form p:last-of-type {
	margin-bottom: 0;
}
.wpcf7 :is(input, textarea, select) {
	font-size: var(--wp--preset--font-size--p-2);
	box-sizing: border-box;
	border-radius: var(--border-radius);
	background-color: transparent;
	border: 1px solid var(--_input-border-color);
}
.wpcf7 textarea {
	resize: block;
	height: 150px;
}
.wpcf7-form-control {
	padding: var(--_input-block-padding) var(--_input-inline-padding);
	border: 1px solid #003f3e33;
	color: var(--_input-color);
	width: 100%;
}
.wpcf7-select {
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	position: relative;
}
.wpcf7-form-control-wrap:has(.wpcf7-select)::after {
	content: "";
	position: absolute;
	inset: calc(50% - 1px) var(--_input-inline-padding) auto auto;
	translate: 0 -50%;
	rotate: 45deg;
	width: var(--_select-arrow-size);
	height: var(--_select-arrow-size);
	aspect-ratio: 1;
	border: 0px solid #003f3e33;
	border-bottom-width: 1px;
	border-right-width: 1px;
}
.wpcf7-textarea::placeholder,
.wpcf7-text::placeholder,
.wpcf7-list-item-label,
.wpcf7-date {
	color: var(--_placeholder-color);
}
.wpcf7-list-item {
	margin: 0;
}
.wpcf7-not-valid-tip {
	font-size: var(--wp--preset--font-size--p-2);
	margin-top: 0.5rem;
	color: #ae2424;
}
input.wpcf7-submit {
	width: 100%;
	padding: var(--_submit-button-padding);
	background-color: var(--_submit-button-color);
	color: var(--_submit-button-text-color);
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--p-1);
	line-height: 1.6;
	text-decoration: none;
	text-transform: uppercase;
	border-radius: 0px;
	border: 1px solid var(--wp--preset--color--text);
	transition: opacity 0.25s ease;
	cursor: pointer;
}
input.wpcf7-submit:hover {
	opacity: 0.75;
}
.wpcf7-spinner {
	display: none;
}
.wpcf7 form.wpcf7-form .wpcf7-response-output {
	border: 1px solid hsl(0, 0%, 60%);
	margin: 0;
	color: hsl(0, 0%, 70%);
}
.wpcf7-form-control.wpcf7-checkbox {
	display: flex;
	flex-direction: column;
}

@media screen and (min-width: 781px) {
	.contact-form form.wpcf7-form {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 1rem;
	}
	.contact-form form.wpcf7-form p {
		margin-top: 0;
	}
	.contact-form form.wpcf7-form p:nth-child(n + 6) {
		grid-column: 1/3;
	}
}

.wpcf7 label {
	font-weight: 600;
}
.wpcf7 .standard-label {
	font-weight: 400;
}

section.wp-block-group > .order-form-section {
	max-width: 1000px;
}

.hero-gradient {
	position: relative;
	isolation: isolate;
}
.hero-gradient::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(0deg, black, transparent 20%);
	z-index: 1;
}

/*------------------------------------------------
pages
------------------------------------------------*/
.person-wrapper {
	display: grid;
	grid-template-columns: 400px 1fr 200px;
	gap: 1rem;
}
.person-wrapper > * {
	margin: 0;
}
.person-wrapper .entry-content * {
	color: var(--wp--preset--color--background);
}
.person-wrapper .wp-block-post-featured-image {
	grid-row: 1/3;
}

.person-wrapper .info {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.person-wrapper .info .info-item {
	margin: 0;
}
.person-wrapper .info .info-item:not(:has(:is(div, p))) {
	display: none !important;
}
.person-wrapper .info .info-item :is(div, p) {
	margin-top: 0.6rem;
}
@media screen and (max-width: 1000px) {
	.person-wrapper {
		grid-template-columns: 250px 1fr 200px;
	}
}
@media screen and (max-width: 850px) {
	.person-wrapper {
		grid-template-columns: 200px 1fr;
	}
	.person-wrapper .info {
		grid-column: 1/2;
	}
	
}
@media screen and (max-width: 600px) {
	.person-wrapper {
		grid-template-columns: 1fr;
	}
	.person-wrapper .info {
		grid-column: 1;
	}
	
}

/* Title Group Styling */
.title-group .left h2.big {
    font-size: 36px;
    margin-bottom: 10px;
}

.title-group .left h2.big span {
    color: #000; /* Adjust to match your theme */
}

.title-group .left h3 {
    font-size: 20px;
    color: #666;
}

footer > .wp-block-group {
	background-color: #000000 !important;
}

.wpcf7 {
	--_input-border-color: transparent;
}
.wpcf7 :is(input, textarea, select):not(input[type="submit"]) {
	border-radius: 0;
	border-bottom-color: var(--wp--preset--color--background-alt);
}

/* ==========================================
   PERSON PROPERTIES RESPONSIVE GRID
   ========================================== */
.person-properties-responsive {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    width: 100%;
}

/* Tablet: 2 columns */
@media (max-width: 1024px) {
    .person-properties-responsive {
        grid-template-columns: repeat(2, 1fr);
        gap: 18px;
    }
}

/* Mobile: Stack in single column */
@media (max-width: 768px) {
    .person-properties-responsive {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }
    
   
}

/* Extra small mobile */
@media (max-width: 480px) {
    .person-properties-responsive {
        gap: 12px !important;
    }
}

/*------------------------------------------------
Property Cards and Sliders
------------------------------------------------*/

/* Responsive adjustments */
@media screen and (max-width: 600px) {
	.property-posts {
		--_min-col-width: 300px;
	}
}

/* Property card base styles */
.property-card {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
/* 	padding: 1rem; */
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: 1fr auto;
	min-height: 220px;
	text-decoration: none;
	isolation: isolate;
	position: relative;
	transition: translate 0.35s ease, box-shadow 0.25s ease-out;
}

/* Ensure property cards in sliders are visible */
.wp-block-tn-property-slider .property-card {
	display: grid;
	width: 100%;
	opacity: 1 !important; /* Prevent any visibility issues */
}

/* Property query card */
.property-query-card {
	min-height: 330px;
}
.property-query-card figure {
	position: absolute;
	inset: 0;
	z-index: -2;
}
.property-query-card figure img {
	width: 100%;
	height: 100%;
	object-fit: cover; /* Ensure images fill the card */
}

/* Alternate card layout */
.property-card-alt {
	--_col-gap: 0.7rem;
	grid-template-columns: auto 1fr;
	column-gap: 0.7rem;
}

/* Hover effects */
.property-card:not(.property-card-alt):hover {
	box-shadow: 0px 0px 12px 2px #9b9b9b47;
	translate: 0px -2px;
}

/* Gradient overlay */
.property-card::before {
	content: '';
	background: linear-gradient(0deg, black, transparent 50%);
	position: absolute;
	inset: 0;
	z-index: -1;
}

/* Card content styles */
.property-card > * {
	margin: 0;
	color: var(--wp--preset--color--background);
}
.property-card :is(.title, .wp-block-post-title) {
	grid-column: 1/3;
	align-self: flex-end;
}
.property-card-alt .title {
	text-transform: uppercase;
}
.property-card :is(.location, .property-location) {
	text-transform: uppercase;
}
.property-card-alt .price::before {
	content: "";
	background-color: var(--wp--preset--color--background);
	width: 4px;
	aspect-ratio: 1;
	border-radius: 50%;
	margin-right: var(--_col-gap);
	display: inline-block;
}
.property-card-alt .price {
	display: flex;
	align-items: center;
}
.property-query-card .price {
	display: flex;
	gap: 0.4rem;
}
.property-query-card .price * {
	margin: 0;
}
.property-card-alt .details {
	font-size: var(--wp--preset--font-size--p-2);
}

/* Team page styles (unchanged) */
.team-page-content .wp-block-tn-team-job-title {
	margin-top: 5px;
	text-transform: uppercase;
}

/* Property slider wrapper styles */
.property-slider-title .subheading-row {
	margin-top: 0;
}
:is(.property-slider-wrapper, .featured-property-slider-wrapper) {
	margin: 0;
	background: var(--wp--preset--color--text);
}

/* Remove Swiper-specific margins since sliders are now grids */
.property-slider .wp-block-post .property-card,
.featured-property-slider .wp-block-post .property-card {
	margin: 0; /* Override slider-specific margins */
}

/* Hide empty sliders */
body:not(:has(.property-slider-wrapper[data-sale-type="buy"] .wp-block-post)) :is(.property-slider-title.buy, .property-slider-wrapper[data-sale-type="buy"]),
body:not(:has(.property-slider-wrapper[data-sale-type="sell"] .wp-block-post)) :is(.property-slider-title.sell, .property-slider-wrapper[data-sale-type="sell"]),
body:not(:has(.property-slider-wrapper[data-sale-type="rent"] .wp-block-post)) :is(.property-slider-title.rent, .property-slider-wrapper[data-sale-type="rent"]) {
	display: none;
}

/* Featured property styles */
.featured-property .featured-property-nav {
	position: absolute;
	inset: auto calc(50% - var(--page-padding)) 1.7rem;
	z-index: 1;
	max-width: var(--wp--style--global--wide-size);
	width: 100%;
	translate: -50% 0;
}
@media screen and (max-width: 600px) {
	.featured-property .featured-property-nav {
		display: none;
	}
}
.featured-property {
	position: relative;
}
.featured-property-slider .property-card {
	min-height: 400px;
}
.featured-property-slider .swiper-button-wrapper {
	display: none;
}

/* Utility classes */
.max-width-700-center {
	max-width: 700px;
	margin-inline: auto !important;
}

/* Ensure grid items are not affected by Swiper styles */
.wp-block-tn-property-slider .wp-block-post{
	margin-top: 0;
	display: block;
	width: 100%;
}

/* Property hero (unchanged) */
.property-hero {
	height: 600px;
	max-width: 100%;
	display: grid;
	grid-template-columns: auto 250px;
	background: linear-gradient(0deg, black, transparent 50%);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	position: relative;
	isolation: isolate;
	margin: 0;
}
.property-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(0deg, black, transparent 20%);
	z-index: 2;
	pointer-events: none;
}
.property-gallery {
	grid-column: 2/3;
	overflow-y: scroll;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 1rem 1rem 5rem;
	overscroll-behavior: contain;
}
.property-gallery img {
	width: 100%;
	height: auto;
	aspect-ratio: 1.78;
}

/* Property section (unchanged) */
.property-section {
	display: grid;
	grid-template-columns: 0.5fr 0.5fr;
}
.property-section .entry-content * {
	color: var(--wp--preset--color--background-alt);
}
@media screen and (max-width: 1000px) {
	.property-section {
		grid-template-columns: 1fr;
	}
}

/* Property features (unchanged) */
.property-features {
	display: grid;
	grid-template-columns: repeat(5, 1fr auto);
	gap: 0.5rem;
}
.property-feature {
	margin: 0;
	display: grid;
	justify-items: center;
	position: relative;
}
.property-feature-divider {
	content: "";
	width: 1px;
	height: 100%;
	background-color: var(--wp--preset--color--text-alt);
	margin: 0;
}
.property-feature figure {
	height: fit-content;
}
.property-feature img {
	max-width: 40px;
	width: 100%;
}

/* Property agent (unchanged) */
.property-agent {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 1rem;
}
@media screen and (max-width: 700px) {
	.property-agent {
		grid-template-columns: 1fr;
	}
}
.property-agent-details-column {
	display: grid;
	gap: 1rem;
}
.property-agent-name {
	margin: 0;
	color: var(--wp--preset--color--background);
}
.property-agent-image {
	width: 100%;
	height: auto;
}
.property-agent-details {
	display: grid;
	gap: 1rem;
}
.property-agent-detail {
	display: grid;
	grid-template-columns: 50px 1fr;
	gap: 1rem;
	align-items: center;
	transition: opacity 0.25s ease;
}
.property-agent-detail:hover {
	opacity: 0.8;
}
.property-agent-detail * {
	color: var(--wp--preset--color--background);
	margin: 0;
}

.main-content.agent-description {
	margin-top: 0.5rem;
}
.main-content.agent-description * {
	color: var(--wp--preset--color--background-alt);
}

.cta-section {
	min-height: 400px;
}
.cta-section .right-column {
	display: grid;
	align-items: center;
}

.communities-cover {
	position: relative;
	isolation: isolate;
}

.featured-property-slider .property-card {
	--_left-column-width: 0.5;
	--_right-column-width: calc(1 - var(--_left-column-width));

	grid-template-columns: [page-start] minmax(var(--page-padding), 1fr) 
		[content-start]	min(calc(100% * var(--_left-column-width) - var(--page-padding)), calc(var(--wp--style--global--wide-size) * var(--_left-column-width))) 
		[middle] min(calc(100% * var(--_right-column-width) - var(--page-padding)), calc(var(--wp--style--global--wide-size) * var(--_right-column-width))) 
		[content-end] minmax(var(--page-padding), 1fr) 
		[page-end];
}
.featured-property-slider .property-card :is(.title, .location, .price, .details, .row) {
	grid-column: content-start;
	margin: 0;
}
.featured-property-slider .property-card .row {
	display: flex;
	gap: 0.7rem;
}

.light-text-content * {
	color: var(--wp--preset--color--background-alt);
}

.search-filter {
	display: flex;
	gap: 1rem;
	max-width: 650px;
	margin-inline: auto;
}
.search-filter * {
	font-family: var(--wp--preset--font-family--body);
}
.search-filter .suggested-search {
	border-bottom: 1px solid var(--wp--preset--color--background-alt);
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex: 1;
	position: relative;
}
.search-filter input[type="text"] {
	background: transparent;
	border: none;
	color: var(--wp--preset--color--background);
	font-size: var(--wp--preset--font-size--p-1);
	position: absolute;
	inset: 0;
	padding-left: 2rem;
}
.search-filter input[type="submit"] {
	border-radius: 3px;
	border: 1px solid var(--wp--preset--color--text-alt);
	background: var(--wp--preset--color--text);
	transition: opacity 0.25s ease;
	color: var(--wp--preset--color--background);
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--p-1);
	padding: 6px 20px;
	text-transform: uppercase;
	cursor: pointer;
}
.search-filter svg path {
	fill: var(--wp--preset--color--background);
}
.search-filter input[type="submit"]:hover {
	opacity: 0.75;
}
.search-filter .submit-wrapper svg {
	display: none;
}

.video-hero {
	height: 600px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}
.video-hero > .wp-block-group {
	width: 100%;
}
.video-hero > * {
	z-index: 2;
}
.video-hero figure {
	display: contents;
}
.video-hero video {
	position: absolute;
	inset: 0;
	z-index: -1;
}

/* ==========================================
   PROPERTY GRIDS MOBILE RESPONSIVE STYLES
   Apply same mobile behavior as person properties
   ========================================== */

/* Base property grid styles for buy/sell/rent sections */
[id*="property-section-"] > div:last-child,
.properties-by-type-grid,
.property-type-grid,
.property-posts {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
   
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

/* Property posts grid responsive */
.property-posts-inner {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 20px !important;
  
}

/* Desktop: 3 columns for property posts */
@media (min-width: 1025px) {
    .property-posts-inner > * {
        flex: 1 1 calc(33.333% - 14px) !important;
        max-width: calc(33.333% - 14px) !important;
    }
}

/* Tablet: 2 columns for property grids */
@media (max-width: 1024px) and (min-width: 769px) {
    [id*="property-section-"] > div:last-child,
    .properties-by-type-grid,
    .property-type-grid,
    .property-posts {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 18px !important;
/*        /* padding: 0 15px */
    }
    
    .property-posts-inner {
        gap: 18px !important;
    }
    
    .property-posts-inner > * {
        flex: 1 1 calc(50% - 9px) !important;
        max-width: calc(50% - 9px) !important;
    }
}

/* Mobile: Stack in single column for property grids */
@media (max-width: 768px) {
    [id*="property-section-"] > div:last-child,
    .properties-by-type-grid,
    .property-type-grid,
    .property-posts {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
/*        /* padding: 0 15px */
    }
    
    /* Property cards mobile adjustments */
    [id*="property-section-"] > div:last-child > div,
    .property-type-card,
    .property-card {
       
        
        margin: 0 !important;
        height: 280px !important;
    }
    
    /* Property section headers mobile */
    [id*="property-section-"] > div:first-child {
        flex-direction: column !important;
        text-align: center !important;
        gap: 20px !important;
/*        /* padding: 0 15px */
    }
    
    /* Property section buttons mobile */
    [id*="property-section-"] > div:first-child > div:last-child {
       
        text-align: center !important;
    }
    
    [id*="property-section-"] > div:first-child > div:last-child a {
        display: inline-block !important;
        padding: 12px 24px !important;
        font-size: 14px !important;
    }
    
    /* Property posts mobile */
    .property-posts,
    .property-posts-inner {
        gap: 15px !important;
/*        /* padding: 0 15px */
    }
    
    .property-posts-inner > * {
        flex: 1 1 100% !important;
    
    }
}

/* Extra small mobile adjustments */
@media (max-width: 480px) {
    [id*="property-section-"] > div:last-child,
    .properties-by-type-grid,
    .property-type-grid,
    .property-posts {
        gap: 12px !important;
/*         padding: 0 10px !important; */
    }
    
    /* Smaller property cards on very small screens */
    [id*="property-section-"] > div:last-child > div,
    .property-type-card,
    .property-card {
        height: 260px !important;
    }
    
    /* Adjust property section padding */
    [id*="property-section-"] {
        padding: 60px 0 !important;
    }
    
    /* Smaller headers on mobile */
    [id*="property-section-"] h1 {
        font-size: 24px !important;
        margin-bottom: 10px !important;
    }
    
    [id*="property-section-"] p {
        font-size: 14px !important;
    }
    
    /* Property posts extra small mobile */
    .property-posts,
    .property-posts-inner {
        gap: 12px !important;
/*         padding: 0 10px !important; */
    }
}

/* Property Sliders and Grids */
.tn-property-slider,
.wp-block-tn-property-slider,
.wp-block-query:not(.community-slider):not(.people-slider) {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
    gap: 20px !important;
  
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 !important;
}

.tn-property-slider .wp-block-post,
.wp-block-tn-property-slider .wp-block-post,
.wp-block-tn-featured-property-slider .wp-block-post,
.wp-block-query:not(.community-slider):not(.people-slider) .wp-block-post {
    
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

.tn-property-slider .swiper-wrapper,
.wp-block-tn-property-slider .swiper-wrapper,
.wp-block-tn-featured-property-slider .swiper-wrapper,
.wp-block-query:not(.community-slider):not(.people-slider) .swiper-wrapper {
    display: contents !important;
}

.tn-property-slider .swiper-slide,
.wp-block-tn-property-slider .swiper-slide,
.wp-block-tn-featured-property-slider .swiper-slide,
.wp-block-query:not(.community-slider):not(.people-slider) .swiper-slide {
    width: auto !important;
    margin: 0 !important;
}

/* Override Theme Constraints */
.tn-property-slider,
.wp-block-tn-property-slider,
.wp-block-tn-featured-property-slider {
    --wp--style--global--content-size: 100% !important;
    --wp--custom--spacing--page-padding: 0 !important;
}

.tn-property-slider .has-global-padding,
.wp-block-tn-property-slider .has-global-padding,
.wp-block-tn-featured-property-slider .has-global-padding {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.tn-property-slider .is-layout-constrained,
.wp-block-tn-property-slider .is-layout-constrained,
.wp-block-tn-featured-property-slider .is-layout-constrained {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
/* Community Slider Section */
.community-slider-section {
    padding: var(--wp--preset--spacing--20) 0;
    max-width: 100%;
    background: var(--wp--preset--color--background, #fff);
}

.community-slider-wrapper {
    max-width: 1200px;
    margin: 0 auto;
/*     padding: 0 20px; */
    box-sizing: border-box;
    width: 100%;
}

.community-slider {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding: 20px 0;
}

.community-slider-inner-wrapper {
    display: flex;
    align-items: stretch;
}

.community-slider .swiper-slide {
    width: 351.667px;
    margin-right: 20px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
}

/* Community Card */
.community-card {
    position: relative !important;
    isolation: isolate !important;
    min-height: 300px !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    cursor: pointer !important;
}

/* Remove gradient overlay since text is below */
.community-card::before {
    display: none !important;
}

/* Featured image container */
.community-card .wp-block-post-featured-image {
    position: relative !important;
    padding-top: 100% !important; /* Square aspect ratio */
    width: 100% !important;
    overflow: hidden !important;
    z-index: 0 !important; /* Below text and card-link */
}

/* Featured image */
.community-card .wp-block-post-featured-image img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    z-index: 0 !important;
}

/* Text container - below image with dark background */
.community-card .text {
    position: relative !important;
    background-color: #000000 !important;
    color: white !important;
    padding: 12px !important;
    text-align: center !important;
    z-index: 5 !important; /* Above card-link */
}

/* Title styling */
.community-card .wp-block-post-title {
    font-size: 1.2rem !important;
    margin: 0 0 5px !important;
    color: white !important;
    z-index: 6 !important; /* Ensure title is interactive */
}

/* Title link */
.community-card .wp-block-post-title a {
    color: white !important;
    text-decoration: none !important;
    font-size: 1.2rem !important;
    z-index: 6 !important;
}

/* Community location */
.community-card .community-location {
    font-size: 0.9rem !important;
    color: #ccc !important;
    margin: 3px 0 8px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    z-index: 6 !important;
}

/* Action link */
.community-card .action {
    margin-top: 5px !important;
    z-index: 6 !important;
}

.community-card .readmore {
    font-size: 0.875rem !important;
    color: white !important;
    text-decoration: none !important;
    border-bottom: 1px solid white !important;
    transition: color 0.3s, border-color 0.3s !important;
    position: relative !important;
    z-index: 6 !important; /* Above card-link */
}

.community-card .readmore:hover {
    color: #ccc !important;
    border-color: #ccc !important;
}

/* Full card clickable link */
.community-card .card-link {
    position: absolute !important;
    inset: 0 !important;
    z-index: 3 !important; /* Below text but above image */
    cursor: pointer !important;
}

/* Override Swiper styles for visibility */
.community-slider .swiper-slide {
    opacity: 1 !important; /* Ensure all slides are visible */
    transform: none !important; /* Remove Swiper transforms */
    display: flex !important;
    flex-direction: column !important;
    height: auto !important;
}

/* ============================================
   COMMUNITY PROPERTIES GRID IMPROVEMENTS
   ========================================== */

/* Community slider properties grid mobile */
@media (max-width: 768px) {
    /* Community slider section container */
    .community-slider-section {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        width: 100% !important;
        overflow-x: hidden !important;
    }
    
    /* Area navigation section */
    .area-navigation-section {
        margin-bottom: 30px !important;
        padding: 0 !important;
        width: 100% !important;
    }
    
    .area-navigation-section > div:first-child {
     
        margin-bottom: 20px !important;
        max-width: 100% !important;
        text-align: center !important;
    }
    
    /* Area nav slider */
    .area-nav-slider {
      
        margin: 0 auto !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }
    
    .area-nav-slider .swiper-wrapper {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 15px !important;
        width: 100% !important;
        transform: none !important;
        justify-content: center !important;
    }
    
    .area-nav-slider .swiper-slide {
        flex: 1 1 calc(50% - 7.5px) !important;
        max-width: calc(50% - 7.5px) !important;
        width: auto !important;
        margin-right: 0 !important;
        transform: none !important;
    }
    
    /* Area nav cards */
    .area-nav-card {
        height: 250px !important;
        margin: 0 !important;
        width: 100% !important;
    }
    
    .area-nav-card .area-image {
        height: 170px !important;
    }
    
    /* Properties by area slider */
    .properties-by-area-slider {
        max-width: 100% !important;
        width: 100% !important;
       
        margin: 0 auto !important;
        overflow: hidden !important;
    }
    
    .properties-by-area-slider .swiper-wrapper {
        display: block !important;
        width: 100% !important;
        transform: none !important;
    }
    
    .properties-by-area-slider .swiper-slide {
        display: block !important;
        width: 100% !important;
        margin-right: 0 !important;
        margin-bottom: 30px !important;
        transform: none !important;
    }
    
    /* Properties grid mobile layout */
    .properties-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* Property cards */
    .community-card,
    .property-card {
        flex: 1 1 100% !important;
        max-width: 100% !important;
        width: 100% !important;
        margin: 0 !important;
        height: 280px !important;
    }
    
    /* Area headers */
    .area-header {
        margin-bottom: 20px !important;
        padding: 0 !important;
        text-align: center !important;
    }
    
    .area-header h3 {
        font-size: 20px !important;
        margin: 0 0 8px 0 !important;
        padding: 0 !important;
    }
    
    .area-header p {
        font-size: 13px !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* Remove any transform or transition that could cause centering issues */
    .community-slider-section * {
        transform: none !important;
    }
    
    /* Ensure pagination is centered */
    .swiper-pagination {
        text-align: center !important;
        width: 100% !important;
        left: 0 !important;
        right: 0 !important;
        margin: 20px auto 0 auto !important;
    }
    
    /* Community page links */
    .area-slide > div:last-child {
        text-align: center !important;
        margin-top: 25px !important;
        padding: 0 !important;
    }
    
    .area-slide > div:last-child a {
        display: inline-block !important;
        font-size: 11px !important;
        padding: 8px 16px !important;
    }
}

/* Extra small mobile adjustments */
@media (max-width: 480px) {
    .area-nav-slider {
        padding: 0 10px !important;
    }
    
    .area-nav-slider .swiper-wrapper {
        gap: 10px !important;
    }
    
    .area-nav-slider .swiper-slide {
        flex: 1 1 calc(50% - 5px) !important;
        max-width: calc(50% - 5px) !important;
    }
    
/*     .properties-by-area-slider {
        padding: 0 10px !important;
    } */
    
    .properties-grid {
        gap: 15px !important;
    }
    
    .area-header h3 {
        font-size: 18px !important;
    }
    
    .area-header p {
        font-size: 12px !important;
    }
}

/* ===== DESKTOP LAYOUT (Preserve existing) ===== */
@media (min-width: 769px) {
    .community-slider-section .properties-by-area-slider {
        max-width: 1200px !important;
        margin: 0 auto !important;
        padding: 0 20px !important;
        overflow: hidden !important;
        width: 100% !important;
    }

    .community-slider-section .properties-by-area-slider .properties-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 30px !important;
        max-width: 1000px !important;
        margin: 0 auto !important;
    }
    
    .area-nav-card {
        height: 250px !important;
    }
    
    .area-nav-card .area-image {
        height: 170px !important;
    }
}

/* Responsive Design */
@media screen and (max-width: 768px) {
    .community-slider .swiper-slide {
        width: 300px;
        margin-right: 15px;
    }

    .community-card .wp-block-post-title {
        font-size: 1.5rem;
    }

    .community-card .readmore {
        font-size: 1rem;
    }

    .community-card .price {
        font-size: 1.1rem;
    }
}

@media screen and (max-width: 640px) {
    .community-slider .swiper-slide {
        width: 250px;
        margin-right: 10px;
    }

    .community-card .wp-block-post-featured-image img {
        height: 400px;
    }

    .community-card {
        min-height: 400px;
    }
}

/* ============================================
   TARGETED PROPERTY GRID STYLES - FIXED VERSION
   ============================================ */

/* Only target specific property sliders by their context or direct selectors */
.property-slider-title.buy + .wp-block-tn-property-slider,
.property-slider-title.sell + .wp-block-tn-property-slider,
.property-slider-title.rent + .wp-block-tn-property-slider,
#buy + .wp-block-tn-property-slider,
#sell + .wp-block-tn-property-slider, 
#rent + .wp-block-tn-property-slider,
.wp-block-tn-featured-property-slider:not(.community-slider):not(.people-slider),
.property-posts {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)) !important;
    gap: 20px !important;
    width: 100% !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

/* Target property grid items without affecting other sliders */
.property-posts .wp-block-post,
.property-posts-inner > .wp-block-post,
.property-slider-title.buy + .wp-block-tn-property-slider .wp-block-post,
.property-slider-title.sell + .wp-block-tn-property-slider .wp-block-post,
.property-slider-title.rent + .wp-block-tn-property-slider .wp-block-post,
.wp-block-tn-featured-property-slider:not(.community-slider):not(.people-slider) .wp-block-post {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    opacity: 1 !important;
}

/* Target property grid wrappers without affecting other slider wrappers */
.property-posts-inner,
.property-slider-title.buy + .wp-block-tn-property-slider .swiper-wrapper,
.property-slider-title.sell + .wp-block-tn-property-slider .swiper-wrapper,
.property-slider-title.rent + .wp-block-tn-property-slider .swiper-wrapper,
.wp-block-tn-featured-property-slider:not(.community-slider):not(.people-slider) .swiper-wrapper {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)) !important;
    gap: 20px !important;
    width: 100% !important;
    transform: none !important;
    transition: none !important;
}

/* ============================================
   PROPERTY GRID STYLES - FLEX LAYOUT VERSION
   ============================================ */

/* Use flex layout for property grids so they wrap properly */
.property-posts,
.property-slider-title.buy + .wp-block-tn-property-slider,
.property-slider-title.sell + .wp-block-tn-property-slider,
.property-slider-title.rent + .wp-block-tn-property-slider,
#buy + .wp-block-tn-property-slider,
#sell + .wp-block-tn-property-slider, 
#rent + .wp-block-tn-property-slider,
.property-slider-wrapper .property-slider:not(.community-slider):not(.people-slider) {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 20px !important;
    width: 100% !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

/* Property grid inner wrappers */
.property-posts-inner,
.property-slider-wrapper .swiper-wrapper,
.property-slider-title.buy + .wp-block-tn-property-slider .swiper-wrapper,
.property-slider-title.sell + .wp-block-tn-property-slider .swiper-wrapper,
.property-slider-title.rent + .wp-block-tn-property-slider .swiper-wrapper {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 20px !important;
    width: 100% !important;
    transform: none !important;
    transition: none !important;
}

/* Property grid items - set to flex basis for flexible sizing */
.property-posts .wp-block-post,
.property-slider-wrapper .wp-block-post,
.property-slider-title.buy + .wp-block-tn-property-slider .wp-block-post,
.property-slider-title.sell + .wp-block-tn-property-slider .wp-block-post,
.property-slider-title.rent + .wp-block-tn-property-slider .wp-block-post {
    flex: 1 1 300px !important; /* Flexible width with min 300px */
    max-width: calc(33.333% - 14px) !important; /* Max 3 columns with gap */
    margin: 0 !important;
    transform: none !important;
    transition: none !important;
    opacity: 1 !important;
}

/* Property card styles */
.property-card {
    position: relative !important;
    display: grid !important;
    background-size: cover !important;
    background-position: center !important;
    min-height: 220px !important;
    width: 100% !important;
}

/* Hide navigation elements on property grids */
.property-posts .swiper-button-wrapper,
.property-slider-wrapper .swiper-button-wrapper,
.property-slider-title.buy + .wp-block-tn-property-slider .swiper-button-wrapper,
.property-slider-title.sell + .wp-block-tn-property-slider .swiper-button-wrapper,
.property-slider-title.rent + .wp-block-tn-property-slider .swiper-button-wrapper {
    display: none !important;
}

/* ============================================
   COMMUNITY SLIDER - SQUARE CARDS WITH LABELS BELOW
   ============================================ */

/* Community slider wrapper */
.community-slider {
    max-width: 1200px !important;
    margin: 0 auto !important;
    overflow: hidden !important;
    padding: 0 20px !important;
}

/* Community slider inner wrapper */
.community-slider .swiper-wrapper {
    display: flex !important;
    transition-property: transform !important;
}

/* Community slider slides */
.community-slider .swiper-slide {
    flex-shrink: 0 !important;
    height: auto !important;
}

/* Card styling to ensure consistent height and layout */
.community-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
}

/* Image container with square aspect ratio */
.community-card .wp-block-post-featured-image {
    position: relative !important;
    padding-top: 100% !important; /* Square aspect ratio */
    width: 100% !important;
    overflow: hidden !important;
}

/* Image positioning within container */
.community-card .wp-block-post-featured-image img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* Text container - BELOW the image with dark background */
.community-card .text {
    position: relative !important;
    background-color: #000000 !important;
    color: white !important;
    padding: 12px !important;
    z-index: 2 !important;
}

/* Title styling */
.community-card .wp-block-post-title {
    font-size: 1.2rem !important;
    margin: 0 0 5px !important;
    color: white !important;
}

.community-card .wp-block-post-title a {
    color: white !important;
    text-decoration: none !important;
    font-size: 1.2rem !important;
}

/* Action link styling */
.community-card .action {
    margin-top: 5px !important;
}

.community-card .readmore {
    font-size: 0.875rem !important;
    color: white !important;
    text-decoration: none !important;
    border-bottom: 1px solid white !important;
}

/* Remove gradient overlay since text is now below */
.community-card::before {
    display: none !important;
}

/* Full card clickable link */
.community-card .card-link {
    position: absolute !important;
    inset: 0 !important;
    z-index: 3 !important;
}

/* Navigation arrows */
.community-slider .swiper-button-next,
.community-slider .swiper-button-prev {
    position: absolute !important;
    top: 40% !important; /* Adjust to center on image part */
    transform: translateY(-50%) !important;
    width: 40px !important;
    height: 40px !important;
    background-color: rgba(0, 0, 0, 0.5) !important;
    color: white !important;
    border-radius: 50% !important;
    z-index: 10 !important;
}

.community-slider .swiper-button-prev {
    left: 10px !important;
}

.community-slider .swiper-button-next {
    right: 10px !important;
}

/* Featured Property Slider - Full-Width Image */
.wp-block-tn-featured-property-slider {
    display: block !important; /* Remove grid layout */
    width: 100% !important;
    /* max-width: 100% !important; Full-width */
    margin: 0 auto !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.wp-block-tn-featured-property-slider.property-posts {
    grid-template-columns: none !important; /* Override property-posts grid */
}

.wp-block-tn-featured-property-slider .property-posts-inner {
    display: block !important; /* Remove grid from inner wrapper */
}

.wp-block-tn-featured-property-slider .wp-block-post {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

.wp-block-tn-featured-property-slider .property-card {
    min-height: 500px !important; /* Adjust height for visual balance */
    width: 100% !important;
    background-size: cover !important;
    background-position: center !important;
    position: relative !important;
    display: grid !important;
    grid-template-columns: 1fr !important; /* Single column */
    grid-template-rows: auto !important;
}

.wp-block-tn-featured-property-slider .property-card figure {
    position: absolute !important;
    inset: 0 !important;
    z-index: -2 !important;
    margin: 0 !important;
}

.wp-block-tn-featured-property-slider .property-card figure img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.wp-block-tn-featured-property-slider .property-card > * {
    grid-column: 1 !important;
    z-index: 1 !important;
    margin: 1rem !important; /* Consistent spacing for text */
    color: var(--wp--preset--color--background) !important;
}

.wp-block-tn-featured-property-slider .property-card::before {
    content: '';
    background: linear-gradient(0deg, black, transparent 50%) !important;
    position: absolute;
    inset: 0;
    z-index: -1 !important;
}

/* Hide Swiper navigation and pagination */
.wp-block-tn-featured-property-slider .swiper-button-wrapper,
.wp-block-tn-featured-property-slider .swiper-pagination {
    display: none !important;
}

/* Featured Property Section - Remove Extra Space */
.featured-property-slider-wrapper {
    margin: 0 !important;
    padding: 0 !important;
    background: var(--wp--preset--color--text) !important;
}

.featured-property-slider-wrapper .wp-block-group.has-global-padding {
    padding-top: 0 !important;
    padding-bottom: 0 !important; /* Remove excessive padding */
}

.featured-property-slider .wp-block-post {
    margin-bottom: 0 !important; /* Remove post margin */
}

.featured-property-slider .property-card {
    margin-bottom: 0 !important; /* Remove card margin */
    min-height: 500px !important; /* Adjust to fit content */
}

.featured-property {
    position: relative !important;
    margin-bottom: 0 !important; /* Remove section margin */
}

/* Ensure no extra space from Swiper wrapper */
.wp-block-tn-featured-property-slider .property-posts-inner {
    margin: 0 !important;
    padding: 0 !important;
}

/* ============================================
   PROPERTIES BY AREA SLIDER - HIGH SPECIFICITY FIXES
   ============================================ */

/* Force the properties grid to display properly */
.community-slider-section .properties-by-area-slider .properties-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
    max-width: 1000px !important;
    margin: 0 auto !important;
    width: 100% !important;
}

/* Fix the slider container width */
.community-slider-section .properties-by-area-slider {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    overflow: hidden !important;
    width: 100% !important;
}

/* Fix slide width and layout */
.community-slider-section .properties-by-area-slider .swiper-slide.area-slide {
    flex-shrink: 0 !important;
    height: auto !important;
    width: 100% !important;
    padding: 20px !important;
    box-sizing: border-box !important;
    max-width: none !important;
}

/* Force the swiper wrapper to be full width */
.community-slider-section .properties-by-area-slider .swiper-wrapper {
    display: flex !important;
    transition-property: transform !important;
    align-items: stretch !important;
    width: 100% !important;
}

/* Fix individual property cards */
.community-slider-section .properties-by-area-slider .property-card {
    position: relative !important;
    overflow: hidden !important;
    height: 280px !important;
    cursor: pointer !important;
    border-radius: 0px !important;
    transition: transform 0.3s ease !important;
    width: 100% !important;
    margin: 0 !important;
}

/* Property card hover effect */
.community-slider-section .properties-by-area-slider .property-card:hover {
    transform: translateY(-5px) !important;
}

/* Property card links */
.community-slider-section .properties-by-area-slider .property-card a {
    display: block !important;
    height: 100% !important;
    text-decoration: none !important;
    color: #fff !important;
}

/* Property text content */
.community-slider-section .properties-by-area-slider .text {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    padding: 20px !important;
    z-index: 2 !important;
    background: linear-gradient(transparent, rgba(0,0,0,0.9)) !important;
}

/* Title styling */
.community-slider-section .properties-by-area-slider .wp-block-post-title {
    font-size: 18px !important;
    font-weight: 500 !important;
    margin-bottom: 6px !important;
    line-height: 1.3 !important;
    color: #fff !important;
    font-family: 'Quicksand', sans-serif !important;
}

/* Location styling */
.community-slider-section .properties-by-area-slider .community-location {
    font-size: 12px !important;
    text-transform: uppercase !important;
    margin-bottom: 8px !important;
    font-weight: 400 !important;
    letter-spacing: 0.5px !important;
    color: #ccc !important;
}

/* Price styling */
.community-slider-section .properties-by-area-slider .property-price {
    font-size: 16px !important;
    font-weight: 500 !important;
    color: #fff !important;
    margin-bottom: 8px !important;
}

/* Read more link */
.community-slider-section .properties-by-area-slider .readmore {
    font-size: 12px !important;
    color: #fff !important;
    text-decoration: none !important;
    border-bottom: 1px solid #fff !important;
    padding-bottom: 1px !important;
    transition: all 0.3s !important;
}

.community-slider-section .properties-by-area-slider .readmore:hover {
    color: #ccc !important;
    border-color: #ccc !important;
}

/* Area header styling */
.community-slider-section .area-header h3 {
    color: #fff !important;
    font-size: 28px !important;
    font-weight: 500 !important;
    margin: 0 0 10px 0 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-family: 'Quicksand', sans-serif !important;
}

.community-slider-section .area-header p {
    color: #96a6b3 !important;
    font-size: 16px !important;
    margin: 0 !important;
    font-weight: 300 !important;
}

/* Navigation arrows */
.community-slider-section .properties-by-area-slider .swiper-button-next,
.community-slider-section .properties-by-area-slider .swiper-button-prev {
    color: #fff !important;
    background: rgba(0, 0, 0, 0.5) !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    margin-top: -22px !important;
}

.community-slider-section .properties-by-area-slider .swiper-button-next:after,
.community-slider-section .properties-by-area-slider .swiper-button-prev:after {
    font-size: 18px !important;
    font-weight: bold !important;
}

.community-slider-section .properties-by-area-slider .swiper-button-next:hover,
.community-slider-section .properties-by-area-slider .swiper-button-prev:hover {
    background: rgba(0, 0, 0, 0.8) !important;
}

/* Pagination dots */
.community-slider-section .properties-by-area-slider .swiper-pagination {
    position: static !important;
    margin-top: 30px !important;
    text-align: center !important;
}

.community-slider-section .properties-by-area-slider .swiper-pagination-bullet {
    background: rgba(255, 255, 255, 0.5) !important;
    opacity: 1 !important;
    width: 12px !important;
    height: 12px !important;
    margin: 0 6px !important;
    transition: all 0.3s !important;
}

.community-slider-section .properties-by-area-slider .swiper-pagination-bullet-active {
    background: #fff !important;
    transform: scale(1.2) !important;
}

/* View all button */
.community-slider-section .properties-by-area-slider .area-slide > div:last-child a {
    display: inline-block !important;
    border: 1px solid #fff !important;
    color: #fff !important;
    text-decoration: none !important;
    padding: 12px 24px !important;
    text-transform: uppercase !important;
    font-size: 12px !important;
    letter-spacing: 0.5px !important;
    font-weight: 400 !important;
    transition: all 0.3s !important;
    border-radius: 4px !important;
}

.community-slider-section .properties-by-area-slider .area-slide > div:last-child a:hover {
    background: #fff !important;
    color: #000 !important;
}

/* ============================================
   GENERAL PROPERTY CARD MOBILE IMPROVEMENTS
   ========================================== */

@media (max-width: 768px) {
    /* Ensure all property cards have consistent mobile styling */
    .property-card,
    .community-card,
    .person-property-card,
    [class*="property"] [style*="height: 280px"] {
        border-radius: 8px !important;
        overflow: hidden !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
        transition: transform 0.3s ease !important;
    }
    
    /* Property card hover effects on mobile */
    .property-card:hover,
    .community-card:hover,
    .person-property-card:hover {
        transform: translateY(-2px) !important;
    }
    
    /* Property text content mobile adjustments */
    .property-card .text,
    .community-card .text,
    .person-property-card .text {
        padding: 15px !important;
    }
    
    /* Property titles mobile */
    .property-card h3,
    .community-card h3,
    .person-property-card h3 {
        font-size: 16px !important;
        line-height: 1.4 !important;
        margin-bottom: 4px !important;
    }
    
    /* Property location text mobile */
    .property-card .location,
    .community-card .location,
    .person-property-card .location {
        font-size: 12px !important;
        margin-bottom: 6px !important;
    }
    
    /* Property price text mobile */
    .property-card .price,
    .community-card .price,
    .person-property-card .price {
        font-size: 14px !important;
        font-weight: 600 !important;
    }
}

/* ============================================
   TOUCH IMPROVEMENTS FOR MOBILE
   ========================================== */

@media (max-width: 768px) {
    /* Better touch targets */
    .property-card a,
    .community-card a,
    .person-property-card a {
        min-height: 44px !important;
        display: flex !important;
        align-items: center !important;
    }
    
    /* Remove hover effects on touch devices */
    @media (hover: none) {
        .property-card:hover,
        .community-card:hover,
        .person-property-card:hover {
            transform: none !important;
        }
    }
}

/* ============================================
   RESPONSIVE UTILITIES
   ========================================== */

/* Hide desktop-only elements on mobile */
@media (max-width: 768px) {
    .desktop-only {
        display: none !important;
    }
    
    .mobile-only {
        display: block !important;
    }
}

/* Show desktop-only elements on desktop */
@media (min-width: 769px) {
    .desktop-only {
        display: block !important;
    }
    
    .mobile-only {
        display: none !important;
    }
}

/* ============================================
   FALLBACK STYLES
   ============================================ */

/* Loading state */
.community-slider-section .properties-by-area-slider.loading {
    min-height: 400px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.community-slider-section .properties-by-area-slider.loading:before {
    content: "Loading properties..." !important;
    color: #fff !important;
    font-size: 16px !important;
}

/* Fallback when Swiper fails */
.community-slider-section .properties-by-area-slider .swiper-wrapper:not(.swiper-wrapper-initialized) {
    display: block !important;
}

.community-slider-section .properties-by-area-slider .swiper-wrapper:not(.swiper-wrapper-initialized) .swiper-slide {
    display: block !important;
    margin-bottom: 40px !important;
    width: 100% !important;
}

/* Mobile padding adjustments for media-text blocks */
@media (max-width: 781px) {
    /* Remove top padding from the section */
    .wp-block-media-text.is-stacked-on-mobile {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        margin-top: 10px !important;
        padding-top: 10px !important;
    }
    
    /* Remove top padding from parent section */
    .wp-block-group:has(.wp-block-media-text.is-stacked-on-mobile) {
        padding-top: 10px !important;
    }
    
    /* Alternative selector for parent section */
    section:has(.wp-block-media-text.is-stacked-on-mobile) {
        padding-top: 10px !important;
    }
    
    /* Adjust image to stay within container with more top padding */
    .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media {
        margin: 0 !important;
        padding: 30px 20px 20px 20px !important;
        width: 100% !important;
        position: static !important;
        left: auto !important;
        right: auto !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        order: -1;
        box-sizing: border-box !important;
    }
    
    /* Style the image to fit within the padded container */
    .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media img {
        width: 100% !important;
        height: auto !important;
        display: block !important;
        margin: 0 !important;
        border-radius: 0 !important;
        object-fit: cover !important;
    }
    
    /* Keep text content within section width */
    .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content {
        padding: 30px 20px 0 20px !important;
        margin: 0 auto !important;
        width: 100% !important;
        max-width: 1200px !important;
        box-sizing: border-box !important;
    }
    
    /* Remove any spacing issues */
    .wp-block-media-text.is-stacked-on-mobile {
        margin-bottom: 0 !important;
        grid-gap: 0 !important;
        row-gap: 0 !important;
        column-gap: 0 !important;
    }
    
    /* Fix heading margin */
    .wp-block-media-text h2 {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }
    
    /* Fix figure/image wrapper */
    .wp-block-media-text.is-stacked-on-mobile figure {
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
    }
}

/* Extra small mobile for media-text */
@media (max-width: 480px) {
    .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content {
        padding: 60px 15px 0 15px !important;
    }
    .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media {
        padding: 60px 15px 15px 15px !important;
    }
}

/* Target the specific section that contains the media-text block */
@media (max-width: 781px) {
    .wp-block-group.has-background:has(.wp-block-media-text.is-stacked-on-mobile) {
        padding-top: 10px !important;
    }
    
    section[style*="padding-top:var(--wp--preset--spacing--80)"]:has(.wp-block-media-text.is-stacked-on-mobile) {
        padding-top: 0px !important;
    }
    
    .wp-block-group[style*="padding-top:var(--wp--preset--spacing--80)"] .wp-block-media-text.is-stacked-on-mobile {
        margin-top: -20px !important;
    }
}

.has-background-background-color {
    background-color: black !important;
}

/* Ensure no overflow issues */
@media (max-width: 781px) {
    body, html {
        overflow-x: hidden !important;
    }
    
     .wp-block-group.alignwide {
        overflow: hidden !important;
    } 
}

/* ===== GENERAL FIXES ===== */

/* Remove navigation buttons completely */
.community-slider .swiper-button-prev,
.community-slider .swiper-button-next,
.properties-by-area-slider .swiper-button-prev,
.properties-by-area-slider .swiper-button-next,
.area-nav-prev,
.area-nav-next,
.main-slider-prev,
.main-slider-next {
    display: none !important;
}

/* Remove button wrapper */
.community-slider .swiper-button-wrapper,
.properties-by-area-slider .swiper-button-wrapper {
    display: none !important;
}

/* Area nav card hover effects */
.area-nav-card {
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    transition: all 0.3s ease;
}

.area-nav-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 10px 25px rgba(0,0,0,0.3) !important;
}

.area-card-link {
    position: absolute !important;
    inset: 0 !important;
    z-index: 3 !important;
    text-decoration: none !important;
}

/* Pagination styling */
.swiper-pagination-bullet {
    background: rgba(255, 255, 255, 0.5) !important;
    opacity: 1 !important;
    width: 10px !important;
    height: 10px !important;
    margin: 0 5px !important;
}

.swiper-pagination-bullet-active {
    background: #fff !important;
}

/* Ensure no horizontal scroll */
.community-slider-section,
.community-slider-section * {
    box-sizing: border-box !important;
}

/* Fix any overflow issues */
body {
    overflow-x: hidden !important;
}

.wp-block-group.alignwide {
    overflow: hidden !important;
}

/* Additional styling for social links table */
.social-links-wrapper table {
    border-collapse: separate !important;
    border-spacing: 10px !important;
    width: 100% !important;
    max-width: 700px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

.social-links-wrapper td {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    vertical-align: top !important;
}

.social-links-wrapper a {
    display: block !important;
    text-decoration: none !important;
}

.social-links-wrapper p {
    margin: 0 !important;
    padding: 0 !important;
}

/* Mobile padding adjustments for "Discover Your Homes True Value" section */
@media (max-width: 640px) {
    /* Target the section containing the "True Value" heading */
    .wp-block-group:has(h2:contains("Discover Your Homes")) {
        padding-top: var(--wp--preset--spacing--40) !important;
    }
    
    /* Alternative selector if :has() isn't supported */
    .wp-block-group.has-text-background-color.has-background.has-global-padding {
        padding-top: var(--wp--preset--spacing--40) !important;
    }
}

@media (max-width: 480px) {
    /* More aggressive reduction for smaller screens */
    .wp-block-group:has(h2:contains("Discover Your Homes")),
    .wp-block-group.has-text-background-color.has-background.has-global-padding {
        padding-top: var(--wp--preset--spacing--30) !important;
    }
}

/* Community location styling */
.community-card .community-location {
    font-size: 0.9rem;
    color: #ccc;
    margin: 3px 0 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ============================================
   COMPLETE MOBILE RESPONSIVE FIX
   Fixes properties grid, community slider, and all areas
   ========================================== */

/* Mobile: Single column with nuclear-level specificity */
@media (max-width: 768px) {
    /* Properties Grid */
    .properties-grid,
    .community-slider-section .properties-grid,
    .properties-by-area-slider .properties-grid,
    .community-slider-section .properties-grid[style],
    .properties-by-area-slider .properties-grid[style],
    div.properties-grid[style*="grid-template-columns"],
    .properties-grid[style*="repeat(3, 1fr)"],
    .properties-grid[style*="repeat(2, 1fr)"],
    
    /* Community Slider */
    .community-slider,
    .wp-block-tn-community-slider,
    .community-slider-wrapper .community-slider,
    .community-slider .swiper-wrapper,
    .community-slider-inner-wrapper,
    .community-slider-section .community-slider,
    .community-slider-section .community-slider[style],
    div.community-slider[style],
    
    /* Properties by Area Slider */
    .properties-by-area-slider,
    .community-slider-section .properties-by-area-slider,
    .community-slider-section .properties-by-area-slider[style],
    div.properties-by-area-slider[style],
    
    /* Maximum specificity selectors */
    body .properties-grid,
    body .community-slider,
    body .properties-by-area-slider,
    html body div.properties-grid,
    html body div.community-slider,
    html body div.properties-by-area-slider {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        max-width: 100% !important;
        margin: 0 !important;
        
        display: grid !important;
        width: 100% !important;
        overflow: visible !important;
        transform: none !important;
        transition: none !important;
    }
    
    /* Swiper wrapper specific fixes */
    .community-slider .swiper-wrapper,
    .community-slider-inner-wrapper {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        width: 100% !important;
        transform: none !important;
        transition: none !important;
    }
    
    /* Swiper slides mobile fixes */
    .community-slider .swiper-slide,
    .community-slider .wp-block-post {
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        display: block !important;
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        flex-shrink: initial !important;
    }
}

/* Tablet: 2 columns */
@media (max-width: 1024px) and (min-width: 769px) {
    .properties-grid,
    .community-slider,
    .wp-block-tn-community-slider,
    .community-slider-wrapper .community-slider,
    .properties-by-area-slider,
    .community-slider .swiper-wrapper,
    .community-slider-inner-wrapper,
    .community-slider-section .properties-grid[style],
    .properties-by-area-slider .properties-grid[style],
    .community-slider-section .community-slider[style],
    .community-slider-section .properties-by-area-slider[style],
    div.properties-grid[style],
    div.community-slider[style],
    div.properties-by-area-slider[style] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 18px !important;
        max-width: 100% !important;
       /* padding: 0 15px */
        display: grid !important;
        width: 100% !important;
    
    }
}

/* Small mobile adjustments */
@media (max-width: 480px) {
    .properties-grid,
    .community-slider,
    .wp-block-tn-community-slider,
    .community-slider-wrapper .community-slider,
    .properties-by-area-slider,
    .community-slider .swiper-wrapper,
    .community-slider-inner-wrapper,
    .community-slider-section .properties-grid[style],
    .community-slider-section .community-slider[style],
    .community-slider-section .properties-by-area-slider[style],
    div.properties-grid[style],
    div.community-slider[style],
    div.properties-by-area-slider[style] {
        gap: 12px !important;
        padding: 0 10px !important;
    }
    
    /* Smaller cards on very small screens */
    .properties-grid .property-card,
    .properties-grid .community-card,
    .community-slider .property-card,
    .community-slider .community-card,
    .properties-by-area-slider .property-card,
    .properties-by-area-slider .community-card {
        height: 260px !important;
    }
}

/* Property/Community cards mobile styling */
@media (max-width: 768px) {
    .properties-grid .property-card,
    .properties-grid .community-card,
    .community-slider .property-card,
    .community-slider .community-card,
    .properties-by-area-slider .property-card,
    .properties-by-area-slider .community-card {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        height: 280px !important;
        border-radius: 8px !important;
        overflow: hidden !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
        transition: transform 0.3s ease !important;
    }
}

/* Hide Swiper navigation on all devices */
.community-slider .swiper-button-prev,
.community-slider .swiper-button-next,
.community-slider .swiper-button-wrapper,
.community-slider .swiper-pagination {
    display: none !important;
}

/* Override WordPress layout constraints */
.community-slider-section,
.community-slider-wrapper {
    --wp--style--global--content-size: 100% !important;
    --wp--custom--spacing--page-padding: 0 !important;
}

.community-slider-section .has-global-padding {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.community-slider-section .is-layout-constrained {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Fallback for when Swiper fails to initialize */
.community-slider .swiper-wrapper:not(.swiper-wrapper-initialized) {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
}

.community-slider .swiper-wrapper:not(.swiper-wrapper-initialized) .swiper-slide {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
}

@media (max-width: 1024px) {
    .community-slider .swiper-wrapper:not(.swiper-wrapper-initialized) {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 18px !important;
    }
}

@media (max-width: 768px) {
    .community-slider .swiper-wrapper:not(.swiper-wrapper-initialized) {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }
}

/* Nuclear option: Target any grid with 3 columns on mobile */
@media (max-width: 768px) {
    [style*="grid-template-columns: repeat(3, 1fr)"],
    [style*="grid-template-columns:repeat(3,1fr)"] {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
       /* padding: 0 15px */
    }
}

.wp-block-video {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.wp-block-video video {
    margin: 0 !important;
    padding: 0 !important;
    display: block !important; /* Ensures video fills container */
}

.wp-site-blocks,
.entry-content,
main,
.wp-block-post-content {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Start simple - target navigation links containing "buy" or "rent" */
.wp-block-navigation a[href*="buy"],
.wp-block-navigation a[href*="rent"] {
    background-color: #EB008B !important;
    color: white !important;
    padding: 4px 8px !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    border-radius: 3px !important;
    text-decoration: none !important;
    display: inline-block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Target the navigation items themselves */
.wp-block-navigation-item a[href*="buy"],
.wp-block-navigation-item a[href*="rent"] {
    background-color: #EB008B !important;
    color: white !important;
    padding: 4px 8px !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    border-radius: 3px !important;
    text-decoration: none !important;
    display: inline-block !important;
    opacity: 1 !important;
    visibility: visible !important;
}


/* Remove any conflicting underline styles */
.wp-block-navigation-item a[href*="buy"],
.wp-block-navigation-item a[href*="rent"] {
    background-image: none !important;
    background-size: 0 !important;
    border-bottom: none !important;
}
/* Footer Logo and Social Media Spacing Fix */

/* Reduce spacing after logo and before "The Office" heading */
.wp-block-safe-svg-svg-icon + h3,
.wp-block-safe-svg-svg-icon + .wp-block-heading {
    margin-top: 15px !important; /* Reduced from 25px */
    padding-top: 5px !important;
}

/* Social media links - increase gaps between icons */
.wp-block-social-links {
    gap: 15px !important;
    margin-top: 20px !important; /* Reduced from 25px */
    margin-bottom: 15px !important;
    padding: 8px 0 !important;
}

/* Individual social media icons */
.wp-block-social-links .wp-social-link {
    margin-right: 12px !important;
    margin-left: 0 !important;
    padding: 0 !important;
}

/* Last social icon - remove right margin */
.wp-block-social-links .wp-social-link:last-child {
    margin-right: 0 !important;
}

/* Social icon hover effects with better spacing */
.wp-block-social-links .wp-social-link a {
    padding: 8px !important;
    border-radius: 4px !important;
    transition: all 0.3s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.wp-block-social-links .wp-social-link a:hover {
    transform: translateY(-2px) !important;
    background-color: rgba(255, 255, 255, 0.1) !important;
}

/* Footer section spacing improvements */
.wp-block-column#footer-contact {
    padding-left: 30px !important;
}

/* The Office heading spacing */
.wp-block-heading.uppercase {
    margin-top: 0 !important;
    margin-bottom: 12px !important;
    padding-bottom: 3px !important;
}

/* Office address lines - add some spacing */
.wp-block-column p {
    margin-bottom: 6px !important; /* Reduced from 8px */
    line-height: 1.4 !important;
}

/* Contact form spacing */
.wp-block-contact-form-7-contact-form-selector {
    margin-top: 20px !important;
    padding-top: 10px !important;
}

/* Form inputs spacing */
.wpcf7-form p {
    margin-bottom: 12px !important;
}

/* Footer bottom text spacing */
.wp-block-group[style*="margin-top:var(--wp--preset--spacing--60)"] {
    margin-top: 30px !important;
    padding-top: 15px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Mobile adjustments - CENTER EVERYTHING */
@media (max-width: 768px) {
    /* Logo spacing on mobile - even tighter */
    .wp-block-safe-svg-svg-icon.safe-svg-cover {
        margin-top: 5px !important;
        margin-bottom: 10px !important; /* Much smaller gap on mobile */
        text-align: center !important;
    }
    
    .wp-block-safe-svg-svg-icon + h3,
    .wp-block-safe-svg-svg-icon + .wp-block-heading {
        margin-top: 10px !important; /* Reduced mobile gap */
    }
    
    .wp-block-social-links {
        gap: 12px !important;
        margin-top: 15px !important;
        justify-content: center !important;
    }
    
    .wp-block-social-links .wp-social-link {
        margin-right: 8px !important;
    }
    
    .wp-block-column#footer-contact {
        padding-left: 0 !important;
        margin-top: 25px !important;
    }
    
    /* CENTER ALL CONTENT ON MOBILE */
    .wp-block-column {
        text-align: center !important;
    }
    
    .wp-block-column p,
    .wp-block-heading {
        text-align: center !important;
    }
    
    .wp-block-social-links {
        justify-content: center !important;
    }
    
    /* Center the contact form */
    .wp-block-contact-form-7-contact-form-selector {
        text-align: center !important;
    }
    
    .wpcf7-form {
        max-width: 400px !important;
        margin: 0 auto !important;
        text-align: left !important; /* Keep form fields left-aligned for usability */
    }
    
    /* Center the logo */
    .safe-svg-inside.safe-svg-inline {
        text-align: center !important;
        margin: 0 auto !important;
    }
    
    /* Center address lines */
    .wp-block-column p.has-background-color {
        text-align: center !important;
        margin: 0 auto 6px auto !important;
    }
}

/* Extra spacing for better visual hierarchy */
.wp-block-columns.alignwide {
    margin-top: 15px !important;
    margin-bottom: 15px !important;
}

/* Ensure logo doesn't get too big */
.safe-svg-inside.safe-svg-inline svg {
    max-width: 250px !important;
    height: auto !important;
}

/* Add subtle separation between sections - hide on mobile */
.wp-block-column:first-child::after {
    content: '';
    position: absolute;
    right: -15px;
    top: 20px;
    bottom: 20px;
    width: 1px;
    background: rgba(255, 255, 255, 0.1);
}

@media (max-width: 768px) {
    .wp-block-column:first-child::after {
        display: none;
    }
    
    /* Stack columns properly on mobile */
    .wp-block-columns {
        flex-direction: column !important;
    }
    
    .wp-block-column {
        width: 100% !important;
        margin-bottom: 20px !important;
    }
}


/* Mobile Property Card Layout Fix - Prevent Bunched Text */

/* Mobile-specific property card fixes */
@media (max-width: 768px) {
    
    /* STEP 1: Reset property card layout for mobile */
    .property-card,
    .property-card-alt {
        display: flex !important;
        flex-direction: column !important;
        justify-content: flex-end !important;
        grid-template-columns: none !important; /* Remove grid layout */
        column-gap: 0 !important;
        padding: 20px !important;
        min-height: 280px !important;
        height: 280px !important;
        position: relative !important;
        background-size: cover !important;
        background-position: center !important;
        text-decoration: none !important;
        color: white !important;
        border-radius: 8px !important;
        overflow: hidden !important;
    }
    
    /* STEP 2: Ensure gradient overlay for text readability */
    .property-card::before,
    .property-card-alt::before {
        content: '' !important;
        position: absolute !important;
        inset: 0 !important;
        background: linear-gradient(to bottom, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.8) 100%) !important;
        z-index: 1 !important;
    }
    
    /* STEP 3: Fix text content positioning and spacing */
    .property-card .title,
    .property-card-alt .title,
    .property-card h3 {
        position: relative !important;
        z-index: 2 !important;
        color: white !important;
        font-size: 18px !important;
        font-weight: 600 !important;
        line-height: 1.3 !important;
        margin: 0 0 10px 0 !important;
        padding: 0 !important;
        grid-column: unset !important; /* Remove grid positioning */
    }
    
    /* STEP 4: Fix row container - make it stack vertically */
    .property-card .row,
    .property-card-alt .row {
        position: relative !important;
        z-index: 2 !important;
        display: flex !important;
        flex-direction: column !important; /* Stack location and price vertically */
        gap: 5px !important;
        margin: 0 0 8px 0 !important;
        grid-column: unset !important; /* Remove grid positioning */
    }
    
    /* STEP 5: Fix location styling */
    .property-card .location,
    .property-card-alt .location {
        position: relative !important;
        z-index: 2 !important;
        color: #ccc !important;
        font-size: 13px !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* STEP 6: Fix price styling */
    .property-card .price,
    .property-card-alt .price {
        position: relative !important;
        z-index: 2 !important;
        color: white !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* STEP 7: Fix details/see details button */
    .property-card .details,
    .property-card-alt .details {
        position: relative !important;
        z-index: 2 !important;
        color: white !important;
        font-size: 12px !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        margin: 5px 0 0 0 !important;
        padding: 0 !important;
        opacity: 0.9 !important;
        grid-column: unset !important; /* Remove grid positioning */
    }
    
    /* STEP 8: Remove any conflicting styles */
    .property-card *,
    .property-card-alt * {
        grid-column: unset !important;
        grid-row: unset !important;
    }
    
    /* STEP 9: Property card container fixes */
    .property-posts .wp-block-post,
    .featured-property-slider .wp-block-post,
    .wp-block-tn-property-slider .wp-block-post {
        width: 100% !important;
        margin: 0 !important;
/*         padding: 0 10px !important; */
        box-sizing: border-box !important;
    }
    
    /* STEP 10: Featured property slider specific fixes */
    .featured-property-slider .property-card {
        grid-template-columns: none !important;
        min-height: 300px !important;
        height: 300px !important;
        padding: 25px !important;
    }
    
    .featured-property-slider .property-card .title,
    .featured-property-slider .property-card h3 {
        font-size: 20px !important;
        margin-bottom: 12px !important;
    }
    
    .featured-property-slider .property-card .price {
        font-size: 18px !important;
    }
    
}

/* Tablet specific adjustments */
@media (max-width: 1024px) and (min-width: 769px) {
    .property-card,
    .property-card-alt {
        min-height: 250px !important;
        height: 250px !important;
        padding: 18px !important;
    }
    
    .property-card .title,
    .property-card-alt .title,
    .property-card h3 {
        font-size: 17px !important;
    }
    
    .property-card .price,
    .property-card-alt .price {
        font-size: 15px !important;
    }
}

/* Extra small mobile devices */
@media (max-width: 480px) {
    .property-card,
    .property-card-alt {
        min-height: 260px !important;
        height: 260px !important;
        padding: 15px !important;
    }
    
    .property-card .title,
    .property-card-alt .title,
    .property-card h3 {
        font-size: 16px !important;
        margin-bottom: 8px !important;
    }
    
    .property-card .location,
    .property-card-alt .location {
        font-size: 12px !important;
    }
    
    .property-card .price,
    .property-card-alt .price {
        font-size: 15px !important;
    }
    
    .property-card .details,
    .property-card-alt .details {
        font-size: 11px !important;
    }
}

/* Hover effects - disable on touch devices */
@media (hover: none) {
    .property-card:hover,
    .property-card-alt:hover {
        transform: none !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
    }
}

/* Additional fix for property grid containers on mobile */
@media (max-width: 768px) {
    .property-posts,
    .property-slider-wrapper,
    [id*="property-section-"] > div:last-child {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 15px !important;
       /* padding: 0 15px */
    }
    
    /* Ensure proper spacing between property cards */
    .property-posts .wp-block-post + .wp-block-post {
        margin-top: 15px !important;
    }
	.wp-block-group.has-background-color.has-text-background-color.has-text-color.has-background.has-link-color.has-global-padding.is-layout-constrained {
    	margin-bottom: 0;
	}
	body.page-id-6 .wp-block-group.has-text-background-color.has-background.has-global-padding.is-layout-constrained.wp-block-group-is-layout-constrained {
    	padding-bottom: 0;
	}

}

.wp-block-group.has-background-color.has-text-background-color.has-text-color.has-background.has-link-color.has-global-padding.is-layout-constrained {
    margin-bottom: var(--wp--preset--spacing--80);
}

.page-id-91 .wp-block-group.has-background-color.has-text-background-color.has-text-color.has-background.has-link-color.has-global-padding.is-layout-constrained {
    margin-bottom: 0px;
}

.wp-block-group.video-hero.hero-gradient {
    padding-top: var(--wp--preset--spacing--40) !important;
    padding-bottom: var(--wp--preset--spacing--40) !important;
}


body.page-id-6 .wp-block-group.has-text-background-color.has-background.has-global-padding.is-layout-constrained.wp-block-group-is-layout-constrained {
    padding-bottom: var(--wp--preset--spacing--80);
}




/* Target the video-hero section on page-id-93 */
body.page-id-93 .wp-block-group.video-hero.hero-gradient {
    /* Current: --wp--preset--spacing--60 
       50% reduction: --wp--preset--spacing--30 */
    padding-top: var(--wp--preset--spacing--30) !important;
}
@media (max-width: 768px) {
    .video-hero {
        height: auto !important;
    }
}




/* Hide specific image on mobile devices */
@media (max-width: 768px) {
    /* Option 1: Target by specific image ID */
    .wp-image-444 {
        display: none !important;
    }
    
    /* Option 2: Target the entire figure container */
    figure.wp-block-media-text__media img.wp-image-444 {
        display: none !important;
    }
    
    /* Option 3: Hide the entire media text block image section */
    .wp-block-media-text__media {
        display: none !important;
    }
}

/* Alternative: Hide on smaller screens (phones only) */
@media (max-width: 480px) {
    .wp-image-444 {
        display: none !important;
    }
}

/* Alternative: Hide on tablets and phones */
@media (max-width: 992px) {
    .wp-image-444 {
        display: none !important;
    }
}

/* Remove max-width constraint on mobile and small tablets */
@media (max-width: 1024px) {
    .team-slider-section,
    .wp-block-group.has-text-background-color.has-background.has-global-padding {
        max-width: none !important;
        width: 100% !important;
    }
    
    .team-slider-section .people-slider-wrapper,
    .wp-block-group.alignwide {
        /* max-width: none !important; */
        width: 100% !important;
    }
}

/* Progressive padding for different screen sizes */
@media (min-width: 480px) {
    .team-slider-section,
    .wp-block-group.has-text-background-color.has-background.has-global-padding {
        /* padding-left: 24px !important;
        padding-right: 24px !important; */
		max-width: none !important;
    }
}

@media (min-width: 768px) {
    .team-slider-section,
    .wp-block-group.has-text-background-color.has-background.has-global-padding {
        padding-left: 40px !important;
        padding-right: 40px !important;
		max-width: none !important;
    }
}

/* Simple mobile height increase */
@media (max-width: 768px) {
    .video-hero.hero-gradient {
        min-height: 70vh !important;
    }
    
    .video-hero .wp-block-video video {
        height: 70vh !important;
        object-fit: cover !important;
    }
}

/* ====================
   PROPERTY CARD TEXT WRAPPING FIX
   Prevents title text from cutting off on mobile
   ==================== */

/* Mobile text wrapping fix */
@media (max-width: 768px) {
    .featured-property-slider .property-card .title {
        /* Allow text wrapping */
        white-space: normal !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        
        /* Typography adjustments */
        font-size: 16px !important;
        line-height: 1.4 !important;
        
        /* Spacing */
        margin-bottom: 12px !important;
        padding-right: 10px !important;
        
        /* Ensure visibility */
        color: white !important;
        text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.8) !important;
        
        /* Height and overflow */
        height: auto !important;
        max-height: none !important;
        overflow: visible !important;
        
        /* Display properties */
        display: block !important;
        width: 100% !important;
    }
    
    /* Adjust card layout to accommodate wrapped text */
    .featured-property-slider .property-card {
        /* Increase card height for wrapped text */
        height: 320px !important;
        
        /* Flex layout for better text positioning */
        display: flex !important;
        flex-direction: column !important;
        justify-content: flex-end !important;
        
        /* Padding adjustments */
        padding: 20px 16px 20px 20px !important;
        
        /* Text area spacing */
        gap: 8px !important;
    }
    
    /* Row content adjustments */
    .featured-property-slider .property-card .row {
        margin-bottom: 12px !important;
        margin-top: 8px !important;
    }
    
    /* Location and price text */
    .featured-property-slider .property-card .location,
    .featured-property-slider .property-card .price {
        font-size: 14px !important;
        line-height: 1.3 !important;
        white-space: nowrap !important; /* Keep these on single lines */
    }
    
    /* Details text */
    .featured-property-slider .property-card .details {
        font-size: 12px !important;
        margin-top: 8px !important;
    }
}

/* Small mobile phones - even more adjustments */
@media (max-width: 480px) {
    .featured-property-slider .property-card .title {
        font-size: 15px !important;
        line-height: 1.3 !important;
        margin-bottom: 10px !important;
    }
    
    .featured-property-slider .property-card {
        height: 300px !important;
        padding: 16px 12px 16px 16px !important;
    }
    
    .featured-property-slider .property-card .location,
    .featured-property-slider .property-card .price {
        font-size: 13px !important;
    }
}

/* Larger mobile/small tablet */
@media (min-width: 481px) and (max-width: 768px) {
    .featured-property-slider .property-card .title {
        font-size: 17px !important;
        line-height: 1.4 !important;
    }
    
    .featured-property-slider .property-card {
        height: 340px !important;
    }
}

/* Tablet and desktop - ensure proper wrapping */
@media (min-width: 769px) {
    .featured-property-slider .property-card .title {
        white-space: normal !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        line-height: 1.4 !important;
        font-size: 18px !important;
        height: auto !important;
        max-height: none !important;
    }
    
    .featured-property-slider .property-card {
        height: 350px !important;
        padding: 24px !important;
    }
}

/* Universal text fixes for all screen sizes */
.featured-property-slider .property-card .title {
    /* Prevent text selection issues */
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    user-select: none !important;
    
    /* Smooth text rendering */
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    
    /* Ensure text doesn't get cut by container */
    box-sizing: border-box !important;
    
    /* Handle long words gracefully */
    hyphens: auto !important;
    -webkit-hyphens: auto !important;
    -moz-hyphens: auto !important;
}

/* Fix for pipe separator spacing */
.featured-property-slider .property-card .title {
    /* Better handling of pipe separators */
    word-spacing: 0.1em !important;
}

/* Ensure card content doesn't overflow */
.featured-property-slider .property-card {
    overflow: hidden !important;
    position: relative !important;
}

/* Background gradient for better text readability */
.featured-property-slider .property-card::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 60% !important;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.8) 0%,
        rgba(0, 0, 0, 0.4) 50%,
        transparent 100%
    ) !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

/* Ensure text is above gradient */
.featured-property-slider .property-card .title,
.featured-property-slider .property-card .row,
.featured-property-slider .property-card .details {
    position: relative !important;
    z-index: 2 !important;
}


/* Screen reader only text */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}



/* Video element styling for better mobile experience */
.wp-block-video video {
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  display: block !important;
}

/* Ensure video doesn't get clipped on mobile */
@media (max-width: 768px) {
  .wp-block-video {
    width: 100% !important;
    overflow: hidden !important;
  }
  
  .wp-block-video video {
    min-height: 250px !important; /* Minimum height on mobile */
    max-height: 70vh !important; /* Don't take up entire screen */
  }
}

/* If video is in a container, ensure proper spacing */
.wp-block-group .wp-block-video:first-child,
.wp-block-cover .wp-block-video:first-child {
  margin-top: 0 !important; /* Reset if inside other blocks */
}




/* SWIPER PAGINATION CENTERING FIX */

/* Force pagination to center properly */
.people-pagination {
    margin-top: 30px !important;
    position: relative !important;
    bottom: auto !important;
      
    /* CENTER THE PAGINATION */
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
}

/* Override dynamic bullets constraints */
.people-pagination.swiper-pagination-bullets-dynamic {
    width: 100% !important;
    left: 0 !important;
    transform: none !important;
}

/* Center individual bullets */
.people-pagination .swiper-pagination-bullet {
    position: relative !important;
    left: auto !important;
    transform: none !important;
    margin: 0 5px !important;
    width: 12px !important;
    height: 12px !important;
    background: rgba(255, 255, 255, 0.4) !important;
    opacity: 1 !important;
    border-radius: 50% !important;
    transition: all 0.3s ease !important;
	
}

.people-pagination .swiper-pagination-bullet-active {
    background: #fff !important;
    transform: scale(1.2) !important;
}

/* Mobile specific centering */
@media (max-width: 768px) {
    .people-pagination {
        padding: 0 20px !important;
        margin-top: 25px !important;
    }
    
    .people-pagination .swiper-pagination-bullet {
        width: 10px !important;
        height: 10px !important;
        margin: 0 4px !important;
    }
}

/* Desktop specific centering */
@media (min-width: 769px) {
    .people-pagination {
        margin-top: 35px !important;
    }
    
    .people-pagination .swiper-pagination-bullet {
        width: 14px !important;
        height: 14px !important;
        margin: 0 6px !important;
    }
}
.wp-block-navigation__container .wp-block-navigation-item__content {
    color: #ffffff !important;
}

/* ===================================
   PEOPLE SLIDER PAGINATION FIXES
   =================================== */

/* Add more bottom padding to slider container */
.people-slider-wrapper {
    padding-bottom: 60px !important; /* More space for pagination */
}

/* Slider container - add bottom padding */
.people-slider.swiper {
    padding-bottom: 50px !important; /* Space for pagination */
    margin-bottom: 20px !important;
}

/* Pagination styling and positioning */
.people-slider .swiper-pagination,
.people-slider .people-pagination {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    width: auto !important;
    max-width: none !important;
    
    /* Spacing and positioning */
    margin-top: 30px !important;
    margin-bottom: 20px !important;
    padding: 10px 20px !important;
    
    /* Center the pagination */
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    
    /* Make sure it's visible */
    opacity: 1 !important;
    visibility: visible !important;
    z-index: 10 !important;
    
    /* Add background for better visibility */
    background: transparent !important;
}

/* Individual pagination bullets */
.people-slider .swiper-pagination-bullet {
    width: 12px !important;
    height: 12px !important;
    background: rgba(255, 255, 255, 0.4) !important;
    opacity: 1 !important;
    border-radius: 50% !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    margin: 0 4px !important;
    flex-shrink: 0 !important;
}

.people-slider .swiper-pagination-bullet-active {
    background: #fff !important;
    transform: scale(1.3) !important;
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.5) !important;
}

/* Dynamic bullets (if using) */
.people-slider .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transform: scale(0.8) !important;
}

.people-slider .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
    transform: scale(1.3) !important;
}

/* ===================================
   MOBILE PAGINATION FIXES
   =================================== */

@media (max-width: 768px) {
    /* More padding on mobile */
    .people-slider-wrapper {
        padding-bottom: 80px !important;
    }
    
    .people-slider.swiper {
        padding-bottom: 60px !important;
        margin-bottom: 30px !important;
    }
    
    /* Mobile pagination adjustments */
    .people-slider .swiper-pagination,
    .people-slider .people-pagination {
        margin-top: 40px !important;
        margin-bottom: 30px !important;
        padding: 15px 20px !important;
    }
    
    /* Slightly larger bullets on mobile for easier tapping */
    .people-slider .swiper-pagination-bullet {
        width: 14px !important;
        height: 14px !important;
        margin: 0 6px !important;
    }
    
    .people-slider .swiper-pagination-bullet-active {
        transform: scale(1.4) !important;
    }
}

/* ===================================
   EXTRA SMALL MOBILE
   =================================== */

@media (max-width: 480px) {
    .people-slider-wrapper {
        padding-bottom: 70px !important;
    }
    
    .people-slider.swiper {
        padding-bottom: 50px !important;
    }
    
    .people-slider .swiper-pagination,
    .people-slider .people-pagination {
        margin-top: 35px !important;
        padding: 12px 15px !important;
    }
}

/* ===================================
   FORCE OVERRIDES FOR STUBBORN CASES
   =================================== */

/* Override any inline styles that might be limiting width */
.people-slider .swiper-pagination[style*="width"] {
    width: auto !important;
    max-width: none !important;
}

/* Ensure pagination container has enough space */
.people-slider .swiper-pagination-bullets-dynamic {
    width: auto !important;
    max-width: 300px !important;
    margin: 0 auto !important;
}



/* ===================================
   SPECIFIC FIX FOR YOUR SLIDER ID
   =================================== */

/* Target your specific slider ID if needed */
#people-slider-6867e6db4b4e5 {
    padding-bottom: 60px !important;
    
}

#people-slider-6867e6db4b4e5 .swiper-pagination {
    position: relative !important;
    margin-top: 40px !important;
    padding: 15px !important;
    width: auto !important;
    max-width: none !important;
}

/* Remove bottom padding from team slider section only */
.team-slider-section {
    padding-bottom: 0 !important;
}

/* Alternative: More specific selector if the above doesn't work */
.wp-block-group.team-slider-section {
    padding-bottom: 0 !important;
}

/* Or target by inline styles if needed */
section.team-slider-section[style*="padding-bottom"] {
    padding-bottom: 0 !important;
}


/* ===================================
   CENTER PROPERTIES IN AREA CARDS
   =================================== */

/* Center the properties grid within each area slide */
.community-slider-section .properties-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
    max-width: 1000px !important;
    margin: 0 auto !important; /* Center the entire grid */
    justify-content: center !important;
    align-items: start !important;
    padding: 0 20px !important;
}

/* Center individual property cards within grid cells */
.community-slider-section .community-card,
.community-slider-section .property-card {
    margin: 0 auto !important; /* Center each card within its grid cell */
    max-width: 100% !important;
    width: 100% !important;
}

/* Center area headers */
.community-slider-section .area-header {
    text-align: center !important;
    margin: 0 auto 30px auto !important;
    max-width: 800px !important;
    padding: 0 20px !important;
}

/* Center area slide content */
.community-slider-section .area-slide {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    width: 100% !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
}

/* Center community page links */
.community-slider-section .area-slide > div:last-child {
    text-align: center !important;
    margin: 30px auto 0 auto !important;
    max-width: 300px !important;
}

/* ===================================
   RESPONSIVE CENTERING
   =================================== */

/* Tablet: 2 columns, centered */
@media (max-width: 1024px) {
    .community-slider-section .properties-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        max-width: 700px !important;
        gap: 18px !important;
    }
}

/* Mobile: 1 column, centered */
@media (max-width: 768px) {
    .community-slider-section .properties-grid {
        grid-template-columns: 1fr !important;
        max-width: 400px !important;
        gap: 15px !important;
        margin: 0 auto !important;
    }
    
    .community-slider-section .area-slide {
        padding: 0 15px !important;
    }
    
    .community-slider-section .area-header {
        padding: 0 15px !important;
        margin-bottom: 20px !important;
    }
}

/* Extra small mobile */
@media (max-width: 480px) {
    .community-slider-section .properties-grid {
        max-width: 350px !important;
        gap: 12px !important;
    }
    
    .community-slider-section .area-slide {
        padding: 0 10px !important;
    }
}

/* ===================================
   ALTERNATIVE: FLEXBOX CENTERING
   =================================== */

/* If you prefer flexbox instead of grid centering */
/*
.community-slider-section .properties-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: flex-start !important;
    gap: 20px !important;
    max-width: 1000px !important;
    margin: 0 auto !important;
}

.community-slider-section .community-card,
.community-slider-section .property-card {
    flex: 0 0 calc(33.333% - 14px) !important;
    max-width: calc(33.333% - 14px) !important;
}

@media (max-width: 1024px) {
    .community-slider-section .community-card,
    .community-slider-section .property-card {
        flex: 0 0 calc(50% - 10px) !important;
        max-width: calc(50% - 10px) !important;
    }
}

@media (max-width: 768px) {
    .community-slider-section .community-card,
    .community-slider-section .property-card {
        flex: 0 0 100% !important;
        max-width: 350px !important;
    }
}
*/

/* ===================================
   CENTER AREA NAVIGATION CARDS TOO
   =================================== */

/* Center the area navigation slider */
.area-navigation-section {
    text-align: center !important;
}

.area-nav-slider {
    max-width: 1200px !important;
    margin: 0 auto !important;
}

.area-nav-slider .swiper-wrapper {
    justify-content: center !important;
}

/* Center area nav cards */
.area-nav-card {
    margin: 0 auto !important;
    max-width: 280px !important;
}

/* ===================================
   FORCE OVERRIDES
   =================================== */

/* Override any existing alignment styles */
.community-slider-section * {
    box-sizing: border-box !important;
}

/* Ensure main slider container is centered */
.properties-by-area-slider {
    max-width: 100% !important;
    margin: 0 auto !important;
    text-align: center !important;
}

/* Center pagination if it exists */
.community-slider-section .swiper-pagination {
    text-align: center !important;
    display: flex !important;
    justify-content: center !important;
    margin: 20px auto 0 auto !important;
}

/* NAVIGATION HOVER UNDERLINES - White lines on hover */


/* DESKTOP ONLY - Hide underlines on mobile */
@media (max-width: 768px) {
    header.wp-block-template-part .wp-block-navigation .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content::before,
    header.wp-block-template-part .wp-block-navigation .wp-block-navigation__container .wp-block-navigation-item a::before {
        display: none !important;
    }
    
    header.wp-block-template-part .wp-block-navigation .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content,
    header.wp-block-template-part .wp-block-navigation .wp-block-navigation__container .wp-block-navigation-item a {
        background-image: none !important;
        background-size: 0 !important;
    }
}

/* Add spacing between separate gallery blocks */
.wp-block-gallery + .wp-block-gallery {
    margin-top: 1rem !important;
}

/* Alternative: Add margin to all gallery blocks */
.wp-block-gallery {
    margin-bottom: 1rem !important;
}

/* For property pages specifically */
.single-property .wp-block-gallery:not(:last-child) {
    margin-bottom: 1rem !important;
}


/* Fix pagination height to prevent cutoff on mobile zoom */
.people-slider .swiper-pagination,
.people-slider .people-pagination {
    height: auto !important;
    min-height: 40px !important;
    padding: 15px 20px !important;
    margin-top: 30px !important;
    margin-bottom: 30px !important;
    box-sizing: border-box !important;
  
    line-height: 1 !important;
}

/* Ensure bullets have proper vertical spacing */
.people-slider .swiper-pagination-bullet {
    vertical-align: middle !important;
    margin: 8px 4px !important;
    display: inline-block !important;
}

/* Mobile-specific height adjustments */
@media (max-width: 768px) {
    .people-slider .swiper-pagination {
        min-height: 50px !important;
        padding: 20px 15px !important;
        margin-top: 35px !important;
        margin-bottom: 35px !important;
    }
    
    .people-slider .swiper-pagination-bullet {
        margin: 10px 5px !important;
    }
}

/* Extra height for zoom scenarios */
@media (max-width: 480px) {
    .people-slider .swiper-pagination {
        min-height: 60px !important;
        padding: 25px 10px !important;
    }
}



/* Ensure Swiper wrapper doesn't clip pagination */
.people-slider .swiper {
    padding-bottom: 80px !important;
    
}

/* Fix for dynamic bullets height issues */
.people-slider .swiper-pagination-bullets-dynamic {
    height: auto !important;
    min-height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ===================================
   MOBILE NAVIGATION FIXES
   =================================== */

@media (max-width: 768px) {
    
    /* ===================================
       FIX 1: REMOVE NAVIGATION OVERLAY FROM IMAGES
       =================================== */
    
    /* Prevent mobile navigation items from overlaying content */
    .wp-block-navigation-item__content,
    .wp-block-navigation-item a {
        position: static !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        width: auto !important;
        height: auto !important;
        z-index: auto !important;
        transform: none !important;
    }
    
    /* Ensure navigation only appears in the mobile menu */
    header.wp-block-template-part .wp-block-navigation__container {
        display: none !important;
    }
    
    /* Only show navigation inside the responsive container */
    header.wp-block-template-part .wp-block-navigation__responsive-container .wp-block-navigation__container {
        display: flex !important;
        flex-direction: column !important;
    }
    
    /* Prevent any navigation elements from floating over content */
    .wp-block-navigation-item {
        position: static !important;
        float: none !important;
        clear: both !important;
    }
    
    /* ===================================
       FIX 2: SOLID BLACK MOBILE MENU BACKGROUND ON SCROLL
       =================================== */
 
    /* ===================================
       FIX 3: ENSURE PROPERTY IMAGES ARE CLICKABLE
       =================================== */
    
    /* Force property images to be on top and clickable */
    .property-section,
    .wp-block-image,
    .image-link,
    figure {
        position: relative !important;
        z-index: 10 !important;
        pointer-events: auto !important;
    }
    
    /* Lightbox modal should be highest */
    .image-modal {
        z-index: 99999 !important;
    }
    
    /* ===================================
       FIX 4: PREVENT STICKY CONTACT ELEMENTS FROM OVERLAYING
       =================================== */
    
    /* Remove any fixed/absolute positioning from contact elements */
    .property-agent-manual,
    .contact-options,
    .agent-contact {
        position: static !important;
        z-index: 5 !important;
    }
    
    /* WhatsApp and phone buttons should not overlay content */
    a[href*="whatsapp"],
    a[href*="tel:"],
    a[href*="mailto:"] {
        position: static !important;
        z-index: 5 !important;
    }
    
 
  
 
}

/* ===================================
   FORCE MOBILE GALLERY IMAGES TO BE CLICKABLE
   =================================== */

@media (max-width: 768px) {
    /* Ensure gallery images are always clickable */
    .wp-block-image img,
    .image-link img,
    figure img {
        pointer-events: auto !important;
        cursor: pointer !important;
        position: relative !important;
        z-index: 15 !important;
    }
    
    /* But keep property feature icons non-clickable */
    .property-feature img,
    .property-features img,
    .agent-photo img {
        pointer-events: none !important;
        cursor: default !important;
        z-index: 5 !important;
    }
}


/* ===================================
   MOBILE NAVIGATION FIXES - HIGHEST Z-INDEX + SCROLL CLASS
   =================================== */

@media (max-width: 768px) {
    
    /* ===================================
       FIX 1: HIGHEST Z-INDEX FOR NAVIGATION BAR
       =================================== */
    
    /* Header gets highest z-index - above everything */
    header.wp-block-template-part {
        z-index: 99999 !important;
        position: fixed !important;
        transition: all 0.3s ease !important;
    }
    
    /* Mobile menu button - very high z-index */
    header.wp-block-template-part .wp-block-navigation__responsive-container-open {
        z-index: 100000 !important;
        position: relative !important;
    }
    
    /* Mobile menu overlay - highest z-index */
    header.wp-block-template-part .wp-block-navigation__responsive-container {
        z-index: 100001 !important;
        background: rgba(0, 0, 0, 0.98) !important;
        backdrop-filter: blur(10px) !important;
    }
    
    /* Mobile menu close button - highest z-index */
    header.wp-block-template-part .wp-block-navigation__responsive-container-close {
        z-index: 100002 !important;
    }
    
    /* ===================================
       FIX 2: SCROLL CLASS INSTEAD OF SCROLLED
       =================================== */
    

    /* SCROLL state on mobile - fully black */
    header.wp-block-template-part.scroll {
        background-color: rgba(0, 0, 0, 1) !important;
        backdrop-filter: blur(10px) !important;
    }
    
    /* When header is in scroll state, make mobile menu even more solid */
    header.wp-block-template-part.scroll .wp-block-navigation__responsive-container {
        background: rgba(0, 0, 0, 1) !important;
        backdrop-filter: blur(15px) !important;
        z-index: 100001 !important;
    }
	
	
	
	
/* ===================================
   HEADER - ABSOLUTE HIGHEST Z-INDEX
   =================================== */

/* Header must be above EVERYTHING */
header.wp-block-template-part {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    z-index: 999999 !important; /* ABSOLUTE HIGHEST */
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-sizing: border-box !important;
}

/* ===================================
   SCROLL BEHAVIOR: TRANSPARENT ↔ BLACK
   =================================== */



/* SCROLL STATE: BLACK (when scrolled down) */
header.wp-block-template-part.scroll {
    background-color: rgba(0, 0, 0, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1) !important;
}

/* ===================================
   NAVIGATION TEXT SHADOW MANAGEMENT
   =================================== */

/* Navigation text with shadow for visibility on transparent background */
header.wp-block-template-part .wp-block-navigation-item__content,
header.wp-block-template-part .wp-block-navigation-item a {
    color: #ffffff !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Remove text shadow when header is black (scroll state) */
header.wp-block-template-part.scroll .wp-block-navigation-item__content,
header.wp-block-template-part.scroll .wp-block-navigation-item a {
    text-shadow: none !important;
}

/* ===================================
   MOBILE NAVIGATION - HIGHEST Z-INDEX
   =================================== */

@media (max-width: 768px) {
    
 
    
    header.wp-block-template-part.scroll {
        background-color: rgba(0, 0, 0, 1) !important; /* Fully black when scrolled */
    }
    
    /* Mobile menu button - extremely high z-index */
    header.wp-block-template-part .wp-block-navigation__responsive-container-open {
        z-index: 1000000 !important;
        position: relative !important;
        display: flex !important;
        background: transparent !important;
        border: 1px solid rgba(255, 255, 255, 0.3) !important;
        color: #ffffff !important;
    }
    
    /* Mobile menu overlay - ABSOLUTE HIGHEST Z-INDEX */
    header.wp-block-template-part .wp-block-navigation__responsive-container {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        z-index: 1000001 !important; /* HIGHEST POSSIBLE */
        background: rgba(0, 0, 0, 0.98) !important;
        backdrop-filter: blur(10px) !important;
        opacity: 0 !important;
        visibility: hidden !important;
        transition: opacity 0.3s ease, visibility 0.3s ease !important;
    }
    
    /* Mobile menu when open */
    header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open {
        opacity: 1 !important;
        visibility: visible !important;
    }
    
    /* Mobile menu close button - ABSOLUTE HIGHEST */
    header.wp-block-template-part .wp-block-navigation__responsive-container-close {
        z-index: 1000002 !important; /* HIGHEST OF ALL */
        position: absolute !important;
        top: 15px !important;
        right: 15px !important;
        background: transparent !important;
        border: 1px solid rgba(255, 255, 255, 0.3) !important;
        color: #ffffff !important;
    }
    
    /* Mobile menu content container */
    header.wp-block-template-part .wp-block-navigation__responsive-container .wp-block-navigation__container {
        display: flex !important;
        flex-direction: column !important;
        z-index: 1000001 !important;
        background: transparent !important;
        padding: 80px 20px 40px 20px !important;
    }
    
    /* Mobile menu navigation items */
    header.wp-block-template-part .wp-block-navigation__responsive-container .wp-block-navigation-item__content,
    header.wp-block-template-part .wp-block-navigation__responsive-container .wp-block-navigation-item a {
        color: #ffffff !important;
        background: transparent !important;
        text-align: left !important;
        width: 100% !important;
        padding: 20px 0 !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
        
        /* Remove any positioning that could cause issues */
        position: static !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
        z-index: auto !important;
        text-shadow: none !important; /* No shadow needed in solid black menu */
    }
    
    /* Hide desktop navigation on mobile */
    header.wp-block-template-part .wp-block-navigation__container {
        display: none !important;
    }
}

/* ===================================
   DESKTOP NAVIGATION - HIGHEST Z-INDEX
   =================================== */

@media (min-width: 769px) {
    
    /* Desktop navigation container */
    header.wp-block-template-part .wp-block-navigation {
        z-index: 999999 !important;
        display: flex !important;
        opacity: 1 !important;
        visibility: visible !important;
        margin-left: auto !important;
    }
    
    header.wp-block-template-part .wp-block-navigation__container {
        z-index: 999999 !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 2rem !important;
    }
    
    /* Hide mobile menu button on desktop */
    header.wp-block-template-part .wp-block-navigation__responsive-container-open {
        display: none !important;
    }
}

/* ===================================
   CONTENT BELOW NAVBAR
   =================================== */

/* Everything else should be below the navbar */
main,
.property-section,
.wp-block-image,
.image-link,
figure {
    position: relative !important;
    z-index: 10 !important;
}

/* Lightbox modal should be very high but below navbar */
.image-modal {
    z-index: 999998 !important;
}
	
	/* Team slider section should be below navbar */
.team-slider-section,
.people-slider-wrapper,
.people-slider,
.swiper {
    z-index: 1 !important;
    position: relative !important;
}

/* Ensure people slider doesn't create stacking context above navbar */
.people-slider-section,
.team-slider-section {
    z-index: 1 !important;
    position: relative !important;
    isolation: auto !important; /* Prevent new stacking context */
}

/* Swiper elements should be low z-index */
.swiper-wrapper,
.swiper-slide,
.person-card {
    z-index: auto !important;
    position: relative !important;
}

/* Navigation and pagination elements */
.swiper-button-prev,
.swiper-button-next,
.swiper-pagination {
    z-index: 2 !important;
}

/* ===================================
   FIX PEOPLE SLIDER NAVBAR CONFLICT
   =================================== */

/* ===================================
   FORCE NAVBAR ABOVE PEOPLE SLIDER SECTION
   =================================== */

/* Team slider section should be below navbar */
.team-slider-section,
.people-slider-wrapper,
.people-slider,
.swiper {
    z-index: 1 !important;
    position: relative !important;
}

/* Ensure people slider doesn't create stacking context above navbar */
.people-slider-section,
.team-slider-section {
    z-index: 1 !important;
    position: relative !important;
    isolation: auto !important; /* Prevent new stacking context */
}

/* Swiper elements should be low z-index */
.swiper-wrapper,
.swiper-slide,
.person-card {
    z-index: auto !important;
    position: relative !important;
}

/* Navigation and pagination elements */
.swiper-button-prev,
.swiper-button-next,
.swiper-pagination {
    z-index: 2 !important;
}

/* ===================================
   REINFORCE NAVBAR HIGHEST Z-INDEX
   =================================== */

/* Force navbar to be absolutely highest - even over sliders */
header.wp-block-template-part {
    z-index: 999999 !important;
    position: fixed !important;
    isolation: isolate !important; /* Create own stacking context */
}

/* All navbar elements get high z-index */
header.wp-block-template-part * {
    z-index: inherit !important;
}

/* Mobile menu elements - absolute highest */
@media (max-width: 768px) {
    header.wp-block-template-part .wp-block-navigation__responsive-container-open {
        z-index: 1000000 !important;
    }
    
    header.wp-block-template-part .wp-block-navigation__responsive-container {
        z-index: 1000001 !important;
    }
    
    header.wp-block-template-part .wp-block-navigation__responsive-container-close {
        z-index: 1000002 !important;
    }
}
/* ===================================
   FIX PEOPLE SLIDER NAVBAR CONFLICT
   =================================== */

/* ===================================
   FORCE NAVBAR ABOVE PEOPLE SLIDER SECTION
   =================================== */

/* Team slider section should be below navbar */
.team-slider-section,
.people-slider-wrapper,
.people-slider,
.swiper {
    z-index: 1 !important;
    position: relative !important;
}

/* Ensure people slider doesn't create stacking context above navbar */
.people-slider-section,
.team-slider-section {
    z-index: 1 !important;
    position: relative !important;
    isolation: auto !important; /* Prevent new stacking context */
}

/* Swiper elements should be low z-index */
.swiper-wrapper,
.swiper-slide,
.person-card {
    z-index: auto !important;
    position: relative !important;
}

/* Navigation and pagination elements */
.swiper-button-prev,
.swiper-button-next,
.swiper-pagination {
    z-index: 2 !important;
}

/* ===================================
   REINFORCE NAVBAR HIGHEST Z-INDEX
   =================================== */

/* Force navbar to be absolutely highest - even over sliders */
header.wp-block-template-part {
    z-index: 999999 !important;
    position: fixed !important;
    isolation: isolate !important; /* Create own stacking context */
}

/* All navbar elements get high z-index */
header.wp-block-template-part * {
    z-index: inherit !important;
}

/* Mobile menu elements - absolute highest */
@media (max-width: 768px) {
    header.wp-block-template-part .wp-block-navigation__responsive-container-open {
        z-index: 1000000 !important;
    }
    
    header.wp-block-template-part .wp-block-navigation__responsive-container {
        z-index: 1000001 !important;
    }
    
    header.wp-block-template-part .wp-block-navigation__responsive-container-close {
        z-index: 1000002 !important;
    }
}

/* ===================================
   PREVENT SECTIONS FROM INTERFERING WITH SCROLL DETECTION
   =================================== */

/* Ensure scroll detection works over all sections */
.team-slider-section,
.people-slider-wrapper,
.swiper,
.wp-block-group {
    pointer-events: auto !important;
    /* But don't let them interfere with scroll events on header */
}

/* ===================================
   FORCE SCROLL BEHAVIOR OVER SLIDER SECTION
   =================================== */


/* ===================================
   FIX SPECIFIC WORDPRESS BLOCK ISSUES
   =================================== */

/* WordPress blocks that might interfere */
.wp-block-group,
.has-background,
.has-text-background-color {
    z-index: auto !important;
    position: relative !important;
}

/* Constrained layout shouldn't interfere */
.is-layout-constrained,
.wp-block-group-is-layout-constrained {
    z-index: auto !important;
    position: relative !important;
}

/* Global padding elements */
.has-global-padding {
    z-index: auto !important;
    position: relative !important;
}

/* ===================================
   DEBUGGING: FORCE VISIBILITY 
   =================================== */

/* Ensure navbar is always visible and on top */
header.wp-block-template-part {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

/* Force navbar above any transform contexts */
header.wp-block-template-part {
    transform: translateZ(0) !important; /* Force own layer */
    will-change: background-color !important;
}


	
	
	@media (max-width: 768px) {
    /* Hide close button when menu is open */
    header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
        display: none !important;
    }
    
    /* Ensure burger menu remains visible and functional */
    header.wp-block-template-part .wp-block-navigation__responsive-container-open {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 40px !important;
        height: 40px !important;
        background: transparent !important;
        border: 1px solid rgba(255, 255, 255, 0.3) !important;
        border-radius: 6px !important;
        color: #ffffff !important;
        cursor: pointer !important;
        margin-left: auto !important;
        opacity: 1 !important;
        visibility: visible !important;
        transition: all 0.3s ease !important;
        flex-shrink: 0 !important;
        z-index: 1000001 !important; /* Ensure it stays above the menu */
    }
    
    /* Adjust menu container to not overlap burger menu */
    header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open {
        opacity: 1 !important;
        visibility: visible !important;
        padding-top: 80px !important; /* Adjust padding to account for burger menu position */
    }
}
	
	
	
/* ===== PEOPLE SLIDER DESKTOP CENTERING FIX ===== */

@media (min-width: 769px) {
    /* Reset and center the main wrapper */
    .people-slider-wrapper {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 auto !important;
        padding: 60px 0 !important;
        background: #000000 !important;
        text-align: center !important;
    }
    
    /* Center the header */
    .people-slider-header {
        text-align: center !important;
        margin: 0 auto 40px auto !important;
        max-width: 800px !important;
        padding: 0 40px !important;
    }
    
    /* Fix the main slider container */
    .people-slider {
        max-width: 1400px !important;
        width: 100% !important;
        margin: 0 auto !important;
        position: relative !important;
        overflow: hidden !important;
        padding: 0 40px !important;
    }
    
    /* Reset swiper wrapper positioning */
    .people-slider .swiper-wrapper {
        display: flex !important;
        align-items: stretch !important;
        width: auto !important;
        transform: none !important;
        transition: transform 0.3s ease !important;
        justify-content: center !important;
        margin: 0 auto !important;
    }
    
    /* Fix slide sizing and spacing */
    .people-slider .swiper-slide {
        width: 280px !important;
        max-width: 280px !important;
        min-width: 280px !important;
        margin-right: 20px !important;
        margin-left: 0 !important;
        display: flex !important;
        justify-content: center !important;
        flex-shrink: 0 !important;
        transform: none !important;
    }
    
    /* Remove margin from last slide */
    .people-slider .swiper-slide:last-child {
        margin-right: 0 !important;
    }
    
    /* Fix first slide - remove any left offset */
    .people-slider .swiper-slide:first-child {
        margin-left: 0 !important;
    }
    
    /* Center person cards within slides */
    .people-slider .person-card {
        width: 100% !important;
        max-width: 280px !important;
        margin: 0 auto !important;
        display: flex !important;
        flex-direction: column !important;
        background: transparent !important;
        border-radius: 8px !important;
        overflow: hidden !important;
        box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
        transition: transform 0.3s ease !important;
    }
    
    /* Keep 2:3 aspect ratio */
    .people-slider .person-image-container {
        position: relative !important;
        width: 100% !important;
        height: 0 !important;
        padding-top: 150% !important; /* 2:3 aspect ratio */
        overflow: hidden !important;
        background: #1a1a1a !important;
    }
    
    /* Image positioning */
    .people-slider .person-image {
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        object-position: center top !important;
    }
    
    /* Text area */
    .people-slider .person-details {
        display: flex !important;
        flex-direction: column !important;
        justify-content: space-between !important;
        flex: 1 !important;
        padding: 18px !important;
        background-color: #000000 !important;
        color: #fff !important;
        min-height: 100px !important;
    }
    
    /* Typography */
    .people-slider .person-name {
        font-size: 17px !important;
        font-weight: 600 !important;
        margin: 0 0 8px 0 !important;
        line-height: 1.3 !important;
        color: #fff !important;
    }
    
    .people-slider .person-title {
        font-size: 14px !important;
        margin: 0 0 15px 0 !important;
        color: #ccc !important;
        font-weight: 400 !important;
    }
    
    .people-slider .person-link {
        font-size: 12px !important;
        color: #fff !important;
        text-decoration: none !important;
        border: 1px solid #fff !important;
        padding: 6px 12px !important;
        border-radius: 4px !important;
        display: inline-block !important;
        transition: all 0.3s ease !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
    }
    
    .people-slider .person-link:hover {
        background-color: #fff !important;
        color: #111 !important;
    }
    
    /* Center pagination */
    .people-pagination {
        margin: 40px auto 0 auto !important;
        position: relative !important;
        bottom: auto !important;
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        width: 100% !important;
        text-align: center !important;
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
    }
    
    .people-pagination .swiper-pagination-bullet {
        width: 12px !important;
        height: 12px !important;
        background: rgba(255, 255, 255, 0.4) !important;
        opacity: 1 !important;
        border-radius: 50% !important;
        transition: all 0.3s ease !important;
        margin: 0 6px !important;
        position: relative !important;
        left: auto !important;
        transform: none !important;
    }
    
    .people-pagination .swiper-pagination-bullet-active {
        background: #fff !important;
        transform: scale(1.3) !important;
    }
}

/* Force override any Swiper positioning */
@media (min-width: 769px) {
    .people-slider .swiper-wrapper[style] {
        justify-content: center !important;
        margin: 0 auto !important;
    }
    
    /* Reset any transform positioning */
    .people-slider .swiper-wrapper[style*="transform"] {
        transform: translateX(0px) !important;
    }
    
    /* Ensure wrapper starts centered */
    .people-slider .swiper-wrapper {
        left: 0 !important;
        right: 0 !important;
    }
}

/* Large desktop */
@media (min-width: 1200px) {
    .people-slider .swiper-slide {
        width: 300px !important;
        max-width: 300px !important;
        min-width: 300px !important;
        margin-right: 25px !important;
    }
    
    .people-slider .person-card {
        max-width: 300px !important;
    }
    
    .people-slider .person-details {
        padding: 20px !important;
        min-height: 110px !important;
    }
    
    .people-slider .person-name {
        font-size: 18px !important;
    }
    
    .people-slider .person-title {
        font-size: 15px !important;
    }
}

/* Hide navigation arrows */
.people-slider .swiper-button-prev,
.people-slider .swiper-button-next,
.people-nav-prev,
.people-nav-next {
    display: none !important;
}

/* Force wrapper to not interfere */
.team-slider-section {
    padding: 0 !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
}
	

