/*
	Theme Name: R&D Events
	Author: Scandola
	Author URI: https://www.scandolagency.ch
	Text Domain: rd-events
	Version: 2.0
	Last update : 5.2.25
*/


/* === VARIABLES === */

:root {
/* === Colors === */
--color-main: #000;
--color-primary: #767473;
--color-lightgrey : #efefef;
--color-border : #cccccc;
--color-light : #ffffff;
--color-dark : #000;

/* === Typography === */
--typo-title : 'Inter', serif;
--font-weight-title-light : 400;
--fw-title-bold : 700;
--fw-title-extrabold : 900;

--typo-main : 'Inter', serif;
--fw-light : 300;
--fw-regular : 400;
--fw-medium : 500;
--fw-semibold : 600;
--fw-bold : 700;

--font-size-1 : 1rem;

--letter-spacing : 0.05rem;

/* width */
--logo-footer : 180px;

/* === Padding === */
--padd1: 1rem;

/* === Margin === */
--margT1 : 1rem;
--margB1 : 1rem;

/* === style === */
--br : 0.2rem;
--br-medium : 0.4rem;
--br-big : 1rem;
--br-top : 0.2rem 0.2rem 0 0;
--br-bottom : 0 0 0.2rem 0.2rem;
--br-round : 50%;

--shadow : 1px -2px 15px rgba(0, 0, 0, 0.6);
--shadow-light : 1px -2px 12px rgba(0, 0, 0, 0.2);
--shadow-bottom : 1px 1px 5px rgba(0, 0, 0, 0.08);
--shadow-inset : inset 2px 2px 20px rgba(0, 0, 0, 0.8);
}



