.article-body .article-media.width--full figure {
	width: 100%;
	max-width: 100%;
	margin-inline: 0;
	margin-block: 0;
	display: block;
	justify-self: stretch;
}

.article-body .article-media.width--full figure img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
}

.article-body .article-media .article-media {
	display: contents;
}

.article-body .article-media.width--full,
.article-body .article-media.parallax-wrapper {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	overflow: hidden;
}

.article-body .article-media.width--full:not(.parallax-wrapper) > figure > figcaption {
	max-width: min(var(--prose-max, 56ch), 100% - var(--grid-margin, 1.5rem) * 2);
	margin-inline: auto;
}

@media (width <= 48rem) {
	.article-body .article-media.width--full figure img {
		border-radius: 0;
	}
}

.article .parallax {
	background-image: var(--background-image);
	background-color: hsl(var(--body-bg)/1);
	aspect-ratio: 16/9;
	background-attachment: fixed;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	margin: 0;
	width: 100%;
	display: block;
	position: relative;
}

.article .parallax > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0;
	pointer-events: none;
}

@media (pointer: coarse) {
	.article .parallax {
		background-attachment: scroll;
	}
}

.article .parallax > figcaption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.5em 1em;
	background: linear-gradient(transparent, rgba(0,0,0,0.6));
	color: #fff;
	font-size: 0.875em;
	opacity: 1;
}
