@charset "UTF-8";

/***************************/
/***************************/
/********** STYLE **********/
/***************************/
/***************************/

/*****************************/
/********** DEFAULT **********/
/*****************************/

* {
	-webkit-box-sizing:border-box;
	   -moz-box-sizing:border-box;
	        box-sizing:border-box;
}
html {
	font-size:100%;
}
html,
input,
textarea,
select,
button {
	-webkit-font-smoothing:antialiased;
	-moz-osx-font-smoothing:grayscale;
	-webkit-text-size-adjust:100%;
}
h1, h2, h3, h4, h5, h6,
ul, ol,
p, a, span,
blockquote, label, div, table,
input, textarea, button, select {
	margin:0;
	padding:0;
	font-weight:inherit;
}
p {
	font-size:inherit;
	line-height:inherit;
	color:inherit;
	text-shadow:inherit;
}
b, strong, del,
i, em {
	font-size:inherit;
	line-height:inherit;
}
mark {
	color:var(--accent-color);
	background: none;
}

/************************/
/********** HR **********/
/************************/

hr {
	width:100%;
	border:0;
	border-bottom:solid var(--line-height);
}
hr.blank {
	border:0 !important;
}

/***********************************/
/********** LIST / INLINE **********/
/***********************************/

.list > * {
	display:block;
}
.inline {
	display:flex;
}
.inline.vertical-centered {
	align-items: center;
}
.inline > * {
	display:inline-block;
	vertical-align:middle;
}

/********************************/
/********** BLOCKQUOTE **********/
/********************************/

blockquote {
	display: flex;
	flex-direction: column;
}
blockquote cite {
	margin-top: 1em;
	font-weight: var(--font-weight-medium);
}

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

@media screen and (max-device-width:320px) {
	body {
		-webkit-text-size-adjust:none;
	}
}

/*****************************/
/*****************************/
/********** UL / OL **********/
/*****************************/
/*****************************/

/********** UL **********/

ul li {
	list-style-type: disc;
	margin-left:1em;
	padding-left: .5em;
}

/********** OL **********/

ol {
	margin:0;
	list-style-type:none;
}
ol li {
	position:relative;
	display:flex;
	align-items:center;
	counter-increment:step-counter;
	text-align:left;
}
ol li + li {
	margin-top:.25em;
}
ol li:before {
	content:counter(step-counter);
	display:inline-block;
	text-align:center;
	font-size:.75em;
	line-height:1em;
	height:1em;
	width:1em;
	min-width:1em;
	padding:.5em;
	margin: 0 1em 0 0;
	border-radius:50%;
	color:var(--bright-color);
	background: var(--dark-color);
}

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

/*****************************/
/********** DEFAULT **********/
/*****************************/

.hidden {
	position:absolute;
	font-size:0 !important;
	padding:0 !important;
}
.disabled {
	opacity:.5;
	pointer-events:none;
}
.centered {
	text-align:center;
}

/****************************/
/********** TITLES **********/
/****************************/

h1,
h2,
h3,
h4,
h5,
h6 {
	display:flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: calc(var(--global-spacing) / 2);
	width:100%;
}
.centered h1,
.centered h2,
.centered h3,
.centered h4,
.centered h5,
.centered h6 {
	justify-content: center;
}
h1 > * + *,
h2 > * + *,
h3 > * + *,
h4 > * + *,
h5 > * + *,
h6 > * + * {
	margin: 0;
}

/**************************/
/********** TAGS **********/
/**************************/

.tags {
	display:flex;
	flex-wrap: wrap;
	gap:1em;
	font-size: calc(var(--body-font-size) * .75);
}
.tags > * {
	display: flex;
	margin-left:0;
	padding-left:0;
}
.tags.large {
	font-size: var(--body-font-size);
	font-size: calc(var(--body-font-size) * .875);
}

/****************************/
/********** OFFERS **********/
/****************************/

.offer-date,
.offer-tag {
	display: inline-flex;
	align-items: center;
	gap: .5em;
	white-space: nowrap;
	padding:.5em 1em;
	border-radius: 2em;
	color:var(--bright-badge-color);
	background:var(--light-color);
}
.offer-date,
.offer-tag > * {
	margin: 0;
}
.offer-date {
	font-size: calc(var(--body-font-size) * .75);
}