/* TYPO */
html,
body {
	font-family: var(--typo-main);
	color: var(--color-main);
	font-weight: var(--fw-light);
	background-color: var(--color-light);
	font-size: 1em;
	margin: 0;
}
a,
a:focus,
a:active {
	color: var(--color-primary);
	text-decoration: none;
}
a:hover {
	color: var(--color-main);
	text-decoration: none;
}
main p a,
main ul a,
main p a:focus,
main ul a:focus,
main p a:active,
main ul a:active {
	color: var(--color-primary);
	font-weight: var(--fw-medium);
	text-decoration: underline;
}
main p a:hover {
	color: var(--color-main);
	text-decoration: underline;
}
h1, h2, h3, h4,
span.h1-title {
	display: block;
	position: relative;
	margin: 0;
}
h1 a, h2 a, h3 a, h4 a {
	text-decoration: none;
}
h1,
span.h1-title {
	font-family: var(--typo-title);
	font-weight: var(--fw-title-bold);
	font-size: 2.5rem;
	margin: 0;
}
h1.h1-hidden {
	display: none;
}
h2,
h2.title {
	font-family: var(--typo-title);
	font-weight: var(--fw-title-bold);
	font-size: 2rem;
	margin-bottom: 1.5rem;
}
h3 {
	font-size: 1.4rem;
	font-family: var(--typo-main);
	font-weight: var(--fw-regular);
	margin-bottom: 0.8rem;
}
h3.surtitle {
	text-transform: uppercase;
	font-weight: var(--fw-light);
	margin-bottom: 1rem;
}
h4 {
	font-size: 1.2rem;
	font-weight: var(--fw-bold);
	margin-bottom: 0.8rem;
}
.nopad_title {
	margin: 0;
	padding: 0;
}
p,
main ul,
main ol {
	line-height: 1.6;
	display: block;
	margin: 0;
	font-size: 1.2rem;
	width: 100%;
}
p {
	padding: 0 0 1rem 0;
}
p:last-of-type {
	padding: 0;
}
.big {
	font-size: 1.5rem;
}
.small-text,
.small-text p {
	font-size: 0.9rem;
}
.medium-text,
.medium-text p {
	font-size: 1rem;
}
main ul,
main ol {
	padding: 0 0 1rem 1rem;
}
main ul li,
main ol li {
	position: relative;
	line-height: 1.7;
	padding-left: 1rem;
}
main .inner ul li {
	list-style: none;
}
main .inner ul li:before {
	position: absolute;
	left: 0;
  content: "\2022";
  color: var(--color-main);
  display: inline-block;
  width: 2rem;
  margin-left: -1rem;
	font-weight: var(--fw-title-extrabold);
}
strong,
.strong {
	font-weight: var(--fw-bold);
}
em {
	font-style: italic;
}
.center,
section.text_img .content-text.center {
	text-align: center;
	align-items: center;
}
.bb {
	padding-bottom: 1rem;
	margin-bottom: 1rem;
	border-bottom: 1px solid var(--color-border);
}
.bt {
	padding-top: 1rem;
	margin-top: 1rem;
	border-top: 1px solid var(--color-border);
}
.coverfit img {
	height: 100%;
	width: 100%;
	object-fit: cover;
}
/* GLOBAL */
*,
*::before,
*::after {
  box-sizing: border-box;
}
pre {
	max-width: 100%;
	background-color: var(--color-border);
	border: 1px solid black;
	font-family: monospace;
	padding: 0.5rem;
	margin: 1rem 0;
	font-size: 0.8rem;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
main {
	position: relative;
}
section {
	position: relative;
	padding-top: 2rem;
	padding-bottom: 2rem;
	text-align: left;
}
section.small-section {
	padding-top: 2rem;
	padding-bottom: 2rem;
}
section.nopadd {
	padding-top: 0;
	padding-bottom: 0;
}
section.nopadd-top {
	padding-top: 0;
}
section.nopadd-bottom {
	padding-bottom: 0;
}
iframe {
	border: 0;
}
.container-fluid {
	padding-left: 2rem;
	padding-right: 2rem;
}
.section-header {
	margin-bottom: 2.5rem;
}
.inner {
	display: block;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
}
.fullwidth,
.fullwidth .inner {
	width: 100%;
	max-width: 100%;
}
.small-inner {
	max-width: 1000px;
	margin: 0 auto;
	text-align: center;
}
.fullwidth .small-inner,
.fullwidth .inner .small-inner {
	width: 100%;
	max-width: 100%;
}
.grid-1,
.grid-2,
.grid-3,
.grid-4,
.grid-5 {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
  grid-gap: 2rem;
}
.compensate-for-scrollbar {
  margin-right: 0 !important;
}
.wp-caption-text {
	position: absolute;
	bottom: 0;
	left: 0;
	background: rgba(255, 255, 255, 0.6);
	font-size: 0.8rem;
	font-style: italic;
	padding: 0 0.3rem !important;
	color: var(--color-main);
}
/* rotate img */
.rotate {
	display: block;
	width: 100%;
	height: auto;
	overflow: hidden;
	position: relative;
}
.rotate {
	-webkit-transition: all 0.4s ease;
	-moz-transition: all 0.4s ease;
	-o-transition: all 0.4s ease;
	-ms-transition: all 0.4s ease;
	transition: all 0.4s ease;
	-webkit-transition-transform-style: preserve-3d;
	-moz-transform-style: preserve-3d;
	-o-transform-style: preserve-3d;
	-ms-transform-style: preserve-3d;
	transform-style: preserve-3d;
	}
.rotate:hover img {
	-webkit-transform: scale(1.01) rotate(-0.2deg);
	-moz-transform: scale(1.01) rotate(-0.2deg);
	-o-transform: scale(1.01) rotate(-0.2deg);
	-ms-transform: scale(1.01) rotate(-0.2deg);
	transform: scale(1.01) rotate(-0.2deg);
}
.radius {
	border-radius: var(--border-radius);
}
.radius-top {
	border-radius: var(--border-radius-top);
}
.radius-bottom {
	border-radius: var(--border-radius-bottom);
}
.no-image {
	background-color: var(--color-border);
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: var(--fw-bold);
}

/* COLORS */
section.white,
.white {
	background-color: var(--color-light);
}
section.grey,
.grey {
	background-color: var(--color-lightgrey);
}
.primary {
	background-color: var(--color-primary);
}
.dark-bg {
	background-color: var(--color-dark);
}

/* light & grey */
footer .footer-top,
footer .footer-content {
	border-bottom: 1px solid var(--color-border);
}

/* PRIMARY (base colors) */
.primary h2,
.primary h3,
.primary .faq-list-item h3,
.primary h4,
.primary p,
.primary ul li,
main .primary ul li:before,
main .primary a,
main .primary a:focus,
main .primary a:active,
main .primary a:hover,
main .primary p a:hover,
section.faq.primary .faq-list-item .plus::before,
.primary .big-title {
	color: var(--color-light);
}
footer .primary .footer-content {
	border-bottom: 1px solid var(--color-lightgrey);
}
section.faq.primary .faq-list-item:hover,
section.faq.primary .faq-list-item.active {
	background-color: rgba(255, 255, 255, .05);
}
/* postlist */
.postlist.primary h4 a {
	color: var(--color-primary);
}  
.postlist.primary h4 a:hover {
	color: var(--color-main);
}
.postlist.primary .button-container .button-link {
	background-color: var(--color-primary);
	color: var(--color-light);
}
.postlist.primary .button-link::before,
.postlist.primary .button-link::after {
	background-color: var(--color-light);
}
.postlist.primary .button-container.main .button-link::before,
.postlist.primary .button-container.main .button-link::after {
	background-color: var(--color-primary);
}
/* button */
.primary .button-container .button-link,
.primary .button-container.main .button-link {
	background-color: var(--color-light);
	color: var(--color-primary);
}
.primary .button-link::before,
.primary .button-link::after {
	background-color: var(--color-primary);
}

/* DARG BG */
.dark-bg h2,
.dark-bg h3,
.dark-bg .faq-list-item h3,
.dark-bg h4,
.dark-bg p,
.dark-bg ul li,
main .dark-bg ul li:before,
main .dark-bg a,
main .dark-bg a:focus,
main .dark-bg a:active,
main .dark-bg a:hover,
main .dark-bg p a:hover,
section.faq.dark-bg .faq-list-item .plus::before,
.dark-bg .big-title {
	color: var(--color-light);
}
footer .dark-bg .footer-content {
	border-bottom: 1px solid var(--color-lightgrey);
}
section.faq.dark-bg .faq-list-item:hover,
section.faq.dark-bg .faq-list-item.active {
	background-color: rgba(255, 255, 255, .05);
}
/* postlist */
.postlist.dark-bg h4 a {
	color: var(--color-primary);
}
.postlist.dark-bg h4 a:hover {
	color: var(--color-main);
}
.postlist.dark-bg .button-container .button-link {
	background-color: var(--color-main);
	color: var(--color-light);
}
.postlist.dark-bg .button-link::before,
.postlist.dark-bg .button-link::after {
	background-color: var(--color-light);
}
.postlist.dark-bg .button-container.main .button-link::before,
.postlist.dark-bg .button-container.main .button-link::after {
	background-color: var(--color-main);
}
/* button */
.dark-bg .button-container .button-link,
.dark-bg .button-container.main .button-link {
	background-color: var(--color-light);
	color: var(--color-main);
}
.dark-bg .button-link::before,
.dark-bg .button-link::after {
	background-color: var(--color-main);
}

.dot-border {
	border: 6px dotted var(--color-primary);
}
.dark-bg .dot-border,
.primary .dot-border {
	border: 6px dotted var(--color-light);
}

/* PATTERNS */
.bg_lines {
	background-image: url(images/bg/bg-lines.svg);
	background-repeat: no-repeat;
	background-position: right bottom;
	background-size: contain;
}
.bg_move {
	animation: gradient 15s ease infinite;
	background-color: #85FFBD;
	background-image: linear-gradient(45deg, #85FFBD, #8bc6ec, #2B7474);
  background-size: 400% 400%;
}
@keyframes gradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

.bg_move_medium {
	animation: gradient_medium 15s ease infinite;
  background: linear-gradient(-45deg, #ee7752, #e73c7e, #23a6d5, #23d5ab);
  background-size: 400% 400%;
} 
@keyframes gradient_medium {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* close button */
.close-btn {
	position: absolute;
  top: 1rem;
  right: 1rem;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  cursor: pointer;
 	display: flex;
 	justify-content: center;
 	align-items: center;
 	padding: 0.3rem;
 	background-color: var(--color-primary);
 	z-index: 10;
}
.close-btn svg {
	fill: var(--color-light);
	width: 25px;
	height: 25px;
}
.close-btn:hover {
 	background-color: var(--color-main);
}

/* transition */
.menu_toggle,
.header,
.header.smallscroll,
.header a,
.header .header-logo img,
.booking-widget,
:hover,
button {
	transition: all 0.3s;
	-webkit-transition: 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
}


/* HEADER */
.header {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	height: auto;	
	background-color: var(--color-light);
	padding: 0 1rem;
	z-index: 11;
}
.header.topMenu {
	justify-content: space-between;
}
.header.fullheight {
	position: fixed;
	background-color: transparent;
}
.header .logo {
	z-index: 30;
	padding: 0.5rem 0;
}
.header .header-logo {
	position: relative;
	z-index: 15;
}
.header .header-logo img {
	width: auto;
	height: 50px;
}
.header .header-logo.lsmall {
	opacity: 0;
	visibility: hidden;
	display: none;
}
/* small header */
.header.smallscroll {
	position: fixed;
	align-items: center;
	background-color: transparent;
}
.header.smallscroll .header-logo img {
	height: 40px;
}
.header.smallscroll .header-logo.lbig {
	opacity: 0;
	visibility: hidden;
	display: none;
}
/* scroll header */
.header.scrolled {
	display: none;
}

/* lang */
.lang {
	display: block;
	transition: opacity 0.5s ease;
	z-index: 30;
}
.smallscroll .lang {
	display: none;
}
/* weglot */
.lang .country-selector.weglot-dropdown {
	background-color: transparent;
	border: 0;
}
.lang .country-selector.weglot-dropdown .wgcurrent {
	border: 0;
	padding: 0 1rem 0 0.3rem
}
.lang .country-selector.weglot-dropdown a,
.lang .country-selector.weglot-dropdown span {
	color: var(--color-main);
	padding: 0 1rem 0 0;
	font-size: 1rem;
	font-weight: var(--fw-medium);
}
.lang .country-selector.weglot-dropdown .wgcurrent:after {
  content: "";
  background: none;
  display: block;
  width: 10px;
  height: 10px;
  border-right: 2px solid;
  border-bottom: 2px solid;
  -webkit-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  right: 11px;
  top: 11px;
  border-color: var(--color-main);
}
.lang .country-selector.weglot-dropdown input:checked ~ .wgcurrent:after {
  -webkit-transform: rotate(225deg);
  -ms-transform: rotate(225deg);
  transform: rotate(225deg);
  top: 16px;
}
.lang .country-selector.weglot-dropdown ul,
.country-selector.weglot-dropdown li {
	border: 0;
	background-color: var(--color-light);
}
.lang .country-selector.weglot-dropdown .wg-li a {
	background-color: transparent;
	border-top: 1px solid var(--color-lightgrey);
	padding: 0;
	padding: 0 0.3rem;
}
.lang .country-selector.weglot-dropdown li:hover {
	background-color: var(--color-lightgrey);
}


/* MENU */

/* toggle */
.page .menu_toggle {
	display: none;
}
.menu_toggle {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 45px;
	height: 45px;
	border-radius: 50%;
	background-color: var(--color-primary);
	border-radius: 50%;
	padding: 0.8rem	;
	z-index: 40;
}
.menu_toggle:hover {
	background-color: var(--color-primary);
}
.menu_toggle .menu_open {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 35px;
}
.menu_toggle:hover .menu_open {
	width: 40px;
}
.menu_toggle .menu_open span {
  display: block;
  width: 100%;
  box-shadow: 0 2px 10px 0 rgba(0,0,0,0.3);
  border-radius: 3px;
  height: 2px;
  background: var(--color-light);
  transition: all .3s;
  position: relative;
}
.menu_toggle .menu_open span + span {
  margin-top: 6px;
}
.menu_toggle.active .menu_open span + span {
  margin-top: 20px;
}
.menu_toggle.active .menu_open span:nth-child(1) {
  animation: ease .7s top forwards;
}
.menu_toggle.not-active .menu_open span:nth-child(1) {
  animation: ease .7s top-2 forwards;
}
.menu_toggle.active .menu_open span:nth-child(2) {
  animation: ease .7s scaled forwards;
}
.menu_toggle.not-active .menu_open span:nth-child(2) {
  animation: ease .7s scaled-2 forwards;
}
.menu_toggle.active .menu_open span:nth-child(3) {
  animation: ease .7s bottom forwards;
}
.menu_toggle.not-active .menu_open span:nth-child(3) {
  animation: ease .7s bottom-2 forwards;
}
@keyframes top {
  0% {
    top: 0;
    transform: rotate(0);
  }
  50% {
    top: 22px;
    transform: rotate(0);
  }
  100% {
    top: 22px;
    transform: rotate(45deg);
  }
}
@keyframes top-2 {
  0% {
    top: 22px;
    transform: rotate(45deg);
  }
  50% {
    top: 22px;
    transform: rotate(0deg);
  }
  100% {
    top: 0;
    transform: rotate(0deg);
  }
}
@keyframes bottom {
  0% {
    bottom: 0;
    transform: rotate(0);
  }
  50% {
    bottom: 22px;
    transform: rotate(0);
  }
  100% {
    bottom: 22px;
    transform: rotate(135deg);
  }
}
@keyframes bottom-2 {
  0% {
    bottom: 22px;
    transform: rotate(135deg);
  }
  50% {
    bottom: 22px;
    transform: rotate(0);
  }
  100% {
    bottom: 0;
    transform: rotate(0);
  }
}
@keyframes scaled {
  50% {
    transform: scale(0);
  }
  100% {
    transform: scale(0);
  }
}
@keyframes scaled-2 {
  0% {
    transform: scale(0);
  }
  50% {
    transform: scale(0);
  }
  100% {
    transform: scale(1);
  }
}

/* menu mobile wrap */
div.menu-wrap {
	position: absolute;
	display: flex;
	flex-flow: column;
	justify-content: flex-start;
	align-items: center;
	width: 0;
	height: 100vh;
	right: calc(-500%);
	top: 0;
	bottom: 0;
	padding: 0;
	margin: 0;
	background-color: var(--color-light);
	transition: all .5s;
	-webkit-transition: all .5s;
	-ms-transition: all .5s;
	-o-transition: all .5s;
	overflow: auto;
	overflow-x: hidden;
	overflow-y: scroll;
	z-index: 10;
}
div.menu-wrap.active {
	width: 85vw;
	right: 0;
	box-shadow: var(--shadow);
}

/* menus */
.header-menu {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-end;
	align-items: center;
	padding: 0.5rem 0;
	z-index: 30;
}
ul.menu {
	padding: 0;
	margin: 0;
}
ul.menu li {
	list-style: none;
	position: relative;
}
ul.menu li a {
	line-height: 1.8;
	position: relative;
	color: var(--color-primary);
}
ul.menu li a:hover {
	color: var(--color-main);
}
ul.menu li.current-menu-parent a:not(ul.sub-menu li a),
ul.menu li.current-page-parent a:not(ul.sub-menu li a),
ul.menu li ul.sub-menu li.current-menu-item a,
ul.menu li.current-menu-item a {
	color: var(--color-main);
	text-decoration: underline;
}

/* top menu */
.top_menu {
	order: 2;
	margin-top: 2rem;
	width: 100%;
	padding: 0 2rem;
	text-align: center;
}
.top_menu ul li a {
	font-size: 1rem;
	font-weight: var(--fw-regular);
	text-transform: none;
}

/* main menu */
.main_menu {
	order: 1;
	width: 100%;
	padding: 0 2rem;
	margin-top: 8rem;
}
.main_menu ul {
	margin: 0;
	padding: 0;
}
.main_menu ul li {
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  list-style: none;
}
.main_menu ul li a {
	font-weight: var(--fw-medium);
	font-size: 1.2rem;
	line-height: 1.4;
  width: 100%;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  text-transform: uppercase;
}
.main_menu ul.menu li.disabled-link a {
	pointer-events: none;
}
.main_menu ul.menu li.disabled-link .sub-menu li a {
	pointer-events: all;
}
/* sub-menu */
.top_menu ul.menu li.menu-item-has-children a::after {
  width: 7px;
  height: 7px;
  margin-top: 3px;
}
.top_menu ul.menu li.menu-item-has-children.active a::after {
	margin-top: 6px;
}
.main_menu ul.menu li.menu-item-has-children a::after {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border: solid var(--color-primary);
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  margin-left: 0.5rem;
  vertical-align: text-top;
  margin-top: 5px;
  transform-origin: center;
}
.main_menu ul.menu li.menu-item-has-children.active a::after {
	transform: rotate(225deg);
	margin-top: 10px;
}
.main_menu ul.menu li.current-menu-parent.menu-item-has-children a::after,
.main_menu ul.menu li.current-menu-parent.menu-item-has-children.active a::after {
  border: solid var(--color-main);
  border-width: 0 2px 2px 0;
}
.main_menu ul.menu li.menu-item-has-children .sub-menu li a::after {
	content: none;
}
.main_menu ul.menu li .sub-menu {
	display: none;
}
.main_menu ul.menu li ul.sub-menu {
	padding: 1rem 0 0 0;
}
.main_menu ul.menu li ul.sub-menu li {
	margin-bottom: 0.8rem;
	padding-bottom: 0;
	border-bottom: 0;
}
.main_menu ul.menu li ul.sub-menu li a {
	font-size: 1.2rem	;
	text-transform: none;
	font-weight: var(--fw-regular);
}


/* button menu link */
ul.menu li.btnMenuLink {
	display: inline-block;
	margin-top: 2rem;
	background-color: var(--color-light);
	border: 0.05rem solid var(--color-primary);
	border-radius: var(--border-radius-medium);
	padding: 0.3rem 0.8rem;
}
ul.menu li.btnMenuLink:hover {
	border: 0.05rem solid var(--color-main);
}
ul.menu li.btnMenuLink a,
.top_menu ul.menu li.current-menu-item.btnMenuLink a {
	color: var(--color-primary);
	font-weight: var(--fw-regular);
}
ul.menu li.btnMenuLink:hover a {
	color: var(--color-main	);
}
.smallscroll ul.menu li.btnMenuLink {
	border: 0;
	padding: 0;
}



/* f010 Cover */
section.cover {
	position: relative;
	width: 100%;
}
section.cover,
section.cover .swiper {
	width: 100%;
}
section.cover.height_min,
section.cover.height_min .swiper {
	height: 40vh;
}
section.cover.height_medium,
section.cover.height_medium .swiper {
	height: 60vh;
}
section.cover.height_full,
section.cover.height_full .swiper {
	height: 100vh;
}

section.cover {
	display: flex;
	justify-content: center;
	align-items: center;
}
section.cover .swiper-slide {
	background-color: rgba(0, 0, 0, 0.3);
	background-blend-mode: multiply;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	display: flex;
	justify-content: center;
	align-items: center;
}
section.cover .tagline-logo {
	width: 150px;
	height: auto;
}
section.cover.header-title .tagline {
	padding: 0;
}
section.cover.header-title .tagline h1,
section.cover.header-title .tagline .h1-title {
	color: var(--color-main);
}
/* tagline title image & video */
.tagline {
	text-align: center;
	padding: 0 4rem;
	z-index: 2;
}
.tagline h1,
.tagline span.h1-title  {
	color: var(--color-light);
  margin: 0;
	padding: 0;
}
.tagline h2 {
	color: var(--color-light);
  margin: 1rem 0 0 0;
}

/* Video background for cover and f035 */
section.video-full {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 60vh;
	overflow: hidden;
}
section.video-full iframe {
	position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100vh;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
}
@media (min-aspect-ratio: 16/9) {
  section.video-full iframe {
    /* height = 100 * (9 / 16) = 56.25 */
    height: 56.25vw;
  }
}
@media (max-aspect-ratio: 16/9) {
  section.video-full iframe {
    /* width = 100 / (9 / 16) = 177.777777 */
    width: 177.78vh;
  }
}


/* ALL ABOUT FLEXIBLE CONTENT */

/* f015 BIG TITLE */
section.title .big-title {
	font-size: 8vw;
	font-weight: var(--fw-title-extrabold);
	font-style: italic;
	line-height: 1;
}


/* f020 TEXT */
section.text h2,
section.text h3 {
	margin-bottom: 0;
}
section.text h3:has(+h2),
section.text h2:has(+p),
section.text h2:has(+.text-content),
section.text h3:has(+.text-content),
section.text h3:has(+p) {
	margin-bottom: 1.5rem;
}
section.text .bloc-wrap > .button-container {
	margin-top: 0;
}

/* f025 duo */
section.duo_text .section-header {
	padding: 0 0 0 3rem;
}
section.duo_text .duo-content {
	padding: 3rem;
	display: flex;
	flex-flow: column wrap;
	justify-content: center;
	align-items: flex-start;
}
section.duo_text .duo-content .duo-header {
	display: flex;
	flex-flow: column wrap;
	justify-content: flex-start;
	align-items: flex-start;
	margin: 0 0 1rem 0;
}
section.duo_text .duo-content .duo-header img {
	width: 90px;
	height: auto;
	margin-bottom: 1rem;
}

/* f030 MEDIA img, parallax, video */
/* media image */
section.media.img .size {
	display: block;
	margin: 0 auto;
}
section.media.img .size-100,
section.media.img .size-50,
section.media.img .size-25 {
	max-width: 100%;
}
section.media.fullwidth img {
	width: 100%;
}
/* media parallax */
section.media.parallax {
	padding: 0;
	display: block;
	position: relative;
	width: 100%;
	height: 50vh;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	background-color: rgba(0, 0, 0, 0.3);
	background-blend-mode: overlay;
}
section.media.parallax .bloc-wrap {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 100%;
	width: 100%;
	height: 100%;
}
section.media.parallax .bloc-wrap .inner {
	transform: translateY(300px);
  opacity: 0;
  transition-property: transform, opacity;
  transition-duration: 1s;
	text-align: center;
	padding: 0 2rem;
}
section.media.parallax .bloc-wrap .inner.inview {
	transform: translateY(0);
  opacity: 1;
}
section.media.parallax .bloc-wrap .inner p {
	color: var(--color-light);
	font-weight: var(--fw-medium);
	font-size: 1.5rem	;
}
/* media video */
section.video .inner {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
}
section.video .content-video {
	width: 100%;
}
section.video .content-video .embed-video {
	position: relative;
	padding-bottom: 56.25%;
	overflow: hidden;
	width: 100%;
	height: auto;
	margin: 0;
}
section.video .content-video .embed-video iframe,
section.video .content-video .embed-video object,
section.video .content-video .embed-video embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* f050 - SLIDER IMG */
section.slider {
	width: 100%;
}
section.slider .bloc-wrap {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: stretch;
	gap: 0;
}
section.slider .slider-img {
	display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: hidden;
  height: 100%;
}
section.slider .slider-content,
section.slider .slider-wrap.with-content {
	width: 100%;
}
section.slider .slider-content {
  display: flex;
  flex-flow: column wrap;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0 0 2rem 0;
 	order: 1;
}
section.slider.fullwidth .slider-content {
  padding: 4rem 2rem;
}
section.slider .slider-wrap {
	max-height: 75vh;
}
section.slider .slider-wrap.with-content {
	position: relative;
	overflow: hidden;
	order: 2;
	margin: 0;
}
section.slider .swiper-wrapper img {
	width: 100% !important;
	height: 100%;
	object-fit: cover;
}

/* f060 - COLUMN */
section.columns .bloc-wrap {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 2rem;
}
section.columns .bloc-wrap .column-box {
  width: 100%;
}
section.columns .column-box .column-img img {
	max-height: 60px;
}
section.columns .column-box .column-img.large img {
	max-height: 270px;
}
section.columns .column-box .column-content {
	margin-top: 1rem;
}
section.columns .column-box .button-container {
	padding-top: 1rem;
	margin: auto auto 0;
}

/* f070 - TEXT & IMG */
section.text_img {
	width: 100%;
}
section.text_img .bloc-wrap {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: stretch;
	gap: 0;
}
section.text_img .content-text,
section.text_img .content_img {
	width: 100%;
}
section.text_img .content-text {
  display: flex;
  flex-flow: column wrap;
  align-items: flex-start;
  justify-content: center;
  margin: 0;
  padding: 0 0 2rem 0;
 	order: 1;
}
section.text_img.fullwidth .content-text {
  padding: 4rem 2rem;
}
section.text_img .content-img {
	position: relative;
	overflow: hidden;
	order: 2;
	margin: 0;
}
section.text_img.thumbnail .content-img {
	max-width: 200px;
	margin: 0;
}
/* display */
section.text_img .content-img.whole {
	display: flex;
	justify-content: center;
	align-items: center;
}
section.text_img .content-img.cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/* SLIDER */
section.text_img.slider .content-slider .slider-img {
	display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: hidden;
  height: 100%;
}
section.text_img.slider .content-slider {
	max-height: 75vh;
}
section.text_img.slider .content-slider.with-text {
	width: 100%;
	position: relative;
	overflow: hidden;
	order: 2;
	margin: 0;
}
section.text_img.slider .content-slider .swiper-wrapper img {
	width: 100% !important;
	height: 100%;
	object-fit: cover;
}
/* VIDEO */
section.text_img .content-video {
  width: 100%;
  order: 2;
}
section.text_img .content-video .embed-video {
	position: relative;
	width: 100%;
	height: 100%;
	padding-bottom: 56.25%;
	overflow: hidden;
}
section.text_img .content-video .embed-video iframe {
	position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100vh;
  transform: translate(-50%, -50%);
  object-fit: cover;
  pointer-events: none;
}
@media (min-aspect-ratio: 16/9) {
  section.video-full .embed-video iframe {
    width: 100%;
    height: 56.25vw; /* Calcul basé sur un ratio 16:9 */
  }
}
@media (max-aspect-ratio: 16/9) {
  section.video-full .embed-video iframe {
    width: 177.78vh; /* Calcul basé sur un ratio 16:9 */
    height: 100%;
  }
}


/* f110 - GALLERY */
section.gallery .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}
section.gallery .gallery-item {
  flex: 1 1 calc(50% - 1rem);
  max-width: calc(50% - 1rem);
  aspect-ratio: 1 / 1;
  overflow: hidden;
}
section.gallery .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* f120 FAQ */
section.faq .faq-list-item:hover,
section.faq .faq-list-item.active {
	background-color: rgba(0, 0, 0, .05);
}
section.faq .faq-list-item {
	margin-bottom: 0.5rem;
	border-radius: var(--br);
}
section.faq .faq-list-item:last-of-type {
	margin: 0;
}
section.faq .faq-list-item .plus {
	width: 100%;
	padding: 0.8rem 1rem;
	cursor: pointer;
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: center;
}
.faq-list-item h3 {
	color: var(--color-main);
}
section.faq .faq-list-item h3 {
	margin: 0;
	width: calc(100% - 2rem);
	font-weight: var(--fw-semibold);
}
section.faq .faq-list-item .plus::before {
	content: "\002B";
	display: inline-block;
	width: 2rem;
	font-size: 1.5rem;
	font-weight: var(--fw-medium);
	color: var(--color-main);
}
section.faq .faq-list-item.active .plus::before {
	content: "\2212";
}
section.faq .faq-list-item .faq-content {
	width: 100%;
	height: auto;
	padding: 0.5rem 2rem 2rem 2.5rem;
	display: none;
	transition: none;
}
section.faq .faq-list-item .faq-content .wrap-content img {
	margin: 1rem 0 0 0;
}

/* f155 form */
/* modal form */
section.form .button-container.modal-btn {
	text-align: center;
}
#form {
	display: none;
	max-width: 800px;
  width: 100%;
}
#form .form-box {
	background-color: var(--color-light);
	padding: 2rem;
}

/* f160 - iFrame */
section.iframe.fullwidth iframe {
	width: 100%;
}
section.iframe#map iframe {
	filter: grayscale(100%);
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
}


