@charset "UTF-8";

/*

-- types --

.grid (grid)
.columns (flex)

-- mode --

.grid
.grid.list

-- style --

.grid.events			== thumbnails / dates / related (grid / list)
.grid.list.archives		== seasons
.grid.artists			== artists
.grid.gallery			== images / logos

*/

/**************************/
/**************************/
/********** VARS **********/
/**************************/
/**************************/

@media (min-width: 0px) {
	.grid {
		--item-width: 20rem;
	}
}
@media (min-width: 1400px) {
	.grid {
		--item-width: 24rem;
	}
}

/************************************/
/************************************/
/********** GRID / DEFAULT **********/
/************************************/
/************************************/

.grid {
	position: relative;
	font-size: var(--font-size);
}
.grid .items {
	position: relative;
	display: -ms-grid;
	display: grid;
	width: 100%;
}
.grid .items + .items {
	margin-top:var(--global-spacing);
}
.grid .item {
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin: 0;
	width: 100%;
	background: var(--bright-color);
}
.grid .item-content {
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	   -moz-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	width: 100%;
	margin: 0;
}

/********** ANIMATIONS **********/

.grid-container.is-loading:before,
.grid.is-loading:before {
	position: fixed;
	z-index: 100;
	top: 50%;
	left: 50%;
	-webkit-transform: translate3d(-50%, -50%, 0);
	   -moz-transform: translate3d(-50%, -50%, 0);
	        transform: translate3d(-50%, -50%, 0);
}
.grid-container.is-loading .results-title,
.grid-container.is-loading .item,
.grid.is-loading .item {
	opacity: 0;
}

/********** STATUS **********/

.grid .item.off {
	position: absolute;
	top: 0;
	left: 0;
	height: 0;
	width: 0;
	opacity: 0;
	-ms-grid-column: 1;
	grid-column: 1 / 1;
	pointer-events: none;
}
.grid .items.unavailable .item figure,
.grid .item.unavailable .item figure {
	opacity: .5;
}
.grid .items.unavailable .item .item-content,
.grid .item.unavailable .item-content {
	color: var(--grey-color);
}
.grid .items.unavailable .item .item-content .infos .event-link > *,
.grid .item.unavailable .item-content .infos .event-link > * {
	color: var(--grey-color) !important;
}
/* END IOS HACK */
.grid .items.unavailable .item .event-cart,
.grid .item.unavailable .event-cart {
	opacity: 0.25;
	pointer-events: none;
	border-bottom: none !important;
	text-decoration: none !important;
}
.grid .items.unavailable .item .event-cart:after,
.grid .item.unavailable .event-cart:after {
	opacity: 0;
}
.grid:not(.empty):not(.search) .grid-message {
	position: absolute;
	top: 0;
	left: 0;
	height: 0;
	width: 0;
	opacity: 0;
	-ms-grid-column: 1;
	grid-column: 1 / 1;
	pointer-events: none;
}

/********************************/
/********************************/
/********** GRID INFOS **********/
/********************************/
/********************************/

.grid .infos {
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	   -moz-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	text-align: left;
	margin: auto;
	height:100%;
	width: 100%;
	padding: 1em;
}
.grid .infos > * {
	margin: 0;
}
.grid .item .excerpt {
	overflow: hidden;
	-o-text-overflow: ellipsis;
	   text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 4; /* number of lines to show */
	line-clamp: 4;
	-webkit-box-orient: vertical;
}

/**************************/
/**************************/
/********** LIST **********/
/**************************/
/**************************/

/* only for events in fine >> turn into .grid.events ?? */

.grid.list .items {
	-ms-grid-columns: 1fr !important;
	grid-template-columns: 1fr !important;
	gap: -webkit-calc(var(--global-spacing) / 2);
	gap: -moz-calc(var(--global-spacing) / 2);
	gap: calc(var(--global-spacing) / 2);
}
.grid.list .item {
	background: none;
}
.grid.list .item-content {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	   -moz-box-orient: horizontal;
	   -moz-box-direction: normal;
	    -ms-flex-direction: row;
	        flex-direction: row;
}
.grid.list .infos {
	text-align: left;
	padding: 0;
}
.grid.list .infos > * {
	margin: 0;
}