/**********************************/
/********** TESTIMONIALS **********/
/**********************************/

.testimonials .thumbnail {
	border-radius: 50%;
}

/*******************************/
/*******************************/
/********** THUMBNAIL **********/
/*******************************/
/*******************************/

/*
ratio 1/1 : 100% / 100% (focus, event) == default
ratio 2/3 : 100% / 150% (portrait)
ratio 16/9 : 160 / 90 (block front)
*/

.thumbnail {
	position:relative;
	display: block;
	height:100%;
	width:100%;
	background:var(--light-color);
	aspect-ratio:1/1;
	max-height:10em;
	max-width:10em;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}
.thumbnail video,
.thumbnail img {
	display:block;
	height:100%;
	width:100%;
	-o-object-fit: cover;
	   object-fit: cover;
	aspect-ratio: inherit;
}


.thumbnail.avatar {
	border-radius:50%;
}

/********** POSITIONS **********/

.thumbnail.top-left img {
	-o-object-position: top left;
	   object-position: top left;
}
.thumbnail.top-center img {
	-o-object-position: top center;
	   object-position: top center;
}
.thumbnail.top-right img {
	-o-object-position: top right;
	   object-position: top right;
}
.thumbnail.center-left img {
	-o-object-position: center left;
	   object-position: center left;
}
.thumbnail.center-center img {
	-o-object-position: center center;
	   object-position: center center;
}
.thumbnail.center-right img {
	-o-object-position: center right;
	   object-position: center right;
}
.thumbnail.bottom-left img {
	-o-object-position: bottom left;
	   object-position: bottom left;
}
.thumbnail.bottom-center img {
	-o-object-position: bottom center;
	   object-position: bottom center;
}
.thumbnail.bottom-right img {
	-o-object-position: bottom right;
	   object-position: bottom right;
}

/********** EMPTY **********/

.thumbnail.empty:after {
	content:"";
	position:absolute;
	top:50%;
	left:50%;
	-webkit-transform:translate3d(-50%,-50%,0);
	   -moz-transform:translate3d(-50%,-50%,0);
	        transform:translate3d(-50%,-50%,0);
	font-size:1em;
	line-height:1em;
	opacity:.5;
}

/********** WITH ANCHOR **********/

.thumbnail a:before {
	content: '';
	position: absolute;
	z-index: 10;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: var(--accent-color);
	mix-blend-mode: screen;
	opacity: 0;
	pointer-events: none;
}
.thumbnail a:hover:before {
	opacity: 1;
}

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

.thumbnail.small {
	max-height:3rem;
	max-width:3rem;
}

/****************************/
/****************************/
/********** IFRAME **********/
/****************************/
/****************************/