/* f170 minislider */
section.minislider .swiper-wrapper .swiper-img {
	height: 300px;
}
section.minislider .swiper-wrapper .swiper-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section.minislider .swiper-wrapper .swiper-content {
	padding: 1rem 2rem 0;
}

/* f190 BUTTON */
ul + .button-container {
	margin-top: 1rem;
}
.button-container {
	position: relative;
	display: block;
	margin-top: 1.5rem;
	overflow: hidden;
}
.button-container .button-link {
	position: relative;
	display: inline-block;
	text-align: center;
	font-family: var(--typo-main);
	font-weight: var(--fw-bold);
	color: var(--color-light);
	background-color: var(--color-primary);
	text-transform: uppercase;
	text-decoration: none;
	letter-spacing: var(--letter-spacing);
	padding: 0.8rem 3rem 0.8rem 1rem;
	border: 0;
	border-radius: var(--br-big);
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
	cursor: pointer;
}
.button-container .button-text {
	position: relative;
}
.button-container a,
.button-container a:focus,
.button-container a:active {
	text-decoration: none;
}
/* + */
.button-link::before,
.button-link::after {
	content: '';
	position: absolute;
	width: 1rem;
	height: 3px;
	background-color: var(--color-light);
	top: 50%;
	right: 1rem;
	transform: translateY(-50%);
	transition: all 0.3s ease;
}
/* vertical + */
.button-link::before {
	transform: translateY(-50%) rotate(90deg); /* Alignement vertical */
}
/* horizontal + */
.button-link::after {
	transform: translateY(-50%) rotate(0deg); /* Alignement horizontal */
}
.button-link:hover::before {
	top: 38%; /* Ajuste la position verticale de la branche haute du chevron */
	transform: translateY(-50%) rotate(45deg); /* Rotation pour former la branche haute */
}
.button-link:hover::after {
	top: 62%; /* Ajuste la position verticale de la branche basse du chevron */
	transform: translateY(-50%) rotate(-45deg); /* Rotation pour former la branche basse */
}