/****************************/
/****************************/
/********** EVENTS **********/
/****************************/
/****************************/

/*
grid		== thumbnails
list		== dates (calendar)
archives	== seasons archives
*/

/******************************************/
/********** DEFAULT (THUMBNAILS) **********/
/******************************************/

.grid.events .infos {
	padding:0;
	margin-top:.5em;
}
.grid.events .event-link {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -moz-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	   -moz-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	border: 0;
	width:100%;
}
.grid.events a.event-link:hover {
	color: var(--primary-color);
}
.grid.events:not(.list) .event-title {
	width:100%;
	font-size: 2em;
	line-height:normal;
	overflow: hidden;
	-o-text-overflow: ellipsis;
	   text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	line-clamp: 1;
	-webkit-box-orient: vertical;
}
.grid.events .event-description {
	font-size: 1.375em;
	line-height: 1.125em;
	margin-top: -.5em;
}
.grid.events .event-dates {
	white-space: nowrap;
}
.grid.events .buttons {
	font-size: .75em;
	margin: auto 0 0 0;
	padding: .5em 0 0 0;
}

/*****************************/
/********** RELATED **********/
/*****************************/

.grid.events.related {
	color:var(--primary-color);
	border-top:solid -webkit-calc(var(--line-height) / 2);
	border-top:solid -moz-calc(var(--line-height) / 2);
	border-top:solid calc(var(--line-height) / 2);
	border-bottom:solid -webkit-calc(var(--line-height) / 2);
	border-bottom:solid -moz-calc(var(--line-height) / 2);
	border-bottom:solid calc(var(--line-height) / 2);
	padding:1em 0;
}
.grid.events .event-dates {
	white-space:normal;
}
.grid.events.related .item .event-type {
	font-size:1.5em;
	text-transform: uppercase;
}
.grid.events.related .item .event-title,
.grid.events.related .item .event-description {
	margin-top:0 !important;
}
.grid.events.related .item .event-description {
	font-size:1.5em;
}

/**********************************/
/********** LIST (DATES) **********/
/**********************************/

.grid.list.events .items {
	gap: 0;
}
.grid.list.events .item:before {
	content: '';
	position: absolute;
	z-index: 10;
	top: 0;
	left: 0;
	width: 100%;
	border-top: solid -webkit-calc(var(--line-height) / 2);
	border-top: solid -moz-calc(var(--line-height) / 2);
	border-top: solid calc(var(--line-height) / 2);
	pointer-events: none;
}
.grid.list.events .item:last-child:after {
	content: '';
	position: absolute;
	z-index: 10;
	bottom: 0;
	left: 0;
	width: 100%;
	border-bottom: solid -webkit-calc(var(--line-height) / 2);
	border-bottom: solid -moz-calc(var(--line-height) / 2);
	border-bottom: solid calc(var(--line-height) / 2);
	pointer-events: none;
}
.grid.list.events .infos {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	   -moz-box-orient: horizontal;
	   -moz-box-direction: normal;
	    -ms-flex-direction: row;
	        flex-direction: row;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	text-transform: uppercase;
	margin:0;
}
.grid.list.events .infos > * {
	-webkit-box-flex: 0;
	-webkit-flex-grow: 0;
	   -moz-box-flex: 0;
	    -ms-flex-positive: 0;
	        flex-grow: 0;
}
.grid.list.events .infos .event-link {
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	   -moz-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
}
.grid.list.events .infos .event-link > * {
	overflow: hidden;
	-o-text-overflow: ellipsis;
	   text-overflow: ellipsis;
	white-space: nowrap;
	margin: 0;
}
.grid.list.events .event-dates,
.grid.list.events .event-title {
	font-size: 1em;
	line-height: inherit;
}
.grid.list.events .event-hour {
	white-space:nowrap;
}
.grid.list.events .item .event-dates {
	margin-left:0;
}
.grid.list.events .button {
	font-size: 1em;
}

