/* ================================================================
   NextWave — Truck Dispatch Services Landing Page
   Page-specific layouts only.
   Base tokens/components live in tds-base.css.
   ================================================================ */


/* ================================================================
   HERO
   ================================================================ */

.tds-hero {
	position: relative;
	display: flex;
	align-items: center;
	min-height: 100vh;
	min-height: 100svh;
	padding: calc(var(--nw-header-h, 72px) + 52px) 24px 72px;
	overflow: hidden;
	background-color: var(--tds-bg-primary);
	background-image: url('https://nextwavebpo.com/wp-content/uploads/ChatGPT-Image-3-may-2026-06_25_13-p.m-e1778192926435.avif');
	background-size: cover;
	background-position: center;
}

.tds-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background-image:
		radial-gradient(ellipse 60% 50% at 12% 20%, rgba(39, 214, 255, 0.09) 0%, transparent 60%),
		radial-gradient(ellipse 40% 40% at 85% 80%, rgba(39, 214, 255, 0.05) 0%, transparent 55%);
}

.tds-hero::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1;
	height: 2px;
	background: linear-gradient(
		90deg,
		transparent 0%,
		var(--tds-cyan) 30%,
		rgba(39, 214, 255, 0.35) 65%,
		transparent 100%
	);
}

.tds-hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
}

.tds-hero__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.18;
}

.tds-hero__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: rgba(2, 6, 12, 0.86);
}

.tds-hero__inner {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1180px;
	margin: 0 auto;
}

.tds-hero__content {
	text-align: center;
}

.tds-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 22px;
	color: var(--tds-cyan);
	font-size: var(--tds-text-xs);
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.tds-hero__eyebrow::before {
	content: '';
	display: block;
	width: 22px;
	height: 2px;
	flex-shrink: 0;
	background-color: currentColor;
}

.tds-hero__title {
	margin: 0 0 24px;
	color: var(--tds-text-primary);
	font-size: var(--tds-h1);
	font-weight: 800;
	line-height: var(--tds-leading-tight);
	letter-spacing: -0.02em;
}

.tds-hero__intro {
	max-width: 560px;
	margin: 0 auto 40px;
	color: var(--tds-text-secondary);
	font-size: clamp(1rem, 2.2vw, 1.1rem);
	line-height: 1.8;
}

.tds-hero__actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	margin-bottom: 32px;
}

.tds-hero__trust {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	color: var(--tds-text-faint);
	font-size: 0.78rem;
	line-height: 1.5;
	letter-spacing: 0.01em;
}

.tds-hero__trust::before {
	content: '';
	display: inline-block;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	flex-shrink: 0;
	background-color: var(--tds-cyan);
	opacity: 0.55;
}


/* Elementor protection */

body.page-template-page-truck-dispatch-services-php .tds-hero__title {
	color: var(--tds-text-primary) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-hero__eyebrow {
	color: var(--tds-cyan) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-btn--primary,
body.page-template-page-truck-dispatch-services-php .tds-btn--primary:visited,
body.page-template-page-truck-dispatch-services-php .tds-btn--primary:hover {
	color: var(--tds-dark-navy) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-btn--secondary,
body.page-template-page-truck-dispatch-services-php .tds-btn--secondary:visited {
	color: var(--tds-white) !important;
}


/* Hero responsive */

@media (min-width: 640px) {
	.tds-hero {
		padding: calc(var(--nw-header-h, 72px) + 56px) 40px 80px;
	}

	.tds-hero__actions {
		flex-direction: row;
		justify-content: center;
		gap: 16px;
	}
}

@media (min-width: 1024px) {
	.tds-hero {
		min-height: 78vh;
		padding: calc(var(--nw-header-h, 72px) + 80px) 64px 120px;
		background-position: center right;
	}

	.tds-hero__overlay {
		background: linear-gradient(
			to right,
			rgba(2, 6, 12, 0.97) 0%,
			rgba(2, 6, 12, 0.93) 28%,
			rgba(2, 6, 12, 0.70) 50%,
			rgba(2, 6, 12, 0.25) 72%,
			rgba(2, 6, 12, 0.05) 100%
		);
	}

	.tds-hero__content {
		max-width: 620px;
		text-align: left;
	}

	.tds-hero__eyebrow {
		margin-bottom: 24px;
	}

	.tds-hero__intro {
		margin-left: 0;
		margin-right: 0;
	}

	.tds-hero__actions {
		justify-content: flex-start;
	}

	.tds-hero__trust {
		justify-content: flex-start;
	}
}


/* ================================================================
   SECTION 2 — PROBLEMS / PAIN
   ================================================================ */

.tds-pain {
	position: relative;
	background-color: #ffffff;
	background-image: none;
}

.tds-pain__panel {
	background-color: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: var(--tds-radius-lg);
	overflow: hidden;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.06);
}

.tds-pain__content {
	padding: 36px 28px 28px;
	text-align: center;
}

.tds-pain__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 18px;
	color: var(--tds-cyan);
	font-size: var(--tds-text-xs);
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.tds-pain__eyebrow::before,
.tds-pain__eyebrow::after {
	content: '';
	display: block;
	width: 20px;
	height: 2px;
	flex-shrink: 0;
	background-color: currentColor;
}

.tds-pain__title {
	max-width: 620px;
	margin: 0 auto 16px;
	color: var(--tds-dark-navy);
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 800;
	line-height: var(--tds-leading-heading);
	letter-spacing: -0.02em;
}

.tds-pain__title-accent {
	color: var(--tds-cyan);
}

.tds-pain__intro {
	max-width: 520px;
	margin: 0 auto;
	color: #4a5568;
	font-size: clamp(0.93rem, 1.6vw, 1rem);
	line-height: 1.75;
}

.tds-pain__problems {
	padding: 0 28px 36px;
}

.tds-pain__cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}

.tds-pain__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	gap: 10px;
	padding: 16px 14px;
	text-align: center;
	background-color: #ffffff;
	border: 1px solid rgba(39, 214, 255, 0.28);
	border-radius: var(--tds-radius-sm);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.tds-card__icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--tds-cyan);
	background: none;
	border: 0;
	border-radius: 0;
}

.tds-pain__card-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--tds-cyan);
	background: none;
	border: 0;
	border-radius: 0;
}

.tds-pain__card-icon svg,
.tds-pain__card-icon i {
	display: block;
	width: 38px;
	height: 38px;
	font-size: 38px;
	line-height: 1;
}

.tds-pain__card-body {
	min-width: 0;
}

.tds-pain__card-title {
	display: block;
	margin: 0 0 4px;
	color: var(--tds-dark-navy);
	font-size: 0.98rem;
	font-weight: 800;
	line-height: 1.22;
}

.tds-pain__card-desc {
	margin: 0;
	color: #4a5568;
	font-size: var(--tds-text-sm);
	line-height: 1.5;
}

.tds-pain__strip {
	padding: 20px 28px 28px;
	border-top: 0;
}

.tds-pain__strip-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 14px;
	text-align: center;
}

