/*
Theme Name: Band Baja
Description: Minimal theme for Elementor; enqueues display fonts (Arapey, Raleway).
Version: 1.0.12
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
Text Domain: bandbaja
*/

/* Full-bleed base — remove default browser / wrapper gaps around Elementor */
html {
	margin: 0;
	padding: 0;
	width: 100%;
	max-width: 100%;
	overflow-x: clip;
}

body {
	margin: 0;
	padding: 0;
	width: 100%;
	max-width: 100%;
	overflow-x: clip;
	font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
.elementor-heading-title,
.elementor-image-box-title {
	font-family: "Arapey", Sans-serif !important;
}

/* Theme fallback template (non-Canvas pages) */
.site-main {
	margin: 0;
	padding: 0;
	max-width: none;
	width: 100%;
}

/* Elementor root: avoid outer horizontal inset from kit/theme */
.elementor-page .elementor {
	margin-left: 0;
	margin-right: 0;
}

/* —— Global header: transparent → solid on scroll —— */
.bandbaja-site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
	background: transparent;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	transition:
		background-color 0.35s ease,
		box-shadow 0.35s ease,
		border-color 0.35s ease,
		backdrop-filter 0.35s ease;
	border-bottom: 1px solid transparent;
	box-shadow: none;
}

.admin-bar .bandbaja-site-header {
	top: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .bandbaja-site-header {
		top: 46px;
	}
}

.bandbaja-site-header.is-scrolled {
	background:
		linear-gradient(180deg, rgba(33, 24, 11, 0.74) 0%, rgba(23, 16, 8, 0.58) 100%);
	backdrop-filter: blur(24px) saturate(170%);
	-webkit-backdrop-filter: blur(24px) saturate(170%);
	box-shadow:
		0 18px 55px rgba(0, 0, 0, 0.18),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
	border-bottom-color: rgba(255, 255, 255, 0.14);
}

.bandbaja-site-header .hero-nav {
	position: relative;
	width: 100%;
}

.bandbaja-site-header .hero-nav-inner {
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	align-items: center;
	min-height: 78px;
	padding: 14px 24px;
	column-gap: 24px;
}

.bandbaja-site-header .hero-nav-start {
	justify-self: start;
}

.bandbaja-site-header .hero-nav-panel {
	display: contents;
}

.bandbaja-site-header .hero-nav-center {
	justify-self: center;
}

.bandbaja-site-header .hero-nav-end {
	justify-self: end;
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.bandbaja-site-header .hero-nav-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
	width: 48px;
	height: 48px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.18);
	color: #fff;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.bandbaja-site-header .hero-nav-mobile-cta {
	display: none;
	align-items: center;
	justify-content: center;
	padding: 11px 16px;
	border-radius: 999px;
	background: #d4af37;
	color: #0c0e16 !important;
	font-family: "Inter", sans-serif;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	white-space: nowrap;
}

.bandbaja-site-header .hero-nav-toggle:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.35);
}

.bandbaja-site-header .hero-nav-toggle-line {
	display: block;
	width: 18px;
	height: 2px;
	border-radius: 999px;
	background: currentColor;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

/* Brand */
.bandbaja-site-header .hero-nav-brand {
	display: inline-flex;
	align-items: center;
	color: #fff !important;
	text-decoration: none;
	transition: color 0.25s ease, opacity 0.25s ease;
}

.bandbaja-site-header .hero-nav-brand-image {
	display: block;
	width: auto;
	height: 50px;
	max-height: 50px;
	max-width: min(300px, 28vw);
	filter: drop-shadow(0 1px 10px rgba(0, 0, 0, 0.18));
}

.bandbaja-site-header .hero-nav-brand:hover {
	opacity: 0.9;
}

/* Nav links (center) */
.bandbaja-site-header .hero-nav-menu {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(12px, 2.5vw, 28px);
	list-style: none;
	margin: 0;
	padding: 0;
	flex-wrap: wrap;
}

.bandbaja-site-header .hero-nav-menu a {
	color: #fff;
	text-decoration: none;
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	font-weight: 500;
	text-transform: none;
	letter-spacing: -0.01em;
	transition: color 0.2s ease;
	text-shadow: 0 1px 10px rgba(0, 0, 0, 0.35);
}

.bandbaja-site-header .hero-nav-menu a:hover,
.bandbaja-site-header .hero-nav-menu .current-menu-item > a,
.bandbaja-site-header .hero-nav-menu .current_page_item > a {
	color: #d4af37;
}

.home .bandbaja-site-header .hero-nav-menu > li:first-child > a {
	color: #d4af37;
}

.bandbaja-site-header .hero-nav-menu li {
	position: relative;
	margin: 0;
	padding: 0;
}

/* Phone — outline pill */
.bandbaja-site-header .hero-nav-phone-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 18px;
	border: 1px solid #d4af37;
	border-radius: 999px;
	color: #fff !important;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
	letter-spacing: -0.01em;
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
	text-shadow: none;
	background: rgba(0, 0, 0, 0.15);
}

.bandbaja-site-header .hero-nav-phone-btn:hover {
	background: rgba(212, 175, 55, 0.15);
	color: #fff !important;
}

.bandbaja-site-header .hero-nav-phone-icon {
	flex-shrink: 0;
	color: #fff;
}

/* Primary CTA — solid */
.bandbaja-site-header .hero-nav-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 13px 24px;
	border-radius: 999px;
	background: #d4af37 !important;
	color: #0c0e16 !important;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: -0.01em;
	border: none;
	text-shadow: none;
	transition: background-color 0.2s ease, color 0.2s ease, transform 0.15s ease;
}

.bandbaja-site-header .hero-nav-cta:hover {
	background: #e0bc4f !important;
	color: #0c0e16 !important;
}

/* Scrolled: slightly calmer shadows on links */
.bandbaja-site-header.is-scrolled .hero-nav-brand {
	text-shadow: none;
}

