/* =========================================================
   DKD Properties — Base Theme Styles
   ========================================================= */

:root {
	--dkdp-accent: #e2364a;
	--dkdp-dark: #1a1a2e;
	--dkdp-text: #2b2b2b;
	--dkdp-muted: #6b7280;
	--dkdp-border: #e7e7ea;
	--dkdp-bg-soft: #f7f7f9;
	--dkdp-radius: 10px;
	--dkdp-shadow: 0 2px 14px rgba(0,0,0,0.06);
	--dkdp-success: #1f9d55;
	--dkdp-warning: #e1a100;
	--dkdp-danger: #c0392b;
}

* { box-sizing: border-box; }

html {
	overflow-x: hidden; /* fallback for older browsers that don't support clip */
	overflow-x: clip; /* preferred: prevents horizontal scroll without breaking position:sticky descendants */
}

body {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--dkdp-text);
	line-height: 1.5;
	background: #fff;
	overflow-x: hidden;
	overflow-x: clip;
	max-width: 100vw;
}

img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; }

.dkdp-container {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 40px;
}

@media (max-width: 768px) {
	.dkdp-container { padding: 0 20px; }
}

/* ---------------- Buttons ---------------- */
.dkdp-btn {
	display: inline-block;
	padding: 11px 22px;
	border-radius: 6px;
	font-weight: 600;
	font-size: 14px;
	border: 1px solid transparent;
	cursor: pointer;
	transition: all .15s ease;
	text-align: center;
}
.dkdp-btn-primary {
	background: var(--dkdp-accent);
	color: #fff;
}
.dkdp-btn-primary:hover { opacity: .9; }
.dkdp-btn-outline {
	background: #fff;
	border: 1px solid var(--dkdp-border);
	color: var(--dkdp-text);
}
.dkdp-btn-outline:hover { border-color: var(--dkdp-accent); color: var(--dkdp-accent); }
.dkdp-btn-outline-light {
	background: rgba(255,255,255,0.15);
	border: 1px solid rgba(255,255,255,0.6);
	color: #fff;
}
.dkdp-btn-whatsapp {
	background: #25D366;
	color: #fff;
}
.dkdp-btn-whatsapp:hover { opacity: .9; }