/********** @MEDIA **********/

@media (max-width: 760px) {
	.grid.list.events {
		font-size:-webkit-calc(var(--font-size) * .75);
		font-size:-moz-calc(var(--font-size) * .75);
		font-size:calc(var(--font-size) * .75);
	}
	.grid.list.events .infos {
		padding: .75em !important;
	}
	.grid.list.events .item .event-link {
		display:-webkit-box;
		display:-webkit-flex;
		display:-moz-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		   -moz-box-orient: horizontal;
		   -moz-box-direction: normal;
		    -ms-flex-direction: row;
		        flex-direction: row;
	}
	.grid.list.events .infos,
	.grid.list.events .event-link {
		gap: 0 .5em;
	}
	.grid.list.events .item .event-dates {
		-webkit-flex-basis: 100%;
		    -ms-flex-preferred-size: 100%;
		        flex-basis: 100%;
	}
}
@media (min-width: 760px) {
	.grid.list.events {
		font-size: var(--font-size);
	}
	.grid.list.events .infos {
		padding: 0.5em !important;
	}
	.grid.list.events .infos,
	.grid.list.events .event-link {
		gap: 0.25em 1em;
	}
	.grid.list.events .item .event-link {
		display:-ms-grid;
		display:grid;
		-ms-grid-columns: 15em 3.25em auto auto auto auto;
		grid-template-columns: 15em 3.25em auto auto auto auto;
	}
	.grid.list.events .event-link > * {
		padding:.25em 0;
	}
	.grid.list.events .item .event-dates {
		-webkit-flex-basis: 7em;
		    -ms-flex-preferred-size: 7em;
		        flex-basis: 7em;
	}
	.grid.list.events .item .event-hour {
		-webkit-flex-basis: 3.25em;
		    -ms-flex-preferred-size: 3.25em;
		        flex-basis: 3.25em;
	}
}

/******************************/
/********** ARCHIVES **********/
/******************************/

.grid.list.archives .item {
	display:-webkit-box;
	display:-webkit-flex;
	display:-moz-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	   -moz-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	gap:0;
}
.grid.list.archives .item > * + * {
	margin:0;
}
.grid.list.archives .title {
	font-weight: 700;
	display:-webkit-inline-box;
	display:-webkit-inline-flex;
	display:-moz-inline-box;
	display:-ms-inline-flexbox;
	display:inline-flex;
}
.grid.list.archives .title span + span {
	margin-left:1em;
}
.grid.list.archives a.title span:first-child {
	display:inline;
	border-bottom:solid -webkit-calc(var(--line-height) / 2) transparent;
	border-bottom:solid -moz-calc(var(--line-height) / 2) transparent;
	border-bottom:solid calc(var(--line-height) / 2) transparent;
	overflow: hidden;
	-o-text-overflow: ellipsis;
	   text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	line-clamp: 1;
	-webkit-box-orient: vertical;
}
.grid.list.archives a.title:hover span:first-child {
	border-bottom:solid -webkit-calc(var(--line-height) / 2);
	border-bottom:solid -moz-calc(var(--line-height) / 2);
	border-bottom:solid calc(var(--line-height) / 2);
}



/***************************/
/***************************/
/********** POSTS **********/
/***************************/
/***************************/

.grid.posts {
	color: var(--secondary-color);
}
.grid.posts .thumbnail {
	background: var(--secondary-color);
}
.grid.posts .title {
	font-size: 2em;
}

/*****************************/
/*****************************/
/********** ARTISTS **********/
/*****************************/
/*****************************/

.grid.artists .item {
	color:var(--secondary-color);
}
.grid.artists .thumbnail {
	color:var(--bright-color);
	background:var(--secondary-color);
	aspect-ratio: 8/5;
}
.grid.artists .infos {
	padding:0;
}
.grid.artists .title {
	font-size:2em;
	margin-top:.5em;
}
.grid.artists .title + *:not(.subtitle) {
	margin-top:.5em;
}
.grid.artists .subtitle {
	font-size:.875em;
	text-transform:uppercase;
	color:inherit;
}
.grid.artists .subtitle + * {
	margin-top:.5em;
}

