/*
	Theme Name: 117 records 2025
		Theme URI: http://html5blank.com
	Description: HTML5 Blank WordPress Theme
	Version: 1.4.3
	Author: Todd Motto (@toddmotto)
	Author URI: http://toddmotto.com
	Tags: Blank, HTML5, CSS3

	License: MIT
	License URI: http://opensource.org/licenses/mit-license.php
*/

/*------------------------------------*\
	MAIN
\*------------------------------------*/

/* global box-sizing */
*,
*:after,
*:before {
	-moz-box-sizing:border-box;
	box-sizing:border-box;
	-webkit-font-smoothing:antialiased;
	font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
}

/* Styling Wide and Full-Width Gutenberg Blocks in WordPress */
body {
	overflow-x: hidden;
}

body {
	font-family: 'Inter Tight', sans-serif;
	font-weight: 400;
	font-size: 16px;
	color: #ffffff;
	line-height: 1.5;
	background-color: #000000;
}

/* clear */
.clear:before,
.clear:after {
	content: ' ';
	display: table;
}

.clear:after {
	clear: both;
}

.clear {
	*zoom: 1;
}

img {
	max-width: 100%;
	vertical-align: bottom;
	height: auto;
}

a {
	color: #0085ca;
	text-decoration: none;
}

a:hover {
	color: #0085ca;
}

a:focus {
	outline: 0;
}

a:hover,
a:active {
	outline: 0;
}

input:focus {
	outline: 0;
	border: 1px solid #04A4CC;
}


ul.liste-apropos {
  list-style: none;
  margin: 0;
  padding: 0;
  list-style-type: none;
}

ul.liste-apropos li {
  margin: 0;
  padding: 0;
  text-indent: 0;
}

.tight-semibold {
  font-family: 'Inter Tight', sans-serif;
  font-weight: 600;
}


/*------------------------------------*\
	STRUCTURE
\*------------------------------------*/

/* wrapper */
.wrapper {
	/* max-width: 1280px; */
	width: 95%;
	margin: 0 auto;
	position: relative;
}

.wrapper-large {
	max-width: 2400px;
	width: 95%;
	margin: 0 auto;
	position: relative;
}

/* header */
.header {
}

/* logo */
.logo {
}

.logo-img {
}

/* nav */
nav {
	font-family: 'Inter', sans-serif;
	font-weight: 500;
	font-size: 20px;
	height: initial;
	color: #fff;
	background-color: transparent !important; /* Override MaterializeCSS */
	width: 100%;
	line-height: 136px;
	height: 136px  !important;
	box-shadow: none;
}


@media screen and (max-width: 992px) {
  nav {
	height: 60px !important;
	line-height: 60px !important;
  }
}



.transparent-nav {
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0)); /* Top darker, bottom transparent */

	box-shadow: none;
	transition: background-color 0.3s ease;
}

.transparent-nav.scrolled {
	background-color: #000000 !important; /* Override MaterializeCSS */
}

nav ul a {
	font-weight: 500;
	color: #ffffff;
	text-transform: none;
	font-size: 20px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	padding: 0 25px;
}

nav ul a.dropdown-trigger {
	padding: 0 4px 0 12px;
}

nav ul a i.right {
	margin-left: 0;
}

.navbar-fixed {
	margin-bottom: 8px;
}


/* Make the current nav item bold in the desktop navbar */
ul.topmenu.right.hide-on-med-and-down li.current-menu-item a {
	font-weight: bold;
}

/* Make the current nav item bold in the sidenav */
ul#slide-out.sidenav li.current-menu-item a {
	font-weight: bold;
}


nav ul li.active{background: none;}

nav ul a:hover {color: #ffffff}

img.nav-logo {
	vertical-align: middle;
	height: 50px;
}

/* Ensure the menu floats right */
ul.topmenu.right.hide-on-med-and-down {
	float: right;
	margin: 0; /* Reset any default margins */
}

/* Position the 117 logo to the right of the menu */
.117-logo.right.hide-on-med-and-down {
	float: right;
	margin-right: 15px; /* Space between the 117 logo and the hamburger menu or edge */
	line-height: 56px; /* Align vertically with the navbar */
}

img.logo-117 {
	width: 55px !important; /* Maintain requested width */
	height: auto; /* Maintain aspect ratio */
	vertical-align: middle;
}

@media screen and (max-width: 600px) {
	img.nav-logo {
		vertical-align: middle;
		height: 30px;
		/* width: 60px; */
		
	}
}

a.sidenav-trigger {
	color: #ffffff;
}

a.sidenav-trigger.right {
	float: right;
}

ul.topmenu {
	margin-block-start: 0em;
	margin-block-end: 0em;
	margin-inline-start: 0px;
	margin-inline-end: 0px;
	padding-inline-start: 0px;
}

.topmenu-extra a .fab {
	font-size: 18px;
	margin-left: 6px;
	margin-right: 6px;
}

nav i.material-icons.mysearch {
	display: inline-block;
	vertical-align: middle;
	margin-left: 5px;
}

.topmenu-extra {
	color: #ffffff;
	margin-left: 10px;
}

.topmenu-extra a {
	color: #ffffff;
}

.nav-inner-wrapper {
	/* max-width: 1280px; */
	width: 95%;
	margin: 0 auto;
}

.nav-sep {
	font-size: 19px;
	display: inline-block;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	margin-left: 10px;
	margin-right: 10px;
}

/* Sous menu */
ul.dropdown-content {
	background-color: #000000;
	padding: 0;
	margin: 0;
}

.dropdown-content li > a, .dropdown-content li > span {
	font-size: 14px;
	color: #ffffff;
}






/* Menu sidenav responsive */

.sidenav ul a
{
  all: unset;
  display: block;
  color: white;
  font-size: 14px;
  text-transform: uppercase;
  margin-bottom: 6px;
  cursor: pointer;
}





.sidenav {
	background-color: #000000;
	width: 100%;
	max-width: 320px;
}

.sidenav li > a {
	font-family: 'Inter', sans-serif;
	font-weight: 500;
	font-size: 16px;
	padding: 0 0 0 0;
	text-transform: none;
	height: 36px;
	line-height: 36px;
	color: #ffffff;
}

.sidenav li > a:hover {
	background-color: transparent;
}

.sidenav li.nolink > a {
	cursor: default;
}

ul.children {
	margin-left: 10px;
	padding-left: 0;
}

.sidenav ul.children li > a {
	text-transform: none;
	padding-left: 10px;
	color: #ffffff;
}

a.sidenav-close {
	color: #ffffff;
	padding-left: 16px;
}

@media only screen and (min-width: 530px) {
	.sidenav {
		max-width: 480px;
	}
}


.sidenav .social-side {
	margin: 30px 16px 0 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding-top: 20px;
}



.sidenav .social-side a {
  all: unset;
  display: block;
  color: white;
  cursor: pointer;
}


.sidenav .social-side a {
	display: block;
	margin-bottom: 0px; /* réduit le spacing */
	margin: 0px;
	padding: 0px;
	font-size: 12px;
	color: #ffffff;
	text-decoration: none;
	text-transform: uppercase;

	transition: color 0.2s ease;
	line-height: 28px;
}

.sidenav .social-side a:hover {
	color: #589DDD;
}

/* Conteneur du logo dans la sidenav */
.sidenav .wrapper-logo-menu {
	padding: 0 !important;
	margin: 0 !important;
}

/* Lien contenant le logo */
.sidenav .wrapper-logo-menu a {
	display: block !important;
	padding: 0 !important;
	margin: 0 !important;
	text-align: left;
}

/* Image du logo */
.sidenav .wrapper-logo-menu img {
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	max-width: 100%;
	height: auto;
}
.sidenav > li:first-child {
	margin-bottom: 20px !important;
}



/* Supprimer le padding implicite du ul juste pour le premier élément (logo) */
#slide-out {
	padding-inline-start: 0 !important;
}

/* Supprime toute indentation du li du logo */
#slide-out > li:first-child {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* Supprime toute marge du wrapper */
#slide-out > li:first-child .wrapper-logo-menu {
	margin: 0 !important;
	padding: 0 !important;
}

/* Supprime tout décalage de l’image */
#slide-out > li:first-child .wrapper-logo-menu a,
#slide-out > li:first-child .wrapper-logo-menu img {
	margin-left: 0 !important;
	padding-left: 0 !important;
	display: block;
}


.sidenav .wrapper-logo-menu a {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* Empêche les règles globales de s'appliquer au logo */
.sidenav .wrapper-logo-menu a {
	padding: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin: 0 !important;
	display: block;
	text-align: left;
}
/* Corrige le padding hérité par le lien logo dans la sidenav uniquement */
.sidenav .wrapper-logo-menu a {
	padding-left: 0 !important;
	padding-right: 0 !important;
}


#slide-out > li:first-child .wrapper-logo-menu a {
	transform: translateX(-21px);
	margin-bottom: 20px  !important;
}



.sidenav .wrapper-logo-menu.117 a {
	display: block;
	margin-left: 20px !important;
}


/* END Menu sidenav responsive */










ul.sub-menu li > a {
	text-transform: none;
	height: 36px;
	line-height: 36px;
	color: #ffffff;
}

ul.sub-menu {
	margin-bottom: 20px;
}



.social-side {
	padding-left: 26px;
	margin-top: 10px;
}

.social-side.nopad {
	padding-left: 0;
}

.social-side a:hover {
	background-color: initial;
}

ul.social-sidemenu {
	padding-left: 4px;
}