/* f200 postlist */
section.postlist {
	text-align: center;
}
.postlist .post-container {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: stretch;
	gap: 2rem;
}
.postlist .section-header {
	text-align: center;
}
.post-item {
	position: relative;
	display: flex;
	flex-flow: column;
	min-height: 100%;
	border-radius: var(--border-radius-big);
	overflow: hidden;
	box-shadow: var(--shadow-light);
	width: 100%;
}
.postlist .post-item .section-header {
	text-align: center;
}
.post-item .post-img {
	height: 250px;
	flex-shrink: 0;
}
.post-item .post-entry.list {
	position: absolute;
	top: 1rem;
	left: 1rem;
	display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
}
.post-item .post-entry.list span {
 	font-size: 0.8rem;
	text-transform: uppercase;
	font-weight: var(--fw-regular);
	background-color: var(--color-main);
	color: var(--color-light);
	padding: 0.5rem;
	margin-right: 0.5rem;
	line-height: 1;
	border-radius: var(--border-radius-medium);
	letter-spacing: var(--letter-spacing);
}
.post-item .post-content {
	display: flex;
	flex-flow: column;
	flex-grow: 1;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 2rem;
	background-color: var(--color-light);
}
.post-item .post-content p {
	line-height: 1.5;
	padding-bottom: 1.5rem;
}
.post-item .post-content .button-container {
	margin-top: auto;
	padding-top: 1rem;
}
/* if background white */
section.white .post-item .post-content {
	background-color: var(--color-lightgrey);
}

