/**
 * DataScan contact page
 */

body.ds-contact-page-active {
	overflow-x: clip;
}

body.ds-contact-page-active .ds-contact-page-main,
body.ds-contact-page-active .ds-contact-content,
body.ds-contact-page-active .ds-contact-content.wp-block-post-content {
	margin: 0 !important;
	padding: 0 !important;
	max-width: none !important;
	width: 100% !important;
}

body.ds-contact-page-active .ds-contact-content > .wp-block-group {
	margin-block: 0;
}

/* Full-bleed breakout — same technique as WP alignfull inside flow layout */
body.ds-contact-page-active .ds-contact-content > .alignfull {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
	padding-inline: 0 !important;
}

/* Hero wrap carries the full-width background */
.ds-contact-hero-wrap {
	background: linear-gradient(135deg, #082f47 0%, #115b8a 50%, #1d3267 100%);
	overflow: hidden;
	position: relative;
}

.ds-contact-hero-wrap::before,
.ds-contact-hero-wrap::after {
	content: "";
	position: absolute;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 50%;
	pointer-events: none;
}

.ds-contact-hero-wrap::before {
	width: 280px;
	height: 280px;
	top: -80px;
	right: 18%;
}

.ds-contact-hero-wrap::after {
	width: 160px;
	height: 160px;
	bottom: -40px;
	left: 8%;
}

/* Hero */
.ds-contact-hero {
	color: #fff;
	padding-block: clamp(2.25rem, 4vw, 3.25rem) clamp(2.75rem, 5vw, 3.75rem);
	position: relative;
	width: 100%;
	background: transparent;
}

.ds-contact-hero-inner {
	max-width: 1200px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 1.5rem);
	position: relative;
	z-index: 1;
}

.ds-contact-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.5rem;
	margin: 0 0 1rem;
	font-size: 0.8125rem;
}

.ds-contact-breadcrumb a {
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
}

.ds-contact-breadcrumb a:hover {
	color: #fff;
	text-decoration: underline;
}

.ds-contact-breadcrumb-sep {
	opacity: 0.65;
}

.ds-contact-breadcrumb-current {
	color: #fff;
	font-weight: 600;
}

.ds-contact-hero-grid {
	display: grid !important;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
	gap: clamp(1.25rem, 3vw, 2rem);
	align-items: center;
}

.ds-contact-hero-grid > .wp-block-column {
	flex-basis: auto !important;
	width: auto !important;
}

.ds-contact-hero-title,
.ds-contact-hero .ds-contact-hero-title {
	margin: 0 0 0.65rem;
	color: #fff !important;
	font-family: var(--ds-font-display, inherit);
	font-size: clamp(1.85rem, 3.8vw, 2.65rem);
	line-height: 1.08;
	font-weight: 800;
}

.ds-contact-hero-lead,
.ds-contact-hero .ds-contact-hero-lead {
	margin: 0 0 1.15rem;
	max-width: 46ch;
	color: rgba(255, 255, 255, 0.9) !important;
	font-size: clamp(0.95rem, 1.6vw, 1.0625rem);
	line-height: 1.6;
}

.ds-contact-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	margin-bottom: 1.35rem;
}

.ds-contact-hero-actions .wp-block-button__link {
	min-height: 42px;
	padding: 0.55rem 1rem !important;
	border-radius: 10px !important;
	font-size: 0.875rem !important;
	font-weight: 700;
}

.ds-contact-hero-btn--primary .wp-block-button__link {
	background: var(--ds-accent, #f36735) !important;
	color: #fff !important;
	border: 0 !important;
	box-shadow: 0 6px 18px rgba(243, 103, 53, 0.35);
}

.ds-contact-hero-btn--primary .wp-block-button__link:hover {
	background: #e05528 !important;
}

.ds-contact-hero-btn--ghost .wp-block-button__link {
	background: rgba(255, 255, 255, 0.1) !important;
	border: 1px solid rgba(255, 255, 255, 0.22) !important;
	color: #fff !important;
}

.ds-contact-hero-btn--ghost .wp-block-button__link:hover {
	background: rgba(255, 255, 255, 0.16) !important;
	color: #fff !important;
}

.ds-contact-hero-badges {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0.65rem;
	margin: 0 !important;
}

.ds-contact-hero-badges > .wp-block-column {
	flex-basis: auto !important;
	width: auto !important;
}

.ds-contact-badge {
	margin: 0;
	padding: 0.75rem 0.85rem;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.1);
	font-size: 0.75rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.78) !important;
}

.ds-contact-badge strong {
	display: block;
	margin-bottom: 0.1rem;
	color: #fff;
	font-size: 0.8125rem;
}

/* Hero visual — icon cards, no images required */
.ds-contact-hero-stage {
	position: relative;
	padding: 1.25rem 1rem 1rem;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	overflow: hidden;
}

.ds-contact-hero-icons {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.65rem;
	margin: 0 !important;
}

.ds-contact-hero-icons > .wp-block-column {
	flex-basis: auto !important;
	width: auto !important;
}

.ds-contact-hero-icon-card {
	margin: 0;
	padding: 0.85rem 0.5rem;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.12);
	font-size: 0.75rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.85) !important;
}

.ds-contact-hero-icon-emoji {
	display: block;
	font-size: 1.65rem;
	line-height: 1;
	margin-bottom: 0.35rem;
}