/* ---------------- Header ---------------- */
.dkdp-site-header {
	border-bottom: 1px solid var(--dkdp-border);
	background: #fff;
	position: sticky;
	top: 0;
	z-index: 100;
}
.dkdp-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 1400px;
	margin: 0 auto;
	padding: 14px 40px;
	gap: 24px;
}
@media (max-width: 768px) {
	.dkdp-header-inner { padding: 14px 20px; }
}
.dkdp-logo img { max-height: 48px; width: auto; }
.dkdp-logo-text { font-size: 22px; font-weight: 800; color: var(--dkdp-dark); }
.dkdp-menu {
	display: flex;
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.dkdp-menu a { font-weight: 600; font-size: 15px; }
.dkdp-menu a:hover { color: var(--dkdp-accent); }
.dkdp-header-actions { display: flex; align-items: center; gap: 16px; }
.dkdp-header-phone { font-weight: 700; color: var(--dkdp-accent); font-size: 15px; white-space: nowrap; }
@media (max-width: 480px) {
	.dkdp-header-phone { display: none; } /* avoid crowding the hamburger button on very narrow screens */
}
.dkdp-mobile-toggle {
	display: none;
	background: none;
	border: 0;
	cursor: pointer;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 38px;
	height: 38px;
	padding: 0;
}
.dkdp-mobile-toggle span {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--dkdp-dark);
	border-radius: 2px;
	transition: transform .2s ease, opacity .2s ease;
}
.dkdp-mobile-toggle[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.dkdp-mobile-toggle[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
}
.dkdp-mobile-toggle[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 860px) {
	.dkdp-primary-nav {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: #fff;
		border-bottom: 1px solid var(--dkdp-border);
		box-shadow: 0 8px 20px rgba(0,0,0,0.08);
		z-index: 99;
	}
	.dkdp-primary-nav.is-open { display: block; }
	.dkdp-menu {
		flex-direction: column;
		gap: 0;
		padding: 8px 0;
	}
	.dkdp-menu li { width: 100%; }
	.dkdp-menu a {
		display: block;
		padding: 12px 24px;
	}
	.dkdp-menu a:hover { background: var(--dkdp-bg-soft); }
	.dkdp-mobile-toggle { display: flex; }
	.dkdp-site-header { position: relative; }
}

/* ---------------- Archive / Grid ---------------- */
.dkdp-archive-main { padding: 32px 0 60px; }
.dkdp-archive-header { margin-bottom: 10px; }
.dkdp-archive-title { font-size: 28px; margin: 0 0 4px; }
.dkdp-archive-count { color: var(--dkdp-muted); margin: 0 0 20px; font-size: 14px; }

.dkdp-filter-bar {
	display: flex;
	gap: 14px;
	margin-bottom: 28px;
	flex-wrap: wrap;
	padding: 20px;
	background: var(--dkdp-bg-soft);
	border-radius: 14px;
	border: 1px solid var(--dkdp-border);
}
.dkdp-filter-group {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	flex: 1 1 130px;
	min-width: 0;
	padding: 14px 10px;
	background: #fff;
	border-radius: 10px;
	border: 1px solid var(--dkdp-border);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.dkdp-filter-group:hover {
	border-color: var(--dkdp-accent);
	box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}
.dkdp-filter-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--dkdp-bg-soft);
	color: var(--dkdp-accent);
}
.dkdp-filter-label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--dkdp-muted);
}
.dkdp-filter-group select {
	width: 100%;
	border: none;
	background: transparent;
	font-size: 14px;
	font-weight: 600;
	text-align: center;
	color: var(--dkdp-dark);
	cursor: pointer;
	padding: 2px 4px;
}
.dkdp-filter-group select:focus { outline: none; }
.dkdp-filter-clear {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 0 14px;
	color: var(--dkdp-accent);
	font-size: 13px;
	font-weight: 700;
	white-space: nowrap;
}

@media (max-width: 700px) {
	.dkdp-filter-bar { gap: 10px; padding: 14px; }
	.dkdp-filter-group { flex: 1 1 calc(50% - 10px); }
}

.dkdp-grid {
	display: grid;
	grid-template-columns: repeat(var(--dkdp-cols, 4), 1fr);
	gap: 16px;
	padding: 0 24px;
}
/* The /properties/ archive page already wraps the grid in .dkdp-container
   (which has its own side padding) — cancel the grid's own padding there
   so the two don't stack, while standalone placements (e.g. the homepage
   [dkdp_properties_grid] shortcode, with no .dkdp-container wrapper)
   still get the padding directly above. Higher specificity (2 classes)
   means this correctly wins over the plain .dkdp-grid rules below,
   including inside the 480px media query. */
.dkdp-container .dkdp-grid {
	padding: 0;
}
@media (max-width: 1100px) { .dkdp-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 780px) { .dkdp-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .dkdp-grid { grid-template-columns: 1fr; padding: 0 16px; } }