.tds-pain__strip-lead {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	color: var(--tds-cyan);
}

.tds-pain__strip-accent {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--tds-cyan);
	background: none;
	border: 0;
	border-radius: 0;
	line-height: 1;
}

.tds-pain__strip-accent svg {
	display: block;
	width: 16px;
	height: 16px;
}

.tds-pain__strip-text {
	margin: 0;
	color: var(--tds-cyan);
	font-size: var(--tds-text-xs);
	font-weight: 800;
	line-height: 1.4;
	letter-spacing: 0.08em;
	text-align: center;
	text-transform: uppercase;
}


/* Elementor protection */

body.page-template-page-truck-dispatch-services-php .tds-pain__title {
	color: var(--tds-dark-navy) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-pain__title-accent,
body.page-template-page-truck-dispatch-services-php .tds-pain__strip-text,
body.page-template-page-truck-dispatch-services-php .tds-pain__strip-accent {
	color: var(--tds-cyan) !important;
}


/* Problems — mobile only (flatten panel, full-width cards) */

@media (max-width: 767px) {
	.tds-pain__panel {
		background: none;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		overflow: visible;
	}

	.tds-pain__content {
		padding-left: 0;
		padding-right: 0;
	}

	.tds-pain__problems {
		padding-left: 0;
		padding-right: 0;
		padding-bottom: 0;
	}

	.tds-pain__strip {
		padding-left: 0;
		padding-right: 0;
	}

	.tds-pain__card {
		flex-direction: row-reverse;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		padding: 24px 20px;
		min-height: 200px;
		text-align: left;
	}

	.tds-card__icon-wrap {
		align-self: center;
		flex-shrink: 0;
	}

	.tds-pain__card-icon svg,
	.tds-pain__card-icon i {
		width: 42px;
		height: 42px;
		font-size: 42px;
	}

	.tds-pain__card-body {
		flex: 0 0 55%;
		max-width: 55%;
	}

	.tds-pain__card-title {
		font-size: 1.3rem;
		margin-bottom: 8px;
	}

	.tds-pain__card-desc {
		font-size: 0.88rem;
	}
}

/* Problems responsive */

@media (min-width: 640px) {
	.tds-pain__content {
		padding: 44px 40px 32px;
	}

	.tds-pain__problems {
		padding: 0 40px 40px;
	}

	.tds-pain__strip {
		padding: 0 40px 44px;
	}
}

@media (min-width: 768px) {
	.tds-pain.tds-section {
		padding: 48px 0;
	}

	.tds-pain__panel {
		background: none;
		border: 0 !important;
		border-radius: 0;
		box-shadow: none;
		overflow: visible;
	}

	.tds-pain__content {
		padding: 0 0 18px;
		text-align: left;
	}

	.tds-pain__eyebrow::after {
		display: none;
	}

	.tds-pain__title,
	.tds-pain__intro {
		max-width: 100%;
		margin-left: 0;
		margin-right: 0;
	}

	.tds-pain__problems {
		display: flex;
		flex-direction: column;
		gap: 24px;
		padding: 0;
	}

	.tds-pain__cards {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 10px;
	}

	.tds-pain__card {
		padding: 14px 12px;
	}

	.tds-pain__card-icon svg,
	.tds-pain__card-icon i {
		width: 32px;
		height: 32px;
		font-size: 32px;
	}

	.tds-pain__card-title {
		font-size: 0.95rem;
	}

	.tds-pain__strip {
		display: contents;
		padding: 0;
		margin: 0;
		border: 0 !important;
	}

	.tds-pain__strip-inner {
		display: contents;
	}

	.tds-pain__strip-lead {
		justify-content: center;
	}

	.tds-pain__cta {
		display: flex;
		justify-content: center;
	}
}

@media (min-width: 1200px) {
	.tds-pain.tds-section {
		padding: 44px 0;
	}

	.tds-pain .tds-container {
		max-width: 1320px;
	}

	.tds-pain__top {
		display: grid;
		grid-template-columns: 36fr 64fr;
		align-items: center;
		border: 0;
	}

	.tds-pain__top::before,
	.tds-pain__top::after,
	.tds-pain__content::before,
	.tds-pain__content::after,
	.tds-pain__problems::before,
	.tds-pain__problems::after {
		display: none;
		content: none;
	}

	.tds-pain__content {
		padding: 0 36px 0 0;
	}

	.tds-pain__eyebrow {
		margin-bottom: 10px;
	}

	.tds-pain__title {
		margin-bottom: 10px;
		font-size: clamp(1.35rem, 2.2vw, 1.85rem);
		line-height: 1.2;
	}

	.tds-pain__intro {
		font-size: 0.88rem;
		line-height: 1.6;
	}

	.tds-pain__problems {
		gap: 18px;
		padding: 0 0 0 32px;
		background: none;
		border: 0;
	}

	.tds-pain__cards {
		gap: 10px;
	}

	.tds-pain__card {
		gap: 10px;
		padding: 14px 12px;
	}

	.tds-pain__strip-lead {
		gap: 8px;
	}

	.tds-pain__strip-text {
		font-size: 0.68rem;
	}
}


/* ================================================================
   SECTION 3 — BENEFITS
   ================================================================ */

.tds-benefits {
	position: relative;
	background-image: url('https://nextwavebpo.com/wp-content/uploads/white-truck-crossing-bridge-sunset-urban-logistics-motion.avif');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	overflow: hidden;
}

/* Mobile overlay — strong full-cover dark for readability */
.tds-benefits::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background: linear-gradient(
		180deg,
		rgba(2, 6, 12, 0.92) 0%,
		rgba(2, 6, 12, 0.88) 100%
	);
}

.tds-benefits .tds-container--wide {
	position: relative;
	z-index: 1;
}

.tds-benefits__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-2xl);
	text-align: center;
}

/* ── Content (eyebrow + heading + copy) ── */

.tds-benefits__content {
	width: 100%;
	text-align: center;
}

.tds-benefits__content .tds-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 18px;
	color: var(--tds-cyan);
	font-size: var(--tds-text-xs);
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.tds-benefits__content .tds-eyebrow::before,
.tds-benefits__content .tds-eyebrow::after {
	content: '';
	display: block;
	width: 20px;
	height: 2px;
	flex-shrink: 0;
	background-color: currentColor;
}

.tds-benefits__content .tds-heading--h2 {
	margin: 0 0 16px;
	color: var(--tds-text-primary);
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 800;
	line-height: var(--tds-leading-heading, 1.18);
	letter-spacing: -0.02em;
	text-align: center;
}

.tds-benefits__content .tds-highlight {
	color: var(--tds-cyan);
}

.tds-benefits__content .tds-copy {
	max-width: 580px;
	margin: 0 auto;
	color: var(--tds-text-secondary);
	font-size: clamp(0.93rem, 1.6vw, 1rem);
	line-height: 1.75;
	text-align: center;
}

/* ── Cards ── */

.tds-benefits__cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
	width: 100%;
}

