/**
 * ===========================================================================
 * THEME STYLES (PRIMARY DESIGN AUTHORITY)
 * ===========================================================================
 *
 * - style.css: desktop-first components and layout.
 * - media.css: adapts the same intent for smaller screens; no separate “framework”.
 * - Layout is owned here—not a third-party grid bundle.
 *
 * Discipline: tokens in variables.css; use `rem` for
 * spacing/typography where appropriate.
 * ===========================================================================
 */

/* -----------------------
   GLOBAL BASE
   ----------------------- */
@import 'font.css';
@import 'variables.css';
@import 'utils.css';

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html,
body {
	width: 100%;
	overflow-x: clip;
}

body {
	font-family: var(--font-base);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	line-height: var(--line-height-base);
	background-color: var(--color-white);
	color: var(--color-primary);
}

/* 
::-webkit-scrollbar-track {
	background-color: var(--theme_color_primary);
	border-left: 1px solid var(--theme_color_primary);
}

::-webkit-scrollbar {
	width: 7px;
	background-color: var(--theme_color_primary);
}

::-webkit-scrollbar-thumb {
	background: var(--theme_color_accent);
} */

/* ::selection {
	color: var(--color-secondary);
	background-color: var(--color-white);
	filter: invert(1);
} */

p {
	line-height: var(--line-height-base);
	margin-bottom: 0px;
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	font-weight: var(--font-weight-bold);
	line-height: var(--line-height-base);
	color: var(--color-primary);
}

img {
	max-width: 100%;
}

a {
	text-decoration: none;
}

a:hover {
	text-decoration: none;
	outline: 0;
}

a:focus {
	text-decoration: none;
	outline: 0;
}

input:focus {
	outline: none;
	border: none;
}

ul li {
	list-style: none;
}


.color-primary {
	color: var(--color-primary);
}

.color-secondary {
	color: var(--color-secondary);
}

.font-primary {
	font-family: var(--font-primary);
}

.font-secondary {
	font-family: var(--font-secondary);
}

.equal-cols>* {
	flex: 1 1 0%;
}

/* --- Layout shells (no external grid framework) --- */
.section {
	width: 100%;
}

.container {
	max-width: var(--container-max-width);
	margin: 0 auto;
	position: relative;
}

.container-full {
	padding-left: 0;
	padding-right: 0;
}

.container-padding-x {
	padding-left: var(--container-padding-x);
	padding-right: var(--container-padding-x);
}

.container-padding-y {
	padding-top: var(--container-padding-y);
	padding-bottom: var(--container-padding-y);
}

.container-padding-x-header {
	padding-left: var(--header-padding-x);
	padding-right: var(--header-padding-x);
}

.container-padding-y-header {
	padding-top: var(--header-padding-y);
	padding-bottom: var(--header-padding-y);
}

.container-padding-bottom {
	padding-bottom: var(--container-padding-bottom);
}

.container-padding-top {
	padding-top: var(--container-padding-top);
}

.bg-primary {
	background: var(--color-primary);
}

.bg-secondary {
	background: var(--color-secondary);
}

.bg-secondary-ultra-light {
	background: var(--color-secondary-ultra-light);
}

.bg-accent {
	background: var(--color-accent);
}

.bg-ink-white {
	background: var(--color-white);
}

.color-muted {
	color: var(--color-muted);
}
.color-white {
	color: var(--color-white);
}

.line-height-xs {
	line-height: var(--line-height-xs);
}

.line-height-sm {
	line-height: var(--line-height-sm);
}

.line-height-base {
	line-height: var(--line-height-base);
}

.line-height-md {
	line-height: var(--line-height-md);
}

.line-height-lg {
	line-height: var(--line-height-lg);
}
.brand-logo-img {
	max-width: 186px;
}

.primary-heading {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-medium);
}

.desktop-show {
	display: block;
}

.desktop-hide {
	display: none;
}

.btn {
	display: inline-block;
	padding: 14px var(--space-lg);
	border-radius: var(--border-radius-xxs);
	text-decoration: none;
}

.btn-primary {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	justify-content: center;
	font-family: var(--font-secondary);
	background: var(--color-gradient-primary);
	color: var(--color-primary);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	line-height: 28px;
}

.btn-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.btn-icon img {
	height: 24px;
	width: 24px;
}

