@charset "UTF-8";

:root {
	--color-beige: 242,238,232;
	--color-black: 0,0,0;
	--color-grey-light: 242,238,232;
	--color-pink: 232,128,128;	
	--color-purple: 80,46,129;	
	--color-red: 198,13,13;
	--color-white: 255,255,255;
	
	--gradient-deg: 185deg;

	--base-w: 430;
	--base-w-mobile: 430;
	--page-margin: clamp(min(25px, (25 / var(--base-w)) * 100vw), (25 / var(--base-w)) * 100vw, 25px);
	--page-margin-neg: calc(var(--page-margin) * -1);
	--page-gap: var(--page-margin);
	--page-gap-neg: var(--page-margin-neg);
	--grid-column-gap: 10px;
	--grid-column-w: calc((min(var(--base-w) * 1px, 100vw) - (var(--page-margin) * 2) - (11 * var(--grid-column-gap))) / 12);

	--base-w-gallery: 1440;
	--grid-column-gap-gallery: clamp(min(24px, (24 / 414) * 100vw), (24 / var(--base-w-gallery)) * 100vw, 24px);
}

html {
	height: 100%;
	font-family: montserrat, sans-serif;
	font-weight: 400;
	font-style: normal;
}

body {
	width: 100%;
	height: 100%;
	background: rgb(var(--color-white));
	overflow-x: hidden;
	overflow-y: scroll;
}

body.noscroll {
	overflow: hidden;
}

/*body.loading:after {
    content: "";
    display: block;
    position: fixed;
    width: 100vw;
    height: 100vh;
    left: 0;
    top: 0;
    background: rgb(var(--color-black)) url("../images/) center center no-repeat;
    background-size: clamp(200px, (400 / 1920) * 100vw, 400px) auto;
    pointer-events: none;
    z-index: 10000;
}

body.loading.loaded:after {
    opacity: 0;
    transform: scale(1.2);
    transition: opacity 0.4s 0.8s linear, transform 1s 0.4s cubic-bezier(0.25,0.25,0.25,1);
}*/

body.loading:before,
body.loading:after {
    content: "";
    display: block;
    position: fixed;
    z-index: 10000;
}

body.loading:before {
    width: 100vw;
    height: 100vh;
    left: 0;
    top: 0;
    background: rgba(var(--color-black),0.5) url("../images/") center center no-repeat;
    background-size: clamp(200px, (400 / 1920) * 100vw, 400px) auto;
}

body.loading:after {
	width: 1em;
	height: 1em;
	left: calc(50% - 0.75em);
	top: calc(50% - 0.75em);
	font-size: clamp(min(30px, (30 / 414) * 100vw), (60 / var(--base-w-gallery)) * 100vw, 60px);
	background-color: rgb(var(--color-white));
	background-image: 
		radial-gradient(rgba(var(--color-white),1) 45%, rgba(var(--color-white),0) 45%),
		conic-gradient(rgba(var(--color-purple),0) 25%, rgba(var(--color-purple),1));
	border: solid 0.25em rgb(var(--color-white));
	border-radius: 9999px;
	animation: kf-gallery-loading 1.2s steps(8) both infinite;
}

.notransition {
	transition: none !important;
}

* {
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	-webkit-text-size-adjust: 100%;
}

img, iframe, video {
	display: block;
}

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, hr, p, blockquote, pre, a, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figure, figcaption, hgroup, menu, footer, header, nav, button, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: none;
}

ul, li {
	list-style: none;
}

a {
	color: inherit;
	text-decoration: none;
}

h1, h2, h3, h4, h5, h6 {
	font-size: inherit;
	font-weight: inherit;
	margin: 0;
}

button {
	background: none;
	border-radius: 0;
	cursor: pointer;
}

button::-moz-focus-inner {
    padding: 0;
    border: 0
}

*:focus {
    outline: 0;
}


/*************************************
	Header
 *************************************/


/*************************************
	Sections
 *************************************/


.container {
	display: flex;
	flex-direction: column;
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 100%;
}

main {
	flex: 1 0 auto;
	display: flex;
	flex-direction: column;
	position: relative;
}

section {
    display: block;
    position: relative;
	/*overflow: hidden;*/
}

section > div,
footer > div {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	grid-column-gap: var(--grid-column-gap);
	grid-row-gap: var(--grid-column-gap);
	position: relative;
	/*width: min(var(--base-w) * 1px, 100vw);*/
	width: min(640px, 100vw);
	margin: 0 auto;
	padding: 0 var(--page-margin);
	z-index: 200;
}

h1 {
	font-size: min(80px, (80 / var(--base-w)) * 100vw);
	font-family: the-seasons, sans-serif;
	font-weight: 700;
	font-style: normal;
	line-height: calc((51 / 80) * 1em);
	text-transform: uppercase;
}

h1 small {
	color: rgb(var(--color-black));
	font-size: calc((21 / 80) * 1em);
	font-family: montserrat, sans-serif;
	font-weight: 600;
	letter-spacing: 0.2em;
}

h1:has(+ img.display-inline) {
	margin-bottom: calc((50 / 80) * 1em);
}

h2 {
	font-size: min(44px, (44 / var(--base-w)) * 100vw);
	font-family: the-seasons, sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: calc((44 / 44) * 1em);
}

h2.hide {
	opacity: 0;
	transform: translateY(50%);	
}

h2.show,
.show-grp.show h2 {
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.6s linear, transform 0.6s cubic-bezier(0.25,0.25,0.25,1);
}

section.intro2 h2.show,
.football-europeen h2.show {
	transition-delay: 0.6s;
}

h2:has(+ h3) {
	margin-bottom: calc((30 / 44) * 1em);
}

h2:has(+ p) {
	margin-bottom: calc((12 / 44) * 1em);
}

h3 {
	display: inline-block;
	/*font-size: min(22, (22 / var(--base-w)) * 100vw);*/
	font-size: 22px;
	font-family: the-seasons, sans-serif;
	font-weight: 700;
	font-style: normal;
	line-height: calc((26 / 22) * 1em);
	text-transform: uppercase;
}

h3 {
	mask-image: linear-gradient(90deg,
		rgba(255,255,0,1) 33%, rgba(255,255,0,0) 66%
	);
	mask-position: 100% 0;
	mask-size: 300% 100%;	
}

section.fevrier-14-16 :has(h2.show) h3,
section.fevrier-15-matinee :has(h2.show) h3,
.decouvrez-effervescence :has(h2.show) h3,
.football-europeen :has(h2.show) h3,
.natural-history-museum :has(h2.show) h3 {
	mask-position: 0 0;
	transition: mask-position 0.8s cubic-bezier(0.25,0.25,0.25,1);
}

section.fevrier-14-16 :has(h2.show) h3,
section.fevrier-15-matinee :has(h2.show) h3,
.decouvrez-effervescence :has(h2.show) h3,
.natural-history-museum :has(h2.show) h3 {
	transition-delay: 0.6s;
}