ul.social-sidemenu li > a > i {
	margin: 0 15px 0 0;
}

ul.social-sidemenu {
	line-height: 12px;
}

ul.social-sidemenu li {
	display: inline-block;
	line-height: inherit;
	font-size: inherit;
}

.courriel-menu {
	padding: 0 0 0 22px;
}

.courriel-menu a:hover {
	background-color: initial;
}

.courriel-menu a {
	color: #ffffff;
	font-size: 12px;
}

.courriel-menu a:hover {
	color: #ffffff;
}

nav, nav .nav-wrapper i, nav a.sidenav-trigger, nav a.sidenav-trigger i {
	height: initial;
}

/* sidebar */
.sidebar {
}

/* footer */
.footer {
	background-color: ##171718;
	color: #ffffff;
	padding: 20px 0px;
}

.footer a {
	color: inherit;
}

.social-footer {
	font-size: 18px;
}

.social-footer a {
	margin-left: 4px;
	margin-right: 4px;
}

@media only screen and (min-width: 680px) {
	.footer {
		padding: 50px 0px 30px 0px;
	}
}

p.contact-footer {
	font-size: 12px;
	font-weight: 300;
	margin-top: 40px;
}

.btn-large:hover {
	color: #fff;
}


.dark-btn {
	font-size: 12px;
	font-weight: 400;
	color: #ffffff;
	background-color: rgba(58, 58, 58, 0.61);
	padding: 8px 32px;
	border-radius: 999px;
	text-decoration: none;
	display: inline-block;
	transition: background-color 0.3s ease;
}

.dark-btn:hover {
	background-color: #1e1e1e;
	color: #ffffff;
}



/*------------------------------------*\
	Parallax
\*------------------------------------*/
.parallax-container {
	height: 110px;
}

@media only screen and (min-width: 321px) {
	.parallax-container {
		height: 150px;
	}
}

@media only screen and (min-width: 680px) {
	.parallax-container {
		height: 250px;
	}
}

@media only screen and (min-width: 880px) {
	.parallax-container {
		height: 460px;
	}
}

/*------------------------------------*\
	Materialize modifications
\*------------------------------------*/
input:not([type]):focus:not([readonly]), input[type=text]:not(.browser-default):focus:not([readonly]), input[type=password]:not(.browser-default):focus:not([readonly]), input[type=email]:not(.browser-default):focus:not([readonly]), input[type=url]:not(.browser-default):focus:not([readonly]), input[type=time]:not(.browser-default):focus:not([readonly]), input[type=date]:not(.browser-default):focus:not([readonly]), input[type=datetime]:not(.browser-default):focus:not([readonly]), input[type=datetime-local]:not(.browser-default):focus:not([readonly]), input[type=tel]:not(.browser-default):focus:not([readonly]), input[type=number]:not(.browser-default):focus:not([readonly]), input[type=search]:not(.browser-default):focus:not([readonly]), textarea.materialize-textarea:focus:not([readonly]) {
	border-bottom: 1px solid #2a2b30;
	-webkit-box-shadow: 0 1px 0 0 #2a2b30;
	box-shadow: 0 1px 0 0 #2a2b30;
}

.tg-search-holder input:not([type]):focus:not([readonly]), 
.tg-search-holder input[type=text]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=password]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=email]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=url]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=time]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=date]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=datetime]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=datetime-local]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=tel]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=number]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder input[type=search]:not(.browser-default):focus:not([readonly]), 
.tg-search-holder textarea.materialize-textarea:focus:not([readonly]) {
	border-bottom: 0px solid #2a2b30;
	-webkit-box-shadow: 0 0px 0 0 #2a2b30;
	box-shadow: 0 0px 0 0 #2a2b30;
}

/*------------------------------------*\
   collapsible
\*------------------------------------*/
ul.collapsible {
	list-style-type: none;
	padding-left: 0;
}

.collapsible {
	border-top: 1px solid #ddd;
	border-right: 1px solid #ddd;
	border-left: 1px solid #ddd;
	margin: 0.5rem 0 1rem 0;
}

.collapsible-header {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
	line-height: 1.5;
	padding: 1rem;
	background-color: #fff;
	border-bottom: 1px solid #ddd;
}

.collapsible-header:focus {
	outline: none;
}

.collapsible-header i {
	width: 1.5rem;
	font-size: 24px;
	display: inline-block;
	text-align: center;
	margin-right: 1rem;
}

.collapsible-body {
	display: none;
	border-bottom: 1px solid #ddd;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 2rem;
}

.collapsible {
	border: none;
	box-shadow: none;
	-webkit-box-shadow: none;
}

.collapsible-header {
	font-size: 32px;
	font-weight: 600 !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background: transparent;
	color: #202124;
}

.collapsible-header.small {
	font-size: 24px;
	line-height: 1.2;
}

@media only screen and (max-width: 680px) { 
	.collapsible-header {
		font-size: 20px;
		padding: 1rem 0rem;
	}
	.collapsible-header i {
		margin-right: 0.8rem;
	}
	.collapsible-body img {
		display: none;
	}
	.collapsible-body {
		padding: 1rem 0rem;
	}
}

.liens-ext a.btn {
	margin-bottom: 10px;
}

.iconadd {
	display: inline-block;
}

.iconremove {
	display: none !important;
}

li.active .collapsible-header .material-icons.iconadd {
	display: none;
}

li.active .collapsible-header .material-icons.iconremove {
	display: inline-block !important;
}

.collapsible li.disabled .collapsible-body {
	display: none !important;
}

.collapsible li.disabled .collapsible-header {
	color: rgba(175, 175, 175, .7);
	pointer-events: none;
}

.collapsible li.disabled:hover {
	cursor: default;
}

.collapsible-header small {
	font-size: 70%;
}

/*------------------------------------*\
	TYPOGRAPHY
\*------------------------------------*/
.small {
	font-family: 'Inter', sans-serif;
	font-weight: 400;
	font-size: 14px;
}

p.lead {
	font-size: 24px;
}

h1.hero-title {
	text-transform: none;
	text-shadow: 4px 2px 8px black;
	color: #f9f9f9;
	font-weight: 600;
	text-align: center;
	line-height: 1.3;
}

@media only screen and (min-width: 1px) {
	h1.hero-title {
		font-size: 18px;
	}
}

@media only screen and (min-width: 321px) {
	h1.hero-title {
		font-size: 21px;
	}
}

@media only screen and (min-width: 680px) {
	h1.hero-title {
		font-size: 36px;
	}
}

@media only screen and (min-width: 880px) {
	h1.hero-title {
		font-size: 48px;
	}
}




h1 {
	font-family: 'Anton', sans-serif;
	font-weight: 400;
	font-size: 100px;
	line-height: 105px;
	color: #ffffff;
	text-transform: uppercase;
}


.nouvelles h1 {
	font-family: 'Anton', sans-serif;
	font-weight: 400;
	font-size: 45px;
	line-height: 55px;
	color: #ffffff;
	text-transform: uppercase;
}

/* Media query for mobile devices (e.g., screens smaller than 768px) */
@media (max-width: 768px) {
	h1 {
		font-size: 14vw; 
		line-height: 14vw; /* Maintains proportion with font-size */
	
		/* margin: 0 auto;  */
	}
}




h1 a, h1 a:hover {
	color: #ffffff;
}

h2 a, h2 a:hover {
	color: #ffffff;
}

h3 a, h3 a:hover {
	color: #ffffff;
}

h2 {
	font-family: 'Inter Tight', sans-serif;
	font-weight: 400;
	font-size: 35px;
	line-height: 38px;
	color: #ffffff;
}

h3 {
	font-family: 'Inter Tight', sans-serif;
	font-weight: 400;
	font-size: 22px;
	line-height: 28px;
	color: #ffffff;
}


h6 {
	font-family: 'Inter Tight', sans-serif;
	font-weight: 600;
	font-size: 22px;
	line-height: 25px;
	color: #ffffff;
}


@media only screen and (min-width: 600px) {
	h2 {
		font-size: 35px;
	}
}

@media only screen and (max-width: 600px) {
	h2 {
		margin-top: 1rem;
	}
}

@media only screen and (max-width: 600px) {
	.wp-block-spacer {
		height: 20px !important;
	}
}


#flex-hero {
	height: 90%; 
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

/*------------------------------------*\
	RESPONSIVE
\*------------------------------------*/
@media only screen and (min-width: 960px) {
	.alignwide, .alignfull {
		width: 100vw;
		max-width: 100vw;
		margin-left: calc(50% - 50vw);
	}
}

@media only screen and (min-width: 320px) {
}

@media only screen and (min-width: 480px) {
}

@media only screen and (min-width: 768px) {
}

@media only screen and (min-width: 1024px) {
}

@media only screen and (min-width: 1140px) {
}

@media only screen and (min-width: 1280px) {
}

@media only screen and (-webkit-min-device-pixel-ratio: 1.5),
	   only screen and (min-resolution: 144dpi) {
}

/*------------------------------------*\
	MISC
\*------------------------------------*/,



::selection {
	background: #04A4CC;
	color: #FFF;
	text-shadow: none;
}

::-webkit-selection {
	background: #04A4CC;
	color: #FFF;
	text-shadow: none;
}

::-moz-selection {
	background: #04A4CC;
	color: #FFF;
	text-shadow: none;
}

button:focus{background-color: transparent  !important}
/*------------------------------------*\
	WORDPRESS CORE
\*------------------------------------*/
.alignnone {
	margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
	display: block;
	margin: 5px auto 5px auto;
}