.btn-secondary-bordered {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-base) var(--space-md);
	background: var(--color-white);
	border: 1px solid var(--color-primary);
	border-radius: var(--border-radius-xxs);
	color: var(--color-primary);
	font-size: var(--font-size-base);
	line-height: 28px;
	text-decoration: none;
}

/* CTA: solid primary + bordered variant (same sizing, reusable) */
.btn-cta-primary-bordered {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: 14px var(--space-lg);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	line-height: 28px;
	border-radius: var(--border-radius-xs);
	text-decoration: none;
	box-sizing: border-box;
	background: transparent;
	color: var(--color-secondary);
	border: 1px solid var(--color-secondary);
}

.btn-cta-primary-bordered .btn-cta-icon {
	color: var(--color-secondary);
}

.header-nav-link {
	font-family: var(--font-secondary);
	font-size: 28px;
	font-weight: var(--font-weight-normal);
	line-height: var(--line-height-fixed-base);

}

/* Reusable gradient-text utilities (use anywhere) */
.text-gradient {
	background: var(--text-gradient, var(--color-gradient-primary));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;
}

.sub-header-wrap {
	background: #0e0f26;
}

.sub-header-wrap li a {
	font-size: var(--font-size-sm);
}

.home-hero-wrap {
	/* Full-screen hero that stays within viewport */
	height: 100vh;
	height: 100svh;
	overflow: hidden;

	/* Simple layering: image + content share same grid cell */
	display: grid;
	place-items: center;
	position: relative;
}

.home-hero-content-wrap {
	max-width: 932px;
	margin: 0 auto;
	z-index: 2;
	grid-area: 1 / 1;
}

.home-hero-image-wrap {
	height: 100%;
	width: 100%;
	overflow: hidden;
	grid-area: 1 / 1;
	z-index: 0;
	position: relative;
}

/* Gradient overlay on top of hero image */
.home-hero-image-wrap::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg,
			rgba(0, 0, 0, 0.6) 0%,
			rgba(0, 0, 0, 0.4) 50%,
			rgba(0, 0, 0, 0.7) 100%);
	z-index: 1;
	pointer-events: none;
}

.home-hero-image-wrap img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	object-position: center;
}

.home-hero-title {
	/* font-family: var(--font-secondary); */
	font-weight: var(--font-weight-semibold);
	font-size: var(--font-size-4xl);
	line-height: 1;
	color: var(--color-white);
	text-align: center;
	/* letter-spacing: -1.5px; */

}

.home-hero-subtitle {
	max-width: 600px;
	margin: 0 auto;
	font-family: var(--font-secondary);
	font-weight: var(--font-weight-normal);
	font-size: var(--font-size-md);
	line-height: var(--line-height-fixed-md);
	letter-spacing: 0%;
	text-align: center;
	color:#FCFAF8E5;
	vertical-align: middle;
}
.section-title
{
	font-family: var(--font-heading);
	font-weight: var(--font-weight-semibold);
	font-size: var(--font-size-2xl);
	line-height: 1.2085;
	letter-spacing: -0.9px;
	position: relative;
	display: inline-block;
}
.home-local-experties-wrap
{
	max-width:768px;
	margin:0 auto;
}

/* ---------- Properties worth (valuation cards) ---------- */
.properties-worth-card {
	min-height: 350px;
	display: flex;
	flex-direction: column;
	height: 100%;
	max-width: 500px;
	padding: var(--space-xl);
	background: var(--color-primary);
    border-radius: var(--border-radius-md);
}

.properties-worth-card-icon {
	flex-shrink: 0;
	width: 66px;
	height: 66px;
	border-radius: 50%;
	background: var(--color-secondary);
	display: flex;
	align-items: center;
	justify-content: center;
}

.properties-worth-card-icon img {
	display: block;
	width: 29px;
	height: 29px;
}

.properties-worth-card-title {
	font-family: var(--font-heading);
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-normal);
	color: var(--color-white);
	line-height: var(--line-height-xs);
}

.properties-worth-card-tagline {
	font-family: var(--font-secondary);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	color: #FCFAF899;
	line-height: var(--line-height-md);
}

.properties-worth-card-desc {
	flex: 1 1 auto;
	font-family: var(--font-secondary);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-md);
	color: #FCFAF8B2;
}

