/* =========================================================================
   KB Custom Homes — design system
   Decoro-inspired: warm neutrals, serif display, generous whitespace.
   ========================================================================= */

:root {
	--cream:      #F6F1E8;
	--ivory:      #FBF8F2;
	--sand:       #E8DFCF;
	--sand-soft:  #F0E8D9;
	--clay:       #B8734A;
	--clay-dark:  #9A5A3A;
	--sage:       #7E8568;
	--olive:      #5E6449;
	--charcoal:   #2A2520;
	--ink:        #14110D;
	--brand-dark:   #0F3D2E; /* logo green — used on primary CTAs + dark bands */
	--brand-darker: #093024; /* hover deepen for green-on-green surfaces */
	--muted:      #7A7067;
	--line:       rgba(42, 37, 32, 0.14);
	--line-soft:  rgba(42, 37, 32, 0.08);

	--radius-sm:  6px;
	--radius:     12px;
	--radius-lg:  22px;

	--shadow-sm:  0 1px 2px rgba(42,37,32,0.05), 0 4px 12px -6px rgba(42,37,32,0.08);
	--shadow:     0 2px 4px rgba(42,37,32,0.06), 0 24px 48px -20px rgba(42,37,32,0.24);
	--shadow-lg:  0 4px 8px rgba(42,37,32,0.08), 0 48px 80px -28px rgba(42,37,32,0.35);

	--ease-out:    cubic-bezier(0.2, 0.7, 0.2, 1);
	--ease-in-out: cubic-bezier(0.6, 0.1, 0.2, 1);
	--ease-fluid:  cubic-bezier(0.16, 1, 0.3, 1);    /* editorial entrance */
	--ease-smooth: cubic-bezier(0.22, 1, 0.36, 1);   /* expo-out */
	--ease-soft:   cubic-bezier(0.33, 1, 0.68, 1);   /* cubic-out */

	--font-serif: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
	--font-sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

	--container:   1280px;
	--container-w: 1480px;
	--gutter:      clamp(1.2rem, 4vw, 2.5rem);
}

/* ------- Base ------- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: 1.65;
	color: var(--charcoal);
	background: var(--ivory);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-variant-numeric: lining-nums;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color 0.3s var(--ease-out); }
a:hover { color: var(--brand-dark); }

h1, h2, h3, h4, h5 {
	font-family: var(--font-serif);
	font-weight: 400;
	color: var(--ink);
	margin: 0 0 0.5em;
	letter-spacing: -0.005em;
	line-height: 1.15;
}

p { margin: 0 0 1.1em; }

::selection { background: var(--clay); color: var(--ivory); }

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px; width: 1px;
	overflow: hidden; word-wrap: normal !important;
}
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--ink); color: var(--ivory); padding: 12px 20px; z-index: 100; }
.skip-link:focus { left: 12px; top: 12px; }

/* ------- Layout ------- */
.kbc-container {
	max-width: var(--container-w);
	margin: 0 auto;
	padding-left: var(--gutter);
	padding-right: var(--gutter);
}

/* Each .kbc-section gets its own full top + bottom padding so adjacent
   sections never feel cramped. Between two sections with DIFFERENT background
   colors the extra padding on both sides feels right; between two sections
   with the same background, we alternate backgrounds (see the overrides
   below) so the seam stays readable. */
.kbc-section {
	padding-top: clamp(2.25rem, 4vw, 4rem);
	padding-bottom: clamp(2.25rem, 4vw, 4rem);
}

.site-main { overflow-x: clip; }

/* ------- Typography utilities ------- */
.kbc-h1 {
	font-size: clamp(2.4rem, 5.8vw, 4.75rem);
	line-height: 1.05;
	font-weight: 400;
	margin-bottom: 0.35em;
}
.kbc-h2 {
	font-size: clamp(2.6rem, 5vw, 4.25rem);
	line-height: 1.05;
	font-weight: 600;
	letter-spacing: -0.014em;
	color: var(--ink);
	margin-bottom: 0.4em;
}
.kbc-h3 {
	font-size: clamp(1.3rem, 2.1vw, 1.75rem);
	font-weight: 500;
}
.kbc-lead {
	font-size: clamp(0.95rem, 1.15vw, 1.1rem);
	line-height: 1.6;
	color: var(--muted);
	max-width: 62ch;
}

.kbc-eyebrow {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: 1.05rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--brand-dark);
	margin-bottom: 1.25rem;
	padding-bottom: 0.25rem;
	position: relative;
	line-height: 1.4;
}
.kbc-eyebrow::before {
	content: '';
	display: inline-block;
	width: 36px;
	height: 1.5px;
	background: currentColor;
	margin-right: 14px;
	transform: translateY(-5px);
	vertical-align: middle;
}

/* ------- Buttons ------- */
.kbc-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.95rem 1.4rem;
	font-family: var(--font-sans);
	font-size: 0.92rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	text-decoration: none;
	border-radius: 999px;
	transition:
		background 0.35s var(--ease-out),
		color 0.35s var(--ease-out),
		border-color 0.35s var(--ease-out),
		transform 0.5s var(--ease-out);
	cursor: pointer;
	border: 1px solid transparent;
	line-height: 1;
}
.kbc-btn__arrow { transition: transform 0.35s var(--ease-out); display: inline-block; }
.kbc-btn:hover .kbc-btn__arrow { transform: translateX(4px); }

.kbc-btn--primary {
	background: var(--brand-dark);
	color: var(--ivory);
}
.kbc-btn--primary:hover {
	background: var(--brand-darker);
	color: var(--ivory);
}

.kbc-btn--ghost {
	background: transparent;
	color: var(--ink);
	border-color: var(--line);
}
.kbc-btn--ghost:hover {
	background: var(--brand-dark);
	color: var(--ivory);
	border-color: var(--brand-dark);
}

.kbc-btn--link {
	background: transparent;
	color: var(--ink);
	padding: 0.25rem 0;
	border-radius: 0;
	border-bottom: 1px solid var(--line);
	border-top: 0; border-left: 0; border-right: 0;
	font-size: 0.88rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 500;
}
.kbc-btn--link:hover { color: var(--brand-dark); border-bottom-color: var(--brand-dark); }

.kbc-btn--sm {
	padding: 0.65rem 1rem;
	font-size: 0.82rem;
}

/* Header state note: the home hero is a light cream gradient (not a dark image),
   so the header keeps dark text in all states. The data-state attribute stays
   on the header for structural purposes (border/blur), but we don't invert
   any colors based on it. */

/* ------- Header ------- */
.site-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 50;
	padding: 1.4rem 0;
	transition: background 0.35s var(--ease-out), border-color 0.35s var(--ease-out), padding 0.35s var(--ease-out);
	border-bottom: 1px solid transparent;
}
.site-header[data-state="scrolled"] {
	background: rgba(251, 248, 242, 0.92);
	backdrop-filter: saturate(1.4) blur(14px);
	-webkit-backdrop-filter: saturate(1.4) blur(14px);
	border-bottom-color: var(--line-soft);
	padding: 0.9rem 0;
}
.site-header__inner {
	max-width: var(--container-w);
	margin: 0 auto;
	padding: 0 var(--gutter);
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 2rem;
	min-height: 88px;
}
.site-header[data-state="scrolled"] .site-header__inner { min-height: 80px; }

/* Uploaded logo (via Customize → Site Identity → Logo).
   site-branding itself is flex-centered so the logo sits perfectly in the
   vertical middle of the header at every scroll state. */
.site-branding {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}
.site-branding .custom-logo-link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	line-height: 0;
}
.site-branding .custom-logo {
	display: block;
	width: auto;
	height: clamp(68px, 7.5vw, 92px);
	max-height: 92px;
	transition: height 0.35s var(--ease-out), opacity 0.3s;
	vertical-align: middle;
}
.site-header[data-state="scrolled"] .site-branding .custom-logo {
	height: clamp(60px, 6.5vw, 80px);
}
.site-branding .custom-logo-link:hover .custom-logo { opacity: 0.82; }

.site-wordmark {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	text-decoration: none;
	color: var(--ink);
}
.site-wordmark__mark {
	display: inline-grid; place-items: center;
	width: 40px; height: 40px;
	border-radius: 50%;
	background: var(--ink);
	color: var(--ivory);
	font-family: var(--font-serif);
	font-size: 1.1rem;
	font-weight: 500;
	letter-spacing: -0.02em;
}
.site-wordmark__name {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 500;
	letter-spacing: -0.01em;
}

.site-nav { justify-self: center; }
.primary-menu {
	display: flex;
	list-style: none;
	margin: 0; padding: 0;
	gap: 2rem;
	align-items: center;
}
.primary-menu a {
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--ink);
	padding: 0.4rem 0;
	position: relative;
	transition: color 0.3s var(--ease-out);
}
.primary-menu a::after {
	content: '';
	position: absolute;
	left: 0; right: 0; bottom: -2px;
	height: 1px;
	background: currentColor;
	transform: scaleX(0);
	transform-origin: right;
	transition: transform 0.45s var(--ease-out);
}
.primary-menu a:hover::after,
.primary-menu .current-menu-item > a::after { transform: scaleX(1); transform-origin: left; }

.primary-menu .sub-menu {
	position: absolute;
	top: 100%; left: 0;
	background: var(--ivory);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 0.75rem;
	min-width: 220px;
	list-style: none;
	margin: 0;
	box-shadow: var(--shadow);
	opacity: 0;
	visibility: hidden;
	transform: translateY(6px);
	transition: opacity 0.3s var(--ease-out), transform 0.3s var(--ease-out), visibility 0.3s;
}
/* Invisible bridge so the cursor can travel from trigger to submenu
   without losing :hover. Covers the 8px visual gap above the dropdown. */
.primary-menu .sub-menu::before {
	content: '';
	position: absolute;
	left: 0; right: 0;
	top: -12px;
	height: 12px;
	background: transparent;
}
/* Keep the parent link visually selectable but treat it as a dropdown toggle
   on desktop — JS also preventDefaults the click (see main.js). */
.primary-menu > .menu-item-has-children > a {
	cursor: pointer;
}
/* Suppress the underlying underline on parent links and render an inline
   chevron using a background-image (keeps the underline intact for
   children and non-parent top-level links). */
.primary-menu > .menu-item-has-children > a::after { display: none; }
.primary-menu > .menu-item-has-children > a {
	padding-right: 14px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none' stroke='%232A2520' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 10px 6px;
	transition: background-position 0.3s var(--ease-out), color 0.3s var(--ease-out);
}
.primary-menu > .menu-item-has-children:hover > a,
.primary-menu > .menu-item-has-children:focus-within > a {
	background-position: right 2px center;
}
.primary-menu > .menu-item-has-children { position: relative; }
.primary-menu > .menu-item-has-children:hover .sub-menu,
.primary-menu > .menu-item-has-children:focus-within .sub-menu {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.primary-menu .sub-menu a { display: block; padding: 0.55rem 0.8rem; border-radius: var(--radius-sm); font-size: 0.88rem; }
.primary-menu .sub-menu a::after { display: none; }
.primary-menu .sub-menu a:hover { background: var(--sand-soft); color: var(--ink); }


.site-header__cta { display: flex; gap: 0.6rem; align-items: center; justify-self: end; }
/* Header ghost button: dark ink text by default, ivory text on dark-ink hover. */
.site-header__cta .kbc-btn--ghost {
	color: var(--ink);
	border-color: var(--line);
	background: transparent;
}
.site-header__cta .kbc-btn--ghost:hover {
	color: var(--ivory);
	background: var(--brand-dark);
	border-color: var(--brand-dark);
}
.site-header__cta .kbc-btn--ghost:hover svg { color: var(--ivory); }

.nav-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 0.6rem;
	width: 44px; height: 44px;
	cursor: pointer;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
}
.nav-toggle span {
	display: block;
	width: 18px; height: 1.5px;
	background: currentColor;
	transition: transform 0.3s var(--ease-out), opacity 0.2s;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

.nav-placeholder { margin: 0; font-size: 0.85rem; color: var(--muted); }
.nav-placeholder a { color: var(--clay); text-decoration: underline; }

/* ------- Hero ------- */
.kbc-hero {
	position: relative;
	padding-top: clamp(8rem, 14vh, 10rem);
	padding-bottom: clamp(4rem, 8vw, 7rem);
	background:
		radial-gradient(ellipse at top right, rgba(184,115,74,0.08), transparent 50%),
		linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
	overflow: hidden;
}
.kbc-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h80v80H0z' fill='none'/%3E%3Ccircle cx='40' cy='40' r='0.6' fill='%232a2520' opacity='0.08'/%3E%3C/svg%3E");
	opacity: 0.7;
	pointer-events: none;
	z-index: 0;
}

/* --- Decorative background layers for "alive" feel on load --- */
.kbc-hero__bg-blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	pointer-events: none;
	z-index: 0;
	will-change: transform, opacity;
}
.kbc-hero__bg-blob--1 {
	width: 520px; height: 520px;
	left: -8%; top: 10%;
	background: radial-gradient(circle, rgba(184,115,74,0.28) 0%, transparent 65%);
	animation: kbcBlob1 18s var(--ease-in-out) infinite alternate;
}
.kbc-hero__bg-blob--2 {
	width: 420px; height: 420px;
	right: 12%; bottom: -6%;
	background: radial-gradient(circle, rgba(126,133,104,0.26) 0%, transparent 65%);
	animation: kbcBlob2 22s var(--ease-in-out) infinite alternate;
}
@keyframes kbcBlob1 {
	0%   { transform: translate(0, 0) scale(1); }
	50%  { transform: translate(40px, -20px) scale(1.1); }
	100% { transform: translate(-20px, 30px) scale(0.95); }
}
@keyframes kbcBlob2 {
	0%   { transform: translate(0, 0) scale(1); }
	50%  { transform: translate(-30px, -40px) scale(1.08); }
	100% { transform: translate(25px, 15px) scale(0.92); }
}

/* Move hero__inner above the decorative blob layers */
.kbc-hero__inner { position: relative; z-index: 1; }
.kbc-hero__meta { position: relative; z-index: 2; }

/* NOVA (word stat) is shorter — needs a smaller serif size than numeric stats */
.kbc-hero__stat-num--word {
	font-size: 1.45rem !important;
	letter-spacing: 0.08em !important;
}
.kbc-hero__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
}
.kbc-hero__copy { max-width: 36rem; }
.kbc-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.6rem, 6vw, 5rem);
	font-weight: 400;
	line-height: 1.03;
	letter-spacing: -0.01em;
	margin: 0 0 1.5rem;
	color: var(--ink);
}
.kbc-hero__lead {
	font-size: clamp(1.05rem, 1.5vw, 1.2rem);
	color: var(--muted);
	line-height: 1.6;
	max-width: 34rem;
	margin-bottom: 2rem;
}
.kbc-hero__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-bottom: 2.5rem; }

.kbc-hero__meta {
	display: grid;
	grid-template-columns: repeat(3, auto);
	gap: clamp(1.2rem, 3vw, 2.4rem);
	padding-top: 1.75rem;
	border-top: 1px solid var(--line);
}
.kbc-hero__stat { display: flex; flex-direction: column; gap: 0.2rem; }
.kbc-hero__stat-num { font-family: var(--font-serif); font-size: 1.75rem; color: var(--ink); letter-spacing: -0.01em; }
.kbc-hero__stat-label { font-size: 0.78rem; color: var(--muted); letter-spacing: 0.04em; }
/* VIRGINIA stat carries a long service-area list — let it wrap, capped to a
   readable measure so the other two stats keep their auto-sized columns. */
/* ------- Hero — full-bleed background-image variant -------
   Activated when `kbc_hero_bg_image` is set in the Customizer. Full-viewport
   editorial layout: copy block vertically centred, stats anchored to the
   bottom on a hairline divider, scroll cue floating at the very bottom. */
.kbc-hero--full-bg {
	position: relative;
	min-height: clamp(640px, 92vh, 880px);
	padding: clamp(7.5rem, 12vh, 10rem) 0 clamp(2.5rem, 5vh, 4rem);
	background: var(--ink);
	color: var(--ivory);
	overflow: hidden;
	display: flex;
	align-items: stretch; /* stretch inner so we can pin stats to bottom */
}
.kbc-hero--full-bg::before { display: none; }

/* Photo layer with a slow Ken Burns drift for cinematic feel. */
.kbc-hero--full-bg .kbc-hero__bg {
	position: absolute;
	inset: -2% -2%; /* slight bleed so the zoom doesn't reveal section edges */
	background-image: var(--kbc-hero-bg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	z-index: 0;
	animation: kbcHeroDrift 28s ease-in-out infinite alternate;
	will-change: transform;
}
@keyframes kbcHeroDrift {
	0%   { transform: scale(1.02) translate(0, 0); }
	100% { transform: scale(1.08) translate(-1%, 0.5%); }
}
@media (prefers-reduced-motion: reduce) {
	.kbc-hero--full-bg .kbc-hero__bg { animation: none; transform: none; }
}

/* Pure-white hero text with a multi-layer shadow stack for visibility.
   The shadow lives in the few pixels around each glyph, so the photo
   isn't tinted, but the text reads cleanly against light or dark areas. */
.kbc-hero--full-bg .kbc-hero__bg::after { content: none; }

.kbc-hero--full-bg .kbc-hero__title,
.kbc-hero--full-bg .kbc-hero__lead,
.kbc-hero--full-bg .kbc-eyebrow,
.kbc-hero--full-bg .kbc-eyebrow *,
.kbc-hero--full-bg .kbc-hero__stat-num,
.kbc-hero--full-bg .kbc-hero__stat-label { color: #ffffff; }
.kbc-hero--full-bg .kbc-eyebrow::before,
.kbc-hero--full-bg .kbc-eyebrow::after   { background: #ffffff; }

.kbc-hero--full-bg .kbc-hero__lead,
.kbc-hero--full-bg .kbc-eyebrow,
.kbc-hero--full-bg .kbc-hero__stat-num,
.kbc-hero--full-bg .kbc-hero__stat-label {
	text-shadow:
		0 0 1px rgba(0, 0, 0, 0.9),
		0 1px 2px rgba(0, 0, 0, 0.85),
		0 2px 10px rgba(0, 0, 0, 0.7),
		0 4px 26px rgba(0, 0, 0, 0.5);
}
.kbc-hero--full-bg .kbc-hero__title {
	text-shadow:
		0 0 2px rgba(0, 0, 0, 0.95),
		0 1px 2px rgba(0, 0, 0, 0.9),
		0 2px 12px rgba(0, 0, 0, 0.8),
		0 4px 28px rgba(0, 0, 0, 0.6),
		0 8px 50px rgba(0, 0, 0, 0.4);
}

/* Inner grid — copy vertically centred, stats pinned to the bottom row. */
.kbc-hero--full-bg .kbc-hero__inner {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: 1fr auto;
	gap: clamp(2.5rem, 5vh, 4rem);
	width: 100%;
	max-width: min(var(--container-w), 1080px);
	align-self: stretch;
	z-index: 1;
}
.kbc-hero--full-bg .kbc-hero__copy {
	max-width: 44rem;
	align-self: center;
	justify-self: center;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

/* Centred eyebrow with hairline accents on either side. */
.kbc-hero--full-bg .kbc-eyebrow,
.kbc-hero--full-bg .kbc-eyebrow * { color: rgba(251, 248, 242, 0.82); }
.kbc-hero--full-bg .kbc-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.95rem;
	font-size: 0.92rem;
	letter-spacing: 0.22em;
}
.kbc-hero--full-bg .kbc-eyebrow::before,
.kbc-hero--full-bg .kbc-eyebrow::after {
	content: '';
	display: block;
	width: clamp(28px, 4vw, 56px);
	height: 1px;
	background: rgba(251, 248, 242, 0.5);
	margin: 0;
	transform: none;
}

/* Title — slightly tighter on dark for editorial feel. */
.kbc-hero--full-bg .kbc-hero__title {
	color: var(--ivory);
	font-size: clamp(3rem, 6.4vw, 5.4rem);
	line-height: 1.05;
	letter-spacing: -0.012em;
	margin: 1.25rem 0 1.5rem;
	text-wrap: balance;
}
.kbc-hero--full-bg .kbc-hero__lead {
	color: rgba(251, 248, 242, 0.88);
	max-width: 40rem;
	margin: 0 auto 2.25rem;
	font-size: clamp(1.15rem, 1.55vw, 1.35rem);
	line-height: 1.65;
}

.kbc-hero--full-bg .kbc-hero__actions { justify-content: center; gap: 0.85rem; margin: 0; }

/* Primary CTA on the dark backdrop — switch to clay so it reads instantly. */
.kbc-hero--full-bg .kbc-btn--primary {
	background: var(--clay);
	color: var(--ivory);
	border-color: var(--clay);
}
.kbc-hero--full-bg .kbc-btn--primary:hover {
	background: var(--clay-dark);
	border-color: var(--clay-dark);
}
/* Ghost button on the dark backdrop. */
.kbc-hero--full-bg .kbc-btn--ghost {
	color: var(--ivory);
	border-color: rgba(251, 248, 242, 0.55);
	background: transparent;
}
.kbc-hero--full-bg .kbc-btn--ghost:hover {
	color: var(--ink);
	background: var(--ivory);
	border-color: var(--ivory);
}

/* Stats row — equal-feeling layout with VIRGINIA twice as wide for cities. */
.kbc-hero--full-bg .kbc-hero__meta {
	grid-template-columns: 1fr minmax(20rem, 2fr) 1fr;
	gap: clamp(1.5rem, 4vw, 3.25rem);
	padding-top: 1.5rem;
	border-top: 1px solid rgba(251, 248, 242, 0.22);
	max-width: 60rem;
	margin: 0 auto;
	align-items: start;
}
.kbc-hero--full-bg .kbc-hero__stat {
	align-items: center;
	text-align: center;
	gap: 0.4rem;
}
.kbc-hero--full-bg .kbc-hero__stat-num {
	color: var(--ivory);
	font-size: clamp(1.95rem, 2.9vw, 2.55rem);
}
.kbc-hero--full-bg .kbc-hero__stat-num--word {
	font-size: clamp(1.5rem, 2.1vw, 1.85rem) !important;
	letter-spacing: 0.12em !important;
}
.kbc-hero--full-bg .kbc-hero__stat-label {
	color: rgba(251, 248, 242, 0.78);
	font-size: 0.86rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
/* City list under VIRGINIA — un-uppercased, mixed case, balanced wrap. */
.kbc-hero--full-bg .kbc-hero__stat-label--cities {
	max-width: none;
	text-transform: none;
	letter-spacing: 0.01em;
	font-size: 0.95rem;
	line-height: 1.6;
	text-wrap: balance;
}
.kbc-hero__stat-city { white-space: nowrap; }

/* Entrance choreography — uses body.kbc-loaded toggled by main.js. */
.kbc-hero--full-bg .kbc-hero__copy > *,
.kbc-hero--full-bg .kbc-hero__meta {
	opacity: 0;
	transform: translateY(14px);
	transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
}
.kbc-loaded .kbc-hero--full-bg .kbc-hero__copy > *,
.kbc-loaded .kbc-hero--full-bg .kbc-hero__meta {
	opacity: 1;
	transform: none;
}
.kbc-loaded .kbc-hero--full-bg .kbc-hero__copy > *:nth-child(1) { transition-delay: 0.10s; }
.kbc-loaded .kbc-hero--full-bg .kbc-hero__copy > *:nth-child(2) { transition-delay: 0.20s; }
.kbc-loaded .kbc-hero--full-bg .kbc-hero__copy > *:nth-child(3) { transition-delay: 0.30s; }
.kbc-loaded .kbc-hero--full-bg .kbc-hero__copy > *:nth-child(4) { transition-delay: 0.40s; }
.kbc-loaded .kbc-hero--full-bg .kbc-hero__meta                  { transition-delay: 0.55s; }

.kbc-hero__stat-label--cities {
	max-width: 22rem;
	white-space: normal;
	line-height: 1.45;
}

.kbc-hero__visual { position: relative; min-height: 560px; }
.kbc-hero__stack {
	position: relative;
	aspect-ratio: 10 / 12;
	max-width: 560px;
	margin-left: auto;
}
.kbc-hero__frame {
	position: absolute;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--sand);
	box-shadow: var(--shadow);
	transition: transform 1.2s var(--ease-out);
}
.kbc-hero__frame img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1.8s var(--ease-out); }
.kbc-hero__frame:hover img { transform: scale(1.04); }
.kbc-hero__frame--1 { top: 0;    right: 0;  width: 72%; height: 68%; z-index: 2; }
.kbc-hero__frame--2 { top: 42%;  left: 0;   width: 55%; height: 48%; z-index: 3; }
.kbc-hero__frame--3 { bottom: 0; right: 8%; width: 40%; height: 34%; z-index: 4; }

.kbc-hero__stack--placeholder .kbc-hero__frame {
	background: linear-gradient(135deg, var(--sand) 0%, var(--sand-soft) 100%);
	display: grid;
	place-items: center;
	color: var(--muted);
	text-align: center;
	padding: 1rem;
	font-size: 0.85rem;
}

.kbc-hero__badge {
	position: absolute;
	right: -8px;
	bottom: 8%;
	width: 140px;
	height: 140px;
	border-radius: 50%;
	background: var(--ink);
	color: var(--ivory);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	text-align: center;
	z-index: 5;
	box-shadow: var(--shadow-lg);
	padding: 1rem;
	line-height: 1;
}
.kbc-hero__badge-top {
	display: block;
	font-size: 0.68rem;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.65);
}
.kbc-hero__badge-main {
	display: block;
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 2rem;
	line-height: 1;
	color: var(--clay);
	letter-spacing: 0.01em;
	margin: 0.15rem 0;
}
.kbc-hero__badge-bottom {
	display: block;
	font-size: 0.58rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.7);
	max-width: 90px;
	line-height: 1.2;
}