.tds-benefits__card {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	gap: 14px;
	padding: 20px 18px;
	text-align: left;
	background-color: var(--tds-bg-card);
	border: 1px solid var(--tds-border-cyan);
	border-radius: var(--tds-radius-sm);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
}

.tds-benefits__card-icon {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-shrink: 0;
	padding-top: 2px;
	color: var(--tds-cyan);
	background: none;
	border: none;
	line-height: 1;
}

.tds-benefits__card-icon svg,
.tds-benefits__card-icon i {
	display: block;
	font-size: 36px;
	line-height: 1;
}

.tds-benefits__card-body {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.tds-benefits__card h3 {
	margin: 0 0 6px;
	color: var(--tds-soft);
	font-size: 1rem;
	font-weight: 800;
	line-height: 1.22;
}

.tds-benefits__card p {
	margin: 0;
	color: var(--tds-text-muted);
	font-size: var(--tds-text-sm);
	line-height: 1.55;
}

/* ── CTA ── */

.tds-benefits__cta {
	display: flex;
	justify-content: center;
}


/* Elementor protection */

body.page-template-page-truck-dispatch-services-php .tds-benefits__content .tds-heading--h2 {
	color: var(--tds-text-primary) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-benefits__content .tds-highlight,
body.page-template-page-truck-dispatch-services-php .tds-benefits__content .tds-eyebrow {
	color: var(--tds-cyan) !important;
}


/* ── Benefits responsive ── */

/* Benefits — mobile only */

@media (max-width: 767px) {
	.tds-benefits__card {
		flex-direction: column;
		align-items: flex-start;
		gap: 16px;
		padding: 24px 20px;
	}

	.tds-benefits__card-icon {
		align-items: center;
		padding-top: 0;
	}

	.tds-benefits__card-icon svg,
	.tds-benefits__card-icon i {
		font-size: 64px;
		width: 64px;
		height: 64px;
	}

	.tds-benefits__card h3 {
		font-size: 1.3rem;
		margin-bottom: 8px;
	}

	.tds-benefits__card p {
		font-size: 0.88rem;
	}
}

@media (min-width: 768px) {
	/* Tablet: overlay slightly lighter so truck shows on right */
	.tds-benefits::before {
		background: linear-gradient(
			180deg,
			rgba(2, 6, 12, 0.90) 0%,
			rgba(2, 6, 12, 0.84) 100%
		);
	}

	/* Tablet+: restore centered vertical card layout */
	.tds-benefits__card {
		flex-direction: column;
		align-items: center;
		text-align: center;
		padding: 28px 20px 24px;
		gap: 0;
	}

	.tds-benefits__card-icon {
		align-items: center;
		padding-top: 0;
		margin-bottom: 14px;
	}

	.tds-benefits__card-body {
		align-items: center;
		text-align: center;
	}

	.tds-benefits__cards {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 12px;
	}
}

@media (min-width: 1200px) {
	/* Desktop: subtle dark fade so truck bleeds through behind content */
	.tds-benefits::before {
		background: linear-gradient(
			180deg,
			rgba(2, 6, 12, 0.88) 0%,
			rgba(2, 6, 12, 0.80) 100%
		);
	}

	.tds-benefits .tds-container--wide {
		max-width: 1320px;
	}

	.tds-benefits__inner {
		max-width: 900px;
		margin-right: auto;
		margin-left: auto;
		gap: var(--tds-space-xl);
	}

	.tds-benefits__cta {
		width: 100%;
	}

	.tds-benefits__cards {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 24px;
	}

	.tds-benefits__card {
		padding: 28px 16px 22px;
	}

	.tds-benefits__card h3 {
		font-size: 0.95rem;
	}
}


/* ================================================================
   SECTION 4 — HOW IT WORKS
   ================================================================ */

.tds-hiw {
	background-color: #ffffff;
	background-image: none;
}

/* ── Header ── */

.tds-hiw__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-md);
	margin-bottom: var(--tds-space-2xl);
	text-align: center;
}

.tds-hiw__header .tds-eyebrow {
	justify-content: center;
}

.tds-hiw__header .tds-heading--h2 {
	max-width: 520px;
	color: var(--tds-dark-navy);
}

.tds-hiw__header .tds-highlight {
	color: var(--tds-cyan);
}

/* ── Flow — mobile: stacked column ── */

.tds-hiw__flow {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-md);
}

.tds-hiw__connector {
	display: none;
}

/* ── Step — mobile: horizontal (circle LEFT, text RIGHT) ── */

.tds-hiw__step {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	gap: var(--tds-space-md);
}

/* ── Step media — mobile: circle badge ── */

.tds-hiw__step-media {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background-color: rgba(39, 214, 255, 0.10);
	border: 2px solid var(--tds-cyan);
}

.tds-hiw__step-num {
	font-size: 1.15rem;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.02em;
	color: var(--tds-cyan);
}

/* ── Step body — mobile: text left ── */

.tds-hiw__step-body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding-top: 8px;
}

.tds-hiw__step-title {
	margin: 0;
	color: var(--tds-dark-navy);
	font-size: 0.92rem;
	font-weight: 800;
	line-height: 1.2;
	min-height: calc(1.2em * 2);
}

.tds-hiw__step-desc {
	margin: 0;
	color: #4a5568;
	font-size: var(--tds-text-sm);
	line-height: 1.65;
}

/* ── Timeline — mobile only ── */

.tds-hiw__tl-bg,
.tds-hiw__tl-fill {
	display: none;
}

@media (max-width: 639px) {
	.tds-hiw__flow {
		position: relative;
		gap: 80px;
	}

	.tds-hiw__step {
		gap: 24px;
	}

	.tds-hiw__tl-bg,
	.tds-hiw__tl-fill {
		display: block;
		position: absolute;
		left: 13px;
		top: 14px;
		width: 2px;
		pointer-events: none;
		z-index: 0;
	}

	.tds-hiw__tl-bg {
		background: rgba(39, 214, 255, 0.22);
		height: 0;
	}

	.tds-hiw__tl-fill {
		background: var(--tds-cyan);
		height: 0;
		transition: height 0.7s cubic-bezier(0.4, 0, 0.2, 1);
	}

	.tds-hiw__step {
		position: relative;
		z-index: 1;
	}

	.tds-hiw__step-media {
		width: 28px;
		height: 28px;
		background-color: #ffffff;
		z-index: 2;
		transition: background-color 0.35s ease;
	}

	.tds-hiw__step.is-active .tds-hiw__step-media {
		background-color: var(--tds-cyan);
	}

	.tds-hiw__step-num {
		font-size: 0.72rem;
		transition: opacity 0.3s ease;
	}

	.tds-hiw__step.is-active .tds-hiw__step-num {
		opacity: 0;
	}

	.tds-hiw__step-body {
		opacity: 0;
		transform: translateY(18px);
		transition: opacity 0.5s ease, transform 0.5s ease;
	}

	.tds-hiw__step.is-visible .tds-hiw__step-body {
		opacity: 1;
		transform: translateY(0);
	}

	.tds-hiw__step-title {
		font-size: 1.25rem;
		min-height: 0;
	}

	.tds-hiw__step-desc {
		font-size: 0.9rem;
	}
}

