@import url("/assets/packandloadOS_builder/css/gomoveit_theme_tokens.css");

/* Default tokens are provided by gomoveit_theme_tokens.css. */

/* Suppress default Frappe header/footer to let Builder chrome take over */
body .navbar,
body .web-footer,
body footer.web-footer,
body .page-breadcrumbs,
body .page-header-wrapper,
body .page-footer {
	display: none !important;
}

body .page-content-wrapper {
	padding-top: 0;
}

html {
	width: 100%;
	overflow-x: hidden;
}

body,
.gomoveit-page {
	width: 100%;
	overflow-x: hidden;
}

/* CRITICAL: GSI logo must ALWAYS stay small - overrides all inline styles */
img[src*="gsi-logo"],
img[src*="/partners/gsi"] {
	max-height: 24px !important;
	max-width: 100px !important;
	width: auto !important;
	height: auto !important;
	object-fit: contain !important;
}

/* Mobile: Even stricter constraints on partner logos */
@media (max-width: 768px) {
	img[src*="gsi-logo"],
	img[src*="/partners/gsi"],
	[data-block-id*="gsi"] img,
	[data-block-id*="partner"] img:not([src*="bbb"]) {
		max-height: 20px !important;
		max-width: 80px !important;
		width: auto !important;
		height: 20px !important;
	}
}

.page-container,
.page-wrapper,
main,
#page-gomoveit {
	max-width: 100%;
	overflow-x: hidden;
}

/* =====================================================
   RESPONSIVE DESIGN - Mobile-first approach
   Only apply restrictions on smaller screens
   ===================================================== */

/* Tablet and below - 1024px */
@media (max-width: 1024px) {
	/* Prevent horizontal scroll */
	html, body {
		overflow-x: hidden;
		max-width: 100vw;
	}

	/* Text wrapping for all text elements */
	p, h1, h2, h3, h4, h5, h6, span, li, a, label {
		word-wrap: break-word;
		overflow-wrap: break-word;
	}

	/* Content containers */
	.page-container,
	.page-content,
	.page-wrapper,
	main {
		max-width: 100vw;
		overflow-x: hidden;
	}

	/* Builder page content needs padding */
	.fb-page [data-block-id="root"] > div > div {
		padding-left: 24px;
		padding-right: 24px;
		box-sizing: border-box;
	}
}

/* Mobile specific - 768px */
@media (max-width: 768px) {
	/* Builder-rendered sections and divs need padding */
	.fb-page [data-block-id="root"] > div > div,
	.fb-page [data-block-id="root"] > div > section {
		padding-left: 16px;
		padding-right: 16px;
		box-sizing: border-box;
	}

	/* Main content containers - these are the divs Builder creates */
	[data-block-id="root"] > div {
		max-width: 100vw;
		overflow-x: hidden;
	}

	/* Content sections with maxWidth need responsive handling */
	[data-block-id] > div[style*="maxWidth"],
	[data-block-id] > div[style*="max-width"] {
		max-width: 100% !important;
		padding-left: 16px;
		padding-right: 16px;
		box-sizing: border-box;
	}

	/* Content images should be responsive on mobile */
	.fb-page img:not(.gomoveit-header__logo):not([class*="logo"]) {
		max-width: 100%;
		height: auto;
	}

	/* GSI logo should stay small on mobile */
	img[src*="gsi-logo"],
	img[src*="gsi-logo.svg"] {
		max-height: 20px !important;
		max-width: 80px !important;
		width: auto !important;
		height: auto !important;
		object-fit: contain !important;
	}

	/* Partner badge logos in hero should stay small */
	section img[src*="gsi"],
	section img[src*="partner"],
	[class*="hero"] img[src*="logo"] {
		max-height: 24px !important;
		max-width: 100px !important;
	}

	/* Lists need proper indentation */
	ul:not(.gomoveit-nav__links):not(.gomoveit-footer__links),
	ol {
		padding-left: 24px;
		margin-left: 8px;
		margin-right: 8px;
		max-width: calc(100vw - 32px);
	}

	/* Nested lists */
	ul ul, ol ol, ul ol, ol ul {
		margin-left: 0;
		padding-left: 20px;
	}

	/* Text should not overflow */
	p, span, li, h1, h2, h3, h4, h5, h6, a {
		max-width: 100%;
		word-wrap: break-word;
		overflow-wrap: break-word;
	}
}

/* Small mobile - 480px */
@media (max-width: 480px) {
	.fb-page [data-block-id="root"] > div > div,
	.fb-page [data-block-id="root"] > div > section {
		padding-left: 12px;
		padding-right: 12px;
	}
}

.gomoveit-page {
	font-family: var(--gomoveit-font-base);
	color: var(--gomoveit-charcoal);
	background-color: #ffffff;
	line-height: 1.6;
}

.gomoveit-page h1,
.gomoveit-page h2,
.gomoveit-page h3,
.gomoveit-page h4 {
	font-family: var(--gomoveit-font-heading);
	font-weight: 800;
	letter-spacing: 0.02em;
	color: var(--gomoveit-dark);
	line-height: 1.15;
	margin: 0 0 1rem;
	text-transform: none;
}

.gomoveit-page h1 {
	font-size: clamp(2.6rem, 4vw, 3.8rem);
}

.gomoveit-page h2 {
	font-size: clamp(2rem, 3.2vw, 3rem);
}

.gomoveit-page h3 {
	font-size: clamp(1.4rem, 2.4vw, 2rem);
}

.gomoveit-page h4 {
	font-size: clamp(1.15rem, 2vw, 1.5rem);
}

.gomoveit-header {
	background: linear-gradient(90deg, #ffffff 0%, #f6f8fb 100%);
	border-bottom: 1px solid rgba(7, 16, 38, 0.08);
	position: sticky;
	position: -webkit-sticky;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	max-width: 100%;
	margin: 0 auto;
	z-index: 9999;
	transition: transform 0.25s ease;
	box-sizing: border-box;
	overflow: visible;
	box-shadow: 0 10px 30px rgba(7, 16, 38, 0.05);
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
}

.gomoveit-header.is-hidden {
	transform: translateY(-100%);
}

.gomoveit-header[data-header-theme="dark"] {
	background: linear-gradient(90deg, #1b1c23 0%, #101117 100%);
	border-bottom-color: rgba(255, 255, 255, 0.12);
	box-shadow: 0 18px 32px rgba(0, 0, 0, 0.35);
}

.gomoveit-header[data-header-theme="dark"] .gomoveit-nav__links a,
.gomoveit-header[data-header-theme="dark"] .gomoveit-nav__link,
.gomoveit-header[data-header-theme="dark"] .gomoveit-header__cta-row,
.gomoveit-header[data-header-theme="dark"] .gomoveit-header__brand {
	color: #ffffff;
}

.gomoveit-header[data-header-theme="dark"] .gomoveit-nav__link {
	color: #ffffff;
}

.gomoveit-header[data-header-theme="dark"] .gomoveit-btn.outline {
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.45);
}

.gomoveit-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
	row-gap: 14px;
	margin: 0 auto;
	width: 100%;
	padding: 16px clamp(20px, 4vw, 48px);
	flex-wrap: wrap;
	box-sizing: border-box;
}

.gomoveit-header__brand {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	margin-right: auto;
}

.gomoveit-header__right {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 16px;
	min-width: 0;
}

.gomoveit-header__brand img {
	height: clamp(90px, 14vw, 130px) !important;
	width: auto !important;
	display: block;
}

.gomoveit-nav__drawer-top {
	display: none;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	width: 100%;
	margin-bottom: 8px;
}

.gomoveit-nav__drawer-brand {
	display: none;
	align-items: center;
	justify-content: flex-start;
	padding-bottom: 6px;
	margin-bottom: 6px;
	width: 100%;
}
.gomoveit-nav__drawer-brand img {
	height: 48px;
}

.gomoveit-nav__mobile-head {
	display: none;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	width: 100%;
	margin-bottom: 4px;
}

.gomoveit-nav__mobile-brand img {
	height: 46px;
	width: auto;
}

.gomoveit-nav__close {
	display: none;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: none;
	background: transparent;
	color: #071026;
	font-size: 1.4rem;
	line-height: 1;
	padding: 0;
	margin-left: auto;
}

.gomoveit-nav__close:focus-visible {
	outline: 2px solid var(--gomoveit-red);
	outline-offset: 2px;
}

.gomoveit-nav {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	justify-content: flex-start;
	gap: 12px;
	flex-wrap: nowrap;
	flex: 1 1 auto;
	width: auto;
	min-width: 0;
}

.gomoveit-nav__links {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	flex: 0 1 auto;
	justify-content: flex-end;
	text-align: right;
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
	min-width: 0;
	font-weight: 600;
}

.gomoveit-header__cta-row {
	display: flex;
	gap: 12px;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: wrap;
	width: 100%;
}
.gomoveit-nav__item {
	position: relative;
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
}

.gomoveit-nav__link {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.35rem;
	text-decoration: none;
	color: #3a3a3a;
	font-weight: 600;
	font-size: 1.02rem;
	letter-spacing: normal;
	text-transform: none;
	white-space: nowrap;
}

.gomoveit-nav__links a {
	text-decoration: none;
	color: #3a3a3a;
	font-weight: 600;
	letter-spacing: normal;
	text-transform: none;
}

.gomoveit-nav__links a:hover {
	color: var(--gomoveit-red);
}

.gomoveit-submenu {
	position: absolute;
	left: 0;
	top: calc(100% + 12px);
	min-width: 220px;
	list-style: none;
	padding: 12px 0;
	margin: 0;
	background: #fff;
	border-radius: 16px;
	border: 1px solid #e4e7ec;
	box-shadow: 0 20px 40px rgba(7, 16, 38, 0.12);
	opacity: 0;
	pointer-events: none;
	transform: translateY(6px);
	transition: all 0.2s ease;
	z-index: 10;
	display: flex;
	flex-direction: column;
	gap: 4px;
	text-align: left;
	align-items: stretch;
}
.gomoveit-nav__item.has-submenu:nth-last-child(-n + 2) > .gomoveit-submenu {
	left: auto;
	right: 0;
}

.gomoveit-nav__item.has-submenu::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 0.85rem;
}

.gomoveit-submenu li {
	margin: 0;
}

.gomoveit-submenu a {
	display: block;
	padding: 8px 18px;
	color: #3a3a3a;
	text-decoration: none;
	font-weight: 500;
	text-transform: none;
	letter-spacing: normal;
	white-space: nowrap;
	text-align: left !important;
}

.gomoveit-submenu,
.gomoveit-submenu li,
.gomoveit-submenu a {
	text-align: left !important;
}

.gomoveit-submenu a:hover {
	background-color: #f5f7fb;
}

.gomoveit-submenu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	border: 1px solid #e4e7ec;
	border-radius: 12px;
	background: #fff;
	color: #071026;
	padding: 0;
	width: 36px;
	height: 36px;
	cursor: pointer;
	transition: border-color 0.2s ease, color 0.2s ease;
}

.gomoveit-submenu-toggle:focus-visible {
	outline: 2px solid #2563eb;
	outline-offset: 2px;
}

.gomoveit-submenu-toggle__chevron {
	display: inline-block;
	width: 10px;
	height: 10px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	transition: transform 0.2s ease;
}

.gomoveit-nav__item.has-submenu.is-expanded > .gomoveit-submenu-toggle .gomoveit-submenu-toggle__chevron {
	transform: rotate(-135deg);
}

.gomoveit-nav__item.has-submenu:hover .gomoveit-submenu,
.gomoveit-nav__item.has-submenu:focus-within .gomoveit-submenu {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.gomoveit-nav__cta {
	display: flex;
	gap: 8px;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: nowrap;
	width: auto;
}
.gomoveit-nav__cta .gomoveit-btn {
	white-space: nowrap;
	font-size: 0.78rem;
	padding: 0.45rem 1.35rem;
	border-radius: 10px;
	letter-spacing: 0.04em;
	font-weight: 700;
	min-height: 34px;
	transition: opacity 0.2s ease;
}

.gomoveit-nav__item.has-submenu > [data-nav-submenu-toggle] {
	display: none;
}

.gomoveit-nav__toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	min-width: 42px;
	border: none;
	border-radius: 50%;
	background: transparent;
	box-shadow: none;
	cursor: pointer;
	padding: 0;
	cursor: pointer;
	transition: opacity 0.2s ease;
	color: #071026;
}

.gomoveit-header.is-nav-open .gomoveit-nav__toggle {
	background: transparent;
	color: #071026;
}

.gomoveit-nav__toggle-icon {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 100%;
}