.bandbaja-site-header.is-scrolled .hero-nav-menu a {
	text-shadow: none;
}

/* Hero outer container (Elementor) — keep centered layout */
.elementor-6 .elementor-element-03d1afd.e-con.e-parent {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

/*
 * Homepage layout + hero CTAs (Elementor post ID 6).
 *
 * Scope with .elementor-6 (the `.elementor.elementor-6` root) so rules apply in the
 * Elementor preview iframe even when body classes differ, and after Elementor’s post CSS
 * in the cascade (see bandbaja_enqueue_theme_stylesheet priority + elementor-post-* dep).
 *
 * Editor vs live: iframe width, responsive preview mode, and editor-preview.css still differ slightly.
 */

/* Hero title & tagline — Arapey (matches enqueued Google font) */
.elementor-6 .elementor-element-7486e3f .elementor-heading-title {
	font-family: "Arapey", sans-serif;
	font-weight: 400;
	font-style: normal;
}

.elementor-6 .elementor-element-1226f4a h2,
.elementor-6 .elementor-element-1226f4a .elementor-heading-title {
	font-family: "Arapey", sans-serif;
	font-weight: 400;
	font-style: normal;
}

.elementor-6 .elementor-element-2c23272 {
	width: fit-content !important;
	max-width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
	box-sizing: border-box !important;
}

.elementor-6 .elementor-element-2c23272 .elementor-widget-button {
	width: auto !important;
	max-width: none !important;
	flex: 0 0 auto !important;
}

/*
 * Hero CTAs (Elementor button widgets): Site Kit “accent” / other globals can tint these
 * orange on hover or idle. Lock to the gradient + ghost styles from the page design.
 */
.elementor-6 .elementor-element-1959d20 .elementor-button,
.elementor-6 .elementor-element-1959d20 .elementor-button:hover,
.elementor-6 .elementor-element-1959d20 .elementor-button:focus,
.elementor-6 .elementor-element-1959d20 .elementor-button:focus-visible,
.elementor-6 .elementor-element-1959d20 .elementor-button:active,
.elementor-6 .elementor-element-1959d20 .elementor-button:visited {
	background-color: transparent !important;
	background-image: linear-gradient(90deg, #c4b5fd 0%, #6d28d9 100%) !important;
	color: #ffffff !important;
	fill: #ffffff !important;
	box-shadow: 0 4px 24px 0 rgba(124, 58, 237, 0.35) !important;
	border: none !important;
}

.elementor-6 .elementor-element-1959d20 .elementor-button:hover,
.elementor-6 .elementor-element-1959d20 .elementor-button:focus-visible {
	filter: brightness(1.07);
}

.elementor-6 .elementor-element-37c13b7 .elementor-button,
.elementor-6 .elementor-element-37c13b7 .elementor-button:hover,
.elementor-6 .elementor-element-37c13b7 .elementor-button:focus,
.elementor-6 .elementor-element-37c13b7 .elementor-button:focus-visible,
.elementor-6 .elementor-element-37c13b7 .elementor-button:active,
.elementor-6 .elementor-element-37c13b7 .elementor-button:visited {
	background-color: rgba(255, 255, 255, 0.08) !important;
	background-image: none !important;
	color: #ffffff !important;
	fill: #ffffff !important;
	border: 1px solid rgba(255, 255, 255, 0.35) !important;
	box-shadow: none !important;
}

.elementor-6 .elementor-element-37c13b7 .elementor-button:hover,
.elementor-6 .elementor-element-37c13b7 .elementor-button:focus-visible {
	background-color: rgba(255, 255, 255, 0.14) !important;
}

.elementor-6 .elementor-element-73db732 {
	width: 100% !important;
	max-width: min(100%, 72rem) !important;
	margin-left: auto !important;
	margin-right: auto !important;
	box-sizing: border-box !important;
}

@media screen and (min-width: 901px) {
	.elementor-6 .elementor-element-73db732 {
		grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	}

	.elementor-6 .elementor-element-73db732 .elementor-widget-heading .elementor-heading-title {
		white-space: nowrap;
	}
}

/*
 * Press logos row: full-width flex containers use justify-content: var(--justify-content).
 * Avoid overflow-x: auto on the same flex box — in browsers this triggers "safe" alignment
 * and the row snaps to the left.
 *
 * The logos container sits inside a column flex parent (f13331b). Column + align-items
 * stretch/start keeps shrink-wrapped rows on the left; margin-left/right alone can lose
 * to Elementor’s margin-inline-* on .e-con. Fix: align-self: center + logical auto margins.
 */
.elementor-6 .elementor-element-e248b56 {
	--flex-wrap: nowrap !important;
	--flex-wrap-mobile: nowrap !important;
	--justify-content: center !important;
	--container-widget-flex-grow: 0 !important;
	--container-widget-align-self: center !important;
	--align-self: center !important;
	align-self: center !important;
	width: fit-content !important;
	max-width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
	margin-inline-start: auto !important;
	margin-inline-end: auto !important;
	box-sizing: border-box !important;
	justify-content: center !important;
	align-items: center !important;
	gap: clamp(0.5rem, 1.8vw, 1.25rem) !important;
}

.elementor-6 .elementor-element-e248b56.e-con.e-flex > .e-con-inner {
	--justify-content: center !important;
	justify-content: center !important;
	align-items: center !important;
	flex-wrap: nowrap !important;
	gap: clamp(0.5rem, 1.8vw, 1.25rem) !important;
}

.elementor-6 .elementor-element-e248b56 > .elementor-element,
.elementor-6 .elementor-element-e248b56 > .e-con-inner > .elementor-element {
	flex: 0 0 auto !important;
	--flex-grow: 0 !important;
}

.elementor-6 .elementor-element-e248b56 .elementor-widget-heading .elementor-heading-title {
	white-space: nowrap;
}

/* VOGUE + INDIA: single inline cluster so the row doesn’t wrap */
.elementor-6 .elementor-element-2ed68c3 {
	--flex-wrap: nowrap !important;
	--flex-wrap-mobile: nowrap !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: baseline !important;
	gap: 0.35em !important;
}

.elementor-6 .elementor-element-2ed68c3 > .elementor-element {
	flex: 0 0 auto;
}

@media screen and (max-width: 900px) {
	.bandbaja-site-header .hero-nav-inner {
		position: relative;
		grid-template-columns: minmax(0, 1fr) auto auto;
		justify-items: stretch;
		min-height: 40px;
		column-gap: 10px;
		padding: 12px 18px;
		text-align: left;
	}

	.bandbaja-site-header .hero-nav-start {
		justify-self: start;
	}

	.bandbaja-site-header .hero-nav-toggle {
		display: inline-flex;
		justify-self: end;
	}

	.bandbaja-site-header .hero-nav-mobile-cta {
		display: inline-flex;
		justify-self: end;
	}

	.bandbaja-site-header .hero-nav-brand {
		justify-content: flex-start;
	}

	.bandbaja-site-header .hero-nav-brand-image {
		height: 44px;
		max-width: min(210px, 60vw);
	}

	.bandbaja-site-header .hero-nav-panel {
		display: none;
		position: absolute;
		top: calc(100% + 12px);
		left: 18px;
		right: 18px;
		z-index: 30;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: 18px;
		border: 1px solid rgba(255, 255, 255, 0.12);
		border-radius: 24px;
		background: linear-gradient(180deg, rgba(12, 14, 24, 0.92) 0%, rgba(12, 14, 24, 0.84) 100%);
		box-shadow: 0 18px 48px rgba(0, 0, 0, 0.22);
	}

	.bandbaja-site-header.is-menu-open .hero-nav-panel {
		display: flex;
	}

	.bandbaja-site-header.is-menu-open .hero-nav-toggle-line:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
	}

	.bandbaja-site-header.is-menu-open .hero-nav-toggle-line:nth-child(2) {
		opacity: 0;
	}

	.bandbaja-site-header.is-menu-open .hero-nav-toggle-line:nth-child(3) {
		transform: translateY(-7px) rotate(-45deg);
	}

	.bandbaja-site-header .hero-nav-center,
	.bandbaja-site-header .hero-nav-end {
		justify-self: stretch;
	}

	.bandbaja-site-header .hero-nav-menu {
		flex-direction: column;
		align-items: flex-start;
		justify-content: flex-start;
		gap: 20px;
	}

	.bandbaja-site-header .hero-nav-menu a {
		font-size: 20px;
		line-height: 1.2;
	}

	.bandbaja-site-header .hero-nav-end {
		display: none;
	}

	.bandbaja-site-header .hero-nav-phone-btn,
	.bandbaja-site-header .hero-nav-cta {
		width: 100%;
		justify-content: center;
	}
}

/*
 * Elementor home hero recreation (page 17 / front page).
 * Scoped to the Elementor document so it stays out of the rest of the site.
 */
.elementor-17 .bandbaja-menu-wrap {
	display: flex;
	justify-content: center;
	width: 100%;
}

.elementor-17 .bandbaja-hero-menu {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(14px, 2vw, 30px);
	list-style: none;
	margin: 0;
	padding: 0;
}

.elementor-17 .bandbaja-hero-menu li {
	margin: 0;
	padding: 0;
}

.elementor-17 .bandbaja-hero-menu a {
	color: #ffffff;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1;
	text-decoration: none;
	transition: color 0.25s ease, opacity 0.25s ease;
}

.elementor-17 .bandbaja-hero-menu a:hover,
.elementor-17 .bandbaja-hero-menu .current-menu-item > a,
.elementor-17 .bandbaja-hero-menu .current_page_item > a {
	color: #a4a7ae;
}

.elementor-17 .bandbaja-hero-topbar {
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	background: linear-gradient(180deg, rgba(9, 11, 20, 0.42) 0%, rgba(9, 11, 20, 0.18) 100%);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 999px;
	box-shadow: 0 18px 60px rgba(0, 0, 0, 0.18);
}

.elementor-17 .bandbaja-home-hero {
	margin-top: 0;
}

.elementor-17 .elementor-element-0a75027 {
	position: relative;
	min-height: calc(100svh - 92px);
}

.elementor-17 .bandbaja-hero-brand .elementor-heading-title {
	font-family: 'Inter', sans-serif;
	font-size: clamp(1.05rem, 1.2vw, 1.25rem);
	font-weight: 700;
	letter-spacing: -0.03em;
}

.elementor-17 .bandbaja-hero-trust {
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 999px;
}

.elementor-17 .bandbaja-hero-trust .elementor-widget-heading .elementor-heading-title,
.elementor-17 .bandbaja-hero-trust .elementor-widget-text-editor,
.elementor-17 .bandbaja-hero-trust .elementor-widget-text-editor p {
	margin: 0;
}

.elementor-17 .elementor-element-0c0a5e6 .elementor-heading-title {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}

.elementor-17 .elementor-element-878c033,
.elementor-17 .elementor-element-319b5d9,
.elementor-17 .elementor-element-badcf53 {
	max-width: 620px;
	margin-left: auto;
	margin-right: auto;
}

.elementor-17 .elementor-element-c6c571e {
	justify-content: center !important;
	align-items: center !important;
}

.elementor-17 .elementor-element-c6c571e > .e-con-inner {
	justify-content: center !important;
	align-items: center !important;
}

.elementor-17 .elementor-element-df22b47 .elementor-button,
.elementor-17 .elementor-element-0543444 .elementor-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
}

