/*---------------------------------------------------------------------------------
Theme Name:   Divi Child
Theme URI:    https://www.elegantthemes.com/
Description:  Divi Child theme by Web Hors Piste
Author:       Web Hors Piste
Author URI:   https://www.webhorspiste.com/
Template:     Divi
Version:      1.0.0
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
------------------------------ ADDITIONAL CSS HERE ------------------------------*/
body.et_pb_recaptcha_enabled .grecaptcha-badge { 
    visibility: hidden;
}

/* ============================================================================
* GLOBAL
* */
#main-content {
	background-color: transparent;
}

body .center-icon-resume .et_pb_main_blurb_image {
	vertical-align: middle;
}

body .align-vertical {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}

/* ============================================================================
* FOOTER
* */

.bottom-footer .et_pb_column{
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
}
@media (max-width: 767px) {
	.bottom-footer .et_pb_column{
		flex-direction: column;
	}
}
.bottom-footer .et_pb_column .et_pb_text_inner{
	display: flex;
}
.bottom-footer .logo-whp{
	margin-right: 10px;
}
/* ============================================================================
* HEADER
* */
header .et_pb_menu__wrap {
	flex-wrap: nowrap !important;
}

header .et_pb_menu__wrap .et_pb_menu__icon {
	min-width: 40px;
	justify-content: center;
	font-weight: bolder;
}

header .header-section {
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	transition: all 0.3s ease;
	border-width: 0;
}

header.scroll .header-section {
	background-color: #0a0a0a !important;
	/*box-shadow: 0 2px 10px rgba(255,255,255,0.1);*/
	border-width: 1px;
}

header .et_pb_menu__logo-wrap {
	margin: 5px 0;
}
header .et_pb_menu__menu,header .et_pb_menu__menu .et-menu-nav, header .et_pb_menu__menu .et-menu-nav ,header .et_pb_menu__menu .et-menu-nav #menu-header,header .et_pb_menu__menu .et-menu-nav #menu-header-english{
	width:100%;
}
header.scroll .header-section #menu-header>li>a,header.scroll .header-section #menu-header-english>li>a {
	padding: 20px 0;
}
header #menu-header li.menu-item-820, header #menu-header-english li.menu-item-1213{
	margin-left: auto !important;
	align-items: center;
}
body header #menu-header .menu-account-icon a,body header #menu-header-english .menu-account-icon a{
	padding: 6px 24px!important;
	background-color: white;
	color: black !important;
	border-radius: 9999px;
	letter-spacing: 1px;
	line-height: 15px;
}
/*
header .menu-account-icon a {
font-size: 0 !important;
position: relative;
padding-left: 10px !important;
padding-right: 10px !important;
display: flex;
}

header .menu-account-icon a:before {
content: "\e08a";
font-family: "ETmodules";
font-size: 20px;
display: flex;
align-items: center;
justify-content: center;
}*/

/* Responsive header */

@media (max-width: 980px) {
	body.no-scroll {
		overflow: hidden;
	}

	#header-section .et_pb_menu__logo-wrap {
		z-index: 999999;
		max-width: 170px;
	}

	#header-section .mobile_nav .mobile_menu_bar {
		z-index: 999999;
	}

	#header-section .mobile_nav .mobile_menu_bar:before {
		font-size: 40px;
		top: unset;
	}

	#header-section:not(.scrolled) .mobile_nav .mobile_menu_bar:before {
		color: white;
	}

	#header-section .mobile_nav.opened .mobile_menu_bar:before {
		content: '\4d';
		color: white;
	}

	#mobile_menu1 {
		position: fixed;
		top: 0;
		bottom: 0px;
		max-height: 100% !important;
		padding-top: 100px;
		background-color: black !important;
	}

	body.logged-in.admin-bar #mobile_menu1 {
		padding-top: calc(100px + 32px);
	}

	#mobile_menu1>li>a {
		padding-top: 15px;
		padding-bottom: 15px;
	}

	#mobile_menu1>li>span.submenu-toggle {
		background-color: rgb(0 120 182 / 30%);
		font-weight: 700;
		font-size: 20px;
		letter-spacing: 1px;
		padding: 15px 5%;
		border-bottom: 1px solid rgba(250, 250, 225, .1);
		display: block;
		cursor: pointer;
		position: relative;
	}

	#mobile_menu1>li>ul.sub-menu {
		max-height: 0;
		overflow: hidden;
		transition: all 0.5s ease;
		background-color: transparent !important
	}

	#mobile_menu1>li>ul.sub-menu>li>a {
		font-size: 17px;
		color: white !important;
	}

	#mobile_menu1 .submenu-toggle::after {
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
		transition: transform 0.3s ease;
		content: "+"
	}

	#mobile_menu1 li.open>.submenu-toggle::after {

		content: "-";
	}

	header .menu-account-icon a {
		padding-left: 5% !important;
		padding-right: 5% !important;
	}

	header .menu-account-icon a:before {
		justify-content: left;
	}
}