/* Style hamburger bars - works for both JS-generated and Builder-generated markup */
.gomoveit-nav__toggle-icon > span {
	display: block;
	width: 22px;
	height: 2px;
	background-color: currentColor;
	border-radius: 999px;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.gomoveit-nav__toggle:focus-visible {
	outline: 2px solid var(--gomoveit-red);
	outline-offset: 2px;
}

.gomoveit-nav__toggle-bar {
	display: block;
	width: 24px;
	height: 3px;
	border-radius: 999px;
	background-color: currentColor;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.gomoveit-nav__toggle-bar + .gomoveit-nav__toggle-bar {
	margin-top: 4px;
}

.gomoveit-header.is-nav-open .gomoveit-nav__toggle-bar:nth-child(1) {
	transform: translateY(6px) rotate(45deg);
}

.gomoveit-header.is-nav-open .gomoveit-nav__toggle-bar:nth-child(2) {
	opacity: 0;
}

.gomoveit-header.is-nav-open .gomoveit-nav__toggle-bar:nth-child(3) {
	transform: translateY(-6px) rotate(-45deg);
}

.gomoveit-nav__overlay {
	display: none;
}

body.gomoveit-nav-open {
	overflow: hidden;
}

/* Elementor header compatibility */
.elementor-menu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	gap: 6px;
	border: 1px solid #e4e7ec;
	border-radius: 12px;
	padding: 10px 14px;
	background: #fff;
	color: #071026;
	cursor: pointer;
	box-shadow: 0 10px 18px rgba(7, 16, 38, 0.08);
}

.elementor-menu-toggle svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

@media (min-width: 1025px) {
	.elementor-hidden-widescreen,
	.elementor-hidden-desktop,
	.elementor-hidden-laptop {
		display: none !important;
	}
}

@media (max-width: 1024px) and (min-width: 768px) {
	.elementor-hidden-tablet {
		display: none !important;
	}
}

@media (max-width: 880px) and (min-width: 768px) {
	.elementor-hidden-mobile_extra {
		display: none !important;
	}
}

@media (max-width: 767px) {
	.elementor-hidden-mobile {
		display: none !important;
	}
}

@media (max-width: 1024px) {
	.elementor-widget-nav-menu.elementor-nav-menu--toggle .elementor-menu-toggle {
		display: inline-flex;
	}
	.elementor-widget-nav-menu.elementor-nav-menu--toggle .elementor-nav-menu--main {
		display: none !important;
	}
	.elementor-widget-nav-menu.elementor-nav-menu--toggle .elementor-nav-menu--dropdown {
		display: none !important;
		width: 100%;
		background: #fff;
		border: 1px solid #e4e7ec;
		border-radius: 16px;
		padding: 12px 0;
		margin-top: 12px;
		box-shadow: 0 25px 45px rgba(7, 16, 38, 0.08);
	}
	.elementor-widget-nav-menu.elementor-nav-menu--toggle .elementor-nav-menu--dropdown a {
		display: block;
		padding: 12px 20px;
		color: #071026;
		text-decoration: none;
		font-weight: 600;
	}
	.elementor-widget-nav-menu.elementor-nav-menu--toggle .elementor-nav-menu--dropdown a:hover {
		background: #f5f7fb;
		color: var(--gomoveit-red);
	}
	.elementor-widget-nav-menu.elementor-nav-menu--toggle.is-open .elementor-nav-menu--dropdown,
	.elementor-widget-nav-menu.elementor-nav-menu--toggle:focus-within .elementor-nav-menu--dropdown {
		display: block !important;
	}
}

.gomoveit-review {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.gomoveit-review__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 8px 12px;
	border-radius: 12px;
}

.gomoveit-review__row:nth-child(odd) {
	background-color: #f9fafb;
}

.gomoveit-review__row span {
	font-weight: 500;
	color: #667085;
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.gomoveit-review__row strong {
	flex: 1 1 auto;
	text-align: right;
	font-weight: 500;
	color: #1d2939;
	font-size: 0.85rem;
	line-height: 1.35;
	white-space: pre-line;
}

.gomoveit-review-stage,
.gomoveit-payment-stage {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.gomoveit-payment-stage {
	margin-top: 24px;
}

.gomoveit-review-actions,
.gomoveit-payment-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.gomoveit-quote-summary__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 6px 0;
	border-bottom: 1px solid #edf0f7;
	font-size: 0.95rem;
}

.gomoveit-quote-summary__row:last-child {
	border-bottom: none;
}

.gomoveit-quote-summary__row span {
	color: #667085;
	font-weight: 500;
}

.gomoveit-quote-summary__row strong {
	font-weight: 600;
	color: #1d2939;
	letter-spacing: 0.01em;
}

.gomoveit-quote-summary__total {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 0;
	margin-top: 8px;
	border-top: 1px solid #edf0f7;
}

.gomoveit-quote-summary__total span {
	font-weight: 700;
	color: #071026;
	text-transform: uppercase;
	font-size: 0.85rem;
	letter-spacing: 0.05em;
}

.gomoveit-quote-summary__total strong {
	font-weight: 700;
	color: #071026;
	font-size: 1.2rem;
}

.gomoveit-expedite-note {
	font-size: 0.85rem;
	color: #b45309;
}

/* Tablet breakpoint - smaller desktop header */
@media screen and (max-width: 1024px) {
	.gomoveit-header__inner {
		gap: 16px;
		padding: 12px clamp(16px, 4vw, 32px);
	}

	.gomoveit-header__brand img {
		height: 130px !important;
	}

	.gomoveit-nav__links {
		gap: 16px;
	}

	.gomoveit-nav__link {
		font-size: 0.9rem;
	}

	.gomoveit-nav__cta .gomoveit-btn {
		font-size: 0.72rem;
		padding: 0.4rem 1rem;
	}
}

/* Small tablet - hide some CTA buttons */
/* DEPRECATED - Old header breakpoints (480px, 768px) replaced by 700px breakpoints at end of file */

.gomoveit-breadcrumbs {
	width: min(1100px, calc(100% - 2.5rem));
	margin: 0 auto;
	padding: 1rem 0 0.5rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.85rem;
	color: #6b7280;
}
.gomoveit-breadcrumbs a {
	text-decoration: none;
	color: var(--gomoveit-charcoal);
	font-weight: 600;
}
.gomoveit-breadcrumbs a::after {
	content: "›";
	margin: 0 0.35rem;
	color: #cbd5f5;
}
.gomoveit-breadcrumbs span {
	color: #a0aec0;
	font-weight: 600;
}

/* Breadcrumbs Mobile Fixes */
@media (max-width: 1024px) {
	.gomoveit-breadcrumbs {
		padding: 0.75rem 0 0.4rem;
		gap: 0.25rem;
		font-size: 0.8rem;
	}
	.gomoveit-breadcrumbs a::after {
		margin: 0 0.25rem;
	}

	/* Builder inline style overrides */
	section > div[style*="padding: 0 24px"],
	section > div[style*="padding: 0px 24px"] {
		padding: 0 16px !important;
	}
	nav[style*="gap: 8px"], nav[style*="gap:8px"] {
		gap: 6px !important;
		font-size: 0.85rem !important;
	}
}

@media (max-width: 768px) {
	.gomoveit-breadcrumbs {
		width: calc(100% - 1.5rem) !important;
		padding: 0.5rem 0 0.35rem;
		gap: 0.2rem;
		font-size: 0.75rem;
	}
	.gomoveit-breadcrumbs a::after {
		margin: 0 0.15rem;
	}

	/* Builder inline style overrides */
	section > div[style*="padding: 0 24px"],
	section > div[style*="padding: 0px 24px"] {
		padding: 0 12px !important;
	}
	nav[style*="gap: 8px"], nav[style*="gap:8px"] {
		gap: 4px !important;
		font-size: 0.8rem !important;
		flex-wrap: wrap !important;
	}
	section[style*="padding: 12px 0"] {
		padding: 8px 0 !important;
	}
}

@media (max-width: 480px) {
	.gomoveit-breadcrumbs {
		font-size: 0.7rem;
		gap: 0.15rem;
	}
	nav[style*="gap: 8px"] a, nav[style*="gap:8px"] a,
	nav[style*="gap: 8px"] span, nav[style*="gap:8px"] span {
		font-size: 0.75rem !important;
	}
	nav[style*="gap: 8px"], nav[style*="gap:8px"] {
		gap: 3px !important;
	}
}

.gomoveit-container {
	width: min(1100px, calc(100% - 2.5rem));
	margin: 0 auto;
}

.gomoveit-section {
	padding: 4rem 0;
	background-color: #ffffff;
}
.gomoveit-faq__columns {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
}
.gomoveit-faq__column {
	flex: 1 1 320px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.gomoveit-faq__item {
	border: 1px solid rgba(15, 17, 42, 0.08);
	border-radius: 18px;
	background-color: #ffffff;
	box-shadow: 0 16px 32px rgba(5, 11, 30, 0.08);
}
.gomoveit-faq__question::-webkit-details-marker {
	display: none;
}
.gomoveit-faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.gomoveit-faq__item[open] .gomoveit-faq__question {
	color: var(--gomoveit-red);
}
.gomoveit-faq__question:focus-visible {
	outline: 2px solid var(--gomoveit-red);
	outline-offset: 3px;
}
.gomoveit-faq__answer {
	border-top: 1px solid rgba(15, 17, 42, 0.08);
}

.gomoveit-section.is-muted {
	background-color: var(--gomoveit-offwhite);
}

.gomoveit-section--quote {
	padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(2rem, 4vw, 3rem);
	background: linear-gradient(180deg, #f5f7fb 0%, #ffffff 65%);
}

.gomoveit-section--photo {
	background: linear-gradient(135deg, #fff, #f7f7f7);
}

.gomoveit-section--photo figure img {
	width: 100%;
	border-radius: var(--gomoveit-radius-lg);
	box-shadow: var(--gomoveit-shadow);
}

.gomoveit-quote-shell {
	width: min(1200px, calc(100% - 1.25rem));
	margin: 0 auto;
	padding: 0 clamp(0.75rem, 4vw, 1.75rem);
	display: flex;
	flex-direction: column;
	gap: clamp(1.25rem, 4vw, 2rem);
}

.gomoveit-quote-header {
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

.gomoveit-quote-header h1 {
	margin: 0;
	font-size: clamp(2.1rem, 4vw, 3rem);
}

.gomoveit-quote-header__subtitle {
	margin: 0 auto;
	max-width: 720px;
	color: #475467;
}

.gomoveit-quote-layout {
	display: grid;
	grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
	gap: clamp(1rem, 3vw, 2rem);
	align-items: flex-start;
}

@media (max-width: 960px) {
	.gomoveit-quote-layout {
		grid-template-columns: 1fr;
	}
}

.gomoveit-hero {
	position: relative;
	padding: clamp(48px, 6vw, 96px) 0;
	background: radial-gradient(circle at top left, rgba(211, 42, 38, 0.15), transparent), #ffffff;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
	border-radius: 0;
	display: flex;
	align-items: center;
	overflow: hidden;
}

.gomoveit-hero--with-form {
	overflow: hidden;
}

.gomoveit-hero--page {
	border-radius: 0;
}

.gomoveit-hero .gomoveit-container {
	width: min(1400px, calc(100% - clamp(32px, 6vw, 120px)));
	margin: 0 auto;
}

.gomoveit-hero__grid {
	display: grid;
	gap: clamp(1.5rem, 3vw, 2.5rem);
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	align-items: center;
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 clamp(1rem, 4vw, 3rem);
}

.gomoveit-hero__grid > * {
	min-height: 100%;
}

.gomoveit-hero__form {
	display: flex;
	justify-content: center;
	align-items: stretch;
	width: 100%;
}

.gomoveit-hero__form > * {
	width: 100%;
}

.gomoveit-hero__media {
	margin-top: 0;
	display: flex;
	justify-content: flex-end;
	align-items: center;
}

.gomoveit-hero__media img {
	width: min(360px, 70vw);
	border-radius: var(--gomoveit-radius-lg);
	box-shadow: var(--gomoveit-shadow);
}

.gomoveit-hero__eyebrow {
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.2em;
	color: var(--gomoveit-red);
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.gomoveit-hero__title {
	font-size: clamp(2.2rem, 4.6vw, 3.6rem);
	line-height: 1.15;
	margin-top: 1rem;
	color: var(--gomoveit-dark);
}

.gomoveit-hero__subtitle {
	font-size: 1.1rem;
	max-width: 48rem;
	color: var(--gomoveit-charcoal);
	margin: 1.5rem 0 2rem;
}

.gomoveit-highlight-list {
	list-style: none;
	padding-left: 0;
	margin: 0;
}

.gomoveit-highlight-list li {
	margin-bottom: 0.5rem;
	padding-left: 1.5rem;
	position: relative;
}

.gomoveit-highlight-list li::before {
	content: "";
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--gomoveit-red);
	position: absolute;
	left: 0;
	top: 0.55rem;
}

.gomoveit-cta-group {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.gomoveit-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	line-height: 1;
	gap: var(--gomoveit-btn-gap);
	border-radius: var(--gomoveit-btn-radius);
	font-weight: 700;
	letter-spacing: 0.12em;
	margin-right: -0.12em;
	text-transform: uppercase;
	font-size: var(--gomoveit-btn-font-md);
	padding: var(--gomoveit-btn-pad-md);
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
	min-height: 44px;
	color: #fff;
	text-decoration: none;
}

.gomoveit-btn svg,
.gomoveit-btn i,
.gomoveit-btn .gomoveit-btn__icon {
	width: 1.05em;
	height: 1.05em;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	order: 2;
}

.gomoveit-btn .gomoveit-btn__label {
	order: 1;
}

.gomoveit-btn:hover {
	transform: translateY(-1px);
	box-shadow: var(--gomoveit-btn-shadow);
}

.gomoveit-btn.primary {
	background-color: var(--gomoveit-red);
	color: #fff;
	border-color: var(--gomoveit-red);
}

.gomoveit-btn.primary:hover {
	background-color: var(--gomoveit-red-dark);
	border-color: var(--gomoveit-red-dark);
}

.gomoveit-btn.secondary,
.gomoveit-btn.ghost,
.gomoveit-btn.outline,
.gomoveit-btn.light {
	background-color: var(--gomoveit-charcoal);
	color: #fff;
	border-color: var(--gomoveit-charcoal);
}

.gomoveit-btn.secondary:hover,
.gomoveit-btn.ghost:hover,
.gomoveit-btn.outline:hover,
.gomoveit-btn.light:hover {
	background-color: var(--gomoveit-charcoal-dark);
	border-color: var(--gomoveit-charcoal-dark);
}

.gomoveit-btn--lg {
	font-size: var(--gomoveit-btn-font-lg);
	padding: var(--gomoveit-btn-pad-lg);
}

.gomoveit-btn--xl {
	font-size: var(--gomoveit-btn-font-xl);
	padding: var(--gomoveit-btn-pad-xl);
}

.gomoveit-btn--md {
	font-size: var(--gomoveit-btn-font-md);
	padding: var(--gomoveit-btn-pad-md);
}

.gomoveit-btn--sm {
	font-size: var(--gomoveit-btn-font-sm);
	padding: var(--gomoveit-btn-pad-sm);
}

.gomoveit-footnote {
	font-size: 0.9rem;
	color: var(--gomoveit-charcoal);
	opacity: 0.85;
}

.gomoveit-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.45rem 0.95rem;
	border-radius: 999px;
	background-color: rgba(211, 42, 38, 0.12);
	color: var(--gomoveit-red);
	font-weight: 600;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.gomoveit-grid {
	display: grid;
	gap: 1.5rem;
}

.gomoveit-grid.cols-2 {
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.gomoveit-grid.cols-3 {
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.gomoveit-step-grid .gomoveit-card {
	justify-content: flex-start;
}

.gomoveit-step-card {
	position: relative;
	padding-top: 1.5rem;
}

.gomoveit-step-card__number {
	position: absolute;
	top: -1rem;
	right: 1.5rem;
	font-size: 3.5rem;
	font-weight: 700;
	color: rgba(14, 12, 21, 0.08);
}

.gomoveit-card {
	background-color: #fff;
	border-radius: var(--gomoveit-radius-lg);
	padding: 2rem;
	box-shadow: var(--gomoveit-shadow);
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 0.8rem;
}

.gomoveit-call-form-card {
	background-color: #ffffff;
	border-radius: 32px;
	box-shadow: 0 25px 60px rgba(7, 16, 38, 0.08);
	padding: 28px;
}

.gomoveit-call-form-card.is-compact {
	padding: 20px;
}

.gomoveit-call-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.gomoveit-call-form__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 16px;
}

.gomoveit-call-form__label {
	letter-spacing: 0.05em;
	text-transform: uppercase;
	font-size: 0.75rem;
	color: #6b7280;
}

.gomoveit-call-form button {
	border-radius: 999px;
	border: none;
	background-color: #071026;
	color: #ffffff;
	cursor: pointer;
	font-weight: 600;
	padding: 12px 24px;
}

.gomoveit-card--quote {
	justify-content: space-between;
}

.gomoveit-card h3 {
	margin-bottom: 0.35rem;
	font-size: 1.1rem;
}

.gomoveit-card p {
	margin: 0;
}

.gomoveit-card--service {
	min-height: 220px;
}

.gomoveit-card--quote {
	gap: 1.25rem;
	font-size: 1rem;
}

.gomoveit-stepper {
	counter-reset: gomoveit-step;
	padding-left: 0;
	margin: 2rem 0 0;
}

.gomoveit-stepper li {
	list-style: none;
	position: relative;
	padding-left: 3.2rem;
	margin-bottom: 2rem;
}

.gomoveit-stepper li::before {
	counter-increment: gomoveit-step;
	content: counter(gomoveit-step, decimal-leading-zero);
	position: absolute;
	left: 0;
	top: 0.2rem;
	width: 2.2rem;
	height: 2.2rem;
	border-radius: 50%;
	background-color: var(--gomoveit-red);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
}

.gomoveit-stats {
	display: flex;
	flex-wrap: wrap;
	gap: 1.2rem;
	margin-top: 2rem;
}

.gomoveit-stats__item {
	flex: 1 1 180px;
	background-color: #fff;
	border-radius: var(--gomoveit-radius-md);
	padding: 1.4rem;
	box-shadow: var(--gomoveit-shadow);
	text-align: center;
}

.gomoveit-stats__value {
	font-size: 2rem;
	font-weight: 700;
	color: var(--gomoveit-red);
	margin-bottom: 0.2rem;
}

.gomoveit-tagline {
	font-size: 0.85rem;
	color: var(--gomoveit-charcoal);
	text-transform: uppercase;
	letter-spacing: 0.2em;
}

.gomoveit-contact-card {
	display: inline-flex;
	align-items: center;
	gap: 1rem;
	padding: 1.25rem 1.5rem;
	border-radius: var(--gomoveit-radius-md);
	background-color: var(--gomoveit-dark);
	color: #fff;
	flex-wrap: wrap;
}

.gomoveit-contact-card a {
	color: #fff;
	font-weight: 600;
	text-decoration: none;
}

.gomoveit-contact-card a:hover {
	text-decoration: underline;
}

.gomoveit-footer {
	width: 100%;
	background: #3a3a3a;
	color: #f4f5f7;
}

.gomoveit-footer a {
	color: inherit;
	text-decoration: none;
}

.gomoveit-footer-shell {
	width: 100%;
	padding: clamp(48px, 6vw, 72px) clamp(20px, 5vw, 72px);
	background-color: #3a3a3a;
	box-sizing: border-box;
}

.gomoveit-footer-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: clamp(20px, 4vw, 36px);
	width: min(1200px, 100%);
	margin: 0 auto;
}

.gomoveit-footer-card {
	background: #2a2a2a;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 24px;
	padding: clamp(20px, 3vw, 32px);
	box-shadow: 0 24px 42px rgba(0, 0, 0, 0.4);
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.gomoveit-footer-card--about .gomoveit-footer-logo img {
	height: 52px;
	width: auto;
	display: block;
}

.gomoveit-footer-logo {
	display: inline-flex;
	align-items: center;
}

.gomoveit-footer-card h3,
.gomoveit-footer-card h4 {
	margin: 0;
	color: #ffffff;
}

.gomoveit-footer-card p {
	margin: 0;
	color: rgba(255, 255, 255, 0.78);
	line-height: 1.6;
}

.gomoveit-footer-lede {
	color: rgba(255, 255, 255, 0.88);
	font-size: 1rem;
}

.gomoveit-footer-contact-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
	font-weight: 400;
}

.gomoveit-footer-contact-list li {
	color: rgba(255, 255, 255, 0.92) !important;
	display: flex;
	align-items: center;
	gap: 10px;
}

.gomoveit-footer-contact-list li span,
.gomoveit-footer-contact-list li a,
.gomoveit-footer-contact-list li .__text_block__ {
	color: rgba(255, 255, 255, 0.92) !important;
}

/* Label spans get bold, link values are normal weight */
.gomoveit-footer-contact-list li > span:first-child,
.gomoveit-footer-contact-list li > .__text_block__:first-child {
	font-weight: 700;
	color: rgba(255, 255, 255, 1) !important;
}

.gomoveit-footer-contact-list li a,
.gomoveit-footer-contact-list li > span:not(:first-child) {
	font-weight: 400;
	color: rgba(255, 255, 255, 0.85) !important;
}

/* Footer contact icons */
.gomoveit-footer-contact-list li::before {
	font-size: 1.1rem;
	opacity: 0.8;
	flex-shrink: 0;
}

.gomoveit-footer-contact-list li:nth-child(1)::before { content: "📞"; }
.gomoveit-footer-contact-list li:nth-child(2)::before { content: "📠"; }
.gomoveit-footer-contact-list li:nth-child(3)::before { content: "🕐"; }
.gomoveit-footer-contact-list li:nth-child(4)::before { content: "🪪"; }
.gomoveit-footer-contact-list li:nth-child(5)::before { content: "📍"; }

.gomoveit-footer-note {
	color: rgba(255, 255, 255, 0.7) !important;
	font-size: 0.9rem;
}

.gomoveit-footer-note.__text_block__,
.gomoveit-footer-note .__text_block__ {
	color: rgba(255, 255, 255, 0.7) !important;
}

/* Ensure all footer card text is white */
.gomoveit-footer-card .__text_block__,
.gomoveit-footer-card span,
.gomoveit-footer-card div,
.gomoveit-footer-card p {
	color: rgba(255, 255, 255, 0.9) !important;
}

.gomoveit-footer-card h3,
.gomoveit-footer-card h3.__text_block__ {
	color: #ffffff !important;
}

.gomoveit-footer-lede,
.gomoveit-footer-lede.__text_block__ {
	color: rgba(255, 255, 255, 0.88) !important;
}

.gomoveit-footer-quicklink span,
.gomoveit-footer-quicklink .__text_block__ {
	color: rgba(255, 255, 255, 0.92) !important;
}

.gomoveit-footer-meta a,
.gomoveit-footer-meta .__text_block__ {
	color: rgba(255, 255, 255, 0.72) !important;
}

.gomoveit-footer-quicklinks {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.gomoveit-footer-quicklink {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 10px 16px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 16px;
	font-weight: 600;
	transition: border-color 0.2s ease, transform 0.2s ease;
}

.gomoveit-footer-quicklink:hover {
	border-color: var(--gomoveit-red);
	transform: translateY(-2px);
}

.gomoveit-footer-cta-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.gomoveit-footer-cta-buttons .gomoveit-btn {
	flex: 0 0 auto;
	min-width: 140px;
	justify-content: center;
}

.gomoveit-footer-meta {
	background: #04050b;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	padding: 20px clamp(20px, 5vw, 72px) 26px;
}

.gomoveit-footer-meta-container {
	width: min(1200px, 100%);
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 10px;
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.82rem;
}

.gomoveit-footer-meta-links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.gomoveit-footer-meta small {
	color: rgba(255, 255, 255, 0.75);
}

.gomoveit-footer-meta a:hover {
	color: #ffffff;
}

@media (max-width: 640px) {
	.gomoveit-footer-cta-buttons .gomoveit-btn {
		flex: 1 1 100%;
	}
}

.gomoveit-proof {
	background: linear-gradient(135deg, #ffffff, #f6f6f6);
}

.gomoveit-proof__copy {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	justify-content: center;
}

.gomoveit-proof__media figure {
	margin: 0;
}

.gomoveit-proof__media img {
	width: 100%;
	border-radius: var(--gomoveit-radius-lg);
	box-shadow: var(--gomoveit-shadow);
}

.gomoveit-nav-banner {
	background-color: #f4f7fb;
	padding: 48px 20px 64px;
}

.gomoveit-nav-banner__grid {
	width: min(1100px, calc(100% - 2.5rem));
	margin: 0 auto;
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.gomoveit-nav-banner__card {
	background: #ffffff;
	border-radius: 20px;
	padding: 24px;
	box-shadow: 0 18px 45px rgba(7, 16, 38, 0.08);
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.gomoveit-nav-banner__card h3 {
	margin: 0;
	font-size: 1.2rem;
	color: #071026;
}

.gomoveit-nav-banner__card p {
	margin: 0;
	color: #4b5563;
}

.gomoveit-link {
	font-weight: 600;
	color: var(--gomoveit-red);
	text-decoration: none;
}

.gomoveit-link:hover {
	text-decoration: underline;
}

.gomoveit-proof__panel {
	background-color: var(--gomoveit-dark);
	color: #fff;
	border-radius: var(--gomoveit-radius-lg);
	padding: 2.5rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	box-shadow: var(--gomoveit-shadow);
}

.gomoveit-proof__panel h3 {
	color: #fff;
}

.gomoveit-metrics {
	padding: 2.5rem 0;
	background: #0f0f0f;
	color: #fff;
}

.gomoveit-metrics__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1.25rem;
}

.gomoveit-metric {
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--gomoveit-radius-lg);
	padding: 1.75rem;
	text-align: center;
}

.gomoveit-metric__value {
	font-size: 2.5rem;
	font-weight: 700;
	display: block;
	margin-bottom: 0.35rem;
}

.gomoveit-metric__label {
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 0.85rem;
	opacity: 0.8;
}

.gomoveit-cta-band {
	background: var(--gomoveit-red);
	color: #fff;
}

.gomoveit-eyebrow {
	font-size: 0.85rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--gomoveit-offwhite);
	display: inline-block;
	margin-bottom: 0.35rem;
}

.gomoveit-hero {
	background: linear-gradient(135deg, rgba(15, 15, 15, 0.92), rgba(15, 15, 15, 0.6)),
		url("/assets/packandloadOS_builder/images/photos/gsi-shelves.jpg") center/cover no-repeat;
	border-radius: var(--gomoveit-radius-lg);
	color: #fff;
	padding-top: 2.5rem;
	padding-bottom: 2.5rem;
}

.gomoveit-hero .gomoveit-form-card {
	box-shadow: 0 35px 80px rgba(0, 0, 0, 0.35);
}

.gomoveit-about,
.gomoveit-services,
.gomoveit-overview,
.gomoveit-updates,
.gomoveit-why,
.gomoveit-reviews {
	border-radius: var(--gomoveit-radius-lg);
}

.gomoveit-about,
.gomoveit-services,
.gomoveit-why {
	background: #fff;
}

.gomoveit-overview,
.gomoveit-reviews {
	background: var(--gomoveit-offwhite);
}

.gomoveit-updates {
	background: #151515;
	color: #fff;
}

.gomoveit-why-card {
	border: 1px solid #ececec;
}

.gomoveit-cta-band__grid {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	flex-wrap: wrap;
}

.gomoveit-cta-band h2 {
	color: #fff;
	margin: 0;
}

.gomoveit-list {
	padding-left: 1.1rem;
	margin: 0;
}

.gomoveit-list li {
	margin-bottom: 0.5rem;
}

.gomoveit-success-banner {
	background: #e8f6ef;
	border-left: 4px solid var(--gomoveit-red);
	padding: 0.85rem 0;
	display: none;
}

.gomoveit-success-banner.is-visible {
	display: block;
}

.gomoveit-success-banner div {
	width: min(1100px, calc(100% - 2.5rem));
	margin: 0 auto;
	font-weight: 600;
	color: #1f7a4c;
}

.gomoveit-form-card {
	display: grid;
	grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
	gap: 1.5rem;
	background: #fff;
	border-radius: var(--gomoveit-radius-lg);
	box-shadow: var(--gomoveit-shadow);
	padding: 1.75rem 1.5rem;
}

.gomoveit-form-card__body {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.gomoveit-form-card.is-compact {
	grid-template-columns: 1fr;
}

.gomoveit-form-card.is-compact .gomoveit-form-card__sidebar {
	display: none;
}

.gomoveit-form-card__sidebar {
	background: var(--gomoveit-offwhite);
	border-radius: var(--gomoveit-radius-md);
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.gomoveit-form-card__sidebar h3 {
	margin-bottom: 0.25rem;
}

.gomoveit-form--split {
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.gomoveit-form__group--full {
	grid-column: 1 / -1;
}

.gomoveit-form__toggles {
	flex-direction: row;
	align-items: center;
	gap: 1rem;
}

.gomoveit-form__toggles label {
	display: flex;
	gap: 0.4rem;
	align-items: center;
	font-weight: 500;
	text-transform: none;
	letter-spacing: normal;
}

.gomoveit-bullet-list {
	list-style: disc;
	padding-left: 1.25rem;
	margin: 0;
	color: var(--gomoveit-charcoal);
}

.gomoveit-bullet-list li {
	margin-bottom: 0.35rem;
}

.gomoveit-card--panel {
	background: #0f0f0f;
	color: #fff;
}

.gomoveit-card--panel h3 {
	color: #fff;
}

.gomoveit-pill-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	padding: 0;
	margin: 0 0 1rem 0;
	list-style: none;
}

.gomoveit-pill-list li {
	padding: 0.45rem 0.85rem;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.4);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.gomoveit-form {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 0.85rem;
	margin-top: 1rem;
}

@media (max-width: 700px) {
	.gomoveit-form {
		grid-template-columns: 1fr;
	}
}

.gomoveit-form__group {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.gomoveit-form label {
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--gomoveit-dark);
}

.gomoveit-form input,
.gomoveit-form select,
.gomoveit-form textarea {
	border: 1px solid rgba(84, 86, 91, 0.25);
	border-radius: 12px;
	padding: 0.7rem 0.9rem;
	font-size: 0.95rem;
	font-family: inherit;
	color: var(--gomoveit-dark);
	background-color: #fff;
}

.gomoveit-form textarea {
	min-height: 120px;
	resize: vertical;
}

.gomoveit-form__footer {
	grid-column: 1 / -1;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: center;
	justify-content: space-between;
	margin-top: 0.5rem;
}

.gomoveit-form__status {
	font-size: 0.95rem;
	font-weight: 600;
	padding: 8px 16px;
	border-radius: 6px;
	margin-bottom: 12px;
	position: relative;
	z-index: 10;
	animation: gomoveit-status-fadein 0.3s ease-out;
}

@keyframes gomoveit-status-fadein {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.gomoveit-form__status:empty {
	display: none;
}

.gomoveit-form__status[data-state="error"] {
	color: #b3261e;
	background-color: #fef2f1;
	border: 1px solid #f5c6c6;
}

.gomoveit-form__status[data-state="success"] {
	color: #1f7a4c;
	background-color: #e8f5e9;
	border: 1px solid #a5d6a7;
}

/* Multi-step provider form */
.gomoveit-form--multistep .gomoveit-form__steps {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.gomoveit-form__step {
	display: none;
}
.gomoveit-form__step-title {
	margin: 0 0 8px;
	font-size: 1.1rem;
}
.gomoveit-form__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 14px;
}
.gomoveit-form__footer--inline {
	display: flex;
	gap: 10px;
	align-items: center;
	justify-content: flex-end;
	margin-top: 6px;
}

/* Multi-step form step indicators */
.gomoveit-form__steps {
	display: flex;
	gap: 8px;
	justify-content: center;
	margin-bottom: 24px;
	flex-wrap: wrap;
}

.gomoveit-form__step-indicator {
	padding: 8px 16px;
	background: #f0f2f5;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 500;
	color: #6b7280;
	transition: all 0.2s ease;
}

.gomoveit-form__step-indicator.is-active {
	background: #071026;
	color: #fff;
}

/* Reservation form step indicators use border-bottom instead of background */
[data-reservation-steps-form] .gomoveit-form__step-indicator,
[data-reservation-steps-form] [data-step]:not([data-reservation-step]) {
	background: transparent !important;
	border-bottom: 2px solid #E5E7EB !important;
	color: #6B7280 !important;
}

[data-reservation-steps-form] .gomoveit-form__step-indicator.is-active,
[data-reservation-steps-form] [data-step]:not([data-reservation-step]).is-active {
	background: transparent !important;
	border-bottom: 2px solid #D32A26 !important;
	color: #111827 !important;
}

.gomoveit-form__step-indicator.is-completed {
	background: #10b981;
	color: #fff;
}

/* Form step visibility */
.gomoveit-form__step {
	display: none;
}

.gomoveit-form__step[style*="display: block"] {
	display: block !important;
}

/* Form actions row */
.gomoveit-form__actions {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	margin-top: 24px;
	flex-wrap: wrap;
}

/* Invalid field styling */
.gomoveit-form input.is-invalid,
.gomoveit-form select.is-invalid,
.gomoveit-form textarea.is-invalid,
input.gomoveit-input--invalid,
.gomoveit-input--invalid {
	border-color: #ef4444 !important;
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}

/* =====================================================
   SERVICE PROVIDER & CLAIM FORM STYLING
   ===================================================== */

/* Force single-column layout for form card - remove sidebar */
[data-provider-steps-form] .gomoveit-form-card,
[data-gomoveit-form="claim"] .gomoveit-form-card,
[data-gomoveit-form="provider"] .gomoveit-form-card {
	display: block !important;
	grid-template-columns: 1fr !important;
}

/* Hide the sidebar/footnote text that appears next to form */
[data-provider-steps-form] .gomoveit-footnote,
[data-gomoveit-form="provider"] .gomoveit-footnote {
	display: none !important;
}

/* Provider step header */
[data-provider-steps-form] h2,
[data-provider-steps-form] h3,
[data-provider-steps-form] h4 {
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	color: #0f0f0f !important;
	margin: 0 0 1rem !important;
	padding-bottom: 0.75rem !important;
	border-bottom: 2px solid #D32A26 !important;
}

/* Provider form field wrapper */
[data-provider-steps-form] .gomoveit-field,
.gomoveit-provider-form .gomoveit-field {
	display: flex !important;
	flex-direction: column !important;
	gap: 0.35rem !important;
	margin-bottom: 0.85rem !important;
}

/* Provider form labels */
[data-provider-steps-form] .gomoveit-field__label,
[data-provider-steps-form] label,
.gomoveit-provider-form label {
	font-size: 0.72rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	color: #475467 !important;
	display: block !important;
}

/* Provider form inputs */
[data-provider-steps-form] input,
[data-provider-steps-form] select,
[data-provider-steps-form] textarea,
.gomoveit-provider-form input,
.gomoveit-provider-form select,
.gomoveit-provider-form textarea {
	width: 100% !important;
	padding: 0.65rem 0.85rem !important;
	font-size: 0.95rem !important;
	border: 1px solid #d0d5dd !important;
	border-radius: 10px !important;
	background: #fff !important;
	color: #0f0f0f !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
	box-sizing: border-box !important;
}

[data-provider-steps-form] input:focus,
[data-provider-steps-form] select:focus,
[data-provider-steps-form] textarea:focus,
.gomoveit-provider-form input:focus,
.gomoveit-provider-form select:focus,
.gomoveit-provider-form textarea:focus {
	border-color: #D32A26 !important;
	box-shadow: 0 0 0 3px rgba(211, 42, 38, 0.1) !important;
	outline: none !important;
}

/* Provider form placeholder styling */
[data-provider-steps-form] input::placeholder,
[data-provider-steps-form] textarea::placeholder,
.gomoveit-provider-form input::placeholder,
.gomoveit-provider-form textarea::placeholder {
	color: #98a2b3 !important;
	font-weight: 400 !important;
}

/* Provider form select styling */
[data-provider-steps-form] select,
.gomoveit-provider-form select {
	appearance: none !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23475467' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: right 12px center !important;
	padding-right: 2.5rem !important;
}

/* Provider form Next/Submit button */
[data-provider-steps-form] button[type="submit"],
[data-provider-steps-form] .gomoveit-btn--next,
[data-provider-steps-form] [data-next-step],
.gomoveit-provider-form button[type="submit"] {
	background: #D32A26 !important;
	color: #fff !important;
	border: none !important;
	padding: 0.85rem 2rem !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	border-radius: 999px !important;
	cursor: pointer !important;
	transition: background 0.2s ease, transform 0.1s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
}

[data-provider-steps-form] button[type="submit"]:hover,
[data-provider-steps-form] .gomoveit-btn--next:hover,
[data-provider-steps-form] [data-next-step]:hover,
.gomoveit-provider-form button[type="submit"]:hover {
	background: #b8221f !important;
	transform: translateY(-1px) !important;
}

/* Provider form step actions container */
[data-provider-steps-form] .gomoveit-step-actions,
.gomoveit-provider-form .gomoveit-step-actions {
	display: flex !important;
	justify-content: flex-end !important;
	gap: 1rem !important;
	margin-top: 1.5rem !important;
	padding-top: 1.25rem !important;
	border-top: 1px solid #e4e7ec !important;
}

/* Provider sidebar info box */
[data-provider-steps-form] .gomoveit-form-sidebar,
.gomoveit-provider-sidebar {
	background: #f8fafc !important;
	border: 1px solid #e4e7ec !important;
	border-radius: 12px !important;
	padding: 1.25rem !important;
	margin-bottom: 1.5rem !important;
}

[data-provider-steps-form] .gomoveit-form-sidebar h4,
.gomoveit-provider-sidebar h4 {
	font-size: 0.9rem !important;
	font-weight: 700 !important;
	color: #0f0f0f !important;
	margin: 0 0 0.5rem !important;
	border: none !important;
	padding: 0 !important;
}

[data-provider-steps-form] .gomoveit-form-sidebar p,
.gomoveit-provider-sidebar p {
	font-size: 0.85rem !important;
	color: #475467 !important;
	line-height: 1.5 !important;
	margin: 0 !important;
}

/* Provider form section dividers */
[data-provider-steps-form] .gomoveit-form-section,
.gomoveit-provider-form .gomoveit-form-section {
	margin-top: 1.5rem !important;
	padding-top: 1.25rem !important;
	border-top: 1px solid #f0f0f2 !important;
}

[data-provider-steps-form] .gomoveit-form-section:first-child,
.gomoveit-provider-form .gomoveit-form-section:first-child {
	margin-top: 0 !important;
	padding-top: 0 !important;
	border-top: none !important;
}

/* Direct targeting of all inputs in provider/claim forms */
[data-provider-steps-form] input[type="text"],
[data-provider-steps-form] input[type="email"],
[data-provider-steps-form] input[type="tel"],
[data-provider-steps-form] input[type="url"],
[data-provider-steps-form] input[type="number"],
[data-provider-steps-form] select,
[data-provider-steps-form] textarea,
[data-gomoveit-form="claim"] input[type="text"],
[data-gomoveit-form="claim"] input[type="email"],
[data-gomoveit-form="claim"] input[type="tel"],
[data-gomoveit-form="claim"] select,
[data-gomoveit-form="claim"] textarea {
	width: 100% !important;
	padding: 0.65rem 0.85rem !important;
	font-size: 0.95rem !important;
	font-family: inherit !important;
	border: 1px solid #d0d5dd !important;
	border-radius: 10px !important;
	background: #fff !important;
	color: #0f0f0f !important;
	box-sizing: border-box !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

[data-provider-steps-form] input:focus,
[data-provider-steps-form] select:focus,
[data-provider-steps-form] textarea:focus,
[data-gomoveit-form="claim"] input:focus,
[data-gomoveit-form="claim"] select:focus,
[data-gomoveit-form="claim"] textarea:focus {
	border-color: #D32A26 !important;
	box-shadow: 0 0 0 3px rgba(211, 42, 38, 0.1) !important;
	outline: none !important;
}

/* Auto-fit grid for form fields - same as contact form */
[data-provider-steps-form] .gomoveit-form__grid,
[data-provider-steps-form] .gomoveit-call-form__grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
	gap: 0.85rem !important;
}

/* Full-width elements in grid */
[data-provider-steps-form] .gomoveit-form__group--full {
	grid-column: 1 / -1 !important;
}

/* Provider form group styling - ensure full width within grid cell */
[data-provider-steps-form] .gomoveit-form__group {
	display: flex !important;
	flex-direction: column !important;
	gap: 0.35rem !important;
	width: 100% !important;
	min-width: 0 !important;
}

/* Ensure inputs fill their containers */
[data-provider-steps-form] .gomoveit-form__group input,
[data-provider-steps-form] .gomoveit-form__group select,
[data-provider-steps-form] .gomoveit-form__group textarea {
	width: 100% !important;
	min-width: 0 !important;
	box-sizing: border-box !important;
}

/* Provider form step title styling */
[data-provider-steps-form] .gomoveit-form__step-title {
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	color: #0f0f0f !important;
	margin: 0 0 1.25rem !important;
	padding-bottom: 0.75rem !important;
	border-bottom: 2px solid #D32A26 !important;
}

/* Provider form footer with buttons */
[data-provider-steps-form] .gomoveit-form__footer {
	display: flex !important;
	justify-content: flex-end !important;
	gap: 1rem !important;
	margin-top: 1.5rem !important;
	padding-top: 1.25rem !important;
	border-top: 1px solid #e4e7ec !important;
}

/* Hide Back and Submit buttons by default - JS will show them on appropriate steps */
[data-provider-prev],
[data-provider-submit] {
	display: none;
}

/* Style all buttons in provider form */
[data-provider-steps-form] button,
[data-provider-next],
[data-provider-prev],
[data-provider-submit],
[data-gomoveit-form="claim"] button[type="submit"] {
	background: #D32A26 !important;
	color: #fff !important;
	border: none !important;
	padding: 0.85rem 2rem !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	font-family: inherit !important;
	border-radius: 999px !important;
	cursor: pointer !important;
	transition: background 0.2s ease, transform 0.1s ease !important;
}

[data-provider-steps-form] button:hover,
[data-provider-next]:hover,
[data-provider-submit]:hover,
[data-gomoveit-form="claim"] button[type="submit"]:hover {
	background: #b8221f !important;
	transform: translateY(-1px) !important;
}

[data-provider-prev] {
	background: #f8fafc !important;
	color: #475467 !important;
	border: 1px solid #d0d5dd !important;
}

[data-provider-prev]:hover {
	background: #f0f2f5 !important;
}

/* Provider/Claim form heading styles */
[data-provider-steps-form] h2,
[data-provider-steps-form] h3,
[data-provider-steps-form] h4,
[data-gomoveit-form="claim"] h2,
[data-gomoveit-form="claim"] h3 {
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: #0f0f0f !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
	margin: 0 0 1rem !important;
	padding-bottom: 0.75rem !important;
	border-bottom: 2px solid #D32A26 !important;
}

/* Provider/Claim form step container - hide all steps by default */
[data-provider-step] {
	padding: 0 !important;
	display: none !important;
}

/* Show provider steps only when JavaScript adds is-active class */
[data-provider-step].is-active {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
}

/* Claim form steps - hide all by default */
[data-claim-step] {
	display: none !important;
}

/* Show claim steps only when JavaScript adds is-active class */
[data-claim-step].is-active {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
}

/* Reservation form steps - hide all by default */
[data-reservation-step] {
	display: none !important;
}

/* Show reservation steps only when JavaScript adds is-active class */
[data-reservation-step].is-active {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
}

/* =====================================================
   CLAIM FORM SPECIFIC STYLING
   ===================================================== */

/* Claim form - using .gomoveit-form--stacked now, no extra container styles needed */

/* Claim form field containers - 2 column grid */
[data-gomoveit-form="claim"] .gomoveit-field-grid,
[data-gomoveit-form="claim"] .gomoveit-form-row {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 1rem !important;
}

@media (max-width: 600px) {
	[data-gomoveit-form="claim"] .gomoveit-field-grid,
	[data-gomoveit-form="claim"] .gomoveit-form-row {
		grid-template-columns: 1fr !important;
	}
}

/* Claim form labels */
[data-gomoveit-form="claim"] label,
[data-gomoveit-form="claim"] .gomoveit-field__label {
	font-size: 0.72rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	color: #475467 !important;
	display: block !important;
	margin-bottom: 0.35rem !important;
}

/* Claim form select dropdown arrow */
[data-gomoveit-form="claim"] select {
	appearance: none !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23475467' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: right 12px center !important;
	padding-right: 2.5rem !important;
}

/* Claim form section headers */
[data-gomoveit-form="claim"] .gomoveit-form-section-title {
	font-size: 0.85rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.08em !important;
	color: #0f0f0f !important;
	margin: 1.5rem 0 1rem !important;
	padding-top: 1.25rem !important;
	border-top: 1px solid #e4e7ec !important;
}

[data-gomoveit-form="claim"] .gomoveit-form-section-title:first-child {
	margin-top: 0 !important;
	padding-top: 0 !important;
	border-top: none !important;
}

/* Claim form textarea */
[data-gomoveit-form="claim"] textarea {
	min-height: 120px !important;
	resize: vertical !important;
}

/* Claim form file upload */
[data-gomoveit-form="claim"] input[type="file"] {
	padding: 0.5rem !important;
	border-style: dashed !important;
}

/* Claim form intro text */
[data-gomoveit-form="claim"] .gomoveit-form-intro,
[data-gomoveit-form="claim"] > p:first-of-type {
	font-size: 0.95rem !important;
	color: #475467 !important;
	line-height: 1.5 !important;
	margin: 0 0 1.25rem !important;
	padding-bottom: 1rem !important;
	border-bottom: 1px solid #e4e7ec !important;
}

/* Both forms - hide Brand/Website Domain fields */
[data-gomoveit-form="claim"] input[name="brand"],
[data-gomoveit-form="claim"] input[name="website_domain"],
[data-provider-steps-form] input[name="brand"],
[data-provider-steps-form] input[name="website_domain"] {
	display: none !important;
}

/* Both forms - field wrapper spacing */
[data-gomoveit-form="claim"] .gomoveit-field,
[data-provider-steps-form] .gomoveit-field {
	margin-bottom: 1rem !important;
}

.gomoveit-hero--simple {
	background-color: #fff;
}

.gomoveit-hero__copy.is-centered {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}

.gomoveit-form-guide {
	/* Removed outer container styling - form has its own border now */
	background: transparent;
	border: none;
	border-radius: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
	box-shadow: none;
	backdrop-filter: none;
}

/* Strip wrapper around quote form - remove nested container */
[data-block-label*="Quote Form Panel"],
[data-outline-label*="Quote Form Panel"],
div:has(> .gomoveit-quote-form) {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 !important;
	border-radius: 0 !important;
	backdrop-filter: none !important;
}

.gomoveit-quote-form {
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 25px 60px rgba(14, 12, 21, 0.12);
	padding: 0.5rem 0.6rem;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	border: 2px solid var(--gomoveit-red);
}

.gomoveit-step-banner {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--gomoveit-red);
	margin: 0 0 0.5rem;
	letter-spacing: 0.02em;
}

@media (max-width: 640px) {
	.gomoveit-quote-form {
		padding: 0.75rem;
	}
}

.gomoveit-form-card__intro {
	padding-bottom: 0.65rem;
	margin-bottom: 0.65rem;
	border-bottom: 1px solid rgba(7, 16, 38, 0.1);
}

.gomoveit-form-card__intro h3 {
	margin: 0;
	font-size: 1.1rem;
	color: var(--gomoveit-dark);
}

.gomoveit-form-card__intro p {
	margin: 0.25rem 0 0;
	color: #475467;
}

.gomoveit-step-card {
	border: none;
	border-radius: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	background: transparent;
}

.gomoveit-step-card.is-accent {
	background: transparent;
	border-color: transparent;
}

.gomoveit-step-card__title {
	margin: 0;
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--gomoveit-dark);
}

.gomoveit-multistep-form {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

.gomoveit-multistep-form input.gomoveit-step-input {
	display: none;
}

.gomoveit-form-panel {
	display: none;
	flex-direction: column;
	gap: 0.75rem;
	border: none;
	border-radius: 0;
	padding: clamp(0.85rem, 1.9vw, 1.35rem);
	background: transparent;
	box-shadow: none;
}

.gomoveit-form-panel.is-step-active {
	outline: 2px solid rgba(211, 42, 38, 0.35);
	border-radius: 18px;
	background: rgba(211, 42, 38, 0.02);
}

.gomoveit-form-panel__title {
	margin: 0 0 0.35rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--gomoveit-dark);
}

.gomoveit-form-panel__intro {
	color: #475467;
	margin: 0 0 0.45rem;
}

#gomoveit-step-1:checked ~ .gomoveit-form-panel[data-panel="1"],
#gomoveit-step-2:checked ~ .gomoveit-form-panel[data-panel="2"],
#gomoveit-step-3:checked ~ .gomoveit-form-panel[data-panel="3"],
#gomoveit-step-4:checked ~ .gomoveit-form-panel[data-panel="4"],
#gomoveit-step-5:checked ~ .gomoveit-form-panel[data-panel="5"],
#gomoveit-step-6:checked ~ .gomoveit-form-panel[data-panel="6"],
#gomoveit-step-7:checked ~ .gomoveit-form-panel[data-panel="7"],
#gomoveit-step-8:checked ~ .gomoveit-form-panel[data-panel="8"],
#gomoveit-step-9:checked ~ .gomoveit-form-panel[data-panel="9"],
#gomoveit-step-10:checked ~ .gomoveit-form-panel[data-panel="10"] {
	display: flex;
}

.gomoveit-field-grid {
	display: grid;
	gap: 0.85rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.gomoveit-field-grid.cols-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 700px) {
	.gomoveit-field-grid.cols-2 {
		grid-template-columns: 1fr;
	}
}

.gomoveit-field {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.gomoveit-field__label {
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--gomoveit-charcoal);
}

.gomoveit-field input,
.gomoveit-field select,
.gomoveit-field textarea {
	border: 1px solid rgba(84, 86, 91, 0.25);
	border-radius: 10px;
	padding: 0.65rem 0.9rem;
	font-size: 0.95rem;
	font-family: inherit;
	background-color: #fff;
}

.gomoveit-field textarea {
	min-height: 120px;
	resize: vertical;
}

.gomoveit-field.is-full {
	grid-column: 1 / -1;
}

.gomoveit-step-actions {
	display: flex;
	flex-wrap: nowrap;
	gap: 0.5rem;
	align-items: center;
	justify-content: flex-end;
}

/* Consistent button sizing for step actions and unit controls */
.gomoveit-step-actions .gomoveit-btn,
.gomoveit-unit-controls .gomoveit-btn {
	font-size: 0.85rem;
	padding: 0.65rem 1.25rem;
	min-height: 44px;
	white-space: nowrap;
}

.gomoveit-step-actions--compact {
	flex-wrap: nowrap;
	gap: 0.5rem;
	justify-content: flex-end;
}

.gomoveit-step-actions--compact .gomoveit-btn {
	font-size: 0.85rem;
	padding: 0.65rem 1.25rem;
	min-height: 44px;
	border-radius: var(--gomoveit-btn-radius);
	white-space: nowrap;
}

/* Back button row - text link style */
.gomoveit-step-actions--back {
	margin-top: 0.15rem;
	justify-content: flex-end;
}

.gomoveit-step-actions--back .gomoveit-btn {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0.25rem 0.5rem;
	font-size: 0.75rem;
	color: var(--gomoveit-gray);
	text-decoration: underline;
}

.gomoveit-step-actions--back .gomoveit-btn:hover {
	color: var(--gomoveit-dark);
	background: transparent !important;
}

.gomoveit-unit-controls {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: center;
}

.gomoveit-unit-count {
	font-weight: 600;
	color: #071026;
}

.gomoveit-unit-repeaters {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.gomoveit-unit-size {
	display: none;
	flex-direction: column;
	gap: 0.35rem;
}

.gomoveit-vendor-panel {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	border: 1px solid #e4e7ec;
	border-radius: 18px;
	padding: 1rem;
	background: #fff;
}

.gomoveit-vendor-status {
	font-size: 0.85rem;
	color: #475467;
}

.gomoveit-vendor-list {
	display: grid;
	gap: 0.75rem;
}

.gomoveit-panel-group {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.gomoveit-panel-heading {
	margin: 0;
	font-size: 1rem;
	font-weight: 600;
}

.gomoveit-multi {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.gomoveit-multi__option {
	border: 1px solid #d0d5dd;
	border-radius: 999px;
	padding: 0.45rem 0.9rem;
	font-size: 0.95rem;
	display: inline-flex;
	gap: 0.35rem;
	align-items: center;
	background: #fff;
	cursor: pointer;
}

.gomoveit-multi.has-error {
	border: 1px solid #f04438;
	border-radius: 12px;
	padding: 0.5rem;
}

.gomoveit-multi__option input {
	margin: 0;
	/* Custom checkbox styling */
	appearance: none;
	-webkit-appearance: none;
	width: 18px;
	height: 18px;
	min-width: 18px;
	border: 2px solid #d0d5dd;
	border-radius: 4px;
	background: #fff;
	cursor: pointer;
	position: relative;
	transition: all 0.15s ease;
}

.gomoveit-multi__option input:checked {
	background: #00a59b !important;
	border-color: #00a59b !important;
}

.gomoveit-multi__option input:checked::after {
	content: '';
	position: absolute;
	left: 5px;
	top: 2px;
	width: 5px;
	height: 9px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.gomoveit-multi__option:has(input:checked) {
	background: #e6f7f6 !important;
	border-color: #00a59b !important;
}

.gomoveit-multi__option input:focus {
	outline: 2px solid #00a59b40;
	outline-offset: 1px;
}

/* Ensure span text is visible next to checkbox in inline multi-options */
.gomoveit-multi__option span {
	position: relative;
	z-index: 1;
	color: #344054;
	font-weight: 500;
	white-space: nowrap;
}

.gomoveit-access-checkbox {
	display: flex;
	gap: 0.5rem;
	align-items: flex-start;
}

.gomoveit-review {
	border: 1px solid #e4e7ec;
	border-radius: 18px;
	padding: 0.75rem 0.85rem;
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

.gomoveit-review__row {
	display: flex;
	justify-content: space-between;
	gap: 0.4rem;
	font-size: 0.88rem;
}

.gomoveit-review__row span {
	color: #475467;
}

.gomoveit-quote-summary {
	border: 1px solid #e4e7ec;
	border-radius: 18px;
	padding: 0.75rem 0.9rem;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.gomoveit-quote-summary__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0.25rem 0.65rem;
}

.gomoveit-quote-summary__row {
	display: flex;
	justify-content: space-between;
	gap: 0.25rem;
}

.gomoveit-quote-summary__total {
	display: flex;
	justify-content: space-between;
	gap: 0.5rem;
	font-weight: 600;
}

.gomoveit-payment-panel {
	border: 1px solid #e4e7ec;
	border-radius: 18px;
	padding: 1.25rem;
	background: #f8fafc;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	overflow: visible;
}

/* Ensure payment grid stays within panel */
.gomoveit-payment-panel .gomoveit-payment-grid {
	width: 100%;
	max-width: 100%;
}

.gomoveit-payment-placeholder {
	border: 1px dashed #cbd4e1;
	border-radius: 14px;
	padding: 1rem;
	text-align: center;
	font-size: 0.9rem;
	color: #475467;
	background: #fff;
}

/* Authorize.net Trust Badge */
.gomoveit-payment-trust-badge {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	margin-top: 12px;
	padding: 8px 16px;
	background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
	border: 1px solid #e2e8f0;
	border-radius: 8px;
}

.gomoveit-payment-trust-badge svg {
	flex-shrink: 0;
}

.gomoveit-payment-trust-text {
	font-size: 0.72rem;
	color: #64748b;
	font-weight: 500;
	letter-spacing: 0.02em;
}

/* Payment Grid Layout */
.gomoveit-payment-grid {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.gomoveit-payment-row {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-end;
	gap: 0.75rem;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* All payment row fields - equal flex, align bottoms */
.gomoveit-payment-row .gomoveit-field {
	flex: 1 1 0;
	min-width: 0;
}

/* Ensure labels align at top, inputs at bottom */
.gomoveit-payment-row .gomoveit-field__label {
	white-space: nowrap;
}

/* Card number validation states */
[data-payment-card-number].is-valid {
	border-color: #22c55e !important;
	background-color: rgba(34, 197, 94, 0.05);
}

[data-payment-card-number].is-invalid {
	border-color: #ef4444 !important;
	background-color: rgba(239, 68, 68, 0.05);
}

[data-payment-card-number]:focus.is-valid {
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

[data-payment-card-number]:focus.is-invalid {
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15);
}

/* Card input wrapper for indicator positioning */
.gomoveit-card-input-wrapper {
	position: relative;
	display: block;
	width: 100%;
}

.gomoveit-card-input-wrapper input {
	width: 100%;
}

/* Card type indicator */
.gomoveit-card-type {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #64748b;
	pointer-events: none;
	padding: 2px 6px;
	border-radius: 4px;
	background: #f1f5f9;
}

.gomoveit-card-type[data-card-type="visa"] {
	color: #1a1f71;
	background: rgba(26, 31, 113, 0.1);
}

.gomoveit-card-type[data-card-type="mastercard"] {
	color: #eb001b;
	background: rgba(235, 0, 27, 0.1);
}

.gomoveit-card-type[data-card-type="amex"] {
	color: #006fcf;
	background: rgba(0, 111, 207, 0.1);
}

.gomoveit-card-type[data-card-type="discover"] {
	color: #ff6000;
	background: rgba(255, 96, 0, 0.1);
}

.gomoveit-card-type:empty {
	display: none;
}

/* Adjust card number input padding for type indicator */
[data-payment-card-number] {
	padding-right: 80px !important;
}

.gomoveit-call-options {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.gomoveit-call-option {
	border: 1px solid rgba(7, 16, 38, 0.12);
	border-radius: 16px;
	padding: 0.75rem 1rem;
	display: flex;
	gap: 0.75rem;
	align-items: center;
	background: #fff;
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.gomoveit-call-option input {
	margin: 0;
	width: 1rem;
	height: 1rem;
	flex-shrink: 0;
}

.gomoveit-call-option__body {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
	line-height: 1.2;
}

.gomoveit-call-option__label {
	font-size: 0.92rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #071026;
}

.gomoveit-call-option small {
	font-size: 0.8rem;
	color: #475467;
}

.gomoveit-call-option.is-selected {
	border-color: var(--gomoveit-red);
	box-shadow: 0 0 0 1px rgba(211, 42, 38, 0.15);
}

/* Truck question options - similar to call options but horizontal */
.gomoveit-truck-question {
	margin-top: 0.5rem;
}

.gomoveit-truck-options {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
}

.gomoveit-truck-option {
	flex: 1;
	min-width: 140px;
	border: 1px solid rgba(7, 16, 38, 0.12);
	border-radius: 12px;
	padding: 0.65rem 0.85rem;
	display: flex;
	gap: 0.6rem;
	align-items: center;
	background: #fff;
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.gomoveit-truck-option input {
	margin: 0;
	width: 1rem;
	height: 1rem;
	flex-shrink: 0;
}

.gomoveit-truck-option__body {
	display: flex;
	flex-direction: column;
	gap: 0.05rem;
	line-height: 1.2;
}

.gomoveit-truck-option__label {
	font-size: 0.85rem;
	font-weight: 600;
	color: #071026;
}

.gomoveit-truck-option small {
	font-size: 0.75rem;
	color: #475467;
}

.gomoveit-truck-option.is-selected {
	border-color: var(--gomoveit-red);
	box-shadow: 0 0 0 1px rgba(211, 42, 38, 0.15);
	background: #fef5f5;
}

/* Services Multi-Select Checkboxes */
.gomoveit-services-multiselect {
	margin-top: 0.5rem;
}

.gomoveit-services-options {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.35rem;
}

.gomoveit-service-checkbox {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.4rem 0.65rem;
	border: 1px solid #d0d5dd;
	border-radius: 8px;
	cursor: pointer;
	transition: all 0.15s ease;
	background: #fff;
	font-size: 0.85rem;
}

.gomoveit-service-checkbox:hover {
	border-color: var(--gomoveit-charcoal);
}

.gomoveit-service-checkbox input[type="checkbox"] {
	width: 0.9rem;
	height: 0.9rem;
	accent-color: var(--gomoveit-red);
}

.gomoveit-service-checkbox:has(input:checked) {
	border-color: var(--gomoveit-red);
	background: #fef5f5;
}

/* Step 2 Grid - Force 2 columns for the 2x2 layout (Services + Units + Equipment + Job Start) */
.gomoveit-step2-grid,
.gomoveit-field-grid.cols-2.gomoveit-step2-grid {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 0.85rem !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

/* Equipment and Job Start questions in Step 2 grid */
.gomoveit-step2-grid .gomoveit-equipment-question,
.gomoveit-step2-grid .gomoveit-job-start-question {
	width: 100% !important;
	box-sizing: border-box !important;
}

/* Labels for Step 2 grid fields */
.gomoveit-step2-grid .gomoveit-field__label {
	font-size: 0.72rem !important;
	font-weight: 600 !important;
	margin-bottom: 0.25rem !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	display: block !important;
}

/* Step 2 Grid - Select and Input styling (exclude dropdown checkboxes) */
.gomoveit-step2-grid > .gomoveit-field > select,
.gomoveit-step2-grid > .gomoveit-field > input:not([type="checkbox"]),
.gomoveit-step2-grid .gomoveit-equipment-question select,
.gomoveit-step2-grid .gomoveit-job-start-question select {
	width: 100%;
	padding: 0.35rem 0.45rem;
	border: 1px solid #d0d5dd;
	border-radius: 6px;
	font-size: 0.75rem;
	background-color: #fff;
}

/* Services multi-select dropdown - proper full width */
.gomoveit-step2-grid .gomoveit-services-dropdown,
.gomoveit-step2-grid .gomoveit-multi-select {
	width: 100%;
}

.gomoveit-step2-grid .gomoveit-multi-select__control {
	width: 100%;
	min-height: 38px;
	padding: 0.35rem 0.5rem;
	border: 1px solid #d0d5dd;
	border-radius: 6px;
	background: #fff;
	font-size: 0.75rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 4px;
}

.gomoveit-step2-grid .gomoveit-multi-select__menu {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	width: 100%;
	min-width: 200px;
	background: #fff;
	border: 1px solid #d0d5dd;
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
	z-index: 100;
	max-height: 200px;
	overflow-y: auto;
	display: none; /* CRITICAL: Must be hidden by default */
}

/* Show menu when dropdown is open */
.gomoveit-step2-grid .gomoveit-multi-select.is-open .gomoveit-multi-select__menu {
	display: block;
}

.gomoveit-step2-grid .gomoveit-multi-select__option {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	padding: 10px 14px !important;
	cursor: pointer !important;
	font-size: 0.85rem !important;
	background: #fff !important;
	border: none !important;
	border-radius: 0 !important;
	margin: 0 !important;
	width: 100% !important;
	position: relative !important;
}

.gomoveit-step2-grid .gomoveit-multi-select__option:hover {
	background: #f5f5f5 !important;
}

/* Hide native checkbox inside the dropdown */
.gomoveit-step2-grid .gomoveit-multi-select__option input[type="checkbox"] {
	position: absolute !important;
	opacity: 0 !important;
	width: 0 !important;
	height: 0 !important;
	pointer-events: none !important;
}

/* Step2-grid checkbox indicator styling */
.gomoveit-step2-grid .gomoveit-multi-select__checkbox {
	width: 18px !important;
	height: 18px !important;
	min-width: 18px !important;
}

.gomoveit-step2-grid .gomoveit-multi-select__label {
	color: #333 !important;
	font-weight: 400 !important;
	white-space: nowrap !important;
}

/* Step 2 grid unit count input styling */
.gomoveit-step2-grid input[name="unit_count"] {
	text-align: center;
}

/* Step 2 grid - stack on phones only */
@media (max-width: 400px) {
	.gomoveit-step2-grid {
		grid-template-columns: 1fr !important;
	}
}

/* 75 feet access confirmation checkbox - hide duplicate label */
.gomoveit-field:has(input[name="access_within_75ft"]) > .gomoveit-field__label,
.gomoveit-field:has(.gomoveit-access-checkbox) > .gomoveit-field__label {
	display: none !important;
}

/* 75 feet checkbox - proper inline styling */
.gomoveit-access-checkbox,
label:has(input[name="access_within_75ft"]) {
	display: flex !important;
	align-items: flex-start !important;
	gap: 10px !important;
	cursor: pointer !important;
	font-size: 0.9rem !important;
	line-height: 1.4 !important;
	padding: 12px !important;
	background: #f9fafb !important;
	border: 1px solid #e5e7eb !important;
	border-radius: 8px !important;
}

.gomoveit-access-checkbox input[type="checkbox"],
input[name="access_within_75ft"] {
	width: 20px !important;
	height: 20px !important;
	min-width: 20px !important;
	margin: 0 !important;
	accent-color: var(--gomoveit-red, #d32a26) !important;
	cursor: pointer !important;
	flex-shrink: 0 !important;
}

.gomoveit-access-checkbox span {
	flex: 1 !important;
	color: #374151 !important;
	font-weight: 500 !important;
}

/* Standardized field labels - match Step 2 styling across all form steps */
.gomoveit-multistep-form .gomoveit-field__label,
.gomoveit-multistep-form .gomoveit-field > label:first-child,
.gomoveit-multistep-form .gomoveit-panel-heading,
.gomoveit-multistep-form [class*="field__label"] {
	font-size: 0.72rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	color: var(--gomoveit-charcoal, #2d3748) !important;
	margin-bottom: 0.35rem !important;
	display: block !important;
}

/* Field Validation Error Highlighting */
.gomoveit-field--error {
	animation: gomoveit-pulse-error 0.4s ease-in-out;
}

.gomoveit-input--error,
.gomoveit-field--error input,
.gomoveit-field--error select,
.gomoveit-field--error textarea {
	border-color: var(--gomoveit-red) !important;
	box-shadow: 0 0 0 3px rgba(211, 42, 38, 0.2) !important;
	background-color: #fef5f5 !important;
}

.gomoveit-field--error .gomoveit-service-checkbox,
.gomoveit-field--error .gomoveit-services-options {
	border-color: var(--gomoveit-red);
	box-shadow: 0 0 0 2px rgba(211, 42, 38, 0.15);
	border-radius: 12px;
	padding: 0.25rem;
}

.gomoveit-shake {
	animation: gomoveit-shake 0.5s ease-in-out;
}

@keyframes gomoveit-shake {
	0%, 100% { transform: translateX(0); }
	10%, 30%, 50%, 70%, 90% { transform: translateX(-5px); }
	20%, 40%, 60%, 80% { transform: translateX(5px); }
}

@keyframes gomoveit-pulse-error {
	0% { background-color: transparent; }
	50% { background-color: rgba(211, 42, 38, 0.1); }
	100% { background-color: transparent; }
}

/* Error message text */
.gomoveit-error-message {
	color: var(--gomoveit-red);
	font-size: 0.8rem;
	margin-top: 0.35rem;
	display: flex;
	align-items: center;
	gap: 0.35rem;
}

.gomoveit-error-message::before {
	content: "⚠";
}

/* Consistent form button sizing across all steps */
.gomoveit-form-panel button[type="submit"],
.gomoveit-form-panel button[type="button"]:not(.gomoveit-multi-select__control),
.gomoveit-form-panel .btn,
[data-panel] button[type="submit"],
[data-panel] button[type="button"]:not(.gomoveit-multi-select__control) {
	font-size: 0.85rem;
	padding: 0.65rem 1.25rem;
	min-height: 44px;
}

/* Review page 75ft text smaller */
.gomoveit-access-confirm,
.gomoveit-access-confirm__label {
	font-size: 0.85rem;
}

.gomoveit-facility-select-group {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	width: 100%;
}

.gomoveit-facility-select {
	width: 100%;
	padding: 0.65rem 0.85rem;
	border: 1px solid #d0d5dd;
	border-radius: 12px;
	font-size: 0.95rem;
	background-color: #fff;
}

.gomoveit-facility-search-inline {
	width: 100%;
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	pointer-events: none;
	transition: max-height 0.2s ease, opacity 0.2s ease, margin 0.2s ease;
}

.gomoveit-facility-search-inline.is-visible {
	max-height: 80px;
	opacity: 1;
	pointer-events: auto;
	margin-top: 0.35rem;
}

.gomoveit-facility-search__input {
	width: 100%;
	border: 1px solid #d0d5dd;
	border-radius: 10px;
	padding: 0.55rem 0.8rem;
	font-size: 0.9rem;
	font-family: inherit;
}

.gomoveit-facility-select:focus + .gomoveit-facility-search-inline {
	max-height: 80px;
	opacity: 1;
	pointer-events: auto;
	margin-top: 0.35rem;
}

.gomoveit-facility-details {
	font-size: 0.85rem;
	color: #475467;
	margin-top: 0.35rem;
	line-height: 1.35;
}

.gomoveit-save-progress-row {
	width: 100%;
	text-align: center;
	margin-top: 0.5rem;
	display: flex;
	justify-content: center;
}

.gomoveit-save-progress {
	background: none;
	border: none;
	color: #071026;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: underline;
	cursor: pointer;
	padding: 0.25rem 0;
}

.gomoveit-access-confirm {
	padding: 14px 16px;
	border: 1px solid #d0d5dd;
	border-radius: 14px;
	background: #f8fafc;
	margin-top: 12px;
}

.gomoveit-access-confirm label {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	cursor: pointer;
	margin: 0;
	width: 100%;
}

.gomoveit-access-confirm input[type="checkbox"] {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	margin: 2px 0 0 0;
	accent-color: var(--gomoveit-red, #d32a26);
	cursor: pointer;
}

.gomoveit-access-confirm span {
	font-weight: 500;
	font-size: 0.95rem;
	line-height: 1.5;
	color: #344054;
}

.gomoveit-access-confirm span strong {
	font-weight: 700;
	color: #071026;
}

.gomoveit-save-progress:hover,
.gomoveit-save-progress:focus-visible {
	opacity: 0.8;
	outline: none;
}

.gomoveit-btn[data-submitting="true"] {
	opacity: 0.65;
	pointer-events: none;
}

@media screen and (max-width: 767px) {
	.gomoveit-hero {
		padding: 4.5rem 0 3rem;
	}

	.gomoveit-cta-group {
		flex-direction: column;
	}

	.gomoveit-contact-card {
		justify-content: center;
		text-align: center;
	}

	.gomoveit-cta-band__grid {
		flex-direction: column;
		align-items: stretch;
	}

	.gomoveit-metric__value {
		font-size: 2rem;
	}

	.gomoveit-form-card {
		grid-template-columns: 1fr;
		padding: 1.5rem;
	}

	.gomoveit-hero__media {
		justify-content: center;
	}

.gomoveit-hero__media img {
	width: 100%;
}

 	.gomoveit-submenu {
		position: static;
		transform: none;
		opacity: 1;
		box-shadow: none;
		padding: 0.25rem 0 0.5rem;
		pointer-events: auto;
	}
}

/* Triage form */
.gomoveit-triage-card {
	background: #ffffff;
	border-radius: 24px;
	box-shadow: 0 20px 60px rgba(7, 16, 38, 0.12);
	padding: 16px 18px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	width: 100%;
}
.gomoveit-triage__title {
	font-size: 1.4rem;
	font-weight: 700;
	color: #071026;
	margin: 4px 0 6px;
}

.gomoveit-triage__progress {
	display: none !important;
}

.gomoveit-triage__form {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.gomoveit-triage__step {
	display: none;
	flex-direction: column;
	gap: 20px;
}

.gomoveit-triage__step.is-active {
	display: flex;
}

.gomoveit-triage__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 12px;
}

.gomoveit-triage__field {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.gomoveit-triage__field.is-full {
	grid-column: 1 / -1;
}

.gomoveit-triage__label {
	font-size: 0.78rem;
	font-weight: 600;
	color: #475467;
}

.gomoveit-triage__toggles {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

.gomoveit-triage__toggles label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	color: #071026;
}

.gomoveit-multi-select {
	position: relative;
}

.gomoveit-multi-select__control {
	width: 100%;
	background-color: #fff !important;
	border: 1px solid rgba(84, 86, 91, 0.25) !important;
	border-radius: 10px;
	padding: 0.65rem 2.5rem 0.65rem 0.9rem;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	min-height: 44px;
	text-align: left;
	cursor: pointer;
	color: var(--gomoveit-charcoal, #3A3A3A) !important;
	font-family: inherit !important;
	font-size: 0.95rem !important;
	font-weight: 400 !important;
}

.gomoveit-multi-select__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
}

.gomoveit-chip {
	border-radius: 999px;
	background: #eef2ff !important;
	color: #1d4ed8 !important;
	font-size: 0.78rem;
	font-weight: 500;
	font-family: inherit;
	padding: 3px 12px;
}

.gomoveit-multi-select__placeholder {
	color: #98a2b3;
	font-size: inherit;
	font-family: inherit;
	font-weight: 400;
}

.gomoveit-multi-select__caret {
	position: absolute;
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 0.85rem;
	color: #475467;
}

.gomoveit-multi-select__menu {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	width: 100%;
	max-height: 230px;
	overflow-y: auto;
	background: #fff;
	border: 1px solid rgba(84, 86, 91, 0.25);
	border-radius: 10px;
	box-shadow: 0 20px 45px rgba(7, 16, 38, 0.12);
	padding: 6px 0;
	display: none;
	z-index: 40;
}

.gomoveit-multi-select.is-open .gomoveit-multi-select__menu {
	display: block;
}

.gomoveit-multi-select__option {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	cursor: pointer;
	font-size: 0.9rem;
	position: relative;
}

.gomoveit-multi-select__option:hover {
	background: #f8fafc;
}

.gomoveit-multi-select__option input {
	/* Hide native checkbox */
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}

/* Custom checkbox indicator element */
.gomoveit-multi-select__checkbox {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	min-width: 20px;
	border: 2px solid #d0d5dd;
	border-radius: 4px;
	background: #fff;
	transition: all 0.15s ease;
	color: transparent;
}

.gomoveit-multi-select__checkbox svg {
	width: 12px;
	height: 10px;
}

/* Checked state - teal background with checkmark */
.gomoveit-multi-select__option:has(input:checked) .gomoveit-multi-select__checkbox {
	background: #00a59b !important;
	border-color: #00a59b !important;
	color: #fff !important;
}

/* Checked row highlight */
.gomoveit-multi-select__option:has(input:checked) {
	background: #e6f7f6 !important;
}

/* Label text */
.gomoveit-multi-select__label {
	color: #333;
	flex: 1;
}

/* Fallback for browsers that don't support :has() */
.gomoveit-multi-select__option input:checked + .gomoveit-multi-select__checkbox {
	background: #00a59b;
	border-color: #00a59b;
	color: #fff;
}

.gomoveit-multi-select.has-error .gomoveit-multi-select__control {
	border-color: #f04438;
	box-shadow: 0 0 0 2px rgba(240, 68, 56, 0.12);
}

.gomoveit-select {
	width: 100%;
	border: 1px solid #d0d5dd;
	border-radius: 12px;
	padding: 10px 12px;
	font-size: 0.95rem;
	background-color: #ffffff;
	color: #071026;
}

.gomoveit-triage__footer {
	display: flex;
	justify-content: flex-end;
	gap: 12px;
}
.gomoveit-triage__cta-row {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	margin-top: 4px;
}
.gomoveit-triage__cta-row .gomoveit-btn {
	flex: 1 1 auto;
	min-width: 100px;
	max-width: 100%;
	padding: var(--gomoveit-btn-pad-sm);
	font-size: var(--gomoveit-btn-font-sm);
	line-height: 1.2;
	white-space: nowrap;
	text-overflow: ellipsis;
	overflow: hidden;
}

/* Stack buttons vertically in narrow containers */
@media (max-width: 500px) {
	.gomoveit-triage__cta-row {
		flex-direction: column;
	}
	.gomoveit-triage__cta-row .gomoveit-btn {
		width: 100%;
		text-align: center;
	}
}
.gomoveit-triage__summary {
	border: 1px solid #e4e7ec;
	border-radius: 16px;
	padding: 14px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	background-color: #fff;
}
.gomoveit-triage__summary.is-full {
	grid-column: 1 / -1;
}
.gomoveit-triage__summary-items {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.gomoveit-triage__summary-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	font-size: 0.9rem;
	color: #0f172a;
}
.gomoveit-triage__summary-label {
	color: #475467;
}
.gomoveit-triage__summary-value {
	font-weight: 600;
}
.gomoveit-footnote--disclaimer {
	margin: 6px 0 0;
	font-size: 0.78rem;
	font-weight: 600;
	color: #1d1f2c;
}

.gomoveit-triage__vendor-panel {
	border: 1px solid #dbe2f0;
	border-radius: 20px;
	padding: 1.25rem 1.5rem;
	background: #f8fafc;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.gomoveit-triage__vendor-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.gomoveit-triage__vendor-option {
	display: flex;
	gap: 0.75rem;
	border: 1px solid #dbe2f0;
	border-radius: 16px;
	padding: 0.75rem 1rem;
	background: #ffffff;
	align-items: flex-start;
}

.gomoveit-triage__vendor-option input[type="radio"] {
	margin-top: 0.3rem;
}

.gomoveit-triage__vendor-option h4 {
	margin: 0;
	font-size: 1rem;
}

.gomoveit-triage__vendor-option p {
	margin: 0.1rem 0 0;
	color: #475467;
}

.gomoveit-triage__vendor-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 16px;
	font-size: 0.9rem;
	color: #0f172a;
}

.gomoveit-triage__vendor-refresh {
	align-self: flex-start;
}

@media (max-width: 640px) {
	.gomoveit-triage-card {
		padding: 20px;
	}

	.gomoveit-triage__footer {
		flex-direction: column;
	}

	.gomoveit-triage__footer .gomoveit-btn {
		width: 100%;
		text-align: center;
	}
	.gomoveit-triage__cta-row {
		flex-direction: column;
	}
}

body.gomoveit-privacy-modal-open {
	overflow: hidden;
}

.gomoveit-cookie-banner {
	position: fixed;
	left: 24px;
	right: auto;
	bottom: 24px;
	transform: none;
	width: min(360px, calc(100% - 48px));
	background: rgba(5, 11, 30, 0.95);
	color: #fff;
	padding: 14px 18px;
	border-radius: 14px;
	border-left: 4px solid var(--gomoveit-red);
	box-shadow: 0 18px 30px rgba(5, 11, 30, 0.28);
	display: flex;
	flex-direction: column;
	gap: 10px;
	z-index: 1100;
	transition: opacity 0.2s ease, transform 0.2s ease;
	text-align: left;
	font-size: 0.9rem;
}

.gomoveit-cookie-banner.is-hidden {
	opacity: 0;
	transform: translateY(30px);
	pointer-events: none;
}

.gomoveit-cookie-banner__title {
	font-weight: 600;
	margin: 0 0 2px;
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.gomoveit-cookie-banner__copy p {
	margin: 0;
	font-size: 0.85rem;
	line-height: 1.4;
	color: rgba(255, 255, 255, 0.85);
}

.gomoveit-cookie-banner__link {
	color: #8bc4ff;
	text-decoration: underline;
}

.gomoveit-cookie-banner__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: flex-start;
	align-items: center;
}

.gomoveit-cookie-banner__actions .gomoveit-btn {
	flex: 0 0 auto;
	min-width: auto;
	padding: var(--gomoveit-btn-pad-sm);
	font-size: var(--gomoveit-btn-font-sm);
}

@media (max-width: 520px) {
	.gomoveit-cookie-banner {
		left: 16px;
		width: calc(100% - 32px);
	}
	.gomoveit-cookie-banner__actions {
		flex-direction: column;
	}
	.gomoveit-cookie-banner__actions .gomoveit-btn {
		width: 100%;
	}
}

.gomoveit-privacy-modal {
	position: fixed;
	inset: 0;
	z-index: 1200;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.gomoveit-privacy-modal.is-open {
	display: flex;
}

.gomoveit-privacy-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(5, 11, 30, 0.78);
	backdrop-filter: blur(2px);
}

.gomoveit-privacy-modal__dialog {
	position: relative;
	width: min(920px, 100%);
	max-height: calc(100vh - 48px);
	overflow-y: auto;
	background: #fff;
	border-radius: 28px;
	box-shadow: 0 50px 80px rgba(5, 11, 30, 0.35);
	padding: clamp(20px, 4vw, 36px);
	z-index: 1;
}

.gomoveit-privacy-modal__close {
	position: absolute;
	top: 12px;
	right: 12px;
	border: none;
	background: transparent;
	color: #0b1224;
	font-size: 1.8rem;
	line-height: 1;
	cursor: pointer;
}

.gomoveit-privacy-modal__tabs {
	display: flex;
	gap: 12px;
	margin-bottom: 24px;
	flex-wrap: wrap;
}

.gomoveit-privacy-modal__tab {
	flex: 1 1 160px;
	border: 1px solid #dde1ed;
	border-radius: 999px;
	padding: 10px 18px;
	background: #f4f6fb;
	color: #071026;
	font-weight: 600;
	text-align: center;
	cursor: pointer;
}

.gomoveit-privacy-modal__tab.is-active {
	background: var(--gomoveit-red);
	border-color: var(--gomoveit-red);
	color: #fff;
}

.gomoveit-privacy-modal__panels {
	display: block;
}

.gomoveit-privacy-modal__panel {
	display: none;
}

.gomoveit-privacy-modal__panel.is-active {
	display: block;
}

.gomoveit-privacy-modal__lead {
	margin: 0 0 20px;
	font-size: 1rem;
	color: #4c5672;
}

.gomoveit-cookie-toggle {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 16px 0;
	border-top: 1px solid #edf0f7;
	align-items: center;
}

.gomoveit-cookie-toggle:first-of-type {
	border-top: none;
}

.gomoveit-cookie-toggle__title {
	margin: 0 0 4px;
	font-weight: 600;
}

.gomoveit-cookie-toggle__copy {
	margin: 0;
	font-size: 0.9rem;
	color: #4c5672;
}

.gomoveit-switch {
	width: 48px;
	height: 26px;
	position: relative;
	display: inline-flex;
	align-items: center;
}

.gomoveit-switch input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.gomoveit-switch__slider {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 999px;
	background: #c5ccdd;
	transition: background 0.2s ease;
}

.gomoveit-switch__slider::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 4px;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: #fff;
	transition: transform 0.2s ease;
	box-shadow: 0 2px 6px rgba(7, 16, 38, 0.15);
}

.gomoveit-switch input:checked + .gomoveit-switch__slider {
	background: #0b7fe0;
}

.gomoveit-switch input:checked + .gomoveit-switch__slider::after {
	transform: translateX(20px);
}

.gomoveit-cookie-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 20px;
}

.gomoveit-cookie-status {
	font-size: 0.9rem;
	color: #0f8b48;
	margin: 12px 0 0;
}

.gomoveit-privacy-form {
	margin-top: 8px;
}

.gomoveit-privacy-form__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 16px;
	margin-bottom: 16px;
}

.gomoveit-privacy-form__grid--stacked {
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	max-width: 520px;
}

.gomoveit-privacy-form__row {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px;
	margin-bottom: 14px;
}

.gomoveit-privacy-form__grid label,
.gomoveit-privacy-form__details {
	display: flex;
	flex-direction: column;
	gap: 6px;
	font-size: 0.9rem;
	font-weight: 600;
	color: #071026;
}

.gomoveit-privacy-form__grid input,
.gomoveit-privacy-form__grid select,
.gomoveit-privacy-form__details textarea {
	border: 1px solid #d7ddea;
	border-radius: 12px;
	padding: 10px 12px;
	font: inherit;
	color: #071026;
	background: #fff;
}

.gomoveit-privacy-form__details textarea {
	resize: vertical;
	min-height: 120px;
}

.gomoveit-privacy-form__policy-note {
	margin: 12px 0 4px;
	font-size: 0.9rem;
	color: #4c5672;
}

.gomoveit-privacy-form__footnote {
	font-size: 0.85rem;
	margin: 12px 0 18px;
	color: #4c5672;
}

.gomoveit-privacy-form__actions {
	display: flex;
	justify-content: flex-end;
}

@media (max-width: 640px) {
	.gomoveit-cookie-toggle {
		flex-direction: column;
		align-items: flex-start;
	}
	.gomoveit-cookie-actions {
		flex-direction: column;
	}
	.gomoveit-privacy-modal__dialog {
		padding: 20px;
	}
	.gomoveit-cookie-banner__actions .gomoveit-btn {
		flex: 1 1 100%;
	}
}

/* ========================================
   LOGIN PAGE STYLING
   ======================================== */

body[data-path="login"] {
	background: linear-gradient(135deg, #f8f9fb 0%, #e8ebf0 100%);
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
}

body[data-path="login"] > div {
	width: 100%;
	max-width: 420px;
}

body[data-path="login"] section.for-login {
	display: block !important;
}

body[data-path="login"] section:not(.for-login) {
	display: none !important;
}

body[data-path="login"] .page-card-head {
	text-align: center;
	margin-bottom: 2rem;
}

body[data-path="login"] .page-card-head .app-logo {
	max-width: 180px;
	height: auto;
	margin-bottom: 1rem;
}

body[data-path="login"] .page-card-head h4 {
	font-family: var(--gomoveit-font-heading);
	font-weight: 700;
	font-size: 1.25rem;
	color: var(--gomoveit-dark);
	margin: 0;
}

body[data-path="login"] .page-card {
	background: #ffffff;
	border-radius: var(--gomoveit-radius-lg);
	box-shadow: 0 10px 40px rgba(0,0,0,0.1);
	border: none;
	padding: 2.5rem;
}

body[data-path="login"] .form-group label {
	font-family: var(--gomoveit-font-base);
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--gomoveit-charcoal);
	margin-bottom: 0.5rem;
}

body[data-path="login"] .form-control,
body[data-path="login"] input[type="text"],
body[data-path="login"] input[type="email"],
body[data-path="login"] input[type="password"] {
	border: 1px solid #d7ddea;
	border-radius: var(--gomoveit-radius-md);
	padding: 0.85rem 1rem;
	font-family: var(--gomoveit-font-base);
	font-size: 1rem;
	color: var(--gomoveit-charcoal);
	background: #fff;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body[data-path="login"] .form-control:focus,
body[data-path="login"] input[type="text"]:focus,
body[data-path="login"] input[type="email"]:focus,
body[data-path="login"] input[type="password"]:focus {
	border-color: var(--gomoveit-red);
	box-shadow: 0 0 0 3px rgba(211, 42, 38, 0.12);
	outline: none;
}

body[data-path="login"] .btn-primary,
body[data-path="login"] .btn-primary-dark {
	background: linear-gradient(135deg, var(--gomoveit-red) 0%, var(--gomoveit-red-dark) 100%);
	border: none;
	border-radius: var(--gomoveit-btn-radius);
	padding: var(--gomoveit-btn-pad-lg);
	font-family: var(--gomoveit-font-base);
	font-weight: 700;
	font-size: var(--gomoveit-btn-font-md);
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	box-shadow: var(--gomoveit-btn-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	width: 100%;
	margin-top: 0.5rem;
}

body[data-path="login"] .btn-primary:hover,
body[data-path="login"] .btn-primary-dark:hover {
	transform: translateY(-2px);
	box-shadow: 0 22px 40px rgba(211, 42, 38, 0.35);
}

body[data-path="login"] a,
body[data-path="login"] .forgot-password-link {
	color: var(--gomoveit-red);
	font-weight: 600;
	text-decoration: none;
	transition: color 0.2s ease;
}

body[data-path="login"] a:hover,
body[data-path="login"] .forgot-password-link:hover {
	color: var(--gomoveit-red-dark);
	text-decoration: underline;
}

body[data-path="login"] .or-label {
	color: #8a94a8;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

body[data-path="login"] .btn-default {
	border: 2px solid #d7ddea;
	border-radius: var(--gomoveit-btn-radius);
	background: #fff;
	color: var(--gomoveit-charcoal);
	font-weight: 600;
	transition: border-color 0.2s ease, background 0.2s ease;
}

body[data-path="login"] .btn-default:hover {
	border-color: var(--gomoveit-red);
	background: rgba(211, 42, 38, 0.04);
}

body[data-path="login"] hr {
	border: none;
	border-top: 1px solid #e8ebf0;
	margin: 1.5rem 0;
}

/* Hide "Powered by Frappe" on login */
body[data-path="login"] .login-footer,
body[data-path="login"] footer {
	display: none !important;
}


/* =====================================================
   Section Theme Variations
   Different accent colors for page categories
   ===================================================== */

/* Moving Options Section - Primary Red Accent */
.gomoveit-section--moving-options,
[data-page-section="moving-options"] {
	--section-accent: var(--gomoveit-red);
	--section-accent-dark: var(--gomoveit-red-dark);
	--section-bg: var(--gomoveit-section-moving-bg);
}

.gomoveit-section--moving-options .gomoveit-section__accent,
[data-page-section="moving-options"] .section-accent {
	color: var(--gomoveit-red);
}

.gomoveit-section--moving-options .gomoveit-badge,
[data-page-section="moving-options"] .gomoveit-badge {
	background-color: rgba(211, 42, 38, 0.12);
	color: var(--gomoveit-red);
}

/* Moving Advice Section - Teal/Dark Accent */
.gomoveit-section--moving-advice,
[data-page-section="moving-advice"] {
	--section-accent: var(--gomoveit-dark);
	--section-accent-dark: var(--gomoveit-dark-deep);
	--section-bg: var(--gomoveit-section-advice-bg);
}

.gomoveit-section--moving-advice .gomoveit-section__accent,
[data-page-section="moving-advice"] .section-accent {
	color: var(--gomoveit-dark);
}

.gomoveit-section--moving-advice .gomoveit-badge,
[data-page-section="moving-advice"] .gomoveit-badge {
	background-color: rgba(18, 70, 80, 0.12);
	color: var(--gomoveit-dark);
}

.gomoveit-section--moving-advice .gomoveit-btn.primary,
[data-page-section="moving-advice"] .gomoveit-btn.accent {
	background-color: var(--gomoveit-dark);
	border-color: var(--gomoveit-dark);
}

.gomoveit-section--moving-advice .gomoveit-btn.primary:hover,
[data-page-section="moving-advice"] .gomoveit-btn.accent:hover {
	background-color: var(--gomoveit-dark-deep);
	border-color: var(--gomoveit-dark-deep);
}

/* Contact Section - Charcoal/Neutral Accent */
.gomoveit-section--contact,
[data-page-section="contact"] {
	--section-accent: var(--gomoveit-charcoal);
	--section-accent-dark: var(--gomoveit-charcoal-dark);
	--section-bg: var(--gomoveit-section-contact-bg);
}

.gomoveit-section--contact .gomoveit-section__accent,
[data-page-section="contact"] .section-accent {
	color: var(--gomoveit-charcoal);
}

.gomoveit-section--contact .gomoveit-badge,
[data-page-section="contact"] .gomoveit-badge {
	background-color: rgba(58, 58, 58, 0.12);
	color: var(--gomoveit-charcoal);
}

/* =====================================================
   Press Release & Blog Styling
   ===================================================== */

.gomoveit-article,
.gomoveit-press-release,
.gomoveit-blog-post {
	max-width: 800px;
	margin: 0 auto;
	padding: 2rem clamp(1rem, 4vw, 2rem);
}

.gomoveit-article__header,
.gomoveit-press-release__header,
.gomoveit-blog-post__header {
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--gomoveit-offwhite);
}

.gomoveit-article__meta,
.gomoveit-press-release__meta,
.gomoveit-blog-post__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: center;
	font-size: 0.9rem;
	color: var(--gomoveit-gray);
	margin-bottom: 1rem;
}

.gomoveit-article__category,
.gomoveit-press-release__category,
.gomoveit-blog-post__category {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	background-color: rgba(211, 42, 38, 0.1);
	color: var(--gomoveit-red);
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.gomoveit-article__title,
.gomoveit-press-release__title,
.gomoveit-blog-post__title {
	font-size: clamp(1.8rem, 4vw, 2.8rem);
	font-weight: var(--gomoveit-font-weight-heading);
	color: var(--gomoveit-charcoal);
	line-height: var(--gomoveit-line-height-tight);
	margin: 0.5rem 0 1rem;
}

.gomoveit-article__content,
.gomoveit-press-release__content,
.gomoveit-blog-post__content {
	font-size: 1.05rem;
	line-height: var(--gomoveit-line-height-loose);
	color: var(--gomoveit-charcoal);
}

.gomoveit-article__content h2,
.gomoveit-press-release__content h2,
.gomoveit-blog-post__content h2 {
	font-size: 1.6rem;
	margin: 2rem 0 1rem;
	color: var(--gomoveit-dark);
}

.gomoveit-article__content h3,
.gomoveit-press-release__content h3,
.gomoveit-blog-post__content h3 {
	font-size: 1.3rem;
	margin: 1.5rem 0 0.75rem;
	color: var(--gomoveit-charcoal);
}

.gomoveit-article__content p,
.gomoveit-press-release__content p,
.gomoveit-blog-post__content p {
	margin-bottom: 1.25rem;
}

.gomoveit-article__content a,
.gomoveit-press-release__content a,
.gomoveit-blog-post__content a {
	color: var(--gomoveit-red);
	text-decoration: underline;
	text-decoration-color: rgba(211, 42, 38, 0.3);
	text-underline-offset: 2px;
	transition: text-decoration-color 0.2s ease;
}

.gomoveit-article__content a:hover,
.gomoveit-press-release__content a:hover,
.gomoveit-blog-post__content a:hover {
	text-decoration-color: var(--gomoveit-red);
}

.gomoveit-article__content blockquote,
.gomoveit-press-release__content blockquote,
.gomoveit-blog-post__content blockquote {
	margin: 1.5rem 0;
	padding: 1rem 1.5rem;
	border-left: 4px solid var(--gomoveit-red);
	background-color: var(--gomoveit-gray-light);
	font-style: italic;
	color: var(--gomoveit-charcoal-light);
}

.gomoveit-article__content ul,
.gomoveit-article__content ol,
.gomoveit-press-release__content ul,
.gomoveit-press-release__content ol,
.gomoveit-blog-post__content ul,
.gomoveit-blog-post__content ol {
	margin: 1rem 0 1.5rem 1.5rem;
}

.gomoveit-article__content li,
.gomoveit-press-release__content li,
.gomoveit-blog-post__content li {
	margin-bottom: 0.5rem;
}

/* =====================================================
   Hero Section Variations
   ===================================================== */

.gomoveit-hero--moving-options {
	background: linear-gradient(135deg, var(--gomoveit-dark) 0%, #1a3f47 100%);
}

.gomoveit-hero--moving-advice {
	background: linear-gradient(135deg, #124650 0%, #0d3339 100%);
}

.gomoveit-hero--contact {
	background: linear-gradient(135deg, var(--gomoveit-charcoal) 0%, #252525 100%);
}

/* =====================================================
   Utility Classes for Brand Colors
   ===================================================== */

.text-gmi-red { color: var(--gomoveit-red) !important; }
.text-gmi-dark { color: var(--gomoveit-dark) !important; }
.text-gmi-charcoal { color: var(--gomoveit-charcoal) !important; }
.text-gmi-gray { color: var(--gomoveit-gray) !important; }
.text-gmi-white { color: var(--gomoveit-white) !important; }

.bg-gmi-red { background-color: var(--gomoveit-red) !important; }
.bg-gmi-dark { background-color: var(--gomoveit-dark) !important; }
.bg-gmi-charcoal { background-color: var(--gomoveit-charcoal) !important; }
.bg-gmi-offwhite { background-color: var(--gomoveit-offwhite) !important; }
.bg-gmi-gray-light { background-color: var(--gomoveit-gray-light) !important; }
.bg-gmi-white { background-color: var(--gomoveit-white) !important; }

.border-gmi-red { border-color: var(--gomoveit-red) !important; }
.border-gmi-dark { border-color: var(--gomoveit-dark) !important; }
.border-gmi-charcoal { border-color: var(--gomoveit-charcoal) !important; }

/* =====================================================
   Legal Page Content Styling (class-based only)
   ===================================================== */

.gomoveit-legal-content {
	max-width: 900px;
	margin: 0 auto;
	padding: 48px 24px;
}

.gomoveit-legal-content h1,
.gomoveit-legal-content h2,
.gomoveit-legal-content h3 {
	color: var(--gomoveit-dark);
	font-family: var(--gomoveit-font-heading);
	font-weight: 700;
	margin-top: 1.5rem;
	margin-bottom: 0.75rem;
}

.gomoveit-legal-content h1 { font-size: 1.75rem; }
.gomoveit-legal-content h2 { font-size: 1.4rem; }
.gomoveit-legal-content h3 { font-size: 1.15rem; }

.gomoveit-legal-content p {
	color: var(--gomoveit-charcoal);
	line-height: 1.7;
	margin-bottom: 1rem;
}

.gomoveit-legal-content a {
	color: var(--gomoveit-red);
	text-decoration: underline;
}

.gomoveit-legal-content ul,
.gomoveit-legal-content ol {
	padding-left: 1.5rem;
	margin-bottom: 1rem;
}

.gomoveit-legal-content li {
	margin-bottom: 0.5rem;
	line-height: 1.6;
}

/* =====================================================
   Hero Form Mobile Responsiveness Fix
   ===================================================== */

@media (max-width: 768px) {
	/* Fix hero grid to stack on mobile */
	[data-block-id*="hero-grid"] {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}

	/* Center the form pane on mobile */
	[data-block-id*="hero-quote-form-pane"],
	[data-block-id*="form-pane"] {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
		margin: 0 auto !important;
	}

	/* Fix form inputs to not overflow */
	[data-block-id*="hero-quote-form-pane"] input,
	[data-block-id*="hero-quote-form-pane"] select,
	[data-block-id*="hero-quote-form-pane"] textarea,
	[data-block-id*="form-pane"] input,
	[data-block-id*="form-pane"] select,
	[data-block-id*="form-pane"] textarea {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Fix all divs inside form pane */
	[data-block-id*="hero-quote-form-pane"] > div,
	[data-block-id*="hero-quote-form-pane"] > div > div,
	[data-block-id*="form-pane"] > div,
	[data-block-id*="form-pane"] > div > div {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Stack two-column form rows on mobile */
	[data-block-id*="hero-quote-form-pane"] [style*="grid-template-columns: repeat(2"],
	[data-block-id*="form-pane"] [style*="grid-template-columns: repeat(2"] {
		grid-template-columns: 1fr !important;
	}

	/* Fix card grids to stack on mobile */
	[data-block-id*="moving-options-nav"],
	[data-block-id*="options-cards"],
	[data-block-id*="card-grid"] {
		display: flex !important;
		flex-direction: column !important;
		gap: 16px !important;
	}

	/* Any 3-column grid should stack */
	[style*="grid-template-columns: repeat(3"],
	[style*="gridTemplateColumns: repeat(3"] {
		grid-template-columns: 1fr !important;
	}

	/* Fix hero container padding on mobile */
	[data-block-id*="hero"] > div:first-child {
		padding: 0 16px !important;
	}

	/* Better centering for form card on mobile */
	[data-block-id*="hero-quote-form-pane"],
	[data-block-id*="form-pane"],
	[data-block-id*="quote-form"] {
		margin-left: auto !important;
		margin-right: auto !important;
		left: 0 !important;
		right: 0 !important;
	}

	/* Fix all gomoveit form inputs to not overflow */
	.gomoveit-field input,
	.gomoveit-field select,
	.gomoveit-field textarea,
	.gomoveit-form input,
	.gomoveit-form select,
	.gomoveit-form textarea,
	.gomoveit-form-panel input,
	.gomoveit-form-panel select,
	.gomoveit-form-panel textarea,
	.gomoveit-multistep-form input,
	.gomoveit-multistep-form select,
	.gomoveit-multistep-form textarea {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Fix form field grid on mobile - but keep Step 2 grid as 2 columns */
	.gomoveit-field-grid:not(.gomoveit-step2-grid),
	.gomoveit-field-grid.cols-2:not(.gomoveit-step2-grid) {
		grid-template-columns: 1fr !important;
		width: 100% !important;
	}

	/* Fix form containers on mobile */
	.gomoveit-form-panel,
	.gomoveit-step-card,
	.gomoveit-multistep-form {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Fix any nested containers */
	.gomoveit-form-panel > div,
	.gomoveit-step-card > div,
	.gomoveit-multistep-form > div {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Fix Moving Advice cards grid on mobile */
	[data-block-id*="moving-advice"] [style*="grid-template-columns: repeat(4"],
	[data-block-id*="moving-resources"] [style*="grid-template-columns: repeat(4"] {
		grid-template-columns: 1fr !important;
	}

	/* Ensure cards have proper width and don't cause vertical text */
	[data-block-id*="moving-advice-card"],
	[data-block-id*="resource-card"] {
		width: 100% !important;
		min-width: 0 !important;
		max-width: 100% !important;
	}

	/* Fix any 4-column grid on mobile */
	[style*="gridTemplateColumns: repeat(4"],
	[style*="grid-template-columns: repeat(4"] {
		grid-template-columns: 1fr !important;
	}

	/* Lists need proper indentation on mobile */
	ul:not(.gomoveit-nav__links):not(.gomoveit-footer__links),
	ol {
		padding-left: 28px;
		margin-left: 8px;
	}

	/* Ensure content images don't overflow - exclude header/logo */
	section img:not(.gomoveit-header__logo):not([class*="logo"]),
	main img:not(.gomoveit-header__logo):not([class*="logo"]),
	article img {
		max-width: 100%;
		height: auto;
	}

	/* Force form inputs to be full width on mobile */
	input[type="text"],
	input[type="email"],
	input[type="tel"],
	input[type="date"],
	input[type="number"],
	select,
	textarea {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
		min-width: 0 !important;
	}

	/* Fix form field containers */
	.gomoveit-field,
	.gomoveit-form__group {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
	}

	/* Force 2-column grids to single column */
	.cols-2,
	[class*="cols-2"],
	.gomoveit-field-grid {
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: 12px !important;
		width: 100% !important;
	}

	/* Fix form panels and cards */
	[data-block-id*="form-pane"],
	[data-block-id*="quote-form"],
	.gomoveit-form-panel,
	.gomoveit-step-card {
		width: 100% !important;
		max-width: 100% !important;
		padding-left: 16px !important;
		padding-right: 16px !important;
		box-sizing: border-box !important;
	}

	/* Fix service selection pill buttons on claim forms */
	.gomoveit-checkbox-group,
	.gomoveit-service-buttons,
	[class*="checkbox-group"],
	[class*="service-select"] {
		display: flex !important;
		flex-wrap: wrap !important;
		gap: 8px !important;
		width: 100% !important;
	}

	/* Pill buttons should be flexible width on mobile */
	.gomoveit-checkbox-group label,
	.gomoveit-service-buttons label,
	[class*="checkbox-group"] label,
	[class*="service-select"] label {
		flex: 1 1 calc(50% - 8px) !important;
		min-width: 120px !important;
		max-width: 100% !important;
		text-align: center !important;
		justify-content: center !important;
		padding: 10px 12px !important;
		font-size: 0.85rem !important;
		white-space: nowrap !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
	}

	/* Multi-step form wizard navigation */
	.gomoveit-multistep-nav,
	.gomoveit-step-indicators {
		flex-wrap: wrap !important;
		gap: 8px !important;
	}

	/* Step cards need full width */
	.gomoveit-step,
	.gomoveit-form-step {
		width: 100% !important;
		padding: 16px !important;
	}

	/* CRITICAL: 2x2 Grid must take full width */
	.gomoveit-2x2-grid-container {
		width: 100% !important;
		max-width: 100% !important;
		flex: 1 1 100% !important;
	}
	.gomoveit-services-units-row,
	.gomoveit-service-questions-row {
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: nowrap !important;
		width: 100% !important;
		max-width: 100% !important;
	}
	/* All grid fields take 50% width */
	.gomoveit-services-units-row > *,
	.gomoveit-service-questions-row > * {
		flex: 1 1 50% !important;
		max-width: 50% !important;
		min-width: 0 !important;
	}
}

/* =====================================================
   CLAIM FORM SPECIFIC RESPONSIVE STYLES
   ===================================================== */

/* Service checkbox buttons container */
.gomoveit-checkbox-group {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

/* Individual checkbox pill buttons */
.gomoveit-checkbox-group label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 20px;
	border-radius: 999px;
	border: 2px solid #d0d5dd;
	background: #ffffff;
	cursor: pointer;
	transition: all 0.2s ease;
	font-weight: 500;
	white-space: nowrap;
}

.gomoveit-checkbox-group label:hover {
	border-color: #D32A26;
	background: rgba(211, 42, 38, 0.05);
}

.gomoveit-checkbox-group input:checked + label,
.gomoveit-checkbox-group label.selected {
	border-color: #D32A26;
	background: rgba(211, 42, 38, 0.1);
	color: #D32A26;
}

/* Tablet breakpoint for service buttons */
@media (max-width: 1024px) {
	.gomoveit-checkbox-group label {
		padding: 10px 16px;
		font-size: 0.9rem;
	}
}

/* Mobile breakpoint for service buttons */
@media (max-width: 600px) {
	.gomoveit-checkbox-group {
		gap: 8px;
	}

	.gomoveit-checkbox-group label {
		flex: 1 1 calc(50% - 8px);
		min-width: 0;
		padding: 10px 8px;
		font-size: 0.8rem;
		text-align: center;
	}
}

/* Very small screens - stack buttons */
@media (max-width: 400px) {
	.gomoveit-checkbox-group label {
		flex: 1 1 100%;
	}
}

/* =====================================================
   CONTACT FORMS - COMPACT STYLING
   Applies to claim, service provider, and contact forms
   ===================================================== */

/* Compact form container - claim/provider now use .gomoveit-form--stacked */
.gomoveit-contact-form,
.web-form-container {
	max-width: 680px;
	margin: 0 auto;
}

/* Compact form card styling */
.gomoveit-contact-form .gomoveit-form-card,
.gomoveit-form-card--compact {
	background: #ffffff;
	border: 1px solid #e4e7ec;
	border-radius: 16px;
	padding: 1.5rem;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
}

/* Compact field labels */
.gomoveit-contact-form .gomoveit-field__label,
.web-form-container label,
.gomoveit-form-card--compact label {
	font-size: 0.72rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	color: #475467 !important;
	margin-bottom: 0.35rem !important;
}

/* Compact inputs */
.gomoveit-contact-form input,
.gomoveit-contact-form select,
.gomoveit-contact-form textarea,
.web-form-container input,
.web-form-container select,
.web-form-container textarea,
.gomoveit-form-card--compact input,
.gomoveit-form-card--compact select,
.gomoveit-form-card--compact textarea {
	padding: 0.55rem 0.75rem !important;
	font-size: 0.92rem !important;
	border-radius: 10px !important;
	border: 1px solid #d0d5dd !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.gomoveit-contact-form input:focus,
.gomoveit-contact-form select:focus,
.gomoveit-contact-form textarea:focus,
.web-form-container input:focus,
.web-form-container select:focus,
.web-form-container textarea:focus {
	border-color: #D32A26 !important;
	box-shadow: 0 0 0 3px rgba(211, 42, 38, 0.1) !important;
	outline: none !important;
}

/* Compact textarea */
.gomoveit-contact-form textarea,
.web-form-container textarea {
	min-height: 100px !important;
	resize: vertical !important;
}

/* Two-column grid for name/email/phone fields */
.gomoveit-contact-form .gomoveit-field-grid,
.gomoveit-form-card--compact .gomoveit-field-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
}

@media (max-width: 600px) {
	.gomoveit-contact-form .gomoveit-field-grid,
	.gomoveit-form-card--compact .gomoveit-field-grid {
		grid-template-columns: 1fr;
	}
}

/* Form introduction text */
.gomoveit-contact-form .gomoveit-form-intro,
.web-form-container .form-introduction {
	font-size: 0.95rem;
	color: #475467;
	line-height: 1.5;
	margin-bottom: 1.25rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid #e4e7ec;
}

/* Section headers within forms */
.gomoveit-contact-form .gomoveit-form-section-title,
.gomoveit-form-card--compact h3,
.gomoveit-form-card--compact h4 {
	font-size: 0.85rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #0f0f0f;
	margin: 1.25rem 0 0.75rem;
	padding-top: 1rem;
	border-top: 1px solid #f0f0f2;
}

.gomoveit-contact-form .gomoveit-form-section-title:first-child {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
}

/* Compact submit button */
.gomoveit-contact-form .gomoveit-btn--primary,
.web-form-container .btn-primary,
.gomoveit-form-card--compact .gomoveit-btn--primary {
	background: #D32A26 !important;
	color: #fff !important;
	border: none !important;
	padding: 0.75rem 1.5rem !important;
	font-size: 0.9rem !important;
	font-weight: 600 !important;
	border-radius: 999px !important;
	cursor: pointer !important;
	transition: background 0.2s ease, transform 0.1s ease !important;
}

.gomoveit-contact-form .gomoveit-btn--primary:hover,
.web-form-container .btn-primary:hover {
	background: #b8221f !important;
	transform: translateY(-1px) !important;
}

/* Required field indicator */
.gomoveit-contact-form .gomoveit-field__label--required::after,
.web-form-container .reqd::after {
	content: " *";
	color: #D32A26;
}

/* =====================================================
   UNIFIED FORM BUTTON STYLING
   Applies to: contact, claim, provider, billing forms
   Uses website's standard gomoveit-btn styling
   ===================================================== */

/* Primary buttons - Submit, Next */
[data-gomoveit-form] button[type="submit"],
[data-gomoveit-form] button.gomoveit-btn.primary,
[data-gomoveit-form] [data-provider-next],
[data-gomoveit-form] [data-claim-next],
[data-gomoveit-form] [data-reservation-next],
[data-provider-steps-form] button[type="submit"],
[data-provider-steps-form] button.gomoveit-btn.primary,
[data-claim-steps-form] button[type="submit"],
[data-claim-steps-form] button.gomoveit-btn.primary,
[data-reservation-steps-form] button[type="submit"],
[data-reservation-steps-form] button.gomoveit-btn.primary {
	background-color: var(--gomoveit-red, #D32A26) !important;
	color: #fff !important;
	border: 1.5px solid var(--gomoveit-red, #D32A26) !important;
	border-radius: var(--gomoveit-btn-radius, 8px) !important;
	padding: var(--gomoveit-btn-pad-sm, 0.35rem 0.7rem) !important;
	font-size: var(--gomoveit-btn-font-sm, 0.7rem) !important;
	font-weight: 700 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	cursor: pointer !important;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease !important;
	min-height: 38px !important;
}

[data-gomoveit-form] button[type="submit"]:hover,
[data-gomoveit-form] button.gomoveit-btn.primary:hover,
[data-gomoveit-form] [data-provider-next]:hover,
[data-gomoveit-form] [data-claim-next]:hover,
[data-provider-steps-form] button[type="submit"]:hover,
[data-provider-steps-form] button.gomoveit-btn.primary:hover,
[data-claim-steps-form] button[type="submit"]:hover,
[data-claim-steps-form] button.gomoveit-btn.primary:hover {
	background-color: var(--gomoveit-red-dark, #a82220) !important;
	border-color: var(--gomoveit-red-dark, #a82220) !important;
	transform: translateY(-1px) !important;
	box-shadow: var(--gomoveit-btn-shadow, 0 18px 35px rgba(211, 42, 38, 0.20)) !important;
}

/* Secondary buttons - Back */
[data-gomoveit-form] button.gomoveit-btn.secondary,
[data-gomoveit-form] [data-provider-prev],
[data-gomoveit-form] [data-claim-prev],
[data-gomoveit-form] [data-reservation-prev],
[data-provider-steps-form] button.gomoveit-btn.secondary,
[data-claim-steps-form] button.gomoveit-btn.secondary,
[data-reservation-steps-form] button.gomoveit-btn.secondary {
	background-color: transparent !important;
	color: var(--gomoveit-charcoal, #3A3A3A) !important;
	border: 1.5px solid #d0d5dd !important;
	border-radius: var(--gomoveit-btn-radius, 8px) !important;
	padding: var(--gomoveit-btn-pad-sm, 0.35rem 0.7rem) !important;
	font-size: var(--gomoveit-btn-font-sm, 0.7rem) !important;
	font-weight: 700 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	cursor: pointer !important;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease !important;
	min-height: 38px !important;
}

[data-gomoveit-form] button.gomoveit-btn.secondary:hover,
[data-gomoveit-form] [data-provider-prev]:hover,
[data-gomoveit-form] [data-claim-prev]:hover,
[data-gomoveit-form] [data-reservation-prev]:hover,
[data-provider-steps-form] button.gomoveit-btn.secondary:hover,
[data-claim-steps-form] button.gomoveit-btn.secondary:hover,
[data-reservation-steps-form] button.gomoveit-btn.secondary:hover {
	background-color: #f5f5f5 !important;
	transform: translateY(-1px) !important;
}

/* Form title with red accent line */
[data-gomoveit-form] h1,
[data-gomoveit-form] h2,
[data-provider-steps-form] h1,
[data-provider-steps-form] h2,
[data-claim-steps-form] h1,
[data-claim-steps-form] h2,
.gomoveit-form__title {
	font-size: 1.5rem !important;
	font-weight: 700 !important;
	color: #0f0f0f !important;
	margin: 0 0 1rem !important;
	padding-bottom: 0.75rem !important;
	border-bottom: 2px solid var(--gomoveit-red, #D32A26) !important;
}

/* Step/section titles within forms */
[data-gomoveit-form] h3,
[data-provider-steps-form] h3,
[data-claim-steps-form] h3,
.gomoveit-form__step-title {
	font-size: 0.85rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.1em !important;
	color: #0f0f0f !important;
	margin: 0 0 1rem !important;
	padding-bottom: 0.5rem !important;
	border-bottom: 2px solid var(--gomoveit-red, #D32A26) !important;
}

/* =====================================================
   COMPREHENSIVE MOBILE RESPONSIVENESS - SITE-WIDE
   Added: 2025-12-28
   ===================================================== */

/* -----------------------------------------------------
   GLOBAL MOBILE RESETS (max-width: 768px)
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* Prevent horizontal scroll */
	html, body {
		overflow-x: hidden !important;
		width: 100% !important;
	}

	/* All containers should be full width */
	body > *,
	main,
	section,
	article,
	.container,
	[class*="container"],
	[class*="wrapper"] {
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Force all grids to single column */
	[style*="grid-template-columns: repeat(2"],
	[style*="grid-template-columns: repeat(3"],
	[style*="grid-template-columns: repeat(4"],
	[style*="gridTemplateColumns: repeat(2"],
	[style*="gridTemplateColumns: repeat(3"],
	[style*="gridTemplateColumns: repeat(4"] {
		grid-template-columns: 1fr !important;
	}

	/* Force flex rows to wrap and stack */
	[style*="flex-direction: row"],
	[style*="flexDirection: row"] {
		flex-wrap: wrap !important;
	}

	/* Reduce horizontal padding on all sections */
	section,
	[data-block-label*="Section"],
	[data-block-label*="Container"] {
		padding-left: 16px !important;
		padding-right: 16px !important;
	}

	/* Fix images to not overflow */
	img {
		max-width: 100% !important;
		height: auto !important;
	}

	/* Fix iframes and embeds */
	iframe,
	video,
	embed,
	object {
		max-width: 100% !important;
	}

	/* Tables should scroll horizontally */
	table {
		display: block;
		overflow-x: auto;
		max-width: 100%;
	}
}

/* -----------------------------------------------------
   BUILDER PAGE BLOCK FIXES (max-width: 768px)
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* All fb- prefixed blocks from Builder */
	[class^="fb-"] {
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Hero sections - single column layout */
	[data-block-label*="Hero"] > div,
	[data-block-label*="Hero · Grid"],
	[data-block-label*="hero-grid"],
	[data-outline-label*="Hero · Grid"] {
		display: flex !important;
		flex-direction: column !important;
		gap: 24px !important;
	}

	/* Hero copy should be full width */
	[data-block-label*="Hero · Copy"],
	[data-outline-label*="Hero · Copy"] {
		width: 100% !important;
		text-align: center !important;
	}

	/* Hero form panel - full width with proper padding */
	[data-block-label*="Hero · Quote Form Panel"],
	[data-block-label*="Quote Form Panel"],
	[data-outline-label*="Hero · Quote Form Panel"] {
		width: 100% !important;
		max-width: 100% !important;
		margin: 0 !important;
		padding: 20px 16px !important;
		box-sizing: border-box !important;
	}

	/* Content sections - stack columns */
	[data-block-label*="Content"],
	[data-block-label*="Features"],
	[data-block-label*="Cards"],
	[data-block-label*="Grid"] {
		flex-direction: column !important;
	}

	/* Card grids should stack */
	[data-block-label*="Card"],
	[data-block-label*="card"] {
		width: 100% !important;
		max-width: 100% !important;
	}

	/* Two-column layouts should stack */
	[data-block-label*="Two Column"],
	[data-block-label*="two-column"],
	[data-block-label*="Split"] {
		flex-direction: column !important;
		gap: 24px !important;
	}

	/* Sidebar layouts - stack sidebar below content */
	[data-block-label*="Sidebar"],
	[data-block-label*="sidebar"] {
		width: 100% !important;
		order: 2 !important;
	}
}

/* -----------------------------------------------------
   NAVIGATION & HEADER MOBILE FIXES
   Note: The main mobile nav styles are defined earlier in the file
   around line 806. These rules only add overflow protection and
   ensure proper body lock when nav is open.
   ----------------------------------------------------- */
@media (max-width: 800px) {
	/* CRITICAL: Ensure header is visible on mobile using STICKY positioning */
	.gomoveit-header {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		position: sticky !important;
		position: -webkit-sticky !important;
		top: 0 !important;
		left: 0 !important;
		right: 0 !important;
		width: 100% !important;
		z-index: 99999 !important;
		background: #ffffff !important;
		min-height: 56px !important;
		height: auto !important;
		box-shadow: 0 2px 10px rgba(0,0,0,0.15) !important;
		transform: none !important;
	}

	/* Ensure header inner is properly laid out */
	.gomoveit-header__inner {
		display: flex !important;
		visibility: visible !important;
		min-height: 56px !important;
		padding: 10px 16px !important;
		align-items: center !important;
		justify-content: space-between !important;
		flex-wrap: nowrap !important;
		gap: 12px !important;
	}

	/* Prevent horizontal scroll on mobile */
	html {
		overflow-x: hidden !important;
	}

	/* Body should NOT have padding-top since header is sticky, not fixed */
	body {
		overflow-x: hidden !important;
		position: relative !important;
		width: 100% !important;
	}

	/* Lock body scroll when nav is open */
	body.gomoveit-nav-open {
		overflow: hidden !important;
		position: fixed !important;
		width: 100% !important;
		height: 100% !important;
	}

	/* CRITICAL: Ensure hamburger toggle is visible and properly styled */
	.gomoveit-nav__toggle {
		display: inline-flex !important;
		visibility: visible !important;
		opacity: 1 !important;
		pointer-events: auto !important;
		position: relative !important;
		z-index: 100 !important;
		width: 44px !important;
		height: 44px !important;
		min-width: 44px !important;
		align-items: center !important;
		justify-content: center !important;
		background: transparent !important;
		border: none !important;
		cursor: pointer !important;
		order: 2 !important;
		flex-shrink: 0 !important;
	}

	/* Ensure hamburger icon container is visible */
	.gomoveit-nav__toggle-icon {
		display: inline-flex !important;
		flex-direction: column !important;
		gap: 5px !important;
		align-items: center !important;
		justify-content: center !important;
	}

	/* Ensure hamburger bars are visible with good contrast */
	.gomoveit-nav__toggle-icon > span,
	.gomoveit-nav__toggle-bar {
		display: block !important;
		width: 22px !important;
		height: 3px !important;
		background-color: #071026 !important;
		border-radius: 2px !important;
	}

	/* Hide desktop nav links on mobile - they move to slide panel */
	.gomoveit-nav__links {
		display: none !important;
	}

	/* Hide desktop CTA row on mobile - CTA is in mobile panel */
	.gomoveit-nav__cta {
		display: none !important;
	}

	/* When nav is open, show the mobile panel */
	.gomoveit-header.is-nav-open .gomoveit-nav {
		transform: translateX(0) !important;
	}

	.gomoveit-header.is-nav-open .gomoveit-nav__links,
	.gomoveit-header.is-nav-open .gomoveit-nav__cta {
		display: flex !important;
	}

	/* Mobile accordion navigation - submenus are HIDDEN by default, expand on toggle tap */

	/* Nav items with submenus - layout for accordion */
	.gomoveit-nav__item.has-submenu {
		flex-direction: column !important;
		align-items: stretch !important;
		position: relative !important;
	}

	/* Wrapper for main link + toggle button */
	.gomoveit-nav__item.has-submenu > a {
		display: block !important;
		flex: 1 !important;
		padding-right: 50px !important; /* Make room for toggle button */
	}

	/* Remove the desktop dropdown arrow indicator */
	.gomoveit-nav__item.has-submenu::after {
		display: none !important;
	}

	/* SHOW the submenu toggle button on mobile - positioned on the right */
	.gomoveit-submenu-toggle {
		display: flex !important;
		position: absolute !important;
		right: 0 !important;
		top: 50% !important;
		transform: translateY(-50%) !important;
		width: 44px !important;
		height: 44px !important;
		align-items: center !important;
		justify-content: center !important;
		background: transparent !important;
		border: none !important;
		cursor: pointer !important;
		z-index: 10 !important;
		padding: 0 !important;
		-webkit-tap-highlight-color: transparent !important;
	}

	/* Chevron arrow styling - points DOWN when collapsed */
	.gomoveit-submenu-toggle__chevron {
		display: inline-block !important;
		width: 10px !important;
		height: 10px !important;
		border-right: 2px solid #1a365d !important;
		border-bottom: 2px solid #1a365d !important;
		transform: rotate(45deg) !important;
		transition: transform 0.2s ease !important;
	}

	/* Chevron points UP when expanded */
	.gomoveit-nav__item.has-submenu.is-expanded > .gomoveit-submenu-toggle .gomoveit-submenu-toggle__chevron {
		transform: rotate(-135deg) !important;
	}

	/* Submenus HIDDEN by default on mobile (accordion collapsed state) */
	.gomoveit-nav__item.has-submenu > .gomoveit-submenu {
		position: static !important;
		background: #f5f7fa !important;
		box-shadow: none !important;
		padding: 0 !important;
		display: none !important; /* HIDDEN by default */
		opacity: 1 !important;
		visibility: hidden !important;
		pointer-events: none !important;
		transform: none !important;
		margin-top: 0 !important;
		border-radius: 8px !important;
		border: none !important;
		min-width: unset !important;
		width: 100% !important;
		z-index: 100 !important;
		max-height: 0 !important;
		overflow: hidden !important;
		transition: max-height 0.3s ease, padding 0.3s ease, margin 0.3s ease !important;
	}

	/* SHOW submenu when parent has .is-expanded class (accordion open state) */
	.gomoveit-nav__item.has-submenu.is-expanded > ul.gomoveit-submenu {
		display: block !important;
		padding: 8px 0 8px 16px !important;
		margin-top: 8px !important;
		max-height: 500px !important;
		opacity: 1 !important;
		pointer-events: auto !important;
		visibility: visible !important;
	}

	/* Submenu link styling - make sure links are clickable */
	.gomoveit-submenu a {
		padding: 12px 16px !important;
		font-size: 15px !important;
		color: #4a5568 !important;
		display: block !important;
		text-decoration: none !important;
		pointer-events: auto !important;
		cursor: pointer !important;
		z-index: 101 !important;
		position: relative !important;
	}

	.gomoveit-submenu li {
		margin: 0 !important;
		list-style: none !important;
		pointer-events: auto !important;
	}

	.gomoveit-submenu a:hover,
	.gomoveit-submenu a:focus,
	.gomoveit-submenu a:active {
		background: #edf2f7 !important;
		color: #1a365d !important;
	}
}

/* -----------------------------------------------------
   FORM ELEMENTS - COMPREHENSIVE MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* All form inputs full width */
	input[type="text"],
	input[type="email"],
	input[type="tel"],
	input[type="number"],
	input[type="date"],
	input[type="time"],
	input[type="url"],
	input[type="password"],
	input[type="search"],
	select,
	textarea {
		width: 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
		box-sizing: border-box !important;
		font-size: 16px !important; /* Prevents iOS zoom on focus */
	}

	/* Form field containers */
	.gomoveit-field,
	.gomoveit-form__group,
	[class*="field"],
	[class*="form-group"] {
		width: 100% !important;
		max-width: 100% !important;
	}

	/* Form grids - single column (except Step 2 grid which stays 2-col) */
	.gomoveit-field-grid:not(.gomoveit-step2-grid),
	.gomoveit-field-grid.cols-2:not(.gomoveit-step2-grid),
	.gomoveit-field-grid.cols-3,
	[class*="field-grid"]:not(.gomoveit-step2-grid),
	[class*="form-row"] {
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: 16px !important;
		width: 100% !important;
	}

	/* Form panels */
	.gomoveit-form-panel,
	.gomoveit-step-card,
	.gomoveit-quote-form,
	[class*="form-panel"],
	[class*="form-card"] {
		width: 100% !important;
		max-width: 100% !important;
		padding: 16px !important;
		box-sizing: border-box !important;
	}

	/* Multi-select checkbox groups */
	.gomoveit-multi,
	[class*="checkbox-group"] {
		display: flex !important;
		flex-wrap: wrap !important;
		gap: 8px !important;
	}

	/* Dropdown multi-select containers (not menus) */
	.gomoveit-multi-select {
		display: block !important;
	}

	/* CRITICAL: Keep dropdown menus hidden when not open on mobile */
	.gomoveit-multi-select__menu {
		display: none !important;
	}
	.gomoveit-multi-select.is-open .gomoveit-multi-select__menu {
		display: block !important;
	}

	/* Dropdown multi-select options - ensure checkbox alignment on mobile */
	.gomoveit-multi-select__option {
		display: flex !important;
		align-items: center !important;
		gap: 10px !important;
		padding: 10px 14px !important;
		position: relative !important;
		font-size: 0.9rem !important;
	}

	/* Hide native checkbox input on mobile */
	.gomoveit-multi-select__option input[type="checkbox"],
	.gomoveit-multi-select__option input[type="radio"] {
		position: absolute !important;
		opacity: 0 !important;
		width: 0 !important;
		height: 0 !important;
		pointer-events: none !important;
	}

	/* Option text on mobile */
	.gomoveit-multi-select__label {
		color: #333 !important;
		flex: 1 !important;
	}

	.gomoveit-multi__option,
	.gomoveit-multi label {
		flex: 1 1 calc(50% - 8px) !important;
		min-width: 120px !important;
	}

	/* Form buttons - stack on mobile */
	.gomoveit-step-actions,
	[class*="form-actions"],
	[class*="button-group"] {
		flex-direction: column !important;
		gap: 12px !important;
		width: 100% !important;
	}

	.gomoveit-step-actions .gomoveit-btn,
	[class*="form-actions"] button,
	[class*="form-actions"] .btn {
		width: 100% !important;
		justify-content: center !important;
	}

	/* Back buttons can stay smaller */
	.gomoveit-step-actions--back .gomoveit-btn {
		width: auto !important;
	}
}

/* -----------------------------------------------------
   TYPOGRAPHY & TEXT CONTENT MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* Reduce heading sizes on mobile */
	h1, .h1 {
		font-size: 2rem !important;
		line-height: 1.2 !important;
	}

	h2, .h2 {
		font-size: 1.5rem !important;
		line-height: 1.25 !important;
	}

	h3, .h3 {
		font-size: 1.25rem !important;
	}

	h4, .h4 {
		font-size: 1.1rem !important;
	}

	/* Paragraphs readable on mobile */
	p, li {
		font-size: 1rem !important;
		line-height: 1.6 !important;
	}

	/* Prevent text overflow */
	h1, h2, h3, h4, h5, h6, p, span, a, li {
		word-wrap: break-word !important;
		overflow-wrap: break-word !important;
	}

	/* Lists proper indentation */
	ul:not(.gomoveit-nav__links):not(.gomoveit-footer__links):not(.gomoveit-submenu),
	ol {
		padding-left: 24px !important;
		margin-left: 0 !important;
	}
}

/* -----------------------------------------------------
   BUTTONS & CTA MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* All buttons need touch-friendly sizing */
	.gomoveit-btn,
	button,
	[class*="btn"],
	input[type="submit"],
	input[type="button"] {
		min-height: 44px !important; /* Apple's recommended touch target */
		padding: 12px 20px !important;
		font-size: 1rem !important;
		line-height: 1.2 !important;
		text-align: center !important;
	}

	/* CTA button groups stack */
	[class*="cta-group"],
	[class*="button-row"] {
		flex-direction: column !important;
		gap: 12px !important;
		width: 100% !important;
	}

	/* Full width CTAs on mobile */
	[class*="cta-group"] .gomoveit-btn,
	[class*="button-row"] .gomoveit-btn {
		width: 100% !important;
	}
}

/* -----------------------------------------------------
   FOOTER MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	.gomoveit-footer {
		padding: 40px 16px !important;
	}

	.gomoveit-footer__inner {
		flex-direction: column !important;
		gap: 32px !important;
	}

	.gomoveit-footer__col {
		width: 100% !important;
		text-align: center !important;
	}

	.gomoveit-footer__links {
		justify-content: center !important;
	}

	.gomoveit-footer__bottom {
		flex-direction: column !important;
		gap: 16px !important;
		text-align: center !important;
	}
}

/* -----------------------------------------------------
   MOVING ADVICE / CONTENT PAGES MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* Article content */
	article,
	.gomoveit-article,
	[class*="article"],
	[class*="blog-post"],
	[class*="content-page"] {
		padding: 16px !important;
	}

	/* Room-by-room planning and similar content grids */
	[data-block-label*="Room"],
	[data-block-label*="Planning"],
	[data-block-label*="Checklist"],
	[data-block-label*="Tips"] {
		padding: 16px !important;
	}

	/* Content cards in advice sections */
	[data-block-label*="Advice"] [class^="fb-"],
	[data-block-label*="Resource"] [class^="fb-"],
	[data-block-label*="Tips"] [class^="fb-"] {
		width: 100% !important;
		max-width: 100% !important;
	}

	/* Moving checklist items */
	.gomoveit-checklist,
	[class*="checklist"] {
		padding-left: 0 !important;
	}

	.gomoveit-checklist li,
	[class*="checklist"] li {
		padding: 12px !important;
		margin-bottom: 8px !important;
	}
}

/* -----------------------------------------------------
   VENDOR/FACILITY SELECTION MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	.gomoveit-vendor-panel,
	.gomoveit-vendor-list,
	[data-vendor-panel],
	[data-vendor-list] {
		width: 100% !important;
	}

	.gomoveit-vendor-card,
	[class*="vendor-card"],
	[class*="facility-card"] {
		width: 100% !important;
		padding: 16px !important;
	}

	/* Vendor info layout */
	.gomoveit-vendor-card__info {
		flex-direction: column !important;
		gap: 8px !important;
	}
}

/* -----------------------------------------------------
   QUOTE SUMMARY & REVIEW MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	.gomoveit-quote-summary,
	.gomoveit-review,
	[class*="quote-summary"],
	[class*="review-panel"] {
		width: 100% !important;
		padding: 16px !important;
	}

	.gomoveit-review__row,
	.gomoveit-quote-summary__row {
		flex-direction: column !important;
		gap: 4px !important;
		padding: 12px 0 !important;
		border-bottom: 1px solid #e4e7ec !important;
	}

	.gomoveit-review__row span:first-child,
	.gomoveit-quote-summary__row span:first-child {
		font-weight: 600 !important;
		color: #667085 !important;
	}

	.gomoveit-quote-summary__grid {
		grid-template-columns: 1fr !important;
	}
}

/* -----------------------------------------------------
   UNIT SIZE SELECTION MOBILE FIXES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	.gomoveit-unit-repeaters,
	.gomoveit-unit-controls {
		flex-direction: column !important;
		gap: 12px !important;
		width: 100% !important;
	}

	.gomoveit-unit-size {
		width: 100% !important;
	}

	.gomoveit-unit-controls .gomoveit-btn {
		flex: 1 !important;
	}
}

/* -----------------------------------------------------
   SMALL MOBILE DEVICES (max-width: 480px)
   ----------------------------------------------------- */
@media (max-width: 480px) {
	/* Even smaller padding */
	section,
	[data-block-label*="Section"],
	[data-block-label*="Container"] {
		padding-left: 12px !important;
		padding-right: 12px !important;
	}

	/* Smaller headings */
	h1, .h1 {
		font-size: 1.75rem !important;
	}

	h2, .h2 {
		font-size: 1.35rem !important;
	}

	/* Multi-select options full width */
	.gomoveit-multi__option,
	.gomoveit-multi label {
		flex: 1 1 100% !important;
	}

	/* Buttons full width */
	.gomoveit-btn,
	button:not(.gomoveit-nav__toggle):not(.gomoveit-nav__close) {
		width: 100% !important;
	}

	/* Form panels tighter padding */
	.gomoveit-form-panel,
	.gomoveit-step-card {
		padding: 12px !important;
	}
}

/* -----------------------------------------------------
   PREVENT COMMON OVERFLOW ISSUES
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* Prevent any fixed-width elements from causing overflow */
	[style*="width: "][style*="px"],
	[style*="min-width: "][style*="px"] {
		width: 100% !important;
		min-width: 0 !important;
		max-width: 100% !important;
	}

	/* Exception for small fixed-width elements like icons */
	[style*="width: "][style*="px"]:not(img):not(svg):not(button):not(input) {
		width: auto !important;
		max-width: 100% !important;
	}

	/* Pre and code blocks should scroll */
	pre, code {
		max-width: 100% !important;
		overflow-x: auto !important;
		white-space: pre-wrap !important;
		word-wrap: break-word !important;
	}
}

/* -----------------------------------------------------
   ACCESSIBILITY - ENSURE TOUCH TARGETS
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* All interactive elements need sufficient size */
	a,
	button,
	input,
	select,
	textarea,
	[role="button"],
	[role="link"] {
		min-height: 44px;
		min-width: 44px;
	}

	/* Links in text can be smaller */
	p a,
	li a,
	span a {
		min-height: auto;
		min-width: auto;
	}
}

/* =====================================================
   BUILDER PAGE INLINE STYLE OVERRIDES
   These fix pages where Builder generates mobile CSS without media queries
   Added: 2025-12-28
   ===================================================== */

/* -----------------------------------------------------
   DESKTOP: Restore two-column grids (min-width: 769px)
   Builder sometimes applies mobile styles without media queries
   ----------------------------------------------------- */
@media (min-width: 769px) {
	/* Hero Grid Layout - restore 2 columns on desktop */
	[data-block-label*="Hero · Grid"],
	[data-outline-label*="Hero · Grid"],
	[data-block-label*="Hero · Grid Layout"],
	[data-outline-label*="Hero · Grid Layout"] {
		display: grid !important;
		grid-template-columns: 1fr 1fr !important;
		gap: 32px !important;
		align-items: center !important;
	}

	/* Hero Copy Column - left align on desktop */
	[data-block-label*="Hero · Copy"],
	[data-outline-label*="Hero · Copy"],
	[data-block-label*="Hero · Copy Column"],
	[data-outline-label*="Hero · Copy Column"] {
		text-align: left !important;
		align-items: flex-start !important;
	}

	/* Two-column content grids */
	[data-block-label*="Two Column"],
	[data-block-label*="two-column"],
	[data-block-label*="Grid Layout"],
	[data-block-label*="Content Grid"] {
		display: grid !important;
		grid-template-columns: 1fr 1fr !important;
		gap: 32px !important;
	}

	/* Three-column grids */
	[data-block-label*="Three Column"],
	[data-block-label*="three-column"] {
		display: grid !important;
		grid-template-columns: repeat(3, 1fr) !important;
		gap: 24px !important;
	}

	/* Four-column grids */
	[data-block-label*="Four Column"],
	[data-block-label*="four-column"],
	[data-block-label*="Card Grid"] {
		display: grid !important;
		grid-template-columns: repeat(4, 1fr) !important;
		gap: 24px !important;
	}

	/* Sidebar layouts - 2/3 + 1/3 split */
	[data-block-label*="Sidebar Layout"],
	[data-block-label*="Content with Sidebar"] {
		display: grid !important;
		grid-template-columns: 2fr 1fr !important;
		gap: 32px !important;
	}

	/* Form panel should have reasonable max-width on desktop */
	[data-block-label*="Quote Form Panel"],
	[data-outline-label*="Quote Form Panel"],
	[data-block-label*="Hero · Quote Form Panel"],
	[data-outline-label*="Hero · Quote Form Panel"] {
		max-width: 500px !important;
		width: 100% !important;
	}

	/* CTA Row - horizontal on desktop */
	[data-block-label*="CTA Row"],
	[data-outline-label*="CTA Row"],
	[data-block-label*="Hero · CTA Row"],
	[data-outline-label*="Hero · CTA Row"] {
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: wrap !important;
		gap: 12px !important;
	}
}

/* -----------------------------------------------------
   TABLET: Adjust for medium screens (769px - 1024px)
   ----------------------------------------------------- */
@media (min-width: 769px) and (max-width: 1024px) {
	/* Hero Grid - still 2 columns but with less gap */
	[data-block-label*="Hero · Grid"],
	[data-outline-label*="Hero · Grid"],
	[data-block-label*="Hero · Grid Layout"],
	[data-outline-label*="Hero · Grid Layout"] {
		gap: 24px !important;
	}

	/* Four-column grids become 2-column on tablet */
	[data-block-label*="Four Column"],
	[data-block-label*="four-column"],
	[data-block-label*="Card Grid"] {
		grid-template-columns: repeat(2, 1fr) !important;
	}

	/* Form panel slightly larger on tablet */
	[data-block-label*="Quote Form Panel"],
	[data-outline-label*="Quote Form Panel"] {
		max-width: 420px !important;
	}
}

/* -----------------------------------------------------
   MOBILE: Stack everything (max-width: 768px)
   ----------------------------------------------------- */
@media (max-width: 768px) {
	/* Force single column on all grid layouts */
	[data-block-label*="Hero · Grid"],
	[data-outline-label*="Hero · Grid"],
	[data-block-label*="Hero · Grid Layout"],
	[data-outline-label*="Hero · Grid Layout"],
	[data-block-label*="Two Column"],
	[data-block-label*="Three Column"],
	[data-block-label*="Four Column"],
	[data-block-label*="Grid Layout"],
	[data-block-label*="Content Grid"],
	[data-block-label*="Card Grid"],
	[data-block-label*="Sidebar Layout"] {
		display: flex !important;
		flex-direction: column !important;
		gap: 24px !important;
	}

	/* Center text on mobile */
	[data-block-label*="Hero · Copy"],
	[data-outline-label*="Hero · Copy"],
	[data-block-label*="Hero · Copy Column"],
	[data-outline-label*="Hero · Copy Column"] {
		text-align: center !important;
		align-items: center !important;
		width: 100% !important;
	}

	/* Form panel full width on mobile */
	[data-block-label*="Quote Form Panel"],
	[data-outline-label*="Quote Form Panel"],
	[data-block-label*="Hero · Quote Form Panel"],
	[data-outline-label*="Hero · Quote Form Panel"] {
		max-width: 100% !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 20px 16px !important;
	}

	/* CTA Row - keep inline on mobile with wrapping */
	[data-block-label*="CTA Row"],
	[data-outline-label*="CTA Row"],
	[data-block-label*="Hero · CTA Row"],
	[data-outline-label*="Hero · CTA Row"] {
		flex-direction: row !important;
		flex-wrap: wrap !important;
		gap: 8px !important;
		justify-content: center !important;
	}

	[data-block-label*="CTA Row"] .gomoveit-btn,
	[data-outline-label*="CTA Row"] .gomoveit-btn,
	[data-block-label*="Hero · CTA Row"] .gomoveit-btn,
	[data-outline-label*="Hero · CTA Row"] .gomoveit-btn,
	[data-block-label*="CTA Row"] a[data-gomoveit-btn],
	[data-outline-label*="CTA Row"] a[data-gomoveit-btn],
	[data-block-label*="CTA Row"] a.gomoveit-btn,
	[data-outline-label*="CTA Row"] a.gomoveit-btn {
		width: auto !important;
		flex: 0 0 auto !important;
		padding: 8px 10px !important;
		font-size: 0.7rem !important;
		min-height: 28px !important;
		line-height: 1.2 !important;
		text-align: center !important;
	}
}

/* -----------------------------------------------------
   VERY SMALL MOBILE (max-width: 480px)
   ----------------------------------------------------- */
@media (max-width: 480px) {
	/* Even tighter spacing */
	[data-block-label*="Hero · Grid"],
	[data-outline-label*="Hero · Grid"],
	[data-block-label*="Hero · Grid Layout"],
	[data-outline-label*="Hero · Grid Layout"] {
		gap: 16px !important;
		padding-left: 12px !important;
		padding-right: 12px !important;
	}

	/* Smaller padding on form panels */
	[data-block-label*="Quote Form Panel"],
	[data-outline-label*="Quote Form Panel"] {
		padding: 16px 12px !important;
	}
}

/* =====================================================
   COMPREHENSIVE RESPONSIVE DESIGN SYSTEM
   Mobile-first approach with progressive enhancement
   Updated: 2025-12-28

   Breakpoints:
   - Mobile: max-width: 480px (matches Builder)
   - Tablet: max-width: 768px
   - Small Desktop: max-width: 1024px
   - Large Desktop: min-width: 1025px
   ===================================================== */

/* ======================
   GLOBAL RESPONSIVE FOUNDATION
   Applied at all screen sizes
   ====================== */

/* Ensure box-sizing is consistent */
*, *::before, *::after {
	box-sizing: border-box;
}

/* Main content container - centers content with max-width */
.gomoveit-container,
[data-block-label*="Container"],
[data-outline-label*="Container"],
main > section > div:first-child {
	width: 100%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}

/* All images responsive by default */
img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* Responsive video/iframe containers */
.gomoveit-video-container,
[data-block-label*="Video"],
.video-wrapper {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%; /* 16:9 aspect ratio */
	height: 0;
	overflow: hidden;
}

.gomoveit-video-container iframe,
.gomoveit-video-container video,
[data-block-label*="Video"] iframe,
[data-block-label*="Video"] video,
.video-wrapper iframe,
.video-wrapper video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* ======================
   MOBILE STYLES (max-width: 480px)
   Core mobile experience
   ====================== */
@media only screen and (max-width: 480px) {
	/* ---- GLOBAL OVERFLOW PREVENTION ---- */
	html {
		overflow-x: hidden !important;
		scroll-behavior: smooth;
	}

	body {
		overflow-x: hidden !important;
		width: 100% !important;
		min-height: 100vh;
	}

	/* All Builder blocks must respect viewport */
	[class^="fb-"] {
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* ---- TYPOGRAPHY ---- */
	h1, .h1 {
		font-size: 1.75rem !important;
		line-height: 1.2 !important;
		margin-bottom: 16px !important;
	}

	h2, .h2 {
		font-size: 1.4rem !important;
		line-height: 1.25 !important;
		margin-bottom: 14px !important;
	}

	h3, .h3 {
		font-size: 1.2rem !important;
		line-height: 1.3 !important;
		margin-bottom: 12px !important;
	}

	h4, .h4, h5, .h5, h6, .h6 {
		font-size: 1rem !important;
		line-height: 1.35 !important;
		margin-bottom: 10px !important;
	}

	p, li {
		font-size: 1rem !important;
		line-height: 1.6 !important;
	}

	/* Prevent bad word breaks */
	h1, h2, h3, h4, h5, h6, p, span, li, a {
		hyphens: none !important;
		-webkit-hyphens: none !important;
		word-break: normal !important;
		overflow-wrap: break-word !important;
	}

	/* ---- LAYOUT CONTAINERS ---- */
	section,
	[data-block-label*="Section"],
	[data-block-label*="Container"] {
		padding-left: 16px !important;
		padding-right: 16px !important;
	}

	.gomoveit-container,
	[data-block-label*="Container"] > div {
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	/* ---- HERO SECTIONS ---- */
	[data-block-label*="Hero"],
	[data-outline-label*="Hero"] {
		padding: 24px 16px !important;
	}

	[data-block-label*="Hero · Grid"],
	[data-outline-label*="Hero · Grid"],
	[data-block-label*="Hero · Grid Layout"] {
		display: flex !important;
		flex-direction: column !important;
		gap: 24px !important;
		align-items: center !important;
	}

	[data-block-label*="Hero · Copy"],
	[data-outline-label*="Hero · Copy"] {
		width: 100% !important;
		text-align: center !important;
		order: 1 !important;
	}

	[data-block-label*="Hero · Quote Form Panel"],
	[data-outline-label*="Hero · Quote Form Panel"],
	[data-block-label*="Quote Form Panel"] {
		width: 100% !important;
		max-width: 100% !important;
		order: 2 !important;
		margin: 0 !important;
	}

	/* ---- FORMS - FULL MOBILE OPTIMIZATION ---- */
	/* All inputs full width with touch-friendly sizing */
	input[type="text"],
	input[type="email"],
	input[type="tel"],
	input[type="number"],
	input[type="date"],
	input[type="time"],
	input[type="url"],
	input[type="password"],
	input[type="search"],
	select,
	textarea {
		width: 100% !important;
		max-width: 100% !important;
		min-height: 48px !important;
		padding: 12px 16px !important;
		font-size: 16px !important; /* Prevents iOS zoom */
		border-radius: 8px !important;
		box-sizing: border-box !important;
	}

	/* Form layouts - single column (except Step 2 grid) */
	.gomoveit-field-grid:not(.gomoveit-step2-grid),
	.gomoveit-field-grid.cols-2:not(.gomoveit-step2-grid),
	.gomoveit-field-grid.cols-3,
	[class*="field-grid"]:not(.gomoveit-step2-grid),
	[class*="form-row"] {
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: 16px !important;
	}

	/* Form field containers */
	.gomoveit-field,
	[class*="field"],
	.gomoveit-field.is-full {
		width: 100% !important;
	}

	/* Form panels */
	.gomoveit-form-panel,
	.gomoveit-step-card,
	.gomoveit-quote-form {
		padding: 16px !important;
		margin: 0 !important;
		width: 100% !important;
	}

	/* Multi-select checkboxes - wrap properly */
	.gomoveit-multi {
		display: flex !important;
		flex-wrap: wrap !important;
		gap: 8px !important;
	}

	.gomoveit-multi__option,
	.gomoveit-multi label {
		flex: 1 1 100% !important;
		min-width: 0 !important;
		padding: 12px !important;
		background: #f9fafb !important;
		border-radius: 8px !important;
		display: flex !important;
		align-items: center !important;
		gap: 8px !important;
	}

	/* ---- FORM BUTTONS - STACK VERTICALLY (forms only) ---- */
	.gomoveit-step-actions,
	[class*="button-group"],
	[class*="cta-group"] {
		display: flex !important;
		flex-direction: column !important;
		gap: 12px !important;
		width: 100% !important;
	}

	/* Form action buttons only - full width */
	.gomoveit-step-actions button,
	.gomoveit-step-actions .gomoveit-btn {
		width: 100% !important;
		min-height: 48px !important;
		justify-content: center !important;
		text-align: center !important;
	}

	/* Back buttons can be smaller */
	.gomoveit-step-actions--back {
		margin-top: 8px !important;
	}

	.gomoveit-step-actions--back .gomoveit-btn {
		width: auto !important;
		padding: 8px 16px !important;
		min-height: 40px !important;
	}

	/* ---- VENDOR/FACILITY CARDS ---- */
	.gomoveit-vendor-panel,
	.gomoveit-vendor-list,
	[data-vendor-panel],
	[data-vendor-list] {
		width: 100% !important;
	}

	.gomoveit-vendor-card,
	[class*="vendor-card"] {
		flex-direction: column !important;
		gap: 12px !important;
		padding: 16px !important;
	}

	/* ---- QUOTE SUMMARY ---- */
	.gomoveit-quote-summary,
	.gomoveit-review {
		padding: 16px !important;
	}

	.gomoveit-quote-summary__row,
	.gomoveit-review__row {
		flex-direction: column !important;
		gap: 4px !important;
		padding: 12px 0 !important;
	}

	.gomoveit-quote-summary__grid {
		grid-template-columns: 1fr !important;
	}

	/* ---- UNIT SIZE CONTROLS ---- */
	.gomoveit-unit-controls {
		flex-direction: row !important;
		flex-wrap: wrap !important;
		gap: 8px !important;
	}

	.gomoveit-unit-controls .gomoveit-btn {
		flex: 1 1 calc(50% - 4px) !important;
		min-width: 100px !important;
	}

	.gomoveit-unit-count {
		flex: 1 1 100% !important;
		text-align: center !important;
		margin-top: 8px !important;
	}

	.gomoveit-unit-repeaters {
		display: flex !important;
		flex-direction: column !important;
		gap: 12px !important;
	}

	.gomoveit-unit-size {
		width: 100% !important;
	}

	/* ---- CONTENT SECTIONS ---- */
	[data-block-label*="Content"],
	[data-block-label*="Features"],
	[data-block-label*="Grid"],
	[data-block-label*="Two Column"],
	[data-block-label*="Three Column"],
	[data-block-label*="Four Column"] {
		display: flex !important;
		flex-direction: column !important;
		gap: 20px !important;
	}

	/* Cards stack full width */
	[data-block-label*="Card"],
	[data-block-label*="card"] {
		width: 100% !important;
		max-width: 100% !important;
	}

	/* ---- FOOTER ---- */
	.gomoveit-footer {
		padding: 32px 16px !important;
	}

	.gomoveit-footer__inner {
		flex-direction: column !important;
		gap: 24px !important;
		text-align: center !important;
	}

	.gomoveit-footer__col {
		width: 100% !important;
	}

	.gomoveit-footer__links {
		justify-content: center !important;
		flex-wrap: wrap !important;
	}

	/* ---- IMAGES & MEDIA ---- */
	img {
		max-width: 100% !important;
		height: auto !important;
	}

	iframe,
	video,
	embed {
		max-width: 100% !important;
	}

	/* ---- TABLES ---- */
	table {
		display: block !important;
		width: 100% !important;
		overflow-x: auto !important;
	}

	/* ---- LISTS ---- */
	ul:not(.gomoveit-nav__links):not(.gomoveit-submenu):not(.gomoveit-footer__links),
	ol {
		padding-left: 20px !important;
		margin-left: 0 !important;
	}

	/* Checklist items */
	ul[class*="checklist"] li,
	.gomoveit-checklist li {
		padding: 12px 16px !important;
		margin-bottom: 8px !important;
	}
}

/* ======================
   TABLET STYLES (577px - 768px)
   ====================== */
@media only screen and (min-width: 577px) and (max-width: 768px) {
	/* Container padding */
	.gomoveit-container,
	[data-block-label*="Container"] {
		padding-left: 24px !important;
		padding-right: 24px !important;
	}

	/* Typography adjustments */
	h1, .h1 {
		font-size: 2rem !important;
	}

	h2, .h2 {
		font-size: 1.5rem !important;
	}

	/* Hero grid - still stacked but more spacing */
	[data-block-label*="Hero · Grid"] {
		gap: 32px !important;
	}

	/* Form grids - 2 columns for short fields */
	.gomoveit-field-grid.cols-2 {
		grid-template-columns: repeat(2, 1fr) !important;
	}

	/* Multi-select - 2 per row */
	.gomoveit-multi__option,
	.gomoveit-multi label {
		flex: 1 1 calc(50% - 8px) !important;
	}

	/* Buttons can be side by side */
	.gomoveit-step-actions:not(.gomoveit-step-actions--back) {
		flex-direction: row !important;
		flex-wrap: wrap !important;
	}

	.gomoveit-step-actions .gomoveit-btn {
		flex: 1 1 calc(50% - 6px) !important;
		min-width: 140px !important;
	}

	/* Card grids - 2 columns */
	[data-block-label*="Card Grid"],
	[data-block-label*="Four Column"] {
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 20px !important;
	}

	/* Footer - 2 columns */
	.gomoveit-footer__inner {
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 24px !important;
	}
}

/* ======================
   SMALL DESKTOP (769px - 1024px)
   ====================== */
@media only screen and (min-width: 769px) and (max-width: 1024px) {
	/* Container */
	.gomoveit-container,
	[data-block-label*="Container"] {
		padding-left: 32px !important;
		padding-right: 32px !important;
	}

	/* Hero grid - 2 columns with less gap */
	[data-block-label*="Hero · Grid"] {
		display: grid !important;
		grid-template-columns: 1fr 1fr !important;
		gap: 24px !important;
		align-items: center !important;
	}

	/* Form grid - up to 3 columns */
	.gomoveit-field-grid.cols-3 {
		grid-template-columns: repeat(3, 1fr) !important;
	}

	/* Quote form panel constrained */
	[data-block-label*="Quote Form Panel"] {
		max-width: 420px !important;
	}

	/* Card grids - 3 columns */
	[data-block-label*="Three Column"],
	[data-block-label*="Card Grid"] {
		display: grid !important;
		grid-template-columns: repeat(3, 1fr) !important;
		gap: 24px !important;
	}

	/* Four column becomes 2x2 */
	[data-block-label*="Four Column"] {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

/* ======================
   LARGE DESKTOP (1025px+)
   ====================== */
@media only screen and (min-width: 1025px) {
	/* Hero grid - 2 columns, generous spacing */
	[data-block-label*="Hero · Grid"] {
		display: grid !important;
		grid-template-columns: 1fr 1fr !important;
		gap: 48px !important;
		align-items: center !important;
	}

	[data-block-label*="Hero · Copy"] {
		text-align: left !important;
	}

	/* Quote form panel */
	[data-block-label*="Quote Form Panel"] {
		max-width: 500px !important;
	}

	/* Four column grids */
	[data-block-label*="Four Column"],
	[data-block-label*="Card Grid"] {
		display: grid !important;
		grid-template-columns: repeat(4, 1fr) !important;
		gap: 24px !important;
	}

	/* Sidebar layouts */
	[data-block-label*="Sidebar Layout"] {
		display: grid !important;
		grid-template-columns: 2fr 1fr !important;
		gap: 40px !important;
	}
}

/* ======================
   ACCESSIBILITY & TOUCH TARGETS
   ====================== */
@media (pointer: coarse) {
	/* Touch devices need larger targets */
	a, button, input, select, textarea,
	[role="button"], [role="link"] {
		min-height: 44px;
	}

	/* But inline text links are fine smaller */
	p a, li a, span a {
		min-height: auto;
	}
}

/* ======================
   HIGH CONTRAST / REDUCED MOTION
   ====================== */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* =====================================================
   HEADER RESPONSIVE BEHAVIOR - MANAGED BY builder_page.py
   This is now handled by MOBILE_CRITICAL_CSS which is injected
   after Builder's inline styles to properly override them.
   ===================================================== */

/* =====================================================
   404 PAGE STYLES
   ===================================================== */
.gomoveit-404 {
	min-height: 80vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 60px 20px;
	background: linear-gradient(135deg, #124650 0%, #0d3339 100%);
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}
.gomoveit-404__inner {
	max-width: 600px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 24px;
}
.gomoveit-404__logo img {
	height: 50px;
	width: auto;
}
.gomoveit-404__code {
	font-size: clamp(80px, 15vw, 140px);
	font-weight: 800;
	color: rgba(255,255,255,0.1);
	line-height: 1;
	margin: -10px 0;
	letter-spacing: -0.02em;
}
.gomoveit-404 h1 {
	margin: 0;
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	color: #FFFFFF;
}
.gomoveit-404__message {
	margin: 0;
	font-size: 1.1rem;
	color: rgba(255,255,255,0.85);
	line-height: 1.7;
}
.gomoveit-404__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
	margin-top: 8px;
}
.gomoveit-404 .gomoveit-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 28px;
	border-radius: 8px;
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	transition: all 0.2s ease;
	border: none;
	cursor: pointer;
}
.gomoveit-404 .gomoveit-btn--primary {
	background: #D32A26;
	color: #FFFFFF;
	box-shadow: 0 8px 24px rgba(211, 42, 38, 0.35);
}
.gomoveit-404 .gomoveit-btn--primary:hover {
	background: #a82220;
	transform: translateY(-2px);
}
.gomoveit-404 .gomoveit-btn--secondary {
	background: rgba(255,255,255,0.1);
	color: #FFFFFF;
	border: 1px solid rgba(255,255,255,0.3);
}
.gomoveit-404 .gomoveit-btn--secondary:hover {
	background: rgba(255,255,255,0.2);
}
.gomoveit-404__help {
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,0.15);
}
.gomoveit-404__help p {
	margin: 0;
	font-size: 0.95rem;
	color: rgba(255,255,255,0.7);
}
.gomoveit-404__help a {
	color: #FFFFFF;
	font-weight: 600;
	text-decoration: none;
}
.gomoveit-404__help a:hover {
	text-decoration: underline;
}
@media (max-width: 480px) {
	.gomoveit-404__actions {
		flex-direction: column;
		width: 100%;
	}
	.gomoveit-404 .gomoveit-btn {
		width: 100%;
	}
}

/* ==========================================================================
   PARTNER LOCATIONS PAGE - Logo and Layout Fixes
   ========================================================================== */

/* Partner locations page - data-path attribute identifies the page */
body[data-path="partner-locations"] img,
body[data-path*="partner-location"] img {
	max-width: 100%;
	height: auto;
}

/* Location card logos - constrain all logos in cards */
.location-card img {
	max-height: 24px !important;
	width: auto !important;
	flex-shrink: 0;
}

/* Hero section logos on partner locations */
body[data-path="partner-locations"] section:first-of-type img {
	max-height: 28px !important;
	width: auto !important;
}

/* Mobile constraints for partner-locations page */
@media (max-width: 768px) {
	/* All logos on partner-locations page */
	body[data-path="partner-locations"] img:not([src*="facility"]):not([src*="aerial"]) {
		max-height: 20px !important;
		width: auto !important;
	}
	
	/* Location card logos - smaller on mobile */
	.location-card img {
		max-height: 18px !important;
	}
	
	/* Hero text scaling */
	body[data-path="partner-locations"] section:first-of-type h1 {
		font-size: 2rem !important;
	}
	
	body[data-path="partner-locations"] section:first-of-type p {
		font-size: 1rem !important;
	}
	
	/* Ensure cards don't overflow */
	.location-card {
		padding: 16px !important;
	}
	
	/* Fix spacing between sections */
	body[data-path="partner-locations"] section {
		margin-top: 0 !important;
		margin-bottom: 0 !important;
	}
}

/* Extra small mobile */
@media (max-width: 480px) {
	body[data-path="partner-locations"] img:not([src*="facility"]):not([src*="aerial"]) {
		max-height: 16px !important;
	}
	
	body[data-path="partner-locations"] section:first-of-type h1 {
		font-size: 1.75rem !important;
	}
}

/* GoMoveIt brand logo constraint - global */
img[src*="gomoveit-logo"],
img[src*="brand/gomoveit"] {
	max-height: 28px !important;
	width: auto !important;
}

@media (max-width: 768px) {
	img[src*="gomoveit-logo"],
	img[src*="brand/gomoveit"] {
		max-height: 22px !important;
	}
}

/* ==========================================================================
   INDIVIDUAL PARTNER LOCATION PAGES - Logo and Layout Fixes
   ========================================================================== */

/* Target individual location pages (data-path="partner-location") */
body[data-path="partner-location"] img {
	max-width: 100%;
	height: auto;
}

/* Hero section on individual location pages - constrain badge logos */
body[data-path="partner-location"] section:first-of-type img {
	max-height: 28px !important;
	width: auto !important;
}

/* Hero text visibility - add text-shadow for contrast */
body[data-path="partner-location"] section:first-of-type h1 {
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5), 0 4px 16px rgba(0, 0, 0, 0.3) !important;
	color: #FFFFFF !important;
}

body[data-path="partner-location"] section:first-of-type > div > div:last-child,
body[data-path="partner-location"] section:first-of-type p,
body[data-path="partner-location"] section:first-of-type div[class*="__text_block__"] {
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4), 0 2px 8px rgba(0, 0, 0, 0.25) !important;
}

/* "Why Choose" section GSI logo - constrain to reasonable size */
body[data-path="partner-location"] img[src*="gsi-logo"],
body[data-path="partner-location"] img[src*="partners/gsi"] {
	max-height: 50px !important;
	width: auto !important;
}

/* GSI Logo specifically in sections after hero (Why Choose, etc.) */
body[data-path="partner-location"] section:not(:first-of-type) img[src*="gsi"] {
	max-height: 50px !important;
	width: auto !important;
}

/* Mobile constraints for individual location pages */
@media (max-width: 768px) {
	/* All logos on individual location pages */
	body[data-path="partner-location"] img:not([src*="facility"]):not([src*="aerial"]):not([src*="moving"]):not([src*="storage"]) {
		max-height: 24px !important;
		width: auto !important;
	}

	/* Hero section logos smaller on mobile */
	body[data-path="partner-location"] section:first-of-type img {
		max-height: 22px !important;
	}

	/* GSI logo in Why Choose section - smaller on mobile */
	body[data-path="partner-location"] img[src*="gsi-logo"],
	body[data-path="partner-location"] img[src*="partners/gsi"] {
		max-height: 40px !important;
	}

	/* Hero text scaling on individual location pages */
	body[data-path="partner-location"] section:first-of-type h1 {
		font-size: 2rem !important;
	}

	body[data-path="partner-location"] section:first-of-type p {
		font-size: 1rem !important;
	}
}

/* Extra small mobile */
@media (max-width: 480px) {
	body[data-path="partner-location"] img:not([src*="facility"]):not([src*="aerial"]):not([src*="moving"]):not([src*="storage"]) {
		max-height: 20px !important;
	}

	body[data-path="partner-location"] section:first-of-type h1 {
		font-size: 1.75rem !important;
	}

	/* GSI logo even smaller on extra small screens */
	body[data-path="partner-location"] img[src*="gsi-logo"],
	body[data-path="partner-location"] img[src*="partners/gsi"] {
		max-height: 32px !important;
	}
}

/* ==========================================================================
   LOCATION CARDS - Partner Locations Page
   ========================================================================== */

.location-card {
	background-color: #FFFFFF;
	border-radius: 12px;
	padding: 24px;
	box-shadow: 0 2px 12px rgba(18,70,80,0.08);
	border: 1px solid #D3D3D3;
	display: flex;
	flex-direction: column;
}

.location-card__header {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid #D3D3D3;
}

.location-card__logo {
	height: 20px;
	width: auto;
	flex-shrink: 0;
}

.location-card__logo--gsi {
	height: 16px;
}

.location-card__plus {
	color: #727272;
	font-size: 0.8rem;
}

.location-card__badge {
	color: #727272;
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-left: auto;
}

.location-card__title {
	color: #124650;
	font-size: 1.1rem;
	font-weight: 700;
	margin: 0 0 8px;
	line-height: 1.3;
}

.location-card__address {
	color: #727272;
	font-size: 0.9rem;
	margin: 0 0 8px;
	line-height: 1.4;
}

.location-card__distance {
	color: #D32A26;
	font-size: 0.85rem;
	font-weight: 600;
	display: none;
	margin-bottom: 12px;
}

.location-card__phone {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: auto;
	padding-top: 12px;
}

.location-card__phone span {
	color: #727272;
	font-size: 0.8rem;
}

.location-card__phone a {
	color: #124650;
	font-size: 0.9rem;
	font-weight: 700;
	text-decoration: none;
}

.location-card__actions {
	display: flex;
	gap: 8px;
	margin-top: 16px;
}

.location-card__btn {
	flex: 1;
	text-align: center;
	padding: 12px 16px;
	font-size: 0.85rem;
	font-weight: 600;
	border-radius: 6px;
	text-decoration: none;
	transition: opacity 0.2s ease;
}

.location-card__btn:hover {
	opacity: 0.9;
}

.location-card__btn--quote {
	background-color: #D32A26;
	color: #FFFFFF;
}

.location-card__btn--details {
	background-color: #124650;
	color: #FFFFFF;
}

/* Mobile adjustments */
@media (max-width: 768px) {
	.location-card {
		padding: 16px;
	}

	.location-card__logo {
		height: 18px;
	}

	.location-card__logo--gsi {
		height: 14px;
	}

	.location-card__badge {
		font-size: 0.6rem;
	}
}

/* =====================================================
   MOBILE TEXT OVERFLOW & CHECKLIST CARD FIXES
   Fixes for moving-advice page and similar checklist layouts
   ===================================================== */

/* Prevent horizontal scrolling on mobile */
@media (max-width: 480px) {
	html, body {
		overflow-x: hidden;
		max-width: 100vw;
	}
}

/* =====================================================
   CHECKLIST CARD STYLING - Mobile Responsive
   Fix checkbox sizing and text wrapping on moving-advice
   ===================================================== */

/* Checklist items: label with checkbox + text */
label[class^="fb-"][data-block-label*="Checklist Item"] {
	display: flex !important;
	align-items: flex-start !important;
	gap: 12px !important;
	padding: 8px 0 !important;
}

/* Checkbox input - fixed size, don't grow */
label[class^="fb-"][data-block-label*="Checklist Item"] input[type="checkbox"] {
	width: 20px !important;
	height: 20px !important;
	min-width: 20px !important;
	min-height: 20px !important;
	max-width: 20px !important;
	max-height: 20px !important;
	flex-shrink: 0 !important;
	margin: 2px 0 0 0 !important;
	cursor: pointer !important;
	accent-color: #D32A26 !important;
}

/* Text next to checkbox - flex and wrap properly */
label[class^="fb-"][data-block-label*="Checklist Item"] span.__text_block__ {
	flex: 1 !important;
	min-width: 0 !important;
	word-wrap: break-word !important;
	overflow-wrap: break-word !important;
	line-height: 1.5 !important;
}

/* Mobile adjustments for checklist cards */
@media (max-width: 480px) {
	/* Checklist card container - proper padding */
	li[class^="fb-"][data-checklist-section] {
		padding: 16px !important;
	}

	/* Slightly smaller checkbox on mobile */
	label[class^="fb-"][data-block-label*="Checklist Item"] input[type="checkbox"] {
		width: 18px !important;
		height: 18px !important;
		min-width: 18px !important;
		min-height: 18px !important;
		max-width: 18px !important;
		max-height: 18px !important;
	}

	/* Ensure text wraps properly */
	label[class^="fb-"][data-block-label*="Checklist Item"] span.__text_block__ {
		font-size: 0.95rem !important;
	}
}

/* =====================================================
   TABLET BUTTON FIX - Prevent buttons from being cut off
   Issue: overflow:hidden on parent containers clips buttons
   Solution: Allow overflow on button containers at tablet
   Added: 2026-01-04
   ===================================================== */

/* Tablet breakpoint (577px - 1024px) - Fix button clipping */
@media (min-width: 577px) and (max-width: 1024px) {
	/* Prevent button parent containers from clipping */
	[class*="cta"]:not(.gomoveit-nav__cta),
	[class*="actions"],
	[data-block-label*="CTA"],
	[data-block-label*="Button"],
	[data-outline-label*="CTA"],
	[data-outline-label*="Button"] {
		overflow: visible !important;
	}

	/* Button rows and containers - allow overflow */
	.gomoveit-step-actions,
	.gomoveit-triage__cta-row,
	.gomoveit-footer-cta-buttons,
	[class*="cta-row"],
	[class*="button-row"],
	[class*="btn-row"] {
		overflow: visible !important;
	}

	/* Buttons themselves - ensure they don't clip text */
	.gomoveit-btn:not(.gomoveit-nav__cta .gomoveit-btn),
	a.gomoveit-btn:not(.gomoveit-nav__cta .gomoveit-btn),
	button.gomoveit-btn:not(.gomoveit-nav__cta .gomoveit-btn) {
		overflow: visible !important;
		text-overflow: clip !important;
		white-space: normal !important;
		max-width: 100% !important;
	}

	/* Builder-generated elements that often have overflow:hidden */
	[class^="fb-"]:has(> .gomoveit-btn),
	[class^="fb-"]:has(> a.gomoveit-btn) {
		overflow: visible !important;
	}

	/* Hero sections - must not clip buttons */
	section:first-of-type,
	[data-block-label*="Hero"],
	[data-outline-label*="Hero"] {
		overflow: visible !important;
	}

	/* Content sections with buttons - prevent clipping */
	section [class^="fb-"],
	main [class^="fb-"] {
		overflow: visible !important;
	}

	/* Tablet button sizing - slightly smaller but readable */
	.gomoveit-btn:not(.gomoveit-nav__cta .gomoveit-btn):not(.gomoveit-cookie-banner__actions .gomoveit-btn) {
		font-size: 0.85rem !important;
		padding: 10px 18px !important;
		min-height: 42px !important;
	}

	/* Cards with overflow:hidden - allow buttons to be visible */
	[class^="fb-"][style*="overflow: hidden"],
	[class^="fb-"][style*="overflow:hidden"] {
		overflow: visible !important;
	}
}

/* Mobile (max-width: 576px) - Smaller inline buttons */
@media (max-width: 576px) {
	/* ALL gomoveit-btn buttons - inline, smaller - exclude form/nav buttons */
	.gomoveit-btn:not(.gomoveit-nav__cta .gomoveit-btn):not(.gomoveit-cookie-banner__actions .gomoveit-btn):not(.location-card__btn):not([type="submit"]):not(.form-submit-btn):not([data-form-submit]):not(.gomoveit-step-actions .gomoveit-btn):not(.gomoveit-unit-controls .gomoveit-btn) {
		width: auto !important;
		display: inline-block !important;
		font-size: 0.85rem !important;
		padding: 10px 16px !important;
		min-height: 38px !important;
	}

	/* Buttons with data-gomoveit-btn attribute (Builder-generated) */
	a[data-gomoveit-btn="true"]:not(.gomoveit-nav__cta a) {
		width: auto !important;
		display: inline-block !important;
		font-size: 0.85rem !important;
		padding: 10px 16px !important;
		min-height: 38px !important;
	}

	/* Button containers - left aligned flex layout */
	.gomoveit-hero__cta,
	.gomoveit-cta-row,
	[class*="button-row"],
	[class*="btn-row"],
	[class*="cta-container"],
	[class*="action-buttons"],
	.gomoveit-how-it-works__cta,
	.gomoveit-section__cta,
	[data-block-label*="CTA"],
	[data-block-label*="cta"],
	div[class^="fb-"]:has(> a[data-gomoveit-btn]),
	div[class^="fb-"]:has(> a.gomoveit-btn) {
		display: flex !important;
		flex-wrap: wrap !important;
		gap: 10px !important;
		justify-content: flex-start !important;
	}

	/* Section buttons - About, How It Works, etc */
	section[data-block-label] .gomoveit-btn:not([type="submit"]):not(.gomoveit-step-actions .gomoveit-btn),
	section[class^="fb-"] .gomoveit-btn:not([type="submit"]):not(.gomoveit-step-actions .gomoveit-btn):not(.gomoveit-unit-controls .gomoveit-btn) {
		width: auto !important;
		display: inline-block !important;
		font-size: 0.85rem !important;
		padding: 10px 16px !important;
		min-height: 38px !important;
	}
}

/* =====================================================
   FOOTER GRID FIX - Always 3 columns or collapse to 1
   Issue: auto-fit creates 2 columns on tablet
   Solution: Force 3 columns on tablet, 1 on mobile
   Added: 2026-01-04
   ===================================================== */

/* Desktop and Tablet (769px+) - Force 3 columns */
@media (min-width: 769px) {
	.gomoveit-footer-grid {
		grid-template-columns: repeat(3, 1fr) !important;
	}
}

/* Small tablet (577px - 768px) - Still 3 columns but tighter */
@media (min-width: 577px) and (max-width: 768px) {
	.gomoveit-footer-grid {
		grid-template-columns: repeat(3, 1fr) !important;
		gap: 16px !important;
	}

	/* Footer cards need smaller padding on tablet */
	.gomoveit-footer-card {
		padding: 16px !important;
	}

	/* Smaller text for footer on tablet */
	.gomoveit-footer-card p,
	.gomoveit-footer-contact-list li {
		font-size: 0.85rem !important;
	}

	.gomoveit-footer-card h3,
	.gomoveit-footer-card h4 {
		font-size: 1rem !important;
	}

	/* Footer logo smaller on tablet */
	.gomoveit-footer-card--about .gomoveit-footer-logo img {
		height: 40px !important;
	}
}

/* Mobile (max-width: 576px) - Single column footer */
@media (max-width: 576px) {
	.gomoveit-footer-grid {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}

	.gomoveit-footer-card {
		padding: 20px !important;
	}
}

/* =====================================================
   MOBILE HERO FORM OPTIMIZATION
   Issue: Hero sections with quote forms have excessive
   padding, margins, and spacing that requires too much
   scrolling on mobile devices
   Solution: Compact all spacing while maintaining readability
   Added: 2026-01-04
   ===================================================== */

@media (max-width: 576px) {
	/* ---- HERO SECTION - REDUCE VERTICAL PADDING ---- */
	/* Target sections before the form (title/intro areas) */
	section[class^="fb-"]:has(+ section .gomoveit-quote-form),
	section[class^="fb-"]:has(+ section .gomoveit-multistep-form) {
		padding-top: 32px !important;
		padding-bottom: 20px !important;
	}

	/* Hero title containers - tighten up */
	section[class^="fb-"]:has(+ section .gomoveit-quote-form) > div,
	section[class^="fb-"]:has(+ section .gomoveit-multistep-form) > div {
		padding-left: 16px !important;
		padding-right: 16px !important;
	}

	/* Hero title - smaller on mobile */
	section[class^="fb-"]:has(+ section .gomoveit-quote-form) h1,
	section[class^="fb-"]:has(+ section .gomoveit-multistep-form) h1 {
		font-size: 1.5rem !important;
		margin-bottom: 8px !important;
	}

	/* Hero subtitle - smaller margin */
	section[class^="fb-"]:has(+ section .gomoveit-quote-form) h1 + div,
	section[class^="fb-"]:has(+ section .gomoveit-multistep-form) h1 + div {
		font-size: 0.95rem !important;
		margin-bottom: 0 !important;
	}

	/* ---- FORM SECTION CONTAINER ---- */
	/* The section containing the form - reduce padding */
	section:has(.gomoveit-quote-form),
	section:has(.gomoveit-multistep-form) {
		padding-top: 24px !important;
		padding-bottom: 32px !important;
	}

	/* Form wrapper container - reduce horizontal padding */
	section:has(.gomoveit-quote-form) > div,
	section:has(.gomoveit-multistep-form) > div {
		padding-left: 12px !important;
		padding-right: 12px !important;
		gap: 16px !important;
	}

	/* ---- QUOTE FORM CARD ---- */
	.gomoveit-quote-form {
		padding: 12px !important;
		gap: 10px !important;
		border-radius: 12px !important;
	}

	/* ---- STEP BANNER (Get an Online Estimate) ---- */
	.gomoveit-step-banner {
		font-size: 0.9rem !important;
		margin: 0 0 2px 0 !important;
		padding: 0 !important;
	}

	/* ---- FORM PANEL (each step container) ---- */
	.gomoveit-form-panel {
		padding: 8px !important;
		gap: 6px !important;
	}

	/* Panel title (Step 1 · Move Details) */
	.gomoveit-form-panel__title {
		font-size: 0.85rem !important;
		margin: 0 0 2px 0 !important;
		padding: 0 !important;
	}

	/* Panel intro text */
	.gomoveit-form-panel__intro {
		font-size: 0.75rem !important;
		margin: 0 0 4px 0 !important;
		padding: 0 !important;
		line-height: 1.3 !important;
	}

	/* ---- STEP CARD (Contact Information, etc) ---- */
	.gomoveit-step-card {
		gap: 6px !important;
		padding: 0 !important;
		margin-top: 2px !important;
	}

	/* Step card title */
	.gomoveit-step-card__title {
		font-size: 0.7rem !important;
		margin: 0 0 2px 0 !important;
		padding: 0 !important;
	}

	/* ---- FIELD GRID - REDUCE GAP BETWEEN FIELDS ---- */
	.gomoveit-field-grid,
	.gomoveit-field-grid.cols-2 {
		gap: 10px !important;
	}

	/* ---- INDIVIDUAL FIELDS ---- */
	.gomoveit-field {
		margin-bottom: 0 !important;
	}

	/* Field labels - more compact */
	.gomoveit-field__label,
	.gomoveit-multistep-form .gomoveit-field__label,
	.gomoveit-multistep-form .gomoveit-field > label:first-child {
		font-size: 0.65rem !important;
		margin-bottom: 3px !important;
		letter-spacing: 0.04em !important;
	}

	/* Panel headings (Select GoStoreIt Location) */
	.gomoveit-panel-heading {
		font-size: 0.7rem !important;
		margin-bottom: 4px !important;
	}

	/* ---- INPUTS, SELECTS, TEXTAREAS ---- */
	.gomoveit-multistep-form input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
	.gomoveit-multistep-form select,
	.gomoveit-multistep-form textarea,
	.gomoveit-quote-form input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
	.gomoveit-quote-form select,
	.gomoveit-quote-form textarea {
		padding: 10px 12px !important;
		font-size: 0.9rem !important;
		min-height: 40px !important;
		border-radius: 8px !important;
	}

	/* Textareas - shorter */
	.gomoveit-multistep-form textarea,
	.gomoveit-quote-form textarea {
		min-height: auto !important;
	}

	/* ---- MULTI-SELECT OPTIONS (checkboxes) ---- */
	.gomoveit-multi {
		gap: 6px !important;
	}

	.gomoveit-multi__option,
	.gomoveit-multi label {
		padding: 8px 10px !important;
		font-size: 0.8rem !important;
		border-radius: 6px !important;
		gap: 6px !important;
	}

	/* Checkbox/radio inside multi-select */
	.gomoveit-multi__option input,
	.gomoveit-multi label input {
		width: 16px !important;
		height: 16px !important;
		min-width: 16px !important;
	}

	/* ---- FOOTNOTES/DISCLAIMERS ---- */
	.gomoveit-footnote {
		font-size: 0.7rem !important;
		margin-top: 6px !important;
		line-height: 1.35 !important;
	}

	.gomoveit-footnote--disclaimer {
		margin-top: 10px !important;
		padding-top: 8px !important;
	}

	/* ---- STEP ACTIONS (buttons) ---- */
	.gomoveit-step-actions {
		gap: 8px !important;
		margin-top: 8px !important;
	}

	.gomoveit-step-actions--back {
		margin-top: 4px !important;
	}

	/* Primary action buttons - slightly smaller */
	.gomoveit-step-actions .gomoveit-btn.primary,
	.gomoveit-step-actions button[type="button"]:not(.ghost) {
		padding: 12px 16px !important;
		font-size: 0.85rem !important;
		min-height: 44px !important;
	}

	/* Back button - smaller */
	.gomoveit-step-actions--back .gomoveit-btn,
	.gomoveit-step-actions .gomoveit-btn.ghost {
		padding: 8px 12px !important;
		font-size: 0.8rem !important;
		min-height: 36px !important;
	}

	/* ---- PANEL GROUP (vendor selection area) ---- */
	.gomoveit-panel-group {
		gap: 8px !important;
		margin-top: 8px !important;
	}

	/* ---- UNIT CONTROLS ---- */
	.gomoveit-unit-controls {
		gap: 6px !important;
		margin-bottom: 8px !important;
	}

	.gomoveit-unit-controls .gomoveit-btn {
		padding: 8px 12px !important;
		font-size: 0.8rem !important;
		min-height: 36px !important;
	}

	.gomoveit-unit-count {
		font-size: 0.8rem !important;
		margin-top: 4px !important;
	}

	/* Unit size selects */
	.gomoveit-unit-repeaters {
		gap: 8px !important;
	}

	.gomoveit-unit-size {
		margin-bottom: 0 !important;
	}

	/* ---- REVIEW/SUMMARY SECTIONS ---- */
	.gomoveit-review,
	.gomoveit-quote-summary {
		padding: 12px !important;
		gap: 8px !important;
	}

	.gomoveit-review__row,
	.gomoveit-quote-summary__row {
		padding: 8px 0 !important;
		gap: 2px !important;
	}

	.gomoveit-review__row span,
	.gomoveit-quote-summary__row span {
		font-size: 0.75rem !important;
	}

	.gomoveit-review__row strong,
	.gomoveit-quote-summary__row strong {
		font-size: 0.85rem !important;
	}

	.gomoveit-quote-summary__total {
		padding: 10px !important;
		margin-top: 8px !important;
	}

	/* ---- ACCESS CHECKBOX (75ft confirmation) ---- */
	.gomoveit-access-checkbox {
		padding: 10px !important;
		gap: 8px !important;
		font-size: 0.8rem !important;
	}

	.gomoveit-access-checkbox input {
		width: 18px !important;
		height: 18px !important;
		min-width: 18px !important;
	}

	/* ---- VENDOR PANEL ---- */
	.gomoveit-vendor-panel {
		gap: 8px !important;
	}

	.gomoveit-vendor-card,
	[class*="vendor-card"] {
		padding: 12px !important;
		gap: 8px !important;
	}

	/* ---- PAYMENT PANEL ---- */
	.gomoveit-payment-panel {
		padding: 12px !important;
		gap: 8px !important;
	}

	.gomoveit-payment-panel h4 {
		font-size: 0.9rem !important;
		margin-bottom: 4px !important;
	}

	.gomoveit-payment-placeholder {
		padding: 16px !important;
		font-size: 0.8rem !important;
	}
}

/* ============================================================================
   CALL-REQUIRED FLOW STYLES
   ============================================================================ */

/* Call Required Alert Animation */
@keyframes slideDown {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Call Required Alert Box - COMPACT HORIZONTAL LAYOUT */
.call-required-alert {
	display: none;
	background: #fff4e6;
	border-left: 4px solid #f59e0b;
	border-radius: 6px;
	padding: 12px 16px;
	margin: 12px 0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
	animation: slideDown 0.3s ease-out;
}

/* Disabled Button State */
.gomoveit-btn.disabled-state,
button[data-call-required-disabled="1"] {
	opacity: 0.5 !important;
	cursor: not-allowed !important;
	pointer-events: none !important;
}

.gomoveit-btn.disabled-state:hover,
button[data-call-required-disabled="1"]:hover {
	background-color: inherit !important;
	transform: none !important;
}

/* Call Button Hover Effect */
.call-required-alert .btn-call:hover {
	background: #2d3748 !important;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
	transition: all 0.2s ease;
}

/* Mobile Responsiveness for Call Required Alert - COMPACT VERSION */
@media (max-width: 768px) {
	.call-required-alert {
		padding: 10px 12px !important;
		margin: 10px 0 !important;
	}

	/* Stack the horizontal layout vertically on mobile */
	.call-required-alert > div {
		flex-direction: column !important;
		align-items: flex-start !important;
	}

	.call-required-alert h4 {
		font-size: 14px !important;
	}

	.call-required-alert p {
		font-size: 12px !important;
	}

	/* Make call button full width on mobile */
	.call-required-alert .btn-call {
		width: 100%;
		text-align: center;
		margin-top: 8px;
	}
}