.dkdp-card {
	border: 1px solid var(--dkdp-border);
	border-radius: 8px;
	overflow: hidden;
	background: #fff;
	box-shadow: var(--dkdp-shadow);
	transition: transform .15s ease, box-shadow .15s ease;
	font-size: 13px;
}
.dkdp-card:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,0.1); }
.dkdp-card-image-link { display: block; aspect-ratio: 16/10; overflow: hidden; }
.dkdp-card-image { width: 100%; height: 100%; object-fit: cover; }
.dkdp-card-image-placeholder { width: 100%; height: 100%; background: var(--dkdp-bg-soft); }
.dkdp-card-body { padding: 11px 12px; }
.dkdp-card-title { font-size: 14px; margin: 0 0 3px; line-height: 1.3; }
.dkdp-card-title a:hover { color: var(--dkdp-accent); }
.dkdp-card-price { font-weight: 700; font-size: 13px; margin: 0 0 3px; }
.dkdp-card-inc { font-weight: 400; color: var(--dkdp-muted); font-size: 10px; }
.dkdp-card-builder { margin: 0 0 3px; font-size: 11px; }
.dkdp-card-builder a { color: var(--dkdp-accent); font-weight: 600; }
.dkdp-card-area { color: var(--dkdp-muted); font-size: 11px; margin: 0 0 6px; }
.dkdp-card-meta {
	display: flex;
	justify-content: space-between;
	font-size: 10px;
	color: var(--dkdp-muted);
	border-top: 1px dashed var(--dkdp-border);
	padding-top: 6px;
	margin-bottom: 8px;
}
.dkdp-card-actions { display: flex; gap: 6px; }
.dkdp-card-actions .dkdp-btn { flex: 1; padding: 6px 8px; font-size: 11px; }

.dkdp-pagination { margin-top: 36px; text-align: center; }
.dkdp-pagination .page-numbers {
	display: inline-block;
	padding: 8px 14px;
	margin: 0 3px;
	border: 1px solid var(--dkdp-border);
	border-radius: 6px;
}
.dkdp-pagination .page-numbers.current { background: var(--dkdp-accent); color: #fff; border-color: var(--dkdp-accent); }

/* ---------------- Single Property ---------------- */
.dkdp-property-hero { position: relative; color: #fff; }
.dkdp-hero-image {
	width: 100%;
	height: 420px;
	object-fit: cover;
	filter: brightness(0.55);
}
.dkdp-hero-overlay {
	position: absolute;
	bottom: 28px;
	left: 0; right: 0;
}
.dkdp-property-title { font-size: 34px; margin: 0 0 8px; }
.dkdp-property-price { font-size: 20px; font-weight: 700; margin: 0 0 10px; }
.dkdp-property-price span { font-weight: 400; opacity: .85; font-size: 13px; }
.dkdp-property-meta-row { display: flex; gap: 18px; flex-wrap: wrap; margin-bottom: 18px; font-size: 14px; opacity: .9; }
.dkdp-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

@media (max-width: 600px) {
	.dkdp-hero-image { height: 320px; }
	.dkdp-property-title { font-size: 24px; }
	.dkdp-property-price { font-size: 17px; }
	.dkdp-property-meta-row { gap: 10px 14px; font-size: 13px; }
	.dkdp-hero-actions { gap: 8px; }
	.dkdp-hero-actions .dkdp-btn { padding: 9px 14px; font-size: 13px; }
}

.dkdp-property-body {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 40px;
	padding: 40px 20px 80px;
	align-items: start;
}
@media (max-width: 900px) { .dkdp-property-body { grid-template-columns: 1fr; } }
@media (max-width: 600px) { .dkdp-property-body { padding: 28px 16px 50px; gap: 28px; } }

.dkdp-property-main section { margin-bottom: 36px; }
.dkdp-property-main h2 { font-size: 22px; margin-bottom: 14px; }

.dkdp-units-table { width: 100%; border-collapse: collapse; }
.dkdp-units-table th, .dkdp-units-table td {
	padding: 12px 14px;
	border-bottom: 1px solid var(--dkdp-border);
	text-align: left;
	font-size: 14px;
}
.dkdp-units-table th { background: var(--dkdp-bg-soft); font-weight: 700; }
.dkdp-status-tag {
	display: inline-block;
	margin-left: 8px;
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 700;
	background: var(--dkdp-warning);
	color: #fff;
}
.dkdp-status-sold_out .dkdp-status-tag { background: var(--dkdp-danger); }
.dkdp-status-sold_out td { color: var(--dkdp-muted); }

.dkdp-property-address { color: var(--dkdp-muted); margin-bottom: 12px; }
.dkdp-map-embed iframe { border-radius: 8px; }
.dkdp-rera { font-size: 13px; color: var(--dkdp-muted); }

/* ---------------- Enquiry Form ---------------- */
.dkdp-property-sidebar { position: sticky; top: 100px; }
.dkdp-enquiry-form-wrap {
	background: var(--dkdp-bg-soft);
	border: 1px solid var(--dkdp-border);
	border-radius: var(--dkdp-radius);
	padding: 24px;
}
.dkdp-enquiry-title { font-size: 18px; margin: 0 0 4px; }
.dkdp-enquiry-subtitle { font-size: 13px; color: var(--dkdp-muted); margin: 0 0 18px; }
.dkdp-form-row { margin-bottom: 14px; }
.dkdp-form-row label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; }
.dkdp-form-row .req { color: var(--dkdp-danger); }
.dkdp-form-row input,
.dkdp-form-row textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--dkdp-border);
	border-radius: 6px;
	font-size: 14px;
	font-family: inherit;
}
.dkdp-form-row input:focus,
.dkdp-form-row textarea:focus {
	outline: none;
	border-color: var(--dkdp-accent);
}
.dkdp-hp-field { position: absolute; left: -9999px; top: -9999px; }
.dkdp-enquiry-submit { width: 100%; }
.dkdp-enquiry-response { margin-top: 12px; font-size: 14px; }
.dkdp-enquiry-response.is-success { color: var(--dkdp-success); }
.dkdp-enquiry-response.is-error { color: var(--dkdp-danger); }
.dkdp-enquiry-submit[disabled] { opacity: .6; cursor: not-allowed; }