/* ============================================================================
* PAGE ACCUEIL
* */
body.home .section-video {
	display: flex;
}

body.home .section-video #mep_0 {
	mask-image: linear-gradient(rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.8));
}

body.home .services-home {
	display: grid;
	/*grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));*/
	grid-template-columns: repeat(5, calc(20% - 12px));
	gap: 15px;
}

@media (max-width: 981px) {
	body.home .services-home {
		grid-template-columns: 50% 50%;
	}
}

@media (max-width: 600px) {
	body.home .services-home {
		grid-template-columns: 100%;
	}
}

body.home .services-home .et_pb_column {
	width: 100%;
	margin: 0 !important
}

body.home .services-home:after {
	display: none;
}

body.home .services-home .et_pb_column .et_pb_blurb {
	height: 100%;
	display: flex;
	align-items: center;
}

body .services-home .et_pb_blurb {
	transition: all 0.3s ease;
}

body .services-home .et_pb_blurb:hover {
	transform: translateY(-6px);
	box-shadow: 0 25px 60px rgba(255, 255, 255, 0.15);
}

/* --- Marquee partenaires logo --- */
.logos-marquee {
	overflow: hidden;
	padding: 30px 0;
}

.logos-track {
	display: flex;
	gap: 120px;
	align-items: center;
	width: max-content;
	animation: logos-scroll 60s linear infinite;
}

.logos-marquee:hover .logos-track {
	animation-play-state: paused;
}

.logo-item {
	width: 120px;
	height: 120px;
	background: #ffffff;
	border-radius: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 15px;
	box-shadow: 0 4px 10px rgba(255, 255, 255, 0.05);

	opacity: 0.7;
	filter: grayscale(100%);
	transition: all .3s ease;
}

.logo-item:hover {
	opacity: 1;
	filter: grayscale(0);
	transform: translateY(-5px);
	box-shadow: 0 4px 10px rgba(255, 255, 255, 0.3);
}

.logo-item img {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	object-fit: contain;

}


@keyframes logos-scroll {
	from {
		transform: translateX(0);
	}

	to {

		transform: translateX(calc(-50% - 60px));
	}
}

/* ============================================================================
* PAGE SERVICES
* */
/*Services liste */
body .services-list .et_pb_column {
	display: grid;
	grid-template-rows: 50% 50%;

}

body .services-list .et_pb_blurb {
	transition: all 0.3s ease;
	cursor: pointer;
}

body .services-list .et_pb_blurb:hover {
	transform: translateY(-6px);
	/*	border-color: rgba(255,255,255,0.15);*/
	box-shadow: 0 25px 60px rgba(255, 255, 255, 0.15);
}

body .services-list .et_pb_blurb .arrow {
	opacity: 0;
	margin-left: 0px;
	transition: all 0.3s ease;
	font-size: 30px;
}

body .services-list .et_pb_blurb:hover .arrow {
	opacity: 1;
	margin-left: 10px;
}

/* Music licensing */
body .tarif-licensing hr {
	border-color: hsl(0deg 0% 100% / 10%);
	margin-bottom: 1.5em;
}

/* ============================================================================
*  PAGE WORKS
* */
/*--- GALLERIE VIDEO DESIGN */
body .pfg-bootstrap .thumbnail {
	border-radius: 0px;
}

body .pfg-bootstrap figure .item-desc {
	background-color: transparent;
	font-weight: bold;
	top: 15% !important;
	bottom: unset !important;
	transform: translateY(-10px);

	/*font-family: 'Montserrat Alternates';*/
	z-index: 2;
	opacity: 0 !important;
	transition: all 0.5s ease-out;
}

body .pfg-bootstrap figure:hover .item-desc {
	display: block !important;
	opacity: 1 !important;
	transform: translateY(0px);
}

