.mosaic-v5 {
	position: relative;
	margin: var(--space-8) auto var(--space-10);
}

.mosaic-v5::after {
	content: '';
	pointer-events: none;
	position: absolute;
	left: 50%;
	bottom: -30px;
	translate: -50% 0;
	display: block;
	width: 100%;
	height: 414px;
	background-image: url(/includes/public/assets/shared/decorations/green-pillars.svg);
	background-repeat: repeat-x;
	background-position: 50% 50%;
	background-size: 1440px;
	z-index: -1;
}

.mosaic-v5 .header-cont {
	text-align: center;
	margin-bottom: 19px;
	padding: 0 var(--space-4);
}

.mosaic-v5 .header-cont h3 {
	font-family: var(--font-dm-serif);
	font-size: 2.625rem;
	font-weight: var(--font-weight-normal);
	line-height: calc(48/42);
	margin-block-end: 13px;
}

.mosaic-v5 .header-cont .description {
	font-size: 0.875rem;
	line-height: calc(21/14);
}

.mosaic-v5 .widget-view-all {
	font-size: 1.25rem;
	padding: 10px;
	display: block;
	width: max-content;
	margin-inline: auto;
}

.mosaic-v5 .widget-view-all::after {
	border-width: 20px 0 20px 10px;
}

.mosaic-v5 .cols {
	display: grid;
	grid-template-columns: repeat(2, auto);
	grid-template-rows: repeat(3, auto);
	grid-auto-flow: row;
	gap: var(--space-2);
	margin-block-end: 20px;
	max-width: 1200px;
	margin-inline: auto;
	padding: 0 20px;
}

.mosaic-v5 .slide.promoted {
	grid-column: span 2;
}

.mosaic-v5 .inner {
	position: relative;
	box-shadow: 0px 4px 12px 0px #00000026;
}

.mosaic-v5 .inner .content-section {
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	pointer-events: none;
	width: max-content;
	display: block;
	text-align: center;
	max-width: calc(100% - 70px);
}

.mosaic-v5 .slide-title {
	font-family: var(--font-archivo-cond-semibold);
	color: var(--purple-8e);
	text-transform: uppercase;
	font-size: 0.75rem;
	font-weight: var(--font-weight-bold);
	line-height: 1;
	background-color: var(--white-fa);
	padding: 6px var(--space-3);
	border-radius: 4px;
	transition: background-color var(--transition-appendix), color var(--transition-appendix)
}

@media screen and (min-width: 375px) {
	.mosaic-v5 .inner .content-section {
		max-width: calc(100% - 80px);
	}

	.mosaic-v5 .slide-title {
		font-size: 0.875rem;
	}
}

.mosaic-v5 .slide img {
	aspect-ratio: 180/160;
}

.mosaic-v5 .slide.promoted img {
	aspect-ratio: 375/196;
}

.mosaic-v5 img {
	width: 100%;
	border-radius: 6px;
}

.mosaic-v5 .shared-play-button {
	left: unset;
	transform: unset;
	top: var(--space-2);
	right: var(--space-2);
	height: var(--space-10);
	width: var(--space-10);
	font-size: var(--text-base);
}

@media (hover:hover) {
	.mosaic-v5 .slide:has(a:hover) .slide-title {
		color: var(--black);
	}

	.mosaic-v5 .slide:nth-of-type(1):has(a:hover) .slide-title {
		background-color: var(--orange-ed);
	}

	.mosaic-v5 .slide:nth-of-type(2):has(a:hover) .slide-title {
		background-color: var(--green-a6);
	}

	.mosaic-v5 .slide:nth-of-type(3):has(a:hover) .slide-title {
		background-color: var(--teal-4f);
	}

	.mosaic-v5 .slide:nth-of-type(4):has(a:hover) .slide-title {
		background-color: var(--pink-eb);
	}

	.mosaic-v5 .slide:nth-of-type(5):has(a:hover) .slide-title {
		background-color: var(--pink-f7);
	}
}

@media (min-width: 40em) {
	.mosaic-v5 .slide img {
		aspect-ratio: 640/569;
	}

	.mosaic-v5 .slide.promoted img {
		aspect-ratio: 1024/535;
	}

	.mosaic-v5 .shared-play-button {
		height: var(--space-12);
		width: var(--space-12);
		font-size: var(--text-lg);
	}
}

@media (min-width: 64em) {
	.mosaic-v5 {
		margin-bottom: 70px;
	}
	.mosaic-v5::after {
        height: 373px;
        bottom: -120px;
        margin-block-end: 80px;
 }

	.mosaic-v5 .header-cont {
		max-width: 766px;
		margin: 0 auto 38px;
	}

	.mosaic-v5 .widget-view-all::after {
		border-width: 20px 0 20px 12px;
	}

	.mosaic-v5 .header-cont h3 {
		font-size: 4.0625rem;
	}

	.mosaic-v5 .header-cont .description {
		font-size: 1rem;
		line-height: calc(24/16);
	}

	.mosaic-v5 .cols {
		grid-template-columns: 337fr 326fr 337fr;
		grid-template-rows: repeat(2, auto);
		gap: var(--space-2);
		grid-auto-flow: column;
		margin-block-end: 41px;
	}
	
	.mosaic-v5 .slide.promoted {
		grid-row: span 2;
		grid-column: span 1;
	}

	.mosaic-v5 .slide-title {
		font-size: 20px;
		padding: 10px 19px;
	}
	
	.mosaic-v5 .slide img {
		aspect-ratio: 470/248;
	}

	.mosaic-v5 .slide.promoted img {
		aspect-ratio: 460/516;
	}
}