/* ---------------- Dynamic Theme Options Sections ---------------- */
.dkdp-stats-strip {
	display: flex;
	justify-content: center;
	gap: 60px;
	flex-wrap: wrap;
	text-align: center;
	padding: 36px 20px;
	background: var(--dkdp-bg-soft);
}
.dkdp-stat-number { font-size: 28px; font-weight: 800; color: var(--dkdp-accent); }
.dkdp-stat-label { color: var(--dkdp-muted); font-size: 14px; }

.dkdp-team-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
	max-width: 1000px;
	margin: 0 auto;
}
.dkdp-team-member {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.dkdp-team-member img {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	object-fit: cover;
	margin: 0 0 12px;
}
.dkdp-team-name { font-weight: 700; line-height: 1.3; }
.dkdp-team-role { color: var(--dkdp-muted); font-size: 13px; margin-top: 2px; }

.dkdp-partners-strip {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 40px;
	flex-wrap: wrap;
	padding: 20px;
}
.dkdp-partner-logo { height: 48px; width: auto; opacity: .8; filter: grayscale(100%); }

@media (max-width: 860px) {
	.dkdp-team-grid { grid-template-columns: repeat(2, 1fr); gap: 28px 20px; }
}
@media (max-width: 600px) {
	.dkdp-stats-strip { gap: 28px 36px; padding: 28px 16px; }
	.dkdp-team-grid { gap: 24px 16px; }
	.dkdp-team-member img { width: 84px; height: 84px; }
	.dkdp-partners-strip { gap: 24px; }
}

/* ---------------- Share Button ---------------- */
.dkdp-share-wrap { position: relative; display: inline-block; }
.dkdp-share-btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
}
.dkdp-card-actions .dkdp-share-btn { flex: 0 0 auto; padding: 6px 9px; }
.dkdp-hero-actions .dkdp-share-wrap .dkdp-share-btn {
	background: rgba(255,255,255,0.15);
	border: 1px solid rgba(255,255,255,0.6);
	color: #fff;
}
.dkdp-share-popover {
	position: absolute;
	bottom: calc(100% + 8px);
	right: 0;
	left: auto;
	background: #fff;
	border: 1px solid var(--dkdp-border);
	border-radius: 8px;
	box-shadow: 0 6px 20px rgba(0,0,0,0.15);
	padding: 8px;
	min-width: 150px;
	max-width: calc(100vw - 32px);
	z-index: 50;
}
.dkdp-share-popover a {
	display: block;
	padding: 7px 10px;
	font-size: 13px;
	color: var(--dkdp-text);
	border-radius: 5px;
	white-space: nowrap;
}
.dkdp-share-popover a:hover { background: var(--dkdp-bg-soft); }
.dkdp-share-popover a.is-copied { color: var(--dkdp-success); font-weight: 600; }