.ds-contact-hero-icon-card strong {
	color: #fff;
	font-size: 0.8125rem;
}

.ds-contact-hero-stage-note {
	margin: 0.85rem 0 0;
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, 0.72) !important;
}

/* Main content — overlap hero so form is above the fold */
.ds-contact-main {
	background: #f5f7fa;
	margin-top: -2.25rem;
	padding-block: 0 clamp(2rem, 4vw, 2.75rem);
	position: relative;
	z-index: 2;
}

.ds-contact-main-inner {
	max-width: 1200px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 1.5rem);
}

.ds-contact-main-grid {
	display: grid !important;
	grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
	align-items: start;
}

.ds-contact-main-grid > .wp-block-column {
	flex-basis: auto !important;
	width: auto !important;
}

/* Contact info card */
.ds-contact-info {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 16px;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}

.ds-contact-info-title {
	margin: 0 0 1.15rem;
	color: var(--ds-navy, #1d3267);
	font-size: clamp(1.25rem, 2.2vw, 1.5rem);
	font-weight: 800;
}

.ds-contact-info-item {
	padding-bottom: 1rem;
	margin-bottom: 0;
	border-bottom: 1px solid #eef2f7;
}

.ds-contact-info-item:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.ds-contact-info-item p {
	margin: 0;
	color: #64748b;
	font-size: 0.9375rem;
	line-height: 1.55;
}

.ds-contact-info-item strong {
	color: var(--ds-navy, #1d3267);
	font-size: 0.875rem;
}

.ds-contact-info-item a {
	color: var(--ds-primary, #115b8a);
	font-weight: 600;
	text-decoration: none;
}

.ds-contact-info-item a:hover {
	text-decoration: underline;
}

/* Form card */
.ds-contact-form-card {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 16px;
	padding: clamp(1.25rem, 3vw, 2rem);
	box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
	scroll-margin-top: 6rem;
}

.ds-contact-form-card-title {
	margin: 0 0 1.15rem;
	color: var(--ds-navy, #1d3267);
	font-size: clamp(1.25rem, 2.2vw, 1.5rem);
	font-weight: 800;
}

.ds-contact-form label span {
	font-weight: 600;
	font-size: 0.875rem;
	color: var(--ds-navy, #1d3267);
}

.ds-contact-form .ds-form-required {
	color: #dc2626;
	margin-left: 0.15rem;
}

.ds-contact-form input,
.ds-contact-form select,
.ds-contact-form textarea {
	border-color: #dbe3ee;
	border-radius: 10px;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ds-contact-form input:focus,
.ds-contact-form select:focus,
.ds-contact-form textarea:focus {
	outline: none;
	border-color: var(--ds-primary, #115b8a);
	box-shadow: 0 0 0 3px rgba(17, 91, 138, 0.12);
}

.ds-contact-form-footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 0.25rem;
}

.ds-contact-form-privacy {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
	color: #64748b;
	font-size: 0.8125rem;
	line-height: 1.45;
}

.ds-contact-form-privacy .ds-contact-icon {
	color: var(--ds-primary, #115b8a);
}

.ds-contact-form-privacy .ds-contact-icon svg {
	width: 18px;
	height: 18px;
}

.ds-contact-form .ds-form-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	min-width: 180px;
	border-radius: 10px;
	background: var(--ds-accent, #f36735);
	font-size: 0.9375rem;
	font-weight: 700;
	box-shadow: 0 8px 20px rgba(243, 103, 53, 0.28);
}

.ds-contact-form .ds-form-submit:hover {
	background: #e05528;
}

.ds-contact-form .ds-form-submit-arrow {
	font-size: 1.1rem;
	line-height: 1;
}

/* Trust bar */
.ds-contact-trust {
	background: #fff;
	border-block: 1px solid #e2e8f0;
	padding-block: clamp(1.15rem, 2.5vw, 1.5rem);
}

.ds-contact-trust-inner {
	max-width: 1200px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 1.5rem);
}

.ds-contact-trust-grid {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1rem 1.25rem;
}

.ds-contact-trust-grid > .wp-block-column {
	flex-basis: auto !important;
	width: auto !important;
}

.ds-contact-trust-item p {
	margin: 0;
	color: #64748b;
	font-size: 0.8125rem;
	line-height: 1.45;
}

.ds-contact-trust-item strong {
	color: var(--ds-navy, #1d3267);
	font-size: 0.875rem;
}

/* Responsive */
@media (max-width: 960px) {
	.ds-contact-hero-grid,
	.ds-contact-main-grid {
		grid-template-columns: 1fr;
	}

	.ds-contact-hero-badges {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.ds-contact-hero-visual-col {
		max-width: 520px;
		margin-inline: auto;
	}

	.ds-contact-trust-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.ds-contact-hero-badges {
		grid-template-columns: 1fr;
	}

	.ds-contact-hero-actions .wp-block-button {
		width: 100%;
	}

	.ds-contact-hero-actions .wp-block-button__link {
		width: 100%;
		justify-content: center;
	}

	.ds-contact-hero-icons {
		grid-template-columns: 1fr !important;
	}

	.ds-contact-trust-grid {
		grid-template-columns: 1fr;
	}

	.ds-contact-form-footer {
		flex-direction: column;
		align-items: stretch;
	}

	.ds-contact-form .ds-form-submit {
		width: 100%;
	}
}