body .pfg-bootstrap figure .item-desc-text {
	bottom: 20% !important;
	transform: translateY(10px);
	position: absolute;
	left: 0;
	right: 0;
	text-align: center;

	/*font-family: 'Montserrat';*/
	font-size: 15px;
	z-index: 2;
	opacity: 0 !important;
	transition: all 0.5s ease-out;
}

body .pfg-bootstrap figure:hover .item-desc-text {
	display: block !important;
	opacity: 1 !important;
	transform: translateY(0px);
}

body .pfg-bootstrap figure i {
	opacity: 0 !important;
	z-index: 2;
	transition: opacity 0.5s ease-out, background-color 0.5s ease-out;

	left: 50%;
	top: 50%;
	right: unset;
	transform: translateX(-50%) translateY(-50%);
}

body .pfg-bootstrap figure:hover i {
	opacity: 1 !important;
}

body .pfg-bootstrap figure i img {
	max-width: 50px;
}

body .pfg-bootstrap .item-position {
	opacity: 0;
	pointer-events: none;
	z-index: 1;
	top: 0 !important;
	bottom: 0;
	left: 0 !important;
	right: 0 !important;
	background-color: rgba(0, 0, 0, 0);
	color: transparent !important;
	transition: opacity 0.5s ease-out, background-color 0.5s ease-out;
}

body .pfg-bootstrap figure:hover .item-position {
	opacity: 1;
	pointer-events: auto;
	background-color: rgba(0, 0, 0, 0.6);
}

body .pfg-bootstrap .filtr_search {
	display: none;
}

/* ============================================================================
* PORTFOLIO FILTER GALLERY - Filtres modernes (parents + enfants)
* ============================================================================ */

/* Conteneur parents : flex centré avec retour à la ligne automatique */
body #f-simplefilter-112 {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	column-gap: 10px;
	row-gap: 8px;
	padding: 0 10px !important;
	margin-bottom: 0;
}

/* Boutons parents : style pill moderne + flèche vers le bas à droite */
#f-simplefilter-112 li.filtr-controls-112 {
	display: inline-block;
	padding: 10px 20px 10px 20px;
	margin: 0;
	font-size: 0.95rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	text-transform: none;
	color: rgba(255, 255, 255, 0.85)!important;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 9px;
	cursor: pointer;
	transition: color 0.25s ease, background 0.25s ease, border-color 0.25s ease, transform 0.2s ease;
	list-style: none;
	position: relative;
}
#f-simplefilter-112 li.filtr-controls-112.pfg-has-children {
	padding: 10px 28px 10px 20px;
}

/* Parent ayant une sous-catégorie active : fond légèrement accentué (sans icône supplémentaire) */
#f-simplefilter-112 li.filtr-controls-112.pfg-parent-has-active-child {
	background: rgb(255 255 255 / 30%);
	border-color: rgba(255, 255, 255, 0.28);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
}

/* Flèche vers le bas uniquement pour les catégories parentes qui ont des enfants */
#f-simplefilter-112 li.filtr-controls-112.pfg-has-children::after {
	content: '▾';
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 0.65rem;
	opacity: 0.7;
	transition: opacity 0.2s ease;
}

#f-simplefilter-112 li.filtr-controls-112.pfg-has-children:hover::after,
#f-simplefilter-112 li.filtr-controls-112.pfg-has-children.active::after {
	opacity: 1;
}

#f-simplefilter-112 li.filtr-controls-112:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.25);
	transform: translateY(-1px);
}

#f-simplefilter-112 li.filtr-controls-112.active {
	color: #fff!important;
	background: rgba(255, 255, 255, 0.18);
	border-color: rgba(255, 255, 255, 0.35);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
}

/* Liste enfants : bloc distinct sous les parents (desktop et tablette) */
ul.pfg-children {
	margin: 12px auto 24px;
	padding: 18px 14px 10px;
	max-width: 1100px;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	column-gap: 10px;
	row-gap: 10px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	position: relative;
	max-width: fit-content;
}
/* Petit label "Sous-catégories" au-dessus des enfants */
ul.pfg-children::before {
	content: 'Sous-catégories';
	position: absolute;
	top: -9px;
	left: 12px;
	padding: 0 6px;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	background: #0a0a0a;
	color: rgba(255,255,255,0.6);
}
/* Boutons enfants : pills plus discrets, alignés sur le style parent */
ul.pfg-children li.pfg-child-filter {
	display: inline-block;
	padding: 6px 16px;
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: rgba(255, 255, 255, 0.8)!important;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 999px;
	cursor: pointer;
	transition: color 0.25s ease, background 0.25s ease, border-color 0.25s ease, transform 0.2s ease;
	position: relative;
}