.kbc-hero__scroll {
	position: absolute;
	left: 50%;
	bottom: 2rem;
	transform: translateX(-50%);
	display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
	color: var(--muted);
	font-size: 0.7rem;
	letter-spacing: 0.28em;
	text-transform: uppercase;
}
.kbc-hero__scroll-line { width: 1px; height: 40px; background: var(--muted); position: relative; overflow: hidden; }
.kbc-hero__scroll-line::after { content: ''; position: absolute; top: -100%; left: 0; width: 100%; height: 50%; background: var(--ink); animation: kbcScrollLine 2s var(--ease-in-out) infinite; }
@keyframes kbcScrollLine { 0% { top: -100%; } 100% { top: 100%; } }

/* ------- Section heads ------- */
.kbc-section__head {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(1.5rem, 4vw, 4rem);
	align-items: end;
	margin-bottom: 3.5rem;
}
.kbc-section__head--center {
	grid-template-columns: 1fr;
	text-align: center;
	margin-left: auto; margin-right: auto;
	max-width: 760px;
}
.kbc-section__head--center .kbc-eyebrow { justify-self: center; }
.kbc-section__head--center .kbc-eyebrow::before { display: none; }
.kbc-section__head-aside { color: var(--muted); max-width: 38rem; }
.kbc-section__head-aside p { margin-bottom: 1rem; }

/* ------- Intro ------- */
.kbc-intro__inner {
	display: grid;
	grid-template-columns: 0.7fr 1fr;
	gap: clamp(2rem, 6vw, 6rem);
	align-items: start;
}
.kbc-intro__head { position: sticky; top: 140px; }
.kbc-intro__body p { font-size: clamp(1.1rem, 1.6vw, 1.35rem); line-height: 1.55; color: var(--charcoal); margin-bottom: 1.5rem; }

/* ------- Projects grid ------- */
.kbc-projects__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.5rem, 3vw, 2.4rem);
}
.kbc-projects__group + .kbc-projects__group { margin-top: clamp(3rem, 6vw, 5rem); }
.kbc-projects__group-title { margin-bottom: 2rem; padding-bottom: 1rem; border-bottom: 1px solid var(--line); }

.kbc-project-card {
	position: relative;
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	background: var(--ivory);
	border: 1px solid var(--line-soft);
	border-radius: var(--radius);
	overflow: hidden;
	transition: transform 0.6s var(--ease-out), box-shadow 0.6s var(--ease-out), border-color 0.4s;
}
.kbc-project-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow);
	border-color: var(--line);
}

/* Stretched link — sits under slider controls, takes clicks on image/body. */
.kbc-project-card__link {
	position: absolute;
	inset: 0;
	z-index: 1;
	text-indent: -9999px;
	overflow: hidden;
}
.kbc-project-card__link:focus-visible {
	outline: 2px solid var(--clay);
	outline-offset: -4px;
	border-radius: var(--radius);
}
.kbc-project-card__media {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--sand);
	border-radius: 0;
	margin-bottom: 0;
}
.kbc-project-card__media::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(20,17,13,0) 60%, rgba(20,17,13,0.28) 100%);
	opacity: 0;
	transition: opacity 0.5s var(--ease-out);
	z-index: 1;
	pointer-events: none;
}
.kbc-project-card:hover .kbc-project-card__media::after { opacity: 1; }

.kbc-project-card__slides { position: absolute; inset: 0; }
.kbc-project-card__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.8s var(--ease-out), visibility 0s linear 0.8s;
}
.kbc-project-card__slide.is-active {
	opacity: 1;
	visibility: visible;
	transition: opacity 0.8s var(--ease-out), visibility 0s;
}
.kbc-project-card__slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transform: scale(1);
	transition: transform 6s var(--ease-out);
}
.kbc-project-card__slide.is-active img { transform: scale(1.04); }
.kbc-project-card:hover .kbc-project-card__slide.is-active img { transform: scale(1.08); }

/* ---- Slider arrows (hover only) ---- */
.kbc-project-card__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid rgba(251,248,242,0.35);
	background: rgba(251,248,242,0.92);
	color: var(--ink);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	box-shadow: 0 6px 18px -6px rgba(20,17,13,0.35);
	opacity: 0;
	pointer-events: none;
	transition:
		opacity 0.35s var(--ease-out),
		background 0.3s var(--ease-out),
		color 0.3s var(--ease-out),
		transform 0.5s var(--ease-out);
	padding: 0;
}
.kbc-project-card__arrow--prev { left: 0.85rem; transform: translateY(-50%) translateX(-6px); }
.kbc-project-card__arrow--next { right: 0.85rem; transform: translateY(-50%) translateX(6px); }
.kbc-project-card:hover .kbc-project-card__arrow {
	opacity: 1;
	pointer-events: auto;
}
.kbc-project-card:hover .kbc-project-card__arrow--prev { transform: translateY(-50%) translateX(0); }
.kbc-project-card:hover .kbc-project-card__arrow--next { transform: translateY(-50%) translateX(0); }
.kbc-project-card__arrow:hover {
	background: var(--ink);
	color: var(--ivory);
	border-color: var(--ink);
}
.kbc-project-card__arrow:focus-visible {
	outline: 2px solid var(--clay);
	outline-offset: 2px;
}

/* ---- Dots (live indicator — visible always when there are multiple images) ---- */
.kbc-project-card__dots {
	position: absolute;
	left: 50%;
	bottom: 0.85rem;
	transform: translateX(-50%);
	display: flex;
	gap: 0.3rem;
	padding: 0.35rem 0.6rem;
	background: rgba(20,17,13,0.45);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-radius: 999px;
	z-index: 5;
	opacity: 0.85;
	transition: opacity 0.4s var(--ease-out);
}
.kbc-project-card:hover .kbc-project-card__dots { opacity: 1; }
.kbc-project-card__dot {
	appearance: none;
	border: 0;
	padding: 0;
	display: inline-block;
	width: 14px;
	height: 2px;
	background: rgba(251,248,242,0.45);
	transition: background 0.4s var(--ease-out), width 0.4s var(--ease-out);
	border-radius: 2px;
	cursor: pointer;
}
.kbc-project-card__dot.is-active {
	background: var(--ivory);
	width: 22px;
}

/* ---- Image count chip (top-right) ---- */
.kbc-project-card__count {
	position: absolute;
	top: 1rem; right: 1rem;
	z-index: 4;
	display: inline-flex;
	align-items: center;
	gap: 2px;
	background: rgba(20,17,13,0.55);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: var(--ivory);
	font-family: var(--font-serif);
	font-size: 0.82rem;
	padding: 0.28rem 0.65rem;
	border-radius: 999px;
	letter-spacing: 0.04em;
	opacity: 0;
	transition: opacity 0.35s var(--ease-out);
}
.kbc-project-card:hover .kbc-project-card__count { opacity: 1; }
.kbc-project-card__count-sep { opacity: 0.5; }
.kbc-project-card__count-current {
	min-width: 0.8em;
	text-align: right;
	font-variant-numeric: tabular-nums;
}

/* Hide the count chip when the arrow is there (visual clutter) on the right. */
.kbc-project-card:hover .kbc-project-card__count { opacity: 0; }

/* ---- Static fallback image ---- */
.kbc-project-card__media > img:not(.kbc-project-card__slides img) {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 1.2s var(--ease-out);
}
.kbc-project-card:hover .kbc-project-card__media > img { transform: scale(1.04); }

/* ---- Card hover lift ---- */
.kbc-project-card { transition: transform 0.6s var(--ease-out); }
.kbc-project-card:hover { transform: translateY(-4px); }
.kbc-project-card:hover .kbc-project-card__media { box-shadow: 0 16px 40px -18px rgba(20,17,13,0.28); }

.kbc-project-card__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--sand) 0%, var(--sand-soft) 100%); }

.kbc-project-card__status {
	position: absolute;
	top: 1rem; left: 1rem;
	z-index: 3;
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	padding: 0.4rem 0.7rem;
	border-radius: 999px;
	background: rgba(251,248,242,0.92);
	color: var(--ink);
	backdrop-filter: blur(8px);
	pointer-events: none;
}
.kbc-project-card__status--available,
.kbc-project-card__status--finished,
.kbc-project-card__status--upcoming { background: var(--brand-dark); color: var(--ivory); }

.kbc-project-card__body { padding: 0 0.25rem; }
.kbc-project-card__title {
	font-family: var(--font-serif);
	font-size: 1.4rem;
	font-weight: 500;
	margin: 0 0 0.4rem;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-project-card__location {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--muted);
	font-size: 0.88rem;
	margin: 0 0 0.75rem;
}
.kbc-project-card__specs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.95rem;
	list-style: none;
	margin: 0 0 0.65rem;
	padding: 0;
	color: var(--charcoal);
	font-size: 0.84rem;
}
.kbc-project-card__specs li { display: inline-flex; align-items: center; gap: 0.35rem; }
.kbc-project-card__price {
	font-family: var(--font-serif);
	font-size: 1.15rem;
	color: var(--clay);
	margin: 0.4rem 0 0;
}
.kbc-project-card__cta {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.8rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--clay);
	padding-top: 1rem;
	border-top: 1px solid var(--line-soft);
	width: 100%;
	transition: gap 0.35s var(--ease-fluid), color 0.3s;
}
.kbc-project-card__cta svg { transition: transform 0.35s var(--ease-fluid); }
.kbc-project-card:hover .kbc-project-card__cta { gap: 0.6rem; color: var(--clay-dark); }
.kbc-project-card:hover .kbc-project-card__cta svg { transform: translateX(3px); }

/* Card body — generous padding, flex column so View Details CTA anchors the bottom. */
.kbc-project-card__body {
	padding: clamp(1.25rem, 1.8vw, 1.75rem);
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
	flex: 1;
}

/* ------- Process — horizontal carousel with rail ------- */
.kbc-process { background: var(--cream); position: relative; --kbc-process-cols: 3; }

.kbc-process__carousel {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	align-items: stretch;
	gap: 0;
	max-width: 1280px;
	margin: 0 auto;
}

.kbc-process__viewport {
	overflow: hidden;
	position: relative;
}

.kbc-process__track {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: calc(100% / var(--kbc-process-cols));
	list-style: none;
	padding: 0;
	margin: 0;
	overflow-x: auto;
	scrollbar-width: none;
}
.kbc-process__track::-webkit-scrollbar { display: none; }

.kbc-process__slide {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

/* Rail — each slide draws its own segment; flush columns make a continuous line */
.kbc-process__rail {
	display: flex;
	flex-direction: column;
	align-items: center;
	user-select: none;
}
.kbc-process__rail-label {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--muted);
	letter-spacing: 0.02em;
	line-height: 1.2;
	margin-bottom: 0.65rem;
}
.kbc-process__rail-row {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	width: 100%;
	height: 40px;
}
.kbc-process__rail-line {
	height: 1px;
	background: var(--line);
}
.kbc-process__rail-dot {
	display: inline-grid;
	place-items: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--ivory);
	border: 1px solid var(--line);
	color: var(--ink);
	transition: background 0.4s, color 0.4s, border-color 0.4s, transform 0.5s var(--ease-fluid);
}

/* Card — sits below the rail with an upward speech-bubble pointer to its dot.
   `flex: 1` lets the card stretch to match the tallest sibling in the row. */
.kbc-process__card {
	position: relative;
	display: flex;
	flex-direction: column;
	flex: 1;
	background: var(--ivory);
	border: 1px solid var(--line-soft);
	border-radius: var(--radius);
	margin: 1.25rem clamp(0.5rem, 1.2vw, 1rem) 0;
	box-shadow: var(--shadow-sm);
	transition: transform 0.6s var(--ease-fluid), box-shadow 0.6s var(--ease-fluid), border-color 0.5s;
}
.kbc-process__card::before {
	content: '';
	position: absolute;
	top: -7px;
	left: 50%;
	width: 12px;
	height: 12px;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
	border-left: 1px solid var(--line-soft);
	transform: translateX(-50%) rotate(45deg);
	z-index: 2;
}
.kbc-process__slide:hover .kbc-process__card {
	transform: translateY(-4px);
	box-shadow: var(--shadow);
	border-color: var(--line);
}
.kbc-process__slide:hover .kbc-process__rail-dot {
	background: var(--clay);
	border-color: var(--clay);
	color: var(--ivory);
	transform: scale(1.06);
}
.kbc-process__slide:hover .kbc-process__rail-label { color: var(--ink); }

.kbc-process__media {
	aspect-ratio: 16 / 11;
	overflow: hidden;
	border-radius: var(--radius) var(--radius) 0 0;
	background: linear-gradient(135deg, var(--sand) 0%, var(--sand-soft) 100%);
}
.kbc-process__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 1.2s var(--ease-fluid);
}
.kbc-process__slide:hover .kbc-process__media img { transform: scale(1.04); }

.kbc-process__body {
	padding: clamp(1.1rem, 1.8vw, 1.45rem) clamp(1.25rem, 2vw, 1.65rem) clamp(1.35rem, 2.2vw, 1.75rem);
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 0.5rem;
}
.kbc-process__title {
	font-family: var(--font-serif);
	font-size: clamp(1.15rem, 1.55vw, 1.35rem);
	font-weight: 500;
	margin: 0;
	color: var(--ink);
	letter-spacing: -0.005em;
	line-height: 1.25;
}
.kbc-process__text {
	color: var(--muted);
	font-size: 0.92rem;
	margin: 0;
	line-height: 1.6;
}

/* Nav — chevron buttons sitting on the rail at left/right ends */
.kbc-process__nav {
	align-self: start;
	/* label height (0.85rem * 1.2) + label margin-bottom (0.65rem) → puts button top
	   at the start of the rail-row, vertically centering it on the line */
	margin-top: calc(0.85rem * 1.2 + 0.65rem);
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--ivory);
	border: 1px solid var(--line);
	color: var(--ink);
	display: grid;
	place-items: center;
	cursor: pointer;
	box-shadow: var(--shadow-sm);
	transition: background 0.3s, color 0.3s, border-color 0.3s, transform 0.4s var(--ease-fluid), opacity 0.3s;
	position: relative;
	z-index: 2;
}
.kbc-process__nav:hover:not(:disabled) {
	background: var(--clay);
	border-color: var(--clay);
	color: var(--ivory);
	transform: scale(1.05);
}
.kbc-process__nav:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}
.kbc-process__nav--prev { margin-right: -20px; }
.kbc-process__nav--next { margin-left: -20px; }

.kbc-process__empty {
	grid-column: 1 / -1;
	text-align: center;
	padding: 3rem;
	color: var(--muted);
}

/* ------- Why KB ------- */
.kbc-why__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 6vw, 5.5rem);
	align-items: center;
}
.kbc-why__visual {
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 3 / 4;
	background: var(--sand);
	position: relative;
}
.kbc-why__visual img { width: 100%; height: 100%; object-fit: cover; }
.kbc-why__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--sand) 0%, var(--sage) 160%); }

.kbc-why__points { list-style: none; padding: 0; margin: 2rem 0 0; }
.kbc-why__points li { padding: 1.5rem 0; border-top: 1px solid var(--line); }
.kbc-why__points li:last-child { border-bottom: 1px solid var(--line); }
.kbc-why__points h3 { font-size: 1.25rem; font-weight: 500; margin: 0 0 0.35rem; }
.kbc-why__points p  { color: var(--muted); margin: 0; font-size: 0.95rem; }

/* ------- Testimonials ------- */
.kbc-testimonials { background: var(--cream); }
.kbc-testimonials__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.5rem, 3vw, 2.2rem);
}
.kbc-testimonial {
	background: var(--ivory);
	padding: 2.25rem 2rem;
	border-radius: var(--radius);
	margin: 0;
	border: 1px solid var(--line-soft);
	display: flex; flex-direction: column; gap: 1rem;
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
}
.kbc-testimonial:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.kbc-testimonial__mark { color: var(--clay); }
.kbc-testimonial__quote {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	line-height: 1.5;
	font-weight: 400;
	margin: 0;
	color: var(--ink);
}
.kbc-testimonial__cite { display: flex; flex-direction: column; font-style: normal; padding-top: 0.5rem; border-top: 1px solid var(--line-soft); }
.kbc-testimonial__cite strong { font-weight: 500; font-size: 0.95rem; color: var(--ink); }
.kbc-testimonial__cite span { font-size: 0.82rem; color: var(--muted); margin-top: 0.1rem; }

