/* PortalFilm Theme: production-cast — Swiper, tarjeta con imagen de fondo y overlay nombre/rol */

.pf_pfilm_template_production_single_cast {
	margin-bottom: var(--spacing-xl);
}

.pf_pfilm_template_production_single_cast_heading {
	font-size: var(--font-size-lg);
	font-weight: 600;
	margin: 0 0 var(--spacing-md);
	color: var(--color-text);
}

/* Tabs: ordenar por rol */
.pf_pfilm_template_production_single_cast_tabs {
	display: flex;
	flex-wrap: nowrap;
	gap: var(--spacing-xs);
	margin-bottom: var(--spacing-md);
	padding-bottom: var(--spacing-xs);
	border-bottom: 1px solid var(--color-border);
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.pf_pfilm_template_production_single_cast_tabs::-webkit-scrollbar {
	height: 4px;
}

.pf_pfilm_template_production_single_cast_tabs::-webkit-scrollbar-thumb {
	background: var(--color-border);
	border-radius: 2px;
}

.pf_pfilm_template_production_single_cast_tab {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-xs);
	padding: var(--spacing-sm) var(--spacing-md);
	font-size: var(--font-size-small);
	border: none;
	border-bottom: 3px solid transparent;
	margin-bottom: -1px;
	background: none;
	color: var(--color-text-secondary);
	cursor: pointer;
	transition: color var(--transition-base), border-color var(--transition-base);
}

.pf_pfilm_template_production_single_cast_tab:hover,
.pf_pfilm_template_production_single_cast_tab:focus {
	color: var(--color-text);
}

.pf_pfilm_template_production_single_cast_tab.is-active {
	color: var(--color-primary);
	border-bottom-color: var(--color-primary);
	font-weight: 600;
}

.pf_pfilm_template_production_single_cast_tab_count {
	display: inline-block;
	min-width: 1.25rem;
	padding: 0 var(--spacing-xs);
	font-size: 0.75rem;
	line-height: 1.25rem;
	text-align: center;
	background-color: var(--color-bg-surface-secondary);
	border-radius: var(--border-radius-sm);
	color: var(--color-text-secondary);
}

.pf_pfilm_template_production_single_cast_tab.is-active .pf_pfilm_template_production_single_cast_tab_count {
	background-color: var(--color-primary);
	color: var(--color-on-primary, #fff);
}

/* Swiper wrap */
.pf_pfilm_template_production_single_cast_swiper_wrap {
	position: relative;
	overflow: hidden;
	padding: var(--spacing-sm) 0 var(--spacing-xl);
}

.pf_pfilm_template_production_single_cast_swiper {
	overflow: visible;
}

.pf_pfilm_template_production_single_cast_slide {
	height: auto;
	box-sizing: border-box;
}

/* Tarjeta: imagen de fondo + overlay (nombre y rol encima) */
.pf_pfilm_template_production_single_cast_card {
	display: block;
	position: relative;
	width: 100%;
	aspect-ratio: 2 / 3;
	border-radius: var(--border-radius-md);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: box-shadow var(--transition-base);
}

a.pf_pfilm_template_production_single_cast_card:hover,
a.pf_pfilm_template_production_single_cast_card:focus {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

/* Capa de imagen de fondo (aspect-image rellena la tarjeta, img cover) */
.pf_pfilm_template_production_single_cast_card_bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.pf_pfilm_template_production_single_cast_card_bg .pf_pfilm_common_aspect_image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	aspect-ratio: unset;
}

.pf_pfilm_template_production_single_cast_card_bg .pf_pfilm_common_aspect_image_img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.pf_pfilm_template_production_single_cast_card_bg .pf_pfilm_common_aspect_image_placeholder {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

/* Overlay inferior: gradiente + nombre + rol */
.pf_pfilm_template_production_single_cast_card_overlay {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: var(--spacing-md) var(--spacing-sm) var(--spacing-sm);
	background: linear-gradient(to top, rgba(0, 0, 0, 0.85), rgba(0, 0, 0, 0.4) 60%, transparent);
	color: #fff;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.pf_pfilm_template_production_single_cast_name {
	font-size: var(--font-size-small);
	font-weight: 600;
	line-height: 1.25;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.pf_pfilm_template_production_single_cast_role {
	font-size: 0.75rem;
	line-height: 1.25;
	opacity: 0.9;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Paginación Swiper */
.pf_pfilm_template_production_single_cast_swiper .swiper-pagination {
	position: relative;
	margin-top: var(--spacing-md);
}

.pf_pfilm_template_production_single_cast_swiper .swiper-pagination-bullet {
	--swiper-pagination-bullet-inactive-opacity: 0.4;
	background: var(--color-text-secondary);
}

.pf_pfilm_template_production_single_cast_swiper .swiper-pagination-bullet-active {
	background: var(--color-primary);
}