/* ── Bottom strip ── */

.tds-hiw__bottom {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-lg);
	margin-top: var(--tds-space-2xl);
	padding-top: var(--tds-space-xl);
	border-top: 1px solid rgba(0, 0, 0, 0.08);
	text-align: center;
}

.tds-hiw__bottom-text {
	max-width: 560px;
	color: #4a5568;
}


/* Elementor protection */

body.page-template-page-truck-dispatch-services-php .tds-hiw__header .tds-heading--h2,
body.page-template-page-truck-dispatch-services-php .tds-hiw__step-title {
	color: var(--tds-dark-navy) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-hiw__step-num,
body.page-template-page-truck-dispatch-services-php .tds-hiw__header .tds-eyebrow,
body.page-template-page-truck-dispatch-services-php .tds-hiw__header .tds-highlight {
	color: var(--tds-cyan) !important;
}


/* ── How It Works responsive ── */

/* Tablet + Desktop: 3-column grid, vertical card layout — proportional across sizes */
@media (min-width: 640px) {
	.tds-hiw__flow {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: var(--tds-space-lg);
		align-items: stretch;
	}

	.tds-hiw__step {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 0;
		padding: var(--tds-space-xl) var(--tds-space-md);
		border: 1px solid rgba(39, 214, 255, 0.18);
		border-radius: var(--tds-radius-md);
		box-shadow: 0 2px 16px rgba(0, 0, 0, 0.06);
		background-color: #ffffff;
	}

	.tds-hiw__step-media {
		width: 60px;
		height: 60px;
		margin-bottom: var(--tds-space-md);
	}

	.tds-hiw__step-num {
		font-size: 1.25rem;
	}

	.tds-hiw__step-body {
		align-items: center;
		text-align: center;
		padding-top: 0;
		gap: var(--tds-space-xs);
	}

	.tds-hiw__step-title {
		font-size: 0.98rem;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
	}
}

@media (min-width: 1200px) {
	.tds-hiw__header {
		margin-bottom: var(--tds-space-3xl);
	}

	.tds-hiw__flow {
		gap: var(--tds-space-xl);
	}

	.tds-hiw__step {
		padding: var(--tds-space-2xl) var(--tds-space-lg);
	}

	.tds-hiw__step-media {
		width: 68px;
		height: 68px;
		margin-bottom: var(--tds-space-lg);
	}

	.tds-hiw__step-num {
		font-size: 1.4rem;
	}

	.tds-hiw__step-title {
		font-size: 1.05rem;
	}

	.tds-hiw__step-desc {
		font-size: var(--tds-text-md);
	}

	/* Bottom: text left, CTA right */
	.tds-hiw__bottom {
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
		text-align: left;
		margin-top: var(--tds-space-3xl);
	}

	.tds-hiw__bottom-text {
		max-width: 500px;
	}
}


/* ================================================================
   SECTION 5 — SOCIAL PROOF
   ================================================================ */

.tds-sp {
	background-color: var(--tds-bg-primary);
	background-image: var(--tds-gradient-page);
}

/* ── Header ── */

.tds-sp__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-md);
	margin-bottom: var(--tds-space-2xl);
	text-align: center;
}

.tds-sp__header .tds-eyebrow {
	justify-content: center;
}

.tds-sp__header .tds-heading--h2 {
	max-width: 600px;
}

.tds-sp__intro {
	max-width: 560px;
}

/* ── Carousel ── */

.tds-sp__carousel {
	position: relative;
}

.tds-sp__track-wrap {
	overflow: hidden;
}

.tds-sp__track {
	display: flex;
	gap: var(--tds-space-lg);
	will-change: transform;
	transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ── Card — mobile: 1 visible ── */

.tds-sp__card {
	flex: 0 0 100%;
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-md);
	padding: var(--tds-space-xl) var(--tds-space-lg);
	background-color: var(--tds-bg-card);
	border: 1px solid var(--tds-border-cyan);
	border-radius: var(--tds-radius-md);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
}

/* ── Nav row: prev · dots · next ── */

.tds-sp__nav {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--tds-space-md);
	margin-top: var(--tds-space-xl);
}

/* ── Arrows ── */

.tds-sp__arrow {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background-color: rgba(2, 6, 12, 0.55);
	border: 1px solid rgba(39, 214, 255, 0.25);
	color: var(--tds-soft);
	cursor: pointer;
	padding: 0;
	transition:
		background-color var(--tds-transition),
		border-color var(--tds-transition),
		color var(--tds-transition);
}

.tds-sp__arrow:hover {
	background-color: rgba(39, 214, 255, 0.12);
	border-color: var(--tds-cyan);
	color: var(--tds-cyan);
}

.tds-sp__arrow:focus-visible {
	outline: 2px solid var(--tds-cyan);
	outline-offset: 2px;
}

.tds-sp__arrow svg {
	display: block;
}

/* Elementor override — prevent global button styles on arrows */
body.page-template-page-truck-dispatch-services-php .tds-sp .tds-sp__arrow {
	background-color: rgba(2, 6, 12, 0.55) !important;
	background-image: none !important;
	border-radius: 50% !important;
	border: 1px solid rgba(39, 214, 255, 0.25) !important;
	color: var(--tds-soft) !important;
	padding: 0 !important;
	font-size: inherit !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	box-shadow: none !important;
	width: 42px !important;
	height: 42px !important;
}

body.page-template-page-truck-dispatch-services-php .tds-sp .tds-sp__arrow:hover {
	background-color: rgba(39, 214, 255, 0.12) !important;
	border-color: var(--tds-cyan) !important;
	color: var(--tds-cyan) !important;
}

/* ── Dots ── */

.tds-sp__dots {
	display: flex;
	align-items: center;
	gap: 6px;
}

.tds-sp__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.22);
	border: 0;
	cursor: pointer;
	padding: 0;
	transition:
		background-color var(--tds-transition),
		width var(--tds-transition),
		border-radius var(--tds-transition);
}

.tds-sp__dot.is-active {
	width: 22px;
	border-radius: 4px;
	background-color: var(--tds-cyan);
}

.tds-sp__dot:focus-visible {
	outline: 2px solid var(--tds-cyan);
	outline-offset: 2px;
}

/* Elementor override — prevent global button styles on dots */
body.page-template-page-truck-dispatch-services-php .tds-sp .tds-sp__dot {
	background-color: rgba(255, 255, 255, 0.22) !important;
	background-image: none !important;
	border-radius: 50% !important;
	border: 0 !important;
	padding: 0 !important;
	width: 8px !important;
	height: 8px !important;
	min-width: 0 !important;
	box-shadow: none !important;
	letter-spacing: normal !important;
	text-transform: none !important;
}

body.page-template-page-truck-dispatch-services-php .tds-sp .tds-sp__dot.is-active {
	background-color: var(--tds-cyan) !important;
	width: 22px !important;
	border-radius: 4px !important;
}

.tds-sp__stars {
	color: var(--tds-cyan);
	font-size: 1.1rem;
	letter-spacing: 0.1em;
	line-height: 1;
}

