/**
 * DBM shared UI — v6-aligned metrics, buttons, layout rhythm (ICP + inner pages).
 */

/* ═══════════════════════════════════════════════════════════════════
   METRICS — match home-v6 stat strip + proof bar
   ═══════════════════════════════════════════════════════════════════ */

/* Hero / inline stat strip on any v6-inner page */
body.dbm-landing--v6-inner .dbm-stat-strip,
.dbm-icp .dbm-stat-strip {
	margin-top: 12px;
	border-radius: 12px;
	border: 1px solid transparent;
	background:
		linear-gradient(#ffffff, #ffffff) padding-box,
		linear-gradient(120deg, rgba(124, 58, 237, 0.28), rgba(13, 148, 136, 0.28), rgba(2, 132, 199, 0.22)) border-box;
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
	overflow: hidden;
}

body.dbm-landing--v6-inner .dbm-stat-cell,
.dbm-icp .dbm-stat-cell {
	padding: clamp(22px, 3vw, 28px) clamp(16px, 2.5vw, 22px);
}

body.dbm-landing--v6-inner .dbm-stat-cell-v,
.dbm-icp .dbm-stat-cell-v {
	font-family: var(--dbm-font, Inter, system-ui, sans-serif);
	font-size: clamp(1.75rem, 3.2vw, 2.5rem) !important;
	font-weight: 600;
	font-style: normal;
	line-height: 1;
	letter-spacing: -0.03em;
}

body.dbm-landing--v6-inner .dbm-stat-cell-v em,
.dbm-icp .dbm-stat-cell-v em {
	font-style: normal;
	color: #7c3aed;
}

body.dbm-landing--v6-inner .dbm-stat-cell-l,
.dbm-icp .dbm-stat-cell-l {
	margin-top: 10px;
	font-family: var(--dbm-mono, monospace);
	font-size: var(--dbm-text-xs, 0.9375rem) !important;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #71717a;
	line-height: 1.45;
}

/* ICP proof band → home-v6 proof bar */
.dbm-icp-proof {
	background: linear-gradient(115deg, #1e1b4b 0%, #312e81 38%, #134e4a 100%);
	padding-block: clamp(40px, 5vw, 56px);
	padding-inline: clamp(20px, 5vw, 60px);
	border-block: none;
	position: relative;
	overflow: hidden;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	width: 100vw;
	max-width: 100vw;
	box-sizing: border-box;
}
/* Soft inner highlight for visual depth */
.dbm-icp-proof::before {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient(60% 100% at 12% 0%, rgba(124, 58, 237, 0.22), transparent 70%),
		radial-gradient(50% 100% at 92% 100%, rgba(20, 184, 166, 0.18), transparent 70%);
}

.dbm-icp-proof-grid {
	position: relative;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	justify-items: center;
	align-items: start;
	gap: clamp(20px, 4vw, 48px);
	max-width: 1140px;
	margin-inline: auto;
	padding-inline: clamp(20px, 5vw, 60px);
	background: none;
}
@media (max-width: 720px) {
	.dbm-icp-proof-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 28px 20px;
	}
}

.dbm-icp-proof-cell {
	flex: 1 1 140px;
	max-width: 220px;
	padding: 0;
	background: transparent;
	text-align: center;
}

.dbm-icp-proof-num {
	display: block;
	font-family: var(--dbm-font, Inter, system-ui, sans-serif);
	font-size: clamp(1.75rem, 3.2vw, 2.5rem) !important;
	font-weight: 600;
	line-height: 1;
	letter-spacing: -0.03em;
	background: none;
	-webkit-background-clip: unset;
	-webkit-text-fill-color: #ffffff;
	color: #ffffff;
	margin-bottom: 8px;
	transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.dbm-icp-proof-cell:hover .dbm-icp-proof-num {
	transform: scale(1.06);
}

.dbm-icp-proof-lbl {
	font-family: var(--dbm-mono, monospace);
	font-size: var(--dbm-text-base, 1.3125rem) !important;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.78) !important;
	line-height: 1.5;
}

body.dbm-landing--v6-inner .dbm-proof-stat span {
	font-size: var(--dbm-text-xs, 0.9375rem) !important;
}


/* ICP results / outcome cards → stat-strip cells */
.dbm-icp-results-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	margin-top: 2rem;
	border-radius: 12px;
	border: 1px solid transparent;
	background:
		linear-gradient(#ffffff, #ffffff) padding-box,
		linear-gradient(120deg, rgba(124, 58, 237, 0.22), rgba(13, 148, 136, 0.22)) border-box;
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
	overflow: hidden;
}

@media (max-width: 780px) {
	.dbm-icp-results-grid {
		grid-template-columns: 1fr;
	}
}

.dbm-icp-result-card {
	border-radius: 0;
	border: none;
	border-bottom: 1px solid #e4e4e7;
	padding: clamp(24px, 3vw, 32px) clamp(20px, 2.5vw, 28px);
	background: #ffffff;
	box-shadow: none;
}

.dbm-icp-results-grid .dbm-icp-result-card:last-child {
	border-bottom: none;
}

@media (min-width: 781px) {
	.dbm-icp-result-card {
		border-bottom: none;
		border-right: 1px solid #e4e4e7;
	}
	.dbm-icp-results-grid .dbm-icp-result-card:last-child {
		border-right: none;
	}
}

.dbm-icp-result-card:first-child {
	border-color: #e4e4e7;
	box-shadow: none;
}

.dbm-icp-result-stat {
	font-family: var(--dbm-font, Inter, system-ui, sans-serif);
	font-size: clamp(1.75rem, 3vw, 2.35rem) !important;
	font-weight: 600;
	letter-spacing: -0.03em;
	line-height: 1;
	color: #09090b;
	margin-bottom: 8px;
}

.dbm-icp-result-label {
	font-size: var(--dbm-text-md, 1.375rem) !important;
	font-weight: 600;
	line-height: var(--dbm-line-tight, 1.25);
}

.dbm-icp-result-desc {
	font-size: var(--dbm-text-base, 1.25rem) !important;
	line-height: var(--dbm-line-body, 1.65);
}

/* Inner pages: proof bar if used */
body.dbm-landing--v6-inner .dbm-proof-bar {
	background: linear-gradient(115deg, #1e1b4b 0%, #312e81 38%, #134e4a 100%);
	padding-block: clamp(36px, 5vw, 48px);
}

body.dbm-landing--v6-inner .dbm-proof-stat strong {
	font-size: clamp(1.75rem, 3.2vw, 2.5rem) !important;
	font-weight: 600;
	letter-spacing: -0.03em;
}

body.dbm-landing--v6-inner .dbm-proof-stat span {
	font-family: var(--dbm-mono, monospace);
	font-size: var(--dbm-text-xs, 0.9375rem) !important;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* Layout rhythm — align ICP with home-v6 */
.dbm-icp-wrap {
	max-width: 1140px;
}

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

.dbm-icp-card,
.dbm-icp-compare-col {
	border-radius: 12px;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.dbm-icp-card:hover {
	transform: translateY(-2px);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.9) inset,
		0 16px 32px -12px rgba(0, 0, 0, 0.08);
}

/* ═══════════════════════════════════════════════════════════════════
   FX cards + world map (home-v6 ops, company locations)
   ═══════════════════════════════════════════════════════════════════ */

/* Hide broken Google Maps embeds (localhost API key errors) on v6 pages */
body.dbm-v6-chrome .gm-err-container,
body.dbm-v6-chrome .gm-style-pbc,
body.dbm-v6-chrome .dismissButton,
body.dbm-v6-chrome .gm-err-message,
body.dbm-v6-chrome .gm-err-content {
	display: none !important;
}

body.dbm-v6-chrome .elementor-widget-google_maps,
body.dbm-v6-chrome .elementor-widget-google_maps .elementor-widget-container {
	display: none !important;
	min-height: 0 !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
}

.dbm-landing--v6 .dbm-flow.fx-mount,
body.dbm-landing--v6-inner .dbm-brand-diagram__canvas {
	min-height: 280px;
	overflow: visible;
}

.dbm-landing--v6 .dbm-ops-sec .dbm-fx-card .dbm-flow,
.dbm-landing--v6 .fx-world {
	overflow: visible;
}

.dbm-landing--v6 .fx-world .fx-world-city-pill {
	filter: drop-shadow(0 1px 2px rgba(15, 23, 42, 0.08));
}

.dbm-landing--v6 .fx-world .fx-world-labels {
	pointer-events: none;
}

.dbm-landing--v6 .fx-world .fx-world-city-lbl-wrap {
	text-anchor: middle;
}

.dbm-landing--v6 .fx-world .fx-world-status {
	display: block;
}

.dbm-landing--v6 .dbm-fx-card-head,
body.dbm-landing--v6-inner .dbm-fx-card-head {
	font-size: var(--dbm-text-sm, 1.125rem) !important;
	letter-spacing: 0.08em;
	line-height: 1.45;
	padding-bottom: 14px;
	margin-bottom: 14px;
}

.dbm-landing--v6 .dbm-fx-card-head strong,
body.dbm-landing--v6-inner .dbm-fx-card-head strong {
	font-size: var(--dbm-text-sm, 1.0625rem) !important;
	font-weight: 700;
}

.dbm-landing--v6 .fx-world .fx-world-city-lbl,
body.dbm-landing--v6-inner .fx-world .fx-world-city-lbl {
	font-size: 8.5px !important;
	font-weight: 600;
}

.dbm-landing--v6 .fx-world.fx-world--hovering path[stroke-opacity] {
	transition: stroke-opacity 0.25s ease;
}

.dbm-landing--v6 .fx-world.fx-world--hovering .fx-world-hub-slot--dim,
body.dbm-landing--v6-inner .fx-world.fx-world--hovering .fx-world-hub-slot--dim {
	opacity: 0.42;
}

.dbm-landing--v6 .fx-world .fx-world-hub-slot,
body.dbm-landing--v6-inner .fx-world .fx-world-hub-slot {
	pointer-events: none;
}

.dbm-landing--v6 .fx-world .fx-world-hub,
body.dbm-landing--v6-inner .fx-world .fx-world-hub {
	pointer-events: auto;
}

.dbm-landing--v6 .fx-world.fx-world--hovering .fx-world-hub--dim .fx-world-city-lbl-wrap,
body.dbm-landing--v6-inner .fx-world.fx-world--hovering .fx-world-hub--dim .fx-world-city-lbl-wrap {
	transform: scale(1);
}

.dbm-landing--v6 .fx-world .fx-world-city-tip,
body.dbm-landing--v6-inner .fx-world .fx-world-city-tip {
	pointer-events: none;
}

.dbm-landing--v6 .fx-world .fx-world-city-pill,
body.dbm-landing--v6-inner .fx-world .fx-world-city-pill {
	stroke-width: 1px;
}

.dbm-landing--v6 .fx-world .fx-world-status,
body.dbm-landing--v6-inner .fx-world .fx-world-status {
	font-size: var(--dbm-text-sm, 1.125rem) !important;
}

body.dbm-landing--v6-inner .dbm-brand-diagram__cap {
	font-size: var(--dbm-text-sm, 1.0625rem) !important;
	line-height: var(--dbm-line-body, 1.65) !important;
}

/* Reduced motion: still show map + labels */
.dbm-fx--reduced .fx-world [class*="-hub"] {
	opacity: 1 !important;
	animation: none !important;
	transform: none !important;
}

.dbm-fx--reduced .fx-world .fx-world-hub--dim,
.dbm-fx--reduced .fx-world .fx-world-hub-slot--dim {
	opacity: 1 !important;
}

.dbm-fx--reduced .fx-world animate,
.dbm-fx--reduced .fx-world animateMotion {
	display: none;
}

/* ═══════════════════════════════════════════════════════════════════
   BUTTONS — unified v6 primary / secondary + hovers
   ═══════════════════════════════════════════════════════════════════ */

.dbm-icp-btn,
.dbm-brand-btn,
.dbm-landing--v6 .dbm-btn,
.dbm-landing--v6 .dbm-v6-btn-primary,
.dbm-landing--v6 .dbm-v6-btn-secondary,
.dbm-landing--v6 .dbm-btn--solid,
.dbm-landing--v6 .dbm-btn--outline,
.dbm-landing--v6 .dbm-btn--white,
.dbm-landing--v6 .dbm-v6-sitehead__solid,
.dbm-landing--v6 .dbm-v6-sitehead__ghost,
.dbm-landing--v6 .dbm-v6-sitefoot__btn,
.dbm-landing--v6 .dbm-v6-mega__cta {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
	border-radius: 10px !important;
	font-size: 15px !important; /* unified button size (was miscalibrated rem var under 62.5% root) */
	font-weight: 600 !important;
	line-height: 1.35 !important;
	padding: 14px 26px !important;
	min-height: 52px !important;
	text-decoration: none !important;
	cursor: pointer;
	transition:
		transform 0.22s cubic-bezier(0.22, 1, 0.36, 1),
		box-shadow 0.22s ease,
		background 0.2s ease,
		border-color 0.2s ease,
		color 0.2s ease,
		filter 0.2s ease !important;
}

/* Primary */
.dbm-icp-btn--primary,
.dbm-brand-btn--solid,
.dbm-landing--v6 .dbm-v6-btn-primary,
.dbm-landing--v6 .dbm-btn--solid:not(.dbm-btn--outline),
.dbm-landing--v6 .dbm-v6-sitehead__solid,
.dbm-landing--v6 .dbm-v6-sitefoot__btn,
.dbm-landing--v6 .dbm-v6-mega__cta {
	background: linear-gradient(135deg, #5b21b6 0%, #7c3aed 42%, #4338ca 100%) !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	border: 1px solid rgba(124, 58, 237, 0.45) !important;
	box-shadow: 0 8px 24px rgba(124, 58, 237, 0.28) !important;
}

.dbm-icp-btn--primary:hover,
.dbm-brand-btn--solid:hover,
.dbm-landing--v6 .dbm-v6-btn-primary:hover,
.dbm-landing--v6 .dbm-btn--solid:not(.dbm-btn--outline):hover,
.dbm-landing--v6 .dbm-v6-sitehead__solid:hover,
.dbm-landing--v6 .dbm-v6-sitefoot__btn:hover,
.dbm-landing--v6 .dbm-v6-mega__cta:hover {
	filter: brightness(1.06) saturate(1.05);
	transform: translateY(-1px);
	box-shadow: 0 12px 28px rgba(124, 58, 237, 0.34) !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
}

.dbm-icp-btn--primary:active,
.dbm-brand-btn--solid:active,
.dbm-landing--v6 .dbm-v6-btn-primary:active {
	transform: translateY(0);
	filter: brightness(0.98);
}

/* Secondary / outline / ghost */
.dbm-icp-btn--outline,
.dbm-brand-btn--ghost,
.dbm-landing--v6 .dbm-v6-btn-secondary,
.dbm-landing--v6 .dbm-btn--outline,
.dbm-landing--v6 .dbm-v6-cta-band__ghost,
.dbm-landing--v6 .dbm-v6-sitehead__ghost {
	background: #ffffff !important;
	color: #09090b !important;
	-webkit-text-fill-color: #09090b !important;
	border: 1px solid #e4e4e7 !important;
	box-shadow: none !important;
}

.dbm-icp-btn--outline:hover,
.dbm-brand-btn--ghost:hover,
.dbm-landing--v6 .dbm-v6-btn-secondary:hover,
.dbm-landing--v6 .dbm-btn--outline:hover,
.dbm-landing--v6 .dbm-v6-cta-band__ghost:hover,
.dbm-landing--v6 .dbm-v6-sitehead__ghost:hover {
	background: rgba(13, 148, 136, 0.06) !important;
	border-color: rgba(13, 148, 136, 0.38) !important;
	color: #0d9488 !important;
	-webkit-text-fill-color: #0d9488 !important;
	transform: translateY(-1px);
}

.dbm-landing--v6 .dbm-btn--white {
	background: #ffffff !important;
	color: #09090b !important;
	-webkit-text-fill-color: #09090b !important;
	border: 1px solid #e4e4e7 !important;
}

.dbm-landing--v6 .dbm-btn--white:hover {
	background: #fafafa !important;
	border-color: #d4d4d8 !important;
	transform: translateY(-1px);
}

/* Compact buttons — same tokens, slightly tighter padding */
.dbm-landing--v6 .dbm-btn--sm,
.dbm-landing--v6 .dbm-btn.dbm-btn--sm {
	min-height: 46px !important;
	padding: 12px 20px !important;
	font-size: 15px !important; /* unified button size (was miscalibrated rem var under 62.5% root) */
}

/* Focus — keyboard accessibility */
.dbm-icp-btn:focus-visible,
.dbm-brand-btn:focus-visible,
.dbm-landing--v6 .dbm-btn:focus-visible,
.dbm-landing--v6 .dbm-v6-btn-primary:focus-visible,
.dbm-landing--v6 .dbm-v6-btn-secondary:focus-visible {
	outline: 2px solid #7c3aed;
	outline-offset: 3px;
}

/* Shell header — compact but same system as hero CTAs */
.dbm-landing--v6 .dbm-v6-sitehead__solid,
.dbm-landing--v6 .dbm-v6-sitehead__ghost {
	min-height: 44px !important;
	padding: 10px 18px !important;
	font-size: 15px !important; /* unified button size */
}

.dbm-landing--v6 .dbm-v6-mega__cta {
	min-height: 44px !important;
	padding: 10px 18px !important;
	font-size: 15px !important; /* unified button size */
}

/* Ribbon CTA pill → align to the standard primary button */
.dbm-landing--v6 .dbm-v6-cta-band__pill {
	border-radius: 10px !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	padding: 14px 26px !important;
	min-height: 52px !important;
	background: linear-gradient(135deg, #5b21b6 0%, #7c3aed 42%, #4338ca 100%) !important;
	box-shadow: 0 8px 24px rgba(124, 58, 237, 0.28) !important;
}

/* Brand buttons on inner pages — beat type-scale's higher-specificity rule */
body.dbm-landing--v6-inner .dbm-brand-btn,
body.dbm-landing--v6-inner .dbm-brand-btn--solid,
body.dbm-landing--v6-inner .dbm-brand-btn--ghost,
body.dbm-landing--v6-inner .dbm-brand-co-mid-wrap .dbm-brand-btn--solid,
body.dbm-landing--v6-inner .dbm-brand-co-mid-wrap .dbm-brand-btn--ghost {
	font-size: 15px !important;
}

/* ── Unified trailing arrow + hover slide on every CTA button ──
   Uses ::before with flex order so it sits AFTER the label — the primary/white
   buttons already use ::after for a shine sweep, so ::after is unavailable. */
.dbm-icp-btn::before,
.dbm-brand-btn::before,
.dbm-landing--v6 .dbm-btn::before,
.dbm-landing--v6 .dbm-v6-btn-primary::before,
.dbm-landing--v6 .dbm-v6-btn-secondary::before,
.dbm-landing--v6 .dbm-v6-sitehead__solid::before,
.dbm-landing--v6 .dbm-v6-sitehead__ghost::before,
.dbm-landing--v6 .dbm-v6-sitefoot__btn::before,
.dbm-landing--v6 .dbm-v6-mega__cta::before,
.dbm-landing--v6 .dbm-v6-cta-band__pill::before {
	content: "\2192"; /* → */
	order: 2;
	display: inline-block;
	font-weight: 600;
	z-index: 1;
	transition: transform 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}
.dbm-icp-btn:hover::before,
.dbm-brand-btn:hover::before,
.dbm-landing--v6 .dbm-btn:hover::before,
.dbm-landing--v6 .dbm-v6-btn-primary:hover::before,
.dbm-landing--v6 .dbm-v6-btn-secondary:hover::before,
.dbm-landing--v6 .dbm-v6-sitehead__solid:hover::before,
.dbm-landing--v6 .dbm-v6-sitehead__ghost:hover::before,
.dbm-landing--v6 .dbm-v6-sitefoot__btn:hover::before,
.dbm-landing--v6 .dbm-v6-mega__cta:hover::before,
.dbm-landing--v6 .dbm-v6-cta-band__pill:hover::before {
	transform: translateX(4px);
}

@media (prefers-reduced-motion: reduce) {
	.dbm-icp-btn:hover,
	.dbm-brand-btn:hover,
	.dbm-icp-card:hover,
	.dbm-icp-proof-num {
		transform: none !important;
	}
}