h3:has(+ p) {
	margin-bottom: calc((36 / 22) * 1em);
}

h4 {
	font-size: clamp(14px, (18 / var(--base-w)) * 100vw, 18px);
	font-family: the-seasons, sans-serif;
	font-weight: 700;
	font-style: normal;
	line-height: calc((26 / 18) * 1em);
	text-transform: uppercase;
}

p {
	font-size: clamp(16px, (20 / var(--base-w)) * 100vw, 20px);
	line-height: calc((24 / 20) * 1em);
}

p {
	opacity: 0;
}

section.intro2 :has(h2.show) p,
section.fevrier-14-16 :has(h2.show) p,
section.fevrier-15-matinee :has(h2.show) p,
.vivez-comme-un-londonien :has(h2.show) p,
.decouvrez-effervescence :has(h2.show) p,
.football-europeen :has(h2.show) p,
.natural-history-museum :has(h2.show) p,
.rappels p {
	opacity: 1;
	transition: opacity 0.6s linear;
}

section.intro2 :has(h2.show) p,
section.fevrier-14-16 :has(h2.show) p,
section.fevrier-15-matinee :has(h2.show) p,
.decouvrez-effervescence :has(h2.show) p,
.football-europeen :has(h2.show) p,
.natural-history-museum :has(h2.show) p {
	transition-delay: 1.2s	
}

.vivez-comme-un-londonien :has(h2.show) p {
	transition-delay: 0.6s	
}

p:has(+ p) {
	margin-bottom: calc((24 / 20) * 1em);
}

strong {
    font-weight: 800;
}

sup {
	display: inline-block;
	position: relative;
	font-size: 0.6em;
	vertical-align: top;
	margin-top: -0.3em;
}

picture {
	display: block;
	position: relative;
}

picture img {
	width: 100%;
	height: auto;
}

.color-white {
	color: rgb(var(--color-white));
}

.align-items-center {
    align-items: center;
}

.justify-content-center {
	justify-content: center;
}

.align-self-center {
    align-self: center;
}

.align-self-end {
	align-self: end;	
}

.text-align-left {
    text-align: left;
}

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

.text-align-right {
    text-align: right;
}

.text-decoration-underline {
	text-decoration: underline !important;
}

.text-transform-none {
	text-transform: none !important;
}

.text-transform-uppercase {
	text-transform: uppercase !important;
}

.word-break {
	word-break: break-all;
}

.white-space-nowrap {
	white-space: nowrap;
}

.display-inline {
	display: inline;
}

.border-radius {
	border-radius: 30px;
	overflow: hidden;
}

.grid-column-start {
	grid-column-start: var(--grid-column-start) !important;
}

.grid-column-end {
	grid-column-end: var(--grid-column-end) !important;
}

.grid-row-start {
	grid-row-start: var(--grid-row-start) !important;
}

.grid-row-end {
	grid-row-end: var(--grid-row-end) !important;
}

.bt {
	background: rgb(var(--color-purple));
	border-radius: 9999px;
	color: rgb(var(--color-grey-light));
	font-size: clamp(14px, (16 / var(--base-w)) * 100vw, 16px);
	line-height: 1em;
	padding: 0.25em 1.875em;
}


/*************************************
	Intro
 *************************************/


section.intro,
section.intro2,
section.fevrier-14-16,
section.fevrier-14-soiree,
section.fevrier-15-matinee,
section.fevrier-15-apres-midi,
section.fevrier-15-soiree,
section.rappels,
section.error-404 {
	text-align: center;
}

section.intro2,
section.fevrier-14-16,
section.fevrier-15-soiree {
	color: rgb(var(--color-white));
}

section.fevrier-14-16 div.fevrier-14-soiree,
section.fevrier-15-matinee,
section.fevrier-15-apres-midi,
section.fevrier-15-soiree div.rappels {
	color: rgb(var(--color-black));
}

section.intro {
	background-image: 
		linear-gradient(var(--gradient-deg), rgb(var(--color-beige)) 30%, rgb(var(--color-pink)) 55%, rgb(var(--color-purple)) 90%),
		url("../images/bckg-noise-640.png");
	background-position: center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
	color: rgb(var(--color-red));
}

section.intro > div {
	min-height: 1375px;
	padding-top: 300px;
}

section.intro h1 + img {
	padding-left: 38px;
	animation: kf-touch-scroll 1.2s linear infinite;
}

@keyframes kf-touch-scroll {
    0% {
		transform: scale(1);
	}
	60%, 100% {
		transform: scale(1.15);
	}
}

section.intro .graphics {
	display: block;
	position: absolute;
	width: 100vw;
	height: 100%;
	/*left: min(0px, ((var(--base-w) * 1px) - 100vw) * 0.5);*/
	left: min(0px, (640px - 100vw) * 0.5);
	top: 0;
	overflow: hidden;
}

section.intro .big-ben {
	display: block;
	position: absolute;
	width: 1em;
	height: calc((554 / 156) * 1em);
	left: 50%;
	top: 0;
	background: url("../images/ill-big-ben.png") center center no-repeat;
	background-size: contain;
	font-size: 156px;
	transform: translate(50px, 435px);
	z-index: 10;
}

section.intro .pont-londres {
	display: block;
	position: absolute;
	width: 1em;
	height: calc((274 / 334) * 1em);
	left: 50%;
	top: 0;
	background: url("../images/ill-pont-londres.png") center center no-repeat;
	background-size: contain;
	font-size: 334px;
	transform: translate(-255px, 585px);
	z-index: 10;
}

section.intro2 {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 1070px;
	background-image: 
		radial-gradient(circle, rgba(var(--color-red),1) 535px, rgba(var(--color-red),0) 535px),
		linear-gradient(rgb(var(--color-purple)), rgb(var(--color-purple))),
		url("../images/bckg-noise-640.png");
	background-position: 
		center center,
		left bottom,
		center center;
	background-repeat: repeat;
	background-size: 
		100%,
		100%,
		10%;
	background-attachment:
		scroll,
		scroll,
		fixed;
	background-blend-mode:
		normal,
		multiply;
}

section.intro2 .couronne {
	display: block;
	position: absolute;
	width: 1em;
	height: calc((115 / 117) * 1em);
	left: calc(50% - 0.5em);
	top: -150px;
	background: url("../images/ill-couronne.png") center center no-repeat;
	background-size: contain;
	font-size: 117px;
}

section.intro2 .couronne {
	opacity: 0;
	transform: scale(0.75) translateY(50%);
	transform-origin: center bottom;
}

section.intro2 .couronne.show {
	opacity: 1;
	transform: scale(1) translateY(0);
	transition: opacity 0.6s linear, transform 0.8s cubic-bezier(0.25,0.25,0.25,1);
}

.arrow-down {
	display: flex;
	justify-content: space-between;
	position: absolute;
	width: 90px;
	height: 90px;
	left: 0;
	right: 0;
	margin: 0 auto;
	margin-top: 100px;
}