/******************************/
/******************************/
/********** PROJECTS **********/
/******************************/
/******************************/

.grid.projects .infos {
	padding:0;
}
.grid.projects .title {
	font-size:2em;
	margin-top:.5em;
}
.grid.projects .title + *:not(.subtitle) {
	margin-top:.5em;
}
.grid.projects .subtitle {
	text-transform: uppercase;
	/*font-size:1.25em;*/
}
.grid.projects .subtitle + * {
	margin-top:.5em;
}

/*****************************/
/*****************************/
/********** GALLERY **********/
/*****************************/
/*****************************/
/* item > media */

.grid.gallery .items {
	gap:-webkit-calc(var(--global-spacing) / 3);
	gap:-moz-calc(var(--global-spacing) / 3);
	gap:calc(var(--global-spacing) / 3);
}
.grid.gallery .media {
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin: auto;
	width: 100%;
}

/***************************/
/***************************/
/********** LOGOS **********/
/***************************/
/***************************/

.grid.logos .items {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	gap:var(--global-spacing);
}
.grid.logos .item {
	width: auto;
}
.grid.logos .media {
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin: auto;
	/*height:100%;*/
	width: 100%;
	max-width: 14em;
}
.grid.logos img {
	height:100%;
	/*width:100%;*/
	width:auto;
	-o-object-fit: contain;
	   object-fit: contain;
	-webkit-filter:grayscale(1);
	        filter:grayscale(1);
}

/********** @MEDIA **********/

@media (max-width: 760px) {
	.grid.logos .media {
		height:6em;
	}
}
@media (min-width: 760px) {
	.grid.logos .media {
		height:8em;
	}
}

/***************************/
/***************************/
/********** SIZES **********/
/***************************/
/***************************/

.grid .items {
	grid-template-columns: repeat(auto-fill, minmax(var(--item-width), 1fr));
	gap: var(--global-spacing);
}
/*
.grid.logos .items {
	grid-template-columns: repeat(auto-fill, minmax(-webkit-calc(var(--item-width) / 4), 1fr));
	grid-template-columns: repeat(auto-fill, minmax(-moz-calc(var(--item-width) / 4), 1fr));
	grid-template-columns: repeat(auto-fill, minmax(calc(var(--item-width) / 4), 1fr));
}
*/

/********** @MEDIA **********/

@media (max-width: 760px) {
	.grid.related .items {
		-ms-grid-columns: 1fr;
		grid-template-columns: 1fr;
	}
}
@media (min-width: 760px) {
	.grid.related .items {
		-ms-grid-columns: (1fr)[2];
		grid-template-columns: repeat(2, 1fr);
	}
}

/*************************************/
/*************************************/
/********** GRID SWIPERABLE **********/
/*************************************/
/*************************************/
/* limit to 1 row = cf. front events */

.grid.swiperable .item {
	-webkit-flex-basis: var(--item-width);
	    -ms-flex-preferred-size: var(--item-width);
	        flex-basis: var(--item-width);
	-ms-grid-row: 1;
	grid-row: 1;
	min-width: var(--item-width);
}

/*****************************/
/*****************************/
/********** COLUMNS **********/
/*****************************/
/*****************************/

/*
> ONE RESPONSIVE LINE
.columns ==  a | b | c | d (x4 max / vertical centered) [default]
.columns.vertical-centered == vertical centered
.columns.centered
.columns.has-gutter
.columns > .has-gutter
*/

/*****************************/
/********** DEFAULT **********/
/*****************************/
/*
css <=> wp
.columns <=> wp-block-columns
*/