/* post-1 */
.post-1 .post-item {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-gap: 0;
}
.post-1 .post-item .post-img {
	height: auto;
}
.post-1 .post-item .post-content {
	justify-content: center;
	padding: 1rem;
}

/* f200 SINGLE */
.post-single .post-header .post-term {
	font-weight: var(--fw-medium);
	text-transform: uppercase;
}
.post-single .post-header .post-title {
	text-align: center;
} 
.post-single .post-header h1 {
	margin: 0	;
}
.post-single .back-btn .button-container {
	margin: 0;
}


/* EVENT TARGET */

/* list attendees */
#attendees-list {
	max-width: 95%;
}
.list-attendees {
	text-align: left;
	margin: 2rem 0 0 0;
}
.list-attendees .attendees {
	grid-gap: 0;

}
.list-attendees .attendees span {
	line-height: 1.3;
}
.list-attendees .attendees.list-header {
	font-weight: var(--fw-semibold);
	padding-bottom: 0.8rem;
	margin-bottom: 0.9rem;
	border-bottom: 1px solid var(--color-primary);
}
.list-attendees .attendees.list-content{
	padding-bottom: 0.5rem;
	margin-bottom: 0.5rem;
	border-bottom: 1px solid var(--color-border);
}
.event-attendees .button-container {
	margin: 0;
} 