.arrow-down span {
	display: block;
	position: relative;
	width: 13px;
	height: 52px;
	background: url("../images/ico-arrow-down.svg") center center no-repeat;
	background-size: contain;
	opacity: 0;
	animation: kf-arrow-down 1.6s linear infinite;
}

@keyframes kf-arrow-down {
    0% {
		transform: translateY(-60%);
	}
	0%, 5% {
		opacity: 0;
	}
	30%, 70% {
		opacity: 1;
	}
	95%, 100% {
		opacity: 0;
	}
	100% {
		transform: translateY(60%);
	}
}

.arrow-down span:nth-child(2) {
	align-self: flex-end;
	animation-delay: 0.33s;
	animation-duration: 1.7s;
}

.arrow-down span:nth-child(3) {
	animation-delay: 0.66s;
	animation-duration: 1.8s;
}

section.fevrier-14-16 {
	background-image: 
		linear-gradient(var(--gradient-deg), rgb(var(--color-purple)) 10%, rgb(var(--color-pink)) 45%, rgb(var(--color-beige)) 70%),
		url("../images/bckg-noise-640.png");
	background-position: 
		left bottom,
		center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
	padding-top: 65px;
}

section.fevrier-14-16 h3.show,
section.fevrier-14-soiree .show-grp.show h3,
section.fevrier-15-matinee .show-grp.show h3 {
	transition-delay: 0.6s;
}

section.fevrier-14-16 div:has(iframe) {
	margin-top: 38px;
}

section.fevrier-14-16 div.fevrier-14-soiree {
	padding-top: 167px;
}

section.fevrier-14-16 div.fevrier-14-soiree div + picture {
	margin-top: 75px;
}

section.fevrier-15-matinee {
	background-image: 
		linear-gradient(var(--gradient-deg), rgb(var(--color-beige)), rgb(var(--color-beige))),
		url("../images/bckg-noise-640.png");
	background-position: 
		left top,
		center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
	padding-top: 150px;
}

section.fevrier-15-matinee .coupes {
	display: block;
	position: relative;
	width: 1em;
	height: calc((167 / 304) * 1em);
	font-size: 304px;
	margin: auto;
	margin-top: 24px;
}

section.fevrier-15-matinee .coupes:before,
section.fevrier-15-matinee .coupes:after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background: url("../images/ill-coupes.png") center center no-repeat;
	background-size: contain;
}

section.fevrier-15-matinee .coupes:before {
	clip-path: inset(0 50% 0 0);
	transform: rotate(30deg);
	transform-origin: 25% top;
}

section.fevrier-15-matinee .coupes:after {
	clip-path: inset(0 0 0 50%);
	transform: rotate(-30deg);
	transform-origin: 75% top;
}

section.fevrier-15-matinee .coupes.hide:before,
section.fevrier-15-matinee .coupes.hide:after {
	opacity: 0;
}

section.fevrier-15-matinee .coupes.show:before,
section.fevrier-15-matinee .coupes.show:after {
	opacity: 1;
	transform: rotate(0);
	transition: opacity 0.2s linear, transform 0.6s cubic-bezier(0.25,0.25,0.25,1.75);
}

