/**
 * Find a Builder — directory layout (sidebar + Google Map).
 * Loaded only on the builder archive.
 */

.sc-bdir {
	--bdir-primary: #1A2E26;
	--bdir-primary-hover: #243f35;
	--bdir-secondary: #A67C52;
	--bdir-bg: #F9F8F6;
	--bdir-surface: #ffffff;
	--bdir-border: #e5e7eb;
	--bdir-border-soft: #f1f1ee;
	--bdir-text: #1f2937;
	--bdir-text-muted: #64748b;
	--bdir-text-faint: #94a3b8;
	--bdir-radius: 0.5rem;
	--bdir-sidebar-w: 460px;
	--bdir-h: calc(100vh - 80px);

	display: flex;
	flex-direction: row;
	width: 100%;
	height: var(--bdir-h);
	min-height: 600px;
	background: var(--bdir-bg);
	color: var(--bdir-text);
	font-family: 'Inter', system-ui, -apple-system, sans-serif;
	overflow: hidden;
	position: relative;
}

/* === Sidebar === */
.sc-bdir__sidebar {
	width: var(--bdir-sidebar-w);
	flex: 0 0 var(--bdir-sidebar-w);
	background: var(--bdir-surface);
	border-right: 1px solid var(--bdir-border);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	z-index: 2;
}

.sc-bdir__intro {
	padding: 1.5rem 1.5rem 1rem;
	border-bottom: 1px solid var(--bdir-border-soft);
	flex-shrink: 0;
}

.sc-bdir__breadcrumbs {
	display: flex;
	gap: 0.5rem;
	font-size: 0.7rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--bdir-text-faint);
	margin-bottom: 0.75rem;
	font-weight: 600;
}

.sc-bdir__breadcrumbs a {
	color: var(--bdir-text-faint);
	text-decoration: none;
}

.sc-bdir__breadcrumbs a:hover {
	color: var(--bdir-primary);
}

.sc-bdir__breadcrumbs span[aria-current] {
	color: var(--bdir-primary);
}

.sc-bdir__title {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 1.875rem;
	font-weight: 700;
	color: var(--bdir-primary);
	margin: 0 0 0.5rem;
	line-height: 1.15;
}

.sc-bdir__lede {
	color: var(--bdir-text-muted);
	font-size: 0.875rem;
	line-height: 1.5;
	margin: 0 0 1.25rem;
}

.sc-bdir__search {
	position: relative;
	margin-bottom: 1rem;
}

.sc-bdir__search-icon {
	position: absolute;
	left: 0.85rem;
	top: 50%;
	transform: translateY(-50%);
	color: var(--bdir-text-faint);
	pointer-events: none;
	display: inline-flex;
	width: 18px;
	height: 18px;
}

.sc-bdir__search input {
	width: 100%;
	padding: 0.75rem 0.85rem 0.75rem 2.5rem;
	background: #f8fafc;
	border: 1px solid var(--bdir-border);
	border-radius: var(--bdir-radius);
	font-size: 0.875rem;
	font-family: inherit;
	color: var(--bdir-text);
	outline: none;
	transition: border-color 120ms, box-shadow 120ms, background 120ms;
}

.sc-bdir__search input:focus {
	background: #fff;
	border-color: var(--bdir-primary);
	box-shadow: 0 0 0 3px rgba(26, 46, 38, 0.12);
}

.sc-bdir__chips {
	display: flex;
	gap: 0.5rem;
	overflow-x: auto;
	padding-bottom: 0.25rem;
	scrollbar-width: none;
	-ms-overflow-style: none;
}

.sc-bdir__chips::-webkit-scrollbar {
	display: none;
}

.sc-bdir__chip {
	white-space: nowrap;
	padding: 0.45rem 0.95rem;
	background: #f1f5f9;
	color: #334155;
	font-size: 0.75rem;
	font-weight: 600;
	border: 0;
	border-radius: 9999px;
	cursor: pointer;
	transition: background 120ms, color 120ms, box-shadow 120ms;
	font-family: inherit;
}

.sc-bdir__chip:hover {
	background: #e2e8f0;
}

.sc-bdir__chip.is-active {
	background: var(--bdir-primary);
	color: #fff;
	box-shadow: 0 2px 8px rgba(26, 46, 38, 0.18);
}

.sc-bdir__results-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.85rem 1.5rem;
	border-bottom: 1px solid var(--bdir-border-soft);
	flex-shrink: 0;
}

.sc-bdir__results-count {
	font-size: 0.8rem;
	font-weight: 500;
	color: var(--bdir-text-muted);
}

.sc-bdir__sort {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--bdir-primary);
	background: transparent;
	border: 0;
	cursor: pointer;
	font-family: inherit;
	padding: 0.25rem 0;
}

.sc-bdir__list {
	flex: 1 1 auto;
	overflow-y: auto;
	padding-bottom: 4rem;
}

.sc-bdir__list-empty {
	padding: 3rem 1.5rem;
	text-align: center;
	color: var(--bdir-text-muted);
	font-size: 0.9rem;
}

.sc-bdir__cta {
	position: absolute;
	bottom: 0;
	left: 0;
	width: var(--bdir-sidebar-w);
	padding: 0.85rem 1.5rem;
	background: var(--bdir-bg);
	border-top: 1px solid var(--bdir-border);
	font-size: 0.65rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 700;
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 3;
}

.sc-bdir__cta-label {
	color: var(--bdir-text-muted);
}

.sc-bdir__cta a {
	color: var(--bdir-primary);
	text-decoration: underline;
	text-underline-offset: 4px;
	text-decoration-thickness: 2px;
}

/* === Card === */
.sc-bdir-card {
	display: block;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid var(--bdir-border-soft);
	cursor: pointer;
	transition: background 120ms;
	color: inherit;
	text-decoration: none;
}