.alignright {
	float: right;
	margin: 5px 0 20px 20px;
}

.alignleft {
	float: left;
	margin: 5px 20px 20px 0;
}

a img.alignright {
	float: right;
	margin: 5px 0 20px 20px;
}

a img.alignnone {
	margin: 5px 20px 20px 0;
}

a img.alignleft {
	float: left;
	margin: 5px 20px 20px 0;
}

a img.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption {
	background: #FFF;
	border: 1px solid #F0F0F0;
	max-width: 96%;
	padding: 5px 3px 10px;
	text-align: center;
}

.wp-caption.alignnone {
	margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
	margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
	margin: 5px 0 20px 20px;
}

.wp-caption img {
	border: 0 none;
	height: auto;
	margin: 0;
	max-width: 98.5%;
	padding: 0;
	width: auto;
}

.wp-caption .wp-caption-text,
.gallery-caption {
	font-size: 11px;
	line-height: 17px;
	margin: 0;
	padding: 0 4px 5px;
}

.sticky {
}

.bypostauthor {
}

/*------------------------------------*\
	PRINT
\*------------------------------------*/
@media print {
	* {
		background: transparent !important;
		color: #000 !important;
		box-shadow: none !important;
		text-shadow: none !important;
	}

	a,
	a:visited {
		text-decoration: underline;
	}

	a[href]:after {
		content: " (" attr(href) ")";
	}

	abbr[title]:after {
		content: " (" attr(title) ")";
	}

	.ir a:after,
	a[href^="javascript:"]:after,
	a[href^="#"]:after {
		content: "";
	}

	pre, blockquote {
		border: 1px solid #999;
		page-break-inside: avoid;
	}

	thead {
		display: table-header-group;
	}

	tr, img {
		page-break-inside: avoid;
	}

	img {
		max-width: 100% !important;
	}

	@page {
		margin: 0.5cm;
	}

	p,
	h2,
	h3 {
		orphans: 3;
		widows: 3;
	}

	h2,
	h3 {
		page-break-after: avoid;
	}
}

/*------------------------------------*\
	FONT IMPORTS
\*------------------------------------*/


h1 {
	font-family: 'Anton', sans-serif !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.sfm-title {
	font-family: 'Anton', sans-serif !important;
}


/* Mai 2025 *//* Ensure main content doesn't overlap with fixed navbar */
main {
	padding-top: 0; /* Remove padding-top since the hero image will be absolutely positioned */
}

/* Spectacles Hero Section */
.spectacles-hero {
	width: 100%;
	height: 800px; /* Adjust height as needed */
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	position: absolute; /* Position behind the menu */
	top: 0;
	left: 0;
	z-index: 1; /* Ensure it’s below the navbar (MaterializeCSS navbars have higher z-index) */
}


@media screen and (max-width: 680px) {
	p.titre-spectacle{font-size: 21px;}
}



@media screen and (min-width: 681px) {
.nouvelles img.attachment-post-thumbnail.size-post-thumbnail.wp-post-image{
	max-width: 50%;
}
}


/* Spacer to push content below the hero image */
.hero-spacer {
  height: 700px; /* fallback */
  transition: height 0.3s ease;
}



@media screen and (min-width: 681px) {
  .nouvelles img.attachment-post-thumbnail.size-post-thumbnail.wp-post-image {
	display: block;
	max-width: 50%;
	margin: 20px auto;
  }
}





/* Title Section */
.title-section {
	text-align: left;
	padding: 40px 0 20px; /* Space above and below the title */
	max-width: 95%;
	margin: 0 auto;
	position: relative;
	z-index: 2; /* Ensure it sits above the hero image */
}

.title-section h1 {
	margin: 0; /* Remove default margin for better control */
	color: #ffffff; /* Match your body text color from style.css */
	font-family: 'Anton', sans-serif; /* Match your h1 font from style.css */
	font-weight: 400;
	font-size: 100px; /* Match your h1 font size from style.css */
	line-height: 105px;
	text-transform: uppercase;
}

/* Center the article content */
section {
	position: relative;
	z-index: 2; /* Ensure content sits above the hero image */
}


@media only screen and (max-width: 680px) {
	.spectacles-hero {
		height: 150px; /* Smaller height for mobile */
	}



	.title-section h1 {
		font-size: 50px; /* Smaller font size for mobile */
		line-height: 55px;
	}

	.title-section {
		padding: 20px 0 10px; /* Reduced padding for mobile */
	}

	
}


/* Styling for spectacles sections */
.spectacles_artiste {
	max-width: 95%;
	margin: 0 auto 40px; /* Space between artist sections */
	padding: 20px 0;
	color: #ffffff; /* Match your body text color */
}

.spectacles_artiste a.bit-widget-initializer {
	color: #ffffff; /* Ensure widget text matches your theme */
}



@media only screen and (max-width: 600px) {
	.spectacles_artiste {
		max-width: 100%;
		padding: 15px;
	}

	h2 {
		font-size: 28px; /* Slightly smaller for mobile */
		line-height: 32px;
	}
}

.artist-box {
	background-color: #191919;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 30px;
	color: #fff;
}

.artist-box h2 {
	margin: 0 0 20px;
	font-size: 35px;
}

.event-row {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	align-items: center;
	padding: 12px 0;
	border-top: 1px solid white;
	gap: 20px;
}

.event-row:first-child {
	border-top: none;
	padding-top: 0;
}

.event-col div:first-child {
	font-weight: 600; /* bold line (date / venue) */
}

.event-col div:last-child {
	font-weight: 400; /* time / city */
}

.tickets-btn {
	font-size: 12px;
	font-weight: 400;
	color: #000;
	background-color: #fff;
	padding: 4px 18px;
	border-radius: 999px;
	text-decoration: none;
	display: inline-block;
	transition: background-color 0.3s ease;
}

.tickets-btn:hover {
	background-color: #a1a1a1;
	color: #000;
}









/* footer 2025 */
.site-footer {
	background-color: #111111;
	color: #ffffff;
	font-size: 16px;
	padding: 40px 0 20px;
}

.footer-wrapper {
	max-width: 95%;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 40px;
}



.footer-logo-row {
	text-align: left;
	margin-bottom: 100px;
}

.footer-logo-row img {
	max-width: 230px;
	height: auto;
}

.footer-main {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 40px;
	align-items: flex-start;
}

.footer-col {
	flex: 1;
	min-width: 200px;
}

.footer-address p {
	line-height: 1.6;
}

.footer-address a {
	color: #fff;
	text-decoration: underline;
}

.newsletter-col {
	flex: 2; 
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}


.newsletter-col p {
	margin-bottom: 10px;
}

.newsletter-col form {
	display: flex;
	align-items: flex-end;
	gap: 12px;
	flex-wrap: wrap;
}

.newsletter-col input[type="email"] {
	background: none;
	border: none;
	border-bottom: 1px solid #fff;
	color: #fff;
	/* padding: 6px 0; */
	width: 320px;
	font-size: 16px;
	line-height: 24px;
}

.newsletter-col input::placeholder {
	color: #aaa;
}

.newsletter-col button {
	background: #fff;
	color: #000;
	border: none;
	border-radius: 999px;
	padding: 8px 24px;
	font-size: 12px;
	font-weight: 400;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

.newsletter-col button:hover {
	background-color: #666666;
	color: #fff;
}

.newsletter-col input::placeholder {
	color: #444444; /* Use a darker gray like #999999 or #666666 if you want it even darker */
	opacity: 1; /* Ensures full opacity in all browsers */
}



.social-col {
	display: flex;
	flex: 1.6; 
	gap: 40px;
	justify-content: left;
	flex-wrap: wrap;
	text-align: left;
	align-self: flex-end;
}

.social-block p {
	margin: 0;
}

.social-block a {
	color: #fff;
	text-decoration: none;
	display: inline-block;
	margin-bottom: 4px;
	font-size: 16px;
	padding-left: 15px;
	padding-right: 15px;
}

@media (max-width: 1024px) {
	.social-block a {
		padding-left: 2px;
		padding-right: 2px;
	}
}


.social-block a:hover {
	text-decoration: underline;
}

.footer-separator {
	border: none;
	border-top: 1px solid #fff;
	margin: 0;
	margin-top: 20px;
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 20px;
	font-size: 14px;
	color: #ffffff;
}

.footer-bottom a {
	color: #ffffff;
	text-decoration: underline;
}

.footer-sponsors img {
	max-width: 530px;
	height: auto;
	display: block;
	width: 90%;
}



/*  footer content on mobile */
@media screen and (max-width: 600px) {
	.footer-wrapper {
		align-items: center;
		text-align: center;
	}
	
	.footer-logo-row {
		text-align: center;
		margin-bottom: 0px;
		
	}
	
	.footer-logo-row img{max-width: 100px}
	
	.newsletter-col form {
		justify-content: center;
		text-align: center;}
			
	.newsletter-col input[type="email"] {text-align: center;
		width: 80%
	}
	
	.social-col {
		justify-content: center;
		text-align: center;
		align-self: center;
	}
	.footer-separator {
		display: none;
	}
	p.copyright{text-align: center;
		margin: 0 auto;
	}
	
	.footer-sponsors img{text-align: center;
		margin: 0 auto;
	}
}






/* preview-section  */

.preview-section {
	position: absolute;
	bottom: 40px;
	left: 40px;
	z-index: 2;
	max-width: 95%;
	width: 60%;
}

.artiste-preview-section {
 position: absolute;
  bottom: 0;
  right: 40px;
  transform: translateY(30%); /* dépassement */
  z-index: 10;
  color: black;
  padding: 20px;
  border-radius: 4px;

  max-width: 95%;
  width: 600px;
}








 .artist-hero {
 position: absolute;
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
 top: 0;
   left: 0;
   width: 100vw;
   height: 80vh;
   z-index: 1;
   /* margin-top: -136px; */
} 

 .artist-hero-single {
 position: absolute;
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
 top: 0;
   left: 0;
   width: 100vw;
   height: 80vh;
   z-index: 1;
   /* margin-top: -136px; */
} 

 .artist-hero-single-diff {
 position: relative;

   /* width: 100vw;
   height: 80vh; */
   z-index: 1;
   /* margin-top: -136px; */
} 


.artist-hero-single-diff .hero-img-diff {
  border-radius: 12px; /* adjust as needed */
  width: 100%;         /* makes it responsive */
  height: auto;
  display: block;
}






body.single-artiste main {
  padding-top: 60px;
  position: relative;
  z-index: 1;
}

.main-content{padding-top: 60px;
	  position: relative;}





 .dynamic-spacer-single-artist{
		  height: 80vh;
			transition: height 0.3s ease;
		  
	  }
	  
	  
	  @media screen and (max-width: 1062px) {
	.dynamic-spacer-single-artist{
		  height: 10px;
			transition: height 0.3s ease;
		  
	  }
	  }





.dynamic-spacer{
		  height: 80vh; /* fallback */
			transition: height 0.3s ease;
	  }
	  


@media screen and (max-width: 768px) {
	
	.dynamic-spacer{
		  height: 30px; /* fallback */
			transition: height 0.3s ease;
		  
	  }
	  
	 
	  
	.artist-hero {
	  min-height: 400px;
	   position: relative;
		background-size: cover;
		background-position: center;
		background-repeat: no-repeat;
		top: 0;
		 left: 0;
		 width: 100vw;
		 height: 400px;
		 z-index: 1;
	
	}
		  
 }
	



@media screen and (max-width: 744px) {
	

  body.single-artiste main {
	padding-top: 60px;
	position: relative;
	z-index: 1;
  }
  
  .main-content{padding-top: 40px;
	position: relative;}
  
  
  .artist-hero-spacer {
	height: 400px;
  }
  

  
 
}

@media screen and (min-width: 680px) {
  .boutique-hero-spacer {
	height: 100px;
  }
}

.boutiquev2-hero-spacer {
	height: 120px;
  }


@media screen and (max-width: 480px) {
	.boutiquev2-hero-spacer {
		height: 80px;
	  }

}


.accueilv2-hero-spacer {
  height: 0px;
}


@media screen and (min-width: 480px) {
.accueilv2-hero-spacer {
	height: 40px;
  }
}



@media screen and (min-width: 780px) {
.accueilv2-hero-spacer {
	height: 120px;
  }
}









 .preview-box {
	background: rgba(255, 255, 255, 0.8);
	color: #000;
	border-radius: 16px;
	padding: 7px 24px;
	width: 100%;	
} 

.single-artiste .preview-box {
  position: relative;
  background: rgba(255, 255, 255, 0.8);
  color: #000;
  border-radius: 16px;
  padding: 7px 24px;
  width: min(92vw, 520px);
  max-height: 380px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  scroll-behavior: smooth;
  clip-path: inset(0 round 16px);
  contain: paint;
  padding-right: 18px;
  scrollbar-gutter: stable both-edges;
}

/* Scrollbar (WebKit) */
.single-artiste .preview-box::-webkit-scrollbar {
  width: 10px;
}

.single-artiste .preview-box::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.8); /* Match the div's background */
  border-radius: 999px;
  /* Remove conflicting background properties */
}