/* ------- Closing CTA ------- */
.kbc-footer-cta {
	background: var(--brand-dark);
	color: var(--ivory);
	padding: clamp(4.5rem, 10vw, 8rem) 0;
	position: relative;
	overflow: hidden;
}
.kbc-footer-cta::before {
	content: '';
	position: absolute;
	inset: -40%;
	background: radial-gradient(circle at 30% 30%, rgba(184,115,74,0.14), transparent 40%);
	pointer-events: none;
}
.kbc-footer-cta__inner { text-align: center; max-width: 820px; margin: 0 auto; position: relative; }
.kbc-footer-cta__inner .kbc-eyebrow { color: rgba(251,248,242,0.7); justify-self: center; display: inline-block; }
.kbc-footer-cta__title {
	font-family: var(--font-serif);
	font-size: clamp(2.2rem, 5vw, 4rem);
	color: var(--ivory);
	margin: 0 0 1rem;
	line-height: 1.08;
}
.kbc-footer-cta__body { color: rgba(251,248,242,0.75); font-size: 1.1rem; margin-bottom: 2rem; }
.kbc-footer-cta__inner .kbc-btn--primary { background: var(--ivory); color: var(--ink); }
.kbc-footer-cta__inner .kbc-btn--primary:hover { background: var(--clay); color: var(--ivory); }

/* ------- Footer ------- */
.site-footer {
	background: var(--cream);
	color: var(--charcoal);
	padding: clamp(4rem, 7vw, 6rem) 0 2rem;
	border-top: 1px solid var(--line-soft);
}
.site-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
	gap: clamp(2rem, 4vw, 3.5rem);
	padding-bottom: 2.5rem;
	border-bottom: 1px solid var(--line);
	align-items: start;
}
.site-footer__brand .footer-logo { margin: 0 0 1.25rem; display: inline-block; }
.site-footer__brand .footer-logo .custom-logo-link { display: inline-block; line-height: 0; }
.site-footer__brand .footer-logo .custom-logo { max-width: 140px; width: auto; height: auto; display: block; }
.site-footer__brand .footer-wordmark { display: inline-flex; align-items: center; gap: 0.6rem; margin: 0 0 1rem; }
.footer-wordmark__mark { display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: 50%; background: var(--ink); color: var(--ivory); font-family: var(--font-serif); font-size: 1rem; }
.footer-wordmark__name { font-family: var(--font-serif); font-size: 1.15rem; }
.site-footer__note {
	color: var(--muted);
	font-size: 0.95rem;
	line-height: 1.55;
	margin: 0 0 1.5rem;
	max-width: 22rem;
}
.site-footer__social { display: flex; gap: 0.55rem; }
.site-footer__social a {
	display: inline-grid;
	place-items: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	border: 1px solid var(--line);
	color: var(--charcoal);
	background: transparent;
	transition: background 0.3s, color 0.3s, border-color 0.3s, transform 0.3s;
}
.site-footer__social a:hover { background: var(--brand-dark); color: var(--ivory); border-color: var(--brand-dark); transform: translateY(-2px); }

.site-footer__col { min-width: 0; }
.site-footer__heading {
	font-family: var(--font-sans);
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--clay);
	font-weight: 600;
	margin: 0 0 1.25rem;
	position: relative;
	padding-bottom: 0.65rem;
}
.site-footer__heading::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 28px;
	height: 1px;
	background: var(--clay);
	opacity: 0.5;
}
.footer-menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.6rem; }
.footer-menu a {
	color: var(--ink);
	font-size: 0.95rem;
	transition: color 0.25s, padding-left 0.25s;
	display: inline-block;
}
.footer-menu a:hover { color: var(--clay); padding-left: 4px; }

.site-footer__contact { display: flex; flex-direction: column; gap: 0.8rem; }
.site-footer__phone {
	font-family: var(--font-serif);
	font-size: clamp(1.25rem, 2vw, 1.5rem);
	color: var(--ink);
	line-height: 1.1;
	letter-spacing: 0.01em;
	transition: color 0.25s;
}
.site-footer__phone:hover { color: var(--clay); }
.site-footer__email {
	color: var(--ink);
	font-size: 0.95rem;
	word-break: break-word;
	transition: color 0.25s;
}
.site-footer__email:hover { color: var(--clay); }
.site-footer__address,
.site-footer__hours {
	font-style: normal;
	color: var(--muted);
	font-size: 0.9rem;
	line-height: 1.55;
	margin: 0;
}
.site-footer__hours { padding-top: 0.25rem; }

.site-footer__bar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: 1.75rem;
	gap: 1rem;
	flex-wrap: wrap;
}
.site-footer__copy {
	margin: 0;
	font-size: 0.8rem;
	color: var(--muted);
	letter-spacing: 0.04em;
}
.site-footer__up {
	background: transparent;
	border: 1px solid var(--line);
	color: var(--ink);
	padding: 0.6rem 1.1rem;
	border-radius: 999px;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	font-size: 0.8rem;
	letter-spacing: 0.05em;
	transition: background 0.3s, color 0.3s, border-color 0.3s;
}
.site-footer__up:hover { background: var(--brand-dark); color: var(--ivory); border-color: var(--brand-dark); }
.site-footer__up-arrow { transition: transform 0.3s; }
.site-footer__up:hover .site-footer__up-arrow { transform: translateY(-3px); }

/* ------- Page hero ------- */
.kbc-page-hero {
	padding-top: clamp(9rem, 16vh, 12rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
	background: var(--cream);
	position: relative;
	overflow: hidden;
}
.kbc-page-hero--image { min-height: 64vh; display: grid; place-items: end start; color: var(--ivory); }
.kbc-page-hero--image .kbc-h1 { color: var(--ivory); }
.kbc-page-hero--image .kbc-eyebrow { color: var(--clay); }
.kbc-page-hero--image .kbc-lead { color: rgba(251,248,242,0.85); }
.kbc-page-hero__bg { position: absolute; inset: 0; z-index: 0; }
.kbc-page-hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.kbc-page-hero--image::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,17,13,0.15) 0%, rgba(20,17,13,0.75) 100%); z-index: 1; }
.kbc-page-hero__inner { position: relative; z-index: 2; max-width: 900px; width: 100%; padding-bottom: 2rem; }

/* ------- Content body ------- */
.kbc-page-content {
	max-width: 780px;
	margin: 0 auto;
	font-size: 1.05rem;
	line-height: 1.7;
	color: var(--charcoal);
}
.kbc-page-content h2 { font-size: 2rem; margin: 2.5rem 0 1rem; }
.kbc-page-content h3 { font-size: 1.45rem; margin: 2rem 0 0.75rem; font-weight: 500; }
.kbc-page-content a  { color: var(--clay); border-bottom: 1px solid currentColor; }
.kbc-page-content blockquote {
	border-left: 3px solid var(--clay);
	margin: 2rem 0;
	padding: 0.5rem 0 0.5rem 1.5rem;
	font-family: var(--font-serif);
	font-size: 1.35rem;
	line-height: 1.5;
	color: var(--ink);
}

/* ------- About page ------- */
.kbc-about__inner {
	display: grid;
	grid-template-columns: 0.85fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}
.kbc-about__visual { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 3 / 4; background: var(--sand); }
.kbc-about__visual img { width: 100%; height: 100%; object-fit: cover; }
.kbc-about__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--sand) 0%, var(--sand-soft) 100%); }
.kbc-about__copy { padding-top: 1rem; }

.kbc-team__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	margin-top: 3rem;
}
.kbc-team__member { margin: 0; text-align: center; }
.kbc-team__photo {
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	overflow: hidden;
	background: var(--sand);
	margin-bottom: 1rem;
	display: grid; place-items: center;
	color: var(--ink);
}
.kbc-team__initials { font-family: var(--font-serif); font-size: 2.2rem; letter-spacing: 0.05em; }
.kbc-team__photo img { width: 100%; height: 100%; object-fit: cover; }
.kbc-team__name { font-family: var(--font-serif); font-size: 1.15rem; margin: 0; color: var(--ink); }
.kbc-team__role { font-size: 0.85rem; color: var(--muted); margin: 0.2rem 0 0; }

/* ------- Features + compare (services page) ------- */
.kbc-features__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
}
.kbc-feature {
	padding: 2rem 1.75rem;
	background: var(--cream);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
}
.kbc-feature:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.kbc-feature__title { font-size: 1.25rem; font-weight: 500; margin: 0 0 0.5rem; }
.kbc-feature__body  { color: var(--muted); margin: 0; font-size: 0.95rem; }

.kbc-compare__list {
	list-style: none;
	padding: 0;
	margin: 2.5rem auto 0;
	max-width: 640px;
	display: grid;
	gap: 0.25rem;
}
.kbc-compare__list li {
	display: flex; align-items: center;
	gap: 1rem;
	padding: 1.1rem 1.5rem;
	background: var(--ivory);
	border: 1px solid var(--line-soft);
	border-radius: var(--radius);
	font-size: 1.05rem;
	color: var(--ink);
}
.kbc-compare__icon { color: var(--clay); font-family: var(--font-serif); font-size: 1.2rem; }

/* ------- Contact page ------- */
.kbc-contact__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}
.kbc-contact__aside {
	padding: 2rem;
	background: var(--cream);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	position: sticky;
	top: 120px;
}
.kbc-contact__list,
.kbc-contact__hours { list-style: none; padding: 0; margin: 0 0 1rem; }
.kbc-contact__list li {
	display: grid;
	grid-template-columns: 24px 1fr;
	gap: 0.9rem;
	padding: 0.85rem 0;
	border-bottom: 1px solid var(--line-soft);
	align-items: center;
}
.kbc-contact__list li:last-child { border-bottom: 0; }
.kbc-contact__list svg { color: var(--clay); }
.kbc-contact__label { display: block; font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
.kbc-contact__rule { border: 0; height: 1px; background: var(--line); margin: 1.5rem 0; }
.kbc-contact__hours li { display: flex; justify-content: space-between; padding: 0.5rem 0; font-size: 0.95rem; color: var(--charcoal); }

/* ------- Forms ------- */
.kbc-form { display: grid; gap: 1.25rem; }
.kbc-form__row { display: grid; gap: 0.4rem; }
.kbc-form__row--split { grid-template-columns: 1fr 1fr; gap: 1rem; }
.kbc-form__row--split .kbc-form__row { gap: 0.4rem; }
.kbc-form label { display: grid; gap: 0.35rem; font-size: 0.95rem; }
.kbc-form label > span {
	font-size: 0.76rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--muted);
}
.kbc-form input[type="text"],
.kbc-form input[type="email"],
.kbc-form input[type="tel"],
.kbc-form select,
.kbc-form textarea {
	width: 100%;
	padding: 0.9rem 1rem;
	border: 1px solid var(--line);
	background: var(--ivory);
	border-radius: var(--radius-sm);
	font-family: inherit;
	font-size: 1rem;
	color: var(--ink);
	transition: border-color 0.3s, box-shadow 0.3s;
}
.kbc-form textarea { resize: vertical; min-height: 140px; }
.kbc-form input:focus,
.kbc-form select:focus,
.kbc-form textarea:focus {
	outline: none;
	border-color: var(--clay);
	box-shadow: 0 0 0 3px rgba(184,115,74,0.12);
}
.kbc-form button { justify-self: start; }
.kbc-form__note { padding: 1rem 1.25rem; border-radius: var(--radius-sm); margin: 0; font-size: 0.95rem; }
.kbc-form__note--ok  { background: rgba(126,133,104,0.12); color: var(--olive); border: 1px solid rgba(126,133,104,0.3); }
.kbc-form__note--err { background: rgba(184,115,74,0.1); color: var(--clay-dark); border: 1px solid rgba(184,115,74,0.3); }

/* ------- Property single ------- */
.kbc-property-hero {
	padding-top: clamp(10rem, 16vh, 14rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
	background: var(--cream);
	position: relative;
	min-height: 70vh;
	display: grid; align-items: end;
	color: var(--ivory);
	overflow: hidden;
}
.kbc-property-hero__bg { position: absolute; inset: 0; z-index: 0; }
.kbc-property-hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.kbc-property-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,17,13,0.15) 0%, rgba(20,17,13,0.75) 100%); z-index: 1; }
.kbc-property-hero:not(.kbc-property-hero--image) { color: var(--ink); }
.kbc-property-hero:not(.kbc-property-hero--image)::after { display: none; }
.kbc-property-hero__inner { position: relative; z-index: 2; padding-bottom: 2rem; }
.kbc-property-hero__inner .kbc-eyebrow { color: var(--clay); }
.kbc-property-hero__inner .kbc-h1 { color: inherit; }
.kbc-property-hero__location {
	display: inline-flex; align-items: center; gap: 0.45rem;
	color: rgba(251,248,242,0.9);
	font-size: 1rem;
}
.kbc-property-hero:not(.kbc-property-hero--image) .kbc-property-hero__location { color: var(--muted); }

.kbc-property__inner {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}
.kbc-property__meta {
	padding: 2rem;
	background: var(--cream);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	position: sticky;
	top: 120px;
}
.kbc-property__specs { list-style: none; padding: 0; margin: 1rem 0 1.75rem; }
.kbc-property__specs li {
	display: flex; justify-content: space-between; align-items: baseline;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--line-soft);
	font-size: 0.95rem;
}
.kbc-property__specs li:last-child { border-bottom: 0; }
.kbc-property__specs strong { font-family: var(--font-serif); font-size: 1.15rem; font-weight: 500; color: var(--ink); }
.kbc-property__specs span { color: var(--muted); letter-spacing: 0.02em; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.14em; }
.kbc-property__contact-min { display: flex; flex-direction: column; gap: 0.55rem; margin-top: 1.5rem; padding-top: 1.25rem; border-top: 1px solid var(--line); }
.kbc-property__contact-min a { display: inline-flex; gap: 0.5rem; align-items: center; font-size: 0.92rem; color: var(--ink); }
.kbc-property__contact-min a:hover { color: var(--brand-dark); }

/* ------- Blog post grid (index) ------- */
.kbc-post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.kbc-post-card__media { display: block; overflow: hidden; border-radius: var(--radius); aspect-ratio: 4 / 3; background: var(--sand); margin-bottom: 1rem; }
.kbc-post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease-out); }
.kbc-post-card:hover .kbc-post-card__media img { transform: scale(1.04); }
.kbc-post-card__meta  { font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin: 0 0 0.5rem; }
.kbc-post-card__title { font-family: var(--font-serif); font-size: 1.4rem; margin: 0 0 0.5rem; font-weight: 500; }
.kbc-post-card__title a { color: var(--ink); }
.kbc-post-card__excerpt { color: var(--muted); font-size: 0.95rem; margin-bottom: 0.75rem; }
.kbc-post-card__more { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.85rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--clay); }

/* ------- Responsive ------- */
@media (max-width: 1024px) {
	.kbc-hero__inner { grid-template-columns: 1fr; }
	.kbc-hero__visual { min-height: auto; }
	.kbc-hero__stack { margin: 0 auto; max-width: 500px; }
	.kbc-projects__grid,
	.kbc-testimonials__grid,
	.kbc-features__grid,
	.kbc-post-grid { grid-template-columns: repeat(2, 1fr); }
	.kbc-team__grid { grid-template-columns: repeat(2, 1fr); }
	.kbc-intro__inner,
	.kbc-why__inner,
	.kbc-about__inner,
	.kbc-contact__inner,
	.kbc-property__inner { grid-template-columns: 1fr; }
	.kbc-intro__head { position: static; }
	.kbc-contact__aside,
	.kbc-property__meta { position: static; }
	.kbc-section__head { grid-template-columns: 1fr; }
	.site-footer__grid { grid-template-columns: 1fr 1fr; gap: 2.5rem 2rem; }
	.site-footer__brand { grid-column: 1 / -1; }

	/* Process carousel — show 2 slides at a time */
	.kbc-process { --kbc-process-cols: 2; }
}

@media (max-width: 768px) {
	.site-header__inner { grid-template-columns: auto 1fr auto; }
	/* Full-viewport drop-down menu — sits below the header (which is now ~96px
	   tall after the logo + min-height bumps) and fills the rest of the screen. */
	.site-nav {
		display: none;
		position: fixed;
		left: 0; right: 0;
		top: 96px; bottom: 0;
		background: var(--ivory);
		padding: 1.5rem var(--gutter) 3rem;
		flex-direction: column;
		overflow-y: auto;
		border-top: 1px solid var(--line);
		z-index: 49;
	}
	.site-header[data-menu-open="true"] .site-nav { display: flex; }
	.primary-menu {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		width: 100%;
		margin: 0;
		padding: 0;
		list-style: none;
	}
	.primary-menu li { display: block; width: 100%; }
	.primary-menu a {
		display: block;
		padding: 1rem 0;
		font-size: 1.15rem;
		width: 100%;
		border-bottom: 1px solid var(--line-soft);
		color: var(--ink);
	}
	.primary-menu .sub-menu {
		position: static;
		box-shadow: none;
		border: 0;
		padding: 0 0 0.5rem 1rem;
		opacity: 1;
		visibility: visible;
		transform: none;
		margin: 0;
		background: transparent;
		min-width: 0;
	}
	.primary-menu .sub-menu a { font-size: 1rem; padding: 0.6rem 0; border-bottom: 0; }
	.site-header__cta { display: none; }
	.nav-toggle { display: inline-flex; }

	.kbc-hero__meta { grid-template-columns: 1fr; gap: 1rem; }
	.kbc-hero__badge { display: none; }

	/* Full-bg hero on mobile — stats stack into one centred column. */
	.kbc-hero--full-bg .kbc-hero__meta {
		grid-template-columns: 1fr;
		gap: 1.4rem;
		max-width: 28rem;
	}
	.kbc-hero--full-bg .kbc-hero__title { font-size: clamp(2.4rem, 9vw, 3.6rem); }
	.kbc-hero--full-bg .kbc-hero__lead  { font-size: 1.1rem; }

	/* Build-stats band on mobile — stack into a single centred column.
	   Allow the title to wrap on narrow viewports where nowrap would
	   overflow. */
	.kbc-build-stats__grid { grid-template-columns: 1fr; gap: 1.5rem; max-width: 28rem; }
	.kbc-build-stats .kbc-h2 { white-space: normal; font-size: clamp(1.7rem, 7vw, 2.4rem); }
	.kbc-projects__grid,
	.kbc-testimonials__grid,
	.kbc-features__grid,
	.kbc-post-grid,
	.kbc-team__grid { grid-template-columns: 1fr; }
	.kbc-form__row--split { grid-template-columns: 1fr; }
	.site-footer__grid { grid-template-columns: 1fr; }
	.site-footer__bar { justify-content: flex-start; flex-direction: column; align-items: flex-start; }

	/* Process carousel — single slide at a time */
	.kbc-process { --kbc-process-cols: 1; }
	.kbc-process__nav--prev { margin-right: -16px; }
	.kbc-process__nav--next { margin-left: -16px; }
}

/* ==========================================================================
   Philosophy page (template-philosophy.php) — bespoke editorial layout
   ========================================================================== */

.kbc-philo-hero {
	padding-top: clamp(8rem, 14vh, 10rem);
	padding-bottom: clamp(3rem, 5vw, 5rem);
	background:
		radial-gradient(ellipse at 20% 20%, rgba(126,133,104,0.10), transparent 55%),
		linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
	position: relative;
	overflow: hidden;
}
.kbc-philo-hero__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-philo-hero__copy { max-width: 34rem; }
.kbc-philo-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.4rem, 5.4vw, 4.5rem);
	line-height: 1.05;
	font-weight: 400;
	margin: 0 0 1.2rem;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-philo-hero__lead {
	font-size: clamp(1.05rem, 1.4vw, 1.2rem);
	color: var(--muted);
	line-height: 1.6;
	margin: 0 0 2rem;
	max-width: 32rem;
}
.kbc-philo-hero__kpis {
	display: grid;
	grid-template-columns: repeat(3, auto);
	gap: clamp(1rem, 3vw, 2.4rem);
	padding-top: 1.5rem;
	border-top: 1px solid var(--line);
}
.kbc-philo-hero__kpis > div { display: flex; flex-direction: column; gap: 0.3rem; }
.kbc-philo-hero__kpis strong {
	font-family: var(--font-serif);
	font-size: 2rem;
	font-weight: 400;
	color: var(--ink);
	letter-spacing: -0.01em;
	line-height: 1;
}
.kbc-philo-hero__kpis span {
	font-size: 0.78rem;
	color: var(--muted);
	letter-spacing: 0.04em;
	line-height: 1.35;
}

.kbc-philo-hero__visual {
	position: relative;
	aspect-ratio: 4 / 5;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--sand);
	box-shadow: var(--shadow-lg);
}
.kbc-philo-hero__visual img { width: 100%; height: 100%; object-fit: cover; }

