/**
 * ICP Landing Pages — shared styles
 * Used by: ppc-management-b2b-saas, ppc-management-ecommerce,
 *           google-ads-management-agency, linkedin-ads-management,
 *           free-ppc-audit, ppc-management-healthcare
 *
 * Inherits design tokens + base from home-base.css + home-v6.css
 */

/* ── Design tokens (light theme) ──────────────────────────────────────── */
.dbm-icp,
body.dbm-landing--v6-inner .dbm-icp,
.dbm-landing--v6 .dbm-faq-wrap {
	/* Tokens defined in dbm-type-scale.css; fallbacks for load order safety. */
	font-size: var(--dbm-text-base, 1.25rem);
	--icp-text-sm: var(--dbm-text-sm, 1.0625rem);
	--icp-text-md: var(--dbm-text-base, 1.25rem);
	--icp-text-lg: var(--dbm-text-lg, 1.5rem);
	--icp-step-title: var(--dbm-text-lg, 1.5rem);
	--icp-step-body: var(--dbm-text-md, 1.375rem);
	--icp-violet:  #7c3aed;
	--icp-teal:    #0d9488;
	--icp-sky:     #0284c7;
	--icp-amber:   #d97706;
	--icp-green:   #16a34a;
	--icp-ink:     #0f172a;
	--icp-ink-2:   #475569;
	--icp-ink-3:   #94a3b8;
	--icp-bg:      #ffffff;
	--icp-bg-2:    #f8fafc;
	--icp-bg-3:    #f1f5f9;
	--icp-line:    #e2e8f0;
	--icp-radius:  16px;
	--icp-font:    'Inter', 'Inter Tight', system-ui, sans-serif;
	--icp-mono:    'JetBrains Mono', 'IBM Plex Mono', monospace;
	--icp-serif:   'Instrument Serif', Georgia, serif;
	font-family: var(--icp-font);
	color: var(--icp-ink);
	background: var(--icp-bg);
}

/* ── Layout helpers ──────────────────────────────────────────────────── */
.dbm-icp-wrap {
	max-width: 1160px;
	margin-inline: auto;
	padding-inline: clamp(20px, 5vw, 60px);
}

.dbm-icp-section {
	padding-block: clamp(60px, 8vw, 100px);
}

.dbm-icp-section--muted { background: var(--icp-bg-2); }
.dbm-icp-section--dark  { background: #0f172a; color: #e2e8f0; }

/* ── Hero ──────────────────────────────────────────────────────────────── */
.dbm-icp-hero {
	padding-block: clamp(72px, 10vw, 120px) clamp(48px, 6vw, 72px);
	background: linear-gradient(160deg, #faf5ff 0%, #f0fdfa 50%, #f8fafc 100%);
	border-bottom: 1px solid var(--icp-line);
	position: relative;
	overflow: hidden;
}
.dbm-icp-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 60% 40% at 80% 20%, rgba(124,58,237,.06) 0%, transparent 70%),
		radial-gradient(ellipse 50% 35% at 20% 80%, rgba(13,148,136,.05) 0%, transparent 70%);
	pointer-events: none;
}

.dbm-icp-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--icp-mono);
	font-size: var(--dbm-text-xs, 0.875rem);
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--icp-violet);
	margin-bottom: 16px;
}
.dbm-icp-eyebrow-dot {
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--icp-teal);
	animation: icp-dot-blink 2s ease-in-out infinite;
}
@keyframes icp-dot-blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.dbm-icp-h1 {
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	font-weight: 800;
	line-height: 1.12;
	letter-spacing: -.02em;
	color: var(--icp-ink);
	margin: 0 0 20px;
	max-width: 820px;
}
.dbm-icp-h1 em {
	font-style: normal;
	background: linear-gradient(135deg, var(--icp-violet), var(--icp-teal));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.dbm-icp-sub {
	font-size: clamp(1.0625rem, 1.85vw, 1.25rem);
	line-height: 1.7;
	color: var(--icp-ink-2);
	max-width: 640px;
	margin: 0 0 32px;
}

.dbm-icp-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

/* Buttons — base layout; colors/hovers in dbm-shared-ui.css */
.dbm-icp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 26px;
	border-radius: 10px;
	font-size: var(--dbm-text-btn, 1.0625rem);
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	border: none;
	min-height: 52px;
}

.dbm-icp-hero-trust {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 28px;
	font-size: var(--dbm-text-sm, 1.125rem);
	color: var(--icp-ink-3);
}
.dbm-icp-hero-trust-stars { color: #f59e0b; letter-spacing: 2px; }

/* Proof / results metrics — styled in dbm-shared-ui.css (home-v6 parity) */

/* ── Section labels & headings ───────────────────────────────────────── */
.dbm-icp-label {
	font-family: var(--icp-mono);
	font-size: var(--dbm-text-xs, 0.875rem);
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--icp-teal);
	margin-bottom: 12px;
}
.dbm-icp-h2 {
	font-size: clamp(1.6rem, 3vw, 2.5rem);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -.015em;
	color: var(--icp-ink);
	margin: 0 0 16px;
}
.dbm-icp-h2 em {
	font-style: italic;
	font-family: var(--icp-serif);
	color: var(--icp-violet);
}
.dbm-icp-section--dark .dbm-icp-h2 { color: #f1f5f9; }
.dbm-icp-sec-sub {
	font-size: var(--icp-text-lg);
	line-height: 1.7;
	color: var(--icp-ink-2);
	max-width: 620px;
	margin: 0 0 40px;
}
.dbm-icp-section--dark .dbm-icp-sec-sub { color: #94a3b8; }

/* ── Feature cards ───────────────────────────────────────────────────── */
.dbm-icp-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin-top: 2rem;
}
@media (max-width: 900px) { .dbm-icp-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .dbm-icp-cards { grid-template-columns: 1fr; } }

.dbm-icp-card {
	background: var(--icp-bg);
	border: 1px solid var(--icp-line);
	border-radius: var(--icp-radius);
	padding: 28px 24px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: transform .28s cubic-bezier(.22,1,.36,1), box-shadow .28s ease, border-color .28s;
	position: relative;
	overflow: hidden;
}
.dbm-icp-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--icp-violet), var(--icp-teal));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .3s cubic-bezier(.22,1,.36,1);
}
.dbm-icp-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(0,0,0,.1); border-color: rgba(124,58,237,.2); }
.dbm-icp-card:hover::before { transform: scaleX(1); }

.dbm-icp-card-icon {
	width: 44px; height: 44px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	flex-shrink: 0;
}
.dbm-icp-card-h { font-size: var(--icp-text-lg); font-weight: 700; color: var(--icp-ink); margin: 0; }
.dbm-icp-card-p { font-size: var(--icp-text-md); line-height: 1.68; color: var(--icp-ink-2); margin: 0; flex: 1; }

/* ═══════════════════════════════════════════════════════════════════
   Font normalisation — aligns ICP pages to home-v6 type system:
   Inter · weight 600 · tight tracking (-0.035em on h2, -0.045em on h1)
   Matches .dbm-v6-display / .dbm-sec-h2 computed values on home-v6.
   ═══════════════════════════════════════════════════════════════════ */

/* Base: Inter + weight 600 + tight tracking on every heading */
.dbm-icp .elementor-heading-title,
.dbm-icp-section .elementor-heading-title,
.dbm-icp-wrap .elementor-heading-title,
.dbm-icp-section h1, .dbm-icp-section h2,
.dbm-icp-section h3, .dbm-icp-section h4,
.dbm-icp-section h5, .dbm-icp-section h6,
.dbm-icp-wrap h1, .dbm-icp-wrap h2,
.dbm-icp-wrap h3, .dbm-icp-wrap h4 {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif !important;
	font-weight: 600 !important;
	letter-spacing: -0.035em !important;
}

/* Hero h1 — matches .dbm-v6-display (34.5px max, -0.045em) */
.dbm-icp-hero h1,
.dbm-icp-section h1 {
	font-size: clamp(2.35rem, 5.2vw, 3.45rem) !important;
	line-height: 1.05 !important;
	letter-spacing: -0.045em !important;
}

/* Section h2 — matches .dbm-sec-h2 on home-v6 (27.5px max, -0.035em) */
.dbm-icp-section h2,
.dbm-icp-wrap h2,
.dbm-icp-section .elementor-heading-title[class*="h2"],
.dbm-icp-section .elementor-size-default {
	font-size: clamp(1.75rem, 3.35vw, 2.75rem) !important;
	line-height: 1.12 !important;
	letter-spacing: -0.035em !important;
	color: var(--icp-ink) !important;
}

.dbm-icp-cta.dbm-icp-section h2,
.dbm-icp-cta .dbm-icp-cta-h {
	color: #ffffff !important;
}