ul.pfg-children li.pfg-child-filter:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.2);
	transform: translateY(-1px);
}

ul.pfg-children li.pfg-child-filter.active {
	color: #fff;
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.28);
}




/* Pas d'icône sur les boutons enfants */
ul.pfg-children li.pfg-child-filter::before {
	content: none;
	display: none;
}

/* ===========================
Portfolio filters – mobile
=========================== */
@media (max-width: 980px) {

	/* Parents : même layout flex, juste plus de marge verticale */
	#f-simplefilter-112 {
		padding: 4px 16px !important;
	}

	#f-simplefilter-112 li.filtr-controls-112 {
		margin-bottom: 6px;
	}

	/* Bloc enfants : marges/paddings un peu resserrés */
	ul.pfg-children {
		/* margin: 10px 12px 16px; */
		padding: 16px 10px 8px;
		/* justify-content: flex-start; */
		column-gap: 6px;
		row-gap: 6px;
		max-width: 95%;
	}

	ul.pfg-children li.pfg-child-filter {
		font-size: 0.8rem;
		padding: 5px 12px;
	}
}
.filter_gallery_112{
	margin-top: 10px;
}
/* ============================================================================
* PAGE TALENTS
* */
.talent-list .et_pb_salvattore_content {
	display: grid;
	grid-template-columns: 33.33% 33.33% 33.33%;
}

.talent-list .et_pb_salvattore_content>.column {
	display: flex;
	flex-direction: column-reverse;
}

.talent-list .et_pb_salvattore_content>.column:nth-child(1) {
	order: 3;
}

.talent-list .et_pb_salvattore_content>.column:nth-child(2) {
	order: 2;
}

.talent-list .et_pb_salvattore_content>.column:nth-child(3) {
	order: 1;
}

@media (max-width: 981px) {
	.talent-list .et_pb_salvattore_content {
		grid-template-columns: 50% 50%;
	}
}

@media (max-width: 767px) {
	.talent-list .et_pb_salvattore_content {
		grid-template-columns: 100%;
	}
}

.talent-list .et_pb_salvattore_content>.column {
	width: 100% !important;
	margin: 0 !important;
}

.et_pb_post.talent {
	overflow: hidden;
	position: relative;
	padding: 0;
	margin: 0 !important;
}

.et_pb_post.talent .entry-title {
	position: absolute;
	bottom: 15%;
	left: 50%;
	transform: translateX(-50%);
}

.et_pb_post.talent .entry-title a {
	text-wrap: nowrap;

}

.et_pb_post.talent .et_pb_image_container,
.et_pb_post.talent .et_pb_image_container a {
	margin: 0;
	border: 0;
}

.et_pb_post.talent img {
	aspect-ratio: 3/2;
	object-fit: cover;
	transition: 0.4s ease;
}

.et_pb_post.talent:hover img {
	transform: scale(1.05);
}
/*TALENTS V2 */

.talents-ligne .et_pb_blurb_content{
	max-width:100%;
}
.talents-ligne .et_pb_main_blurb_image{
	margin-bottom:0px;
	display:block!important;
}
.talents-ligne .et_pb_blurb_container{
	position: absolute;
	bottom: 15%;
	left: 50%;
	transform: translateX(-50%);
	width: 100% !important;
}

/* ============================================================================
* PAGE TALENT TEMPLATE DETAIL
* */

.talent-hero {
	align-items: center;
	display: flex;
}

@media (max-width: 767px) {
	.talent-hero {
		flex-direction: column;
	}
}

.talent-hero .et_pb_column:last-child .et_pb_image_wrap img {
	mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 100%);
}

.description-talent .et_pb_text_inner {
	white-space: pre-line;
}

.talent-music {}

/* ============================================================================
* BOUTON SCROLL TO TOP
* */
#scrollTopBtn {
	position: fixed;
	bottom: 30px;
	right: 30px;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: #111116;
	color: #fff;
	font-size: 25px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: all .35s ease;
	box-shadow: 0 6px 20px rgba(255, 255, 255, 0.2);
	z-index: 999;
	border: 2px solid rgba(255, 255, 255, 0.2);
}

#scrollTopBtn.show {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

#scrollTopBtn:hover {
	background: rgba(255, 255, 255, 0.2);
	transform: translateY(-3px);
	box-shadow: 0 10px 30px rgba(255, 255, 255, 0.5);

}