/* ---------------- Nearby Places ---------------- */
.dkdp-nearby-places-section {
	padding: 48px 0 24px;
	border-top: 1px solid var(--dkdp-border);
	margin-top: 24px;
}
.dkdp-nearby-heading { font-size: 26px; font-weight: 800; margin: 0 0 6px; }
.dkdp-nearby-subtitle { color: var(--dkdp-muted); font-size: 14px; margin: 0 0 24px; }
.dkdp-nearby-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}
@media (max-width: 700px) { .dkdp-nearby-list { grid-template-columns: 1fr; } }
.dkdp-nearby-item {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 20px 22px;
	border: 1px solid var(--dkdp-border);
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 2px 10px rgba(0,0,0,0.05);
	transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.dkdp-nearby-item:hover {
	box-shadow: 0 8px 22px rgba(0,0,0,0.1);
	transform: translateY(-2px);
	border-color: var(--dkdp-accent);
}
.dkdp-nearby-icon {
	flex: 0 0 auto;
	width: 52px;
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--dkdp-bg-soft);
	color: var(--dkdp-accent);
}
.dkdp-nearby-icon svg { width: 24px; height: 24px; }
.dkdp-nearby-info { flex: 1 1 auto; display: flex; flex-direction: column; min-width: 0; gap: 2px; }
.dkdp-nearby-name { font-weight: 700; font-size: 16px; }
.dkdp-nearby-category { color: var(--dkdp-muted); font-size: 13px; }
.dkdp-nearby-distance {
	flex: 0 0 auto;
	font-weight: 800;
	font-size: 17px;
	color: var(--dkdp-accent);
	white-space: nowrap;
}

/* ---------------- Property Gallery Grid + Lightbox ---------------- */
.dkdp-gallery-heading { font-size: 26px; font-weight: 800; margin-bottom: 18px; }
.dkdp-gallery-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-template-rows: repeat(2, 220px);
	gap: 14px;
}
.dkdp-gallery-grid .dkdp-gallery-tile:nth-child(1) {
	grid-column: span 2;
	grid-row: span 2;
}
.dkdp-gallery-tile {
	position: relative;
	border: none;
	padding: 0;
	margin: 0;
	border-radius: 14px;
	overflow: hidden;
	cursor: pointer;
	background: var(--dkdp-bg-soft);
	box-shadow: 0 3px 12px rgba(0,0,0,0.08);
	transition: box-shadow .2s ease, transform .2s ease;
}
.dkdp-gallery-tile:hover {
	box-shadow: 0 10px 28px rgba(0,0,0,0.18);
	transform: translateY(-3px);
}
.dkdp-gallery-tile img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .35s ease;
}
.dkdp-gallery-tile:hover img { transform: scale(1.07); }
.dkdp-gallery-more-overlay {
	position: absolute;
	inset: 0;
	background: rgba(15,15,20,0.62);
	color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
	backdrop-filter: blur(1px);
}
.dkdp-gallery-more-count { font-size: 28px; font-weight: 800; }
.dkdp-gallery-more-overlay svg { opacity: .9; }

@media (max-width: 900px) {
	.dkdp-gallery-grid { grid-template-rows: repeat(2, 170px); }
}
@media (max-width: 700px) {
	.dkdp-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: repeat(3, 160px);
		gap: 10px;
	}
	.dkdp-gallery-grid .dkdp-gallery-tile:nth-child(1) {
		grid-column: span 2;
		grid-row: span 1;
		height: 220px;
	}
}