.single-artiste .preview-box::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.28);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}

.single-artiste .preview-box:hover::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.42);
}

/* Scrollbar (Firefox) */
.single-artiste .preview-box {
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, 0.35) transparent;
}








.page-template-template-spectacles .preview-box {
  position: relative;
  background: rgba(255, 255, 255, 0.8);
  color: #000;
  border-radius: 16px;
  padding: 7px 24px;
  width: min(92vw, 520px);
  max-height: 380px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  scroll-behavior: smooth;
  clip-path: inset(0 round 16px);
  contain: paint;
  padding-right: 18px;
  scrollbar-gutter: stable both-edges;
}

/* Scrollbar (WebKit) */
.page-template-template-spectacles .preview-box::-webkit-scrollbar {
  width: 10px;
}

.page-template-template-spectacles .preview-box::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.8); /* Match the div's background */
  border-radius: 999px;
  /* Remove conflicting background properties */
}

.page-template-template-spectacles .preview-box::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.28);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}

.page-template-template-spectacles .preview-box:hover::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.42);
}

/* Scrollbar (Firefox) */
.page-template-template-spectacles .preview-box {
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, 0.35) transparent;
}








.preview-filters {
	display: flex;
	gap: 20px;
	margin-bottom: 16px;
}

.preview-filters select {
	font-size: 16px;
	padding: 10px 20px;
	border-radius: 999px;
	border: none;
	background: #fff;
	color: #000;
	font-weight: bold;
	cursor: pointer;
}

.preview-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-top: 1px solid #000;
	padding: 12px 0;
	flex-wrap: wrap;
}

@media screen and (max-width: 680px) {
	.preview-row {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
		border-top: 1px solid #000;
		padding: 12px 0;
		flex-wrap: wrap;
	}
	
}

.preview-row:first-child {
	border-top: none;
}

.preview-col {
	flex: 1;
	min-width: 120px;
	font-size: 14px;
}

.preview-col.artist {
	flex: 1;
}

.preview-col.ticket {
	flex: 0 0 auto;
}

@media only screen and (max-width: 680px) {
  .preview-col.ticket {
	flex: 1 1;
	margin-top: 10px;
  }
}


.preview-ticket-btn {
	background: #000;
	color: #fff;
	font-size: 12px;
	border-radius: 999px;
	padding: 4px 18px;
	text-decoration: none;
	font-weight: 400;
	transition: background 0.3s ease;
}

a.preview-ticket-btn:hover{color: #ffffff}


.preview-ticket-btn:hover {
	background: #333;
}

/* Page artistes */
/* ========== GRID LAYOUT ========== */
.artists-grid {
  display: grid;
  gap: 20px;                        /* gutter between cards */
  grid-template-columns: 1fr;       /* 1 column on small */
  margin: 0;                        /* flush with wrapper-off */
  padding: 0;
}

@media (min-width: 601px) {
  .artists-grid {
	grid-template-columns: repeat(2, 1fr); /* 2 columns on midsize */
  }
}

@media (min-width: 993px) {
  .artists-grid {
	grid-template-columns: repeat(3, 1fr); /* 3 columns on desktop */
  }
}

/* ========== CARD RATIO & IMAGE ========== */
.artist-card {
  position: relative;
  overflow: hidden;

  /* modern browsers */
  aspect-ratio: 472 / 300;
  /* fallback if needed:
  width: 100%;
  padding-bottom: 63.56%; 
  */
}

.artist-card img {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;               /* fill & crop */
  transition: transform .3s ease,
			  filter .3s ease;
}

/* ========== OVERLAY & HOVER ========== */
.artist-card .overlay {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0);
  transition: background .3s ease;
}

.artist-card:hover img {
  transform: scale(1.05);
  filter: brightness(70%);
}

.artist-card:hover .overlay {
  background: rgba(0,0,0,0.3);
}

/* ========== LABELS ========== */
/* hidden by default */
.artist-name,
.badge {
  opacity: 0;
  transition: opacity .3s ease;
  z-index: 2;
}

/* fade in on hover */
.artist-card:hover .artist-name,
.artist-card:hover .badge {
  opacity: 1;
}

/* positioning & styling */
.artist-name {
  position: absolute;
  bottom: 10px;
  left: 15px;
  color: #fff;
  font-size: 28px;
  font-family: 'Anton', sans-serif !important;
  text-transform: uppercase;
}







.badge {
  position: absolute;
  bottom: 15px;
  right: 15px;
  background: #fff;
  color: #000;
  padding: 6px 18px;
  border-radius: 21px;
  font-size: 12px;
}



@media (min-width: 993px) and (max-width: 1125px) {
  .artist-card .artist-name {
	/* move name into bottom-left */
	bottom: 10px;    /* adjust as needed */
	top: auto;       /* unset any top */
	left: 15px;
  }

  .artist-card .badge {
	/* badge sits just below the name */
	bottom: 58px;    /* adjust so it’s under the name */
	top: auto;       /* unset any top */
	left: 15px;
	right: auto;     /* unset right */
  }
}





.carousel-arrow-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none; /* Important */
  z-index: 9999;
}






.carousel.carousel-slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 1;
}

.carousel .carousel-item {
  width: 100% !important;
}


.carousel-control {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 64px;
  height: 64px;
  cursor: pointer;
  pointer-events: all; /* Important */
  display: flex;
  align-items: center;
  justify-content: center;
}


.carousel-control {
  z-index: 1000;
  pointer-events: all;
}
.carousel-arrow-container {
  pointer-events: none;
  z-index: 999;
}

.carousel-control svg {
  display: block;
  width: 48px;
  height: 48px;
}


.carousel-control.left {
  left: 20px;
}


.page-template-template-spectacles .carousel-control.left {display: none;}

.carousel-control.right {
  right: 20px;
}

.carousel .prev, 
.carousel .next {
  display: none !important;
}

.carousel .indicators {
  display: none !important;
}