iframe {
	max-width:100%;
	border:none;
}
iframe.full {
	width:100%;
}
.iframe-container {
	position:relative;
	background-size:cover !important;
	background-position:center center !important;
	min-height:2rem;
	width:100%;
	padding:56.25% 0 0 0 !important;
	background:var(--light-color);
}
.iframe-container iframe {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

/****************************/
/****************************/
/********** MEDIAS **********/
/****************************/
/****************************/

/**************************/
/********** LOGO **********/
/**************************/

figure.logo {
	/*height:6em; */
}
figure.logo > * {
	height:100%;
}

/****************************/
/********** RATIOS **********/
/****************************/

.aspect-ratio-1-1 {
	aspect-ratio:1/1;
}
.aspect-ratio-2-3 {
	aspect-ratio:2/3;
}
.aspect-ratio-16-9 {
	aspect-ratio:16/9;
}

/** containing .aspect-ratio-xxx **/

[class*="aspect-ratio-"] > *,
[class*="aspect-ratio-"] img {
	display:block;
	height:100%;
	width:100%;
	-o-object-fit: cover;
	   object-fit: cover;
	aspect-ratio: inherit;
}

/*********************************/
/*********************************/
/********** MEDIAPLAYER **********/
/*********************************/
/*********************************/

/*
.mediaplayer == default
.mediaplayer.youtube == for youtube video
> data-background == for background image / if none youtube default
> id == video id
.mediaplayer-container == for overlay max-width 1024px
*/

/********** MEDIAPLAYER **********/

.mediaplayer {
	position:relative;
	background-size:cover !important;
	background-position:center center !important;
	height:100%;
	width:100%;
}

.mediaplayer:after {
	content:"";
	position:absolute;
	top:0;
	left:0;
	height:100%;
	width:100%;
	background:var(--light-color);
	opacity:.5;
}
.mediaplayer iframe {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

/********** MEDIAPLAYER-CONTAINER **********/

.mediaplayer-container {
	position:relative;
	display:block;
	height:100%;
	width:100%;
	margin-right:auto;
	margin-left:auto;
	border-radius: .5em;
	overflow: hidden;
}

/********** MEDIAPLAYER BUTTON **********/

.mediaplayer-container .play-button {
	position:absolute;
	z-index:30;
	top:50%;
	left:50%;
	display:inline-flex;
	align-items: center;
	justify-content: center;
	cursor:pointer;
	line-height:1;
	opacity:0;
	height:2.5em;
	width:2.5em;
	transform:translate3d(-50%,-50%,0);
}
.mediaplayer-container .play-button .icon-play {
	margin-left:.125em;
}
.mediaplayer-container .play-button:after {
	content:"";
	position:absolute;
	z-index:-1;
	inset:0;
	display:inline-flex;
	background:var(--bright-color);
	border-radius: 50%;
}
.mediaplayer-container .play-button:hover:after {
	transform: scale(1.2);
}
.mediaplayer-container .play-button:focus-visible,
.mediaplayer-container.is-ready .play-button,
.mediaplayer-container.is-loaded.is-paused .play-button,
.mediaplayer-container.is-loaded.is-playing .play-button.on {
	opacity:1;
}

/** mobile **/
@media (max-width:760px) {
	.mediaplayer-container .play-button {
		font-size:1.5em;
	}
}
/** desktop **/
@media (min-width:760px) {
	.mediaplayer-container .play-button {
		font-size:2.5em;
	}
}

/********** HTML5 VIDEO **********/

video {
	display:block;
	height:auto;
	width:100%;
}
.mediaplayer.chrome video::-internal-media-controls-download-button {
	display:none;
}
.mediaplayer.chrome video::-webkit-media-controls-enclosure {
	overflow:hidden;
}
.mediaplayer.chrome video::-webkit-media-controls-panel {
	width:-webkit-calc(100% + 32px);
	width:calc(100% + 32px);
	margin-left:auto;
}

/********** VLITE **********/

/*
--vlite-colorPrimary	#ff7f15	Primary color
--vlite-transition	0.25s ease	Transition
--vlite-controlBarHeight	50px	Control bar height
--vlite-controlBarHorizontalPadding	10px	Control bar horizontal padding
--vlite-controlBarBackground	linear-gradient(to top, #000 -50%, transparent)	Control bar background
--vlite-controlsColor	#fff|#000	Controls color (video|audio)
--vlite-controlsOpacity	0.9	Controls opacity
--vlite-progressBarHeight	5px	Progress bar height
--vlite-progressBarBackground	rgba(0 0 0 / 25%)	Progress bar background
*/

.v-vlite.v-video {
	aspect-ratio:initial !important;
}
.mediaplayer-container iframe,
.mediaplayer-container.is-loaded iframe {
	opacity:0;
}
.mediaplayer-container.is-loaded.is-playing iframe {
	opacity:1;
}
.mediaplayer-container .v-controlBar {
	z-index:10;
	background:none !important;
}
.mediaplayer-container .v-controlBar:after {
	content:"";
	position:absolute;
	z-index:-1;
	inset:0;
	background:linear-gradient(0deg,var(--dark-color),transparent) !important;
}
.mediaplayer-container.is-loaded.is-paused .v-controlBar:after {
	opacity:0;
}
.mediaplayer-container.is-loaded .v-controlBar {
	background:var(--dark-color) !important;
	background:linear-gradient(0deg,var(--dark-color),transparent) !important;
}
.mediaplayer-container.is-loaded.is-playing .v-controlBar {
	background:linear-gradient(0deg,var(--dark-color),transparent) !important;
}
.mediaplayer-container.is-loaded .v-poster {
	opacity:.25 !important;
	pointer-events:none;
}
.mediaplayer-container.is-ready .v-controlBar {
	opacity:0 !important;
	pointer-events:none;
}
.v-vlite.v-video {
	background:var(--dark-color) !important;
}
.v-iconPressed {
	margin:0;
}
.v-vlite {
	--vlite-colorPrimary: var(--bright-color) !important;
	--vlite-progressBarBackground: var(--dark-color) !important;
}
.v-progressBar {
	min-height:auto;
}

/****************************/
/****************************/
/********** IFRAME **********/
/****************************/
/****************************/

iframe {
	max-width:100%;
	border:none;
}
iframe.full {
	width:100%;
}
.iframe-container {
	position:relative;
	background-size:cover !important;
	background-position:center center !important;
	min-height:2rem;
	width:100%;
	padding:56.25% 0 0 0 !important;
	background:var(--light-color);
}
.iframe-container iframe {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

/*******************************/
/*******************************/
/********** IMG / SVG **********/
/*******************************/
/*******************************/

/*
img
svg
picture
.background
*/

/********** IMG **********/

figure {
	display:block;
	height:auto;
	max-width:100%;
	margin:0;
	border:0;
	border-radius: .5em;
	overflow:hidden; /* for aspect-ratio */
}
img {
	display:block;
	height:auto;
	max-width:100%;
	margin:0 auto;
	border:0;
}
figure img {
	width:100%;
}

/********** IMG FULL **********/
/*
img.full {
	display:block;
	height:auto;
	width:100%;
	margin:0 auto;
}
*/
/********** IMG WITHIN TEXT **********/

.alignleft {
	float:left;
	margin:0 1rem 0 0;
}
.alignright {
	float:right;
	margin:0 0 0 1rem;
}
.aligncenter {
    display:block;
}
.alignleft:after,
.alignright:after,
.aligncenter:after {
	content:"";
    display:block;
    clear:both;
}

/********** SVG **********/

svg {
	display:block;
	-webkit-transform:translate3d(0,0,0);
	   -moz-transform:translate3d(0,0,0);
	        transform:translate3d(0,0,0);
	-webkit-backface-visibility:hidden;
	   -moz-backface-visibility:hidden;
	        backface-visibility:hidden;
}
figure > svg {
	display:block;
	height:100%;
	width:100%;
	margin:0 auto;
}

/** footer **/

.svg-icon-outline {
	fill:none;
	stroke:var(--dark-color);
	stroke-width:-webkit-calc(var(--logo-line-height) / 4);
	stroke-width:-moz-calc(var(--logo-line-height) / 4);
	stroke-width:calc(var(--logo-line-height) / 4);
}

/********************************/
/********************************/
/********** BACKGROUND **********/
/********************************/
/********************************/

.background-container {
	position:absolute;
	z-index:-1;
	top:0;
	left:-100%;
	right:-100%;
	height:100%;
	width:auto;
	overflow:hidden;
	padding:0 !important;
	margin:0 !important;
}
.background {
	position:absolute;
	z-index:-1;
	top:0;
	left:0;
	height:100%;
	width:100%;
	margin:0 !important;
	padding:0 !important;
	border-radius: 0;
	max-width:none;
	-webkit-background-size:cover !important;
	   -moz-background-size:cover !important;
	     -o-background-size:cover !important;
	        background-size:cover !important;
	background-repeat:no-repeat !important;
	background-position:center center !important;
}
.background.contain {
	-webkit-background-size:contain !important;
	   -moz-background-size:contain !important;
	     -o-background-size:contain !important;
	        background-size:contain !important;
	background-position:left !important;
}

/********** BACKGROUND CONTENT **********/

.background > *,
.background img {
	height:100%;
	width:100%;
	-o-object-fit: cover;
	   object-fit: cover;
}
.background.contain > *,
.background.contain img {
	-o-object-fit: contain;
	   object-fit: contain;
}

/********** BACKGROUND POSITIONS **********/

.bg-top-left {
	background-position:top left !important;
}
.bg-top-center {
	background-position:top center !important;
}
.bg-top-right {
	background-position:top right !important;
}
.bg-center-left {
	background-position:center left !important;
}
.bg-center-right {
	background-position:center right !important;
}
.bg-bottom-left {
	background-position:bottom left !important;
}
.bg-bottom-center {
	background-position:bottom center !important;
}
.bg-bottom-right {
	background-position:bottom right !important;
}

/***************************/
/***************************/
/********** ICONS **********/
/***************************/
/***************************/

.icon {
	display:inline-flex;
	justify-content: center;
	font-size:3em;
	line-height:1em;
	aspect-ratio: 1/1;
	height:1em;
	width:1em;
	text-align:center;
	margin:auto;
}
/*
.icon.large {
	font-size:3em;
}
.icon svg {
	height:1em;
	width:1em;
}
*/

/**************************/
/**************************/
/********** LOGO **********/
/**************************/
/**************************/

/* dark as default */

.logo {
	display:flex;
	max-width:150px;
	
	overflow:visible;
	margin:auto;
	fill:inherit;
}
.logo svg {
	height:100%;
	width:100%;
	fill:inherit;
}
.logo .logo-circles {
	fill:var(--dark-color);
}

/********************************/
/********************************/
/********** RESPONSIVE **********/
/********************************/
/********************************/

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

@media (min-width:760px) {
	.only-mobile {
		visibility:hidden;
		display:none !important;
	}
}
@media (max-width:760px) {
	.only-desktop {
		visibility:hidden;
		display:none !important;
	}
}

/*****************************/
/*****************************/
/********** ANCHORS **********/
/*****************************/
/*****************************/

/********** DEFAULT INLINE **********/

a {
	position:relative;
	font-size:inherit;
	line-height:inherit;
	color:inherit;
	text-shadow:inherit;
	outline:0;
	text-decoration:none;
}
p a,
li a {
	cursor:pointer;
	border-bottom:solid var(--line-height);
}
p a:hover,
li a:hover {
	color:var(--accent-color);
	text-shadow:0 0 0 var(--accent-color);
	border-color:var(--accent-color);
}

/********** WITH ICONS **********/

a span {
	display:inline-block;
	font-family:inherit;
	font-size:inherit;
	line-height:inherit;
	color:inherit;
	text-shadow:inherit;
}

/********** WITH LABELS **********/

a .label,
button .label {
	position:absolute !important;
	font-size:0 !important;
}

/********** MORE-LINK **********/

.more-link {
	position:absolute;
	z-index:10;
	top:0;
	left:0;
	height:100%;
	width:100%;
}

/********** BEHAVIOURS **********/

:focus {
	outline-color:transparent;
	outline-style:none;
}

/* cf. navigation.css > accessibility for focus-visible */

/********************************/
/********************************/
/********** COLUMNIZER **********/
/********************************/
/********************************/

/*
data-columns == 2 / 3 / 4
2 == default

cf. grid.css for mixing with grid
*/

/********** BEHAVIOURS **********/

.columnizer .break {
	-webkit-column-break-before:always;
	-moz-column-break-before:always;
	break-before:always;
	padding-top:0;
}

/********** SPACING **********/

.columnizer > * + * {
	padding:0;
	margin:0;
}
.columnizer > *:not(:last-child) {
	margin-bottom:var(--global-spacing);
}
.columnizer > li:not(:last-child),
.columnizer > ul li:not(:last-child),
.columnizer > ol li:not(:last-child) {
	margin:0;
}

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

@media (min-width:760px) {
	.columnizer {
		-webkit-column-count:2;
		   -moz-column-count:2;
		        column-count:2;
		-webkit-column-gap:var(--gutter-gap);
		   -moz-column-gap:var(--gutter-gap);
		        column-gap:var(--gutter-gap);
	}
}
@media (min-width:1000px) {
	.columnizer[data-columns="3"] {
		-webkit-column-count:3;
		   -moz-column-count:3;
		        column-count:3;
	}
	.columnizer[data-columns="4"] {
		-webkit-column-count:4;
		   -moz-column-count:4;
		        column-count:4;
	}
}