:root {
	--color-bleu: #0097B2;
	--color-contrast: #000000
}

/* Treure els borders als enllaços */
:where(.wp-site-blocks *:focus) {
    outline-width: 0!important;
    outline-style: none!important;
}

h3 {
	font-size: 2.125rem;
	font-weight: 700;
	line-height: 1.1;
	margin: 0 0 10px;
}

p {
	max-width: 60ch;
}

.current-menu-item {
	color: var(--color-bleu);
}

.film-title {
	h1 {
		margin: 0;
	}

	h2 {
		color: var(--color-bleu);
		font-size: var(--wp--preset--font-size--x-large);
		margin: 0;
		line-height: 1.4;
	}
}

/* Shortcodes */

.ip-film-sheet {
	border-top: 1px solid #666;
}

.ip-film-sheet-section {
	border-bottom: 1px solid #666;
}

.ip-film-sheet-section summary {
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 0;
	cursor: pointer;

	&:hover .ip-film-sheet-title {
		color: var(--color-contrast);
	}
}

.ip-film-sheet-section summary::-webkit-details-marker {
	display: none;
}

.ip-film-sheet-title {
	font-size: 2.125rem;
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-bleu);
	margin: 0;
}

.ip-film-sheet-icon {
	position: relative;
	width: 34px;
	height: 34px;
	flex: 0 0 34px;
}

.ip-film-sheet-icon::before,
.ip-film-sheet-icon::after {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 34px;
	height: 1px;
	background: #666;
	transform: translateY(-50%);
}

.ip-film-sheet-icon::after {
	transform: translateY(-50%) rotate(90deg);
}

.ip-film-sheet-section[open] .ip-film-sheet-icon::after {
	opacity: 0;
}

.ip-film-sheet-content {
	padding: 0 0 24px;
	font-size: 1.125rem;
	line-height: 1.4;
}

.ip-film-sheet-content p {
	margin: 0 0 0.4em;
}

.ip-film-sheet-content ul {
	margin: 0;
	padding-left: 1.2em;
}

.ip-film-sheet-content a {
	text-decoration: underline;
}

.ip-film-directors {
	display: grid;
	grid-template-columns: 1fr 1fr;
}

.ip-film-director-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.ip-film-directors-image {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	object-fit: cover;
	margin: 0 auto 14px;
}

.ip-film-directors-image-placeholder {
	background: #d9d9d9;
}

.ip-film-director-title {
	margin: 0;
	text-align: center;
	font-size: 2rem;
	line-height: 1.1;
	color: var(--color-bleu);
	&:hover {
		color: var(--color-contrast);
	}
}

.films-loop {

	li {
		position: relative
	}

	figure {
		margin-bottom: 0;
	}

	.film-title {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		display: flex;
		justify-content: center;
		align-content: center;
		margin: 0;
		opacity: 0;
		transition: opacity 0.3s;
		background-color: #0097B288;
		color: white;
	}

	a:hover .film-title {
		opacity: 1;
	}

}

/* Lista de films en plantilla de director — [ip_director_films] */

.ip-director-films {
	border-top: 3px solid var(--color-contrast);
}

.ip-director-films-list {
	display: flex;
	flex-direction: column;
}

.ip-director-film-row {
	display: grid;
	grid-template-columns: minmax(120px, 1.1fr) 72px minmax(0, 2fr) auto;
	gap: 1.25rem 2rem;
	align-items: start;
	padding: 1.5rem 0;
	border-bottom: 1px solid #eee;

	p {
		margin: 0;
	}
}

.ip-director-film-title {
	margin: 0;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.3;
}

.ip-director-film-title-link {
	color: var(--color-contrast);
	text-decoration: none;

	&:hover {
		color: var(--color-bleu);
	}
}

.ip-director-film-year {
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--color-bleu);
}

.ip-director-film-body {
	min-width: 0;
}

.ip-director-film-excerpt {
	margin: 0 0 0.35em;
	font-size: 1rem;
	line-height: 1.45;
	color: var(--color-contrast);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.ip-director-film-meta {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.4;
	color: #888;
}

.ip-director-film-link {
	align-self: center;
	justify-self: end;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	color: var(--color-bleu);
	white-space: nowrap;

	&:hover {
		color: var(--color-contrast);
	}
}

.director-film-list {
	ul {
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex;
		gap: 10px;
	}
	li {
		margin: 0;
		padding: 0;
	}
}


@media (width < 768px) {

	a .film-title {
		opacity: 1!important;
	}

	.ip-director-film-row {
		grid-template-columns: 1fr auto;
		grid-template-areas:
			"title year"
			"body body"
			"link link";
		gap: 0.75rem 1rem;
	}

	.ip-director-film-title {
		grid-area: title;
	}

	.ip-director-film-year {
		grid-area: year;
		justify-self: end;
	}

	.ip-director-film-body {
		grid-area: body;
	}

	.ip-director-film-link {
		grid-area: link;
		justify-self: start;
		align-self: start;
	}

}