.kbc-philo-hero__badge {
	position: absolute;
	right: 1.5rem; bottom: 1.5rem;
	width: 140px; height: 140px;
	border-radius: 50%;
	background: var(--ivory);
	color: var(--ink);
	display: grid; place-items: center;
	text-align: center;
	box-shadow: var(--shadow);
	transform: rotate(-6deg);
	padding: 0.5rem;
}
.kbc-philo-hero__badge-top,
.kbc-philo-hero__badge-bottom {
	font-size: 0.64rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--muted);
	display: block;
}
.kbc-philo-hero__badge-main {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 1.6rem;
	line-height: 1;
	color: var(--clay);
	margin: 0.25rem 0;
	display: block;
}

/* ---- Intro split ---- */
.kbc-philo-intro {
	padding: clamp(3rem, 7vw, 5.5rem) 0;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
	border-bottom: 1px solid var(--line-soft);
}
.kbc-philo-intro__inner {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: clamp(2rem, 6vw, 5rem);
	align-items: start;
}
.kbc-philo-intro__label { position: sticky; top: 120px; }
.kbc-philo-intro__label h2 em { font-style: italic; color: var(--clay); }
.kbc-philo-intro__body p { margin: 0 0 1.1rem; }
.kbc-philo-intro__body p:last-child { margin: 0; }

/* ---- Pillars (Commitment + Innovating) ---- */
.kbc-philo-pillars {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
}
.kbc-philo-pillars--commit { background: var(--cream); }
.kbc-philo-pillars--innov  { background: var(--ivory); }

.kbc-philo-pillars__head {
	max-width: 680px;
	margin: 0 auto 3rem 0;
	display: flex; flex-direction: column; gap: 0.75rem;
}
.kbc-philo-pillars__head--center {
	margin: 0 auto 3rem;
	text-align: center;
	align-items: center;
}
.kbc-philo-pillars__head--center .kbc-eyebrow::before { display: none; }
.kbc-philo-pillars__head p { margin: 0; }

.kbc-philo-pillars__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
}
.kbc-philo-pillars__grid--bordered { gap: 0; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.kbc-philo-pillars__grid--bordered .kbc-pillar {
	border-right: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	background: transparent;
	border-radius: 0;
}

.kbc-pillar {
	background: var(--ivory);
	padding: 2rem 1.75rem;
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	display: flex; flex-direction: column; gap: 0.9rem;
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out), border-color 0.5s;
	position: relative;
}
.kbc-pillar:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--line); }
.kbc-pillar--minimal { background: transparent; border: 0; padding: 2rem 0; }
.kbc-pillar--minimal:hover { transform: none; box-shadow: none; }

.kbc-pillar__num {
	font-family: var(--font-serif);
	font-size: 2.8rem;
	line-height: 1;
	color: var(--clay);
	letter-spacing: -0.01em;
	margin-bottom: 0.25rem;
}
.kbc-pillar__title {
	font-size: 1.35rem;
	font-weight: 500;
	margin: 0;
	color: var(--ink);
	font-family: var(--font-serif);
	letter-spacing: -0.005em;
}
.kbc-pillar__body { color: var(--muted); margin: 0; font-size: 0.98rem; line-height: 1.65; }
.kbc-pillar__tags {
	list-style: none;
	padding: 0;
	margin: 0.25rem 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}
.kbc-pillar__tags li {
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 0.3rem 0.6rem;
	background: var(--sand-soft);
	border-radius: 999px;
	color: var(--charcoal);
}
.kbc-philo-pillars--innov .kbc-pillar__title { font-size: 1.5rem; }

/* ---- Image breaker ---- */
.kbc-philo-breaker {
	position: relative;
	min-height: 48vh;
	padding: clamp(4rem, 10vw, 7rem) 0;
	background-size: cover;
	background-position: center;
	color: var(--ivory);
	display: grid;
	align-items: center;
	overflow: hidden;
}
.kbc-philo-breaker::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(20,17,13,0.55) 0%, rgba(20,17,13,0.25) 60%, rgba(94,100,73,0.35) 100%);
}
.kbc-philo-breaker__inner {
	position: relative;
	max-width: 820px;
}
.kbc-philo-breaker__inner .kbc-eyebrow { color: rgba(255,255,255,0.85); }
.kbc-philo-breaker__inner .kbc-eyebrow::before { background: rgba(255,255,255,0.7); }
.kbc-philo-breaker__title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	line-height: 1.08;
	font-weight: 400;
	margin: 0.5rem 0 0;
	color: var(--ivory);
}

/* ---- Building with Purpose ---- */
.kbc-philo-purpose {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-philo-purpose__head { max-width: 780px; margin: 0 auto 2.5rem; text-align: center; }
.kbc-philo-purpose__head .kbc-eyebrow { display: inline-block; }
.kbc-philo-purpose__head .kbc-eyebrow::before { display: none; }
.kbc-philo-purpose__head h2 { margin: 0; }

.kbc-philo-purpose__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
}
.kbc-purpose-card {
	background: var(--ivory);
	padding: clamp(2rem, 3vw, 2.75rem);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
}
.kbc-purpose-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.kbc-purpose-card__tag {
	display: inline-block;
	font-family: var(--font-serif);
	font-size: 1.1rem;
	font-style: italic;
	color: var(--clay);
	margin-bottom: 1rem;
	letter-spacing: 0.01em;
}
.kbc-purpose-card p { margin: 0; color: var(--charcoal); font-size: 1rem; line-height: 1.7; }

/* ---- Closing quote ---- */
.kbc-philo-quote {
	padding: clamp(4rem, 8vw, 7rem) 0;
	background: var(--ink);
	color: var(--ivory);
	position: relative;
	overflow: hidden;
}
.kbc-philo-quote::before {
	content: '';
	position: absolute;
	inset: -40%;
	background: radial-gradient(circle at 20% 30%, rgba(184,115,74,0.2), transparent 40%);
	pointer-events: none;
}
.kbc-philo-quote__inner {
	position: relative;
	max-width: 860px;
	margin: 0 auto;
	text-align: center;
	display: flex; flex-direction: column; align-items: center; gap: 1.25rem;
}
.kbc-philo-quote svg { color: var(--clay); opacity: 0.7; }
.kbc-philo-quote__text {
	font-family: var(--font-serif);
	font-size: clamp(1.5rem, 3vw, 2.35rem);
	line-height: 1.3;
	font-weight: 400;
	font-style: italic;
	color: var(--ivory);
	margin: 0;
	letter-spacing: -0.005em;
}
.kbc-philo-quote__attr {
	font-size: 0.78rem;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.7);
	margin: 0.5rem 0 0;
}

/* ---- Philosophy responsive ---- */
@media (max-width: 1024px) {
	.kbc-philo-hero__inner,
	.kbc-philo-intro__inner,
	.kbc-philo-pillars__grid,
	.kbc-philo-purpose__grid { grid-template-columns: 1fr; }
	.kbc-philo-intro__label { position: static; }
	.kbc-philo-pillars__grid { gap: 1.2rem; }
	.kbc-philo-pillars__grid--bordered { border: 0; }
	.kbc-philo-pillars__grid--bordered .kbc-pillar { border: 1px solid var(--line-soft); border-radius: var(--radius); background: var(--cream); }
}
@media (max-width: 768px) {
	.kbc-philo-hero__kpis { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
	.kbc-philo-hero__kpis strong { font-size: 1.6rem; }
	.kbc-philo-hero__badge { width: 100px; height: 100px; right: 1rem; bottom: 1rem; }
	.kbc-philo-hero__badge-main { font-size: 1.2rem; }
	.kbc-pillar { padding: 1.5rem 1.25rem; }
}

/* ==========================================================================
   Why Choose Us page (template-why.php)
   ========================================================================== */

.kbc-why-hero {
	padding-top: clamp(8rem, 14vh, 10rem);
	padding-bottom: clamp(3rem, 5vw, 5rem);
	background:
		radial-gradient(ellipse at 80% 20%, rgba(184,115,74,0.10), transparent 55%),
		linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
	position: relative;
	overflow: hidden;
}
.kbc-why-hero__inner {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-why-hero__copy { max-width: 36rem; }
.kbc-why-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.5rem, 5.8vw, 4.75rem);
	line-height: 1.04;
	font-weight: 400;
	margin: 0 0 1.2rem;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-why-hero__lead {
	font-size: clamp(1.05rem, 1.4vw, 1.2rem);
	color: var(--muted);
	line-height: 1.6;
	margin: 0 0 2rem;
	max-width: 34rem;
}
.kbc-why-hero__actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-bottom: 2.5rem;
}
.kbc-why-hero__trust {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1rem, 2.5vw, 2rem);
	padding-top: 1.75rem;
	border-top: 1px solid var(--line);
}
.kbc-why-hero__trust > div { display: flex; flex-direction: column; gap: 0.35rem; }
.kbc-why-hero__trust strong {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 1.4rem;
	font-weight: 500;
	color: var(--clay);
	letter-spacing: -0.005em;
	line-height: 1;
}
.kbc-why-hero__trust span {
	font-size: 0.82rem;
	color: var(--muted);
	line-height: 1.4;
}

.kbc-why-hero__visual {
	position: relative;
	aspect-ratio: 4 / 5;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--sand);
	box-shadow: var(--shadow-lg);
}
.kbc-why-hero__visual img { width: 100%; height: 100%; object-fit: cover; }

.kbc-why-hero__chip {
	position: absolute;
	left: 1.5rem; top: 1.5rem;
	width: 110px; height: 110px;
	border-radius: 50%;
	background: var(--ink);
	color: var(--ivory);
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	text-align: center;
	box-shadow: var(--shadow);
	gap: 0.1rem;
}
.kbc-why-hero__chip-num {
	font-family: var(--font-serif);
	font-size: 2.6rem;
	line-height: 1;
	color: var(--clay);
	letter-spacing: -0.02em;
	font-weight: 500;
}
.kbc-why-hero__chip-label {
	font-size: 0.62rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.85);
	line-height: 1.3;
}

/* ---- Intro ---- */
.kbc-why-intro {
	padding: clamp(3rem, 7vw, 5.5rem) 0;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
	border-bottom: 1px solid var(--line-soft);
}
.kbc-why-intro__inner {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: clamp(2rem, 6vw, 5rem);
	align-items: start;
}
.kbc-why-intro__label { position: sticky; top: 120px; }
.kbc-why-intro__label h2 em { font-style: italic; color: var(--clay); }
.kbc-why-intro__body p { margin: 0 0 1.1rem; }
.kbc-why-intro__body p:last-child { margin: 0; }

/* ---- Nine reasons grid ---- */
.kbc-why-reasons {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-why-reasons__head {
	max-width: 680px;
	margin: 0 auto 3rem 0;
}
.kbc-why-reasons__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
	list-style: none;
	padding: 0;
	margin: 0;
}
.kbc-why-reason {
	background: var(--ivory);
	padding: clamp(1.75rem, 2.8vw, 2.25rem);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	display: flex; flex-direction: column; gap: 0.75rem;
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out), border-color 0.5s;
	position: relative;
}
.kbc-why-reason:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow);
	border-color: var(--line);
}
.kbc-why-reason__num {
	font-family: var(--font-serif);
	font-size: 2.75rem;
	line-height: 1;
	color: var(--clay);
	letter-spacing: -0.01em;
	margin-bottom: 0.35rem;
	font-weight: 400;
}
.kbc-why-reason__title {
	font-family: var(--font-serif);
	font-size: 1.4rem;
	font-weight: 500;
	margin: 0;
	color: var(--ink);
	letter-spacing: -0.005em;
	line-height: 1.2;
}
.kbc-why-reason__body {
	color: var(--muted);
	margin: 0;
	font-size: 0.96rem;
	line-height: 1.65;
}

/* ---- Image breaker ---- */
.kbc-why-breaker {
	position: relative;
	min-height: 52vh;
	padding: clamp(4rem, 10vw, 7rem) 0;
	background-size: cover;
	background-position: center;
	color: var(--ivory);
	display: grid;
	align-items: center;
	overflow: hidden;
}
.kbc-why-breaker::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(20,17,13,0.72) 0%, rgba(20,17,13,0.35) 60%, rgba(184,115,74,0.3) 100%);
}
.kbc-why-breaker__inner {
	position: relative;
	max-width: 880px;
}
.kbc-why-breaker__inner .kbc-eyebrow { color: rgba(255,255,255,0.88); }
.kbc-why-breaker__inner .kbc-eyebrow::before { background: rgba(255,255,255,0.7); }
.kbc-why-breaker__title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	line-height: 1.08;
	font-weight: 400;
	margin: 0.5rem 0 1rem;
	color: var(--ivory);
	letter-spacing: -0.005em;
}
.kbc-why-breaker__sub {
	font-size: clamp(1rem, 1.4vw, 1.15rem);
	color: rgba(251,248,242,0.85);
	margin: 0;
	max-width: 42rem;
}

/* ---- Closing CTA split ---- */
.kbc-why-closing {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
}
.kbc-why-closing__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
}
.kbc-why-closing__copy h2 { margin-bottom: 1rem; }
.kbc-why-closing__copy .kbc-lead { margin-bottom: 2rem; }

.kbc-why-closing__aside {
	background: var(--cream);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	text-align: center;
	box-shadow: var(--shadow-sm);
}
.kbc-why-closing__aside-label {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0 0 0.75rem;
}
.kbc-why-closing__phone {
	display: block;
	font-family: var(--font-serif);
	font-size: clamp(1.65rem, 2.8vw, 2.2rem);
	color: var(--ink);
	margin: 0 0 0.5rem;
	letter-spacing: -0.01em;
	font-weight: 500;
	text-decoration: none;
}
.kbc-why-closing__phone:hover { color: var(--clay); }
.kbc-why-closing__email {
	display: inline-block;
	font-size: 0.95rem;
	color: var(--charcoal);
	border-bottom: 1px solid var(--line);
	padding-bottom: 2px;
	margin-bottom: 1rem;
}
.kbc-why-closing__email:hover { color: var(--clay); border-bottom-color: var(--clay); }
.kbc-why-closing__note {
	font-size: 0.82rem;
	color: var(--muted);
	margin: 0;
	font-style: italic;
}

/* ---- Why responsive ---- */
@media (max-width: 1024px) {
	.kbc-why-hero__inner,
	.kbc-why-intro__inner,
	.kbc-why-closing__inner { grid-template-columns: 1fr; }
	.kbc-why-intro__label { position: static; }
	.kbc-why-reasons__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
	.kbc-why-hero__trust { grid-template-columns: 1fr 1fr; }
	.kbc-why-hero__chip { width: 84px; height: 84px; left: 1rem; top: 1rem; }
	.kbc-why-hero__chip-num { font-size: 1.8rem; }
	.kbc-why-reasons__grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Lots + Land page (template-lots-land.php)
   ========================================================================== */

.kbc-lots-hero {
	padding-top: clamp(8rem, 14vh, 10rem);
	padding-bottom: clamp(3rem, 5vw, 5rem);
	background:
		radial-gradient(ellipse at 15% 25%, rgba(126,133,104,0.10), transparent 55%),
		linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
	position: relative;
	overflow: hidden;
}
.kbc-lots-hero__inner {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-lots-hero__copy { max-width: 36rem; }
.kbc-lots-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.4rem, 5.4vw, 4.5rem);
	line-height: 1.05;
	font-weight: 400;
	margin: 0 0 1.2rem;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-lots-hero__lead {
	font-size: clamp(1.05rem, 1.4vw, 1.2rem);
	color: var(--muted);
	line-height: 1.6;
	margin: 0 0 2rem;
	max-width: 34rem;
}
.kbc-lots-hero__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 2.5rem; }

.kbc-lots-hero__stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1rem, 2.5vw, 2rem);
	padding-top: 1.75rem;
	border-top: 1px solid var(--line);
}
.kbc-lots-hero__stats > div { display: flex; flex-direction: column; gap: 0.35rem; }
.kbc-lots-hero__stats strong {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 1.4rem;
	font-weight: 500;
	color: var(--sage);
	letter-spacing: -0.005em;
	line-height: 1;
}
.kbc-lots-hero__stats span { font-size: 0.82rem; color: var(--muted); line-height: 1.4; }

.kbc-lots-hero__visual {
	position: relative;
	aspect-ratio: 4 / 5;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--sand);
	box-shadow: var(--shadow-lg);
}
.kbc-lots-hero__visual img { width: 100%; height: 100%; object-fit: cover; }

.kbc-lots-hero__stamp {
	position: absolute;
	right: 1.5rem; bottom: 1.5rem;
	width: 135px; height: 135px;
	border-radius: 50%;
	background: var(--ivory);
	color: var(--ink);
	display: grid; place-items: center;
	text-align: center;
	box-shadow: var(--shadow);
	transform: rotate(6deg);
	padding: 0.5rem;
}
.kbc-lots-hero__stamp-top,
.kbc-lots-hero__stamp-bottom {
	font-size: 0.64rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--muted);
	display: block;
}
.kbc-lots-hero__stamp-main {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 1.5rem;
	line-height: 1;
	color: var(--sage);
	margin: 0.25rem 0;
	display: block;
}

/* ---- Three pathways ---- */
.kbc-lots-paths {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
}
.kbc-lots-paths__head {
	max-width: 720px;
	margin: 0 auto 3rem 0;
}
.kbc-lots-paths__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
}
.kbc-lots-path {
	background: var(--cream);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out), border-color 0.5s;
}
.kbc-lots-path:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--line); }
.kbc-lots-path--feature {
	background: var(--ink);
	color: var(--ivory);
	border-color: transparent;
	position: relative;
}
.kbc-lots-path--feature::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 100% 0%, rgba(184,115,74,0.18), transparent 45%);
	border-radius: inherit;
	pointer-events: none;
}
.kbc-lots-path__tag {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--clay);
	margin-bottom: 0.25rem;
}
.kbc-lots-path--feature .kbc-lots-path__tag { color: rgba(251,248,242,0.7); }
.kbc-lots-path__title {
	font-family: var(--font-serif);
	font-size: 1.8rem;
	font-weight: 500;
	margin: 0;
	letter-spacing: -0.01em;
	line-height: 1.15;
	color: var(--ink);
}
.kbc-lots-path--feature .kbc-lots-path__title { color: var(--ivory); }
.kbc-lots-path__body { margin: 0; color: var(--muted); font-size: 0.98rem; line-height: 1.65; flex: 1; }
.kbc-lots-path--feature .kbc-lots-path__body { color: rgba(251,248,242,0.78); }
.kbc-lots-path__link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.85rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--clay);
	font-weight: 500;
	margin-top: 0.5rem;
	border-bottom: 1px solid transparent;
	width: fit-content;
	padding-bottom: 3px;
	transition: border-color 0.3s, gap 0.3s;
}
.kbc-lots-path__link:hover { border-bottom-color: currentColor; gap: 0.7rem; }
.kbc-lots-path--feature .kbc-lots-path__link { color: var(--ivory); }

/* ---- Purchase criteria ---- */
.kbc-lots-criteria {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-lots-criteria__head { max-width: 820px; margin: 0 auto 3rem 0; }
.kbc-lots-criteria__head .kbc-lead { margin-top: 0.75rem; }
.kbc-lots-criteria__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
	list-style: none;
	padding: 0;
	margin: 0;
}
.kbc-lots-criterion {
	background: var(--ivory);
	padding: clamp(1.75rem, 2.8vw, 2.25rem);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out), border-color 0.5s;
}
.kbc-lots-criterion:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--line); }
.kbc-lots-criterion__num {
	font-family: var(--font-serif);
	font-size: 2.5rem;
	line-height: 1;
	color: var(--sage);
	letter-spacing: -0.01em;
}
.kbc-lots-criterion__title {
	font-family: var(--font-serif);
	font-size: 1.3rem;
	font-weight: 500;
	margin: 0;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-lots-criterion__body { color: var(--muted); margin: 0; font-size: 0.95rem; line-height: 1.65; }

/* last two items span wider on 3-col grid so they don't look orphaned */
.kbc-lots-criterion:nth-child(4) { grid-column: span 1; }
.kbc-lots-criterion:nth-child(5) { grid-column: span 2; }

/* ---- Image breaker ---- */
.kbc-lots-breaker {
	position: relative;
	min-height: 48vh;
	padding: clamp(4rem, 10vw, 7rem) 0;
	background-size: cover;
	background-position: center;
	color: var(--ivory);
	display: grid;
	align-items: center;
	overflow: hidden;
}
.kbc-lots-breaker::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(20,17,13,0.72) 0%, rgba(20,17,13,0.35) 60%, rgba(126,133,104,0.3) 100%);
}
.kbc-lots-breaker__inner { position: relative; max-width: 880px; }
.kbc-lots-breaker__inner .kbc-eyebrow { color: rgba(255,255,255,0.88); }
.kbc-lots-breaker__inner .kbc-eyebrow::before { background: rgba(255,255,255,0.7); }
.kbc-lots-breaker__title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	line-height: 1.08;
	font-weight: 400;
	margin: 0.5rem 0 1rem;
	color: var(--ivory);
	letter-spacing: -0.005em;
}
.kbc-lots-breaker__sub {
	font-size: clamp(1rem, 1.4vw, 1.15rem);
	color: rgba(251,248,242,0.85);
	margin: 0;
	max-width: 42rem;
}