.tds-sp__quote {
	margin: 0;
	flex: 1;
}

.tds-sp__quote p {
	margin: 0;
	color: var(--tds-text-secondary);
	font-size: var(--tds-text-md);
	line-height: 1.7;
	font-style: italic;
}

.tds-sp__author {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

.tds-sp__author-name {
	color: var(--tds-soft);
	font-size: var(--tds-text-sm);
	font-weight: 800;
}

.tds-sp__author-sep {
	color: var(--tds-text-faint);
	font-size: var(--tds-text-sm);
}

.tds-sp__author-role {
	color: var(--tds-text-muted);
	font-size: var(--tds-text-sm);
}

/* ── Bottom strip ── */

.tds-sp__bottom {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-lg);
	margin-top: var(--tds-space-2xl);
	padding-top: var(--tds-space-xl);
	border-top: 1px solid var(--tds-border-soft);
	text-align: center;
}

.tds-sp__tagline {
	margin: 0;
	color: var(--tds-cyan);
	font-size: var(--tds-text-sm);
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* ── Elementor protection ── */

body.page-template-page-truck-dispatch-services-php .tds-sp__header .tds-heading--h2 {
	color: var(--tds-text-primary) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-sp__header .tds-highlight,
body.page-template-page-truck-dispatch-services-php .tds-sp__tagline,
body.page-template-page-truck-dispatch-services-php .tds-sp__stars,
body.page-template-page-truck-dispatch-services-php .tds-sp__header .tds-eyebrow {
	color: var(--tds-cyan) !important;
}

/* ── Social Proof responsive ── */

/* Tablet: 2 cards visible — (100% - 1 gap) / 2 */
@media (min-width: 768px) {
	.tds-sp__card {
		flex: 0 0 calc(50% - 12px);
	}
}

/* Desktop: 3 cards visible — (100% - 2 gaps) / 3 */
@media (min-width: 1025px) {
	.tds-sp__card {
		flex: 0 0 calc(33.333% - 16px);
	}
}

@media (min-width: 640px) {
	.tds-sp__bottom {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
	}
}

@media (min-width: 1200px) {
	.tds-sp__card {
		padding: var(--tds-space-2xl) var(--tds-space-xl);
	}

	.tds-sp__quote p {
		font-size: var(--tds-text-base);
	}
}


/* ================================================================
   SECTION 6 — LEAD FORM
   ================================================================ */

.tds-lf {
	background-color: #ffffff;
	background-image: none;
}

/* ── Inner split layout ── */

.tds-lf__inner {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-2xl);
}

/* ── Copy side ── */

.tds-lf__copy {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-lg);
}

.tds-lf__title {
	margin: 0;
	color: var(--tds-dark-navy);
	font-size: clamp(1.75rem, 4vw, 2.6rem);
	font-weight: 800;
	line-height: var(--tds-leading-heading);
	letter-spacing: -0.025em;
}

.tds-lf__title-accent {
	color: var(--tds-cyan);
}

.tds-lf__sub {
	margin: 0;
	color: #4a5568;
	font-size: clamp(0.93rem, 1.6vw, 1rem);
	line-height: 1.75;
}

.tds-lf__bullets {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-sm);
}

.tds-lf__bullet {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--tds-dark-navy);
	font-size: var(--tds-text-md);
	font-weight: 600;
	line-height: 1.4;
}

.tds-lf__bullet-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background-color: rgba(39, 214, 255, 0.12);
	color: var(--tds-cyan);
}

/* ── Form card ── */

.tds-lf__form-wrap {
	background-color: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: var(--tds-radius-lg);
	padding: var(--tds-space-xl) var(--tds-space-lg);
	box-shadow: 0 4px 32px rgba(0, 0, 0, 0.08);
}

.tds-lf__form {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-md);
}

.tds-lf__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tds-space-md);
}

.tds-lf__field {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-xs);
}

.tds-lf__label {
	color: var(--tds-dark-navy);
	font-size: var(--tds-text-sm);
	font-weight: 700;
}

.tds-lf__required {
	color: var(--tds-cyan);
}

.tds-lf__input {
	width: 100%;
	box-sizing: border-box;
	padding: 14px 16px;
	border: 1px solid rgba(0, 0, 0, 0.14);
	border-radius: var(--tds-radius-sm);
	background-color: #f8fafc;
	color: var(--tds-dark-navy);
	font-family: inherit;
	font-size: var(--tds-text-md);
	line-height: 1.4;
	transition:
		border-color var(--tds-transition-fast),
		box-shadow var(--tds-transition-fast),
		background-color var(--tds-transition-fast);
	-webkit-appearance: none;
	appearance: none;
}

.tds-lf__input::placeholder {
	color: #a0aec0;
}

.tds-lf__input:focus {
	outline: none;
	border-color: var(--tds-cyan);
	box-shadow: 0 0 0 3px rgba(39, 214, 255, 0.18);
	background-color: #ffffff;
}

.tds-lf__select {
	cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2302172F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	padding-right: 44px;
}

.tds-lf__submit {
	width: 100%;
	justify-content: center;
	padding: 14px 24px;
	margin-top: var(--tds-space-xs);
}

.tds-lf__trust-line {
	margin: 0;
	color: #a0aec0;
	font-size: var(--tds-text-xs);
	text-align: center;
	line-height: 1.5;
}

/* ── Elementor protection ── */

body.page-template-page-truck-dispatch-services-php .tds-lf__title {
	color: var(--tds-dark-navy) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__title-accent {
	color: var(--tds-cyan) !important;
}

/* ── Lead Form responsive ── */

@media (min-width: 640px) {
	.tds-lf__row {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.tds-lf__form-wrap {
		padding: var(--tds-space-2xl) var(--tds-space-xl);
	}
}

@media (min-width: 960px) {
	.tds-lf__inner {
		display: grid;
		grid-template-columns: 42fr 58fr;
		gap: var(--tds-space-3xl);
		align-items: start;
	}

	.tds-lf__copy {
		position: sticky;
		top: var(--tds-space-xl);
	}
}

@media (min-width: 1200px) {
	.tds-lf__inner {
		grid-template-columns: 40fr 60fr;
		gap: 80px;
	}

	.tds-lf__title {
		font-size: clamp(1.55rem, 2.4vw, 2.1rem);
	}
}


/* ================================================================
   SECTION 7 — FAQ
   ================================================================ */

.tds-faq {
	background-color: #f8fafc;
	background-image: none;
}

/* ── Header ── */

.tds-faq__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-md);
	margin-bottom: var(--tds-space-3xl);
	text-align: center;
}

.tds-faq__header .tds-eyebrow {
	justify-content: center;
}

.tds-faq__title {
	margin: 0;
	color: var(--tds-dark-navy);
	font-size: clamp(1.6rem, 3.5vw, 2.4rem);
	font-weight: 800;
	line-height: var(--tds-leading-heading);
	letter-spacing: -0.02em;
	max-width: 600px;
}