.dkdp-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.92);
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
}
.dkdp-lightbox[hidden] { display: none; }
.dkdp-lightbox-stage {
	max-width: 90vw;
	max-height: 85vh;
	display: flex;
	align-items: center;
	justify-content: center;
}
.dkdp-lightbox-image {
	max-width: 90vw;
	max-height: 85vh;
	object-fit: contain;
	border-radius: 4px;
}
.dkdp-lightbox-close,
.dkdp-lightbox-prev,
.dkdp-lightbox-next {
	position: absolute;
	background: rgba(255,255,255,0.12);
	border: none;
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: background .15s ease;
}
.dkdp-lightbox-close:hover,
.dkdp-lightbox-prev:hover,
.dkdp-lightbox-next:hover { background: rgba(255,255,255,0.25); }
.dkdp-lightbox-close {
	top: 20px; right: 20px;
	width: 42px; height: 42px;
	font-size: 26px;
	line-height: 1;
}
.dkdp-lightbox-prev,
.dkdp-lightbox-next {
	top: 50%;
	transform: translateY(-50%);
	width: 50px; height: 50px;
	font-size: 30px;
	line-height: 1;
}
.dkdp-lightbox-prev { left: 16px; }
.dkdp-lightbox-next { right: 16px; }
.dkdp-lightbox-counter {
	position: absolute;
	bottom: 20px;
	left: 0; right: 0;
	text-align: center;
	color: #fff;
	font-size: 14px;
	opacity: .85;
}

@media (max-width: 600px) {
	.dkdp-lightbox-prev, .dkdp-lightbox-next { width: 40px; height: 40px; font-size: 24px; }
	.dkdp-lightbox-close { width: 36px; height: 36px; font-size: 22px; }
}

/* ---------------- Possession Stages (scrolling marquee) ---------------- */
.dkdp-possession-section {
	max-width: 1240px;
	margin: 0 auto;
	padding: 40px 20px;
}
.dkdp-possession-eyebrow {
	display: flex;
	align-items: center;
	gap: 6px;
	color: #1f9d55;
	font-weight: 700;
	font-size: 13px;
	letter-spacing: 0.5px;
	margin-bottom: 10px;
}
.dkdp-possession-title {
	font-size: 28px;
	font-weight: 800;
	margin: 0 0 6px;
}
.dkdp-possession-subtitle {
	color: var(--dkdp-muted);
	margin: 0 0 24px;
}

@media (max-width: 480px) {
	.dkdp-possession-title { font-size: 22px; }
	.dkdp-possession-section { padding: 30px 16px; }
}

.dkdp-possession-scroll-wrap {
	overflow: hidden;
	position: relative;
	-webkit-mask-image: linear-gradient(to right, transparent, #000 5%, #000 95%, transparent);
	mask-image: linear-gradient(to right, transparent, #000 5%, #000 95%, transparent);
}
.dkdp-possession-track {
	display: flex;
	gap: 18px;
	width: max-content;
	animation: dkdp-marquee-scroll 18s linear infinite;
}
.dkdp-possession-scroll-wrap:hover .dkdp-possession-track {
	animation-play-state: running; /* continuous per requirement — never pauses */
}
@keyframes dkdp-marquee-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); } /* exactly half, since card set is duplicated once */
}

.dkdp-possession-card {
	position: relative;
	flex: 0 0 260px;
	height: 170px;
	border-radius: 10px;
	background-color: #2a2a2a;
	background-size: cover;
	background-position: center;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 14px 16px;
	color: #fff;
	text-decoration: none;
}
.dkdp-possession-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.15) 55%, rgba(0,0,0,0.35) 100%);
}
.dkdp-possession-tag {
	position: absolute;
	top: 12px;
	left: 12px;
	background: #1f9d55;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 3px 10px;
	border-radius: 4px;
	z-index: 1;
}
.dkdp-possession-count {
	position: relative;
	z-index: 1;
	font-size: 26px;
	font-weight: 800;
	line-height: 1.2;
}
.dkdp-possession-meta {
	position: relative;
	z-index: 1;
	font-size: 13px;
	opacity: .9;
}

@media (max-width: 640px) {
	.dkdp-possession-card { flex: 0 0 200px; height: 150px; }
	.dkdp-possession-count { font-size: 22px; }
}