/* ---- Your Design × Our Skill ---- */
.kbc-lots-duo {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
}
.kbc-lots-duo__inner {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-lots-duo__copy h2 { margin-bottom: 2rem; }
.kbc-lots-duo__pair {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.75rem;
}
.kbc-lots-duo__pair h3 {
	font-size: 1.15rem;
	font-weight: 500;
	font-family: var(--font-serif);
	margin: 0 0 0.6rem;
	padding-bottom: 0.6rem;
	border-bottom: 1px solid var(--line);
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-lots-duo__pair p { color: var(--muted); margin: 0; font-size: 0.95rem; line-height: 1.7; }

.kbc-lots-duo__visual {
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 3 / 4;
	background: var(--sand);
	box-shadow: var(--shadow);
}
.kbc-lots-duo__visual img { width: 100%; height: 100%; object-fit: cover; }

/* ---- Sell direct benefits ---- */
.kbc-lots-benefits {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-lots-benefits__inner {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: stretch;
}
.kbc-lots-benefits__copy h2 { margin-bottom: 1rem; }
.kbc-lots-benefits__copy .kbc-lead { margin-bottom: 2rem; }
.kbc-lots-benefits__list {
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	display: grid;
	gap: 0;
}
.kbc-lots-benefits__list li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.1rem;
	padding: 1.2rem 0;
	border-bottom: 1px solid var(--line);
}
.kbc-lots-benefits__list li:last-child { border-bottom: 0; }
.kbc-lots-benefits__icon {
	font-family: var(--font-serif);
	font-size: 1.6rem;
	color: var(--clay);
	line-height: 1;
	padding-top: 0.1rem;
}
.kbc-lots-benefits__list strong {
	display: block;
	font-size: 1.05rem;
	font-weight: 500;
	margin-bottom: 0.25rem;
	color: var(--ink);
	font-family: var(--font-serif);
	font-style: italic;
}
.kbc-lots-benefits__list p { margin: 0; color: var(--muted); font-size: 0.92rem; line-height: 1.6; }

.kbc-lots-benefits__aside {
	position: relative;
	background-size: cover;
	background-position: center;
	border-radius: var(--radius-lg);
	overflow: hidden;
	min-height: 380px;
	display: grid;
	align-items: end;
	box-shadow: var(--shadow);
}
.kbc-lots-benefits__aside::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(20,17,13,0.05) 0%, rgba(20,17,13,0.75) 100%);
}
.kbc-lots-benefits__aside-inner {
	position: relative;
	padding: clamp(1.5rem, 3vw, 2.25rem);
	color: var(--ivory);
}
.kbc-lots-benefits__quote {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: clamp(1.15rem, 1.8vw, 1.4rem);
	line-height: 1.4;
	margin: 0 0 0.75rem;
	color: var(--ivory);
}
.kbc-lots-benefits__attr {
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.8);
	margin: 0;
}

/* ---- Lots responsive ---- */
@media (max-width: 1024px) {
	.kbc-lots-hero__inner,
	.kbc-lots-duo__inner,
	.kbc-lots-benefits__inner { grid-template-columns: 1fr; }
	.kbc-lots-paths__grid,
	.kbc-lots-criteria__grid { grid-template-columns: repeat(2, 1fr); }
	.kbc-lots-criterion:nth-child(5) { grid-column: span 1; }
	.kbc-lots-duo__pair { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
	.kbc-lots-hero__stats { grid-template-columns: 1fr 1fr; }
	.kbc-lots-hero__stamp { width: 100px; height: 100px; right: 1rem; bottom: 1rem; }
	.kbc-lots-hero__stamp-main { font-size: 1.2rem; }
	.kbc-lots-paths__grid,
	.kbc-lots-criteria__grid,
	.kbc-lots-duo__pair { grid-template-columns: 1fr; }
	.kbc-lots-criterion:nth-child(5) { grid-column: span 1; }
}

/* ==========================================================================
   Available Listings page (template-available.php)
   ========================================================================== */

.kbc-avail-hero {
	padding-top: clamp(9rem, 15vh, 11rem);
	padding-bottom: clamp(3rem, 5vw, 4.5rem);
	background:
		radial-gradient(ellipse at 80% 20%, rgba(184,115,74,0.10), transparent 55%),
		linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
	position: relative;
	overflow: hidden;
}
.kbc-avail-hero__inner {
	display: grid;
	grid-template-columns: 1fr 1.05fr;
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
}
.kbc-avail-hero__copy { max-width: 44rem; align-self: center; }

.kbc-avail-hero__visual {
	position: relative;
	margin: 0;
	aspect-ratio: 5 / 4;
	border-radius: calc(var(--radius) * 1.2);
	overflow: hidden;
	box-shadow: 0 30px 80px -30px rgba(42,37,32,0.35), 0 8px 24px -10px rgba(42,37,32,0.2);
	transform: translateZ(0);
}
.kbc-avail-hero__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 12s var(--ease-out);
}
.kbc-avail-hero__visual:hover .kbc-avail-hero__image { transform: scale(1.05); }
.kbc-avail-hero__visual::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 40%, rgba(42,37,32,0.55) 100%);
	pointer-events: none;
}

.kbc-avail-hero__caption {
	position: absolute;
	left: clamp(1rem, 2.5vw, 1.75rem);
	bottom: clamp(1rem, 2.5vw, 1.75rem);
	right: clamp(1rem, 2.5vw, 1.75rem);
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	color: var(--ivory);
	z-index: 2;
	margin: 0;
	max-width: 60%;
}
.kbc-avail-hero__caption-label {
	font-size: 0.68rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.75);
	font-weight: 500;
}
.kbc-avail-hero__caption-title {
	font-family: var(--font-serif);
	font-size: clamp(1.2rem, 1.8vw, 1.6rem);
	font-weight: 500;
	line-height: 1.15;
	letter-spacing: -0.005em;
}
.kbc-avail-hero__caption-meta {
	font-size: 0.82rem;
	color: rgba(251,248,242,0.8);
	letter-spacing: 0.02em;
}
.kbc-avail-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.5rem, 5.8vw, 4.75rem);
	line-height: 1.04;
	font-weight: 400;
	margin: 0 0 1rem;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-avail-hero__lead {
	font-size: clamp(1.05rem, 1.4vw, 1.2rem);
	color: var(--muted);
	line-height: 1.6;
	margin: 0 0 2rem;
	max-width: 34rem;
}
.kbc-avail-hero__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }

.kbc-avail-hero__counter {
	position: absolute;
	top: clamp(1rem, 2vw, 1.5rem);
	right: clamp(1rem, 2vw, 1.5rem);
	display: inline-flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.35rem;
	padding: 1.1rem 1.35rem;
	background: var(--ink);
	color: var(--ivory);
	border-radius: var(--radius);
	box-shadow: 0 18px 40px -15px rgba(42,37,32,0.5);
	z-index: 3;
}
.kbc-avail-hero__counter--solo {
	position: static;
	min-width: 180px;
	padding: 1.5rem 1.75rem;
	box-shadow: var(--shadow);
	justify-self: end;
	align-self: end;
}
.kbc-avail-hero__counter-num {
	font-family: var(--font-serif);
	font-size: clamp(2.2rem, 3.5vw, 3rem);
	line-height: 0.95;
	font-weight: 500;
	color: var(--clay);
	letter-spacing: -0.02em;
}
.kbc-avail-hero__counter--solo .kbc-avail-hero__counter-num {
	font-size: clamp(3rem, 5vw, 4.25rem);
}
.kbc-avail-hero__counter-label {
	font-size: 0.78rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.8);
	line-height: 1.4;
}
.kbc-avail-hero__counter-dot {
	position: absolute;
	top: 1rem; right: 1rem;
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--clay);
	box-shadow: 0 0 0 0 rgba(184,115,74,0.7);
	animation: kbcPulse 2s var(--ease-out) infinite;
}
@keyframes kbcPulse {
	0%   { box-shadow: 0 0 0 0 rgba(184,115,74,0.7); }
	70%  { box-shadow: 0 0 0 14px rgba(184,115,74,0); }
	100% { box-shadow: 0 0 0 0 rgba(184,115,74,0); }
}

/* ---- Featured listing ---- */
.kbc-avail-featured {
	padding: clamp(3rem, 7vw, 5.5rem) 0;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
}
.kbc-avail-featured__inner {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-avail-featured__media {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 5;
	background: var(--sand);
	box-shadow: var(--shadow-lg);
}
.kbc-avail-featured__media img { width: 100%; height: 100%; object-fit: cover; }

.kbc-avail-featured__badge {
	position: absolute;
	top: 1.25rem; left: 1.25rem;
	background: var(--clay);
	color: var(--ivory);
	padding: 0.5rem 0.9rem;
	border-radius: 999px;
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-weight: 500;
	box-shadow: var(--shadow-sm);
}

.kbc-avail-featured__thumbs {
	position: absolute;
	left: 1.25rem;
	bottom: 1.25rem;
	right: 1.25rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.6rem;
}
.kbc-avail-featured__thumbs img {
	width: 100%;
	height: 78px;
	object-fit: cover;
	border-radius: var(--radius-sm);
	border: 2px solid var(--ivory);
	box-shadow: var(--shadow-sm);
	cursor: pointer;
	transition: transform 0.4s var(--ease-out);
}
.kbc-avail-featured__thumbs img:hover { transform: translateY(-3px) scale(1.03); }

.kbc-avail-featured__body .kbc-avail-featured__eyebrow {
	display: inline-block;
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--clay);
	margin-bottom: 0.85rem;
	padding-left: 42px;
	position: relative;
	font-weight: 500;
}
.kbc-avail-featured__body .kbc-avail-featured__eyebrow::before {
	content: '';
	position: absolute;
	left: 0; top: 50%;
	width: 28px; height: 1px;
	background: currentColor;
}
.kbc-avail-featured__title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 400;
	line-height: 1.1;
	margin: 0 0 0.75rem;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-avail-featured__location {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--muted);
	font-size: 1rem;
	margin: 0 0 1.5rem;
}
.kbc-avail-featured__desc { color: var(--charcoal); line-height: 1.7; margin: 0 0 2rem; }

.kbc-avail-featured__specs {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	border-top: 1px solid var(--line);
	border-left: 1px solid var(--line);
}
.kbc-avail-featured__specs li {
	padding: 1rem 1.1rem;
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
	border-right: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.kbc-avail-featured__specs span {
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--muted);
}
.kbc-avail-featured__specs strong {
	font-family: var(--font-serif);
	font-size: 1.35rem;
	font-weight: 500;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-avail-featured__specs-price strong { color: var(--clay); }

.kbc-avail-featured__actions {
	display: flex;
	gap: 1.2rem;
	align-items: center;
	flex-wrap: wrap;
}

/* ---- Also available grid ---- */
.kbc-avail-rest {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-avail-rest__head {
	max-width: 720px;
	margin: 0 auto 3rem 0;
}
.kbc-avail-rest__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.5rem, 3vw, 2.4rem);
}
.kbc-avail-card {
	display: flex;
	flex-direction: column;
	background: var(--ivory);
	border-radius: var(--radius);
	overflow: hidden;
	color: inherit;
	text-decoration: none;
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
	border: 1px solid var(--line-soft);
}
.kbc-avail-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.kbc-avail-card__media {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--sand);
}
.kbc-avail-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease-out); }
.kbc-avail-card:hover .kbc-avail-card__media img { transform: scale(1.05); }
.kbc-avail-card__tag {
	position: absolute;
	top: 1rem; left: 1rem;
	background: var(--clay);
	color: var(--ivory);
	font-size: 0.68rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 0.35rem 0.7rem;
	border-radius: 999px;
	font-weight: 500;
}
.kbc-avail-card__body { padding: 1.5rem 1.5rem 1.75rem; display: flex; flex-direction: column; gap: 0.55rem; }
.kbc-avail-card__title {
	font-family: var(--font-serif);
	font-size: 1.4rem;
	font-weight: 500;
	margin: 0;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-avail-card__location {
	display: inline-flex; align-items: center; gap: 0.4rem;
	color: var(--muted); font-size: 0.88rem; margin: 0;
}
.kbc-avail-card__specs {
	list-style: none;
	padding: 0;
	margin: 0.25rem 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	color: var(--charcoal);
	font-size: 0.85rem;
}
.kbc-avail-card__specs li { display: inline-flex; align-items: center; gap: 0.35rem; }
.kbc-avail-card__price {
	font-family: var(--font-serif);
	font-size: 1.15rem;
	color: var(--clay);
	margin: 0.25rem 0 0;
}
.kbc-avail-card__cta {
	margin-top: 0.5rem;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.8rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--clay);
	font-weight: 500;
	padding-top: 0.75rem;
	border-top: 1px solid var(--line-soft);
	transition: gap 0.3s var(--ease-out);
}
.kbc-avail-card:hover .kbc-avail-card__cta { gap: 0.6rem; }

/* ---- Selling direct band ---- */
.kbc-avail-selling {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
}
.kbc-avail-selling__inner {
	display: grid;
	grid-template-columns: 1.35fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}
.kbc-avail-selling__copy h2 { margin-bottom: 1rem; }
.kbc-avail-selling__copy .kbc-lead { margin-bottom: 2rem; }
.kbc-avail-selling__list {
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	display: grid;
	gap: 0;
}
.kbc-avail-selling__list li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.1rem;
	padding: 1.1rem 0;
	border-bottom: 1px solid var(--line);
}
.kbc-avail-selling__list li:last-child { border-bottom: 0; }
.kbc-avail-selling__list li > span {
	font-family: var(--font-serif);
	font-size: 1.6rem;
	color: var(--clay);
	line-height: 1;
	padding-top: 0.1rem;
}
.kbc-avail-selling__list strong {
	display: block;
	font-size: 1.05rem;
	font-weight: 500;
	font-family: var(--font-serif);
	font-style: italic;
	margin-bottom: 0.25rem;
	color: var(--ink);
}
.kbc-avail-selling__list p { margin: 0; color: var(--muted); font-size: 0.92rem; line-height: 1.6; }

.kbc-avail-selling__aside {
	background: var(--cream);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	padding: clamp(1.75rem, 3vw, 2.25rem);
	text-align: center;
	box-shadow: var(--shadow-sm);
	position: sticky;
	top: 120px;
}
.kbc-avail-selling__aside-label {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0 0 0.75rem;
}
.kbc-avail-selling__phone {
	display: block;
	font-family: var(--font-serif);
	font-size: clamp(1.55rem, 2.5vw, 2rem);
	color: var(--ink);
	margin: 0 0 0.5rem;
	letter-spacing: -0.01em;
	font-weight: 500;
}
.kbc-avail-selling__phone:hover { color: var(--clay); }
.kbc-avail-selling__email {
	display: inline-block;
	font-size: 0.95rem;
	color: var(--charcoal);
	border-bottom: 1px solid var(--line);
	padding-bottom: 2px;
	margin-bottom: 1rem;
}
.kbc-avail-selling__email:hover { color: var(--clay); border-bottom-color: var(--clay); }
.kbc-avail-selling__note {
	font-size: 0.82rem;
	color: var(--muted);
	margin: 0;
	font-style: italic;
	line-height: 1.5;
}

/* ---- Available responsive ---- */
@media (max-width: 1024px) {
	.kbc-avail-hero__inner { grid-template-columns: 1fr; align-items: start; }
	.kbc-avail-hero__visual { aspect-ratio: 16 / 10; }
	.kbc-avail-featured__inner,
	.kbc-avail-selling__inner { grid-template-columns: 1fr; }
	.kbc-avail-selling__aside { position: static; }
	.kbc-avail-rest__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
	.kbc-avail-rest__grid { grid-template-columns: 1fr; }
	.kbc-avail-featured__specs { grid-template-columns: repeat(2, 1fr); }
	.kbc-avail-featured__thumbs { position: static; margin-top: 0.8rem; left: auto; bottom: auto; right: auto; }
	.kbc-avail-featured__thumbs img { height: 68px; border-width: 1px; }
}

/* ==========================================================================
   Finished Projects page (template-finished.php)
   ========================================================================== */

.kbc-fin-hero {
	padding-top: clamp(9rem, 15vh, 11rem);
	padding-bottom: clamp(3rem, 5vw, 5rem);
	background:
		radial-gradient(ellipse at 15% 20%, rgba(184,115,74,0.08), transparent 55%),
		linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
	position: relative;
	overflow: hidden;
}
.kbc-fin-hero__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-fin-hero__copy { max-width: 36rem; }
.kbc-fin-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.4rem, 5.4vw, 4.5rem);
	line-height: 1.05;
	font-weight: 400;
	margin: 0 0 1.2rem;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-fin-hero__lead {
	font-size: clamp(1.05rem, 1.4vw, 1.2rem);
	color: var(--muted);
	line-height: 1.6;
	margin: 0 0 2rem;
	max-width: 34rem;
}
.kbc-fin-hero__stats {
	display: grid;
	grid-template-columns: repeat(3, auto);
	gap: clamp(1rem, 3vw, 2.4rem);
	padding: 1.5rem 0 2rem;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	margin-bottom: 2rem;
}
.kbc-fin-hero__stats > div { display: flex; flex-direction: column; gap: 0.3rem; }
.kbc-fin-hero__stats strong {
	font-family: var(--font-serif);
	font-size: clamp(1.85rem, 3vw, 2.5rem);
	font-weight: 500;
	color: var(--clay);
	letter-spacing: -0.01em;
	line-height: 1;
}
.kbc-fin-hero__stats span { font-size: 0.78rem; color: var(--muted); letter-spacing: 0.04em; line-height: 1.35; }
.kbc-fin-hero__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }

.kbc-fin-hero__stack {
	position: relative;
	aspect-ratio: 10 / 12;
	max-width: 580px;
	margin-left: auto;
}
.kbc-fin-hero__frame {
	position: absolute;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--sand);
	box-shadow: var(--shadow);
	transition: transform 1.2s var(--ease-out);
}
.kbc-fin-hero__frame img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.5s var(--ease-out); }
.kbc-fin-hero__frame:hover img { transform: scale(1.04); }
.kbc-fin-hero__frame--1 { top: 0;    right: 0;  width: 72%; height: 62%; z-index: 2; }
.kbc-fin-hero__frame--2 { top: 38%;  left: 0;   width: 55%; height: 48%; z-index: 3; }
.kbc-fin-hero__frame--3 { bottom: 0; right: 6%; width: 42%; height: 34%; z-index: 4; }

.kbc-fin-hero__stamp {
	position: absolute;
	right: -14px; bottom: 12%;
	background: var(--ink);
	color: var(--ivory);
	width: 130px; height: 130px;
	border-radius: 50%;
	display: grid; place-items: center;
	text-align: center;
	z-index: 5;
	box-shadow: var(--shadow-lg);
	transform: rotate(-7deg);
	padding: 0.5rem;
}
.kbc-fin-hero__stamp-top,
.kbc-fin-hero__stamp-bottom {
	font-size: 0.64rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.75);
	display: block;
}
.kbc-fin-hero__stamp-main {
	font-family: var(--font-serif);
	font-size: 2.6rem;
	color: var(--clay);
	line-height: 1;
	letter-spacing: -0.02em;
	font-weight: 500;
	display: block;
	margin: 0.1rem 0;
}

/* ---- Two-up featured projects ---- */
.kbc-fin-featured {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
}
.kbc-fin-featured__head { max-width: 680px; margin: 0 auto 3rem 0; }
.kbc-fin-featured__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 4vw, 3.5rem);
}
.kbc-fin-feature { display: flex; flex-direction: column; gap: 1.25rem; }
.kbc-fin-feature__media {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--sand);
	display: block;
}
.kbc-fin-feature__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-out); }
.kbc-fin-feature__media:hover img { transform: scale(1.05); }
.kbc-fin-feature__num {
	position: absolute;
	top: 1.25rem; left: 1.25rem;
	font-family: var(--font-serif);
	font-size: 1.4rem;
	color: var(--ivory);
	background: rgba(20,17,13,0.6);
	backdrop-filter: blur(6px);
	padding: 0.3rem 0.8rem;
	border-radius: 999px;
	letter-spacing: 0.02em;
}
.kbc-fin-feature__body { padding: 0 0.25rem; }
.kbc-fin-feature__title {
	font-family: var(--font-serif);
	font-size: clamp(1.5rem, 2.4vw, 1.95rem);
	font-weight: 500;
	margin: 0 0 0.4rem;
	letter-spacing: -0.005em;
}
.kbc-fin-feature__title a { color: var(--ink); }
.kbc-fin-feature__title a:hover { color: var(--brand-dark); }
.kbc-fin-feature__location {
	display: inline-flex; align-items: center; gap: 0.4rem;
	color: var(--muted); font-size: 0.95rem; margin: 0 0 0.75rem;
}
.kbc-fin-feature__desc { color: var(--charcoal); font-size: 0.98rem; margin: 0 0 1rem; line-height: 1.65; }
.kbc-fin-feature__specs {
	display: flex; flex-wrap: wrap; gap: 1rem;
	list-style: none; padding: 0; margin: 0 0 1rem;
	color: var(--charcoal); font-size: 0.85rem;
}
.kbc-fin-feature__specs li { display: inline-flex; align-items: center; gap: 0.35rem; }
.kbc-fin-feature__link {
	display: inline-flex; align-items: center; gap: 0.4rem;
	font-size: 0.82rem; letter-spacing: 0.14em; text-transform: uppercase;
	font-weight: 500; color: var(--clay);
	border-bottom: 1px solid var(--line);
	padding-bottom: 3px;
	width: fit-content;
	transition: border-color 0.3s, gap 0.3s;
}
.kbc-fin-feature__link:hover { border-bottom-color: var(--clay); gap: 0.65rem; }