.tds-faq__title-accent {
	color: var(--tds-cyan);
}

/* ── List — independent card stack ── */

.tds-faq__list {
	max-width: 720px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-sm);
}

/* ── Item — individual white card ── */

.tds-faq__item {
	background-color: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: var(--tds-radius-md);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
	overflow: hidden;
	transition:
		box-shadow var(--tds-transition),
		border-color var(--tds-transition);
}

.tds-faq__item:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.09);
}

.tds-faq__item.is-open {
	border-color: rgba(39, 214, 255, 0.30);
	box-shadow: 0 4px 20px rgba(39, 214, 255, 0.08), 0 2px 8px rgba(0, 0, 0, 0.04);
}

/* ── Trigger (button) ── */

.tds-faq__trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--tds-space-md);
	width: 100%;
	padding: var(--tds-space-lg) var(--tds-space-xl);
	background: none;
	border: 0;
	cursor: pointer;
	text-align: left;
}

.tds-faq__trigger:focus-visible {
	outline: 2px solid var(--tds-cyan);
	outline-offset: -2px;
	border-radius: var(--tds-radius-md);
}

.tds-faq__q {
	color: var(--tds-dark-navy);
	font-size: var(--tds-text-md);
	font-weight: 700;
	line-height: 1.45;
}

/* ── Chevron — circle badge, neutral closed / cyan open ── */

.tds-faq__chevron {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background-color: rgba(0, 0, 0, 0.05);
	color: #64748b;
	transition:
		transform var(--tds-transition),
		background-color var(--tds-transition),
		color var(--tds-transition);
}

.tds-faq__item.is-open .tds-faq__chevron {
	transform: rotate(180deg);
	background-color: rgba(39, 214, 255, 0.14);
	color: var(--tds-cyan);
}

/* ── Answer panel ── */

.tds-faq__answer {
	overflow: hidden;
	max-height: 0;
	transition: max-height 0.32s ease;
}

.tds-faq__item.is-open .tds-faq__answer {
	max-height: 400px;
}

.tds-faq__answer p {
	margin: 0;
	padding: var(--tds-space-md) var(--tds-space-xl) var(--tds-space-xl);
	color: #4a5568;
	font-size: var(--tds-text-md);
	line-height: 1.75;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
}

/* ── Elementor protection ── */

body.page-template-page-truck-dispatch-services-php .tds-faq__title {
	color: var(--tds-dark-navy) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-faq__title-accent,
body.page-template-page-truck-dispatch-services-php .tds-faq__header .tds-eyebrow {
	color: var(--tds-cyan) !important;
}

/* Elementor injects global button styles (background-color, border-radius, padding, etc.)
   onto every <button> element. These overrides beat that specificity for the FAQ trigger. */

body.page-template-page-truck-dispatch-services-php .tds-faq .tds-faq__trigger {
	background-color: transparent !important;
	background-image: none !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	padding: var(--tds-space-lg) var(--tds-space-xl) !important;
	color: inherit !important;
	font-size: var(--tds-text-md) !important;
	font-weight: 700 !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	line-height: 1.45 !important;
	width: 100% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: var(--tds-space-md) !important;
	text-align: left !important;
	cursor: pointer !important;
}

body.page-template-page-truck-dispatch-services-php .tds-faq .tds-faq__trigger:hover {
	background-color: transparent !important;
}

body.page-template-page-truck-dispatch-services-php .tds-faq .tds-faq__q {
	color: var(--tds-dark-navy) !important;
	font-size: var(--tds-text-md) !important;
	font-weight: 700 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

/* ── FAQ responsive ── */

@media (min-width: 640px) {
	.tds-faq__trigger {
		padding: var(--tds-space-lg) var(--tds-space-2xl);
	}

	body.page-template-page-truck-dispatch-services-php .tds-faq .tds-faq__trigger {
		padding: var(--tds-space-lg) var(--tds-space-2xl) !important;
	}

	.tds-faq__answer p {
		padding: var(--tds-space-md) var(--tds-space-2xl) var(--tds-space-xl);
	}
}

@media (min-width: 1200px) {
	.tds-faq__header {
		margin-bottom: 80px;
	}
}


/* ================================================================
   SECTION 8 — SEO CONTENT
   ================================================================ */

.tds-seo {
	background-color: #ffffff;
	background-image: none;
}

.tds-seo__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-md);
	margin-bottom: var(--tds-space-2xl);
	text-align: center;
}

.tds-seo__header .tds-eyebrow {
	justify-content: center;
}

.tds-seo__header .tds-heading--h2 {
	max-width: 600px;
	color: var(--tds-dark-navy);
}

.tds-seo__header .tds-highlight {
	color: var(--tds-cyan);
}

.tds-seo__body {
	max-width: 760px;
	margin-inline: auto;
}

.tds-seo__intro {
	margin: 0 0 var(--tds-space-2xl);
	color: #4a5568;
	font-size: clamp(0.93rem, 1.6vw, 1rem);
	line-height: 1.75;
}

.tds-seo__blocks {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-xl);
}

.tds-seo__block-title {
	margin: 0 0 var(--tds-space-sm);
	color: var(--tds-dark-navy);
	font-size: clamp(1.1rem, 2vw, 1.35rem);
	font-weight: 800;
	line-height: 1.3;
}

.tds-seo__block-text {
	margin: 0 0 var(--tds-space-md);
	color: #4a5568;
	font-size: clamp(0.93rem, 1.6vw, 1rem);
	line-height: 1.75;
}

.tds-seo__block-text:last-child {
	margin-bottom: 0;
}

.tds-seo__link {
	color: var(--tds-cyan);
	font-weight: 600;
	text-decoration: underline;
	text-decoration-color: rgba(39, 214, 255, 0.45);
	text-underline-offset: 2px;
	transition: text-decoration-color var(--tds-transition);
}

.tds-seo__link:hover {
	text-decoration-color: var(--tds-cyan);
}


/* Elementor protection */

body.page-template-page-truck-dispatch-services-php .tds-seo__header .tds-heading--h2,
body.page-template-page-truck-dispatch-services-php .tds-seo__block-title {
	color: var(--tds-dark-navy) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-seo__header .tds-highlight,
body.page-template-page-truck-dispatch-services-php .tds-seo__header .tds-eyebrow,
body.page-template-page-truck-dispatch-services-php .tds-seo__link {
	color: var(--tds-cyan) !important;
}


/* SEO section responsive */

@media (min-width: 768px) {
	.tds-seo__blocks {
		gap: var(--tds-space-2xl);
	}
}


/* ================================================================
   SECTION 9 — FINAL CTA
   ================================================================ */

.tds-fcta {
	background-color: var(--tds-bg-primary);
	background-image: var(--tds-gradient-hero);
	overflow: hidden;
}

.tds-fcta::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 70% 60% at 50% 50%, rgba(39, 214, 255, 0.06) 0%, transparent 70%);
	pointer-events: none;
	z-index: 0;
}

.tds-fcta .tds-container {
	position: relative;
	z-index: 1;
}

/* ── Inner ── */