.event-alert {
	padding-bottom: 2rem;
}
.event-alert .gform_wrapper {
	padding-top: 2rem;
}

/* 404 */
.error404 section {
	min-height: 75vh;
	display: flex;
	flex-flow: column wrap;
	justify-content: center;
	align-items: center;
	background-image: url(images/bg-img.webp);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	background-color: rgba(0, 0, 0, 0.3);
	background-blend-mode: multiply;
}
.error404 section h2,
.error404 section h3,
.error404 section a {
	text-align: center;
	color: var(--color-light);
}

/* COOKIES STYLE */
.cc-revoke.cc-bottom {
  background-image: url(images/cookie.svg);
  background-size: 16px;
  background-repeat: no-repeat;
  background-position: center;
  width: 30px;
  height: 30px;
  color: rgba(0, 0, 0, 0) !important;
  background-color: var(--color-dark) !important;
  bottom: 1rem !important;
  left: 0 !important;
  font-size: 0.7rem;
  font-weight: var(--fw-light);
  margin: 0;
  font-style: italic;
	border-top-left-radius: 0 !important;
  border-top-right-radius: 0.3em !important;
  border-bottom-right-radius: 0.3em  !important;
	border-bottom-left-radius: 0 !important;
}
/* COOKIES STYLES */
.cookies-wrap {
	border: 1px solid #d1d1d1;
	margin-bottom: 2rem;
}
.cookies-wrap .cookies-line {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
  grid-gap: 1rem;
  padding: 0.8rem;
  border-bottom: 1px solid #d1d1d1;
}
.cookies-wrap .cookies-line:last-of-type {
	border-bottom: 0;
}
.cookies-wrap .cookies-line.strong {
	font-weight: bold;
}
@media (min-width: 640px) {
	.cookies-wrap .cookies-line {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 992px) {
	.cookies-wrap .cookies-line {
		grid-template-columns: repeat(4, 1fr);
	}
}


/* FOOTER */
footer {
	position: relative;
	width: 100%;
	margin-top: -6px;
}
footer .top,
footer .footer-content {
	padding-bottom: 3rem;
	margin-bottom: 3rem;
}
footer .top {
	display: flex;
	flex-flow: column wrap;
	justify-content: center;
	align-items: center;
}
footer .top .logo img {
	width: var(--logo-footer);
	height: auto;
}
footer .footer-item {
	display: flex;
  flex-flow: column wrap;
  justify-content: flex-start;
}
main footer p {
	font-size: 0.9rem;
	font-weight: var(--fw-regular);
}
main footer p a {
	color: var(--color-main);
	text-decoration: none;
	font-weight: var(--fw-regular);
}
main footer p a:hover {
	color: var(--color-primary);
}

/* social media */
.pictos-sm {
	display: flex;
	flex-flow: row wrap;
	align-items: center;
	justify-content: center;
	margin-top: 2rem;
}
.picto-sm {
	display: block;
	margin: 0 1rem;
	padding: 0;
}
.picto-sm,
.picto-sm img {
	height: 30px;
  width: 30px;
	opacity: 1;
}
.picto-sm img:hover {
	opacity: 0.7;
}

/* footer credit */
.credit {
	position: relative;
	display: block;
	text-align: center;
	width: 100%;
	margin: 4rem 0 0 0;
	font-size: 0.9rem;
}

/* GRAVITY */
/* dark bg */
.dark-bg .gform-theme--framework label,
.dark-bg .gform-theme--framework legend,
.dark-bg .gform-theme--framework .gfield_description,
.dark-bg .gsection_description,
.dark-bg .gform-theme--framework .gform_confirmation_message,
.dark-bg .gform-theme--framework input[type].gform-text-input-reset,
.dark-bg .gfield_description,
.dark-bg .gform_confirmation_message,
.dark-bg .gform_wrapper .ginput_product_price_wrapper span,
.dark-bg .gform_wrapper .ginput_container_total input,
.primary .gform-theme--framework label,
.primary .gform-theme--framework legend,
.primary .gform-theme--framework .gfield_description,
.primary .gsection_description,
.primary .gform-theme--framework .gform_confirmation_message,
.primary .gform-theme--framework input[type].gform-text-input-reset,
.primary .gfield_description,
.primary .gform_confirmation_message,
.primary .gform_wrapper .ginput_product_price_wrapper span,
.primary .gform_wrapper .ginput_container_total input {
	color: var(--color-light);
}
.grey .gfield_consent_description {
	background-color: var(--color-light) !important;
}

/* typo (legend, description) */
.form-box .gform_wrapper .gform_required_legend,
.form-box .gsection_description,
.form-box .gfield--type-html,
.form-box .gfield--type-html p,
.form-box .gfield--type-html li,
.form-box .char_count {
	font-size: 0.9rem;
	font-weight: var(--fw-regular);
}

/* hide product fields used to calculate total in voucher form */
.not-show {
	visibility: hidden !important; /* Cache visuellement l'élément */
	height: 0 !important;          /* Supprime la hauteur */
	width: 0 !important;           /* Supprime la largeur */
	margin: 0 !important;          /* Supprime les marges */
	padding: 0 !important;         /* Supprime les paddings */
	border: 0 !important;          /* Supprime les bordures */
	overflow: hidden !important;   /* Empêche tout contenu de déborder */
	position: absolute !important; /* Retire l'élément du flux normal */
}
/* modale */
.animated-modal .gform_wrapper {
	margin: 1rem auto 0 !important;
}
.form-box .form-text {
	padding-bottom: 1rem;
}
/* required legend */
.form-box .gform_wrapper .gform_required_legend {
	margin-bottom: 1rem;
}
/* grid GF */
.form-box .gform-theme--foundation .gform_fields {
	row-gap: 1rem;
}
/* section */
.form-box h3.gsection_title {
	font-size: 1.3rem;
	margin: 1rem 0 0 0;
}
.form-box .gsection_description {
	margin: 0.5rem 0 0 0;
}
/* label */
.gform-theme--framework .gform-field-label:where(:not([class*=gform-field-label--type-])) {
	font-size: 1.1rem !important;
}
/* description */
.form-box .gform-theme--framework .gfield_description:where(:not(.gform-theme__disable):not(.gform-theme__disable *):not(.gform-theme__disable-framework):not(.gform-theme__disable-framework *)),
.form-box .char_count {
	font-size: 0.9rem;
}
/* char count description */
.form-box .char_count {
	margin: 0.5rem 0 0 0;
}
/* checkbox & radio */
.gform_wrapper .gfield_checkbox .gchoice,
.gform_wrapper .gfield_radio .gchoice {
	display: flex;
	align-items: center;
}
.gform_wrapper .gfield_checkbox label,
.gform_wrapper .gfield_radio label {
	line-height: 1.5;
	font-size: 1.1rem !important;
}
/* price */
.gform_wrapper .ginput_product_price_wrapper span,
.gform_wrapper .ginput_container_total input {
	font-size: 1.3rem !important;
  background-color: transparent !important;
  border: 0 !important;
  font-weight: bold !important;
  color: var(--color-main);
}
.gform_wrapper .ginput_product_price_wrapper span.ginput_product_price_label {
	padding-right: 0.5rem;
}
.form-box .gform-theme--framework input[type].gform-text-input-reset.ginput_total {
	font-size: 1.5rem	;
}
/* input */
.gform-theme--framework input {
	font-size: 1.1rem !important;
}
/* button & submit */
.form-box .gform-theme--framework input[type=button] {
	background-color: var(--color-primary) !important;
	font-size: 0.9rem !important;
  color: var(--color-light) !important;
	border: 0 !important;
	text-transform: uppercase !important;
	letter-spacing: var(--letter-spacing) !important;
}
.form-box .gform-theme--framework input[type=submit] {
	background-color: var(--color-primary) !important;
	font-size: 1.1rem !important;
  color: var(--color-light) !important;
	border: 0 !important;
	font-weight: var(--fw-semibold) !important;
	text-transform: uppercase !important;
	letter-spacing: var(--letter-spacing) !important;
}
.form-box .gform-theme--framework input[type=button]:hover,
.form-box .gform-theme--framework input[type=submit]:hover {
	opacity: 0.8 !important;
}
/* consent */ 
.gfield_consent_description {
	background-color: var(--color-lightgrey) !important;
	color: var(--color-main) !important;
	border-radius: var(--br) !important;
	border: 0 !important;
}
/* readonly field */
.read-only input {
	padding: 0 !important;
	border: 0 !important;
	box-shadow: none !important;
	-webkit-box-shadow: none !important;
	font-weight: var(--fw-medium) !important;
}
/* stripe */
.ElementsApp,
.ElementsApp .InputElement {
	font-family: var(--typo-main);
	color: var(--color-main);
}
/* confirmation message */
.gform_confirmation_message {
	font-weight: var(--fw-medium); !important;
  font-size: 1.3rem !important;
  text-align: center !important;
}


/* MEDIA QUERIES */

/* smartphones, touchscreens */
@media (hover: none) and (pointer: coarse) {
	section.cover .swiper-slide,
	article.post-single section.main-pic,
	section.media.parallax {
		background-attachment: scroll;
	}
}
/* stylus-based screens */
@media (hover: none) and (pointer: fine) {
	section.cover .swiper-slide,
	article.post-single section.main-pic,
	section.media.parallax {
		background-attachment: scroll;
	}
}
/* Nintendo Wii controller, Microsoft Kinect */
@media (hover: hover) and (pointer: coarse) {
	section.cover .swiper-slide,
	article.post-single section.main-pic,
	section.media.parallax {
		background-attachment: scroll;
	}
}
/* mouse, touch pad */
@media (hover: hover) and (pointer: fine) {
	article.post-single section.main-pic,
	section.media.parallax {
		background-attachment: fixed;
	}
}


/* MIN WIDTH */

@media (min-width: 576px) {

	/* reset */
	.alignleft,
	.alignright,
	.aligncenter {
		float: inherit;
		margin: inherit;
		width: inherit;
	}
	/* typo */
	h1,
	span.h1-title {
		font-size: 3rem;
	}
	h2 {
		font-size: 2.3rem;
	}
	h3 {
		font-size: 1.5rem;
	}
	h4,
	p,
	main ul,
	main ol,
	.faq-list-item h3 {
		font-size: 1.3rem;
	}
	.small-text,
	.small-text p {
		font-size: 1rem;
	}
	.medium-text,
	.medium-text p {
		font-size: 1.1rem;
	}
	/* global */
	/* global */
	section {
		padding-top: 5rem;
		padding-bottom: 5rem;
	}
	.grid-4,
	.grid-5 {
		grid-template-columns: repeat(2, 1fr);
	}
	/* cover */
	section.cover .header-title {
		padding: 3rem 0 1rem;
	}
	/* media img */
	section.media.img .size-25 {
		max-width: 50%;
	}
	/* columns */
	section.columns .bloc-wrap .column-box {
	  width: calc(50% - 2rem);
	}
	/* gallery */
  section.gallery .gallery-item {
    flex: 1 1 calc(33.33% - 1rem);
    max-width: calc(33.33% - 1rem);
  }
	/* postlist */
	.post-item .post-content {
		padding: 2rem;
	}

}

@media (min-width: 680px) {

	/* global */
	.grid-3 {
		grid-template-columns: repeat(2, 1fr);
	}	
	.grid-4 {
		grid-template-columns: repeat(3, 1fr);
	}
	/* columns */
	section.columns .bloc-wrap .column-box {
    width: calc(33.333% - 2rem);
  }
	/* media img */
	section.media.img .size-50 {
		max-width: 75%;
	}
	section.media.img .size-25 {
		max-width: 33%;
	}
	/* postlist */
	.post-item {
		width: calc(50% - 2rem);
	}
	.post-1 .post-item {
		width: 100%;
	}

}

@media (min-width: 768px) {

	/* typo */
	h1,
	span.h1-title {
		font-size: 3.5rem;
	}
	h3 {
		font-size: 2rem;
	}
	h4,
	p,
	main ul,
	main ol,
	.faq-list-item h3 {
		font-size: 1.4rem;
	}
	/* global */
	.grid-2 {
		grid-template-columns: repeat(2, 1fr);
	}
	/* cover */
	section.cover .cover-logo {
		max-width: 500px	;
	}
	/* faq */
	section.faq .faq-list-item .faq-content .wrap-content.hasImage {
    display: grid;
    grid-template-columns: 26% auto;
    grid-gap: 2rem;
	}
	section.faq .faq-list-item .faq-content .wrap-content.noImage {
    display: grid;
    grid-template-columns: 100%;
	}
	section.faq .faq-list-item .faq-content .wrap-content img {
		order: 1;
		margin: 0;
	}
	section.faq .faq-list-item .faq-content .wrap-content .faq-text {
		order: 2;
	}
	/* postlist */
	.post-1 .post-item {
		grid-template-columns: repeat(2, 1fr);
	}
	/* footer */
	footer .top {
		flex-flow: row wrap;
		justify-content: space-between;
	}
	.pictos-sm {
		justify-content: flex-end;
		margin-top: 0;
		margin-left: auto	;
	}
	.picto-sm {
		margin: 0 0 0 2rem;
	}

}

@media (min-width: 880px) {

	/* text img */
	section.text_img .content-text {
		padding: 2rem;
	}
	section.text_img .content-img {
		max-height: inherit;
	}
	section.text_img.left .content-text {
		order: 2;
	}
	section.text_img.right .content-text {
		order: 1;
	}
	section.text_img.left .content-img,
	section.text_img.left .content-slider.with-text,
	section.text_img.left .content-video {
		order: 1;
	}
	section.text_img.right .content-img,
	section.text_img.right .content-slider.with-text,
	section.text_img.right .content-video {
		order: 2;
	}
	/* big */
	section.text_img.big .content-text {
		width: 30%;
	}
	section.text_img.big .content-img,
	section.text_img.big .content-slider.with-text,
	section.text_img.big .content-video {
		width: 70%;
	}
	/* demi */
	section.text_img.demi .content-text,
	section.text_img.demi .content-img,
	section.text_img.demi .content-slider.with-text,
	section.text_img.demi .content-video {
		width: 50%;
		margin: 0;
	}	
	/* tiers */
	section.text_img.tiers .content-text {
		width: 70%;
	}
	section.text_img.tiers .content-img,
	section.text_img.tiers .content-slider.with-text,
	section.text_img.tiers .content-video {
		width: 30%;
	}
	/* thumbnail */
	section.text_img.thumbnail .content-text {
		width: 85%;
	}
	section.text_img.thumbnail .content-img {
		width: 15%;
	}
	/* gallery */
  section.gallery .gallery-item {
    flex: 1 1 calc(25% - 1rem);
    max-width: calc(25% - 1rem);
  }
  /* footer */
 	.picto-sm,
	.picto-sm img {
		height: 45px;
	  width: 45px;
	}

}

@media (min-width: 992px) {

	/* typo */
	h1,
	span.h1-title {
		font-size: 4rem;
	}
	h2 {
		font-size: 2.5rem;
	}
	h3 {
		font-size: 2rem;
	}
	h4,
	p,
	main ul,
	main ol,
	.faq-list-item h3 {
		font-size: 1.5rem;
	}
	/* global */
	section {
		padding-top: 6rem;
		padding-bottom: 6rem;
	}
	.grid-3 {
		grid-template-columns: repeat(3, 1fr);
	}
	.grid-4 {
		grid-template-columns: repeat(4, 1fr);
	}
	.grid-5 {
		grid-template-columns: repeat(5, 1fr);
	}
	/* header */
	.header.smallscroll {
		background-color: var(--color-light);
		box-shadow: var(--shadow-bottom);
	}
	.header .header-logo img {
		height: 100px;
	}
	.header.smallscroll .header-logo img {
		height: 40px;
	}
	.header.smallscroll .header-logo.lsmall {
		opacity: 1;
		visibility: visible;
		display: block;
	}
	/* cover */
	section.cover .button-container {
	  margin: 2rem 0 0 0;
	}
	/* columns */
	section.columns .column-header {
	  padding-bottom: 4rem;
	}
	/* columns */
	section.columns.fullwidth .bloc-wrap .column-box {
    width: calc(25% - 2rem);
  }
	/* media img */
	section.media.img .size-50 {
		max-width: 50%;
	}
	section.media.img .size-25 {
		max-width: 25%;
	}
	/* media parallax */
	section.media.parallax .bloc-wrap .inner.small-inner {
		max-width: 1000px;
	}
	section.media.parallax .bloc-wrap .inner p {
		font-size: 2rem	;
	}
	/* f190 BUTTON */
	.button-container {
	  margin-top: 2rem;
	}
	.button-container.small-btn {
	  margin-top: 1.5rem;
	}
  /* footer */
	footer p {
		font-size: 1.4rem;
	}

	/* MENU */
	.menu_toggle {
		display: none;
	}
	nav {
		width: 100%;
		height: 100%;
	}
	div.menu-wrap {
		position: relative;
		justify-content: center;
		align-items: flex-end;
		width: 100%;
		height: auto;
		top: auto;
		right: auto;
		left: auto; 	 		
		padding: 0;
		margin: 0;
		background-color: transparent;
		z-index: 5;
		overflow: initial;
		overflow-x: initial;
		overflow-y: initial;
	}
	div.menu-wrap.active {
		height: auto;
		top: auto;
		bottom: auto;
		box-shadow: none;
		width: 100%;
	}
	div.menu-wrap ul {
		display: flex;
		flex-flow: row;
		justify-content: flex-end;
		align-items: center;
		height: 100%;
	}
	.top_menu + .main_menu {
		margin-top: 2rem;
	}	
	/* top menu */
	.top_menu {
		order: 1;
		margin-top: 0;
		text-align: initial;
		margin-bottom: 1rem;
		padding: 0 0 1rem 0;
	}
	.header.smallscroll .top_menu {
		margin-bottom: 0;
		padding-bottom: 0;
		border-bottom: 0;
	}
	.header.smallscroll .top_menu ul {
		margin-bottom: 0.5rem;
		padding-bottom: 0.5rem;
		border-bottom: 1px solid var(--color-lightgrey);
	}
	.top_menu ul li {
		padding: 0 0 0 2rem;
	}
	.smallscroll .top_menu ul li.wpml-ls-item {
		padding: 0;
	}
	.top_menu ul li a {
		font-size: 0.8rem;
	}

	/* main menu */
	.top_menu + .main_menu {
		margin-top: 0;
	}
	.main_menu {
		order: 2;
		width: auto;
		padding: 0;
		margin-top: 0;
	}
	.main_menu ul li {
	  display: flex;
	  align-items: center;
	  padding: 0;
	  border-bottom: 0;
	  margin-bottom: 0;
	  margin-left: 1.5rem;
	}
	.smallscroll .main_menu ul li {
	  margin-left: 1rem;
	}
	.main_menu ul li a:not(.btnMenuLink a) {
	  display: initial;
	  padding: 0;
	}
	.smallscroll .main_menu ul li a {
		font-size: 1.2rem;
	}
	.smallscroll .main_menu ul.menu li.menu-item-has-children a::after,
	.smallscroll .main_menu ul.menu li.current-menu-parent.menu-item-has-children a::after {
		margin-top: 2px;
	}
	.smallscroll .main_menu ul.menu li.current-menu-parent.menu-item-has-children.active a::after {
		margin-top: 7px;
	}
	ul.menu li.btnMenuLink {
		display: block;
		margin-top: 0;
		margin-left: 2rem;
		transform: none;
	}
	/* sub-menu */
	.main_menu ul.menu li ul.sub-menu {
		display: none;
		position: absolute;
		width: auto;
		height: auto;
		padding: 1rem 0;
		top: 3rem;
		left: 0;
		background-color: var(--color-light);
		box-shadow: var(--shadow-light);
		z-index: 10;
	}
	.smallscroll .main_menu ul.menu li ul.sub-menu {
		top: 2rem;
	}
	.main_menu ul.menu li ul.sub-menu li {
		display: block;
		width: 100%;
		height: auto;
		margin: 0;
	}
	.main_menu ul.menu li ul.sub-menu li:hover {
		background-color: var(--color-light);
	}
	.main_menu ul.menu li ul.sub-menu li a {
		display: block;
		font-size: 1rem;
		white-space: nowrap;
		height: auto;
		padding: 1rem 3rem;
		border: 0;
	}
	.smallscroll .main_menu 	ul.menu li ul.sub-menu li a {
		padding: 0.8rem 2rem;
	}	 
	.main_menu ul.menu li.menu-item-has-children ul.sub-menu li a::after {
		content: none;
	}

}

@media (min-width: 1200px) {
	
	/* typo */
	h1,
	span.h1-title {
		font-size: 4.5rem;
	}
	h2 {
		font-size: 3rem;
	}
	h3 {
		font-size: 2rem;
	}
	h4,
	p,
	main ul,
	main ol,
	.faq-list-item h3 {
		font-size: 1.6rem;
	}
	/* header */
	.header {
		padding: 0 2rem;
	}
	/* cover */
	section.cover .tagline {
		padding: 0 8rem;
	}
 	/* text img */
	section.text_img .content-text,
	section.text_img.fullwidth .content-text {
	  padding: 5rem;
	}
	/* columns */
	section.columns.fullwidth .bloc-wrap .column-box {
    width: calc(16.666% - 2rem);
  }
	/* gallery */
  section.gallery .gallery-item {
    flex: 1 1 calc(20% - 1rem);
    max-width: calc(20% - 1rem);
  }
  section.gallery .gallery-item:last-of-type {
  	display: block;
  }
	/* MENU */
	.main_menu ul li {
	  margin-left: 2rem;
	}
	.main_menu ul li a {
		font-size: 1.4rem;
	}

}