/* ---- Full portfolio grid ---- */
.kbc-fin-grid-section {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-fin-grid-head {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 2rem;
	margin-bottom: 3rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--line);
}
.kbc-fin-grid-head .kbc-h2 { margin: 0; }
.kbc-fin-grid-head__count {
	margin: 0;
	font-size: 0.75rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--muted);
	padding-bottom: 0.4rem;
}
.kbc-fin-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.5rem, 3vw, 2.4rem);
}
.kbc-fin-card {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	text-decoration: none;
	color: inherit;
	transition: transform 0.5s var(--ease-out);
}
.kbc-fin-card:hover { transform: translateY(-4px); }
.kbc-fin-card__media {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--sand);
}
.kbc-fin-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-out); }
.kbc-fin-card:hover .kbc-fin-card__media img { transform: scale(1.05); }
.kbc-fin-card__title {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 500;
	margin: 0;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-fin-card__location { color: var(--muted); font-size: 0.88rem; margin: 0; }
.kbc-fin-card__specs { color: var(--charcoal); font-size: 0.82rem; margin: 0; letter-spacing: 0.02em; }

/* ---- Where we build ---- */
.kbc-fin-map {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
}
.kbc-fin-map__inner {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}
.kbc-fin-map__copy h2 { margin: 0 0 1rem; }
.kbc-fin-map__list {
	list-style: none;
	padding: 0;
	margin: 0;
	border-top: 1px solid var(--line);
}
.kbc-fin-map__list li {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 1rem;
	align-items: center;
	padding: 1.15rem 0.25rem;
	border-bottom: 1px solid var(--line);
	transition: background 0.3s;
}
.kbc-fin-map__list li:hover { background: var(--cream); padding-left: 0.75rem; }
.kbc-fin-map__place {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-fin-map__count {
	font-size: 0.8rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--clay);
	font-weight: 500;
}

/* ---- Testimonial band ---- */
.kbc-fin-testimonial {
	padding: clamp(4rem, 8vw, 6.5rem) 0;
	background: var(--cream);
}
.kbc-fin-testimonial__inner {
	max-width: 840px;
	margin: 0 auto;
	text-align: center;
	display: flex; flex-direction: column; align-items: center; gap: 1.2rem;
}
.kbc-fin-testimonial svg { color: var(--clay); opacity: 0.7; }
.kbc-fin-testimonial__text {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: clamp(1.4rem, 2.8vw, 2.1rem);
	line-height: 1.35;
	color: var(--ink);
	margin: 0;
	letter-spacing: -0.005em;
}
.kbc-fin-testimonial__attr {
	font-size: 0.78rem;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0.5rem 0 0;
}

/* ==========================================================================
   Upcoming Projects page (template-upcoming.php)
   ========================================================================== */

.kbc-up-hero {
	padding-top: clamp(9rem, 15vh, 11rem);
	padding-bottom: clamp(3rem, 5vw, 5rem);
	background:
		radial-gradient(ellipse at 75% 25%, rgba(126,133,104,0.10), transparent 55%),
		linear-gradient(180deg, var(--cream) 0%, var(--ivory) 100%);
	position: relative;
	overflow: hidden;
}
.kbc-up-hero__inner {
	display: grid;
	grid-template-columns: 1fr 1.05fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-up-hero__copy { max-width: 40rem; }
.kbc-up-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.5rem, 5.8vw, 4.75rem);
	line-height: 1.04;
	font-weight: 400;
	margin: 0 0 1.2rem;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-up-hero__lead {
	font-size: clamp(1.05rem, 1.4vw, 1.2rem);
	color: var(--muted);
	line-height: 1.6;
	margin: 0 0 2rem;
	max-width: 36rem;
}
.kbc-up-hero__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }

.kbc-up-hero__panel {
	background: var(--ink);
	color: var(--ivory);
	padding: clamp(2rem, 3vw, 2.5rem);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	position: relative;
	overflow: hidden;
}
.kbc-up-hero__panel::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 100% 0%, rgba(126,133,104,0.22), transparent 45%);
	pointer-events: none;
}
.kbc-up-hero__count {
	position: relative;
	display: flex; align-items: baseline; gap: 1.25rem;
	padding-bottom: 1.5rem;
	margin-bottom: 1.5rem;
	border-bottom: 1px solid rgba(251,248,242,0.15);
}
.kbc-up-hero__count-num {
	font-family: var(--font-serif);
	font-size: clamp(3.5rem, 6vw, 5rem);
	line-height: 0.95;
	color: var(--sage);
	letter-spacing: -0.02em;
	font-weight: 500;
}
.kbc-up-hero__count-label {
	font-size: 0.82rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.75);
	line-height: 1.4;
}

.kbc-up-hero__ticker {
	position: relative;
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex; flex-direction: column; gap: 0.85rem;
}
.kbc-up-hero__ticker li {
	display: flex; align-items: center; gap: 0.8rem;
	font-size: 0.92rem;
	color: rgba(251,248,242,0.88);
}
.kbc-up-hero__dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: rgba(251,248,242,0.35);
	flex: 0 0 auto;
}
.kbc-up-hero__dot--live {
	background: var(--sage);
	box-shadow: 0 0 0 0 rgba(126,133,104,0.6);
	animation: kbcPulse 2.2s var(--ease-out) infinite;
}

/* ---- Active projects grid ---- */
.kbc-up-projects {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
}
.kbc-up-projects__head {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 2rem;
	flex-wrap: wrap;
	margin-bottom: 3rem;
}
.kbc-up-projects__head h2 { margin: 0.5rem 0 0; }
.kbc-up-projects__head-note {
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0;
}
.kbc-up-projects__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: clamp(2rem, 4vw, 3rem);
}
/* If only one project, let it span full width */
.kbc-up-projects__grid > .kbc-up-project:only-child { grid-column: 1 / -1; }

.kbc-up-project {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	background: var(--cream);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--line-soft);
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
}
.kbc-up-project:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.kbc-up-projects__grid > .kbc-up-project:only-child { grid-template-columns: 1.2fr 1fr; }

.kbc-up-project__media {
	position: relative;
	aspect-ratio: auto;
	min-height: 320px;
	overflow: hidden;
	background: var(--sand);
}
.kbc-up-project__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-out); }
.kbc-up-project:hover .kbc-up-project__media img { transform: scale(1.04); }

.kbc-up-project__placeholder {
	width: 100%; height: 100%;
	display: grid; place-items: center;
	background: linear-gradient(135deg, var(--sand) 0%, var(--sand-soft) 100%);
}
.kbc-up-project__placeholder span {
	font-family: var(--font-serif);
	font-size: 3rem;
	color: var(--muted);
	letter-spacing: 0.02em;
}

.kbc-up-project__phase {
	position: absolute;
	top: 1.25rem; left: 1.25rem;
	background: rgba(20,17,13,0.82);
	color: var(--ivory);
	padding: 0.4rem 0.85rem;
	border-radius: 999px;
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 500;
	backdrop-filter: blur(6px);
}

.kbc-up-project__body {
	padding: clamp(1.75rem, 3vw, 2.25rem);
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.kbc-up-project__head { padding-bottom: 0.5rem; border-bottom: 1px solid var(--line); }
.kbc-up-project__title {
	font-family: var(--font-serif);
	font-size: clamp(1.4rem, 2.2vw, 1.85rem);
	font-weight: 500;
	margin: 0 0 0.35rem;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-up-project__location {
	display: inline-flex; align-items: center; gap: 0.4rem;
	color: var(--muted); font-size: 0.88rem; margin: 0 0 0.5rem;
}
.kbc-up-project__desc { color: var(--charcoal); margin: 0; font-size: 0.95rem; line-height: 1.65; }

.kbc-up-project__facts {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.5rem 1.25rem;
	margin: 0;
	padding: 0;
}
.kbc-up-project__facts > div {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--line-soft);
}
.kbc-up-project__facts dt {
	font-size: 0.68rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0;
}
.kbc-up-project__facts dd {
	font-family: var(--font-serif);
	font-size: 1.1rem;
	font-weight: 500;
	color: var(--ink);
	margin: 0;
	letter-spacing: -0.005em;
}

.kbc-up-project__actions {
	display: flex; gap: 1rem; align-items: center; flex-wrap: wrap;
	margin-top: 0.5rem;
}

/* ---- Four phases ---- */
.kbc-up-phases {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-up-phases__head {
	max-width: 780px;
	margin: 0 auto 3rem;
	text-align: center;
}
.kbc-up-phases__head h2 { margin: 0; }
.kbc-up-phases__head .kbc-lead { margin: 1rem auto 0; }
.kbc-up-phases__head .kbc-eyebrow { display: inline-block; }
.kbc-up-phases__head .kbc-eyebrow::before { display: none; }

.kbc-up-phases__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
	counter-reset: phase;
	position: relative;
}
.kbc-up-phases__item {
	background: var(--ivory);
	padding: 2rem 1.75rem;
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	display: flex;
	flex-direction: column;
	gap: 1rem;
	position: relative;
	transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
}
.kbc-up-phases__item:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.kbc-up-phases__item:not(:last-child)::after {
	content: '';
	position: absolute;
	top: 50%;
	right: calc(-1 * clamp(0.75rem, 1.5vw, 1.25rem));
	transform: translateY(-50%);
	width: 10px; height: 10px;
	border-right: 1.5px solid var(--line);
	border-top: 1.5px solid var(--line);
	transform-origin: center;
	transform: translateY(-50%) rotate(45deg);
}
.kbc-up-phases__num {
	font-family: var(--font-serif);
	font-size: 2rem;
	color: var(--sage);
	line-height: 1;
	letter-spacing: -0.01em;
	font-weight: 500;
}
.kbc-up-phases__item h3 {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	font-weight: 500;
	margin: 0 0 0.35rem;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-up-phases__item p { color: var(--muted); margin: 0; font-size: 0.92rem; line-height: 1.6; }

/* ---- Notify band ---- */
.kbc-up-notify {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
}
.kbc-up-notify__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-up-notify__copy h2 { margin-bottom: 1rem; }
.kbc-up-notify__copy .kbc-lead { margin-bottom: 2rem; }

.kbc-up-notify__aside {
	background: var(--cream);
	border-radius: var(--radius);
	border: 1px solid var(--line-soft);
	padding: clamp(1.75rem, 3vw, 2.25rem);
	text-align: center;
	box-shadow: var(--shadow-sm);
}
.kbc-up-notify__aside-label {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0 0 0.75rem;
}
.kbc-up-notify__phone {
	display: block;
	font-family: var(--font-serif);
	font-size: clamp(1.55rem, 2.5vw, 2rem);
	color: var(--ink);
	margin: 0 0 0.5rem;
	letter-spacing: -0.01em;
	font-weight: 500;
}
.kbc-up-notify__phone:hover { color: var(--clay); }
.kbc-up-notify__email {
	display: inline-block;
	font-size: 0.95rem;
	color: var(--charcoal);
	border-bottom: 1px solid var(--line);
	padding-bottom: 2px;
	margin-bottom: 1rem;
}
.kbc-up-notify__email:hover { color: var(--clay); border-bottom-color: var(--clay); }
.kbc-up-notify__note { font-size: 0.82rem; color: var(--muted); margin: 0; font-style: italic; }

/* ---- Finished + Upcoming responsive ---- */
@media (max-width: 1024px) {
	.kbc-fin-hero__inner,
	.kbc-fin-featured__grid,
	.kbc-fin-map__inner,
	.kbc-up-hero__inner,
	.kbc-up-notify__inner { grid-template-columns: 1fr; }
	.kbc-fin-grid,
	.kbc-up-projects__grid { grid-template-columns: repeat(2, 1fr); }
	.kbc-up-project { grid-template-columns: 1fr; }
	.kbc-up-project__media { min-height: 260px; }
	.kbc-up-phases__list { grid-template-columns: repeat(2, 1fr); }
	.kbc-up-phases__item::after { display: none; }
}
@media (max-width: 768px) {
	.kbc-fin-hero__stats { grid-template-columns: 1fr; border-bottom: 0; padding-bottom: 0.5rem; }
	.kbc-fin-grid,
	.kbc-up-projects__grid,
	.kbc-up-phases__list { grid-template-columns: 1fr; }
	.kbc-fin-hero__stamp { width: 90px; height: 90px; right: 0; }
	.kbc-fin-hero__stamp-main { font-size: 1.8rem; }
	.kbc-fin-grid-head { flex-direction: column; align-items: flex-start; }
}

/* ==========================================================================
   Single property (single-property.php) — editorial layout
   ========================================================================== */

.kbc-prop-single { display: block; }

/* Override the older .kbc-property-hero styles (no longer used). */

/* ---- Full-bleed hero ---- */
.kbc-prop-hero {
	position: relative;
	min-height: 92vh;
	padding-top: clamp(7rem, 12vh, 9rem);
	padding-bottom: clamp(3rem, 5vw, 4.5rem);
	display: grid;
	align-items: stretch;
	color: var(--ivory);
	overflow: hidden;
	background: var(--ink);
}
.kbc-prop-hero__bg { position: absolute; inset: 0; z-index: 0; }
.kbc-prop-hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.kbc-prop-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(20,17,13,0.45) 0%, rgba(20,17,13,0.15) 35%, rgba(20,17,13,0.55) 75%, rgba(20,17,13,0.88) 100%);
	z-index: 1;
}
.kbc-prop-hero.no-image { background: linear-gradient(160deg, var(--ink) 0%, #3a332c 100%); }
.kbc-prop-hero.no-image::after { display: none; }

.kbc-prop-hero__inner {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;
	gap: 2rem;
}

.kbc-prop-hero__top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}
.kbc-prop-hero__crumbs {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	font-size: 0.78rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.75);
}
.kbc-prop-hero__crumbs a { color: inherit; transition: color 0.3s; }
.kbc-prop-hero__crumbs a:hover { color: var(--ivory); }
.kbc-prop-hero__crumbs span[aria-hidden] { opacity: 0.4; }
.kbc-prop-hero__crumbs > span:not([aria-hidden]) { color: var(--ivory); }

.kbc-prop-hero__status {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.45rem 0.95rem;
	background: rgba(251,248,242,0.12);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border: 1px solid rgba(251,248,242,0.22);
	border-radius: 999px;
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--ivory);
}
.kbc-prop-hero__status-dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--clay);
}
.kbc-prop-hero__status--available .kbc-prop-hero__status-dot {
	background: #9ab07a;
	box-shadow: 0 0 0 0 rgba(154,176,122,0.6);
	animation: kbcPulse 2.2s var(--ease-out) infinite;
}
.kbc-prop-hero__status--upcoming .kbc-prop-hero__status-dot { background: var(--sage); }
.kbc-prop-hero__status--finished .kbc-prop-hero__status-dot { background: var(--clay); }

.kbc-prop-hero__bottom {
	display: grid;
	grid-template-columns: 1.2fr auto;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: end;
}

.kbc-prop-hero__title-block { max-width: 60rem; }
.kbc-prop-hero__title-block .kbc-eyebrow { color: rgba(251,248,242,0.85); }
.kbc-prop-hero__title-block .kbc-eyebrow::before { background: rgba(251,248,242,0.7); }
.kbc-prop-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.4rem, 6.5vw, 5.5rem);
	line-height: 1.02;
	font-weight: 400;
	margin: 0 0 1rem;
	color: var(--ivory);
	letter-spacing: -0.015em;
}
.kbc-prop-hero__location {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1rem;
	color: rgba(251,248,242,0.85);
	margin: 0;
}

.kbc-prop-hero__summary {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(70px, auto);
	gap: 0;
	border-top: 1px solid rgba(251,248,242,0.22);
	border-left: 1px solid rgba(251,248,242,0.22);
	padding: 0;
	background: rgba(20,17,13,0.35);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-radius: var(--radius);
	overflow: hidden;
}
.kbc-prop-hero__summary-item {
	padding: 1rem 1.35rem;
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
	border-right: 1px solid rgba(251,248,242,0.22);
	border-bottom: 1px solid rgba(251,248,242,0.22);
	min-width: 84px;
}
.kbc-prop-hero__summary-item strong {
	font-family: var(--font-serif);
	font-size: 1.65rem;
	font-weight: 500;
	color: var(--ivory);
	line-height: 1;
	letter-spacing: -0.005em;
}
.kbc-prop-hero__summary-item span {
	font-size: 0.68rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.72);
}

.kbc-prop-hero__scroll {
	position: absolute;
	left: 50%;
	bottom: 1.25rem;
	transform: translateX(-50%);
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.4rem;
	color: rgba(251,248,242,0.75);
	font-size: 0.68rem;
	letter-spacing: 0.28em;
	text-transform: uppercase;
}
.kbc-prop-hero__scroll-line { width: 1px; height: 32px; background: rgba(251,248,242,0.4); position: relative; overflow: hidden; }
.kbc-prop-hero__scroll-line::after {
	content: '';
	position: absolute;
	top: -100%;
	left: 0;
	width: 100%;
	height: 50%;
	background: var(--ivory);
	animation: kbcScrollLine 2s var(--ease-in-out) infinite;
}

/* ---- Intro split ---- */
.kbc-prop-intro {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
}
.kbc-prop-intro__inner {
	display: grid;
	grid-template-columns: 1.35fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}

.kbc-prop-intro__body { max-width: 40rem; }
.kbc-prop-intro__headline {
	font-family: var(--font-serif);
	font-size: clamp(1.8rem, 3.2vw, 2.65rem);
	font-weight: 400;
	line-height: 1.2;
	color: var(--ink);
	margin: 0 0 1.5rem;
	letter-spacing: -0.005em;
}
.kbc-prop-intro__content {
	font-size: 1.05rem;
	line-height: 1.75;
	color: var(--charcoal);
	max-width: 100%;
}
.kbc-prop-intro__content > p:first-child { font-size: 1.1rem; color: var(--charcoal); }

.kbc-prop-intro__card {
	position: sticky;
	top: 120px;
	background: var(--cream);
	border: 1px solid var(--line-soft);
	border-radius: var(--radius-lg);
	padding: clamp(1.75rem, 3vw, 2.25rem);
	box-shadow: var(--shadow-sm);
}
.kbc-prop-intro__price {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding-bottom: 1.5rem;
	margin-bottom: 1.25rem;
	border-bottom: 1px solid var(--line);
}
.kbc-prop-intro__price span {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--muted);
}
.kbc-prop-intro__price strong {
	font-family: var(--font-serif);
	font-size: clamp(1.6rem, 3vw, 2.25rem);
	color: var(--clay);
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1;
}

.kbc-prop-intro__facts {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}
.kbc-prop-intro__facts > div {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.85rem 0;
	border-bottom: 1px solid var(--line-soft);
}
.kbc-prop-intro__facts > div:last-child { border-bottom: 0; }
.kbc-prop-intro__facts dt {
	font-size: 0.78rem;
	color: var(--muted);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin: 0;
}
.kbc-prop-intro__facts dd {
	font-family: var(--font-serif);
	font-size: 1.1rem;
	font-weight: 500;
	color: var(--ink);
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
}
.kbc-prop-intro__facts-icon { color: var(--clay); display: inline-flex; }

.kbc-prop-intro__cta {
	margin-top: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.kbc-prop-intro__cta .kbc-btn { justify-content: center; }
.kbc-prop-intro__direct {
	display: flex;
	justify-content: space-between;
	gap: 0.5rem;
	padding-top: 1rem;
	border-top: 1px solid var(--line-soft);
	flex-wrap: wrap;
}
.kbc-prop-intro__direct a {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.85rem;
	color: var(--ink);
}
.kbc-prop-intro__direct a:hover { color: var(--brand-dark); }

/* ---- Gallery mosaic ---- */
.kbc-prop-gallery {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background: var(--cream);
}
.kbc-prop-gallery__head {
	display: flex;
	justify-content: space-between;
	align-items: end;
	margin-bottom: 2.5rem;
	gap: 1rem;
	flex-wrap: wrap;
}
.kbc-prop-gallery__head h2 { margin: 0.5rem 0 0; }

.kbc-prop-gallery__grid {
	display: grid;
	gap: clamp(0.75rem, 1.5vw, 1.1rem);
}
.kbc-prop-gallery__grid.is-two { grid-template-columns: repeat(2, 1fr); }
.kbc-prop-gallery__grid.is-three { grid-template-columns: repeat(3, 1fr); }

.kbc-prop-gallery__grid.is-mosaic {
	grid-template-columns: repeat(4, 1fr);
	grid-auto-rows: 220px;
}
.kbc-prop-gallery__grid.is-mosaic .kbc-prop-gallery__item--1 { grid-column: span 2; grid-row: span 2; }
.kbc-prop-gallery__grid.is-mosaic .kbc-prop-gallery__item--4 { grid-column: span 2; }

.kbc-prop-gallery__item {
	margin: 0;
	padding: 0;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--sand);
	position: relative;
	border: 0;
	cursor: zoom-in;
	font: inherit;
	color: inherit;
	width: 100%;
	display: block;
	appearance: none;
}
.kbc-prop-gallery__item:focus-visible {
	outline: 2px solid var(--clay);
	outline-offset: 3px;
}
.kbc-prop-gallery__item img,
.kbc-prop-gallery__img {
	width: 100%;
	height: 100%;
	min-height: 220px;
	object-fit: cover;
	transition: transform 1.5s var(--ease-out);
	display: block;
}
.kbc-prop-gallery__item:hover img { transform: scale(1.04); }

