/* ============================================================
   Doctors Page
   Loaded only on template-doctors.php (see functions.php).
   Breadcrumb + bottom CTA live in global.css.
   ============================================================ */

/* === HERO ============================================ */
.doctors-hero-wrapper {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 100px;
}
.doctors-hero {
	width: 100%;
	height: 580px;
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: center;
	padding: 60px 170px;
}
.doctors-hero-bg {
	position: absolute;
	inset: 0;
}
.doctors-hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.doctors-hero-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.8));
}
.doctors-hero-content {
	position: relative;
	z-index: 1;
	text-align: center;
	width: 862px;
	max-width: 100%;
}
.doctors-hero-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	margin-bottom: 12px;
}
.doctors-hero-title {
	font-size: 72px;
	line-height: 80px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

/* === INFO BAND ======================================== */
.doctors-info {
	max-width: 1440px;
	margin: 160px auto 0;
	padding: 0 100px;
}
.doctors-info-line {
	width: 3px;
	height: 80px;
	background: var(--color-primary-green);
	border-radius: 2px;
	margin: 0 auto 80px;
}
.doctors-info-row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	max-width: 1240px;
	margin: 0 auto 36px;
	gap: 40px;
}
.doctors-info-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	width: 364px;
	flex-shrink: 0;
}
.doctors-info-desc {
	font-size: 20px;
	line-height: 26px;
	color: var(--color-grey-9);
	width: 800px;
}
.doctors-info-desc p {
	margin: 0;
}
.doctors-info-desc p + p {
	margin-top: 16px;
}

/* === GRID OF DOCTORS ================================== */
.doctors-grid-wrap {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 100px;
}
.doctors-grid {
	display: flex;
	gap: 24px;
	align-items: stretch;
}
.doctor-card {
	height: 560px;
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	cursor: pointer;
	flex-shrink: 0;
	transition: width 0.55s cubic-bezier(0.4, 0, 0.2, 1);
	width: 230px;
	flex: 0 0 230px;
}
.doctor-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	inset: 0;
	filter: grayscale(100%);
	transition: filter 0.5s ease;
}
.doctor-card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 36.6%, rgba(0, 0, 0, 1));
	transition: opacity 0.4s ease;
}
.doctor-card-info {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 24px;
	z-index: 1;
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.doctor-card-name {
	font-size: 24px;
	line-height: 30px;
	font-weight: var(--fw-medium);
}
.doctor-card-role {
	font-size: 18px;
	line-height: 24px;
}
.doctor-card-bio {
	font-size: 18px;
	line-height: 24px;
}
.doctor-card-name,
.doctor-card-role,
.doctor-card-bio {
	opacity: 0;
	transition: opacity 0.35s ease 0.05s;
}
.doctor-card.is-active {
	width: 478px;
	flex: 0 0 478px;
}
.doctor-card.is-active img {
	filter: grayscale(0%);
}
.doctor-card.is-active .doctor-card-info {
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.94));
}
.doctor-card.is-active .doctor-card-name,
.doctor-card.is-active .doctor-card-role,
.doctor-card.is-active .doctor-card-bio {
	opacity: 1;
}

/* === SERVICES CTA CARD ================================ */
.doc-services {
	max-width: 1440px;
	margin: 160px auto 0;
	padding: 0 100px;
}
.doc-services-card {
	background: #E7F1FB;
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	min-height: 460px;
	display: flex;
	align-items: flex-start;
}
.doc-services-text {
	padding: 48px 40px;
	width: 694px;
	flex-shrink: 0;
	position: relative;
	z-index: 1;
}
.doc-services-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.doc-services-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-9);
	margin-top: 16px;
	max-width: 600px;
}
.doc-services-btn {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	height: 54px;
	padding: 16px 24px;
	border-radius: var(--radius-xl);
	border: 1px solid var(--color-grey-5);
	background: transparent;
	color: var(--color-primary-blue);
	font-size: 17px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	cursor: pointer;
	margin-top: 32px;
	transition: border-color var(--transition-fast);
}
.doc-services-btn:hover {
	border-color: var(--color-blue-n3);
}
.doc-services-btn svg {
	width: 20px;
	height: 20px;
}
.doc-services-images {
	position: absolute;
	right: 40px;
	top: -20px;
	bottom: -20px;
	width: 440px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	align-content: center;
}
.doc-services-images .dsi {
	border-radius: var(--radius-lg);
	overflow: hidden;
	height: 250px;
}
.doc-services-images .dsi img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.doc-services-images .dsi:nth-child(1) {
	margin-top: 63px;
}
.doc-services-images .dsi:nth-child(3) {
	margin-top: 63px;
}