.sc-bdir-card:hover,
.sc-bdir-card.is-active {
	background: #fafaf8;
}

.sc-bdir-card.is-hidden {
	display: none;
}

.sc-bdir-card__top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 1rem;
	margin-bottom: 0.65rem;
}

.sc-bdir-card__heading {
	flex: 1 1 auto;
	min-width: 0;
}

.sc-bdir-card__title {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--bdir-text);
	margin: 0 0 0.35rem;
	line-height: 1.25;
	transition: color 120ms;
}

.sc-bdir-card:hover .sc-bdir-card__title,
.sc-bdir-card.is-active .sc-bdir-card__title {
	color: var(--bdir-primary);
}

.sc-bdir-card__region {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--bdir-text-muted);
}

.sc-bdir-card__region svg {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

.sc-bdir-card__logo-wrap {
	flex: 0 0 64px;
	width: 64px;
	height: 64px;
	background: #f1f5f9;
	border-radius: var(--bdir-radius);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sc-bdir-card__logo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.9;
	transition: opacity 120ms;
}

.sc-bdir-card:hover .sc-bdir-card__logo {
	opacity: 1;
}

.sc-bdir-card__logo-placeholder {
	color: var(--bdir-text-faint);
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 1.5rem;
	font-weight: 700;
}

.sc-bdir-card__excerpt {
	font-size: 0.85rem;
	line-height: 1.5;
	color: var(--bdir-text-muted);
	margin: 0 0 1rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.sc-bdir-card__services {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0 0 1rem;
}

.sc-bdir-card__service {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.7rem;
	font-weight: 600;
	color: var(--bdir-text-muted);
}

.sc-bdir-card__service svg {
	width: 14px;
	height: 14px;
}

.sc-bdir-card__cta {
	display: block;
	width: 100%;
	padding: 0.65rem 1rem;
	background: var(--bdir-primary);
	color: #fff;
	border: 0;
	border-radius: var(--bdir-radius);
	font-size: 0.8rem;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	font-family: inherit;
	cursor: pointer;
	transition: background 120ms, transform 120ms;
}

.sc-bdir-card__cta:hover {
	background: var(--bdir-primary-hover);
	color: #fff;
}

.sc-bdir-card.is-tier-featured .sc-bdir-card__title::after,
.sc-bdir-card.is-tier-premium .sc-bdir-card__title::after {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	margin-left: 0.45rem;
	border-radius: 9999px;
	background: var(--bdir-secondary);
	vertical-align: middle;
}

/* === Map === */
.sc-bdir__map {
	flex: 1 1 auto;
	position: relative;
	background: #e6e9ec;
	min-height: 0;
}

.sc-bdir__map-canvas {
	position: absolute;
	inset: 0;
}

.sc-bdir__map-fallback {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 0.75rem;
	padding: 2rem;
	text-align: center;
	color: var(--bdir-text-muted);
	background: linear-gradient(to bottom, rgba(26, 46, 38, 0.04), rgba(26, 46, 38, 0.08));
}

.sc-bdir__map-fallback strong {
	color: var(--bdir-primary);
	font-size: 1rem;
}

/* Info window */
.sc-bdir__iw {
	font-family: 'Inter', system-ui, sans-serif;
	min-width: 180px;
	max-width: 220px;
}

.sc-bdir__iw-title {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 1rem;
	font-weight: 700;
	color: var(--bdir-primary);
	margin: 0 0 0.35rem;
}

.sc-bdir__iw-region {
	font-size: 0.75rem;
	color: var(--bdir-text-muted);
	margin: 0 0 0.65rem;
}

.sc-bdir__iw-link {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--bdir-primary);
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* === Mobile toggle === */
.sc-bdir__list-toggle {
	display: none;
	position: absolute;
	bottom: 1.25rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 4;
	padding: 0.75rem 1.5rem;
	background: var(--bdir-primary);
	color: #fff;
	border: 0;
	border-radius: 9999px;
	font-size: 0.85rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	box-shadow: 0 8px 24px rgba(26, 46, 38, 0.35);
	display: none;
	align-items: center;
	gap: 0.4rem;
}

.sc-bdir__list-toggle svg {
	width: 18px;
	height: 18px;
}

/* === Responsive === */
@media (max-width: 1023px) {
	.sc-bdir {
		flex-direction: column;
		--bdir-h: calc(100vh - 80px);
	}

	.sc-bdir__sidebar {
		width: 100%;
		flex: 0 0 auto;
		max-height: 60%;
		border-right: 0;
		border-bottom: 1px solid var(--bdir-border);
		transform: translateY(100%);
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		top: auto;
		max-height: 75%;
		transition: transform 220ms ease;
		z-index: 5;
		box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.12);
	}

	.sc-bdir.is-list-open .sc-bdir__sidebar {
		transform: translateY(0);
	}

	.sc-bdir__cta {
		width: 100%;
	}

	.sc-bdir__list-toggle {
		display: inline-flex;
	}

	.sc-bdir.is-list-open .sc-bdir__list-toggle .sc-bdir__list-toggle-show {
		display: none;
	}

	.sc-bdir:not(.is-list-open) .sc-bdir__list-toggle .sc-bdir__list-toggle-hide {
		display: none;
	}

	.sc-bdir__map {
		flex: 1 1 auto;
		min-height: 320px;
	}
}

@media (max-width: 480px) {
	.sc-bdir__intro {
		padding: 1.25rem 1.25rem 0.75rem;
	}

	.sc-bdir__title {
		font-size: 1.5rem;
	}

	.sc-bdir-card {
		padding: 1.1rem 1.25rem;
	}

	.sc-bdir__cta {
		padding: 0.75rem 1.25rem;
	}
}