/* ---------------- Floating WhatsApp Button ---------------- */
.dkdp-floating-whatsapp {
	position: fixed;
	bottom: 22px;
	right: 22px;
	width: 56px;
	height: 56px;
	background: #25D366;
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 14px rgba(0,0,0,0.25);
	z-index: 999;
	transition: transform .15s ease;
}
.dkdp-floating-whatsapp:hover { transform: scale(1.08); }
@media (max-width: 480px) {
	.dkdp-floating-whatsapp { width: 48px; height: 48px; bottom: 16px; right: 16px; }
}

/* ---------------- Banner Slider ---------------- */
.dkdp-banner-slider {
	position: relative;
	overflow: hidden;
	min-height: 480px;
}
.dkdp-banner-track {
	position: relative;
	min-height: 480px;
}
.dkdp-banner-slide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity .6s ease;
	min-height: 480px;
}
.dkdp-banner-slide.is-active {
	opacity: 1;
	visibility: visible;
	position: relative;
}
.dkdp-banner-overlay {
	position: absolute;
	inset: 0;
	background: rgba(20,20,30,0.45);
}
.dkdp-banner-content {
	position: relative;
	text-align: center;
	color: #fff;
	max-width: 800px;
	padding: 0 20px;
	z-index: 1;
}
.dkdp-banner-content h1 { font-size: 40px; margin-bottom: 14px; }
.dkdp-banner-content p { font-size: 17px; opacity: .92; margin-bottom: 22px; }
.dkdp-banner-dots {
	position: absolute;
	bottom: 18px;
	left: 0; right: 0;
	display: flex;
	justify-content: center;
	gap: 8px;
	z-index: 2;
}
.dkdp-banner-dot {
	width: 9px; height: 9px;
	border-radius: 50%;
	border: 1px solid #fff;
	background: rgba(255,255,255,0.3);
	cursor: pointer;
	padding: 0;
}
.dkdp-banner-dot.is-active { background: #fff; }

@media (max-width: 640px) {
	.dkdp-banner-slider, .dkdp-banner-track, .dkdp-banner-slide { min-height: 360px; }
	.dkdp-banner-content h1 { font-size: 28px; }
	.dkdp-banner-content p { font-size: 14px; }
}

/* ---------------- Footer ---------------- */
.dkdp-site-footer {
	background: #f0f0f3;
	color: #4a4a55;
	padding: 40px 0 24px;
	margin-top: 40px;
	border-top: 1px solid var(--dkdp-border);
}
.dkdp-footer-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 20px;
	margin-bottom: 24px;
	padding-bottom: 24px;
	border-bottom: 1px solid rgba(0,0,0,0.08);
}
.dkdp-footer-logo {
	text-align: left;
	flex: 0 0 auto;
}
.dkdp-footer-logo img {
	max-height: 72px;
	width: auto;
	margin: 0;
	display: inline-block;
}
.dkdp-footer-logo-text {
	font-size: 26px;
	font-weight: 800;
	color: var(--dkdp-dark);
}
.dkdp-footer-nav { flex: 1 1 auto; display: flex; justify-content: flex-end; }
.dkdp-footer-menu { list-style: none; display: flex; gap: 22px; padding: 0; margin: 0; flex-wrap: wrap; }
.dkdp-footer-menu a { color: #5a5a66; font-size: 14px; font-weight: 600; }
.dkdp-footer-menu a:hover { color: var(--dkdp-accent); }
.dkdp-footer-copy { font-size: 13px; color: #8a8a95; margin: 0; text-align: center; }

@media (max-width: 640px) {
	.dkdp-footer-top { flex-direction: column; align-items: flex-start; }
	.dkdp-footer-nav { justify-content: flex-start; width: 100%; }
}

/* ---------------- Generic page ---------------- */
.dkdp-page-title { font-size: 30px; margin: 30px 0 20px; }
.dkdp-page-content { padding-bottom: 40px; }
.dkdp-page-content .dkdp-container,
.dkdp-post-content { padding: 0 20px; }