/* === RESPONSIVE ======================================= */
@media (max-width: 1279px) {
	.doctors-hero-wrapper {
		padding: 0 32px;
	}
	.doctors-hero {
		padding: 60px 80px;
	}
	.doctors-info,
	.doctors-grid-wrap {
		padding: 0 32px;
	}
	.doctor-card {
		width: 180px;
		flex: 0 0 180px;
	}
	.doctor-card.is-active {
		width: 420px;
		flex: 0 0 420px;
	}
	.doc-services {
		padding: 0 32px;
	}
	.doc-services-text {
		width: 50%;
	}
	.doc-services-images {
		right: 24px;
		width: 380px;
	}
}

@media (max-width: 991px) {
	.doctors-hero-wrapper {
		padding: 0 16px;
	}
	.doctors-hero {
		height: 580px;
		padding: 32px 24px;
		border-radius: var(--radius-lg);
		align-items: flex-start;
		justify-content: flex-end;
	}
	.doctors-hero-content {
		width: 100%;
		text-align: center;
	}
	.doctors-hero-sub {
		font-size: 16px;
		line-height: 22px;
	}
	.doctors-hero-title {
		font-size: 40px;
		line-height: 46px;
	}
	.doctors-info {
		padding: 0 16px;
		margin-top: 116px;
	}
	.doctors-info-line {
		margin-bottom: 72px;
	}
	.doctors-info-row {
		flex-direction: column;
		gap: 12px;
		margin-bottom: 32px;
	}
	.doctors-info-title {
		font-size: 24px;
		line-height: 30px;
		width: 100%;
	}
	.doctors-info-desc {
		font-size: 16px;
		line-height: 22px;
		width: 100%;
	}
	.doctors-grid-wrap {
		padding: 0 16px;
	}
	.doctors-grid {
		flex-direction: column;
		gap: 16px;
	}
	.doctor-card {
		width: 100% !important;
		flex: 1 1 auto !important;
		height: 270px;
		border-radius: var(--radius-lg);
	}
	.doctor-card img {
		filter: grayscale(0%) !important;
	}
	.doctor-card .doctor-card-info {
		backdrop-filter: blur(16px);
		-webkit-backdrop-filter: blur(16px);
		background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.94));
	}
	.doctor-card .doctor-card-name,
	.doctor-card .doctor-card-role {
		opacity: 1;
	}
	.doctor-card .doctor-card-bio {
		opacity: 0;
	}
	.doctor-card.is-active {
		height: 460px;
	}
	.doctor-card.is-active .doctor-card-bio {
		opacity: 1;
	}
	.doctor-card-info {
		padding: 20px;
	}
	.doctor-card-name {
		font-size: 20px;
		line-height: 26px;
	}
	.doctor-card-role {
		font-size: 16px;
		line-height: 22px;
	}
	.doctor-card-bio {
		font-size: 16px;
		line-height: 22px;
	}
	.doc-services {
		padding: 0 16px;
		margin-top: 116px;
	}
	.doc-services-card {
		flex-direction: column;
		min-height: auto;
		border-radius: var(--radius-lg);
	}
	.doc-services-text {
		width: 100%;
		padding: 32px 24px;
	}
	.doc-services-title {
		font-size: 24px;
		line-height: 30px;
	}
	.doc-services-sub {
		font-size: 16px;
		line-height: 22px;
		margin-top: 12px;
	}
	.doc-services-btn {
		height: 48px;
		padding: 12px 20px;
		font-size: 16px;
		margin-top: 24px;
		width: 100%;
		justify-content: center;
	}
	.doc-services-images {
		position: relative;
		right: auto;
		top: auto;
		bottom: auto;
		width: 100%;
		padding: 0 16px 16px;
		grid-template-columns: 1fr 1fr;
		gap: 12px;
	}
	.doc-services-images .dsi {
		height: 180px;
		border-radius: var(--radius-lg);
	}
	.doc-services-images .dsi:nth-child(1) {
		margin-top: 0;
	}
	.doc-services-images .dsi:nth-child(2) {
		margin-top: 40px;
	}
	.doc-services-images .dsi:nth-child(3) {
		margin-top: -20px;
	}
	.doc-services-images .dsi:nth-child(4) {
		margin-top: 20px;
	}
}

@media (max-width: 575px) {
	.doctors-hero-wrapper,
	.doctors-info,
	.doctors-grid-wrap,
	.doc-services {
		padding: 0 12px;
	}
}

.doctors-grid-wrap--empty {
	margin-top: 0;
}
.doctors-empty {
	max-width: 860px;
	margin: 0 auto;
	padding: 40px;
	border: 1px solid var(--color-grey-4);
	border-radius: var(--radius-lg);
	background: var(--color-grey-0);
	text-align: center;
}
.doctors-empty h2 {
	font-size: 28px;
	line-height: 36px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.doctors-empty p {
	max-width: 700px;
	margin: 12px auto 0;
	font-size: 18px;
	line-height: 26px;
	color: var(--color-grey-9);
}
@media (max-width: 991px) {
	.doctors-empty {
		padding: 28px 20px;
	}
	.doctors-empty h2 {
		font-size: 22px;
		line-height: 28px;
	}
	.doctors-empty p {
		font-size: 16px;
		line-height: 22px;
	}
}