section.fevrier-15-apres-midi {
	background-image: 
		linear-gradient(var(--gradient-deg), rgb(var(--color-beige)) 10%, rgb(var(--color-pink)) 25%, rgb(var(--color-purple)) 50%),
		url("../images/bckg-noise-640.png");
	background-position: center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
	padding-top: 110px;
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien,
section.fevrier-15-apres-midi .decouvrez-effervescence,
section.fevrier-15-apres-midi .football-europeen {
	background-image:
		linear-gradient(rgb(var(--color-beige)), rgb(var(--color-beige))),
		radial-gradient(ellipse, rgba(var(--color-beige),1) 350px, rgba(var(--color-beige),0) 350px),
		radial-gradient(ellipse, rgba(var(--color-beige),1) 350px, rgba(var(--color-beige),0) 350px),
		linear-gradient(rgb(var(--color-purple)), rgb(var(--color-purple)));
	background-position:
		center top 285px,
		center top 110px,
		center bottom 110px,
		center top;
	background-repeat: no-repeat;
	background-size: 
		100% calc(100% - 220px - 350px),
		700px 513px,
		700px 513px,
		100%;
	padding-top: 270px;
	padding-bottom: 270px;
	z-index: 50;
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien h2,
section.fevrier-15-apres-midi .decouvrez-effervescence h2,
section.fevrier-15-apres-midi .football-europeen h2 {
	color: rgb(var(--color-purple));
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien h2:has(+ h3),
section.fevrier-15-apres-midi .decouvrez-effervescence h2:has(+ h3),
section.fevrier-15-apres-midi .football-europeen h2:has(+ h3) {
	margin-bottom: calc((9 / 44) * 1em);
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien h3 + h2,
section.fevrier-15-apres-midi .decouvrez-effervescence h3 + h2,
section.fevrier-15-apres-midi .football-europeen h3 + h2 {
	margin-top: calc((7 / 44) * 1em);
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien h2:has(+ p),
section.fevrier-15-apres-midi .decouvrez-effervescence h2:has(+ p),
section.fevrier-15-apres-midi .football-europeen h2:has(+ p) {
	margin-bottom: calc((38 / 44) * 1em);
}

section.fevrier-15-apres-midi h4 {
	display: inline-block;
	background: rgb(var(--color-purple));
	border-radius: 20px 20px 0 0;
	color: rgb(var(--color-white));
	margin-top: 30px;
	padding: 0.5em 1.6667em 0 1.6667em;
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien {
	border-radius: 30px 30px 0 0;
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien .tasse-the {
	display: block;
	position: absolute;
	width: 1em;
	height: calc((92 / 124) * 1em);
	left: 0;
	right: 0;
	background: url("../images/ill-tasse-the.png") center center no-repeat;
	background-size: contain;
	font-size: 124px;
	margin: auto;
	margin-top: 24px;
}

section.fevrier-15-apres-midi .decouvrez-effervescence .book-of-mormon {
	display: block;
	position: absolute;
	width: 1em;
	height: calc((209 / 145) * 1em);
	left: 0;
	right: 0;
	background: url("../images/ill-book-of-mormon.png") center center no-repeat;
	background-size: contain;
	font-size: 145px;
	margin: auto;
	margin-top: 24px;
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien .tasse-the.hide,
section.fevrier-15-apres-midi .decouvrez-effervescence .book-of-mormon.hide {
	opacity: 0;
	transform: scale(0.75) translateY(50%);
	transform-origin: center 75%;
}

section.fevrier-15-apres-midi .vivez-comme-un-londonien .tasse-the.show,
section.fevrier-15-apres-midi .decouvrez-effervescence .book-of-mormon.show {
	opacity: 1;
	transform: scale(1) translateY(0);
	transition: opacity 0.2s linear, transform 0.6s cubic-bezier(0.25,0.25,0.25,1);
}

section.fevrier-15-apres-midi .football-europeen {
	background-size: 
		100% calc(100% - 220px - 350px),
		700px 513px,
		700px 513px,
		100% calc(100% - 110px - 175px);
}

section.fevrier-15-apres-midi .football-europeen .ballon-football {
	display: block;
	position: absolute;
	width: 1em;
	height: calc((125 / 127) * 1em);
	left: 0;
	right: 0;
	background: url("../images/ill-ballon-football.png") center center no-repeat;
	background-size: contain;
	font-size: 127px;
	margin: auto;
	margin-top: 24px;
}

section.fevrier-15-apres-midi .football-europeen .ballon-football.hide {
	opacity: 0;
	transform: scale(0.75) translateY(50%);
	transform-origin: center bottom;
}

section.fevrier-15-apres-midi .football-europeen .ballon-football.show {
	opacity: 1;
	transition: opacity 0.2s linear;
	animation: kf-ballon-football 1s linear forwards;
}

@keyframes kf-ballon-football {
    0% {
		transform: scaleY(1) translateY(-50%);
	}
    20% {
		transform: scaleY(1) translateY(0);
	}
	25% {
		transform: scaleY(0.85) translateY(0);
	}
	30% {
		transform: scaleY(1) translateY(0);
	}
    50% {
		transform: scaleY(1) translateY(-25%);
	}
    70% {
		transform: translateY(0);
	}
	75% {
		transform: scaleY(0.95) translateY(0);
	}
	80% {
		transform: scaleY(1) translateY(0);
	}
	90% {
		transform: scaleY(1) translateY(-5%);
	}
	100% {
		transform: scaleY(1) translateY(0);
	}
}

section.fevrier-15-soiree {
	background-image: 
		linear-gradient(var(--gradient-deg), rgb(var(--color-purple)) 10%, rgb(var(--color-pink)) 45%, rgb(var(--color-beige)) 70%),
		url("../images/bckg-noise-640.png");
	background-position: 
		left bottom,
		center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
}

section.fevrier-15-soiree .natural-history-museum .black-tie {
	display: block;
	width: 1em;
	height: calc((150 / 210) * 1em);
	background: url("../images/ill-black-tie.png") center center no-repeat;
	background-size: contain;
	font-size: 210px;
	margin: auto;
	margin-top: 24px;
}

section.fevrier-15-soiree .natural-history-museum .black-tie {
	mask-image: linear-gradient(
		rgba(255,255,0,0) 33%, rgba(255,255,0,1) 66%
	);
	mask-size: 100% 300%;
}

section.fevrier-15-soiree .natural-history-museum .black-tie.show {
	mask-position: 0 100%;
	transition: mask-position 0.8s cubic-bezier(0.25,0.25,0.25,1);
}

section.fevrier-15-soiree .rappels {
	text-align: left;
	padding-top: 137px;
	padding-bottom: 50px;
}

section.fevrier-15-soiree .rappels p {
	font-size: 14px;
}

section.fevrier-15-soiree .rappels a,
section.fevrier-15-soiree .rappels strong {
	color: rgb(var(--color-purple));
}

section.fevrier-15-soiree .rappels a {
	text-decoration: underline;
}

.bus-container {
	display: block;
	position: absolute;
	width: 100vw;
	height: 100%;
	left: calc(50% - 50vw);
	overflow: hidden;
	pointer-events: none;
	transform: scale(1.5);
	transform-origin: center 15%;
}

.bus {
	display: block;
	position: absolute;
	width: 766px;
	left: calc(50% - (766px / 2));
}

@media screen and (min-width: 640px) {
	.bus {
		mask-image: linear-gradient(90deg, 
			rgba(255,255,0,0) calc(50% - (var(--base-w) * 0.5px)), rgba(255,255,0,1) calc((50% - (var(--base-w) * 0.5px)) + 50px), 
			rgba(255,255,0,1) calc((50% + (var(--base-w) * 0.5px)) - 50px), rgba(255,255,0,0) calc(50% + (var(--base-w) * 0.5px))
		);
	}
}

.bus > div.img {
	position: relative;
	width: 0;
	height: 0;
	offset-path: var(--path);
	transform: scale(calc((var(--offset-d) * 0.4) + 0.6));
}

.bus > div.img > div {
	content: "";
	display: block;
	width: 168px;
	height: 168px;
	left: 0;
	top: 0;
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: 100% auto;
	transform: translate(-50%, -100%);
}

.bus-container.from-left .bus > div.img > div {
	background-image: url("../images/img-bus-from-left.png");
}

@supports (background-image: url("../images/img-bus-from-left.webp")) {
	.bus-container.from-left .bus > div.img > div {
		background-image: url("../images/img-bus-from-left.webp");
	}
}

.bus-container.from-right .bus > div.img > div {
	background-image: url("../images/img-bus-from-right.png");
}

@supports (background-image: url("../images/img-bus-from-right.webp")) {
	.bus-container.from-right .bus > div.img > div {
		background-image: url("../images/img-bus-from-right.webp");
	}
}

.bus-container.from-left .bus > div.img {
	offset-distance: calc(var(--offset-d) * 100%);
}

.bus-container.from-right .bus > div.img {
	offset-distance: calc(100% - (var(--offset-d) * 100%));
}

.bus > div.img > img {
	display: none;
}

.bus svg {
	width: 766px;
	height: auto;
}

.bus svg path {
	fill: none;
	stroke: rgb(var(--color-red));
	stroke-miterlimit: 10;
	stroke-width: 2px;
}

section.intro .bus-container.intro.from-right {
	top: 180px;
}

section.intro .bus-container.intro.from-right .bus > div.img {
	transform: none;
}

section.intro .bus-container.intro.from-right .bus svg path {
	stroke: none;
}

section.intro .bus-container.from-right {
	top: 430px;
}

section.intro .bus-container.from-left {
	top: 1000px;
}

section.fevrier-14-16 .bus-container.from-right {
	top: -110px;
}

section.fevrier-14-16 div.fevrier-14-soiree .bus-container.from-left {
	top: -50px;
}

section.fevrier-15-matinee .bus-container.from-right {
	top: -250px;
}

section.fevrier-15-apres-midi .bus-container.from-left {
	height: 180px;
	top: -170px;
}

section.fevrier-15-apres-midi .decouvrez-effervescence .bus-container.from-right {
	top: -110px;
}

section.fevrier-15-apres-midi .football-europeen .bus-container.from-left {
	height: 250px;
	/*top: -150px;*/
	top: -220px;
}

section.fevrier-15-soiree .natural-history-museum .bus-container.from-right {
	top: -180px;
}

section.fevrier-15-soiree .rappels .bus-container.from-left {
	top: -80px;
}

section.fevrier-15-soiree .rappels .bus-container.from-left {
	top: -140px;
	height: 300px;
}

section.fevrier-15-soiree .rappels .bus-container.from-left .bus > div.img {
	offset-distance: calc(var(--offset-d) * 50%);
}

div.coeurs {
	display: block;
	position: fixed;
	width: 100vw;
	height: 100vh;
	left: 0;
	top: 0;
	z-index: 100;
	pointer-events: none;
}

div.coeur {
	--coeur-base-s: 25px;
	--coeur-move-up: calc((var(--coeur-s) * (var(--coeur-base-s) * 2)) * -1);
	display: block;
	position: absolute;
	width: 0;
	height: 0;
	left: var(--coeur-x);
	top: var(--coeur-y);
	opacity: var(--coeur-s);
	animation: kf-coeur-scale 3s linear forwards;
}

div.coeur:before {
	content: "";
	display: block;
	position: absolute;
	width: calc(var(--coeur-base-s) * var(--coeur-s));
	height: calc((180 / 200) * (var(--coeur-base-s) * var(--coeur-s)));
	left: calc((var(--coeur-base-s) * -0.5) * var(--coeur-s));
	top: calc((180 / 200) * ((var(--coeur-base-s) * -1) * var(--coeur-s)));
	background: url("../images/ill-coeur.svg") center center no-repeat;
	background-size: contain;
	animation: kf-coeur-move-up 3s linear forwards;
}

@keyframes kf-coeur-move-up {
    0% {
		opacity: 0;
		transform: translateY(0);
	}
    25%, 75% {
		opacity: 1;
	}
    100% {
		opacity: 0;
		transform: translateY(var(--coeur-move-up));
	}
}

@keyframes kf-coeur-scale {
    0% {
		transform: scale(0.1);
		animation-timing-function: linear;
	}
	25% {
		transform: scale(0.75);
		animation-timing-function: cubic-bezier(0.25,0.25,0.25,1);
	}
    75% {
		transform: scale(1);
		animation-timing-function: linear;
	}
    100% {
		transform: scale(1.2);
		animation-timing-function: cubic-bezier(0.25,0.25,0.25,1);
	}
}

section.intro2 div.coeurs-larges {
	display: block;
	position: absolute;
	width: min(800px, 100vw);
	height: 120vh;
	min-height: 0 !important;
	left: 0;
	right: 0;
	top: calc(250px - 120vh);
	margin: 0 auto !important;
	padding: 0 !important;
	overflow: hidden;
}

@media screen and (min-width: 640px) {
	section.intro2 div.coeurs-larges {
		mask-image: linear-gradient(90deg, 
			rgba(255,255,0,0), rgba(255,255,0,1) 10%, 
			rgba(255,255,0,1) 90%, rgba(255,255,0,0)
		);
	}
}

section.intro2 div.coeurs-larges > div {
	display: block;
	position: absolute;
	width: 100%;
	height: 100px;
	left: 0;
	bottom: 0;
}

section.intro2 div.coeurs-larges div.coeur {
	--coeur-base-s: 300px;
	--coeur-move-up: calc((var(--coeur-s) * (var(--coeur-base-s) * 1)) * -1);
	opacity: 1;
}

.view-master-container {
	display: block;
	position: absolute;
	width: 100%;
	height: 300px;
	left: 0;
	top: 0;
	overflow: hidden;
	z-index: 10;
	mask-image: linear-gradient(rgba(255,255,0,1) 75%, rgba(255,255,0,0));
}

.view-master {
	display: block;
	position: absolute;
	width: 700px;
	height: 513px;
	left: calc(50% - 350px);
	top: 110px;
}

.view-master > picture {
	offset-path: path("M0.5,257c0-141.7,156.7-256.5,350-256.5s350,114.8,350,256.5");
	width: 0;
	height: 0;
}

.view-master > picture.img1 {
	offset-distance: calc((var(--offset-d) * 100%) + 50%);
}

.view-master > picture.img2 {
	offset-distance: calc((var(--offset-d) * 100%) + 25%);
}

.view-master > picture.img3 {
	offset-distance: calc((var(--offset-d) * 100%));
}

.view-master > picture.img4 {
	offset-distance: calc((var(--offset-d) * 100%) - 25%);
}

.view-master > picture.img5 {
	offset-distance: calc((var(--offset-d) * 100%) - 50%);
}

.view-master > picture > img {
	width: 145px;
	height: auto;
	transform: translate(-50%, -50%);
}




section:has(> div.gallery):before {
	content: "";
	display: block;
	position: fixed;
	width: 100vw;
	height: 100vh;
	background-image: 
		linear-gradient(var(--gradient-deg), rgb(var(--color-beige)) 30%, rgb(var(--color-pink)) 55%, rgb(var(--color-purple)) 90%),
		url("../images/bckg-noise-640.png");
	background-position: center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
	color: rgb(var(--color-red));
}

section > div.gallery {
	/*display: grid;
	grid-template-columns: repeat(12, 1fr);
	grid-column-gap: var(--grid-column-gap-gallery);
	grid-row-gap: var(--grid-column-gap-gallery);
	position: relative;
	width: min(640px, 100vw);
	padding: 0 var(--page-margin);
	z-index: 200;*/
	position: relative;
	width: min(var(--base-w-gallery) * 1px, 100vw);
	margin: 0 auto;
	padding: 0 clamp(min(100px, (100 / var(--base-w-gallery)) * 100vw), (100 / var(--base-w-gallery)) * 100vw, 100px);
}

section > div.gallery > form {
	grid-column: 1 / -1;
}

.gallery h1 {
	grid-column: 1 / -1;
	color: rgb(var(--color-purple));
	line-height: 0.9em;
	margin-top: 2em;
	transform: translateY(1.1111em);
}

.gallery.show h1 {
	opacity: 1;
	transform: translate(0);
	transition: opacity 0.4s linear, transform 0.6s cubic-bezier(0.25,0.25,0.25,1);
	transition-delay: calc(var(--transition-delay) + var(--transition-delay-1));
}

.gallery h2 {
	color: rgb(var(--color-black));
	opacity: 0;
	margin: 0.5em 0 2em;
}

.gallery.show h2 {
	transition-delay: calc(var(--transition-delay) + var(--transition-delay-1) + 0.4s);
}

.gallery ul {
	grid-column: 1 / -1;
	display: grid;
	position: relative;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	grid-gap: var(--grid-column-gap-gallery);
	padding: var(--grid-column-gap-gallery);
}

.gallery ul li {
	position: relative;
	background: rgb(var(--color-white));
}

.gallery ul li:after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	left: calc(var(--grid-column-gap-gallery) * -0.25);
	top: calc(var(--grid-column-gap-gallery) * -0.25);
	border: solid rgba(var(--color-white),0.75) calc(var(--grid-column-gap-gallery) * 0.25);
	pointer-events: none;
}

.gallery ul li div {
	display: block;
	position: relative;
	margin: calc((var(--grid-column-gap-gallery) * 0.25) * -1);
	overflow: hidden;
}

.gallery ul li picture {
	display: block;
	position: relative;
	margin: calc((var(--grid-column-gap-gallery) * 0.25));
	padding-top: 66%;
	transition: transform 1.2s cubic-bezier(0.25,0.25,0.25,1);
}

.gallery ul li:hover picture.loaded {
	transform: scale(1.1);
}

.gallery ul li picture:before {
	content: "";
	min-height: 0vh;
	display: block;
	position: absolute;
	width: 1em;
	height: 1em;
	left: calc(50% - 0.5em);
	top: calc(50% - 0.5em);
	font-size: clamp(min(30px, (30 / 414) * 100vw), (30 / var(--base-w-gallery)) * 100vw, 30px);
	background-image: 
		radial-gradient(rgba(var(--color-white),1) 45%, rgba(var(--color-white),0) 45%),
		conic-gradient(rgba(var(--color-purple),0) 25%, rgba(var(--color-purple),1));
	border-radius: 9999px;
	animation: kf-gallery-loading 1.2s steps(8) both infinite;
	opacity: 0;
	transition: opacity 0.2s linear;
}

.gallery.show ul li picture:before {
	opacity: 1;
	transition-delay: 0.4s;
}

.gallery.show ul li picture.loaded:before {
	opacity: 0;
	transition-delay: 0s;
}

@keyframes kf-gallery-loading {
    0% {
		transform: rotate(0deg);
	}
    100% {
		transform: rotate(360deg);
	}
}

.gallery ul li img {
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	object-fit: cover;
	opacity: 0;

}

.gallery.show ul li picture.loaded img {
	opacity: 1;
	transition: opacity 0.4s linear;
	transition-delay: calc(var(--transition-delay) + var(--transition-delay-1) + var(--transition-delay-2) + 0.2s);
}

.gallery.show ul li a[data-iframe] figure:after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background-position: center center;
	background-repeat: no-repeat;
}

.gallery.show ul li a[data-iframe*="https://www.youtube.com/"] figure:after,
.gallery.show ul li a[data-iframe*="https://player.vimeo.com/"] figure:after {
	background-image: url("../images/ico-play.svg");
}

.gallery.show ul li a[data-iframe*="https://my.matterport.com/"] figure:after {
	background-image: url("../images/ico-360.svg");
}

.gallery.show ul li a[data-iframe] figure picture:after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background-image: 
		linear-gradient(rgba(var(--color-blue-1),0.65), rgba(var(--color-blue-1),0.5));
	background-position: center center;
	background-repeat: no-repeat;
}

.gallery figcaption {
	display: block;
	position: absolute;
	width: calc(100% - (var(--grid-column-gap-gallery) * 0.5));
	left: calc(var(--grid-column-gap-gallery) * 0.25);
	bottom: calc(var(--grid-column-gap-gallery) * 0.25);
	background: rgba(var(--color-white),0.75);
	color: rgb(var(--color-white));
	text-align: center;
	padding: calc(var(--grid-column-gap-gallery) * 0.5);
}

.gallery .tools {
	display: flex;
	justify-content: space-between;
	position: sticky;
	width: 100%;
	top: 0;
	background: rgb(var(--color-purple));
	border-radius: 10px;
	color: rgb(var(--color-white));
	font-size: clamp(12px, (16 / var(--base-w)) * 100vw, 16px);
	line-height: calc((24 / 20) * 1em);
	margin-bottom: 1.5em;
	padding: 0.75em;
	z-index: 10;
}

.gallery .tools button {
	background: rgb(var(--color-white));
	border-radius: 5px;
	color: rgb(var(--color-purple));
    font-size: clamp(12px, (16 / var(--base-w)) * 100vw, 16px);
	padding: 0.75em;
}

.gallery .tools button.select-all span {
	display: inline-block;
	position: relative;
	width: 1em;
    height: 1em;
    min-height: 0vh;
    background: rgb(var(--color-white));
	border: solid 1px rgb(var(--color-purple));
	border-radius: 0.2em;
	vertical-align: middle;
}

.gallery .tools button.select-all span:after {
	content: "";
	position: absolute;
	width: 0.7em;
	height: 0.7em;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
    background: rgb(var(--color-purple));
	border: none;
	border-radius: 0.1em;
	margin: auto;
}

.gallery:has(input[name="selection[]"]:checked) .tools button.select-all span:after {
	display: none;
}

.gallery .tools button[type="submit"] {
	opacity: 0.25;
	pointer-events: none;
}

.gallery:has(input[name="selection[]"]:checked) .tools button[type="submit"] {
	opacity: 1;
	pointer-events: auto;
}

.gallery .download {
	display: flex;
	justify-content: flex-end;
	position: absolute;
	width: calc(100% - (var(--grid-column-gap-gallery) * 0.5));
	left: calc(var(--grid-column-gap-gallery) * 0.25);
	bottom: calc(var(--grid-column-gap-gallery) * 0.25);
	/*background: rgba(var(--color-white),0.5);*/
	font-size: clamp(12px, (16 / var(--base-w)) * 100vw, 16px);
	margin: 0;
	padding: 0.5em 0.75em;
}

.gallery .download button {
	display: none;
	color: rgb(var(--color-white));
	font-size: 16px;
}

.gallery input[type="checkbox"] {
	position: relative;
    align-self: start;
	width: auto;
	height: auto;
	-webkit-appearance: none;
	appearance: none;
	border: none;
	font-size: 0;
	margin: 0;
	padding: 0;
}

.gallery input[type="checkbox"]:before,
.gallery input[type="checkbox"]:after,
.gallery.lightbox-content button.select:before,
.gallery.lightbox-content button.select:after {
	content: "";
    display: block;
    width: 1em;
    height: 1em;
    min-height: 0vh;
    background: rgb(var(--color-white));
	border: solid 2px rgb(var(--color-purple));
	border-radius: 0.2em;
    font-size: clamp(12px, (16 / var(--base-w)) * 100vw, 16px);
	/*margin: 0.4em;*/
    transition: background 0.2s linear;
}

.gallery input[type="checkbox"]:before, 
.gallery.lightbox-content button.select:before {
	box-shadow: 0 0 1.5em rgb(var(--color-white),0.5);
}

.gallery input[type="checkbox"]:after,
.gallery.lightbox-content button.select:after {
	position: absolute;
	width: 0.7em;
	height: 0.7em;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	border: none;
	border-radius: 0.1em;
	margin: auto;
}

.gallery input[type="checkbox"]:checked:after,
.gallery.lightbox-content button.select.selected:after {
    background: rgb(var(--color-purple));
}

.gallery.lightbox-content button.select {
	position: absolute;
	right: calc(var(--grid-column-gap) * 2);
	bottom: calc(var(--grid-column-gap) * 2);
}

form.login {
	display: flex;
	flex-direction: column;
	position: absolute;
	left: 50%;
	top: 50%;
	font-size: 0px;
	transform: translate(-50%, -50%);
}

form.login input, 
form.login textarea,
form.login select,
form.login label,
form.login p,
form.login button[type="submit"] {
    display: block;
    position: relative;
    min-height: 0vh;
	font-family: montserrat, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: clamp(16px, (20 / var(--base-w-gallery)) * 100vw, 20px);
    line-height: 1.3333em;
    margin: 0;
}

form.login input, 
form.login textarea,
form.login select,
form.login button[type="submit"] {
    width: 100%;
    background: rgb(var(--color-white));
	border: solid 1px rgb(var(--color-purple));
	border-radius: 0.25em;
    color: rgb(var(--color-purple));
    -webkit-appearance: none;
	appearance: none;
    padding: 0.5em;
}

form.login label + input,
form.login label + textarea {
    margin-top: 0.3333em;
}

form.login input:not([type="hidden"]) + label {
    margin-top: 1.5em;
}

form.login button[type="submit"] {
    background: rgb(var(--color-purple));
    color: rgb(var(--color-white));
    font-weight: 500;
    text-transform: uppercase;
    margin-top: 1.5em;
}

form.login input:-webkit-autofill,
form.login input:-webkit-autofill:hover, 
form.login input:-webkit-autofill:focus, 
form.login input:-webkit-autofill:active{
    -webkit-text-fill-color: rgb(var(--color-blue-2));
	-webkit-box-shadow: 0 0 0 60px rgb(var(--color-beige-2)) inset !important;
	box-shadow: 0 0 0 60px rgb(var(--color-beige-2)) inset !important;
}

form.login p {
	color: rgb(var(--color-blue-3));
}

form.login button[type="submit"] + p {
	margin-top: 4.5em;
}

form.login p small {
	font-size: 0.7em;
    line-height: 1.2em;
}




/*form.login * + label {
	margin-top: 1em;
}

form.login input {
	margin-top: 1em;
}

form.login button {
	margin-top: 2em;
}*/


section.error-404 {
	display: flex;
	align-items: center;
	min-height: 100vh;
	color: rgb(var(--color-black));
}

section.error-404 h1 {
	color: rgb(var(--color-grey-light));
	font-size: min(195px, (195 / var(--base-w)) * 100vw);
	font-weight: 400;
	line-height: 1em;
}

section.error-404 h1:has(+ img.display-inline) {
	margin-bottom: calc((-145 / 195) * 1em);
}

section.error-404 h1 + img {
	width: min(280px, (280 / var(--base-w)) * 100vw);
}

section.error-404 h2 {
	color: rgb(var(--color-purple));
	text-transform: uppercase;
	margin: calc((50 / 44) * 1em) 0 calc((28 / 44) * 1em) 0;
}

section.error-404 p {
	opacity: 1;
}

body.deroulement-et-renseignements p {
	opacity: 1;
}

body.deroulement-et-renseignements ol {
    counter-reset: count-ordered-list;
}

body.deroulement-et-renseignements ol li,
body.deroulement-et-renseignements ul li {
	position: relative;
	font-size: clamp(16px, (20 / var(--base-w)) * 100vw, 20px);
	line-height: calc((24 / 20) * 1em);	
	padding-left: 1rem;
}

body.deroulement-et-renseignements ol li + li,
body.deroulement-et-renseignements ul li + li {
	margin-top: calc((24 / 20) * 1em);
}

body.deroulement-et-renseignements ol li:before {
    content: counter(count-ordered-list)".";
	counter-increment: count-ordered-list;
    display: inline-block;
    position: absolute;
    left: 0;
}

body.deroulement-et-renseignements ul li:before {
    content: "•";
    display: inline-block;
    position: absolute;
    left: 0;
}

body.deroulement-et-renseignements a {
	text-decoration: underline;
}

body.deroulement-et-renseignements h2 {
	color: rgb(var(--color-purple));
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.6s linear, transform 0.6s cubic-bezier(0.25,0.25,0.25,1);
}

body.deroulement-et-renseignements h3 {
	mask-position: 0 0;
}

body.deroulement-et-renseignements p + h3,
body.deroulement-et-renseignements ol + h3,
body.deroulement-et-renseignements ul + h3 {
	margin-top: calc((36 / 22) * 1em);
}

body.deroulement-et-renseignements h4 {
	text-transform: none;
}

body.deroulement-et-renseignements ol + p,
body.deroulement-et-renseignements ul + p,
body.deroulement-et-renseignements h2 + p,
body.deroulement-et-renseignements p + ol,
body.deroulement-et-renseignements p + ul,
body.deroulement-et-renseignements h2 + ol,
body.deroulement-et-renseignements h2 + ul,
body.deroulement-et-renseignements h3 + p,
body.deroulement-et-renseignements h3 + ol,
body.deroulement-et-renseignements h3 + ul,
body.deroulement-et-renseignements h4 + p,
body.deroulement-et-renseignements h4 + ol,
body.deroulement-et-renseignements h4 + ul {
	margin-top: calc((24 / 20) * 1em);
}

body.deroulement-et-renseignements h4 {
	font-size: 22px;
	line-height: calc((26 / 22) * 1em);
}

body.deroulement-et-renseignements section {
	background-position: center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
	color: rgb(var(--color-black));
	padding: var(--page-margin) 0;
}

body.deroulement-et-renseignements section > div > div {
	padding: var(--page-margin);
}

body.deroulement-et-renseignements section.der-intro {
	background-image: 
		linear-gradient(rgb(var(--color-purple)) 25%, rgb(var(--color-beige))),
		url("../images/bckg-noise-640.png");
	color: rgb(var(--color-beige));
}

body.deroulement-et-renseignements section.der-avion,
body.deroulement-et-renseignements section.der-transport,
body.deroulement-et-renseignements section.der-souper-15,
body.deroulement-et-renseignements section.der-notes-medical {
	background-image: 
		linear-gradient(rgb(var(--color-beige)), rgb(var(--color-beige))),
		url("../images/bckg-noise-640.png");
}

body.deroulement-et-renseignements section.der-hebergement {
	background-image: 
		linear-gradient(rgb(var(--color-beige)), rgba(var(--color-pink),0.75)),
		url("../images/bckg-noise-640.png");
}

body.deroulement-et-renseignements section.der-souper-14 {
	background-image: 
		linear-gradient(rgba(var(--color-pink),0.75), rgba(var(--color-pink),0.75)),
		url("../images/bckg-noise-640.png");
}

body.deroulement-et-renseignements section.der-samedi {
	background-image: 
		linear-gradient(rgba(var(--color-pink),0.75), rgba(var(--color-pink),0.5)),
		url("../images/bckg-noise-640.png");
}

body.deroulement-et-renseignements section.der-souper-15 {
	background-image: 
		linear-gradient(rgba(var(--color-pink),0.5), rgb(var(--color-beige))),
		url("../images/bckg-noise-640.png");
}

body.deroulement-et-renseignements section.der-main {
	background-image: 
		linear-gradient(rgb(var(--color-beige)), rgb(var(--color-pink)) 55%, rgb(var(--color-beige)) 90%),
		url("../images/bckg-noise-640.png");
	background-position: center center;
	background-repeat: repeat;
	background-size: 
		100%,
		10%;
	background-attachment:
		scroll,
		fixed;
	background-blend-mode: multiply;
}

body.deroulement-et-renseignements section.der-informations {
	background: rgb(var(--color-purple));
	color: rgb(var(--color-beige));
}

body.deroulement-et-renseignements section.der-informations h2 {
	color: rgb(var(--color-beige));
}

section.header-back {
	background-image: 
		linear-gradient(rgb(var(--color-purple)), rgb(var(--color-purple))),
		url("../images/bckg-noise-640.png");
	color: rgb(var(--color-beige));
	text-align: center;
	padding: 0 !important;
}

section.header-back > div > div {
	padding: calc(var(--page-margin) * 0.5) !important;
}

section.header-back p {
	opacity: 1;
}

section.header-back a {
	color: rgb(var(--color-beige));
	text-decoration: underline;
	text-transform: uppercase;
}


/*************************************
	Lightbox
 *************************************/


#lightbox,
#lightbox .lightbox_bckg {
	position: fixed;
	display: none;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
}

#lightbox {
	z-index: 2000;
}

#lightbox.show {
	display: block;
	animation: kf-fade-in 0.2s linear 0s forwards;
}

#lightbox .lightbox_bckg {
	display: block;
	background: rgba(var(--color-black),0.6);
}

#lightbox button.bt-close {
	position: absolute;
	width: 1em;
	height: 1em;
	right: 0;
	top: -1.25em;
	font-size: clamp(min(36px, (36 / 414) * 100vw), (45 / var(--base-w-gallery)) * 100vw, 45px);
	background: rgba(var(--color-white),1) url("../images/ico-close.svg") center center no-repeat;
	background-size: auto 0.6em;
}

