/**
 * DataFlow page styles.
 *
 * @package MedSolutions_Academy
 */

.msa-page--dataflow .hero {
	padding: 26px 0 50px;
}

.msa-page--dataflow .hero-grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 50px;
	align-items: center;
}

@media (max-width: 980px) {
	.msa-page--dataflow .hero-grid {
		grid-template-columns: 1fr;
	}
}

.msa-page--dataflow .hero h1 {
	font-family: 'Fraunces', serif;
	font-size: clamp(2.1rem, 3.8vw, 3.1rem);
	font-weight: 600;
	color: var(--blue-navy);
	line-height: 1.1;
	margin-bottom: 18px;
	letter-spacing: -0.01em;
}

.msa-page--dataflow .hero h1 em {
	font-style: italic;
	font-weight: 300;
	color: var(--green);
}

.msa-page--dataflow .hero p.lead {
	font-size: 1.02rem;
	color: rgba(44, 62, 80, 0.75);
	line-height: 1.65;
	max-width: 520px;
	margin-bottom: 30px;
}

.msa-page--dataflow .hero-actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
}

.msa-page--dataflow .process-card {
	background: var(--glass-bg);
	backdrop-filter: blur(18px);
	border: 1px solid var(--glass-border);
	border-radius: var(--radius-lg);
	padding: 32px;
	box-shadow: var(--shadow-soft);
}

.msa-page--dataflow .pc-step {
	display: flex;
	gap: 14px;
	padding: 14px 0;
	border-bottom: 1px solid rgba(11, 79, 135, 0.08);
	align-items: flex-start;
}

.msa-page--dataflow .pc-step:last-child {
	border-bottom: none;
}

.msa-page--dataflow .pc-step .dot {
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--blue-deep);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'IBM Plex Mono', monospace;
	font-weight: 600;
	font-size: 0.72rem;
	flex-shrink: 0;
	margin-top: 2px;
}

.msa-page--dataflow .pc-step.done .dot {
	background: var(--green-fresh);
}

.msa-page--dataflow .pc-step .title {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--blue-navy);
}

.msa-page--dataflow .pc-step .sub {
	font-size: 0.78rem;
	color: rgba(44, 62, 80, 0.6);
	margin-top: 2px;
}

.msa-page--dataflow .pc-step .eta {
	margin-left: auto;
	font-family: 'IBM Plex Mono', monospace;
	font-size: 0.72rem;
	color: rgba(44, 62, 80, 0.55);
	flex-shrink: 0;
}

.msa-page--dataflow .section {
	padding: 60px 0;
}

.msa-page--dataflow .section-head {
	max-width: 680px;
	margin-bottom: 40px;
}

.msa-page--dataflow .section-head h2 {
	font-size: clamp(1.6rem, 2.6vw, 2.2rem);
}

.msa-page--dataflow .section-head p {
	margin-top: 12px;
	font-size: 0.98rem;
}

.msa-page--dataflow .services-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}

@media (max-width: 920px) {
	.msa-page--dataflow .services-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 640px) {
	.msa-page--dataflow .services-grid {
		grid-template-columns: 1fr;
	}
}

.msa-page--dataflow .service-card {
	background: #fff;
	border-radius: var(--radius-md);
	padding: 26px;
	border: 1px solid rgba(11, 79, 135, 0.08);
	box-shadow: 0 16px 40px -28px rgba(11, 79, 135, 0.3);
}

.msa-page--dataflow .service-icon {
	width: 46px;
	height: 46px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	margin-bottom: 16px;
	color: #fff;
	background: linear-gradient(135deg, var(--blue-deep), var(--blue-navy));
}

.msa-page--dataflow .service-card:nth-child(3n+2) .service-icon {
	background: linear-gradient(135deg, var(--green-fresh), var(--green));
}

.msa-page--dataflow .service-card:nth-child(3n+3) .service-icon {
	background: linear-gradient(135deg, #2c3e50, #0b4f87);
}

.msa-page--dataflow .service-card h3 {
	font-family: 'Fraunces', serif;
	font-size: 1.02rem;
	color: var(--blue-navy);
	margin-bottom: 8px;
}

.msa-page--dataflow .service-card p {
	font-size: 0.86rem;
	color: rgba(44, 62, 80, 0.7);
	line-height: 1.55;
}

.msa-page--dataflow .stepper {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 0;
	position: relative;
}

@media (max-width: 920px) {
	.msa-page--dataflow .stepper {
		grid-template-columns: 1fr;
		gap: 20px;
	}
}

.msa-page--dataflow .step-item {
	position: relative;
	padding: 0 16px;
	text-align: center;
}

.msa-page--dataflow .step-item::before {
	content: "";
	position: absolute;
	top: 19px;
	left: -50%;
	width: 100%;
	height: 2px;
	background: rgba(11, 79, 135, 0.15);
	z-index: 0;
}

.msa-page--dataflow .step-item:first-child::before {
	display: none;
}

@media (max-width: 920px) {
	.msa-page--dataflow .step-item::before {
		display: none;
	}
}

.msa-page--dataflow .step-circle {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #fff;
	border: 2px solid var(--blue-deep);
	color: var(--blue-deep);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 14px;
	font-family: 'IBM Plex Mono', monospace;
	font-weight: 600;
	font-size: 0.85rem;
	position: relative;
	z-index: 1;
}

.msa-page--dataflow .step-item h4 {
	font-family: 'Fraunces', serif;
	font-size: 0.86rem;
	color: var(--blue-navy);
	margin-bottom: 6px;
}

.msa-page--dataflow .step-item p {
	font-size: 0.76rem;
	color: rgba(44, 62, 80, 0.6);
	line-height: 1.5;
}

.msa-page--dataflow .faq-item {
	border-bottom: 1px solid rgba(11, 79, 135, 0.1);
	padding: 20px 0;
}

.msa-page--dataflow .faq-q {
	font-weight: 600;
	color: var(--blue-navy);
	font-size: 0.96rem;
}

.msa-page--dataflow .faq-a {
	font-size: 0.88rem;
	color: rgba(44, 62, 80, 0.72);
	line-height: 1.65;
	margin-top: 10px;
	max-width: 680px;
}

.msa-page--dataflow .faq-wrap {
	max-width: 820px;
	margin: 0 auto;
}

.msa-page--dataflow .section-head.centered {
	margin: 0 auto 30px;
	text-align: center;
}

.msa-page--dataflow .cta-strip h3 {
	font-size: 1.4rem;
}

.msa-page--dataflow .cta-strip p {
	font-size: 0.9rem;
}

.msa-page--dataflow .cta-strip {
	padding: 50px;
}

@media (max-width: 640px) {
	.msa-page--dataflow .cta-strip {
		padding: 32px 24px;
	}
}