.kbc-prop-gallery__zoom {
	position: absolute;
	top: 0.9rem;
	right: 0.9rem;
	display: inline-grid;
	place-items: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: rgba(42,37,32,0.72);
	color: var(--ivory);
	backdrop-filter: blur(4px);
	opacity: 0;
	transform: translateY(-4px) scale(0.9);
	transition: opacity 0.3s var(--ease-out), transform 0.3s var(--ease-out);
	pointer-events: none;
	z-index: 2;
}
.kbc-prop-gallery__item:hover .kbc-prop-gallery__zoom,
.kbc-prop-gallery__item:focus-visible .kbc-prop-gallery__zoom {
	opacity: 1;
	transform: translateY(0) scale(1);
}

/* ---- Lightbox ---- */
.kbc-lightbox {
	position: fixed;
	inset: 0;
	z-index: 1000;
	background: rgba(14,12,10,0.94);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(3.5rem, 6vw, 5rem) clamp(3.5rem, 8vw, 6rem);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s var(--ease-out), visibility 0s linear 0.3s;
}
.kbc-lightbox.is-open {
	opacity: 1;
	visibility: visible;
	transition: opacity 0.3s var(--ease-out), visibility 0s;
}
.kbc-lightbox__stage {
	margin: 0;
	max-width: min(1200px, 100%);
	max-height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
}
.kbc-lightbox__image {
	max-width: 100%;
	max-height: calc(100vh - 10rem);
	width: auto;
	height: auto;
	object-fit: contain;
	border-radius: 4px;
	box-shadow: 0 40px 80px -20px rgba(0,0,0,0.6);
	opacity: 0;
	transform: scale(0.98);
	transition: opacity 0.35s var(--ease-out), transform 0.35s var(--ease-out);
}
.kbc-lightbox.is-loaded .kbc-lightbox__image {
	opacity: 1;
	transform: scale(1);
}
.kbc-lightbox__caption {
	display: flex;
	gap: 1rem;
	align-items: center;
	color: rgba(251,248,242,0.85);
	font-size: 0.88rem;
	letter-spacing: 0.04em;
	text-align: center;
}
.kbc-lightbox__count {
	font-family: var(--font-serif);
	font-size: 1rem;
	color: var(--clay);
	letter-spacing: 0.06em;
}
.kbc-lightbox__title { max-width: 48ch; }

.kbc-lightbox__close,
.kbc-lightbox__nav {
	position: absolute;
	background: rgba(251,248,242,0.08);
	border: 1px solid rgba(251,248,242,0.2);
	color: var(--ivory);
	width: 46px;
	height: 46px;
	border-radius: 50%;
	display: inline-grid;
	place-items: center;
	cursor: pointer;
	transition: background 0.25s, border-color 0.25s, transform 0.25s;
	backdrop-filter: blur(6px);
	padding: 0;
}
.kbc-lightbox__close:hover,
.kbc-lightbox__nav:hover {
	background: rgba(251,248,242,0.18);
	border-color: rgba(251,248,242,0.4);
}
.kbc-lightbox__close { top: clamp(1rem, 2.5vw, 1.5rem); right: clamp(1rem, 2.5vw, 1.5rem); }
.kbc-lightbox__nav--prev { left: clamp(1rem, 2.5vw, 1.5rem); top: 50%; transform: translateY(-50%); }
.kbc-lightbox__nav--next { right: clamp(1rem, 2.5vw, 1.5rem); top: 50%; transform: translateY(-50%); }
.kbc-lightbox__nav--prev:hover { transform: translateY(-50%) translateX(-2px); }
.kbc-lightbox__nav--next:hover { transform: translateY(-50%) translateX(2px); }
.kbc-lightbox__nav:disabled {
	opacity: 0.35;
	cursor: not-allowed;
	pointer-events: none;
}

@media (max-width: 640px) {
	.kbc-lightbox { padding: 3.5rem 0.75rem 5rem; }
	.kbc-lightbox__nav { width: 40px; height: 40px; }
	.kbc-lightbox__image { max-height: calc(100vh - 12rem); }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
	.kbc-lightbox,
	.kbc-lightbox__image,
	.kbc-lightbox__close,
	.kbc-lightbox__nav,
	.kbc-prop-gallery__zoom { transition: none; }
}

/* Lock body scroll when open */
body.kbc-lightbox-open { overflow: hidden; }

/* ---- At a glance ---- */
.kbc-prop-glance {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
	border-top: 1px solid var(--line-soft);
}
.kbc-prop-glance__head {
	max-width: 640px;
	margin: 0 auto 3rem 0;
}
.kbc-prop-glance__grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid var(--line);
	border-left: 1px solid var(--line);
}
.kbc-prop-glance__item {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.75rem;
	border-right: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	transition: background 0.4s var(--ease-out);
}
.kbc-prop-glance__item:hover { background: var(--cream); }
.kbc-prop-glance__icon {
	width: 48px; height: 48px;
	border-radius: 50%;
	background: var(--cream);
	display: grid;
	place-items: center;
	color: var(--clay);
	flex: 0 0 auto;
	transition: background 0.4s var(--ease-out), color 0.4s;
}
.kbc-prop-glance__icon--dot {
	position: relative;
}
.kbc-prop-glance__icon--dot::before {
	content: '';
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--clay);
}
.kbc-prop-glance__item:hover .kbc-prop-glance__icon { background: var(--clay); color: var(--ivory); }
.kbc-prop-glance__item:hover .kbc-prop-glance__icon--dot::before { background: var(--ivory); }

.kbc-prop-glance__label {
	display: block;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--muted);
	margin-bottom: 0.2rem;
}
.kbc-prop-glance__value {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	font-weight: 500;
	color: var(--ink);
	letter-spacing: -0.005em;
}

/* ---- Signature details (4 principles) ---- */
.kbc-prop-features {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--cream);
}
.kbc-prop-features__inner {
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: clamp(2rem, 5vw, 4rem);
	align-items: start;
}
.kbc-prop-features__copy { position: sticky; top: 120px; }
.kbc-prop-features__copy h2 { margin: 0 0 1rem; }
.kbc-prop-features__copy .kbc-lead { margin: 0 0 1.5rem; }

.kbc-prop-features__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 0;
}
.kbc-prop-features__list > li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.5rem;
	padding: 1.75rem 0;
	border-top: 1px solid var(--line);
}
.kbc-prop-features__list > li:last-child { border-bottom: 1px solid var(--line); }
.kbc-prop-features__num {
	font-family: var(--font-serif);
	font-size: 2rem;
	color: var(--clay);
	line-height: 1;
	letter-spacing: -0.01em;
	padding-top: 0.1rem;
}
.kbc-prop-features__list h3 {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 500;
	margin: 0 0 0.35rem;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-prop-features__list p {
	color: var(--muted);
	font-size: 0.95rem;
	line-height: 1.65;
	margin: 0;
}

/* ---- Related projects ---- */
.kbc-prop-related {
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: var(--ivory);
}
.kbc-prop-related__head {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 1rem;
	flex-wrap: wrap;
	margin-bottom: 3rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--line);
}
.kbc-prop-related__head h2 { margin: 0.5rem 0 0; }
.kbc-prop-related__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.5rem, 3vw, 2.4rem);
}

/* ---- Single-property closing CTA ---- */
.kbc-prop-cta {
	padding: clamp(4rem, 8vw, 7rem) 0;
	background: var(--brand-dark);
	color: var(--ivory);
	position: relative;
	overflow: hidden;
}
.kbc-prop-cta::before {
	content: '';
	position: absolute;
	inset: -40%;
	background: radial-gradient(circle at 25% 30%, rgba(184,115,74,0.2), transparent 45%);
	pointer-events: none;
}
.kbc-prop-cta__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}
.kbc-prop-cta__copy h2 {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4vw, 3rem);
	color: var(--ivory);
	margin: 0 0 1rem;
	line-height: 1.1;
	font-weight: 400;
}
.kbc-prop-cta__copy .kbc-eyebrow { color: rgba(251,248,242,0.7); }
.kbc-prop-cta__copy .kbc-eyebrow::before { background: rgba(251,248,242,0.6); }
.kbc-prop-cta__copy .kbc-lead { color: rgba(251,248,242,0.85); margin-bottom: 2rem; }
.kbc-prop-cta__copy .kbc-btn--primary { background: var(--ivory); color: var(--ink); }
.kbc-prop-cta__copy .kbc-btn--primary:hover { background: var(--clay); color: var(--ivory); }

.kbc-prop-cta__direct {
	background: rgba(251,248,242,0.07);
	border: 1px solid rgba(251,248,242,0.15);
	border-radius: var(--radius);
	padding: 2rem;
	text-align: center;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}
.kbc-prop-cta__direct-label {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(251,248,242,0.7);
	margin: 0 0 0.75rem;
}
.kbc-prop-cta__phone {
	display: block;
	font-family: var(--font-serif);
	font-size: clamp(1.55rem, 2.8vw, 2.1rem);
	color: var(--ivory);
	margin: 0 0 0.5rem;
	letter-spacing: -0.01em;
	font-weight: 500;
}
.kbc-prop-cta__phone:hover { color: var(--clay); }
.kbc-prop-cta__email {
	display: inline-block;
	font-size: 0.95rem;
	color: rgba(251,248,242,0.85);
	border-bottom: 1px solid rgba(251,248,242,0.3);
	padding-bottom: 2px;
}
.kbc-prop-cta__email:hover { color: var(--clay); border-bottom-color: var(--clay); }

/* Remove the old .kbc-property-hero margin if lingering — no visual impact
   since the markup doesn't use it anymore, but cleans up specificity. */

/* ---- Single property responsive ---- */
@media (max-width: 1024px) {
	.kbc-prop-hero { min-height: 80vh; }
	.kbc-prop-hero__bottom { grid-template-columns: 1fr; align-items: start; }
	.kbc-prop-hero__summary { grid-auto-flow: row; grid-auto-columns: auto; grid-template-columns: repeat(auto-fit, minmax(84px, 1fr)); }
	.kbc-prop-intro__inner { grid-template-columns: 1fr; }
	.kbc-prop-intro__card { position: static; }
	.kbc-prop-glance__grid { grid-template-columns: repeat(2, 1fr); }
	.kbc-prop-features__inner { grid-template-columns: 1fr; }
	.kbc-prop-features__copy { position: static; }
	.kbc-prop-related__grid { grid-template-columns: repeat(2, 1fr); }
	.kbc-prop-cta__inner { grid-template-columns: 1fr; }
	.kbc-prop-gallery__grid.is-mosaic { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
	.kbc-prop-gallery__grid.is-mosaic .kbc-prop-gallery__item--1,
	.kbc-prop-gallery__grid.is-mosaic .kbc-prop-gallery__item--4 { grid-column: span 2; grid-row: auto; }
}
@media (max-width: 768px) {
	.kbc-prop-hero__summary-item { padding: 0.75rem 1rem; min-width: 0; }
	.kbc-prop-hero__summary-item strong { font-size: 1.3rem; }
	.kbc-prop-glance__grid,
	.kbc-prop-related__grid,
	.kbc-prop-gallery__grid.is-three { grid-template-columns: 1fr; }
	.kbc-prop-gallery__grid.is-mosaic { grid-template-columns: 1fr; grid-auto-rows: auto; }
	.kbc-prop-gallery__img { min-height: 220px; }
	.kbc-prop-hero__crumbs { font-size: 0.7rem; }
}

/* ==========================================================================
   Homepage — bespoke sections matching the live kbchomes.com order
   ========================================================================== */

.kbc-home-section__head {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 2rem;
	flex-wrap: wrap;
	margin-bottom: 1.75rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--line);
}
.kbc-home-section__head h2 { margin: 0.4rem 0 0; }
.kbc-home-section__head--center {
	flex-direction: column;
	align-items: center;
	text-align: center;
	max-width: 780px;
	margin: 0 auto 1.75rem;
	border-bottom: 0;
	padding-bottom: 0;
}
.kbc-home-section__head--center .kbc-eyebrow::before { display: none; }
.kbc-home-section__head--center .kbc-lead { margin: 1rem auto 0; }

/* ---- Build-stats band — three branded cards below the hero ---- */
.kbc-build-stats {
	background:
		radial-gradient(ellipse at 20% 0%, rgba(15, 61, 46, 0.06), transparent 55%),
		radial-gradient(ellipse at 80% 100%, rgba(184, 115, 74, 0.04), transparent 50%),
		linear-gradient(180deg, var(--ivory) 0%, var(--cream) 100%);
}
/* "Build Your Home — Your Way" stays on one line. Override the
   section-head max-width and let the title size itself. */
.kbc-build-stats .kbc-home-section__head--center { max-width: none; }
.kbc-build-stats .kbc-h2 {
	white-space: nowrap;
	font-size: clamp(2rem, 4.4vw, 3.85rem);
}
.kbc-build-stats__grid {
	display: grid;
	grid-template-columns: 1fr 1.7fr 1fr;
	gap: clamp(1rem, 1.75vw, 1.6rem);
	max-width: 72rem;
	margin: 0 auto;
	padding-top: 0.5rem;
	align-items: stretch;
}
.kbc-build-stats__stat {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	text-align: center;
	gap: 0.6rem;
	background: var(--ivory);
	border: 1px solid var(--line-soft);
	border-radius: 14px;
	padding: clamp(2rem, 3vw, 2.6rem) clamp(1.2rem, 2.2vw, 1.9rem);
	box-shadow: 0 10px 32px rgba(15, 61, 46, 0.05), 0 1px 2px rgba(20, 17, 13, 0.03);
	overflow: hidden;
	transition: transform 0.45s var(--ease-fluid),
	            box-shadow 0.45s var(--ease-fluid),
	            border-color 0.4s;
}
/* Brand-green accent stripe on top of each card. */
.kbc-build-stats__stat::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 56px;
	height: 3px;
	background: var(--brand-dark);
	border-radius: 0 0 4px 4px;
	transition: width 0.45s var(--ease-fluid);
}
.kbc-build-stats__stat:hover {
	transform: translateY(-4px);
	box-shadow: 0 18px 48px rgba(15, 61, 46, 0.10), 0 2px 4px rgba(20, 17, 13, 0.05);
	border-color: rgba(15, 61, 46, 0.18);
}
.kbc-build-stats__stat:hover::before { width: 96px; }

.kbc-build-stats__num {
	font-family: var(--font-serif);
	font-size: clamp(2.6rem, 4.4vw, 3.85rem);
	font-weight: 600;
	line-height: 1;
	color: var(--brand-dark);
	letter-spacing: -0.014em;
}
.kbc-build-stats__num--word {
	font-size: clamp(1.65rem, 2.6vw, 2.25rem) !important;
	letter-spacing: 0.12em !important;
}
.kbc-build-stats__label {
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--muted);
	font-weight: 600;
}
.kbc-build-stats__label--cities {
	max-width: 28rem;
	text-transform: none;
	letter-spacing: 0.01em;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--charcoal);
	font-weight: 400;
	text-wrap: balance;
	margin-top: 0.15rem;
}

/* ---- Welcome statement — centered editorial ---- */
.kbc-welcome {
	padding-top: clamp(2.5rem, 4.5vw, 4rem);
	padding-bottom: clamp(2.5rem, 4.5vw, 4rem);
	background: var(--ivory);
	position: relative;
	overflow: hidden;
}
.kbc-welcome::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 85vw;
	height: 85vw;
	max-width: 1100px;
	max-height: 1100px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(184,115,74,0.06) 0%, rgba(126,133,104,0.04) 50%, transparent 70%);
	pointer-events: none;
}
.kbc-welcome::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='0.6' fill='%232a2520' opacity='0.12'/%3E%3C/svg%3E");
	opacity: 0.5;
	pointer-events: none;
}

.kbc-welcome__inner {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.kbc-welcome__statement {
	max-width: 960px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
}
/* Welcome eyebrow — "Welcome to KB Custom Homes" treated as a real
   heading: serif, dark green, large, bold. */
.kbc-welcome__inner .kbc-eyebrow {
	margin-bottom: 1.75rem;
	font-family: var(--font-serif);
	font-size: clamp(1.6rem, 2.8vw, 2.4rem);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: none;
	color: var(--brand-dark);
}
.kbc-welcome__inner .kbc-eyebrow::before { display: none; }

.kbc-welcome__title {
	font-family: var(--font-serif);
	font-size: clamp(3rem, 6vw, 5.25rem);
	font-weight: 600;
	line-height: 1.05;
	color: var(--ink);
	margin: 0 0 1.75rem;
	letter-spacing: -0.014em;
	max-width: 36ch;
}
.kbc-welcome__body {
	font-size: clamp(1.05rem, 1.5vw, 1.2rem);
	line-height: 1.7;
	color: var(--muted);
	margin: 0 0 2.5rem;
	max-width: 52ch;
}

.kbc-welcome__divider {
	display: block;
	width: 56px;
	height: 1px;
	background: var(--clay);
	margin: 0 0 2.5rem;
	position: relative;
}
.kbc-welcome__divider::before,
.kbc-welcome__divider::after {
	content: '';
	position: absolute;
	top: 50%;
	width: 4px; height: 4px;
	border-radius: 50%;
	background: var(--clay);
	transform: translateY(-50%);
}
.kbc-welcome__divider::before { left: -8px; }
.kbc-welcome__divider::after  { right: -8px; }

/* Four pillars row — full-width editorial trust markers */
.kbc-welcome__pillars {
	list-style: none;
	padding: 0;
	margin: 0 0 3rem;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	width: 100%;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.kbc-welcome__pillars li {
	padding: clamp(1.75rem, 2.8vw, 2.4rem) clamp(1.5rem, 2.5vw, 2rem);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
	gap: 0.55rem;
	position: relative;
	transition: background 0.4s var(--ease-fluid);
	min-height: 190px;
}
.kbc-welcome__pillars li + li { border-left: 1px solid var(--line-soft); }
.kbc-welcome__pillars li:hover { background: var(--cream); }
.kbc-welcome__pillar-num {
	font-family: var(--font-serif);
	font-size: 1rem;
	font-style: italic;
	color: var(--clay);
	letter-spacing: 0.08em;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.kbc-welcome__pillar-num::after {
	content: '';
	display: inline-block;
	width: 20px;
	height: 1px;
	background: var(--clay);
	opacity: 0.5;
}
.kbc-welcome__pillars strong {
	font-family: var(--font-serif);
	font-size: clamp(1.4rem, 2vw, 1.75rem);
	font-weight: 500;
	color: var(--ink);
	letter-spacing: -0.01em;
	line-height: 1.15;
	margin-top: 0.25rem;
}
.kbc-welcome__pillars span {
	font-size: 1rem;
	color: var(--muted);
	line-height: 1.55;
	margin-top: 0.15rem;
}

.kbc-welcome__actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	justify-content: center;
}

/* ---- Finished projects section on homepage ---- */
.kbc-home-finished {
	background: var(--cream);
	padding-top: clamp(4rem, 8vw, 7rem);
	padding-bottom: clamp(4rem, 8vw, 7rem);
}

/* ---- Upcoming feature ---- */
.kbc-home-upcoming {
	background: var(--ivory);
}
.kbc-home-upcoming__feature {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: 0;
	background: var(--cream);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--line-soft);
	text-decoration: none;
	color: inherit;
	transition: transform 0.6s var(--ease-fluid), box-shadow 0.6s var(--ease-fluid);
	position: relative;
}
.kbc-home-upcoming__feature:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.kbc-home-upcoming__media {
	position: relative;
	aspect-ratio: auto;
	min-height: 420px;
	overflow: hidden;
	background: var(--sand);
}
.kbc-home-upcoming__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.4s var(--ease-fluid); }
.kbc-home-upcoming__feature:hover .kbc-home-upcoming__media img { transform: scale(1.05); }
.kbc-home-upcoming__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--sand) 0%, var(--sand-soft) 100%); }
.kbc-home-upcoming__tag {
	position: absolute;
	top: 1.25rem; left: 1.25rem;
	background: var(--brand-dark);
	color: var(--ivory);
	padding: 0.4rem 0.9rem;
	border-radius: 999px;
	font-size: 0.7rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-weight: 500;
	box-shadow: var(--shadow-sm);
}
.kbc-home-upcoming__body {
	padding: clamp(2rem, 3.5vw, 3rem);
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 1rem;
}
.kbc-home-upcoming__eyebrow {
	display: inline-block;
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--sage);
	font-weight: 500;
}
.kbc-home-upcoming__title {
	font-family: var(--font-serif);
	font-size: clamp(1.75rem, 3.5vw, 2.85rem);
	font-weight: 400;
	margin: 0;
	line-height: 1.08;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-home-upcoming__location {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	color: var(--muted);
	font-size: 0.95rem;
	margin: 0;
}
.kbc-home-upcoming__desc { color: var(--charcoal); font-size: 0.98rem; line-height: 1.7; margin: 0; }
.kbc-home-upcoming__specs {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 1.25rem;
	color: var(--charcoal);
	font-size: 0.88rem;
	flex-wrap: wrap;
}
.kbc-home-upcoming__specs li { display: inline-flex; align-items: center; gap: 0.4rem; }
.kbc-home-upcoming__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: 0.5rem;
	font-size: 0.84rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--clay);
	border-bottom: 1px solid var(--line);
	padding-bottom: 4px;
	width: fit-content;
	transition: border-color 0.3s, gap 0.3s var(--ease-fluid);
}
.kbc-home-upcoming__feature:hover .kbc-home-upcoming__cta { gap: 0.7rem; border-bottom-color: var(--clay); }