#lightbox div.lightbox-container {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
    pointer-events: none;
}

#lightbox div.lightbox-content {
	display: block;
	position: relative;
    pointer-events: auto;
}

#lightbox div.lightbox-content.gallery {
	display: flex;
	justify-content: center;
	align-items: center;
	width: auto;
	height: auto;
}

#lightbox div.lightbox-content.gallery iframe,
#lightbox div.lightbox-content.gallery img {
	border: solid var(--grid-column-gap) rgb(var(--color-white));
	/*box-shadow: 0 min(30px, (30 / 414) * 100vw) min(60px, (60 / 414) * 100vw) rgba(var(--color-black),0.35);*/
	box-shadow: 0 0 10vw rgba(var(--color-black),0.5);	
	animation: kf-fade-in 0.8s linear 0s forwards;
}

#lightbox div.lightbox-content.gallery img {
	width: auto;
	height: auto;
	/*max-width: calc((var(--grid-column-w) * 10) + (var(--grid-column-gap-gallery) * 9));
	max-height: calc(100vh - ((var(--grid-column-w) * 2) + (var(--grid-column-gap-gallery) * 2)));*/
	max-width: 80vw;
	max-height: 80vh;
}

#lightbox div.lightbox-content.gallery iframe {
	width: 100vw;
	height: 100vh;
	/*max-width: calc((var(--grid-column-w) * 10) + (var(--grid-column-gap) * 9));
	max-height: calc((480 / 853) * ((var(--grid-column-w) * 10) + (var(--grid-column-gap) * 9)));*/
	max-width: 80vw;
	max-height: calc((9 / 16) * 80vw);
	background: rgb(var(--color-black));
}