/* Feature / card h3 — no color override so dark-bg cards can use their own light text */
.dbm-icp-section h3,
.dbm-icp-wrap h3 {
	font-size: var(--icp-text-lg) !important;
	line-height: 1.35 !important;
	letter-spacing: -0.02em !important;
}

/* Step card typography — readable at all times; emphasis via card/badge only */
.dbm-icp-step h3,
.dbm-icp-step .dbm-icp-step-h,
.dbm-icp-step .dbm-icp-step-title {
	font-size: var(--icp-step-title) !important;
	font-weight: 700 !important;
	letter-spacing: -0.02em !important;
	line-height: 1.3 !important;
	color: var(--icp-ink) !important;
	transition: color 0.35s ease, opacity 0.35s ease;
}
.dbm-icp-step p,
.dbm-icp-step .dbm-icp-step-p,
.dbm-icp-step .dbm-icp-step-desc {
	font-size: var(--icp-step-body) !important;
	line-height: 1.65 !important;
	color: var(--icp-ink-2) !important;
	transition: color 0.35s ease, opacity 0.35s ease;
}
.dbm-icp-step:not(.step-active) h3,
.dbm-icp-step:not(.step-active) .dbm-icp-step-h,
.dbm-icp-step:not(.step-active) .dbm-icp-step-title {
	opacity: 0.55;
}
.dbm-icp-step:not(.step-active) p,
.dbm-icp-step:not(.step-active) .dbm-icp-step-p,
.dbm-icp-step:not(.step-active) .dbm-icp-step-desc {
	opacity: 0.6;
}
.dbm-icp-step.step-active h3,
.dbm-icp-step.step-active .dbm-icp-step-h,
.dbm-icp-step.step-active .dbm-icp-step-title,
.dbm-icp-step.step-active p,
.dbm-icp-step.step-active .dbm-icp-step-p,
.dbm-icp-step.step-active .dbm-icp-step-desc {
	opacity: 1;
}

/* Body paragraphs */
.dbm-icp .elementor-widget-text-editor,
.dbm-icp .elementor-widget-text-editor p,
.dbm-icp-section p:not([class]) {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
	font-size: var(--icp-text-md);
	line-height: 1.72;
	color: var(--icp-ink-2);
}

/* ═══════════════════════════════════════════════════════════════════
   Pro-grade process steps
   Desktop  : 4-column horizontal card grid with connector
   Mobile   : animated vertical timeline
   ═══════════════════════════════════════════════════════════════════ */

