.dcc-wwa-memoriam {
	background: var(--dcc-white);
	padding-block: clamp(3rem, 4.5vw, 5.5rem);
}

.dcc-wwa-memoriam__container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 3rem);
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 2.5vw, 3rem);
}

.dcc-wwa-memoriam__heading {
	font-family: var(--ff-serif);
	font-weight: 700;
	font-size: clamp(2.25rem, 3.4vw, 3.25rem);
	line-height: 1.1;
	color: var(--dcc-navy);
	margin: 0;
	text-align: center;
}

.dcc-wwa-memoriam__card {
	background: #F9F9F9;
	border: 1px solid var(--dcc-border);
	border-radius: clamp(8px, 1vw, 14px);
	overflow: hidden;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	gap: 0;
	align-items: stretch;
}

.dcc-wwa-memoriam__photo {
	background: #d8d4c8;
	min-height: clamp(220px, 22vw, 320px);
}

.dcc-wwa-memoriam__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.dcc-wwa-memoriam__photo-empty {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #c4a052 0%, #0a1530 100%);
	opacity: .15;
}

.dcc-wwa-memoriam__details {
	padding: clamp(1.5rem, 2.5vw, 3rem);
	display: flex;
	flex-direction: column;
	gap: clamp(.35rem, .55vw, .55rem);
	justify-content: center;
}

.dcc-wwa-memoriam__name {
	font-family: var(--ff-serif);
	font-weight: 700;
	font-size: clamp(1.5rem, 2.2vw, 2.25rem);
	line-height: 1.15;
	color: var(--dcc-navy);
	margin: 0;
}

.dcc-wwa-memoriam__dates {
	font-family: var(--ff-sans);
	font-weight: 400;
	font-size: clamp(.875rem, .95vw, 1rem);
	color: var(--dcc-text-muted);
}

.dcc-wwa-memoriam__divider {
	display: block;
	width: clamp(28px, 3vw, 44px);
	height: 2px;
	background: #C5A059;
	margin: clamp(.5rem, .9vw, .85rem) 0 clamp(.65rem, 1vw, 1rem);
}

.dcc-wwa-memoriam__role {
	font-family: var(--ff-sans);
	font-weight: 700;
	font-size: clamp(.75rem, .82vw, .875rem);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--dcc-navy);
	line-height: 1.4;
}

.dcc-wwa-memoriam__subrole {
	font-family: var(--ff-sans);
	font-weight: 400;
	font-size: clamp(.75rem, .8vw, .85rem);
	color: var(--dcc-text-muted);
	letter-spacing: .04em;
}

@media (max-width: 900px) {
	.dcc-wwa-memoriam__card {
		grid-template-columns: 1fr;
	}
	.dcc-wwa-memoriam__photo {
		min-height: 240px;
		aspect-ratio: 16 / 10;
	}
}

@media (max-width: 600px) {
	.dcc-wwa-memoriam { padding-block: 2.5rem; }
	.dcc-wwa-memoriam__heading { font-size: 1.875rem; }
}

@media (min-width: 1025px) {
	.dcc-wwa-memoriam__container {
		max-width: 100%;
		padding-inline: 7rem;
	}
}

@media (min-width: 1441px) {
	.dcc-wwa-memoriam {
		padding-block: clamp(4.5rem, 5.5vw, 7rem);
	}

	.dcc-wwa-memoriam__container {
		padding-inline: 13rem;
		gap: clamp(2rem, 2.8vw, 3.5rem);
	}

	.dcc-wwa-memoriam__heading {
		font-size: clamp(3rem, 3.8vw, 4rem);
	}

	.dcc-wwa-memoriam__card {
		border-radius: clamp(12px, 1.2vw, 18px);
	}

	.dcc-wwa-memoriam__photo {
		min-height: clamp(280px, 22vw, 380px);
	}

	.dcc-wwa-memoriam__details {
		padding: clamp(2rem, 3vw, 3.75rem);
		gap: clamp(.5rem, .7vw, .75rem);
	}

	.dcc-wwa-memoriam__name {
		font-size: clamp(2rem, 2.6vw, 2.75rem);
	}

	.dcc-wwa-memoriam__dates {
		font-size: clamp(1rem, 1.05vw, 1.125rem);
	}

	.dcc-wwa-memoriam__divider {
		width: clamp(40px, 3.6vw, 56px);
		height: 2.5px;
		margin: clamp(.85rem, 1.2vw, 1.25rem) 0 clamp(1rem, 1.3vw, 1.4rem);
	}

	.dcc-wwa-memoriam__role {
		font-size: clamp(.875rem, .95vw, 1.0625rem);
	}

	.dcc-wwa-memoriam__subrole {
		font-size: clamp(.875rem, .92vw, 1rem);
	}
}
