.mosaic-v5 {
	position: relative;
	margin: var(--space-8) auto 60px;
	background: var(--sw-darkblue-white-stripes);
	background-size: 30px;
	background-position: 50% 50%;
	padding: var(--space-5) 0;
}

.mosaic-v5 .header-cont {
	text-align: center;
	margin-bottom: 17px;
	padding: 0 var(--space-4);
}

.mosaic-v5 .header-cont h3 {
	font-family: var(--font-damion);
	font-size: 2.25rem;
	font-weight: var(--font-weight-normal);
	line-height: 1;
	color: var(--blue-00);
}

.mosaic-v5 .view-all {
	margin-inline: auto;
	position: relative;
	display: block;
	padding: 14.5px 35px 14.5px 14px;
	font-size: 0.8125rem;
	width: max-content;
	font-weight: var(--font-weight-semibold);
	line-height: 1;
	color: var(--sw-button-primary-color);
	text-decoration: none;
	background-color: var(--sw-button-primary-bg);
	border: var(--sw-button-primary-border);
	transition:
	color var(--transition-appendix),
	background-color var(--transition-appendix);
}

.mosaic-v5 .view-all::after {
	content: '';
    display: block;
    pointer-events: none;
    background-image: url(/includes/public/assets/shared/arrows/black-arrow.svg);
    background-repeat: no-repeat;
    background-size: cover;
    height: 14px;
    width: 15px;
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translate(0, -50%);
    transition: background-image var(--transition-appendix);
}

.mosaic-v5 .view-all:hover {
	background-color: var(--sw-button-primary-bg-hover);
	color: var(--sw-button-primary-color-hover);
	border: var(--sw-button-primary-border-hover);
}

.mosaic-v5 .view-all:hover::after {
	background-image: url(/includes/public/assets/shared/arrows/red-arrow.svg);
}

.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);
	max-width: 1200px;
	margin-inline: auto;
	margin-block-end: 20px;
}

.mosaic-v5 .slide.promoted {
	grid-column: span 2;
}

.mosaic-v5 .inner {
	position: relative;
}

.mosaic-v5 .inner .content-section {
	position: absolute;
	bottom: 13px;
	left: 10px;
	width: auto;
	max-width: calc(100% - 40px);
	pointer-events: none;
	border: solid 1px var(--black-33);
	outline: solid 1px var(--black-33);
	outline-offset: -4px;
	z-index: 2;
	transition: outline-offset var(--transition-appendix);
}

.mosaic-v5 .content-section h4 {
	font-family: var(--font-body);
	color: var(--sw-text-color);
	font-size: 0.6875rem;
	letter-spacing: 0.02rem;
	font-weight: 500;
	background-color: var(--white);
	padding: 10px 14px;
}

@media screen and (min-width: 375px) {
	.mosaic-v5 .content-section h4 {
		font-size: 0.75rem;
	}
}	

.mosaic-v5 .slide img {
	aspect-ratio: 180/160;
}

.mosaic-v5 .slide.promoted img {
	aspect-ratio: 375/196;
}

.mosaic-v5 img {
	width: 100%;
}

.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);
}

.mosaic-v5 .slide .img-cont::after { 
	content: '';
	pointer-events: none;
	position: absolute;
	left: 50%;
	top: 50%;
	translate: -50% -50%;
	display: block;
	width: 100%;
	height: 100%;
	z-index: 2;
	opacity: 0;
	background-color: var(--pink-ff);
	transition: opacity var(--transition-appendix);
}

@media (hover:hover) {
	.mosaic-v5 .slide:has(a:hover) .img-cont::after {
		opacity: 0.8;
	}
}

@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 {
		padding-block: 40px;
		margin-block-end: 110px;
	}

	.mosaic-v5 .header-cont {
		max-width: var(--width-comfortable);
		margin: 0 auto 30px;
	}

	.mosaic-v5 .header-cont h3 {
		font-size: 3.25rem;
		
	}

	.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: 40px;
	}
	
	.mosaic-v5 .slide.promoted {
		grid-row: span 2;
		grid-column: span 1;
	}

	.mosaic-v5 .content-section h4 {
		font-size: 0.9375rem;
		line-height: calc(21/15);
		padding: 14px 14px;
	}
	
	.mosaic-v5 .slide img {
		aspect-ratio: 470/248;
	}

	.mosaic-v5 .slide.promoted img {
		aspect-ratio: 460/516;
	}
}