/* Desktop */
.carousel .carousel-item > .slide-wrapper {
  height: 100vh;
  background-size: cover;
  background-position: center;
}

@media (max-width: 680px) {
  .carousel .carousel-item > .slide-wrapper {
	height: 60vh;
	background-size: cover; /* ou auto */
	background-position: center;
  }
}







@media screen and (min-width: 320px) {

  .carousel.carousel-slider.carousel-boutique {
	  position: relative !important;
	  height: 30vh !important;
	  min-height: 30vh !important;
	}

}

@media screen and (min-width: 480px) {

  .carousel.carousel-slider.carousel-boutique {
	  position: relative !important;
	  height: 40vh !important;
	  min-height: 40vh !important;
	}

}

@media screen and (min-width: 680px) {

  .carousel.carousel-slider.carousel-boutique {
	  position: relative !important;
	  height: 80vh !important;
	  min-height: 80vh !important;
	}

}






@media screen and (max-width: 680px) {
	
	.carousel.carousel-slider {
		position: relative !important;
		height: 60vh !important;
		min-height: 60vh !important;
	  }
 

  .carousel .carousel-item {
	height: 60vh !important;
	min-height: 60vh !important;
	max-height: 60vh !important;
	background-size: contain !important;   /* ou 'auto' selon ton besoin */
	background-position: center !important;
	aspect-ratio: auto !important;
  }
  

  

  
  
  .carousel-item.top-spectacles {height: 60vh  !important;
	  background-size: cover !important; /* ou auto */
	  background-position: center !important;}
	  


  .preview-section {
	position: relative;
	bottom: auto;
	left: auto;
	right: auto;
	z-index: 2;
	max-width: 100%;
	width: 100%;
	text-align: left;
	margin-top: 40px;
	margin-bottom: 60px;
  }
  


  .title-section {
	text-align: center;
  }

  .title-section h1 {
	text-align: center;
  }

  .hero-spacer {
	display: none;
  }
}





@media screen and (max-width: 1062px) {
	.artiste-preview-section {
		  position: relative;
		  bottom: auto;
		  left: auto;
		  right: auto;
		  z-index: 2;
		  max-width: 100%;
		  width: 100%;
		  text-align: left;
		  margin-top: 40px;
		  margin-bottom: 60px;
		  margin: 0 auto; 
		  transform: initial;
		  padding: 40px 0px 0px 0px;
	
		}
	
	  .preview-box {
		width: 95%;
		margin: 0 auto;
	  }
	  
	  .artist-hero-single {
		min-height: 400px;
		 position: relative;
		  background-size: cover;
		  background-position: center;
		  background-repeat: no-repeat;
		  top: 0;
		   left: 0;
		   width: 100vw;
		   height: 400px;
		   z-index: 1;
	  
	  }
	
}


/* #shopify */
.boutique-section {
  /* margin-left: -15px;
  margin-right: -15px; */
}

/* Espacement horizontal pour chaque colonne */
#shopify-products .col {
  padding-left: 15px;
  padding-right: 15px;
}

/* Supprimer le padding gauche de la 1re colonne visible */
#shopify-products .col:first-child {
  padding-left: 0;
}

/* Supprimer le padding droit de la dernière colonne visible sur desktop */
@media screen and (min-width: 993px) {
  #shopify-products .col:nth-child(4) {
	padding-right: 0;
  }
}

.boutique-item {
  color: white;
  margin-bottom: 30px;
}

.boutique-item img {
  width: 100%;
  height: auto;
  display: block;
}

.boutique-title {
  font-size: 18px;
  font-weight: 400;
  margin: 16px 0 4px 0;
}

.boutique-price {
  font-size: 15px;
  font-weight: 400;
  color: #ffffff;
  margin-bottom: 12px;
  padding: 10px 0px;
}

.boutique-button {
  display: inline-flex;
  align-items: center;
  border: 1px solid white;
  color: white  !important;
  padding: 6px 18px;
  text-transform: none;
  font-size: 14px;
  font-weight: 400;
  background: transparent;
  text-decoration: none;
  transition: all 0.2s ease;
  border-radius: 20px;
  text-transform: none  !important;
}

.boutique-button:hover {
  background: white;
  color: #000  !important;
}


.boutique-full-separator {
  width: 100vw;
  height: 1px;
  background-color: white;
  margin: 100px 0 20px 0;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}


@media screen and (max-width: 769px) {
	
	
	.boutique-button {
		display: inline-flex;
		align-items: center;
		border: 1px solid white;
		color: white  !important;
		padding: 6px 14px;
		text-transform: none;
		font-size: 12px;
		font-weight: 400;
		background: transparent;
		text-decoration: none;
		transition: all 0.2s ease;
		border-radius: 20px;
		text-transform: none  !important;
	}
	
	i.right{margin-left: 2px  !important;}
}



/* modal *//* Modal tiroir avec fond noir */
.modal.bottom-sheet.custom-modal {
	background-color: #171718 !important;
	color: #fff;
	height: 80vh !important;
	max-height: 80vh !important;
	overflow-y: auto;
	border-radius: 16px !important; /* Coins arrondis partout */
	z-index: 1100 !important;

	/* Centrage + largeur responsive */
	width: 90% !important;
	max-width: 100vw;
	margin: 0 auto;
	left: 50% !important;
	transform: translateX(-50%);
}

@media (min-width: 680px) {
  .modal.bottom-sheet.custom-modal {
	background-color: #171718 !important;
	color: #fff;
	height: 50vh !important;
	max-height: 50vh !important;
	overflow-y: auto;
	border-radius: 16px !important; /* Coins arrondis partout */
	z-index: 1100 !important;
	
	/* Centrage + largeur responsive */
	width: 90% !important;
	max-width: 75vw;
	margin: 0 auto;
	left: 50% !important;
	transform: translateX(-50%);
  }
}

.custom-modal:focus-visible {
  outline: none;
}



/* Contenu du tiroir */
.modal.bottom-sheet .modal-content {
  padding: 24px;
  width: 95%;
  margin: 0 auto;
}

/* Titre + bouton fermeture */
.modal.bottom-sheet .modal-close {
  font-size: 24px;
  color: #fff;
  position: absolute;
  top: 16px;
  right: 24px;
  cursor: pointer;
  text-decoration: none;
}


.modal.bottom-sheet.custom-modal::-webkit-scrollbar {
  width: 8px;
}

.modal.bottom-sheet.custom-modal::-webkit-scrollbar-track {
  background: transparent;
}

.modal.bottom-sheet.custom-modal::-webkit-scrollbar-thumb {
  background-color: rgba(255, 255, 255, 0.2);
  border-radius: 4px;
  

}


.modal-overlay-blur {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(23, 23, 24, 0.4); /* léger fond sombre */
  backdrop-filter: blur(5px);
  z-index: 900; /* juste derrière le modal (modal = 1100) */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.modal-overlay-blur.active {
  opacity: 1;
  pointer-events: all;
}








.modal.bottom-sheet h5 {
  margin-top: 0;
  font-size: 20px;
  color: #fff;
}

/* Contenu texte en blanc */
.modal.bottom-sheet .bio-content p,
.modal.bottom-sheet .bio-content h1,
.modal.bottom-sheet .bio-content h2,
.modal.bottom-sheet .bio-content h3 {
  color: #fff;
}



.contact-section {
  background-color: #000;
  color: white;
  padding: 40px 0;
}

.contact-title {
  font-size: 2rem;
  margin-bottom: 30px;
  font-weight: 400;
}

.contact-row {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid white;
  padding: 20px 0;
  flex-wrap: wrap;
}

.contact-left {
  flex: 1 1 auto;
}

.contact-name {
  font-weight: 600;
  font-size: 1.2rem;
  margin-bottom: 5px;
}

.contact-role {
  font-weight: 400;
  font-size: 1rem;
}

.contact-right {
  text-align: right;
  flex-shrink: 0;
}

.contact-email {
  color: white;
  text-decoration: none;
  font-size: 1.1rem;
  font-weight: 400;
  word-break: break-word;
}

@media (max-width: 600px) {
  .contact-row {
	flex-direction: column;
	align-items: flex-start;
  }

  .contact-right {
	text-align: left;
	margin-top: 10px;
  }
}

.col.no-padding {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.intro-bio p {
  margin-bottom: 30px;
}



.slogan {
  min-height: 0px; /* ou 150px selon ton design */
  display: flex;
  align-items: center;
  font-weight: 400;
  line-height: 1.2;
  font-size: 50px;
  color: white;
  margin-top: 60px;
  margin-bottom: 60px;
}


@media screen and (max-width: 680px) {
	.slogan {
	  min-height: 0px; /* ou 150px selon ton design */
	  display: flex;
	  align-items: center;
	  font-weight: 400;
	  line-height: 1.2;
	  font-size: 32px;
	  color: white;
	  margin-top: 50px;
	  margin-bottom: 40px;
	}
}


.social-links {
  background: #000;
  padding: 0px 0px 160px 0px;
}


@media screen and (max-width: 680px) {
	.social-links {
	  background: #000;
	  padding: 0px 0px 20px 0px;
	}

}

.social-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}

.social-list li a {
  color: white;
  font-size: 1.2rem;
  text-decoration: none;
  font-weight: 400;
  transition: opacity 0.3s ease;
}

.social-list li a:hover {
  opacity: 0.7;
}

.row.no-margin {
  margin: 0;
}



.col.no-padding {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

@media (max-width: 600px) {
  .social-list {
	flex-direction: column;
	gap: 20px;
  }
}


/* album-carousel-section */

.album-carousel-section {
  background: #000;
  color: white;
  padding: 40px 0;
  position: relative;
  overflow: hidden;
}

.carousel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin-bottom: 30px;
}

.carousel-controls {
  display: flex;
  gap: 10px;
}

.carousel-header h2 {
  flex-grow: 1;
  margin: 0;
}

.album-carousel-wrapper {
  overflow-x: auto;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* Firefox */
}

.album-carousel-wrapper::-webkit-scrollbar {
  display: none; /* Chrome, Safari */
}


.album-carousel-track {
  display: flex;
  gap: 40px;
  transition: transform 0.3s ease;
}

.album-item {
  flex: 0 0 calc(100% / 3.5);
  max-width: calc(100% / 3.5);
}

.album-item img {
  width: 100%;
  height: 336px;
  object-fit: contain;
  display: block;
  background: #000;
}

.album-item p {
  font-size: 21px;
  margin-top: 20px;
  font-weight: 400;
}

.carousel-prev,
.carousel-next {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
}


.carousel-prev:focus,
.carousel-next:focus,
.carousel-prev:active,
.carousel-next:active {
  outline: none;
  box-shadow: none;
  background-color: transparent !important;
}

.carousel-prev,
.carousel-next {
  -webkit-tap-highlight-color: transparent;
}




@media screen and (max-width: 768px) {
  .album-item {
	flex: 0 0 80%;
	max-width: 80%;
  }
}


.album-carousel-track {
  padding-left: 0 !important;
}

.album-item:first-child {
  margin-left: 0 !important;
}
.album-item {
  flex: 0 0 336px;
  max-width: 336px;
}



/* Page accueil */

.intro-text{font-size: 22px;}

.artist-list {
  list-style: none;
  padding: 0;
  font-weight: 400;
  font-size: 65px;
  line-height: 1;
  font-family: 'Anton', sans-serif !important;
  text-transform: uppercase;
  padding-left: 5rem;
}

@media screen and (max-width: 600px) {
  .artist-list {
	padding-left: 0;
	
  }

  .intro-text {
	margin-top: 3rem;
	margin-bottom: 3rem;
  }
  
  
  
}

ul.artist-list{padding-top: 0; margin-top: 0;}

.artist-list li {
  cursor: default; /* ou retire complètement la propriété */
}

.artist-list li a {
  color: #fff;
  text-decoration: none;
  transition: opacity 0.3s ease;
  cursor: pointer;
  
}






.artist-list li a:hover {
  opacity: 0.5;
}


@media screen and (max-width: 600px) {

  .artist-list li {padding-bottom: 20px;}
  
}





#artist-preview {
  position: fixed;
  pointer-events: none;
  z-index: 9999;
  transform: translate(20px, 20px);
}

