/**
 * EF TV Netflix - Frontend UI.
 * Version: 0.2.0
 */

.ef-tv-netflix-hero {
	position: relative;
	min-height: 86vh;
	overflow: hidden;
	background: #000;
	color: #fff;
	isolation: isolate;
}

.ef-tv-netflix-hero,
.ef-tv-netflix-hero * {
	box-sizing: border-box;
}

.ef-tv-netflix-hero__slides {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.ef-tv-netflix-hero__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity 650ms ease, visibility 650ms ease;
	pointer-events: none;
}

.ef-tv-netflix-hero__slide.is-active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.ef-tv-netflix-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center center;
	transform: scale(1.02);
	transition: transform 9000ms ease;
	z-index: 1;
}

.ef-tv-netflix-hero__slide.is-active .ef-tv-netflix-hero__bg {
	transform: scale(1);
}

.ef-tv-netflix-hero__bg--mobile {
	display: none;
}

.ef-tv-netflix-hero__shade {
	position: absolute;
	inset: 0;
	z-index: 2;
	background:
		linear-gradient(90deg, rgba(0,0,0,.9) 0%, rgba(0,0,0,.58) 34%, rgba(0,0,0,.14) 68%, rgba(0,0,0,.03) 100%),
		linear-gradient(0deg, #000 0%, rgba(0,0,0,.75) 12%, rgba(0,0,0,.16) 42%, rgba(0,0,0,.1) 100%);
}

.ef-tv-netflix-hero__content {
	position: absolute;
	z-index: 3;
	left: clamp(1.5rem, 4vw, 4.2rem);
	bottom: clamp(9.5rem, 18vh, 13.5rem);
	width: min(680px, 48vw);
	transform-origin: left bottom;
	transition: transform 520ms ease, bottom 520ms ease;
}

.ef-tv-netflix-hero__title {
	font-size: clamp(3rem, 5.6vw, 6.5rem);
	line-height: .92;
	font-weight: 800;
	margin: 0 0 1.15rem;
	letter-spacing: -.055em;
	text-shadow: 0 4px 28px rgba(0,0,0,.48);
	transition: font-size 520ms ease, transform 520ms ease, margin 520ms ease;
}

.ef-tv-netflix-hero__excerpt {
	font-size: clamp(1rem, 1.2vw, 1.25rem);
	line-height: 1.42;
	max-width: 42rem;
	margin: 0 0 1.35rem;
	color: rgba(255,255,255,.94);
	text-shadow: 0 2px 12px rgba(0,0,0,.55);
	transition: opacity 420ms ease, transform 420ms ease, max-height 420ms ease, margin 420ms ease;
}

.ef-tv-netflix-hero__actions {
	display: flex;
	gap: .75rem;
	align-items: center;
}

.ef-tv-netflix-hero__play,
.ef-tv-netflix-hero__more {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .55rem;
	min-height: 48px;
	padding: 0 1.25rem;
	border-radius: 4px;
	font-weight: 800;
	font-size: 1rem;
	line-height: 1;
	text-decoration: none;
	border: 0;
	cursor: pointer;
	transition: transform 180ms ease, background 180ms ease, opacity 180ms ease;
}

.ef-tv-netflix-hero__play:hover,
.ef-tv-netflix-hero__more:hover {
	transform: translateY(-1px);
}

.ef-tv-netflix-hero__play {
	background: #fff;
	color: #000;
}

.ef-tv-netflix-hero__play-icon {
	width: 0;
	height: 0;
	border-top: .42rem solid transparent;
	border-bottom: .42rem solid transparent;
	border-left: .7rem solid currentColor;
}

.ef-tv-netflix-hero__more {
	background: rgba(109,109,110,.72);
	color: #fff;
	backdrop-filter: blur(8px);
}

.ef-tv-netflix-hero__info-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.45rem;
	height: 1.45rem;
	border: 2px solid currentColor;
	border-radius: 999px;
	font-weight: 900;
	font-family: Georgia, serif;
	font-style: italic;
}

