/* MGH Contact ("Kontakt os") – self-contained section: header + two-column layout. */
/* Light background; H1 title, paragraph description; column titles H4. */
/* Gold email/phone links with leading inline SVG icon; acute column gets a left divider on desktop. */
/* Top spacing from margin-top only (60px mobile, 100px desktop); horizontal padding only (20px/50px sides). */

.mgh-contact {
	margin-top: 60px;
	padding: 0 20px;
	color: #2c3a60;
}

.mgh-contact--no-top-padding {
	margin-top: 0;
}

.mgh-contact__header {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin: 0 0 40px 0;
}

/* Specificity beats Elementor per-page typography CSS (post-*.css). Same tokens as hero: mobile_heading_1 / heading_1. */
div.elementor-widget.elementor-widget-mgh_contact .mgh-contact .mgh-contact__header .mgh-contact__title {
	font-family: Poppins, sans-serif;
	font-size: 34px;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0;
	color: #2c3a60;
}

.mgh-contact__title {
	margin: 0;
}

.mgh-contact__description {
	margin: 0;
	max-width: 640px;
	line-height: 1.4;
	font-family: Poppins, sans-serif;
	font-weight: 300;
	font-size: 14px;
	color: #2c3a60;
}

.mgh-contact__columns {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.mgh-contact__col {
	display: flex;
	flex-direction: column;
	gap: 16px;
	min-width: 0;
}

/* Mobile: columns stack, so the divider runs horizontally above the acute column. */
.mgh-contact__col--acute {
	padding-top: 40px;
	border-top: 1px solid rgba(44, 58, 96, 0.20);
}

.mgh-contact__col-title {
	margin: 0;
	line-height: 1.2;
	font-family: Poppins, sans-serif;
	font-weight: 600;
	font-size: 22px;
	color: #2c3a60;
}

.mgh-contact__address {
	margin: 0;
	line-height: 1.4;
	font-family: Poppins, sans-serif;
	font-weight: 300;
	font-size: 14px;
	color: #2c3a60;
}

/* Gold email/phone links with leading icon. */
.mgh-contact__links {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
}

.mgh-contact .mgh-contact__link,
.mgh-contact .mgh-contact__link:visited,
.mgh-contact .mgh-contact__link:active,
.mgh-contact .mgh-contact__link:focus,
.mgh-contact .mgh-contact__link span {
	color: #baa558;
	text-decoration: none;
}

.mgh-contact .mgh-contact__link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	line-height: 1.4;
	font-family: Poppins, sans-serif;
	font-weight: 600;
	font-size: 14px;
}

.mgh-contact .mgh-contact__link svg {
	flex-shrink: 0;
	width: 1em;
	height: 1em;
	vertical-align: middle;
	color: inherit;
}

/* Force icon shapes to follow the link color in every state (rest, visited, hover). */
.mgh-contact .mgh-contact__link svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.mgh-contact .mgh-contact__link svg [fill]:not([fill="none"]) {
	fill: currentColor;
}

.mgh-contact .mgh-contact__link:hover,
.mgh-contact .mgh-contact__link:hover span,
.mgh-contact .mgh-contact__link:hover svg {
	color: #2c3a60;
	text-decoration: none;
}

.mgh-contact__hours {
	display: flex;
	flex-direction: column;
	gap: 5px;
	margin-top: 8px;
	line-height: 1.4;
	font-family: Poppins, sans-serif;
	font-size: 14px;
	color: #2c3a60;
}

.mgh-contact__hours-label {
	font-weight: 600;
}

.mgh-contact__hours-value {
	font-weight: 300;
}

.mgh-contact__acute-desc {
	margin: 0;
	line-height: 1.4;
	font-family: Poppins, sans-serif;
	font-weight: 300;
	font-size: 14px;
	color: #2c3a60;
}

.mgh-contact__col--acute .mgh-button {
	align-self: flex-start;
	margin-top: 8px;
}

/* Desktop: two columns side by side with a vertical divider; wider padding/title. */
@media (min-width: 1280px) {
	.mgh-contact {
		margin-top: 100px;
		padding: 0 50px;
	}

	.mgh-contact--no-top-padding {
		margin-top: 0;
	}

	.mgh-contact__header {
		gap: 16px;
		margin-bottom: 60px;
	}

	div.elementor-widget.elementor-widget-mgh_contact .mgh-contact .mgh-contact__header .mgh-contact__title {
		font-size: 53px;
	}

	.mgh-contact__columns {
		flex-direction: row;
		gap: 64px;
		align-items: flex-start;
	}

	.mgh-contact__col {
		flex: 1;
	}

	.mgh-contact__col--acute {
		padding-top: 0;
		border-top: none;
		padding-left: 64px;
		border-left: 1px solid rgba(44, 58, 96, 0.20);
	}

	.mgh-contact--single .mgh-contact__col--main {
		flex: 0 1 auto;
	}

	.mgh-contact__col-title {
		font-size: 24px;
	}
}