#artist-preview img {
  opacity: 0;
  transition: opacity 0.4s ease, transform 0.2s ease;
  max-width: 320px;
  height: auto;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.6);
}


/* .slider-caption {
  position: absolute;
  bottom: 40px;
  left: 40px;
  max-width: 320px;
  color: white;
  z-index: 10;
  text-align: left;
} */

/* ✅ Fond semi-transparent uniquement autour du texte */
/* .slider-caption .slider-text {
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px); 
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 1.5rem;
  line-height: 1.8rem;
  margin-bottom: 15px;
  font-weight: 400;
  text-shadow: none;
  display: inline-block;
} */

/* ✅ Bouton reste normal */
 .slider-caption .dark-btn {
  background: #000000;
 
} 


/* Mobile adjustments */
@media screen and (max-width: 600px) {
  .slider-caption {
	/* left: 50%;
	top: 20px;
	transform: translateX(-50%);
	text-align: center;
	width: 90%;
	max-width: 680px; */
  }
  
  
  .slider-caption .en-savoir-plus{
	position: absolute;
	  left: 50%;
	  transform: translateX(-50%);
	  text-align: center;
	  bottom: 18px;}
	  
	  
	  .slider-caption a.dark-btn.en-savoir-plus{background-color: rgba(0, 0, 0, 0.7) }
  
  

  .slider-caption .slider-text {
	/* font-size: 1.2rem;
	line-height: 1.4rem;
	text-align: center; */
  }

  .slider-caption a.dark-btn {
	display: inline-block;
	font-size: 0.9rem;
  }
}


/* CSS spécifique .actualites-carousel-* */

.actualites-carousel-section {
  background: #000;
  color: white;
  padding: 40px 0;
  overflow: hidden;
}

.actualites-carousel-section .carousel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin-bottom: 30px;
}

.actualites-carousel-controls {
  display: flex;
  gap: 10px;
}