.elementor-17 .elementor-element-df22b47 .elementor-button-content-wrapper,
.elementor-17 .elementor-element-0543444 .elementor-button-content-wrapper {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.elementor-17 .elementor-element-df22b47 .elementor-button-icon,
.elementor-17 .elementor-element-0543444 .elementor-button-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

.elementor-17 .elementor-element-0543444 .elementor-button-icon {
	font-size: 2em;
	line-height: 1;
}

.elementor-17 .elementor-element-0543444 .elementor-button-icon svg,
.elementor-17 .elementor-element-0543444 .elementor-button-icon i {
	width: 1em;
	height: 1em;
}

@media screen and (max-width: 767px) {
	.elementor-17 .elementor-element-c6c571e,
	.elementor-17 .elementor-element-c6c571e > .e-con-inner {
		width: 100% !important;
		align-items: stretch !important;
	}

	.elementor-17 .elementor-element-c6c571e > .elementor-element {
		width: 100% !important;
		max-width: 100% !important;
	}

	.elementor-17 .elementor-element-df22b47 .elementor-button-wrapper,
	.elementor-17 .elementor-element-0543444 .elementor-button-wrapper,
	.elementor-17 .elementor-element-df22b47 .elementor-button,
	.elementor-17 .elementor-element-0543444 .elementor-button {
		width: 100% !important;
		max-width: 100% !important;
	}
}

.elementor-17 .bandbaja-hero-checklist {
	width: 100%;
}

.elementor-17 .bandbaja-hero-checklist .elementor-icon-list-items {
	justify-content: center;
}

.elementor-17 .bandbaja-hero-checklist .elementor-icon-list-item {
	align-items: center;
}

.elementor-17 .bandbaja-hero-checklist .elementor-icon-list-text {
	white-space: nowrap;
}

@media screen and (min-width: 1200px) {
	.elementor-17 .bandbaja-hero-checklist {
		width: min(calc(100vw - 64px), 1320px);
		max-width: none;
		position: relative;
		left: 50%;
		transform: translateX(-50%);
	}

	.elementor-17 .bandbaja-hero-checklist .elementor-icon-list-items.elementor-inline-items {
		display: flex;
		flex-wrap: nowrap;
		justify-content: center;
	}
}

@media screen and (max-width: 1199px) {
	.elementor-17 .bandbaja-hero-checklist .elementor-icon-list-text {
		white-space: normal;
	}
}

@media screen and (min-width: 768px) {
	.elementor-17 .elementor-element-0a75027 {
		justify-content: flex-start !important;
		align-items: center !important;
		padding-top: 0 !important;
		padding-bottom: 0 !important;
		position: relative;
	}

	.elementor-17 .elementor-element-8ffd3b0 {
		position: absolute;
		left: 50%;
		top: 50%;
		width: min(100%, 980px);
		transform: translate(-50%, -50%);
	}

	.elementor-17 .elementor-element-5541dc7 {
		position: static;
		width: 100%;
		transform: none;
		margin: 6px 0 0 !important;
	}

	.elementor-17 .elementor-element-ffe4b7c {
		position: absolute;
		left: 50%;
		bottom: 50px;
		width: auto;
		transform: translateX(-50%);
		margin: 0 !important;
		z-index: 9;
	}
}

@media screen and (max-width: 1024px) {
	.elementor-17 .bandbaja-hero-topbar {
		border-radius: 28px;
	}

	.elementor-17 .elementor-element-0c0a5e6 .elementor-heading-title {
		font-size: 64px;
		letter-spacing: -2px;
	}
}

 .elementor-17 .elementor-element.elementor-element-05abe52 {
	--padding-top: 0px !important;
}

@media screen and (max-width: 767px) {
	.elementor-17 .bandbaja-hero-menu {
		flex-wrap: wrap;
		row-gap: 10px;
	}

	.elementor-17 .bandbaja-menu-wrap {
		justify-content: center;
	}

	.elementor-17 .elementor-element-0c0a5e6 .elementor-heading-title {
		font-size: 42px !important;
		letter-spacing: -1px;
	}

	.elementor-17 .elementor-element-0c0a5e6 {
		padding-top: 40px !important;
	}

	.elementor-17 .elementor-element-878c033 p {
		margin: 0 !important;
	}

	.elementor-17 .elementor-element-0a75027 {
		min-height: calc(100svh - 88px);
		padding-top: 8px !important;
		padding-bottom: 32px !important;
		position: relative;
	}

	.elementor-17 .elementor-element-8ffd3b0,
	.elementor-17 .elementor-element-5541dc7 {
		position: static;
		width: 100%;
		transform: none;
	}

	.elementor-17 .elementor-element-ffe4b7c {
		position: absolute;
		left: 50%;
		bottom: 18px;
		width: auto;
		transform: translateX(-50%);
		margin: 0 !important;
		z-index: 9;
	}

	.elementor-17 .elementor-element.elementor-element-3ae0f36 {
		--padding-top: 8px;
		--padding-bottom: 8px;
		--padding-left: 30px;
		--padding-right: 30px;
	}

	.elementor-17 .bandbaja-hamlet-copy .elementor-heading-title {
		font-size: 36px !important;
		letter-spacing: -1px !important;
	}
}

@media screen and (max-width: 575px) {
	.elementor-17 .elementor-element-0c0a5e6 .elementor-heading-title {
		font-size: 42px !important;
		line-height: 1.02;
	}

	.elementor-17 .elementor-element-878c033 .elementor-widget-container,
	.elementor-17 .elementor-element-badcf53 .elementor-widget-container {
		font-size: 14px;
	}

	.elementor-17 .elementor-element-0a75027 {
		min-height: calc(100svh - 82px);
		padding-top: 8px !important;
		padding-bottom: 24px !important;
	}

	.elementor-17 .elementor-element-ffe4b7c {
		bottom: 8px;
	}
}

/*
 * Services section under the hero.
 * Built from native Elementor image/heading/text/button widgets so editors can change everything.
 */
.elementor-17 .bandbaja-services-section {
	display: flex !important;
	align-items: stretch !important;
	background: #ffffff;
	justify-content: flex-start !important;
	gap: 0 !important;
	min-height: 620px;
	width: min(calc(100% - 48px), 1320px);
	margin: 0 auto;
	border-radius: 32px;
	overflow: hidden;
}

.elementor-17 .bandbaja-services-media,
.elementor-17 .bandbaja-services-copy {
	flex: 0 0 50%;
	width: 50%;
	max-width: 50%;
}

.elementor-17 .bandbaja-services-media {
	position: relative;
	min-height: 620px;
	overflow: hidden;
}

.elementor-17 .bandbaja-services-image,
.elementor-17 .bandbaja-services-image .elementor-widget-container,
.elementor-17 .bandbaja-services-image img {
	height: 100%;
}

.elementor-17 .bandbaja-services-image img {
	display: block;
	width: 100%;
	object-fit: cover;
}

.elementor-17 .elementor-element-091d65c,
.elementor-17 .elementor-element-091d65c .elementor-widget-container,
.elementor-17 .elementor-element-091d65c img {
	height: 100% !important;
}

.elementor-17 .elementor-element-091d65c img {
	display: block;
	width: 100%;
	object-fit: cover;
}

.elementor-17 .elementor-element.elementor-element-3ae0f36.e-con {
	padding-bottom: 30px !important;
}

.elementor-17 .elementor-element-46bd213 .elementor-heading-title {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	border-radius: 6px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.elementor-17 .bandbaja-services-copy {
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-items: flex-start !important;
	box-sizing: border-box;
	min-height: 620px;
}

.elementor-17 .bandbaja-services-copy .elementor-heading-title {
	max-width: 480px;
}

.elementor-17 .bandbaja-services-copy .elementor-widget-text-editor {
	max-width: 610px;
}

.elementor-17 .bandbaja-services-actions .elementor-button-wrapper {
	display: inline-flex;
}

.elementor-17 .bandbaja-services-primary-btn .elementor-button {
	box-shadow: none;
}

.elementor-17 .bandbaja-services-link-btn .elementor-button {
	padding-left: 0 !important;
	padding-right: 0 !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}

.elementor-17 .bandbaja-services-link-btn .elementor-button:hover {
	background: transparent !important;
}

@media screen and (max-width: 1200px) {
	.elementor-17 .bandbaja-services-copy {
		padding: 72px 48px !important;
	}
}

@media screen and (max-width: 900px) {
	.elementor-17 .bandbaja-services-section {
		min-height: 0;
		width: calc(100% - 32px);
	}

	.elementor-17 .bandbaja-services-media,
	.elementor-17 .bandbaja-services-copy {
		flex-basis: 100%;
		width: 100%;
		max-width: 100%;
	}

	.elementor-17 .bandbaja-services-media {
		min-height: 420px;
	}

	.elementor-17 .bandbaja-services-copy {
		min-height: 0;
		padding: 56px 28px !important;
	}

	.elementor-17 .bandbaja-services-copy .elementor-heading-title {
		font-size: 48px !important;
		letter-spacing: -1.6px !important;
	}
}

@media screen and (max-width: 575px) {
	.elementor-17 .bandbaja-services-section {
		width: calc(100% - 24px);
		border-radius: 24px;
	}

	.elementor-17 .bandbaja-services-media {
		min-height: 320px;
	}

	.elementor-17 .bandbaja-services-copy {
		padding: 8px 30px !important;
	}

	.elementor-17 .bandbaja-services-copy .elementor-heading-title {
		font-size: 36px !important;
		letter-spacing: -1px !important;
	}

	.elementor-17 .bandbaja-services-actions {
		gap: 14px !important;
	}

	.elementor-17 .bandbaja-services-actions .elementor-element,
	.elementor-17 .bandbaja-services-actions .elementor-button-wrapper,
	.elementor-17 .bandbaja-services-actions .elementor-button {
		width: 100% !important;
		max-width: 100% !important;
	}

	.elementor-17 .elementor-element-3f5f13d {
		margin-bottom: 60px !important;
	}
}

/*
 * "The Hamlet" feature section.
 * Mirror the services split-section behavior so the copy is truly centered against the image.
 */
.elementor-17 .bandbaja-hamlet-inner {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex-direction: column !important;
	gap: 20px !important;
}

.elementor-17 .bandbaja-hamlet-media,
.elementor-17 .bandbaja-hamlet-copy {
	max-width: none !important;
}

.elementor-17 .bandbaja-hamlet-media {
	flex: 0 0 200px !important;
	position: relative;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 200px !important;
	margin: 0 auto !important;
}

.elementor-17 .bandbaja-hamlet-media .elementor-widget-image,
.elementor-17 .bandbaja-hamlet-media .elementor-widget-container {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	margin: 0 auto !important;
}

.elementor-17 .bandbaja-hamlet-media img {
	display: block;
	width: 200px !important;
	height: 200px !important;
	max-width: 200px !important;
	border-radius: 999px !important;
	object-fit: cover !important;
}

.elementor-17 .bandbaja-hamlet-copy {
	flex: 0 1 auto !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-items: center !important;
	box-sizing: border-box;
	width: 100% !important;
	padding: 0 !important;
}

.elementor-17 .bandbaja-hamlet-copy .elementor-heading-title {
	font-family: "Arapey", Sans-serif !important;
	font-size: 48px !important;
	font-weight: 700 !important;
	letter-spacing: -2.2px !important;
	line-height: 1.02em !important;
	color: #1f1f1f !important;
	text-align: center !important;
}

.elementor-17 .bandbaja-hamlet-copy .bandbaja-hamlet-highlight {
	color: #d4af37 !important;
}

.elementor-17 .bandbaja-hamlet-section {
	padding-top: 72px !important;
	padding-bottom: 72px !important;
}

@media screen and (max-width: 900px) {
	.elementor-17 .bandbaja-hamlet-inner {
		gap: 20px !important;
	}

	.elementor-17 .bandbaja-hamlet-media {
		flex-basis: 160px !important;
		width: 160px !important;
	}

	.elementor-17 .bandbaja-hamlet-media img {
		width: 160px !important;
		height: 160px !important;
		max-width: 160px !important;
	}
}

@media screen and (max-width: 575px) {
	.elementor-17 .bandbaja-hamlet-section {
		padding-top: 56px !important;
		padding-bottom: 56px !important;
	}

	.elementor-17 .bandbaja-hamlet-inner {
		gap: 16px !important;
	}

	.elementor-17 .bandbaja-hamlet-media {
		flex-basis: 120px !important;
		width: 120px !important;
	}

	.elementor-17 .bandbaja-hamlet-media img {
		width: 120px !important;
		height: 120px !important;
		max-width: 120px !important;
	}

	.elementor-17 .bandbaja-hamlet-copy .elementor-heading-title {
		font-size: 36px !important;
		letter-spacing: -1px !important;
		text-align: center !important;
	}
}

/*
 * Popular services grid section.
 */
.elementor-17 .bandbaja-popular-services {
	background: #ffffff;
	padding-top: 72px !important;
	padding-bottom: 88px !important;
}

.elementor-17 .bandbaja-popular-services-head {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 16px !important;
	margin-bottom: 30px !important;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(17, 17, 17, 0.08);
}

.elementor-17 .bandbaja-popular-services-head > .elementor-element:last-child {
	margin-left: auto !important;
}

.elementor-17 .bandbaja-popular-services-head .elementor-heading-title {
	font-family: "Arapey", sans-serif !important;
	font-size: 62px !important;
	font-weight: 400 !important;
	letter-spacing: -2.2px !important;
	line-height: 0.98 !important;
}

.elementor-17 .bandbaja-popular-services-head .elementor-button {
	padding: 14px 22px !important;
	border-color: rgba(17, 17, 17, 0.14) !important;
	background: rgba(255, 255, 255, 0.68) !important;
	backdrop-filter: blur(10px);
}

.elementor-17 .bandbaja-popular-services-grid .elementor-widget-image-box {
	width: 100%;
}

.elementor-17 .bandbaja-popular-services-grid {
	display: grid !important;
	grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
	grid-auto-rows: minmax(180px, auto);
	gap: 18px !important;
	--grid-column-gap: 18px !important;
	--grid-row-gap: 18px !important;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element {
	min-width: 0;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) {
	grid-column: span 6;
	grid-row: span 2;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(2),
.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(3) {
	grid-column: span 3;
	grid-row: span 1;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(4),
.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(5) {
	grid-column: span 3;
	grid-row: span 1;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(n + 6) {
	grid-column: span 4;
	grid-row: span 1;
}

.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-wrapper {
	position: relative;
	display: flex;
	align-items: stretch;
	width: 100%;
	height: 100%;
	min-height: 260px;
	border-radius: 28px;
	overflow: hidden;
	background: #0f0c0a;
	box-shadow: 0 24px 44px rgba(55, 35, 10, 0.14);
	isolation: isolate;
}

.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-img {
	position: absolute;
	inset: 0;
	display: block;
	width: 100% !important;
	height: 100%;
	margin-bottom: 0 !important;
}

.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-img img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 0;
	transform: scale(1.01);
	transition: transform 0.55s ease;
	filter: saturate(0.96) contrast(1.02);
}

.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-wrapper::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(12, 9, 6, 0.08) 0%, rgba(12, 9, 6, 0.2) 36%, rgba(12, 9, 6, 0.84) 100%);
	z-index: 1;
}

.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	width: 100%;
	margin-top: auto;
	padding: 24px 22px 22px;
	text-align: left;
}

.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-title {
	margin-bottom: 6px;
	color: #fff;
	font-family: "Arapey", sans-serif;
	font-size: 34px;
	font-weight: 400;
	letter-spacing: -1px;
	line-height: 0.98;
}

.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-description {
	color: rgba(255, 255, 255, 0.82);
	font-family: "Inter", sans-serif;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
	max-width: 28ch;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-wrapper {
	min-height: 560px;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-content {
	padding: 34px 30px 30px;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-title {
	font-size: 54px;
	letter-spacing: -2px;
	max-width: 8ch;
}

.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-description {
	font-size: 16px;
	max-width: 34ch;
}

.elementor-17 .bandbaja-popular-services-grid .elementor-widget-image-box:hover img {
	transform: scale(1.05);
}

@media screen and (min-width: 768px) {
	.elementor-17 .elementor-element.elementor-element-6f807a3 .elementor-image-box-img img {
		height: 100% !important;
	}
}

@media screen and (max-width: 1100px) {
	.elementor-17 .bandbaja-popular-services-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1),
	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(2),
	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(3),
	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(n + 4) {
		grid-column: span 1;
		grid-row: span 1;
	}

	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-wrapper {
		min-height: 320px;
	}

	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-title {
		font-size: 40px;
		max-width: none;
	}
}

@media screen and (max-width: 575px) {
	.elementor-17 .bandbaja-popular-services {
		padding-top: 32px !important;
		padding-bottom: 42px !important;
		padding-left: 16px !important;
		padding-right: 16px !important;
		border-radius: 28px;
	}

	.elementor-17 .bandbaja-popular-services-head {
		gap: 14px !important;
		align-items: flex-start !important;
	}

	.elementor-17 .bandbaja-popular-services-head .elementor-heading-title {
		font-size: 42px !important;
	}

	.elementor-17 .bandbaja-popular-services-head > .elementor-element:last-child {
		margin-left: 0 !important;
	}

	.elementor-17 .bandbaja-popular-services-head .elementor-widget-button,
	.elementor-17 .bandbaja-popular-services-head .elementor-button-wrapper {
		width: auto;
		text-align: left !important;
		justify-content: flex-start !important;
	}

	.elementor-17 .bandbaja-popular-services-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
	}

	.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-wrapper,
	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-wrapper {
		min-height: 280px;
		border-radius: 22px;
	}

	.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-content,
	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-content {
		padding: 22px 18px 18px;
	}

	.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-title,
	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-title {
		font-size: 28px;
		letter-spacing: -0.8px;
		max-width: none;
	}

	.elementor-17 .bandbaja-popular-services-grid .elementor-image-box-description,
	.elementor-17 .bandbaja-popular-services-grid > .elementor-element:nth-child(1) .elementor-image-box-description {
		font-size: 13px;
		max-width: none;
	}
}

/*
 * Global footer.
 */
.bandbaja-site-footer {
	background: linear-gradient(180deg, #15110d 0%, #0d0a08 100%);
	color: rgba(255, 255, 255, 0.82);
	padding: 40px 24px 28px;
}

.bandbaja-site-footer__inner {
	max-width: 1320px;
	margin: 0 auto;
}

.bandbaja-site-footer__top {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) repeat(3, minmax(0, 0.7fr));
	gap: 32px;
	align-items: start;
	padding-bottom: 24px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.bandbaja-site-footer__logo-link {
	display: inline-flex;
	align-items: center;
}

.bandbaja-site-footer__logo {
	width: 210px;
	height: auto;
	display: block;
}

.bandbaja-site-footer__tagline {
	max-width: 440px;
	margin: 18px 0 0;
	font-family: "Inter", sans-serif;
	font-size: 16px;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.72);
}

.bandbaja-site-footer__heading {
	margin: 0 0 16px;
	font-family: "Inter", sans-serif;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #d7a84c;
}

.bandbaja-site-footer__nav {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 12px;
}

.bandbaja-site-footer__nav a,
.bandbaja-site-footer__contact-link {
	color: rgba(255, 255, 255, 0.86);
	text-decoration: none;
	font-family: "Inter", sans-serif;
	font-size: 15px;
	line-height: 1.45;
	transition: color 0.2s ease, opacity 0.2s ease;
}

.bandbaja-site-footer__nav a:hover,
.bandbaja-site-footer__contact-link:hover,
.bandbaja-site-footer__social-link:hover {
	color: #d7a84c;
}

.bandbaja-site-footer__contact {
	display: grid;
	gap: 12px;
}

.bandbaja-site-footer__socials {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.bandbaja-site-footer__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(255, 255, 255, 0.04);
	color: #ffffff;
	transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.bandbaja-site-footer__social-link:hover {
	transform: translateY(-1px);
	border-color: rgba(215, 168, 76, 0.55);
	background: rgba(215, 168, 76, 0.08);
}

.bandbaja-site-footer__social-link svg {
	width: 20px;
	height: 20px;
	display: block;
}

.bandbaja-site-footer__bottom {
	padding-top: 18px;
}

.bandbaja-site-footer__copyright {
	margin: 0;
	font-family: "Inter", sans-serif;
	font-size: 13px;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.54);
}

@media screen and (max-width: 960px) {
	.bandbaja-site-footer__top {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 640px) {
	.bandbaja-site-footer {
		padding: 34px 18px 24px;
	}

	.bandbaja-site-footer__top {
		grid-template-columns: minmax(0, 1fr);
		gap: 26px;
	}

	.bandbaja-site-footer__logo {
		width: 190px;
	}

	.bandbaja-site-footer__tagline {
		margin-top: 14px;
		max-width: none;
		font-size: 15px;
	}
}

/*
 * Headless callback form section.
 */
.bandbaja-callback-section {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(520px, 0.95fr);
	gap: 56px;
	align-items: stretch;
	width: 100%;
	max-width: 1320px;
	margin-left: auto;
	margin-right: auto;
}

.bandbaja-callback-frame {
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
	padding: 84px 24px;
	background: #f7f3ee;
	box-sizing: border-box;
}

.bandbaja-callback-shell {
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
	background: transparent !important;
	--content-width: 100%;
	--padding-top: 0px;
	--padding-right: 0px;
	--padding-bottom: 0px;
	--padding-left: 0px;
}

.bandbaja-callback-shell > .elementor-element,
.bandbaja-callback-shell .elementor-widget-shortcode,
.bandbaja-callback-shell .elementor-widget-container,
.bandbaja-callback-shell .elementor-shortcode {
	width: 100%;
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.bandbaja-callback-copy {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.bandbaja-callback-copy h2 {
	margin: 0;
	max-width: 560px;
	font-family: "Arapey", sans-serif;
	font-size: 72px;
	line-height: 0.98;
	letter-spacing: -2.8px;
	color: #111111;
}

.bandbaja-callback-copy p {
	margin: 22px 0 0;
	max-width: 420px;
	font-family: "Inter", sans-serif;
	font-size: 18px;
	line-height: 1.7;
	color: #5c5a57;
}

.bandbaja-callback-card {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;
	max-width: 100%;
	padding: 34px 34px 32px;
	border: 1px solid #ddd3c7;
	border-radius: 24px;
	background: #fff;
	box-shadow: 0 30px 80px rgba(80, 56, 24, 0.08);
	box-sizing: border-box;
}

.bandbaja-callback-card > div {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	height: 100%;
	max-width: 520px;
}

.bandbaja-callback-card h3 {
	margin: 0 0 28px;
	font-family: "Arapey", sans-serif;
	font-size: 42px;
	line-height: 1;
	color: #111111;
}

.bandbaja-callback-form {
	display: flex;
	flex-direction: column;
	gap: 12px;
	flex: 1 1 auto;
	height: 100%;
}

.bandbaja-callback-field {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.bandbaja-callback-field--wide {
	grid-column: 1 / -1;
}

.bandbaja-callback-field--honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
}

.bandbaja-callback-field label {
	font-family: "Inter", sans-serif;
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: #111111;
}

.bandbaja-callback-field input,
.bandbaja-callback-field textarea {
	width: 100%;
	padding: 0 0 16px;
	border: 0;
	border-bottom: 1px solid #d8d0c4;
	border-radius: 0;
	background: transparent;
	font-family: "Inter", sans-serif;
	font-size: 20px;
	line-height: 1.5;
	color: #111111;
	outline: none;
	box-shadow: none;
	transition: border-color 0.2s ease;
}

.bandbaja-callback-field input::placeholder,
.bandbaja-callback-field textarea::placeholder {
	color: #a59b90;
}

.bandbaja-callback-field textarea {
	min-height: 150px;
	resize: vertical;
	padding-top: 0;
}

.bandbaja-callback-field input:focus,
.bandbaja-callback-field textarea:focus {
	border-bottom-color: #d4af37;
}

.bandbaja-callback-field input.is-error,
.bandbaja-callback-field textarea.is-error {
	border-bottom-color: #c84d3a;
}

.bandbaja-callback-error {
	margin: 0;
	min-height: 18px;
	font-family: "Inter", sans-serif;
	font-size: 12px;
	line-height: 1.4;
	color: #c84d3a;
}

.bandbaja-callback-feedback {
	grid-column: 1 / -1;
	margin-top: 4px;
	font-family: "Inter", sans-serif;
	font-size: 14px;
	line-height: 1.5;
}

.bandbaja-callback-feedback.is-success {
	color: #387a4f;
}

.bandbaja-callback-feedback.is-error {
	color: #c84d3a;
}

.bandbaja-callback-submit-wrap {
	grid-column: 1 / -1;
	margin-top: auto;
}

.bandbaja-callback-submit {
	margin-top: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 66px;
	border: 0;
	border-radius: 999px;
	background: #d4af37;
	font-family: "Inter", sans-serif;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #111111;
	cursor: pointer;
	transition: background-color 0.2s ease, filter 0.2s ease, opacity 0.2s ease;
}

.bandbaja-callback-submit:hover {
	background: #e0bc4f;
	filter: none;
}

.bandbaja-callback-submit:disabled {
	opacity: 0.72;
	cursor: wait;
}

.bandbaja-callback-consent {
	margin: 10px 0 0;
	font-family: "Inter", sans-serif;
	font-size: 11px;
	line-height: 1.5;
	color: #7a746d;
	text-align: center;
}

@media (max-width: 1024px) {
	.bandbaja-callback-section {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.bandbaja-callback-frame {
		padding-top: 72px;
		padding-bottom: 72px;
	}

	.bandbaja-callback-copy,
	.bandbaja-callback-card {
		min-height: auto;
	}

	.bandbaja-callback-copy h2 {
		font-size: 58px;
		max-width: 700px;
	}
}

@media (max-width: 767px) {
	.bandbaja-callback-copy h2 {
		font-size: 42px;
		letter-spacing: -1.4px;
	}

	.bandbaja-callback-frame {
		padding: 40px 20px;
	}

	.bandbaja-callback-section,
	.bandbaja-callback-copy,
	.bandbaja-callback-card,
	.bandbaja-callback-form,
	.bandbaja-callback-field,
	.bandbaja-callback-field input,
	.bandbaja-callback-field textarea,
	.bandbaja-callback-submit {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
	}

	.bandbaja-callback-copy p {
		font-size: 16px;
	}

	.bandbaja-callback-card {
		padding: 24px 22px 22px;
		border-radius: 20px;
	}

	.bandbaja-callback-card h3 {
		font-size: 34px;
		margin-bottom: 22px;
	}

	.bandbaja-callback-form {
		grid-template-columns: 1fr;
	}

	.bandbaja-callback-field--wide,
	.bandbaja-callback-feedback,
	.bandbaja-callback-submit-wrap {
		grid-column: auto;
	}

.bandbaja-callback-submit {
	min-height: 58px;
	font-size: 16px;
	}
}

.bandbaja-logo-marquee__group {
	gap: 24px !important;
	padding-right: 24px !important;
}

.bandbaja-logo-marquee__item {
	min-width: 0 !important;
	width: auto !important;
	padding: 0 20px !important;
}

.elementor-17 .elementor-element.elementor-element-ab74cf0 {
	padding-bottom: 20px !important;
}

.elementor-17 .elementor-element.elementor-element-05abe52 > .e-con-inner {
	padding-top: 0 !important;
	padding-bottom: 60px !important;
}

.elementor-17 .elementor-element.elementor-element-05abe52 .bandbaja-google-reviews-widget__title {
	margin: 0 0 28px !important;
	text-align: center !important;
	color: #0a0d12 !important;
	-webkit-text-stroke-color: #0a0d12 !important;
	font-family: 'Arapey', sans-serif !important;
	font-size: 64px !important;
	font-weight: 400 !important;
	line-height: 1em !important;
	letter-spacing: -3.2px !important;
}

.elementor-17 .elementor-element.elementor-element-05abe52 .bandbaja-google-reviews-widget__subtitle {
	max-width: 720px;
	margin: -10px auto 28px !important;
	text-align: center !important;
	font-size: 16px !important;
	line-height: 22px !important;
}

.bandbaja-callback-shell {
	background-color: #F7F3EE !important;
}

.bandbaja-callback-frame {
	padding-top: 20px !important;
	padding-bottom: 20px !important;
}

.bandbaja-logo-marquee__item img {
	display: block !important;
	width: auto !important;
	height: auto !important;
	max-width: 140px !important;
	object-fit: contain !important;
	opacity: 1 !important;
	filter: brightness(0) invert(1) brightness(20) !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
.elementor-heading-title {
	font-weight: 400 !important;
}

@media (max-width: 767px) {
	.bandbaja-logo-marquee__group {
		gap: 16px !important;
		padding-right: 16px !important;
	}
}

@media (min-width: 768px) {
	.bandbaja-scroll-cue {
		top: auto !important;
		bottom: -20px !important;
	}
}
