/**
 * Contact Us page — contact information band (scoped).
 * Matches PrimeHealthPlus card / icon patterns (insurance notice, provider items, footer socials).
 */

.phplus-contact-info-section {
	background: var(--bg-color);
	padding: 56px 0 64px;
	width: 100%;
}

.phplus-contact-info-section .container {
	max-width: 1300px;
}

/* Top row: heading + socials */
.phplus-contact-info-top {
	align-items: flex-start;
	display: flex;
	flex-wrap: wrap;
	gap: 28px 40px;
	justify-content: space-between;
	margin-bottom: 48px;
}

.phplus-contact-info-heading {
	color: var(--primary-color);
	font-family: var(--accent-font, "Sora", sans-serif);
	font-size: clamp(1.65rem, 3.2vw, 2.65rem);
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
	max-width: 820px;
}

.phplus-contact-info-heading-accent {
	color: var(--primary-color);
	font-weight: 700;
}

/* Social icons — aligned with footer-social-links pattern on light background */
.phplus-contact-socials {
	align-items: center;
	display: flex;
	flex-direction: column;
	flex-shrink: 0;
	gap: 14px;
}

.phplus-contact-socials__label {
	color: var(--primary-color);
	font-family: var(--accent-font, "Sora", sans-serif);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.02em;
}

.phplus-contact-socials__list {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: flex-end;
}

.phplus-contact-socials__link {
	align-items: center;
	background: var(--white-color);
	border: 1px solid var(--divider-color);
	border-radius: 50%;
	box-shadow: 0 6px 18px rgba(30, 95, 122, 0.08);
	color: var(--primary-color);
	display: inline-flex;
	height: 40px;
	justify-content: center;
	text-decoration: none;
	transition: all 0.4s ease-in-out;
	width: 40px;
}

.phplus-contact-socials__link:hover {
	background-color: var(--accent-color);
	border-color: var(--accent-color);
	color: var(--primary-color);
	transform: translateY(-2px);
}

.phplus-contact-socials__link i {
	color: inherit;
	font-size: 18px;
	line-height: 1;
}

/* Contact cards grid */
.phplus-contact-info-grid {
	display: grid;
	gap: 20px;
}

.phplus-contact-info-grid--cols-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.phplus-contact-info-grid--cols-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.phplus-contact-info-card {
	background: var(--white-color);
	border: 1px solid var(--divider-color);
	border-radius: 20px;
	box-shadow: 0 12px 40px rgba(30, 95, 122, 0.08);
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	height: 100%;
	min-width: 0;
	padding: 28px 24px 30px;
	transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.phplus-contact-info-card:hover {
	border-color: rgba(30, 95, 122, 0.25);
	box-shadow: 0 14px 32px rgba(30, 95, 122, 0.12);
	transform: translateY(-4px);
}

.phplus-contact-info-card:hover .phplus-contact-info-icon {
	background: var(--primary-color);
	color: var(--white-color);
}

.phplus-contact-info-icon {
	align-items: center;
	background: var(--accent-color);
	border-radius: 16px;
	color: var(--primary-color);
	display: flex;
	flex: 0 0 64px;
	font-size: 24px;
	height: 64px;
	justify-content: center;
	margin-bottom: 20px;
	transition: background-color 0.35s ease, color 0.35s ease;
	width: 64px;
}

.phplus-contact-info-card__title {
	color: var(--primary-color);
	font-family: var(--accent-font, "Sora", sans-serif);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.35;
	margin: 0 0 12px;
}

.phplus-contact-info-card__body {
	color: var(--text-color);
	flex: 1;
	font-size: 16px;
	line-height: 1.65;
	min-width: 0;
}

.phplus-contact-info-card__body p {
	margin: 0 0 6px;
	min-width: 0;
	max-width: 100%;
}

.phplus-contact-info-card__body p:has(a[href^="mailto:"]) {
	container-type: inline-size;
	container-name: phplus-contact-email;
	min-width: 0;
	max-width: 100%;
}

.phplus-contact-info-card__body p:last-child {
	margin-bottom: 0;
}

.phplus-contact-info-card__body a {
	color: var(--primary-color);
	font-weight: 600;
	text-decoration: none;
	transition: color 0.3s ease;
}

/* Contact email — wrap by default; one line only when the card body is wide enough */
.phplus-contact-info-card__body a[href^="mailto:"] {
	display: inline-block;
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: normal;
	white-space: normal;
}

@container phplus-contact-email (min-width: 360px) {
	.phplus-contact-info-card__body a[href^="mailto:"] {
		display: inline;
		overflow-wrap: normal;
		white-space: nowrap;
	}
}

@media (max-width: 1499px) {
	.phplus-contact-info-card__body a[href^="mailto:"] {
		display: inline-block;
		max-width: 100%;
		overflow-wrap: anywhere;
		word-break: normal;
		white-space: normal;
	}
}

.phplus-contact-info-card__body a:hover {
	color: var(--primary-color);
	opacity: 0.85;
	text-decoration: underline;
}

@media (max-width: 1199px) {
	.phplus-contact-info-grid--cols-4,
	.phplus-contact-info-grid--cols-3 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.phplus-contact-info-section {
		padding: 44px 0 48px;
	}

	.phplus-contact-info-top {
		flex-direction: column;
		margin-bottom: 36px;
	}

	.phplus-contact-socials {
		align-items: flex-start;
	}

	.phplus-contact-socials__list {
		justify-content: flex-start;
	}

	.phplus-contact-info-grid--cols-4,
	.phplus-contact-info-grid--cols-3 {
		grid-template-columns: 1fr;
	}
}