#lightbox div.lightbox-content.gallery .ctrl-arr {
	display: flex;
	justify-content: space-between;
	position: absolute;
	width: min((var(--base-w-gallery) * 1px) - (var(--page-margin) * 2), 100vw - (var(--page-margin) * 2));
	left: 50%;
	top: 50%;
	pointer-events: none;
	transform: translate(-50%, -50%);
}

#lightbox div.lightbox-content.gallery .ctrl-arr button {
	display: block;
	width: clamp(min(36px, (36 / 414) * 100vw), (80 / var(--base-w-gallery)) * 100vw, 80px);
	height: clamp(min(27px, (27 / 414) * 100vw), (60 / var(--base-w-gallery)) * 100vw, 60px);
	background: rgba(var(--color-white),1) url("../images/ico-arrow-slideshow.svg") center center no-repeat;
	background-size: clamp(min(24px, (24 / 414) * 100vw), (50 / var(--base-w-gallery)) * 100vw, 50px) auto;
	opacity: 0.2;
	pointer-events: none;
}

#lightbox div.lightbox-content.gallery .ctrl-arr button[data-dir="next"] {
    transform: scaleX(-100%);
}

#lightbox div.lightbox-content.gallery div.ctrl-arr button.show {
	opacity: 1;
	pointer-events: auto;
}