/* ---- Testimonials on home ---- */
.kbc-home-testimonials {
	background: var(--cream);
}
.kbc-home-testimonials__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.5rem, 2.5vw, 2rem);
}
.kbc-home-testimonial {
	background: var(--ivory);
	padding: clamp(2rem, 3vw, 2.5rem);
	border-radius: var(--radius);
	margin: 0;
	border: 1px solid var(--line-soft);
	display: flex; flex-direction: column; gap: 1rem;
	transition: transform 0.5s var(--ease-fluid), box-shadow 0.5s var(--ease-fluid);
}
.kbc-home-testimonial:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.kbc-home-testimonial__mark { color: var(--clay); display: block; }
.kbc-home-testimonial__mark--close { text-align: right; margin: 0.5rem 0 0.75rem; opacity: 0.6; }
.kbc-home-testimonial__quote {
	font-family: var(--font-serif);
	font-size: clamp(1.1rem, 1.4vw, 1.25rem);
	line-height: 1.5;
	margin: 0;
	color: var(--ink);
	flex: 1;
}
.kbc-home-testimonial__cite { display: flex; flex-direction: column; padding-top: 1rem; border-top: 1px solid var(--line-soft); }
.kbc-home-testimonial__cite strong { font-weight: 500; font-size: 0.95rem; color: var(--ink); }
.kbc-home-testimonial__cite span { font-size: 0.82rem; color: var(--muted); margin-top: 0.2rem; }

/* ---- Team grid ---- */
.kbc-home-team {
	background: var(--ivory);
}
.kbc-home-team__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(1.5rem, 2.5vw, 2.5rem);
}
.kbc-home-team__member {
	margin: 0;
	text-align: center;
	padding: 1.5rem 1rem;
	transition: transform 0.5s var(--ease-fluid);
}
.kbc-home-team__member:hover { transform: translateY(-4px); }
.kbc-home-team__photo {
	aspect-ratio: 1 / 1;
	width: 100%;
	max-width: 220px;
	margin: 0 auto 1.25rem;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--cream) 0%, var(--sand-soft) 100%);
	border: 1px solid var(--line-soft);
	display: grid; place-items: center;
	overflow: hidden;
	position: relative;
	transition: box-shadow 0.6s var(--ease-fluid);
}
.kbc-home-team__photo::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 25%, rgba(184,115,74,0.08), transparent 55%);
}
.kbc-home-team__member:hover .kbc-home-team__photo { box-shadow: var(--shadow); }
.kbc-home-team__photo img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.kbc-home-team__initials {
	font-family: var(--font-serif);
	font-size: clamp(2.5rem, 5vw, 3.5rem);
	color: var(--ink);
	letter-spacing: 0.02em;
	position: relative;
	font-weight: 400;
}
.kbc-home-team__name {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	font-weight: 500;
	margin: 0;
	color: var(--ink);
	letter-spacing: -0.005em;
}
.kbc-home-team__role {
	font-size: 0.85rem;
	color: var(--muted);
	margin: 0.35rem 0 0;
	line-height: 1.5;
}

/* ---- Available feature on home ---- */
.kbc-home-available {
	background: var(--cream);
}
.kbc-home-available__feature {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 0;
	background: var(--ivory);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--line-soft);
	box-shadow: var(--shadow-sm);
	align-items: stretch;
}
.kbc-home-available__media {
	position: relative;
	min-height: 440px;
	overflow: hidden;
	background: var(--sand);
	display: block;
}
.kbc-home-available__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.4s var(--ease-fluid); }
.kbc-home-available__media:hover img { transform: scale(1.04); }
.kbc-home-available__badge {
	position: absolute;
	top: 1.25rem; left: 1.25rem;
	background: var(--brand-dark);
	color: var(--ivory);
	padding: 0.4rem 0.9rem;
	border-radius: 999px;
	font-size: 0.7rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-weight: 500;
	box-shadow: var(--shadow-sm);
}
.kbc-home-available__body {
	padding: clamp(2rem, 3.5vw, 3rem);
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 1rem;
}
.kbc-home-available__title {
	font-family: var(--font-serif);
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	font-weight: 400;
	margin: 0;
	line-height: 1.1;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.kbc-home-available__location {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	color: var(--muted);
	font-size: 0.95rem;
	margin: 0;
}
.kbc-home-available__desc { color: var(--charcoal); font-size: 0.98rem; margin: 0; line-height: 1.7; }

.kbc-home-available__facts {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	margin: 0.5rem 0;
	border-top: 1px solid var(--line);
	border-left: 1px solid var(--line);
}
.kbc-home-available__facts > div {
	padding: 0.9rem 1.1rem;
	border-right: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}
.kbc-home-available__facts dt {
	font-size: 0.7rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0;
}
.kbc-home-available__facts dd {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	color: var(--ink);
	margin: 0;
	font-weight: 500;
	letter-spacing: -0.005em;
}

.kbc-home-available__actions {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	flex-wrap: wrap;
	margin-top: 0.5rem;
}

/* ---- Dark seller benefits band ---- */
.kbc-home-benefits {
	background: var(--brand-dark);
	color: var(--ivory);
	padding: clamp(2.5rem, 4.5vw, 4rem) 0;
	position: relative;
	overflow: hidden;
}
.kbc-home-benefits::before {
	content: '';
	position: absolute;
	inset: -40%;
	background: radial-gradient(circle at 85% 30%, rgba(184,115,74,0.16), transparent 50%);
	pointer-events: none;
}
.kbc-home-benefits__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1fr 1.35fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: start;
}
.kbc-home-benefits__copy { position: sticky; top: 140px; }
.kbc-home-benefits__copy .kbc-eyebrow { color: rgba(251,248,242,0.7); }
.kbc-home-benefits__copy .kbc-eyebrow::before { background: rgba(251,248,242,0.7); }
.kbc-home-benefits__title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4.5vw, 3.25rem);
	font-weight: 400;
	margin: 0 0 1rem;
	line-height: 1.1;
	color: var(--ivory);
	letter-spacing: -0.01em;
}
.kbc-home-benefits__lead {
	color: rgba(251,248,242,0.8);
	font-size: 1.05rem;
	line-height: 1.7;
	margin: 0 0 2rem;
	max-width: 34rem;
}
.kbc-home-benefits__copy .kbc-btn--primary {
	background: var(--ivory);
	color: var(--ink);
}
.kbc-home-benefits__copy .kbc-btn--primary:hover {
	background: var(--brand-darker);
	color: var(--ivory);
}
.kbc-home-benefits__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 0;
}
.kbc-home-benefits__list li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.75rem;
	padding: 1.75rem 0;
	border-top: 1px solid rgba(251,248,242,0.18);
	transition: padding-left 0.4s var(--ease-fluid), border-color 0.4s;
}
.kbc-home-benefits__list li:last-child { border-bottom: 1px solid rgba(251,248,242,0.18); }
.kbc-home-benefits__list li:hover {
	padding-left: 1rem;
	border-top-color: var(--clay);
}
.kbc-home-benefits__num {
	font-family: var(--font-serif);
	font-size: 2rem;
	color: var(--clay);
	line-height: 1;
	font-weight: 400;
	letter-spacing: -0.01em;
	padding-top: 0.2rem;
}
.kbc-home-benefits__list strong {
	display: block;
	font-family: var(--font-serif);
	font-size: 1.4rem;
	color: var(--ivory);
	font-weight: 500;
	margin-bottom: 0.35rem;
	letter-spacing: -0.005em;
}
.kbc-home-benefits__list p {
	margin: 0;
	color: rgba(251,248,242,0.72);
	font-size: 0.95rem;
	line-height: 1.6;
}

/* ---- Homepage responsive ---- */
@media (max-width: 1024px) {
	.kbc-welcome__pillars { grid-template-columns: repeat(2, 1fr); }
	.kbc-welcome__pillars li:nth-child(3) { border-left: 0; border-top: 1px solid var(--line-soft); }
	.kbc-welcome__pillars li:nth-child(4) { border-top: 1px solid var(--line-soft); }
	.kbc-home-upcoming__feature,
	.kbc-home-available__feature,
	.kbc-home-benefits__inner { grid-template-columns: 1fr; }
	.kbc-home-upcoming__media,
	.kbc-home-available__media { min-height: 340px; }
	.kbc-home-benefits__copy { position: static; }
	.kbc-home-testimonials__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
	.kbc-welcome__pillars { grid-template-columns: 1fr; }
	.kbc-welcome__pillars li + li { border-left: 0; border-top: 1px solid var(--line-soft); }
	.kbc-home-section__head { flex-direction: column; align-items: flex-start; }
	.kbc-home-testimonials__grid { grid-template-columns: 1fr; }
	.kbc-home-available__facts { grid-template-columns: 1fr; }
	.kbc-home-benefits__list li { padding: 1.25rem 0; gap: 1rem; }
}

/* ==========================================================================
   Animation system — editorial, choreographed, cascading.

   Entry points:
   · .kbc-reveal         → fade + rise, cascading via --kbc-reveal-delay (set by JS)
   · .kbc-reveal-text    → wrap headings; child slides up from 110% Y inside a mask
   · .kbc-reveal-image   → image scales from 1.06 with an inset clip (curtain-in)
   · .kbc-stagger > *    → direct children each get a 70-90ms stagger (nth-child)
   · .kbc-hero-enter     → body class; runs the hero choreography on page load
   ========================================================================== */

/* Fade + rise (default reveal) */
.kbc-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition:
		opacity 1.2s var(--ease-fluid),
		transform 1.2s var(--ease-fluid);
	transition-delay: var(--kbc-reveal-delay, 0ms);
	will-change: opacity, transform;
}
.kbc-reveal.is-in { opacity: 1; transform: none; }

/* Heading mask reveal — wrap any H1/H2/H3 with `.kbc-reveal-text` to get
   the slide-up-from-behind-a-mask effect. */
.kbc-reveal-text {
	display: inline-block;
	overflow: hidden;
	vertical-align: bottom;
	padding-bottom: 0.08em;
}
.kbc-reveal-text__inner {
	display: inline-block;
	transform: translateY(105%);
	transition: transform 1.2s var(--ease-fluid);
	transition-delay: var(--kbc-reveal-delay, 0ms);
	will-change: transform;
}
.kbc-reveal-text.is-in .kbc-reveal-text__inner { transform: translateY(0); }

/* Image curtain reveal — clip-path inset + subtle zoom-out. */
.kbc-reveal-image {
	opacity: 0;
	transform: scale(1.06);
	clip-path: inset(8% 4% 8% 4%);
	-webkit-clip-path: inset(8% 4% 8% 4%);
	transition:
		opacity 1.6s var(--ease-fluid),
		transform 1.8s var(--ease-fluid),
		clip-path 1.6s var(--ease-fluid),
		-webkit-clip-path 1.6s var(--ease-fluid);
	transition-delay: var(--kbc-reveal-delay, 0ms);
	will-change: opacity, transform, clip-path;
}
.kbc-reveal-image.is-in {
	opacity: 1;
	transform: scale(1);
	clip-path: inset(0);
	-webkit-clip-path: inset(0);
}

/* Stagger direct children (e.g. grids of cards) via nth-child delays.
   Works when the parent has .kbc-stagger AND each child has .kbc-reveal. */
.kbc-stagger > *:nth-child(1) { --kbc-reveal-delay: 0ms; }
.kbc-stagger > *:nth-child(2) { --kbc-reveal-delay: 80ms; }
.kbc-stagger > *:nth-child(3) { --kbc-reveal-delay: 160ms; }
.kbc-stagger > *:nth-child(4) { --kbc-reveal-delay: 240ms; }
.kbc-stagger > *:nth-child(5) { --kbc-reveal-delay: 320ms; }
.kbc-stagger > *:nth-child(6) { --kbc-reveal-delay: 400ms; }
.kbc-stagger > *:nth-child(7) { --kbc-reveal-delay: 460ms; }
.kbc-stagger > *:nth-child(8) { --kbc-reveal-delay: 520ms; }
.kbc-stagger > *:nth-child(9) { --kbc-reveal-delay: 580ms; }
.kbc-stagger > *:nth-child(10) { --kbc-reveal-delay: 640ms; }
.kbc-stagger > *:nth-child(n+11) { --kbc-reveal-delay: 700ms; }

/* ---- Hero enter sequence (runs on page load via body.kbc-loaded) ----
   Paints in the eyebrow → title → lead → actions → visual on first load,
   without waiting for scroll. */
body:not(.kbc-loaded) .kbc-hero__copy > *,
body:not(.kbc-loaded) .kbc-hero__visual,
body:not(.kbc-loaded) .kbc-philo-hero__copy > *,
body:not(.kbc-loaded) .kbc-philo-hero__visual,
body:not(.kbc-loaded) .kbc-why-hero__copy > *,
body:not(.kbc-loaded) .kbc-why-hero__visual,
body:not(.kbc-loaded) .kbc-lots-hero__copy > *,
body:not(.kbc-loaded) .kbc-lots-hero__visual,
body:not(.kbc-loaded) .kbc-avail-hero__copy > *,
body:not(.kbc-loaded) .kbc-avail-hero__counter,
body:not(.kbc-loaded) .kbc-fin-hero__copy > *,
body:not(.kbc-loaded) .kbc-fin-hero__stack,
body:not(.kbc-loaded) .kbc-up-hero__copy > *,
body:not(.kbc-loaded) .kbc-up-hero__panel,
body:not(.kbc-loaded) .kbc-prop-hero__top,
body:not(.kbc-loaded) .kbc-prop-hero__bottom {
	opacity: 0;
	transform: translateY(22px);
}

body.kbc-loaded .kbc-hero__copy > *,
body.kbc-loaded .kbc-hero__visual,
body.kbc-loaded .kbc-philo-hero__copy > *,
body.kbc-loaded .kbc-philo-hero__visual,
body.kbc-loaded .kbc-why-hero__copy > *,
body.kbc-loaded .kbc-why-hero__visual,
body.kbc-loaded .kbc-lots-hero__copy > *,
body.kbc-loaded .kbc-lots-hero__visual,
body.kbc-loaded .kbc-avail-hero__copy > *,
body.kbc-loaded .kbc-avail-hero__counter,
body.kbc-loaded .kbc-fin-hero__copy > *,
body.kbc-loaded .kbc-fin-hero__stack,
body.kbc-loaded .kbc-up-hero__copy > *,
body.kbc-loaded .kbc-up-hero__panel,
body.kbc-loaded .kbc-prop-hero__top,
body.kbc-loaded .kbc-prop-hero__bottom {
	opacity: 1;
	transform: none;
	transition:
		opacity 1.1s var(--ease-fluid),
		transform 1.1s var(--ease-fluid);
}

/* Cascade hero inner items */
body.kbc-loaded .kbc-hero__copy > *:nth-child(1),
body.kbc-loaded .kbc-philo-hero__copy > *:nth-child(1),
body.kbc-loaded .kbc-why-hero__copy > *:nth-child(1),
body.kbc-loaded .kbc-lots-hero__copy > *:nth-child(1),
body.kbc-loaded .kbc-avail-hero__copy > *:nth-child(1),
body.kbc-loaded .kbc-fin-hero__copy > *:nth-child(1),
body.kbc-loaded .kbc-up-hero__copy > *:nth-child(1),
body.kbc-loaded .kbc-prop-hero__top { transition-delay: 0.05s; }

body.kbc-loaded .kbc-hero__copy > *:nth-child(2),
body.kbc-loaded .kbc-philo-hero__copy > *:nth-child(2),
body.kbc-loaded .kbc-why-hero__copy > *:nth-child(2),
body.kbc-loaded .kbc-lots-hero__copy > *:nth-child(2),
body.kbc-loaded .kbc-avail-hero__copy > *:nth-child(2),
body.kbc-loaded .kbc-fin-hero__copy > *:nth-child(2),
body.kbc-loaded .kbc-up-hero__copy > *:nth-child(2) { transition-delay: 0.18s; }

body.kbc-loaded .kbc-hero__copy > *:nth-child(3),
body.kbc-loaded .kbc-philo-hero__copy > *:nth-child(3),
body.kbc-loaded .kbc-why-hero__copy > *:nth-child(3),
body.kbc-loaded .kbc-lots-hero__copy > *:nth-child(3),
body.kbc-loaded .kbc-avail-hero__copy > *:nth-child(3),
body.kbc-loaded .kbc-fin-hero__copy > *:nth-child(3),
body.kbc-loaded .kbc-up-hero__copy > *:nth-child(3) { transition-delay: 0.3s; }

body.kbc-loaded .kbc-hero__copy > *:nth-child(4),
body.kbc-loaded .kbc-philo-hero__copy > *:nth-child(4),
body.kbc-loaded .kbc-why-hero__copy > *:nth-child(4),
body.kbc-loaded .kbc-lots-hero__copy > *:nth-child(4),
body.kbc-loaded .kbc-avail-hero__copy > *:nth-child(4),
body.kbc-loaded .kbc-fin-hero__copy > *:nth-child(4),
body.kbc-loaded .kbc-up-hero__copy > *:nth-child(4) { transition-delay: 0.42s; }

body.kbc-loaded .kbc-hero__copy > *:nth-child(n+5),
body.kbc-loaded .kbc-philo-hero__copy > *:nth-child(n+5),
body.kbc-loaded .kbc-why-hero__copy > *:nth-child(n+5),
body.kbc-loaded .kbc-lots-hero__copy > *:nth-child(n+5),
body.kbc-loaded .kbc-avail-hero__copy > *:nth-child(n+5),
body.kbc-loaded .kbc-fin-hero__copy > *:nth-child(n+5),
body.kbc-loaded .kbc-up-hero__copy > *:nth-child(n+5) { transition-delay: 0.55s; }

/* Hero visuals arrive last with a gentle scale */
body:not(.kbc-loaded) .kbc-hero__visual,
body:not(.kbc-loaded) .kbc-philo-hero__visual,
body:not(.kbc-loaded) .kbc-why-hero__visual,
body:not(.kbc-loaded) .kbc-lots-hero__visual,
body:not(.kbc-loaded) .kbc-fin-hero__stack,
body:not(.kbc-loaded) .kbc-avail-hero__counter,
body:not(.kbc-loaded) .kbc-up-hero__panel {
	transform: translateY(30px) scale(0.97);
}
body.kbc-loaded .kbc-hero__visual,
body.kbc-loaded .kbc-philo-hero__visual,
body.kbc-loaded .kbc-why-hero__visual,
body.kbc-loaded .kbc-lots-hero__visual,
body.kbc-loaded .kbc-fin-hero__stack,
body.kbc-loaded .kbc-avail-hero__counter,
body.kbc-loaded .kbc-up-hero__panel {
	transform: none;
	transition:
		opacity 1.4s var(--ease-fluid) 0.2s,
		transform 1.4s var(--ease-fluid) 0.2s;
}

/* ---- Smoother slider transitions (richer crossfade with motion) ---- */
.kbc-project-card__slide {
	transition:
		opacity 1s var(--ease-fluid),
		visibility 0s linear 1s,
		transform 1.4s var(--ease-fluid);
	transform: scale(1.02);
}
.kbc-project-card__slide.is-active {
	transform: scale(1);
	transition:
		opacity 1s var(--ease-fluid),
		visibility 0s,
		transform 1.4s var(--ease-fluid);
}

/* ---- Count-up marker (JS handles the actual number change) ---- */
.kbc-count-up { font-variant-numeric: tabular-nums; }

/* ---- Page transition: tiny section fade as you enter each ---- */
@keyframes kbcSectionFade {
	from { opacity: 0; transform: translateY(16px); }
	to   { opacity: 1; transform: none; }
}

/* ---- Reduced motion: honor user preference ---- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
	}
	.kbc-reveal,
	.kbc-reveal-text__inner,
	.kbc-reveal-image { opacity: 1; transform: none; clip-path: none; -webkit-clip-path: none; }
	body:not(.kbc-loaded) *,
	body.kbc-loaded * { opacity: 1 !important; transform: none !important; }
}