.tds-fcta__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-lg);
	text-align: center;
	max-width: 780px;
	margin-inline: auto;
}

.tds-fcta__eyebrow {
	justify-content: center;
}

.tds-fcta__title {
	max-width: 640px;
}

.tds-fcta__sub {
	max-width: 560px;
}

/* ── Actions ── */

.tds-fcta__actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-md);
	width: 100%;
}

.tds-fcta__actions .tds-btn {
	width: 100%;
	justify-content: center;
	max-width: 360px;
}

/* ── Trust line ── */

.tds-fcta__trust {
	margin: 0;
	color: var(--tds-text-muted);
	font-size: var(--tds-text-sm);
}

/* ── Elementor protection ── */

body.page-template-page-truck-dispatch-services-php .tds-fcta__title {
	color: var(--tds-text-primary) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-fcta .tds-highlight,
body.page-template-page-truck-dispatch-services-php .tds-fcta__eyebrow {
	color: var(--tds-cyan) !important;
}

/* ── Final CTA responsive ── */

@media (min-width: 640px) {
	.tds-fcta__actions {
		flex-direction: row;
		justify-content: center;
		width: auto;
	}

	.tds-fcta__actions .tds-btn {
		width: auto;
	}
}


/* ================================================================
   MOBILE FIXES — max-width: 767px
   ================================================================ */

@media (max-width: 767px) {

	/* 1 — Hero: trim excess bottom padding */
	.tds-hero {
		padding-bottom: 40px;
	}

	/* 1 — Hero: soften overlay so background image is more visible */
	.tds-hero__overlay {
		background: rgba(2, 6, 12, 0.74);
	}

	/* 2 — Hero trust line: tighter gap, solid vertical centering */
	.tds-hero__trust {
		gap: 4px;
		align-items: center;
	}

	.tds-hero__trust::before {
		display: block;
		flex-shrink: 0;
		margin-top: 0;
	}

	/* 3 — Global sections: reduce vertical padding ~40% */
	.tds-section {
		padding-block: 42px;
	}

	/* 4 — How It Works: tighter header gap */
	.tds-hiw__header {
		margin-bottom: var(--tds-space-xl);
	}
}


/* ================================================================
   PROFIT CALCULATOR
   ================================================================ */

.tds-calc__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-md);
	text-align: center;
	max-width: 600px;
	margin: 0 auto var(--tds-space-2xl);
}

.tds-calc__lead {
	max-width: 520px;
	font-size: var(--tds-text-lg);
}

/* ── Card ── */
.tds-calc__card {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tds-space-xl);
	background: var(--tds-bg-card-soft);
	border: 1px solid var(--tds-border-cyan);
	border-radius: var(--tds-radius-lg);
	padding: var(--tds-space-xl);
	max-width: 820px;
	margin: 0 auto;
}

@media (min-width: 720px) {
	.tds-calc__card {
		grid-template-columns: 1fr auto 1fr;
		align-items: center;
		padding: var(--tds-space-2xl);
		gap: 0;
	}
}

/* ── Inputs ── */
.tds-calc__inputs {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-lg);
}

.tds-calc__field {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-xs);
}

.tds-calc__label {
	font-size: var(--tds-text-sm);
	font-weight: 700;
	color: var(--tds-text-muted);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.tds-calc__input-wrap {
	display: flex;
	align-items: center;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid var(--tds-border-soft);
	border-radius: var(--tds-radius-sm);
	overflow: hidden;
	transition: border-color var(--tds-transition);
}

.tds-calc__input-wrap:focus-within {
	border-color: var(--tds-border-cyan-strong);
}

.tds-calc__prefix,
.tds-calc__suffix {
	padding: 0 var(--tds-space-sm);
	color: var(--tds-cyan);
	font-size: var(--tds-text-lg);
	font-weight: 700;
	flex-shrink: 0;
	-webkit-user-select: none;
	user-select: none;
	line-height: 1;
}

.tds-calc__input {
	flex: 1;
	min-width: 0;
	background: transparent;
	border: none;
	outline: none;
	color: var(--tds-text-primary);
	font-family: inherit;
	font-size: var(--tds-text-base);
	font-weight: 600;
	padding: 13px var(--tds-space-sm);
	width: 100%;
}

.tds-calc__input::placeholder {
	color: var(--tds-text-faint);
	font-weight: 400;
}

.tds-calc__input[type="number"]::-webkit-inner-spin-button,
.tds-calc__input[type="number"]::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.tds-calc__input[type="number"] {
	-moz-appearance: textfield;
	appearance: textfield;
}

.tds-calc__select {
	width: 100%;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid var(--tds-border-soft);
	border-radius: var(--tds-radius-sm);
	color: var(--tds-text-secondary);
	font-family: inherit;
	font-size: var(--tds-text-base);
	padding: 13px 36px 13px var(--tds-space-md);
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2327D6FF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	transition: border-color var(--tds-transition);
	outline: none;
}

.tds-calc__select:focus {
	border-color: var(--tds-border-cyan-strong);
}

.tds-calc__select option {
	background: var(--tds-navy);
	color: var(--tds-text-primary);
}

/* ── Divider ── */
.tds-calc__divider {
	display: none;
}

@media (min-width: 720px) {
	.tds-calc__divider {
		display: block;
		width: 1px;
		min-height: 200px;
		align-self: stretch;
		flex-shrink: 0;
		margin: 0 var(--tds-space-2xl);
		background: linear-gradient(
			to bottom,
			transparent,
			var(--tds-border-cyan-strong) 20%,
			var(--tds-border-cyan-strong) 80%,
			transparent
		);
	}
}

/* ── Results ── */
.tds-calc__results {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.tds-calc__result-row {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: var(--tds-space-md) 0;
	border-bottom: 1px solid var(--tds-border-soft);
}

.tds-calc__result-row:first-child {
	padding-top: 0;
}

.tds-calc__result-row:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.tds-calc__result-row--highlight {
	margin-top: var(--tds-space-xs);
	padding-top: var(--tds-space-md);
	border-top: 1px solid var(--tds-border-cyan);
	border-bottom: none;
}

.tds-calc__result-label {
	font-size: var(--tds-text-sm);
	font-weight: 600;
	color: var(--tds-text-muted);
	line-height: 1.3;
}

.tds-calc__result-label em {
	font-style: normal;
	color: var(--tds-text-faint);
}

.tds-calc__result-value {
	font-size: clamp(1.45rem, 3vw, 1.9rem);
	font-weight: 800;
	color: var(--tds-text-secondary);
	letter-spacing: -0.03em;
	line-height: 1;
	transition: color var(--tds-transition);
}

.tds-calc__result-value--us {
	color: var(--tds-cyan);
}

.tds-calc__result-value--extra {
	font-size: clamp(1.7rem, 3.5vw, 2.2rem);
	color: var(--tds-text-secondary);
}

.tds-calc__result-value--extra.is-positive {
	color: #4ade80;
}

.tds-calc__result-value--extra.is-negative {
	color: #f87171;
}

/* ── CTA ── */
.tds-calc__cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tds-space-md);
	margin-top: var(--tds-space-2xl);
	text-align: center;
}