@media screen and (max-width: 960px) {
	#lightbox button.bt-close {
		right: 0.25em;
	}
	
	#lightbox div.lightbox-content.gallery img {
		max-width: 100vw;
		max-height: 100vh;
	}
	
	#lightbox div.lightbox-content.gallery iframe {
		/*max-width: calc((var(--grid-column-w) * 14) + (var(--grid-column-gap-gallery) * 13));
		max-height: calc((var(--grid-column-w) * 14) + (var(--grid-column-gap-gallery) * 13));*/
		max-width: 100vw;
		max-height: calc((9 / 16) * 100vw);
	}
}




.bp-980,
.bp-640 {
	display: none;
}

.bp-1920 {
	display: inline-block;
}

@media screen and (max-width: 980px) {
	.bp-1920 {
		display: none;
	}
	
	.bp-980 {
		display: inline-block;
	}
	
	.grid-column-start-tablet {
		grid-column-start: var(--grid-column-start-tablet) !important;
	}

	.grid-column-end-tablet {
		grid-column-end: var(--grid-column-end-tablet) !important;
	}

	.grid-row-start-tablet {
		grid-row-start: var(--grid-row-start-tablet) !important;
	}

	.grid-row-end-tablet {
		grid-row-end: var(--grid-row-end-tablet) !important;
	}
}

@media screen and (max-width: 640px) {
	--base-w: 430;
	
	.bp-980 {
		display: none;
	}
	
	.bp-640 {
		display: inline-block;
	}
	
	section > div {
		width: min(var(--base-w) * 1px, 100vw);
	}
	
	section.intro .graphics {
		left: min(0px, ((var(--base-w) * 1px) - 100vw) * 0.5);
	}
	
	.bus-container {
		transform: scale(1);
	}
	
	section.fevrier-15-soiree .rappels .bus-container.from-left {
		top: -80px;
	}
	
	section.fevrier-15-apres-midi .football-europeen .bus-container.from-left {
		top: -150px;
	}

	
	.grid-column-start-mobile {
		grid-column-start: var(--grid-column-start-mobile) !important;
	}

	.grid-column-end-mobile {
		grid-column-end: var(--grid-column-end-mobile) !important;
	}

	.grid-row-start-mobile {
		grid-row-start: var(--grid-row-start-mobile) !important;
	}

	.grid-row-end-mobile {
		grid-row-end: var(--grid-row-end-mobile) !important;
	}
}

.body-preload,
.preload {
	display: none !important;
}