/* ── Keyframes ──────────────────────────────────────────────────── */
@keyframes dbm-step-num-in {
	0%   { opacity: 0; transform: scale(0.4) rotate(-15deg); }
	55%  { transform: scale(1.18) rotate(4deg); }
	78%  { transform: scale(0.94) rotate(-1deg); }
	100% { opacity: 1; transform: scale(1) rotate(0deg); }
}
@keyframes dbm-step-badge-pop {
	0%   { transform: scale(0.82); }
	58%  { transform: scale(1.14); }
	82%  { transform: scale(0.95); }
	100% { transform: scale(1); }
}
@keyframes dbm-step-badge-glow {
	0%, 100% { box-shadow: 0 0 0 0 rgba(124,58,237,0), 0 3px 12px rgba(124,58,237,.3); }
	50%       { box-shadow: 0 0 0 7px rgba(124,58,237,.1), 0 5px 22px rgba(124,58,237,.4); }
}
@keyframes dbm-step-signal-v {
	0%   { transform: translateY(0);    opacity: 0; }
	10%  { opacity: 1; }
	90%  { opacity: 1; }
	100% { transform: translateY(100%); opacity: 0; }
}
@keyframes dbm-step-card-in {
	from {
		opacity: 0;
		transform: translateY(28px) scale(0.94);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}
@keyframes dbm-step-fill-shimmer {
	0%   { filter: brightness(1); }
	50%  { filter: brightness(1.12); }
	100% { filter: brightness(1); }
}

/* ─────────────────────────────────────────────
   DESKTOP — sequential activation stepper (≥ 780 px)
   ───────────────────────────────────────────── */
@media (min-width: 780px) {

	/* Grid */
	.dbm-icp-steps {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 24px;
		margin-top: 2.75rem;
		position: relative;
		padding-bottom: 8px;
		--steps-rail-y: 53px; /* aligned to badge vertical centre */
		--steps-rail-left: 0px;
		--steps-rail-width: 0px;
	}

	/* Dashed base connector — sits BEHIND the cards (z-index 0). Cards are
	   opaque white at z-index 2, so this only shows in the gaps between
	   them, reading as dotted links between the numbered steps. */
	.dbm-icp-steps::before {
		content: '';
		position: absolute;
		top: var(--steps-rail-y);
		left: var(--steps-rail-left);
		width: var(--steps-rail-width);
		right: auto;
		height: 2px;
		background-image: repeating-linear-gradient(
			to right,
			#cdcdd4 0, #cdcdd4 5px,
			transparent 5px, transparent 11px
		);
		transform: translateY(-50%);
		z-index: 0;
		opacity: 0;
		transition: opacity 0.4s ease;
	}
	.dbm-icp-steps.steps-started::before {
		opacity: 1;
	}

	/* Progress fill — solid violet "completed" connector. Also behind cards
	   (z-index 1) so it only paints the gaps it has reached. */
	.dbm-icp-steps__fill {
		position: absolute;
		top: var(--steps-rail-y);
		height: 2px;
		transform: translateY(-50%);
		background: linear-gradient(
			90deg,
			#7c3aed 0%,
			#0d9488 45%,
			#0284c7 70%,
			#16a34a 100%
		);
		border-radius: 99px;
		z-index: 1;
		pointer-events: none;
		width: 0;
	}
	.dbm-icp-steps.steps-progressing .dbm-icp-steps__fill {
		animation: dbm-step-fill-shimmer 2.4s ease-in-out infinite;
	}
	.dbm-icp-steps.steps-done .dbm-icp-steps__fill {
		animation: none;
	}

	/* No travelling dot on desktop — line sits behind badge halos */
	.dbm-icp-steps::after {
		display: none;
	}

	/* ── Each step card — entrance + activation ── */
	.dbm-icp-step {
		display: flex;
		flex-direction: column;
		gap: 0;
		padding: 0;
		border-radius: 18px;
		background: #ffffff;
		border: 1px solid #ebebef;
		box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
		overflow: hidden;
		position: relative;
		z-index: 2;
		opacity: 0;
		transform: translateY(28px) scale(0.94);
		will-change: transform, opacity;
		transition:
			border-color 0.45s ease,
			box-shadow   0.45s ease,
			transform    0.45s cubic-bezier(.22,1,.36,1);
	}
	.dbm-icp-step.step-reveal {
		animation: dbm-step-card-in 0.65s cubic-bezier(0.22, 1, 0.36, 1) both;
	}
	.dbm-icp-step:nth-child(1).step-reveal { animation-delay: 0.05s; }
	.dbm-icp-step:nth-child(2).step-reveal { animation-delay: 0.14s; }
	.dbm-icp-step:nth-child(3).step-reveal { animation-delay: 0.23s; }
	.dbm-icp-step:nth-child(4).step-reveal { animation-delay: 0.32s; }
	.dbm-icp-step:nth-child(5).step-reveal { animation-delay: 0.41s; }
	.dbm-icp-step:last-child { border-bottom: none; }

	/* Top accent bar — always in layout (keeps badge y-position stable),
	   hidden until card activates */
	.dbm-icp-step::before {
		content: '';
		display: block;
		height: 4px;
		width: 100%;
		flex-shrink: 0;
		opacity: 0;
		transform: scaleX(0.5);
		transform-origin: left;
		transition:
			opacity   0.32s ease 0.12s,
			transform 0.44s cubic-bezier(.22,1,.36,1) 0.06s;
	}
	.dbm-icp-step:nth-child(1)::before { background: linear-gradient(90deg, #7c3aed, #a855f7); }
	.dbm-icp-step:nth-child(2)::before { background: linear-gradient(90deg, #0d9488, #06b6d4); }
	.dbm-icp-step:nth-child(3)::before { background: linear-gradient(90deg, #0284c7, #38bdf8); }
	.dbm-icp-step:nth-child(4)::before { background: linear-gradient(90deg, #16a34a, #4ade80); }
	.dbm-icp-step:nth-child(5)::before { background: linear-gradient(90deg, #d97706, #fbbf24); }

	/* No pseudo watermark */
	.dbm-icp-step::after { display: none; }

	/* Shared z-index */
	.dbm-icp-step-num,
	.dbm-icp-step-title,
	.dbm-icp-step-desc,
	.dbm-icp-step-time { position: relative; z-index: 1; }

	/* Badge — sits above connector with white halo */
	.dbm-icp-step-num {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 52px;
		height: 52px;
		border-radius: 14px;
		font-size: 1.0625rem;
		font-weight: 800;
		font-family: 'Inter', system-ui, sans-serif;
		color: #a1a1aa;
		background: #f4f4f6;
		box-shadow: 0 0 0 5px #ffffff;
		flex-shrink: 0;
		margin: 22px 22px 16px;
		letter-spacing: -0.02em;
		position: relative;
		z-index: 3;
		transition:
			color      0.4s cubic-bezier(.22,1,.36,1),
			background 0.4s cubic-bezier(.22,1,.36,1),
			box-shadow 0.4s cubic-bezier(.22,1,.36,1),
			transform  0.4s cubic-bezier(.22,1,.36,1);
	}

	/* Text — layout/spacing */
	.dbm-icp-step-h,
	.dbm-icp-step h3,
	.dbm-icp-step-title {
		margin: 0 22px 10px;
		font-family: 'Inter', system-ui, sans-serif;
	}
	.dbm-icp-step-p,
	.dbm-icp-step p,
	.dbm-icp-step-desc {
		margin: 0 22px 22px;
		flex: 1;
		font-family: 'Inter', system-ui, sans-serif;
	}
	.dbm-icp-step-time {
		display: inline-flex;
		align-items: center;
		gap: 5px;
		margin: 14px 20px 20px;
		font-family: 'IBM Plex Mono', ui-monospace, monospace;
		font-size: 10.5px;
		font-weight: 600;
		letter-spacing: .06em;
		text-transform: uppercase;
		color: #c4c4c8;
		background: #f9f9fb;
		border: 1px solid #f0f0f3;
		border-radius: 6px;
		padding: 5px 10px;
		transition:
			color        0.38s ease,
			background   0.38s ease,
			border-color 0.38s ease;
	}

	/* ── ACTIVE state (JS adds .step-active) ── */
	.dbm-icp-step.step-active {
		border-color: #e0e0e6;
		box-shadow:
			0 4px 12px rgba(15, 23, 42, 0.06),
			0 16px 40px rgba(15, 23, 42, 0.08);
	}
	.dbm-icp-step.step-active::before {
		opacity: 1;
		transform: scaleX(1);
	}
	.dbm-icp-step.step-active:hover {
		transform: translateY(-5px);
		border-color: rgba(124,58,237,.22);
		box-shadow:
			0 12px 40px rgba(0,0,0,.10),
			0 0 0 1px rgba(124,58,237,.10);
	}

	/* Badge — active: per-step gradient + pop animation */
	.dbm-icp-step:nth-child(1).step-active .dbm-icp-step-num {
		background: linear-gradient(135deg, #7c3aed, #a855f7);
		color: #fff;
		box-shadow:
			0 0 0 5px #ffffff,
			0 6px 20px rgba(124,58,237,.35);
		animation: dbm-step-badge-pop 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
	}
	.dbm-icp-step:nth-child(2).step-active .dbm-icp-step-num {
		background: linear-gradient(135deg, #0d9488, #06b6d4);
		color: #fff;
		box-shadow: 0 0 0 5px #ffffff, 0 6px 20px rgba(13,148,136,.35);
		animation: dbm-step-badge-pop 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
	}
	.dbm-icp-step:nth-child(3).step-active .dbm-icp-step-num {
		background: linear-gradient(135deg, #0284c7, #38bdf8);
		color: #fff;
		box-shadow: 0 0 0 5px #ffffff, 0 6px 20px rgba(2,132,199,.35);
		animation: dbm-step-badge-pop 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
	}
	.dbm-icp-step:nth-child(4).step-active .dbm-icp-step-num {
		background: linear-gradient(135deg, #16a34a, #4ade80);
		color: #fff;
		box-shadow: 0 0 0 5px #ffffff, 0 6px 20px rgba(22,163,74,.35);
		animation: dbm-step-badge-pop 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
	}
	.dbm-icp-step:nth-child(5).step-active .dbm-icp-step-num {
		background: linear-gradient(135deg, #d97706, #fbbf24);
		color: #fff;
		box-shadow: 0 0 0 5px #ffffff, 0 6px 20px rgba(217,119,6,.35);
		animation: dbm-step-badge-pop 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
	}

	/* Text active colors are handled by the !important block in font-normalization */

	/* Time tags — active: per-step tint */
	.dbm-icp-step:nth-child(1).step-active .dbm-icp-step-time { color: #7c3aed; background: rgba(124,58,237,.06); border-color: rgba(124,58,237,.15); }
	.dbm-icp-step:nth-child(2).step-active .dbm-icp-step-time { color: #0d9488; background: rgba(13,148,136,.06); border-color: rgba(13,148,136,.15); }
	.dbm-icp-step:nth-child(3).step-active .dbm-icp-step-time { color: #0284c7; background: rgba(2,132,199,.06);  border-color: rgba(2,132,199,.15); }
	.dbm-icp-step:nth-child(4).step-active .dbm-icp-step-time { color: #15803d; background: rgba(21,128,61,.06);  border-color: rgba(21,128,61,.15); }
}

/* ─────────────────────────────────────────────
   MOBILE — enhanced vertical timeline (< 780 px)
   ───────────────────────────────────────────── */
@media (max-width: 779px) {

	.dbm-icp-steps {
		display: flex;
		flex-direction: column;
		gap: 0;
		margin-top: 2rem;
		position: relative;
		padding-left: 0;
	}

	/* Vertical gradient rail */
	.dbm-icp-steps::before {
		content: '';
		position: absolute;
		left: 23px;
		top: 60px;
		bottom: 60px;
		width: 2px;
		background: linear-gradient(to bottom, #7c3aed 0%, #0d9488 50%, #16a34a 100%);
		border-radius: 2px;
		transform: scaleY(0);
		transform-origin: top center;
		transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.15s;
	}
	.dbm-icp-steps.is-visible::before { transform: scaleY(1); }

	/* Signal dot */
	.dbm-icp-steps::after {
		content: '';
		position: absolute;
		left: 19px;
		top: 60px;
		width: 10px; height: 10px;
		border-radius: 50%;
		background: radial-gradient(circle, #fff 25%, #a78bfa 100%);
		box-shadow: 0 0 8px rgba(124,58,237,.7);
		opacity: 0;
		pointer-events: none;
	}
	.dbm-icp-steps.is-visible::after {
		animation: dbm-step-signal-v 2.8s cubic-bezier(0.4,0,0.6,1) 0.4s infinite;
	}

	.dbm-icp-step {
		display: grid;
		grid-template-columns: 48px 1fr;
		gap: 18px;
		padding: 24px 0;
		border-bottom: 1px solid var(--icp-line);
		align-items: flex-start;
		opacity: 0;
		transform: translateX(-14px);
		transition: opacity .5s cubic-bezier(.16,1,.3,1), transform .5s cubic-bezier(.16,1,.3,1);
	}
	.dbm-icp-step:last-child { border-bottom: none; }
	.dbm-icp-step:nth-child(1) { transition-delay: 0.05s; }
	.dbm-icp-step:nth-child(2) { transition-delay: 0.22s; }
	.dbm-icp-step:nth-child(3) { transition-delay: 0.39s; }
	.dbm-icp-step:nth-child(4) { transition-delay: 0.56s; }
	.dbm-icp-step.is-visible { opacity: 1; transform: translateX(0); }

	.dbm-icp-step-num {
		width: 48px; height: 48px;
		border-radius: 50%;
		background: linear-gradient(135deg, var(--icp-violet), var(--icp-teal));
		color: #fff;
		font-size: 17px;
		font-weight: 800;
		font-family: 'Inter', system-ui, sans-serif;
		display: flex;
		align-items: center;
		justify-content: center;
		flex-shrink: 0;
		transform: scale(0.45);
		opacity: 0;
		transition: none;
	}
	.dbm-icp-step.is-visible .dbm-icp-step-num {
		animation: dbm-step-num-in .55s cubic-bezier(.34,1.56,.64,1) both,
		           dbm-step-badge-glow 3.2s ease-in-out 0.7s infinite;
	}
	.dbm-icp-step:nth-child(1).is-visible .dbm-icp-step-num { animation-delay: 0.08s, 0.8s; }
	.dbm-icp-step:nth-child(2).is-visible .dbm-icp-step-num { animation-delay: 0.25s, 0.97s; }
	.dbm-icp-step:nth-child(3).is-visible .dbm-icp-step-num { animation-delay: 0.42s, 1.14s; }
	.dbm-icp-step:nth-child(4).is-visible .dbm-icp-step-num { animation-delay: 0.59s, 1.31s; }

	.dbm-icp-step-title {
		font-size: var(--icp-step-title);
		font-weight: 700;
		font-family: 'Inter', system-ui, sans-serif;
		color: var(--icp-ink);
		margin: 0 0 6px;
		letter-spacing: -0.01em;
	}
	.dbm-icp-step-desc {
		font-size: var(--icp-step-body);
		line-height: 1.65;
		font-family: 'Inter', system-ui, sans-serif;
		color: var(--icp-ink-2);
		margin: 0;
	}
	.dbm-icp-step-time {
		display: inline-block;
		margin-top: 8px;
		font-family: 'JetBrains Mono', 'IBM Plex Mono', monospace;
		font-size: 10.5px;
		font-weight: 600;
		color: var(--icp-teal);
		background: rgba(13,148,136,.08);
		border-radius: 99px;
		padding: 3px 10px;
		letter-spacing: .05em;
		text-transform: uppercase;
	}
}

/* ─────────────────────────────────────────────
   Reduced motion — show everything immediately
   ───────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
	.dbm-icp-steps::after        { display: none !important; }
	.dbm-icp-steps__fill         { display: none !important; }
	.dbm-icp-step                { opacity: 1 !important; transition: none !important; animation: none !important; transform: none !important; }
	.dbm-icp-step::before        { opacity: 1 !important; transform: scaleX(1) !important; transition: none !important; }
	.dbm-icp-step-num            { transition: none !important; animation: none !important; }
	/* JS handles .step-active for these states */
}

/* ── Mini comparison ────────────────────────────────────────────────── */
.dbm-icp-compare {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin-top: 2rem;
}
@media (max-width: 640px) { .dbm-icp-compare { grid-template-columns: 1fr; } }

.dbm-icp-compare-col {
	border-radius: var(--icp-radius);
	padding: 28px 24px;
}
.dbm-icp-compare-col--agency {
	background: var(--icp-bg-2);
	border: 1px solid var(--icp-line);
}
.dbm-icp-compare-col--dbm {
	background: linear-gradient(145deg, rgba(124,58,237,.06), rgba(13,148,136,.06));
	border: 1.5px solid rgba(124,58,237,.25);
	box-shadow: 0 8px 32px rgba(124,58,237,.08);
}
.dbm-icp-compare-head {
	font-size: var(--dbm-text-sm, 1.125rem);
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	margin: 0 0 16px;
}
.dbm-icp-compare-col--agency .dbm-icp-compare-head { color: var(--icp-ink-3); }
.dbm-icp-compare-col--dbm .dbm-icp-compare-head { color: var(--icp-violet); }
.dbm-icp-compare-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.dbm-icp-compare-list li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: var(--dbm-text-base, 1.3125rem);
	line-height: var(--dbm-line-body, 1.65);
	color: var(--icp-ink-2);
}
.dbm-icp-compare-list li::before {
	content: '✕';
	font-size: 12px;
	font-weight: 800;
	color: #f87171;
	background: rgba(248,113,113,.12);
	border-radius: 50%;
	width: 20px; height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-top: 1px;
}
.dbm-icp-compare-col--dbm .dbm-icp-compare-list li { color: #1e293b; }
.dbm-icp-compare-col--dbm .dbm-icp-compare-list li::before {
	content: '✓';
	color: var(--icp-teal);
	background: rgba(13,148,136,.12);
}

/* ── FAQ accordion ───────────────────────────────────────────────────── */
/* Specificity override — .dbm-icp-section h3 (17px !important) must be beaten */
.dbm-icp-section .dbm-icp-faq-q,
.dbm-icp-wrap .dbm-icp-faq-q {
	font-size: var(--dbm-text-md, 1.4375rem) !important;
	line-height: var(--dbm-line-body, 1.65) !important;
	font-weight: 600 !important;
}
.dbm-icp-faq {
	display: flex;
	flex-direction: column;
	border-top: 1px solid var(--icp-line);
}
.dbm-icp-faq-item {
	border-bottom: 1px solid var(--icp-line);
}
.dbm-icp-faq-q {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 24px 0;
	font-size: var(--dbm-text-md, 1.4375rem) !important;
	font-weight: 600 !important;
	line-height: var(--dbm-line-body, 1.65) !important;
	color: var(--icp-ink);
	margin: 0;
	cursor: pointer;
	user-select: none;
	transition: color 0.2s ease;
}
/* Native button element — accessible accordion trigger */
button.dbm-icp-faq-q {
	width: 100%;
	text-align: left;
	background: none;
	border: none;
	font: inherit;
	letter-spacing: inherit;
}
.dbm-icp-faq-q:hover { color: var(--icp-violet); }

/* Chevron indicator */
.dbm-icp-faq-q::after {
	content: '';
	display: block;
	width: 8px; height: 8px;
	border-right: 2px solid var(--icp-ink-3);
	border-bottom: 2px solid var(--icp-ink-3);
	transform: rotate(45deg) translateY(-2px);
	flex-shrink: 0;
	transition: transform 0.28s cubic-bezier(.22,1,.36,1),
	            border-color 0.2s ease;
}
.dbm-icp-faq-q:hover::after { border-color: var(--icp-violet); }
.dbm-icp-faq-item.faq-open .dbm-icp-faq-q {
	color: var(--icp-violet);
}
.dbm-icp-faq-item.faq-open .dbm-icp-faq-q::after {
	transform: rotate(-135deg) translateY(-2px);
	border-color: var(--icp-violet);
}

/* Answer — animates open via max-height */
.dbm-icp-faq-a {
	font-size: var(--dbm-text-base, 1.3125rem) !important;
	line-height: var(--dbm-line-body, 1.65) !important;
	color: var(--icp-ink-2);
	margin: 0;
	max-height: 0;
	overflow: hidden;
	padding-bottom: 0;
	transition:
		max-height 0.38s cubic-bezier(0.4, 0, 0.2, 1),
		padding-bottom 0.28s ease;
}
.dbm-icp-faq-item.faq-open .dbm-icp-faq-a {
	max-height: 600px;
	padding-bottom: 22px;
}

/* ── FAQs hub: hero jump links + wrapped CTAs ─────────────────────── */
.dbm-brand-doc--faqs .dbm-icp-hero .dbm-icp-actions {
	flex-wrap: wrap;
	gap: 12px;
}
.dbm-icp-jump-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 28px;
}
.dbm-icp-jump-nav .dbm-btn {
	font-size: 13px;
	padding: 8px 14px;
}
.dbm-brand-doc--faqs .dbm-faq-more-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px 18px;
	margin: 0 0 28px;
}
.dbm-brand-doc--faqs .dbm-faq-more-hint {
	font-size: var(--dbm-text-sm, 1.125rem);
	color: var(--icp-ink-3);
}

/* /faqs/ — questionnaire modal (Contact Form 7) */
html.dbm-faq-ask-modal-open {
	overflow: hidden;
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal {
	position: fixed;
	inset: 0;
	z-index: 2147483095;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	grid-template-rows: minmax(0, 1fr);
	place-items: center;
	padding:
		max(20px, env(safe-area-inset-top))
		max(20px, env(safe-area-inset-right))
		max(20px, env(safe-area-inset-bottom))
		max(20px, env(safe-area-inset-left));
	box-sizing: border-box;
	pointer-events: none;
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal[hidden] {
	display: none !important;
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal > * {
	pointer-events: auto;
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal__backdrop {
	grid-area: 1 / 1;
	align-self: stretch;
	justify-self: stretch;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	border: 0;
	cursor: pointer;
	background: rgba(9, 9, 11, 0.55);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal__dialog {
	grid-area: 1 / 1;
	position: relative;
	z-index: 1;
	width: min(520px, calc(100vw - 40px));
	max-height: min(90vh, 720px);
	display: flex;
	flex-direction: column;
	padding: 22px 22px 20px;
	border-radius: 18px;
	border: 1px solid rgba(124, 58, 237, 0.2);
	background: linear-gradient(165deg, rgba(255, 255, 255, 0.99) 0%, rgba(245, 243, 255, 0.97) 52%, rgba(255, 255, 255, 0.99) 100%);
	box-shadow:
		0 0 0 1px rgba(255, 255, 255, 0.65) inset,
		0 28px 70px rgba(15, 23, 42, 0.22);
	box-sizing: border-box;
	animation: dbm-faq-ask-modal-in 0.28s ease both;
}
@keyframes dbm-faq-ask-modal-in {
	from {
		opacity: 0;
		transform: translateY(12px) scale(0.985);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}
@media (prefers-reduced-motion: reduce) {
	.dbm-brand-doc--faqs .dbm-faq-ask-modal__dialog {
		animation: none;
	}
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal__close {
	position: absolute;
	top: 14px;
	right: 14px;
	z-index: 2;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0;
	border: 0;
	border-radius: 10px;
	cursor: pointer;
	font-size: 24px;
	line-height: 1;
	color: var(--icp-ink-2, #475569);
	background: rgba(241, 245, 249, 0.9);
	transition: background 0.15s ease, color 0.15s ease;
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal__close:hover {
	background: rgba(226, 232, 240, 0.98);
	color: var(--icp-ink, #0f172a);
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal__scroll {
	flex: 1 1 auto;
	min-height: 0;
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	margin: 0 -4px;
	padding: 4px 12px 8px 4px;
}
.dbm-brand-doc--faqs .dbm-faq-ask-modal__dialog .dbm-faq-ask-card {
	box-shadow: none;
	border-radius: var(--icp-radius, 14px);
	margin: 0;
	width: 100%;
	max-width: none;
	box-sizing: border-box;
	padding: clamp(14px, 3vw, 22px);
}
.dbm-brand-doc--faqs .dbm-faq-more-cards {
	margin-top: 0;
}

/* ── CTA band ────────────────────────────────────────────────────────── */
/* Full-bleed: break out of constrained parents (Elementor widget, theme
   containers, managed-HTML wrappers) so the gradient always reaches the
   viewport edges. Uses 100vw and negative left margin instead of `width:
   100vw + margin-left: calc(50% - 50vw)` because some parents have
   transform/contain that breaks the calc form. */
.dbm-icp-cta {
	background: linear-gradient(135deg, #1e0a3c 0%, #0f172a 50%, #012e2b 100%);
	color: #fff;
	text-align: center;
	position: relative;
	overflow: hidden;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	width: 100vw;
	max-width: 100vw;
	padding-inline: clamp(20px, 5vw, 60px);
	box-sizing: border-box;
}
.dbm-icp-cta::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 70% 60% at 50% 50%, rgba(124,58,237,.25) 0%, transparent 70%);
	pointer-events: none;
}
.dbm-icp-cta-inner { position: relative; max-width: 700px; margin-inline: auto; text-align: center; }
.dbm-icp-cta-eyebrow {
	font-family: var(--icp-mono);
	font-size: var(--dbm-text-xs, 1rem);
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: #5eead4;
	margin-bottom: 16px;
}
.dbm-icp-cta-h {
	font-size: clamp(1.8rem, 3.5vw, 3rem);
	font-weight: 800;
	line-height: 1.15;
	color: #fff;
	margin: 0 0 16px;
}
.dbm-icp-cta-sub {
	font-size: 1.0625rem;
	line-height: 1.65;
	color: #94a3b8;
	margin: 0 0 32px;
}
.dbm-icp-cta-note {
	margin-top: 16px;
	font-size: var(--dbm-text-sm, 1.125rem);
	color: #64748b;
}

/* ── Breadcrumb ─────────────────────────────────────────────────────── */
.dbm-icp-breadcrumb {
	font-size: var(--dbm-text-sm, 1.125rem);
	color: var(--icp-ink-3);
	margin-bottom: 20px;
}
.dbm-icp-breadcrumb a { color: var(--icp-ink-3); text-decoration: none; }
.dbm-icp-breadcrumb a:hover { color: var(--icp-violet); }
.dbm-icp-breadcrumb span { margin-inline: 6px; }

/* Results grid — layout/metrics in dbm-shared-ui.css */
.dbm-icp-result-tag {
	display: inline-block;
	margin-top: 12px;
	font-family: var(--icp-mono);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: .08em;
	color: var(--icp-teal);
	background: rgba(13,148,136,.08);
	border-radius: 99px;
	padding: 3px 10px;
}

/* ── Reveal animations (mirrors home-v6 reveal) ─────────────────────── */
.dbm-icp .dbm-reveal {
	opacity: 0;
	transform: translate3d(0, 24px, 0) scale(.98);
	transition:
		opacity .55s cubic-bezier(.22,1,.36,1),
		transform .55s cubic-bezier(.22,1,.36,1);
	/* Safety net: if reveal.js never runs, fade in after 1.2s instead of staying invisible. */
	animation: dbm-icp-reveal-fallback 0.55s cubic-bezier(.22,1,.36,1) 1.2s forwards;
}
.dbm-icp .dbm-reveal.is-visible {
	opacity: 1;
	transform: translate3d(0,0,0) scale(1);
	animation: none;
}
@keyframes dbm-icp-reveal-fallback {
	to { opacity: 1; transform: translate3d(0,0,0) scale(1); }
}

/* ── Responsive tweaks ───────────────────────────────────────────────── */
@media (max-width: 640px) {
	.dbm-icp-h1 { font-size: 1.9rem; }
	.dbm-icp-step { grid-template-columns: 40px 1fr; gap: 14px; }
	.dbm-icp-step-num { width: 40px; height: 40px; font-size: 16px; }
	.dbm-icp-steps::before { left: 19px; }
	.dbm-icp-steps::after  { left: 15px; }
}

/* ── Brand pages (Company / About / Contact) inside ICP shell ───────────── */
.dbm-icp.dbm-brand-doc--company,
.dbm-icp.dbm-brand-doc--contact {
	background: var(--icp-bg);
}

/* ── Breadcrumb bar (all brand pages) ──────────────────────────────────── */
/* ── Duplicate-breadcrumb suppression ─────────────────────────────────────
   Some legacy ICP landing pages (free-ppc-audit, google-ads-management-agency,
   linkedin-ads-management, ppc-management-b2b-saas / -ecommerce / -healthcare)
   have an inline `<nav class="dbm-icp-breadcrumb">` baked into their Elementor
   data — this would render as a second, smaller breadcrumb beneath the global
   one. The global breadcrumb uses `<nav class="dbm-icp-breadcrumb-wrap">` for
   its container element (the inner `<ol>` carries `.dbm-icp-breadcrumb`), so
   targeting `nav.dbm-icp-breadcrumb` only hides the duplicate.
   ─────────────────────────────────────────────────────────────────────── */
nav.dbm-icp-breadcrumb { display: none !important; }

.dbm-icp-breadcrumb-wrap {
	background: var(--icp-bg);
	border-bottom: 1px solid var(--icp-line);
}
.dbm-icp-breadcrumb-wrap .dbm-icp-wrap {
	padding-block: 14px 14px;
}
.dbm-icp-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
	font-family: var(--icp-mono);
	font-size: var(--dbm-text-xs, 0.875rem);
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--icp-ink-3);
	text-align: center;
}
.dbm-icp-breadcrumb li { margin: 0; }
.dbm-icp-breadcrumb a {
	color: var(--icp-ink-2);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: color 0.15s ease, border-color 0.15s ease;
}
.dbm-icp-breadcrumb a:hover {
	color: var(--icp-violet);
	border-bottom-color: rgba(124, 58, 237, 0.4);
}
.dbm-icp-breadcrumb-sep {
	color: var(--icp-ink-3);
	user-select: none;
}
.dbm-icp-breadcrumb-current {
	color: var(--icp-ink);
}
body.dbm-landing--v6-inner .dbm-icp-breadcrumb a,
body.dbm-landing--v6-inner .dbm-icp-breadcrumb { font-size: var(--dbm-text-xs) !important; }

/* ── Contact page: split hero + inline contact form ──────────────────── */
/* Tighten the whole hero vertical rhythm vs. the standard ICP hero,
   so the form column never extends past the copy column. */
.dbm-icp .dbm-icp-hero--split {
	padding-block: clamp(36px, 5vw, 56px) clamp(32px, 4vw, 48px);
	position: relative;
	overflow: hidden;
	isolation: isolate;
}
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-copy .dbm-icp-eyebrow { margin-bottom: 12px; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-copy .dbm-icp-h1 { margin-bottom: 14px; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-copy .dbm-icp-sub { margin-bottom: 22px; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-bullets { margin: 0 0 22px; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-actions { margin-bottom: 18px; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-trust { margin: 0; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-meta { margin-top: 20px; padding-top: 18px; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-meta-grid { gap: 14px; }
.dbm-icp .dbm-icp-hero--split .dbm-icp-hero-press { margin-top: 16px; }
/* Subtle radial mesh behind the hero — depth without noise */
.dbm-icp .dbm-icp-hero--split::before,
.dbm-icp .dbm-icp-hero--split::after {
	content: '';
	position: absolute;
	z-index: -1;
	pointer-events: none;
	border-radius: 50%;
	filter: blur(60px);
	opacity: 0.55;
}
.dbm-icp .dbm-icp-hero--split::before {
	width: 520px;
	height: 520px;
	left: -180px;
	top: -120px;
	background: radial-gradient(closest-side, rgba(124, 58, 237, 0.22), transparent 70%);
}
.dbm-icp .dbm-icp-hero--split::after {
	width: 560px;
	height: 560px;
	right: -200px;
	bottom: -160px;
	background: radial-gradient(closest-side, rgba(20, 184, 166, 0.18), transparent 70%);
}
.dbm-icp .dbm-icp-hero-split {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	gap: clamp(32px, 5vw, 64px);
	align-items: start;
}
@media (max-width: 960px) {
	.dbm-icp .dbm-icp-hero-split { grid-template-columns: 1fr; gap: 36px; }
}
/* Free PPC audit: single split hero — copy + form above the fold */
.dbm-icp .dbm-icp-hero--audit .dbm-icp-hero-split {
	align-items: center;
}
.dbm-icp .dbm-icp-hero--audit .dbm-icp-hero-copy .dbm-icp-h1 em {
	font-style: normal;
	background: linear-gradient(135deg, var(--icp-violet), var(--icp-teal));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.dbm-icp .dbm-icp-hero--audit .dbm-icp-hero-meta {
	margin-top: 20px;
	padding-top: 18px;
}
@media (max-width: 960px) {
	.dbm-icp .dbm-icp-hero--audit .dbm-icp-hero-meta-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}
.dbm-icp .dbm-icp-hero-copy .dbm-icp-h1 {
	margin: 12px 0 14px;
}
.dbm-icp .dbm-icp-hero-bullets {
	list-style: none;
	margin: 22px 0 28px;
	padding: 0;
	display: grid;
	gap: 10px;
	font-size: var(--dbm-text-sm);
	line-height: var(--dbm-line-body);
	color: var(--icp-ink-2);
	max-width: 540px;
}
.dbm-icp .dbm-icp-hero-bullets li {
	position: relative;
	padding-left: 22px;
}
.dbm-icp .dbm-icp-hero-bullets li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.3em;
	width: 18px;
	height: 18px;
	border-radius: 6px;
	background:
		linear-gradient(135deg, var(--icp-violet), var(--icp-teal));
	box-shadow: 0 4px 10px -4px rgba(124, 58, 237, 0.35);
}
.dbm-icp .dbm-icp-hero-bullets li::after {
	content: '';
	position: absolute;
	left: 5px;
	top: 0.6em;
	width: 8px;
	height: 4px;
	border-left: 2px solid #fff;
	border-bottom: 2px solid #fff;
	transform: rotate(-45deg);
}
.dbm-icp .dbm-icp-hero-bullets li {
	padding-left: 30px;
}
.dbm-icp .dbm-icp-hero-meta {
	margin-top: 26px;
	padding-top: 22px;
	border-top: 1px solid var(--icp-line);
	max-width: 560px;
}
.dbm-icp .dbm-icp-hero-meta-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	margin: 0;
}
@media (max-width: 540px) {
	.dbm-icp .dbm-icp-hero-meta-grid { grid-template-columns: 1fr 1fr; }
}
.dbm-icp .dbm-icp-hero-meta-cell { margin: 0; }
.dbm-icp .dbm-icp-hero-meta-cell dt {
	margin: 0 0 4px;
	font-family: var(--icp-mono);
	font-size: 10.5px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--icp-ink-3);
}
.dbm-icp .dbm-icp-hero-meta-cell dd {
	margin: 0;
	font-size: var(--dbm-text-sm);
	font-weight: 600;
	line-height: 1.35;
	color: var(--icp-ink);
}
.dbm-icp .dbm-icp-hero-press {
	margin: 22px 0 0;
	font-size: var(--dbm-text-xs);
	color: var(--icp-ink-3);
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.dbm-icp .dbm-icp-hero-press span { color: var(--icp-violet); }
.dbm-icp .dbm-icp-hero-press a {
	color: var(--icp-ink-2);
	font-weight: 600;
	border-bottom: 1px solid rgba(124, 58, 237, 0.25);
	transition: color 0.15s ease, border-color 0.15s ease;
}
.dbm-icp .dbm-icp-hero-press a:hover {
	color: var(--icp-violet);
	border-bottom-color: var(--icp-violet);
}
.dbm-icp .dbm-icp-hero-form {
	position: relative;
}
@media (min-width: 961px) {
	.dbm-icp .dbm-icp-hero-form { position: sticky; top: 24px; }
}

/* ── CF7 form skinning (mirrors the previous inline-form styles) ────── */
.dbm-icp .dbm-icp-cf7 .wpcf7 { margin: 0; padding: 0; }
.dbm-icp .dbm-icp-cf7 form.wpcf7-form {
	display: grid;
	gap: 10px;
}
/* Kill ALL nested <p> margins CF7 autop adds (including inside .dbm-cf7-row + .dbm-cf7-actions). */
.dbm-icp .dbm-icp-cf7 form.wpcf7-form p { margin: 0; }
.dbm-icp .dbm-icp-cf7 form.wpcf7-form br { display: none; }
/* Submit row sits flush — no margin/padding from autop wrappers. */
.dbm-icp .dbm-icp-cf7 .dbm-cf7-actions { margin: 0; }
.dbm-icp .dbm-icp-cf7 .dbm-cf7-actions > p { margin: 0; }
.dbm-icp .dbm-icp-cf7 .dbm-cf7-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
@media (max-width: 560px) {
	.dbm-icp .dbm-icp-cf7 .dbm-cf7-row { grid-template-columns: 1fr; }
}
.dbm-icp .dbm-icp-cf7 .dbm-cf7-label,
.dbm-icp .dbm-icp-cf7 form.wpcf7-form label {
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--icp-ink-2);
	line-height: 1.3;
}
.dbm-icp .dbm-icp-cf7 .wpcf7-form-control-wrap { display: block; }
.dbm-icp .dbm-icp-cf7 input.wpcf7-form-control,
.dbm-icp .dbm-icp-cf7 textarea.wpcf7-form-control,
.dbm-icp .dbm-icp-cf7 select.wpcf7-form-control {
	width: 100%;
	padding: 10px 12px;
	font: inherit;
	font-size: var(--dbm-text-sm);
	font-weight: 400;
	letter-spacing: 0;
	text-transform: none;
	color: var(--icp-ink);
	background: #fff;
	border: 1.5px solid var(--icp-line);
	border-radius: 8px;
	box-shadow: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	-webkit-appearance: none;
	appearance: none;
}
.dbm-icp .dbm-icp-cf7 select.wpcf7-form-control {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237c3aed' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 14px;
	padding-right: 40px;
	cursor: pointer;
}
.dbm-icp .dbm-icp-cf7 input.wpcf7-form-control:hover,
.dbm-icp .dbm-icp-cf7 textarea.wpcf7-form-control:hover,
.dbm-icp .dbm-icp-cf7 select.wpcf7-form-control:hover {
	border-color: rgba(124, 58, 237, 0.35);
}
.dbm-icp .dbm-icp-cf7 input.wpcf7-form-control:focus,
.dbm-icp .dbm-icp-cf7 textarea.wpcf7-form-control:focus,
.dbm-icp .dbm-icp-cf7 select.wpcf7-form-control:focus {
	outline: none;
	border-color: var(--icp-violet);
	box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.12);
}
.dbm-icp .dbm-icp-cf7 textarea.wpcf7-form-control {
	min-height: 72px;
	resize: vertical;
	line-height: 1.45;
}
/* Checkbox list — compact pill chips that fit all 6 in one row */
.dbm-icp .dbm-icp-cf7 .wpcf7-checkbox {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin-top: 2px;
}
.dbm-icp .dbm-icp-cf7 .wpcf7-checkbox .wpcf7-list-item {
	margin: 0;
	display: inline-flex;
}
.dbm-icp .dbm-icp-cf7 .wpcf7-checkbox .wpcf7-list-item label {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 8px;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--icp-ink-2);
	background: #fff;
	border: 1.5px solid var(--icp-line);
	border-radius: 999px;
	cursor: pointer;
	transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
	line-height: 1.1;
	white-space: nowrap;
}
.dbm-icp .dbm-icp-cf7 .wpcf7-checkbox .wpcf7-list-item label:hover {
	border-color: rgba(124, 58, 237, 0.45);
	color: var(--icp-violet);
}
.dbm-icp .dbm-icp-cf7 .wpcf7-checkbox .wpcf7-list-item:has(input:checked) label {
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.10), rgba(20, 184, 166, 0.10));
	border-color: var(--icp-violet);
	color: var(--icp-violet);
}
.dbm-icp .dbm-icp-cf7 .wpcf7-checkbox input[type="checkbox"] {
	accent-color: var(--icp-violet);
	width: 12px;
	height: 12px;
	margin: 0;
}
/* Submit + helper note */
.dbm-icp .dbm-icp-cf7 .dbm-cf7-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-top: 4px;
}
.dbm-icp .dbm-icp-cf7 input.wpcf7-form-control.wpcf7-submit,
.dbm-icp .dbm-icp-cf7 input[type="submit"].dbm-btn {
	-webkit-appearance: none;
	appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
	padding: 12px 24px;
	font-family: inherit;
	font-size: var(--dbm-text-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: none;
	color: #fff;
	background:
		linear-gradient(135deg, #7c3aed 0%, #6d28d9 45%, #0d9488 100%);
	background-size: 200% 100%;
	background-position: 0% 50%;
	border: none;
	border-radius: 10px;
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-position 0.4s ease;
	box-shadow:
		0 10px 24px -10px rgba(124, 58, 237, 0.55),
		inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.dbm-icp .dbm-icp-cf7 input.wpcf7-form-control.wpcf7-submit:hover {
	transform: translateY(-1px);
	background-position: 100% 50%;
	box-shadow:
		0 16px 32px -12px rgba(124, 58, 237, 0.7),
		inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.dbm-icp .dbm-icp-cf7 input.wpcf7-form-control.wpcf7-submit:focus {
	outline: 2px solid var(--icp-violet);
	outline-offset: 3px;
}
.dbm-icp .dbm-icp-cf7 .dbm-cf7-note {
	font-size: var(--dbm-text-xs);
	color: var(--icp-ink-3);
}
/* CF7 inline + global validation messaging */
.dbm-icp .dbm-icp-cf7 .wpcf7-not-valid-tip {
	display: block;
	margin-top: 6px;
	font-size: var(--dbm-text-xs);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #b91c1c;
}
.dbm-icp .dbm-icp-cf7 input.wpcf7-not-valid,
.dbm-icp .dbm-icp-cf7 textarea.wpcf7-not-valid,
.dbm-icp .dbm-icp-cf7 select.wpcf7-not-valid {
	border-color: #fca5a5;
	box-shadow: 0 0 0 4px rgba(248, 113, 113, 0.12);
}
.dbm-icp .dbm-icp-cf7 .wpcf7 form .wpcf7-response-output {
	margin: 16px 0 0;
	padding: 12px 14px;
	font-size: var(--dbm-text-sm);
	line-height: var(--dbm-line-body);
	border-radius: 10px;
	border: 1px solid var(--icp-line);
	background: #f8fafc;
	color: var(--icp-ink);
}
.dbm-icp .dbm-icp-cf7 .wpcf7 form.invalid .wpcf7-response-output,
.dbm-icp .dbm-icp-cf7 .wpcf7 form.unaccepted .wpcf7-response-output,
.dbm-icp .dbm-icp-cf7 .wpcf7 form.payment-required .wpcf7-response-output {
	background: #fef2f2;
	border-color: #fecaca;
	color: #b91c1c;
}
.dbm-icp .dbm-icp-cf7 .wpcf7 form.sent .wpcf7-response-output {
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.08), rgba(20, 184, 166, 0.08));
	border-color: rgba(124, 58, 237, 0.25);
	color: var(--icp-ink);
}
.dbm-icp .dbm-icp-cf7 .wpcf7-spinner {
	background-color: var(--icp-violet);
}
/* Hide the floating reCAPTCHA badge on this page if you'd rather show the disclaimer inline */
.dbm-icp .dbm-icp-cf7 .grecaptcha-badge { box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08) !important; }
.dbm-icp .dbm-icp-contact-form-card-eyebrow {
	margin: 0 0 6px;
	font-family: var(--icp-mono);
	font-size: var(--dbm-text-xs);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--icp-violet);
}
.dbm-icp .dbm-icp-contact-form-card-h {
	margin: 0 0 4px;
	font-size: clamp(1.25rem, 1.9vw, 1.5rem);
	line-height: 1.25;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--icp-ink);
}
.dbm-icp .dbm-icp-contact-form-card-sub {
	margin: 0 0 12px;
	font-size: var(--dbm-text-xs);
	color: var(--icp-ink-2);
	line-height: 1.5;
}
.dbm-icp .dbm-icp-contact-form-card {
	position: relative;
	background: #fff;
	border: 1px solid var(--icp-line);
	border-radius: 16px;
	padding: clamp(18px, 2vw, 22px) clamp(16px, 1.8vw, 22px) clamp(14px, 1.6vw, 18px);
	box-shadow:
		0 1px 0 rgba(15, 23, 42, 0.03),
		0 30px 80px -36px rgba(91, 33, 182, 0.18),
		0 8px 20px -14px rgba(15, 23, 42, 0.08);
	overflow: hidden;
}
.dbm-icp .dbm-icp-contact-form-card-bar {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--icp-violet) 0%, #c084fc 35%, var(--icp-teal) 100%);
}
.dbm-icp .dbm-icp-contact-form-status {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 5px 11px 5px 9px;
	margin: 0 0 12px;
	font-family: var(--icp-mono);
	font-size: 10.5px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #047857;
	background: rgba(16, 185, 129, 0.08);
	border: 1px solid rgba(16, 185, 129, 0.25);
	border-radius: 999px;
}
.dbm-icp .dbm-icp-contact-form-status-dot {
	position: relative;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #10b981;
	box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.18);
}
.dbm-icp .dbm-icp-contact-form-status-dot::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: rgba(16, 185, 129, 0.55);
	animation: dbm-icp-status-pulse 1.8s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
.dbm-icp .dbm-icp-contact-form-status-sep { opacity: 0.45; }
.dbm-icp .dbm-icp-contact-form-status-meta { color: #065f46; opacity: 0.8; }
@keyframes dbm-icp-status-pulse {
	0%   { transform: scale(1);   opacity: 0.7; }
	70%  { transform: scale(2.4); opacity: 0; }
	100% { transform: scale(2.4); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
	.dbm-icp .dbm-icp-contact-form-status-dot::before { animation: none; }
}
/* Alt-CTA below submit (opens the FAB modal) */
.dbm-icp .dbm-icp-contact-form-altcta {
	margin-top: 10px;
	padding-top: 10px;
	border-top: 1px dashed var(--icp-line);
	text-align: center;
	font-size: var(--dbm-text-xs);
	color: var(--icp-ink-3);
}
.dbm-icp .dbm-icp-contact-form-altcta span {
	margin-right: 4px;
	color: var(--icp-ink-3);
}
.dbm-icp .dbm-icp-contact-form-altcta a {
	color: var(--icp-violet);
	font-weight: 600;
	border-bottom: 1px solid rgba(124, 58, 237, 0.3);
	transition: color 0.15s ease, border-color 0.15s ease;
}
.dbm-icp .dbm-icp-contact-form-altcta a::after {
	content: ' →';
	transition: transform 0.15s ease;
	display: inline-block;
}
.dbm-icp .dbm-icp-contact-form-altcta a:hover {
	color: var(--icp-teal);
	border-bottom-color: var(--icp-teal);
}
.dbm-icp .dbm-icp-contact-form-altcta a:hover::after {
	transform: translateX(3px);
}
.dbm-icp .dbm-icp-contact-form {
	display: block;
}
.dbm-icp .dbm-icp-contact-form .dbm-v6-agent-step {
	display: grid;
	gap: 16px;
}
.dbm-icp .dbm-icp-contact-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}
@media (max-width: 560px) {
	.dbm-icp .dbm-icp-contact-form-row { grid-template-columns: 1fr; }
}
.dbm-icp .dbm-icp-contact-form .dbm-v6-agent-label {
	display: flex;
	flex-direction: column;
	gap: 6px;
	font-size: var(--dbm-text-xs);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--icp-ink-2);
}
.dbm-icp .dbm-icp-contact-form-req {
	color: var(--icp-violet);
	margin-left: 2px;
}
.dbm-icp .dbm-icp-contact-form .dbm-v6-agent-input {
	width: 100%;
	padding: 12px 14px;
	font: inherit;
	font-size: var(--dbm-text-base);
	font-weight: 400;
	letter-spacing: 0;
	text-transform: none;
	color: var(--icp-ink);
	background: #fff;
	border: 1.5px solid var(--icp-line);
	border-radius: 10px;
	box-shadow: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.dbm-icp .dbm-icp-contact-form .dbm-v6-agent-input:hover {
	border-color: rgba(124, 58, 237, 0.35);
}
.dbm-icp .dbm-icp-contact-form .dbm-v6-agent-input:focus {
	outline: none;
	border-color: var(--icp-violet);
	box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.12);
}
.dbm-icp .dbm-icp-contact-form .dbm-v6-agent-ta {
	min-height: 110px;
	resize: vertical;
	line-height: var(--dbm-line-body);
}
.dbm-icp .dbm-icp-contact-form-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 14px;
	margin-top: 4px;
}
.dbm-icp .dbm-icp-contact-form-actions .dbm-btn { min-width: 180px; }
.dbm-icp .dbm-icp-contact-form-note {
	font-size: var(--dbm-text-xs);
	color: var(--icp-ink-3);
}
.dbm-icp .dbm-icp-contact-form-err {
	margin: 12px 0 0;
	padding: 10px 12px;
	font-size: var(--dbm-text-sm);
	color: #b91c1c;
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 8px;
}
.dbm-icp .dbm-icp-contact-form-success {
	padding: 18px 20px;
	border-radius: 12px;
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.08), rgba(20, 184, 166, 0.08));
	border: 1px solid rgba(124, 58, 237, 0.2);
}
.dbm-icp .dbm-icp-contact-form-success .dbm-v6-agent-success-title {
	margin: 0 0 6px;
	font-size: var(--dbm-text-lg);
	font-weight: 600;
	color: var(--icp-ink);
}
.dbm-icp .dbm-icp-contact-form-success .dbm-v6-agent-success-body {
	margin: 0;
	font-size: var(--dbm-text-sm);
	line-height: var(--dbm-line-body);
	color: var(--icp-ink-2);
}

/* Contact: checklist styling */
.dbm-icp.dbm-brand-doc--contact .dbm-icp-checklist {
	list-style: none;
	margin: 24px 0 0;
	padding: 0;
	display: grid;
	gap: 14px;
	max-width: 760px;
}
.dbm-icp.dbm-brand-doc--contact .dbm-icp-checklist li {
	position: relative;
	padding-left: 28px;
	font-size: var(--dbm-text-md);
	line-height: var(--dbm-line-body);
	color: var(--icp-ink-2);
}
.dbm-icp.dbm-brand-doc--contact .dbm-icp-checklist li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 14px;
	height: 14px;
	border-radius: 4px;
	background: linear-gradient(135deg, var(--icp-violet), var(--icp-teal));
}
.dbm-icp.dbm-brand-doc--contact .dbm-icp-checklist li strong {
	color: var(--icp-ink);
}

/* Company/About hero uses pure ICP markup now — no overrides needed. */

.dbm-icp.dbm-brand-doc--company .dbm-brand-doc__main .dbm-icp-section {
	padding-block: clamp(48px, 6vw, 80px);
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta.dbm-icp-cta {
	padding-block: clamp(72px, 9vw, 108px) clamp(56px, 7vw, 84px);
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta .dbm-icp-cta-inner {
	max-width: 760px;
	padding-inline: clamp(20px, 4vw, 40px);
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta .dbm-icp-cta-eyebrow {
	margin-bottom: 14px;
	font-size: var(--dbm-text-xs, 1rem);
	color: #67e8f9;
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta .dbm-icp-cta-h {
	font-size: clamp(2rem, 4vw, 3.15rem);
	margin-bottom: 18px;
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta .dbm-icp-cta-sub {
	max-width: 58ch;
	margin: 0 auto 34px;
	color: #cbd5e1;
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta-actions {
	display: flex !important;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
	margin: 0 auto;
	width: 100%;
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta-actions .dbm-brand-btn {
	min-height: 52px;
	padding-inline: 22px;
}

.dbm-icp.dbm-brand-doc--company .dbm-co-cta .dbm-icp-cta-note {
	margin-top: 18px;
	color: #94a3b8;
}

/* ═══════════════════════════════════════════════════════════════════════
   Services hub & SEM detail — extended card variants + simple 3-step flow.
   These supplement the ICP design system without touching home-v6's
   animated `.dbm-icp-steps` framework module.
   ═══════════════════════════════════════════════════════════════════════ */

/* Card variant: small eyebrow label above the heading */
.dbm-icp .dbm-icp-card-eyebrow {
	font-family: var(--icp-font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--icp-violet, #7c3aed);
	margin: 0;
}

/* Card variant: bullet list inside a card */
.dbm-icp .dbm-icp-card-list {
	list-style: none;
	margin: 4px 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
	font-size: var(--icp-text-sm, 14px);
	color: var(--icp-ink-2, #334155);
	line-height: 1.55;
}
.dbm-icp .dbm-icp-card-list li {
	position: relative;
	padding-left: 22px;
}
.dbm-icp .dbm-icp-card-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 7px;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--icp-violet, #7c3aed), var(--icp-teal, #0d9488));
	box-shadow: inset 0 0 0 3px #fff;
}

/* Card variant: CTA pinned to the bottom of the card */
.dbm-icp .dbm-icp-card-cta {
	margin: 12px 0 0;
}
.dbm-icp .dbm-icp-card-cta .dbm-btn {
	font-size: 14px;
	padding: 10px 16px;
}

/* Card variant: accent (highlighted service) */
.dbm-icp .dbm-icp-card--accent {
	background: linear-gradient(180deg, #fffaf3 0%, #ffffff 100%);
	border-color: rgba(124, 58, 237, .35);
	box-shadow: 0 18px 48px rgba(124, 58, 237, .12);
}
.dbm-icp .dbm-icp-card--accent::before {
	transform: scaleX(1);
}

/* Card variant: metric tile (big number + tagline) */
.dbm-icp .dbm-icp-card--metric .dbm-icp-card-metric {
	font-family: var(--icp-font-display, 'Plus Jakarta Sans', Inter, sans-serif);
	font-size: clamp(40px, 5vw, 56px);
	font-weight: 700;
	letter-spacing: -0.035em;
	line-height: 1;
	background: linear-gradient(135deg, var(--icp-violet, #7c3aed), var(--icp-teal, #0d9488));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	margin: 0;
}

/* Card variants: compare (pos / neg) */
.dbm-icp .dbm-icp-cards--compare {
	grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 720px) {
	.dbm-icp .dbm-icp-cards--compare { grid-template-columns: 1fr; }
}
.dbm-icp .dbm-icp-card--neg {
	background: #fbf7f5;
	border-color: rgba(220, 38, 38, .18);
}
.dbm-icp .dbm-icp-card--neg .dbm-icp-card-eyebrow {
	color: #dc2626;
}
.dbm-icp .dbm-icp-card--neg .dbm-icp-card-list li::before {
	background: #fee2e2;
	box-shadow: inset 0 0 0 3px #fff, inset 0 0 0 7px #ef4444;
}
.dbm-icp .dbm-icp-card--pos {
	background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%);
	border-color: rgba(16, 185, 129, .22);
}
.dbm-icp .dbm-icp-card--pos .dbm-icp-card-eyebrow {
	color: #047857;
}
.dbm-icp .dbm-icp-card--pos .dbm-icp-card-list li::before {
	background: linear-gradient(135deg, #10b981, #0d9488);
	box-shadow: inset 0 0 0 3px #fff;
}

/* Grid variants: services + outcomes default to 3 cols, wider gap */
.dbm-icp .dbm-icp-cards--services,
.dbm-icp .dbm-icp-cards--outcomes {
	gap: 24px;
}
@media (min-width: 1080px) {
	.dbm-icp .dbm-icp-cards--services { grid-template-columns: repeat(3, 1fr); }
	.dbm-icp .dbm-icp-cards--outcomes { grid-template-columns: repeat(4, 1fr); }
}

/* ── Simple process flow (Services hub + SEM page) ────────────────── */
.dbm-icp .dbm-icp-process {
	list-style: none;
	margin: 36px 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
	counter-reset: dbm-icp-proc;
}
.dbm-icp .dbm-icp-process-step {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 22px;
	align-items: flex-start;
	background: #fff;
	border: 1px solid var(--icp-line, #e5e7eb);
	border-radius: 18px;
	padding: 22px 24px;
	box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
	position: relative;
	transition: transform .28s cubic-bezier(.22,1,.36,1), box-shadow .28s ease, border-color .28s;
}
.dbm-icp .dbm-icp-process-step:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 30px rgba(15, 23, 42, .08);
	border-color: rgba(124, 58, 237, .25);
}
.dbm-icp .dbm-icp-process-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 52px;
	height: 52px;
	padding: 0 12px;
	border-radius: 14px;
	background: linear-gradient(135deg, var(--icp-violet, #7c3aed), var(--icp-teal, #0d9488));
	color: #fff;
	font-weight: 700;
	font-size: 18px;
	letter-spacing: .04em;
	box-shadow: 0 8px 20px rgba(124, 58, 237, .25);
}
.dbm-icp .dbm-icp-process-body { display: flex; flex-direction: column; gap: 6px; }
.dbm-icp .dbm-icp-process-h {
	font-size: var(--icp-text-lg, 19px);
	font-weight: 700;
	color: var(--icp-ink, #0f172a);
	margin: 0;
	letter-spacing: -0.02em;
}
.dbm-icp .dbm-icp-process-body p {
	margin: 0;
	color: var(--icp-ink-2, #334155);
	line-height: 1.65;
}

/* On wider screens stretch process steps to three columns */
@media (min-width: 980px) {
	.dbm-icp .dbm-icp-process {
		grid-template-columns: repeat(3, 1fr);
		gap: 20px;
	}
	.dbm-icp .dbm-icp-process-step {
		grid-template-columns: 1fr;
		gap: 14px;
		padding: 24px 22px;
	}
	.dbm-icp .dbm-icp-process-num {
		justify-self: flex-start;
	}
}

/* ── Reduced motion ─────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
	.dbm-icp .dbm-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
	.dbm-icp-card:hover { transform: none; }
	.dbm-icp-btn:hover { transform: none; }
	.dbm-icp-eyebrow-dot { animation: none; }
	.dbm-icp .dbm-icp-process-step:hover { transform: none; box-shadow: 0 1px 2px rgba(15, 23, 42, .04); }
}