.tds-calc__microcopy {
	margin-top: 0;
}

/* Helper text below the "Current Dispatcher Fee" label */
.tds-calc__hint {
	margin: 2px 0 0;
	color: var(--tds-text-faint);
	font-size: var(--tds-text-xs);
	font-style: italic;
	line-height: 1.4;
}


/* ================================================================
   GRAVITY FORMS — Form ID 2 (Truck Dispatch Landing Page only)
   Scoped to this template so it never bleeds into other GF forms.
   ================================================================ */

/* ── Wrapper reset ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_wrapper,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_wrapper.gravity-theme {
	margin: 0;
	padding: 0;
	max-width: none;
	background: none;
	border: none;
	box-shadow: none;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_body,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform-body {
	margin: 0;
	padding: 0;
}

/* ── Field list ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_fields {
	display: flex;
	flex-direction: column;
	gap: var(--tds-space-md);
	margin: 0;
	padding: 0;
	list-style: none;
}

/* ── Individual field ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield {
	margin: 0;
	padding: 0;
}

/* ── Labels ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_label,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield > label {
	display: block;
	margin: 0 0 var(--tds-space-xs) !important;
	color: var(--tds-dark-navy) !important;
	font-size: var(--tds-text-sm) !important;
	font-weight: 700 !important;
	line-height: 1.4;
	text-transform: none !important;
	letter-spacing: normal !important;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_required {
	color: var(--tds-cyan);
	font-weight: 700;
}

/* ── Inputs, selects, textareas ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="image"]):not([type="hidden"]),
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container select,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container textarea {
	width: 100% !important;
	box-sizing: border-box !important;
	padding: 14px 16px !important;
	border: 1px solid rgba(0, 0, 0, 0.14) !important;
	border-radius: var(--tds-radius-sm) !important;
	background-color: #f8fafc !important;
	background-image: none !important;
	color: var(--tds-dark-navy) !important;
	font-family: inherit !important;
	font-size: var(--tds-text-md) !important;
	line-height: 1.4 !important;
	box-shadow: none !important;
	transition:
		border-color var(--tds-transition-fast),
		box-shadow var(--tds-transition-fast),
		background-color var(--tds-transition-fast);
	-webkit-appearance: none;
	appearance: none;
	margin: 0 !important;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container input::placeholder,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container textarea::placeholder {
	color: #a0aec0;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container input:focus:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="image"]):not([type="hidden"]),
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container select:focus,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container textarea:focus {
	outline: none !important;
	border-color: var(--tds-cyan) !important;
	box-shadow: 0 0 0 3px rgba(39, 214, 255, 0.18) !important;
	background-color: #ffffff !important;
}

/* ── Select — custom chevron ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container select {
	cursor: pointer !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2302172F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: right 16px center !important;
	padding-right: 44px !important;
}

/* ── Name field — sub-label styling ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container_name {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tds-space-md);
}

@media (min-width: 540px) {
	body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container_name {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container_name span {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container_name .name_first label,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .ginput_container_name .name_last label {
	color: #718096 !important;
	font-size: var(--tds-text-xs) !important;
	font-weight: 600 !important;
	margin: 0 !important;
}

/* ── Hide UTM / GCLID hidden fields ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield--type-hidden,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_visibility_hidden {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	position: absolute !important;
	pointer-events: none !important;
}

/* ── Submit button — match .tds-btn.tds-btn--primary ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_footer,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_page_footer {
	margin: var(--tds-space-xs) 0 0 !important;
	padding: 0 !important;
	border: none !important;
	background: none !important;
	text-align: left;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_button,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap input[type="submit"].gform_button {
	display: block !important;
	width: 100% !important;
	box-sizing: border-box !important;
	padding: 16px 26px !important;
	background-color: var(--tds-cyan) !important;
	background-image: none !important;
	border: 2px solid var(--tds-cyan) !important;
	border-radius: var(--tds-radius-pill) !important;
	color: var(--tds-dark-navy) !important;
	font-family: inherit !important;
	font-size: 0.9rem !important;
	font-weight: 800 !important;
	line-height: 1 !important;
	letter-spacing: 0.02em !important;
	text-align: center !important;
	text-transform: none !important;
	box-shadow: none !important;
	cursor: pointer !important;
	-webkit-appearance: none;
	appearance: none;
	transition:
		background-color var(--tds-transition),
		border-color var(--tds-transition),
		transform var(--tds-transition);
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_button:hover,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap input[type="submit"].gform_button:hover {
	background-color: var(--tds-cyan-hover) !important;
	border-color: var(--tds-cyan-hover) !important;
	color: var(--tds-dark-navy) !important;
	transform: translateY(-2px) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_button:focus-visible,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap input[type="submit"].gform_button:focus-visible {
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(39, 214, 255, 0.5) !important;
}

/* ── Validation — field errors ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_validation_errors,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .validation_error {
	margin: 0 0 var(--tds-space-md) !important;
	padding: var(--tds-space-md) var(--tds-space-lg) !important;
	background-color: rgba(248, 113, 113, 0.08) !important;
	border: 1px solid rgba(248, 113, 113, 0.30) !important;
	border-radius: var(--tds-radius-sm) !important;
	color: #dc2626 !important;
	font-size: var(--tds-text-sm) !important;
	font-weight: 600;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_error .gfield_label,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_error > label {
	color: #dc2626 !important;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_error .ginput_container input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="image"]):not([type="hidden"]),
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_error .ginput_container select,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_error .ginput_container textarea {
	border-color: rgba(220, 38, 38, 0.5) !important;
	background-color: rgba(254, 242, 242, 0.5) !important;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .validation_message,
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_validation_message {
	margin: var(--tds-space-xs) 0 0 !important;
	padding: 0 !important;
	background: none !important;
	border: none !important;
	color: #dc2626 !important;
	font-size: var(--tds-text-xs) !important;
	font-weight: 600;
}

/* ── Confirmation message (on success) ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_confirmation_wrapper {
	padding: var(--tds-space-xl) !important;
	background-color: rgba(39, 214, 255, 0.06) !important;
	border: 1px solid rgba(39, 214, 255, 0.28) !important;
	border-radius: var(--tds-radius-md) !important;
	text-align: center;
}

body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_confirmation_message {
	color: var(--tds-dark-navy) !important;
	font-size: var(--tds-text-md);
	font-weight: 600;
	line-height: 1.65;
}

/* ── Spinner / progress ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gform_ajax_spinner {
	display: inline-block;
	margin-left: var(--tds-space-sm);
	vertical-align: middle;
}

/* ── Description text below fields ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfield_description {
	margin: var(--tds-space-xs) 0 0;
	color: #718096;
	font-size: var(--tds-text-xs);
	line-height: 1.5;
}

/* ── Remove GF's own bottom margin from last field ── */
body.page-template-page-truck-dispatch-services-php .tds-lf__form-wrap .gfields > .gfield:last-of-type {
	margin-bottom: 0;
}