.actualites-carousel-wrapper {
  overflow-x: auto;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.actualites-carousel-wrapper::-webkit-scrollbar {
  display: none;
}

.actualites-carousel-track {
  display: flex;
  gap: 40px;
}

.actualite-item {
  flex: 0 0 336px;
  max-width: 336px;
}

.actualite-item img {
  width: 100%;
  height: auto;
  display: block;
  background: #000;
}


.actualite-item p {
  font-size: 18px;
  margin-top: 20px;
  font-weight: 400;
}

.categorie-pastille {
  display: inline-block;
 color: #ffffff;
 background-color: rgba(58, 58, 58, 0.61);
  border-radius: 8px;
  padding: 6px 16px;
  font-size: 12px;
  margin-top: 2px;
  font-weight: 400;
  text-transform: none;
  text-decoration: none;
  transition: background 0.3s ease;
  letter-spacing: 1px;
}
a.categorie-pastille {color: #ffffff  !important;}

.categorie-pastille {
  margin-right: 6px;
}



.categorie-pastille:hover {
  background-color: #1e1e1e;
}

.carousel-prev-actualites,
.carousel-next-actualites {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .actualite-item {
	flex: 0 0 80%;
	max-width: 80%;
  }
}


.card-title a {
  color: #fff;
  text-decoration: none;
  font-size: 22px;
  font-weight: 400;
  line-height: 1;
  
}

.card-title{margin-top: 21px;
	margin-bottom: 21px  !important;
}

.card-content {
  background: #000;
  color: white;
}

.blog-date {
  font-size: 12px;
  color: #ccc;
  margin-bottom: 5px;
}

.card{background-color: transparent}
.card-pastille{margin-top: 20px;}

.categorie-pastille{margin-bottom: 6px;}





.h1-inline-small {
  font-size: 0.5em;
  font-weight: normal;
  display: block;
  margin-bottom: 0; /* ou 2px si tu veux un tout petit écart */
  line-height: 1.1;
}
h1 span.h1-inline-small + br {
  display: none; /* masque le <br> s’il est là juste pour forcer un retour */
}

.page-category h1 {
  line-height: 1.1 !important; /* remplace le 105px trop grand */
}


img[sizes="auto"] {
  contain-intrinsic-size: auto !important;
}





/* SECTION FULL WIDTH */
.timeline-scroll-section {
  position: relative;
  background: black;
  padding: 60px 0;
  width: 100vw;
  overflow: hidden;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
}

/* EN-TÊTE */
.timeline-header {
  display: flex;
  justify-content: flex-end; /* Aligns content to the right */
  align-items: center;
  padding: 0 60px;
  color: white;
}



/* BOUTONS */

/* BOUTONS */
.timeline-controls {
  display: flex;
  gap: 10px; /* Optional: adds spacing between buttons */
}

.timeline-controls button {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}

/* ZONE SCROLLABLE */
.timeline-scroll-container {
  position: relative;
  overflow-x: scroll;
  overflow-y: visible;
  white-space: nowrap;
  scrollbar-width: none; /* Firefox */
}
.timeline-scroll-container::-webkit-scrollbar {
  display: none; /* Chrome, Safari */
}

/* LIGNE CENTRALE */


.timeline-line {
  position: absolute;
  top: 60px;
  left: 0;
  height: 2px;
  background: white;
  z-index: 0;
  width: 100%;
}



/* CONTENEUR D'ÉLÉMENTS */
.timeline-items {
  display: flex;
  flex-wrap: nowrap;
  gap: 80px;
  padding: 80px 0px 40px 60px; /* top right bottom left */
  position: relative;
  z-index: 2;
}


.timeline-items::after {
  content: "";
  flex: 0 0 60px; /* identique à padding-left */
}



/* ÉLÉMENT INDIVIDUEL */
.timeline-item {
  display: inline-block;
  min-width: 160px;
  max-width: 220px; /* Ajuste selon ton visuel */
  text-align: center;
  position: relative;
  color: white;
  cursor: pointer;
  white-space: normal; /* <-- PERMET LE MULTILIGNE */
  word-wrap: break-word;
}



/* POINT */
.timeline-dot {
  width: 20px;
  height: 20px;
  background: #d9d9d9;
  border-radius: 50%;
  position: absolute;
  top: -29px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
}

/* CONTENU */
.timeline-content {
  margin-top: 20px;
  position: relative;
  white-space: normal;
}

.timeline-content {
  min-height: 80px; /* ajuste selon besoin */
}

.timeline-content div {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}


.timeline-image {
  margin-top: 10px;
  opacity: 1;
  transition: filter 0.3s ease-in-out;
  filter: grayscale(100%);
}

.timeline-item:hover .timeline-image {
  filter: grayscale(0%);
}


/* TAILLE MAX DE L’IMAGE */


.timeline-image img {
  max-width: 140px;
  height: auto;
  display: block;
  margin-top: 10px;
  filter: grayscale(100%);
  transition: filter 0.1s ease-in-out, transform 0.1s ease-in-out;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.timeline-item:hover .timeline-image img {
  filter: grayscale(0%);
  transform: scale(1.4); /* effet de zoom */
}





.page-template-template-apropos h1{margin-bottom: 20px;}


.galerie-apropos {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  flex-wrap: nowrap;
  overflow: visible;
  margin: 60px auto;
  padding: 0;
  gap: 0;
}

/* Toutes les figures ont un padding sauf la première et la dernière */
.galerie-apropos figure {
  padding: 0 10px;
  margin: 0 !important;
  flex: 0 0 auto;
  overflow: hidden;
}

/* Supprime le padding à gauche de la première */
.galerie-apropos figure:first-child {
  padding-left: 0;
}

/* Supprime le padding à droite de la dernière */
.galerie-apropos figure:last-child {
  padding-right: 0;
}

/* Hauteur des images alternées */
.galerie-apropos figure:nth-child(1),
.galerie-apropos figure:nth-child(3) {
  height: 420px;
  padding-top: 60px;
}

.galerie-apropos figure:nth-child(2),
.galerie-apropos figure:nth-child(4) {
  height: 600px;
}

/* Image 100% hauteur du conteneur */
.galerie-apropos figure img {
  height: 100%;
  width: auto;
  object-fit: cover;
  display: block;
  max-height: none !important;
}

@media screen and (max-width: 768px) {
  .galerie-apropos {
	overflow-x: scroll;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-end;
	-webkit-overflow-scrolling: touch;
	padding: 0;
	margin: 40px 0;
	gap: 0;

	/* Masquer la scrollbar */
	scrollbar-width: none; /* Firefox */
  }

  .galerie-apropos::-webkit-scrollbar {
	display: none; /* Chrome, Safari */
  }

  .galerie-apropos figure {
	padding: 0 20px;
	flex: 0 0 auto;
  }

  .galerie-apropos figure:first-child {
	padding-left: 0;
  }

  .galerie-apropos figure:last-child {
	padding-right: 0;
  }

  .galerie-apropos figure:nth-child(1),
  .galerie-apropos figure:nth-child(3) {
	height: 300px;
	padding-top: 40px;
  }

  .galerie-apropos figure:nth-child(2),
  .galerie-apropos figure:nth-child(4) {
	height: 400px;
  }

  .galerie-apropos figure img {
	height: 100%;
	width: auto;
	object-fit: cover;
	display: block;
  }
}


.intro-apropos{padding-top: 40px  !important;
	padding-top: 20px;
}


.recompenses {
	width: 100%;
	margin: 0 auto;
	color: #fff;
	background-color: #000;
	margin-bottom: 140px;
}

.recompense-table {
	width: 100%;
}

.recompense-row {
	display: flex;
	width: 100%;
	margin: 0;
	padding: 0px 0;
}

.recompense-row span {
	padding: 1px 10px;
	text-align: left;
	white-space: normal; /* Allow text to wrap */
	word-wrap: break-word; /* Break long words */
}

.recompense-row span.category {
	flex: 0 0 20%; /* Fixed width for category column */
	text-transform: uppercase;
}

.recompense-row span.empty {
	flex: 0 0 20%; /* Same width as category, but empty */
}

.recompense-row span:nth-child(2) {
	flex: 0 0 10%; /* Fixed width for year column */
}

.recompense-row span:nth-child(3) {
	flex: 0 0 35%; /* Fixed width for award column */
}

.recompense-row span:nth-child(4) {
	flex: 0 0 30%; /* Fixed width for artist column */
}

@media (max-width: 768px) {
	.recompense-row {
		flex-direction: column;
		padding: 10px 0;
	}

	.recompense-row span {
		width: 100%;
		text-align: left;
		padding: 0px 0;
	}

	.recompense-row span.category {
		font-size: 1.2em;
	}
}


/* contact-section  */
.contact-section {
  /* background-color: black;
  color: white;
  padding: 60px 30px; */
}

.label-block h5 {
  font-size: 2rem;
  margin-bottom: 10px;
}

.label-divider {
  width: 100%;
  height: 1px;
  background-color: white;
  margin-bottom: 25px;
}

.label-block a {
  color: white;
  text-decoration: none;
}

.label-block a:hover {
  text-decoration: underline;
}

.formulaire{margin-top: 100px;
	margin-bottom: 60px;
}

.form-column {
  padding-right: 60px; /* Adjust as needed (e.g., 60px or 5%) */
}

body .gform_wrapper .gform_required_legend {
  display: none;
}


body .gform_wrapper .gform_body .gform_fields .gfield_label {
  color: #ffffff;
}


body .gform_wrapper input::placeholder,
body .gform_wrapper textarea::placeholder {
  color: rgba(255, 255, 255, 0.6);
}


body .gform_wrapper input[type="text"],
body .gform_wrapper input[type="email"],
body .gform_wrapper input[type="tel"],
body .gform_wrapper textarea {
  color: #000000;
  /* border-bottom: 1px solid #ffffff; */
}

body .gform_wrapper input[type="text"]:focus,
body .gform_wrapper input[type="email"]:focus,
body .gform_wrapper input[type="tel"]:focus,
body .gform_wrapper textarea:focus {
  border-bottom: 1px solid #ffffff;
  box-shadow: 0 1px 0 0 #ffffff;
}

#gform_submit_button_1.form-btn {
	all: unset; /* resets every inherited and default property */
		display: inline-block;
	
		/* Your desired custom style */
		height: 30px;
		line-height: 30px;
		width: auto;
		background-color: #fff;
		color: #000;
		font-size: 12px;
		font-weight: 400;
		padding: 0 18px;
		border-radius: 999px;
		text-align: center;
		cursor: pointer;
		transition: background-color 0.3s ease;
	}

}


#gform_submit_button_1.form-btn:hover {
	background-color: #a1a1a1;
	color: #000;
}

.btn.ghost {
  background-color: transparent !important;
  border: 1px solid white;
  color: white !important;
  text-transform: none;
  box-shadow: none;
  border-radius: 24px; /* Coins arrondis */
  padding: 0 20px;
  height: 42px;
  line-height: 42px;
}

.btn.ghost:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

#audio-permission {
  transition: opacity 0.4s ease, visibility 0.4s ease;
}

#audio-permission.hidden {
  opacity: 0;
  visibility: hidden;
}




/* Bouton "mouse scroll" */
/* Scroll hint réduit et positionné à droite */
.scroll-hint {
  position: absolute;
  bottom: 16px;     /* distance du bas */
  right: 30px;      /* distance du bord droit */
  z-index: 20;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

/* Contour de souris réduit */
.scroll-hint .mouse {
  width: 24px;
  height: 40px;
  border: 2px solid #fff;
  border-radius: 14px;
  position: relative;
  opacity: 0.9;
}

.scroll-hint .wheel {
  width: 3px;
  height: 8px;
  background: #fff;
  border-radius: 2px;
  position: absolute;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
  animation: wheelMove 1.5s infinite;
}

/* Flèche réduite */
.scroll-hint .hint-arrow {
  font-size: 16px;
  line-height: 1;
  color: #fff;
  animation: arrowBounce 1.6s ease-in-out infinite;
  opacity: 0.9;
}

@keyframes wheelMove {
  0%   { opacity: 0; top: 8px; }
  30%  { opacity: 1; top: 14px; }
  70%  { opacity: 1; top: 18px; }
  100% { opacity: 0; top: 24px; }
}

/* Petite flèche Materialize en dessous (optionnelle) */
.scroll-hint .hint-arrow {
  font-size: 22px;
  line-height: 1;
  color: #fff;
  animation: arrowBounce 1.6s ease-in-out infinite;
  opacity: 0.9;
}

@keyframes arrowBounce {
  0%, 100% { transform: translateY(0); opacity: 0.7; }
  50%      { transform: translateY(4px); opacity: 1; }
}

/* Accessibilité : réduire les animations si demandé */
@media (prefers-reduced-motion: reduce) {
  .scroll-hint .wheel,
  .scroll-hint .hint-arrow {
	animation: none;
  }
}

/* Mobile : laisse de la place à ta preview box en bas-gauche */
@media (max-width: 680px) {
  .scroll-hint {
	bottom: 12px;
  }
}

@media (max-width: 680px) {
  .scroll-hint {
	display: none !important;
  }
}



/* Quand il n'y a pas d'événements, garder l'espace sans afficher le contenu */
.artiste-preview-section.is-empty .preview-box {
  visibility: hidden;   /* occupe l’espace, mais invisible */
}

/* Optionnel : si tu veux forcer une hauteur minimale spécifique à 1062px et moins */
@media (max-width:1062px) {
  .artiste-preview-section.is-empty .preview-box {
	min-height: 0px;  /* ajuste à la hauteur de ta boîte habituelle */
  }
}


/* diffuseur */


.diffuseur h2{font-size: 50px; line-height: 1.5}

.diffuseur .intro-bio{font-size: 22px;
	margin-bottom: 60px;
}

/* wrapper: keeps corners & hides any bleed */
.videoclips-diff .video-box {
  border-radius: 0;     /* pas de radius */
  overflow: visible;    /* laisse l’iframe normal */
  background: #000;     /* force le fond noir */
}

.videoclips-diff .video-container {
  line-height: 0;
}

.videoclips-diff .video-container iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: #000;     /* cache les bandes blanches internes */
}

/* Container stays responsive (Materialize uses padding-bottom) */
.videoclips-diff .video-container{
  position: relative;
  overflow: hidden;
  line-height: 0;
  background: #000;            /* avoids any white peek-through */
}