.properties-worth-card-input {
	width: 100%;
	padding: 15px 20px;
	font-family: var(--font-secondary);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-md);
	color: #FCFAF880;
	background: #FCFAF81A;
	border: 1px solid #FCFAF833;
	border-radius: var(--border-radius-xs);
	box-sizing: border-box;
}
.properties-worth-card-input:focus {
	border: 1px solid rgba(255, 255, 255, 0.35);
}

/* ---------- Our Property Services ---------- */
.property-services-grid {
	grid-template-columns: repeat(5, minmax(0, 1fr));
	list-style: none;
	margin: 0;
	padding: 0;
}

.property-services-card {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 140px;
	max-width: 230px;
	text-align: center;
	border: 1px solid #A69E6F52;
	box-sizing: border-box;
	border-radius: var(--border-radius-xs);
}

.property-services-card-text {
	font-family: var(--font-heading);
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-normal);
	line-height: var(--line-height-sm);
}

/* ---------- Reviews ---------- */
.reviews-card {
	padding: var(--space-lg);
	background: var(--color-accent);
	border: 1px solid rgba(24, 25, 63, 0.1);
	border-radius: var(--border-radius-sm);
	box-sizing: border-box;
}

.reviews-avatar {
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	border-radius: 50%;
	background: var(--color-secondary);
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-semibold);
}

.reviews-google-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--color-white);
	border: 1px solid rgba(24, 25, 63, 0.12);
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-bold);
	line-height: 1;
	color: var(--color-primary);
}

.cta-intro {
	max-width: 640px;
	margin: 0;
	color: var(--color-accent);
}

/* ---------- property cards ---------- */
.properties-grid {
	align-items: stretch;
}

.property-card {
	background: var(--color-white);
	box-shadow: 0px 8px 30px -8px #1D30291A;
	border-radius: var(--border-radius-xs);
	overflow: hidden;
	box-sizing: border-box;
	min-width: 0;
}

.property-card-image {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
}

.property-card-image img {
	width: 100%;
	height: 100%;
	min-height: 300px;
	object-fit: cover;
	display: block;
}

.property-card-body {
	padding: 20px;
}

.property-card-body img {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	display: block;
}

.property-card-location {
	font-family: var(--font-secondary);
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-medium);
	line-height: var(--line-height-sm);
	color: var(--color-muted);
	flex: 1 1 auto;
	min-width: 0;
	text-align: left;
}

.property-card-price {
	font-family: var(--font-secondary);
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	line-height: 32px;
	color: var(--color-primary);
	margin: 0;
	flex-shrink: 0;
	text-align: right;
}

.property-card-specs {
	font-size: var(--font-size-xs);
	line-height: var(--line-height-fixed-sm);
}

/* ---------- Follow Our Journey ---------- */
.follow-journey-ig {
	flex-shrink: 0;
	display: block;
}

.follow-journey-photo {
	min-width: 0;
	aspect-ratio: 3 / 2;
}

.follow-journey-photo img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ---------- Footer ---------- */
.footer-inner {
	padding-top: var(--footer-padding-top);
	padding-bottom: var(--footer-padding-bottom);
}

.footer a {
	color: var(--color-white);
	text-decoration: none;
}

.footer a:hover {
	opacity: 0.85;
}

.footer-brand-logo {
	display: block;
	max-width: 220px;
	height: auto;
}

.footer-brand-text {
	line-height: var(--line-height-md);
	opacity: 0.92;
}

.footer-social-link {
	display: inline-flex;
	color: var(--color-white);
	line-height: 1;
}

.footer-col-title {
	font-family: var(--font-heading);
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-semibold);
	color: var(--color-secondary);
	line-height: var(--line-height-sm);
}

.footer-icon {
	flex-shrink: 0;
	color: var(--color-white);
	margin-top: 2px;
}

.footer-icon-img {
	display: block;
	filter: brightness(0) invert(1);
	opacity: 0.92;
}

.footer-nav-link {
	font-family: var(--font-secondary);
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-normal);
	line-height: 20px;
	color: #FCFAF8CC;
}
.footer-partners {
	padding-top: var(--space-3xl);
}

.footer-partner-logo {
	display: block;
	max-height: 94px;
	width: auto;
	object-fit: contain;
}

.footer-bottom {
	margin-top: var(--space-5xl);
}

.footer-bottom-text {
	font-size: var(--font-size-xs);
	line-height: var(--line-height-sm);
}

.footer-site-by {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}