.ef-tv-netflix-hero.is-compact .ef-tv-netflix-hero__content {
	bottom: clamp(8rem, 15vh, 11rem);
	transform: scale(.78);
}

.ef-tv-netflix-hero.is-compact .ef-tv-netflix-hero__excerpt {
	opacity: 0;
	max-height: 0;
	margin: 0;
	transform: translateY(.45rem);
	overflow: hidden;
}

.ef-tv-netflix-hero__rail {
	position: absolute;
	z-index: 5;
	left: clamp(1.5rem, 4vw, 4.2rem);
	right: 0;
	bottom: clamp(1.25rem, 4vh, 2.4rem);
}

.ef-tv-netflix-hero__rail-title {
	font-size: clamp(1rem, 1.55vw, 1.45rem);
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 .65rem;
	color: #fff;
	text-shadow: 0 2px 12px rgba(0,0,0,.62);
}

.ef-tv-netflix-hero__rail-track {
	display: flex;
	gap: .5rem;
	overflow-x: auto;
	overflow-y: visible;
	padding: .15rem clamp(1.5rem, 4vw, 4.2rem) .35rem 0;
	scrollbar-width: none;
}

.ef-tv-netflix-hero__rail-track::-webkit-scrollbar {
	display: none;
}

.ef-tv-netflix-hero__rail-item {
	position: relative;
	flex: 0 0 clamp(150px, 15vw, 250px);
	aspect-ratio: 16 / 9;
	padding: 0;
	border: 2px solid transparent;
	border-radius: 5px;
	overflow: hidden;
	background: rgba(255,255,255,.08);
	cursor: pointer;
	transition: transform 180ms ease, border-color 180ms ease, opacity 180ms ease;
}

.ef-tv-netflix-hero__rail-item:hover,
.ef-tv-netflix-hero__rail-item.is-active {
	transform: translateY(-3px);
	border-color: rgba(255,255,255,.9);
}

.ef-tv-netflix-hero__rail-item img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media (max-width: 1024px) {
	.ef-tv-netflix-hero {
		min-height: 82vh;
	}

	.ef-tv-netflix-hero__content {
		width: min(620px, 65vw);
	}
}

@media (max-width: 767px) {
	.ef-tv-netflix-hero {
		min-height: 96vh;
	}

	.ef-tv-netflix-hero__bg--desktop {
		display: none;
	}

	.ef-tv-netflix-hero__bg--mobile {
		display: block;
		background-position: center top;
	}

	.ef-tv-netflix-hero__shade {
		background:
			linear-gradient(0deg, #000 0%, rgba(0,0,0,.92) 20%, rgba(0,0,0,.38) 56%, rgba(0,0,0,.08) 100%);
	}

	.ef-tv-netflix-hero__content {
		left: 1.1rem;
		right: 1.1rem;
		bottom: 8.5rem;
		width: auto;
	}

	.ef-tv-netflix-hero__title {
		font-size: clamp(2.35rem, 12vw, 4.4rem);
	}

	.ef-tv-netflix-hero__excerpt {
		font-size: .98rem;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.ef-tv-netflix-hero__actions {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: .65rem;
	}

	.ef-tv-netflix-hero__play,
	.ef-tv-netflix-hero__more {
		min-height: 48px;
		padding: 0 .8rem;
		font-size: .95rem;
	}

	.ef-tv-netflix-hero.is-compact .ef-tv-netflix-hero__content {
		transform: scale(.88);
		bottom: 7.6rem;
	}

	.ef-tv-netflix-hero__rail {
		left: 1.1rem;
		bottom: 1.15rem;
	}

	.ef-tv-netflix-hero__rail-track {
		padding-right: 1.1rem;
	}

	.ef-tv-netflix-hero__rail-item {
		flex-basis: 132px;
	}
}