/* Make the iframe fill and slightly overscan to kill subpixel gaps */
.videoclips-diff .video-container iframe{
  position: absolute;
  top: -1px;                   /* nudge up */
  left: 0;
  width: 100%;
  height: calc(100% + 9px);    /* 1px over top & bottom */
  display: block;
  border: 0;
  background: #000;
  transform: translateZ(0);    /* fix for some GPU rounding cases */
}

.contact-diff{margin-top: 120px;}

.artist-hero-single-diff {
  position: relative;
}

.hero-img-diff {
  display: block;
  width: 100%;
  height: auto;
}

.hero-download-btn {
  position: absolute;
  bottom: 20px;
  right: 20px;
  text-decoration: none;
  /* Tu gardes la classe .newsletter-col button donc tu hérites déjà du style bouton */
}

.white-btn{
	background: #fff;
	color: #000;
	border: none;
	border-radius: 999px;
	padding: 8px 24px;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.3s ease;
	font-family: font-family: 'Inter', sans-serif;
	
}

.white-btn:hover {
	background-color: #666666;
	color: #fff;
}

.diff-download-buttons {
	padding-top: 30px;
  display: flex;
  justify-content: left;
  gap: 30px;
  margin: 40px 0;
  flex-wrap: wrap; /* pour éviter que ça déborde sur petits écrans */
}

/* .diff-btn {
  display: inline-flex;
  align-items: left;
  gap: 6px;
  border-radius: 9999px;
  padding: 12px 24px;
  font-weight: 600;
  text-decoration: none;
  background: #fff; 
  color: #000;
  transition: background .3s, color .3s;
}

.diff-btn:hover {
  background: #000;
  color: #fff;
} */

.diff-btn svg {
  margin-top: 2px;
  fill: currentColor; /* l’icône suit la couleur du texte */
}



/* Espace Synchro */
/* Filter bar styling */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; /* Center-align chips horizontally */
  gap: 10px;
  margin: 20px 0 80px;
  max-width: 650px; /* Limit width to 650px */
  margin-left: auto; /* Center the container */
  margin-right: auto; /* Center the container */
}

/* Default filter chip styles */
.filter-chip.chip {
  background: #000000;
  color: #ffffff;
  border: 1px solid #ffffff;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 14px;
  padding: 8px 20px;
  line-height: 1;
  transition: border-color 0.3s ease;
}

/* Specific active state for filter chips */
.filter-chip.chip.active {
  background: #ffffff !important;
  color: #000000 !important;
  border: 1px solid #ffffff !important;
}

/* Optional: Hover state for better UX */
.filter-chip.chip:hover {
  background: #333333;
  color: #ffffff;
  border: 1px solid #ffffff;
  transition: background 0.3s ease, border-color 0.3s ease;
}



/* Cartes */
.playlists-grid { margin-top: 10px; }
.playlist-card {
  background: #0b0b0b;
  border-radius: 14px;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.playlist-card:hover { transform: translateY(-2px); }

/* Poster (carré) */
.playlist-poster {
  position: relative;
  aspect-ratio: 1/1;
  background: #111;
  display: flex;
  align-items: center;
  justify-content: center;
}
.play-overlay {
  position: absolute;
  bottom: 12px;
  left: 12px;
}
.play-overlay i { line-height: 36px; }

/* Iframe */
.playlist-embed { padding: 0 14px 16px; }
.playlist-embed iframe { border-radius: 12px; width: 100%; }

/* Voir plus */
.voir-plus-wrap { margin: 24px 0 60px; }







.playlist-card-wrapper {
  opacity: 1;
  transition: opacity 0.1s ease;
}

.playlist-card-wrapper.fade-out {
  opacity: 0 !important;
  transition: opacity 0.1s ease;
}

.playlist-card-wrapper:not(.fade-out) {
  opacity: 1;
}


.ghost-button {
	font-family: 'Inter', sans-serif;
  display: inline-flex;
  align-items: center;
  border: 1px solid white;
  color: white  !important;
  padding: 6px 18px;
  text-transform: none;
  font-size: 14px;
  font-weight: 500;
  background: transparent;
  text-decoration: none;
  transition: all 0.2s ease;
  border-radius: 20px;
  text-transform: none  !important;
}

.ghost-button:hover {
  background: white;
  color: #000  !important;
}




/* ===== Placements : full-bleed ===== */

/* Conteneur pleine largeur, même si le parent est limité */
.placements-fullbleed {
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;
  /* Optionnel: aligne avec le haut/bas de la page */
  padding: 0;
}

/* Tableau flexible, look "liste noire" comme ton screenshot */
.placements-table {
  display: block;
  background: #000;              /* fond noir */
  color: #fff;                   /* texte blanc */
  font-size: 22px;
  border-top: 1px solid rgba(255, 255, 255, 1);
  margin-top: 120px;
  margin-bottom: 180px;
}

/* Lignes */
.placements-row {
  display: grid;
  grid-template-columns: 1fr 120px 1fr 160px; /* Titre | Année | Client | Type */
  gap: 24px;
  align-items: center;
  padding: 18px 44px;
  border-bottom: 1px solid rgba(255, 255, 255, 1);
  text-decoration: none;         /* utile pour <a> englobant */
  color: inherit;
}



/* Lignes cliquables */
.placements-item {
  background: transparent;
  transition: background-color .18s ease, box-shadow .18s ease;
}
.placements-item:hover,
.placements-item:focus {
  background: #1d1d1d;          /* highlight au survol */
  outline: none;
  color: #fff !important;
}

/* Garde le texte blanc au survol */
.placements-item:hover,
.placements-item:focus {
  background: #1d1d1d;
  color: #fff !important;
  text-decoration: none; /* évite soulignement global */
}

/* Souligner seulement la colonne "Client" */
.placements-item:hover .placements-col--type,
.placements-item:focus .placements-col--type {
  text-decoration: underline;
}

/* Colonnes spécifiques (permet d’ajuster facilement) */
.placements-col--title {
  min-width: 240px;
  font-weight: 500;
}
.placements-col--year {
  text-align: left;
  opacity: .9;
  min-width: 90px;
}
.placements-col--client {
  opacity: .9;
}
.placements-col--type {
  text-align: left;
  opacity: 1;
  font-weight: 500;
}

/* Ligne vide */
.placements-empty {
  grid-template-columns: 1fr;
  text-align: left;
  color: rgba(255,255,255,0.7);
  padding: 40px 24px;
}

/* Responsive */
@media (max-width: 992px) {
  .placements-row {
	grid-template-columns: 1fr 80px 1fr 120px;
	gap: 16px;
	padding: 16px 16px;
  }
}
@media (max-width: 600px) {
  /* Sur mobile : on empile en 2 lignes, mais toute la rangée reste cliquable */
  .placements-row {
	grid-template-columns: 1fr 1fr;
	grid-auto-rows: auto;
	row-gap: 6px;
  }
  .placements-col--title { grid-column: 1 / 3; }
  .placements-col--client { grid-column: 1 / 2; }
  .placements-col--year   { grid-column: 1 / 3; text-align: left; }
  .placements-col--type   { grid-column: 1 / 3; text-align: left; opacity: .9; }
}

a.onglet-synchro {color: #fff;
	font-size: 20px;
}



/* ==========================================================
   Boutique carousel — pas de crop, pas d'espace haut/bas,
   SANS toucher au conteneur .carousel.carousel-slider
   ========================================================== */

/* Base boutique (garde) */
.carousel-boutique {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.carousel-boutique .carousel-item {
  height: auto !important;             /* neutralise le 60vh global sur l'item */
  background: none !important;
}
.carousel-boutique .carousel-item > .slide-wrapper {
  height: auto !important;              /* neutralise les 100vh/60vh globaux sur le wrapper */
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: contain !important;  /* pas de crop */
}
.carousel-boutique .slide-wrapper {
  width: 100%;
  display: block;
  aspect-ratio: var(--w, 16) / var(--h, 9);
  padding-top: 0 !important;           /* évite la fausse marge */
}

/* Flèches: desktop seulement */

  .carousel-boutique .carousel-arrow-container { display: none !important; }

@media (min-width: 680px) {
  .carousel-boutique .carousel-arrow-container {
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: space-between;
	pointer-events: none;
  }
  .carousel-boutique .carousel-control {
	pointer-events: auto; cursor: pointer;
	width: 64px; height: 64px; display:flex; align-items:center; justify-content:center;
	opacity: .85; transition: opacity .2s, transform .2s;
  }
  .carousel-boutique .carousel-control:hover { opacity: 1; transform: scale(1.05); }
}

/* Dots (optionnel) */
.carousel-boutique .indicators { bottom: 15px; }
.carousel-boutique .indicators .indicator-item { background-color: rgba(255,255,255,.5); }
.carousel-boutique .indicators .indicator-item.active { background-color: #fff; }

/* ==========================================================
   Overrides ciblés des règles globales conflictuelles
   (ne touche pas au conteneur .carousel.carousel-slider)
   ========================================================== */

/* Desktop: annule la hauteur forcée 100vh appliquée au wrapper global */
.carousel-boutique .carousel-item > .slide-wrapper { height: auto !important; }

/* Mobile ≤ 680px: annule la hauteur forcée 60vh sur l'item + wrapper */
@media (max-width: 680px) {
  .carousel-boutique .carousel-item { height: auto !important; min-height: 0 !important; max-height: none !important; }
  .carousel-boutique .carousel-item > .slide-wrapper { height: auto !important; }
}