.columns {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	   -moz-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	width: 100%;
	max-width: none; /* for back WP */
	gap: var(--gutter-gap);
}
.columns > * {
	margin: 0;
	list-style-type: none;
}
.columns.fit {
	gap: 0;
}
.columns.large {
	gap: -webkit-calc(var(--gutter-gap) * 2);
	gap: -moz-calc(var(--gutter-gap) * 2);
	gap: calc(var(--gutter-gap) * 2);
}
.columns.reversed {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-webkit-flex-direction: row-reverse;
	   -moz-box-orient: horizontal;
	   -moz-box-direction: reverse;
	    -ms-flex-direction: row-reverse;
	        flex-direction: row-reverse;
}

/***************************/
/********** SIZES **********/
/***************************/

.columns > .min {
	-webkit-box-flex: 0;
	-webkit-flex-grow: 0;
	   -moz-box-flex: 0;
	    -ms-flex-positive: 0;
	        flex-grow: 0;
}
.columns > .short {
	-webkit-box-flex: 0.5;
	-webkit-flex-grow: 0.5;
	   -moz-box-flex: 0.5;
	    -ms-flex-positive: 0.5;
	        flex-grow: 0.5;
}
.columns > .large {
	-webkit-box-flex: 2;
	-webkit-flex-grow: 2;
	   -moz-box-flex: 2;
	    -ms-flex-positive: 2;
	        flex-grow: 2;
}

/******************************/
/********** CENTERED **********/
/******************************/

.columns.centered {
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}
.columns.centered > * {
	text-align: center;
}
.columns.centered ul,
.columns.centered ol {
	text-align: left;
}
.columns.vertical-centered {
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}
.columns.vertical-centered > * {
	margin-top: auto;
	margin-bottom: auto;
}

/**************************/
/********** FULL **********/
/**************************/
/* for ? */

.columns.full > * {
	width: 100%;
	height: 100%;
}

/****************************/
/********** @MEDIA **********/
/****************************/

@media (min-width: 0px) {
	.columns > * {
		-webkit-box-flex: 1;
		-webkit-flex-grow: 1;
		   -moz-box-flex: 1;
		    -ms-flex-positive: 1;
		        flex-grow: 1;
		width: 100%;
	}
	/* gutter */
	.columns.has-gutter > *:not(:last-child) {
		border-bottom: solid var(--line-height);
		padding-bottom: var(--gutter-gap);
		margin-bottom: 0;
	}
}
@media (min-width: 760px) {
	.columns > * {
		-webkit-box-flex: 1;
		-webkit-flex-grow: 1;
		   -moz-box-flex: 1;
		    -ms-flex-positive: 1;
		        flex-grow: 1;
		-webkit-flex-basis: 0 !important;
		    -ms-flex-preferred-size: 0 !important;
		        flex-basis: 0 !important;
		min-width: 15rem;
	}
	/* gutter */
	.columns.has-gutter > *:not(:last-child) {
		border-bottom: 0;
		border-right: solid var(--line-height);
		padding-bottom: 0;
		padding-right: var(--gutter-gap);
		margin-right: 0;
		margin-bottom: var(--gutter-gap);
	}
	.columns > *.has-gutter {
		border-left: solid var(--line-height);
		padding-left: var(--gutter-gap);
	}
}

/***************************/
/********** LIMIT **********/
/***************************/

@media (min-width: 760px) {
	.columns[data-columns='2'] > * {
		-webkit-flex-basis: 50%;
		    -ms-flex-preferred-size: 50%;
		        flex-basis: 50%;
		max-width: -webkit-calc(50% - var(--gutter-gap));
		max-width: -moz-calc(50% - var(--gutter-gap));
		max-width: calc(50% - var(--gutter-gap));
	}
}

/** working as columns **/

.columns.is-limited-large {
	margin-left: auto;
	margin-right: auto;
}
.is-limited-large {
	max-width: -webkit-calc(var(--content-maxwidth) * 2 / 3);
	max-width: -moz-calc(var(--content-maxwidth) * 2 / 3);
	max-width: calc(var(--content-maxwidth) * 2 / 3);
}

/****************************/
/********** CUSTOM **********/
/****************************/

.columns.team {
	font-size:.75em;
}
.columns.team strong {
	font-weight:900;
}