@charset "UTF-8";


/* ==========================================================================
   Root variables
   ========================================================================== */

:root {
  --color-black: #1d1d1d;
  --color-white: #ffffff;
  --color-coral: #ff5a32;
  --color-celeste: #c6e7e0; 
}


/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html,button,input,select,textarea,a { color: #1d1d1d; }
html, body { min-height: 100%; -webkit-text-size-adjust: 100%; }
html { overflow-y: scroll; overflow-x: hidden; }
body { font-size: 16px; line-height: 1.4; font-weight: 400; font-family: "Ambit W01", 'Helvetica Neue',Helvetica,Arial,sans-serif; background: #fff; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

*, *:before, *:after { box-sizing: border-box; }

::-moz-selection { background: #ddd; text-shadow: none; }
::selection { background: #ddd; text-shadow: none; }

b, strong { font-weight: 700; }

img { vertical-align: middle; }

:focus { outline: 0; }
:focus { outline:none; } ::-moz-focus-inner { border:0; }
a:focus { outline: none; }
a { text-decoration: none; color: inherit; }
a, a:hover, a:active { outline: 0; -webkit-tap-highlight-color: rgba(0, 0, 0, 0);}
 
ul, ol { list-style: none; padding: 0; margin: 0; }

button { margin: 0; padding: 0; border: 0; cursor: pointer; cursor: hand; background-color: transparent; border-radius: 0; -webkit-box-shadow: none; box-shadow: none; -moz-appearance: none; -webkit-appearance: none; }

[class^="icon-"], [class*=" icon-"] { height: 100%; width: 100%; display: inline-block; fill: currentColor; vertical-align: middle; }



/* ==========================================================================
   Custom styles
   ========================================================================== */

.logo-brugge { background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgdmlld0JveD0iMCAwIDEwMCA2OCI+PHBhdGggZD0ibTQ5LjQ5IDI1LjExLTEuMi0uMWMtLjkxLS4wOS0xLjYyLS4zNy0yLjEyLS44Mi0uNDgtLjQ2LS43Mi0xLjA1LS43Mi0xLjc4di03LjI3aDEuNzhxLjQ1IDAgLjkzLjI0Yy4zMi4xNi41Ni4zNS43Mi41OGw3Ljg4IDEwLjY2cS4wNzUuMTA1LjI0LjIxYy4xMS4wNS4yMi4wNy4zMS4wN2g1Ljg5di0xLjQ3bC0uOTktLjFjLTEuMTQtLjE0LTIuMTQtLjc3LTIuOTgtMS44OGwtNS4yNC03LjA2Yy0uNDMtLjU5LS45NC0xLjEtMS41MS0xLjUxdi0uMzhjMi40OS0uMjMgNC40NC0uOTUgNS44Ni0yLjE2czIuMTItMi43OSAyLjEyLTQuNzNjMC0xLjQyLS40MS0yLjY0LTEuMjMtMy42Ny0uOC0xLjA1LTEuOTYtMS44NS0zLjUtMi40LTEuNTEtLjU3LTMuMjgtLjg2LTUuMzEtLjg2aC0xMi4zdjEuNzhsLjk5LjFjLjc1LjA5IDEuMzQuMzcgMS43NS44Mi40MS40Ni42MiAxLjA1LjYyIDEuNzhWMjIuNGMwIC43My0uMjEgMS4zMy0uNjIgMS43OC0uNDEuNDYtLjk5LjczLTEuNzUuODJsLS45OS4xdjEuNzhINDkuNVYyNS4xWk00NS40NCAyLjhjMC0uMDkuMDMtLjE3LjEtLjI0cy4xNS0uMS4yNC0uMWg0LjI1cTIuODA1IDAgNC4zNSAxLjQ0YzEuMDUuOTQgMS41OCAyLjI3IDEuNTggNC4wMXMtLjUgMy4wOC0xLjUxIDQuMDRjLTEuMDEuOTQtMi40MyAxLjQxLTQuMjggMS40MWgtNC43M3oiLz48cGF0aCBkPSJNOTYuMi42OGgtNS4yNHYxLjc4bC45OS4xYy43NS4wOSAxLjM0LjM3IDEuNzUuODIuNDEuNDYuNjIgMS4wNS42MiAxLjc4djEyLjNjMCAxLjQ0LS4zMiAyLjcxLS45NiAzLjgtLjYyIDEuMS0xLjUgMS45NC0yLjY0IDIuNTQtMS4xNC41OS0yLjQ2Ljg5LTMuOTQuODlzLTIuOC0uMy0zLjk0LS44OWMtMS4xMi0uNTktMS45OS0xLjQ0LTIuNi0yLjU0LS41OS0xLjEtLjg5LTIuMzYtLjg5LTMuOFY1LjE3YzAtLjczLjIxLTEuMzMuNjItMS43OHMuOTktLjczIDEuNzUtLjgybC45OS0uMVYuNjhINzIuMDJ2MS43OGwuOTkuMWMuNzUuMDkgMS4zNC4zNyAxLjc1LjgyLjQxLjQ2LjYyIDEuMDUuNjIgMS43OHYxMi4zYzAgMS45Ni40MyAzLjY4IDEuMyA1LjE0czIuMDkgMi41OSAzLjY3IDMuMzljMS42Ljc4IDMuNDcgMS4xNyA1LjYyIDEuMTdzNC4wMS0uMzkgNS41OS0xLjE3YzEuNi0uOCAyLjgzLTEuOTMgMy43LTMuMzlzMS4zLTMuMTggMS4zLTUuMTRWNS4xN2MwLS43My4yMS0xLjMzLjYyLTEuNzguNDEtLjQ2Ljk5LS43MyAxLjc1LS44MmwuOTktLjFWLjY4aC0zLjdaIi8+CiAgPHBhdGggZD0iTTk0LjUyIDYyLjM5cS0uMzE1IDEuNTE1LTEuMjMgMi4xOS0uOTMuNjktMi40LjY5aC02LjY4Yy0uNTcgMC0xLjA2LS4xOS0xLjQ3LS41OC0uMzktLjQxLS41OC0uOS0uNTgtMS40N3YtOC43aDMuNmMuODUgMCAxLjUyLjE4IDIuMDIuNTUuNTMuMzcuODguOTkgMS4wNiAxLjg4bC4zMSAxLjU0aDEuODh2LTkuOGgtMS44OGwtLjMxIDEuNTRjLS4xOC44OS0uNTQgMS41Mi0xLjA2IDEuODgtLjUuMzctMS4xOC41NS0yLjAyLjU1aC0zLjZ2LTkuN2MwLS4wOS4wMy0uMTcuMS0uMjRzLjE1LS4xLjI0LS4xaDcuNjRxMS40NyAwIDIuNC42OXQxLjIzIDIuMTlsLjY5IDMuNWgxLjkydi04LjE2SDc0LjgydjEuNzhsLjk5LjFjLjc1LjA5IDEuMzQuMzcgMS43NS44Mi40MS40Ni42MiAxLjA1LjYyIDEuNzh2MTcuMjRjMCAuNzMtLjIxIDEuMzMtLjYyIDEuNzgtLjQxLjQ2LS45OS43My0xLjc1LjgybC0uOTkuMXYxLjc4aDIyLjMxdi04LjE2aC0xLjkybC0uNjkgMy41WiIvPgogIDxwYXRoIGQ9Ik0yMi4xNCA1NC45OGgtNC40NXYxLjc4bDEuMi4xYy45MS4wOSAxLjYxLjM3IDIuMDkuODIuNDkuNDUuNzQgMS4wMy43NSAxLjc1IDAgMS4xLS4zNSAyLjEyLTEuMDMgMy4wNS0uNjkuOTQtMS42MiAxLjY4LTIuODEgMi4yM3MtMi41LjgyLTMuOTQuODJjLTEuODcgMC0zLjUxLS40OC00LjktMS40NC0xLjM3LS45Ni0yLjQzLTIuMzMtMy4xOS00LjExLS43My0xLjc4LTEuMS0zLjg2LTEuMS02LjI0cy4zNS00LjM1IDEuMDYtNi4wN2MuNzMtMS43MSAxLjc2LTMuMDMgMy4wOC0zLjk0IDEuMzUtLjk0IDIuOTItMS40IDQuNzMtMS40IDIuMTUgMCAzLjg4LjY1IDUuMjEgMS45NSAxLjMzIDEuMjggMi4xIDMuMDUgMi4zMyA1LjMxaDQuNjljLS4xMS0xLjY5LS43MS0zLjIyLTEuNzgtNC41OS0xLjA1LTEuMzktMi40Ny0yLjQ4LTQuMjUtMy4yNi0xLjc2LS44LTMuNzEtMS4yLTUuODYtMS4yLTIuNiAwLTQuOTcuNTgtNy4wOSAxLjc1LTIuMSAxLjE3LTMuNzYgMi43Ni00Ljk3IDQuOEMuNyA0OS4xMi4wOSA1MS40MS4wOSA1My45NHMuNTggNC43NiAxLjc1IDYuODJxMS43ODUgMy4wNDUgNC44MyA0LjhjMi4wNiAxLjE3IDQuMzQgMS43NSA2Ljg1IDEuNzUgMS4wNSAwIDEuOTktLjA5IDIuODEtLjI3czEuNzUtLjQ2IDIuNzgtLjgyYzEuMDEtLjM0IDEuODctLjU5IDIuNi0uNzUuNzUtLjE4IDEuNi0uMjcgMi41NC0uMjcuNDMgMCAuODkuMDMgMS4zNy4xdi01LjgzYzAtLjczLjIxLTEuMzMuNjItMS43OC40MS0uNDYuOTktLjczIDEuNzUtLjgybC45OS0uMXYtMS43OGgtNi44NVoiLz4KICA8cGF0aCBkPSJNNTkuNjMgNTQuOThoLTQuNDZ2MS43OGwxLjIuMWMuOTEuMDkgMS42MS4zNyAyLjA5LjgyLjQ5LjQ1Ljc0IDEuMDMuNzUgMS43NSAwIDEuMS0uMzUgMi4xMi0xLjAzIDMuMDUtLjY5Ljk0LTEuNjIgMS42OC0yLjgxIDIuMjNzLTIuNS44Mi0zLjk0LjgyYy0xLjg3IDAtMy41MS0uNDgtNC45LTEuNDQtMS4zNy0uOTYtMi40My0yLjMzLTMuMTktNC4xMS0uNzMtMS43OC0xLjEtMy44Ni0xLjEtNi4yNHMuMzUtNC4zNSAxLjA2LTYuMDdjLjczLTEuNzEgMS43Ni0zLjAzIDMuMDgtMy45NCAxLjM1LS45NCAyLjkyLTEuNCA0LjczLTEuNCAyLjE1IDAgMy44OC42NSA1LjIxIDEuOTUgMS4zMyAxLjI4IDIuMSAzLjA1IDIuMzMgNS4zMWg0LjY5Yy0uMTEtMS42OS0uNzEtMy4yMi0xLjc4LTQuNTktMS4wNS0xLjM5LTIuNDctMi40OC00LjI1LTMuMjYtMS43Ni0uOC0zLjcxLTEuMi01Ljg2LTEuMi0yLjYgMC00Ljk3LjU4LTcuMDkgMS43NS0yLjEgMS4xNy0zLjc2IDIuNzYtNC45NyA0LjgtMS4yMSAyLjAzLTEuODIgNC4zMi0xLjgyIDYuODVzLjU4IDQuNzYgMS43NSA2LjgycTEuNzg1IDMuMDQ1IDQuODMgNC44YzIuMDYgMS4xNyA0LjM0IDEuNzUgNi44NSAxLjc1IDEuMDUgMCAxLjk5LS4wOSAyLjgxLS4yN3MxLjc1LS40NiAyLjc4LS44MmMxLjAxLS4zNCAxLjg3LS41OSAyLjYtLjc1Ljc1LS4xOCAxLjYtLjI3IDIuNTQtLjI3LjQzIDAgLjg5LjAzIDEuMzcuMXYtNS44M2MwLS43My4yMS0xLjMzLjYyLTEuNzguNDEtLjQ2Ljk5LS43MyAxLjc1LS44MmwuOTktLjF2LTEuNzhoLTYuODVaIi8+CiAgPHBhdGggZD0iTTI0LjM2IDE2LjI3Yy0uOC0xLjA3LTEuOTQtMS45LTMuNDMtMi40Ny0uNS0uMjEtMS4wNS0uMzYtMS42MS0uNXYtLjM2Yy4zNi0uMS43LS4yMSAxLjAzLS4zNSAxLjMtLjUzIDIuMzEtMS4yNiAzLjAyLTIuMTkuNzEtLjk2IDEuMDYtMi4wNiAxLjA2LTMuMjkgMC0xLjMtLjM5LTIuNDMtMS4xNi0zLjM5LS43NS0uOTgtMS44NC0xLjc0LTMuMjYtMi4yNlMxNi45NS42NyAxNS4wOC42N0gzLjEydjEuNzhsLjk5LjFjLjc1LjA5IDEuMzQuMzcgMS43NS44MnMuNjIgMS4wNS42MiAxLjc4djE3LjI0YzAgLjczLS4yMSAxLjMzLS42MiAxLjc4cy0uOTkuNzMtMS43NS44MmwtLjk5LjF2MS43OGgxMy4wNmMxLjg3IDAgMy41Mi0uMjkgNC45My0uODYgMS40Mi0uNTcgMi41MS0xLjM4IDMuMjktMi40M3MxLjE3LTIuMjcgMS4xNy0zLjY3LS40LTIuNjItMS4yLTMuNjdaTTEwLjQ1IDIuOGMwLS4wOS4wMy0uMTcuMS0uMjRzLjE1LS4xLjI0LS4xaDMuOTFjMS43MSAwIDMuMDQuNDMgMy45OCAxLjMuOTYuODUgMS40NCAyLjA0IDEuNDQgMy42cy0uNDggMi43Ni0xLjQ0IDMuNjNjLS45NC44NS0yLjI2IDEuMjctMy45OCAxLjI3aC00LjI1em05LjAxIDIwLjg3Yy0xLjA1Ljk2LTIuNTIgMS40NC00LjQyIDEuNDRIMTIuNWMtLjU3IDAtMS4wNi0uMTktMS40Ny0uNTgtLjM5LS40MS0uNTgtLjktLjU4LTEuNDd2LTguOTRoNC4yNWMyLjAxIDAgMy41Ni40OSA0LjY2IDEuNDcgMS4xMi45NiAxLjY4IDIuMzEgMS42OCA0LjA0cy0uNTMgMy4wOC0xLjU4IDQuMDQiLz48L3N2Zz4=");
}


.section-hero-home .logo-brugge {
  position: absolute;
  left: 48px;
  top: 48px;
  display: block;
  width: 150px;
  height: 102px;
  background-position: center center;
  background-size: contain; 
  z-index: 4; 
}

/* 
 *	 elements 
 *	
 */


body {
	display: flex;
  flex-direction: column;
  min-height: 100vh;
}

main {
  position: relative;
  padding-top: 100px;
  z-index: 2;
}

section, #header, footer, #header nav {
	position: relative;
	margin: 0 auto;
	width: 100%;
}

.container {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 1920px;
  padding-left: 50px;
  padding-right: 50px;	
}

.container.no-padding {
  padding-left: 0;
  padding-right: 0;
}

#header nav {
  padding-left: 50px;
  padding-right: 50px;
}

.constraint {
  position: relative;
  margin: 0 auto;
}

.row {
	position:relative;
	clear: both;
}

.row-align-left { margin-left: 0; margin-right: auto; }
.row-align-right { margin-left: auto; margin-right: 0; }
.row-align-center { margin-left: auto; margin-right: auto; }

.row-full, .row-wide, .row-base, .row-narrow {
  position: relative;
  display: block;
  margin: 0 auto;
}

.row-full {
  padding-left: 0;
  padding-right: 0;
}

.row-wide {
  padding-left: 50px;
  padding-right: 50px;
}

.row-base {
  padding-left: 150px;
  padding-right: 150px;
}

.row > .inner {
  position: relative;
  display: block;
  margin: 0 auto;
  width: 100%;
}





.flex {
	display: flex;
  flex-direction: row;
	justify-content: flex-start;
	align-items: flex-start;
}

.flex-direction-col, .flex-column{ flex-direction: column; }

.flex-align-left { justify-content: flex-start; }
.flex-align-right { justify-content: flex-end; }
.flex-align-center { justify-content: center; }
.flex-align-between { justify-content: space-between; }

.flex-valign-top { align-items: flex-start; }
.flex-valign-center { align-items: center; }
.flex-valign-bottom { align-items: flex-end; }
.flex-valign-stretch { align-items: stretch; }

.flex-wrap { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }

.padding-top-small { padding-top: 25px; }
.padding-top-regular { padding-top: 50px; }
.padding-top-medium { padding-top: 70px; }
.padding-top-large { padding-top: 110px; }

.padding-bottom-small { padding-bottom: 25px; }
.padding-bottom-regular { padding-bottom: 50px; }
.padding-bottom-medium { padding-bottom: 80px; }
.padding-bottom-large { padding-bottom: 110px; }

.background-grey { background-color: #ffffff; color: #1d1d1d; }
.background-purple { background-color: #c6e7e0; color: #1d1d1d; }
.background-blue { background-color: #c6e7e0; color: #1d1d1d; }


.background-white { background-color: #ffffff; color: #1d1d1d; }
.background-celeste { background-color: #c6e7e0; color: #1d1d1d; }
.background-coal { background-color: #1d1d1d; color: #ffffff; }
.background-coral { background-color: #ff5a32; color: #ffffff; }







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

.img {
	position: relative;
	width: 100%;
	height: 0;
	overflow: hidden;
}

.img img {
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
	min-height: 100%;
	z-index: 1;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0) scale(1.0, 1.0);
}

.img.img-0 img { opacity: 1; }
.img.img-10 img { opacity: 0.9; }
.img.img-20 img { opacity: 0.8; }
.img.img-30 img { opacity: 0.7 }
.img.img-40 img { opacity: 0.6 }
.img.img-50 img { opacity: 0.5 }
.img.img-60 img { opacity: 0.4 }
.img.img-70 img { opacity: 0.3 }
.img.img-80 img { opacity: 0.2 }
.img.img-90 img { opacity: 0.1 }

.img.img-10:has(.b-loaded),  
.img.img-20:has(.b-loaded),
.img.img-30:has(.b-loaded),
.img.img-40:has(.b-loaded),
.img.img-50:has(.b-loaded),
.img.img-60:has(.b-loaded),
.img.img-70:has(.b-loaded),
.img.img-80:has(.b-loaded),
.img.img-90:has(.b-loaded) { background-color: var(--color-celeste); }

.block-video .videobox > div { background-color: var(--color-celeste); }

p {	
	margin-top: 1em;
	margin-bottom: 0;
}

/*
 *  bridges
 *
 */
 
.bridge {
  position: relative;
  width: 100%;
  height: 0;
  z-index: 1;
  margin-bottom: -1px;
}
 
.bridge svg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
 
.bridge.bridge-single { padding-top: 48%; }
.bridge.bridge-logo { padding-top: 40%; }
.bridge.bridge-logo-wide { padding-top: 35%; }
.bridge.bridge-wide { padding-top: 34%; }
.bridge.bridge-narrow { padding-top: 48%; }
.bridge.bridge-high { padding-top: 88%; }
.bridge.bridge-double { padding-top: 30%; }
.bridge.bridge-triple { padding-top: 20%; }
.bridge.bridge-triple-high { padding-top: 50%; }
.bridge.bridge-quintuple { padding-top: 20%; }
.bridge.bridge-quintuple-low { padding-top: 18%; }
.bridge.bridge-combined { padding-top: 22%; }
.bridge.bridge-combined:before { position: absolute; display: block; top: 0; left: 74.45%; width: 2px;   height: 100%; background-color: #fff; content: ""; z-index: 2; }
.bridge.bridge-double-combined { padding-top: 20%; }
.bridge.bridge-double-combined:before { position: absolute; display: block; top: 0; left: 37.77%; width: 2px; height: 100%; background-color: #fff; content: ""; z-index: 2; }

.background-grey .bridge, .section-bridge .bridge {
  color:  #c7e8e1; 
}


/*
 *	 buttons 
 *
 */
 
.section-button { text-align: center; } 
.section-button.section-button-left { text-align: left; }

.button {
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1), background-color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.button-pill {
  position: relative;
  display: inline-block;
  border-radius: 9999px; 
  padding: 0.455em 0.8em 0.295em;   
  font-size: 2rem;
  line-height: 1;
  text-transform: uppercase;
  vertical-align: top;
}

.button-grey { background-color: #fff; color: #2e61ff; }
.button-grey:hover { background-color: #fff; color: #2e61ff; }

.button-purple { background-color: #2e61ff; color: #fff; }
.button-purple:hover { background-color: #fff; color: #2e61ff; }

.button-white { background-color: #fff; color: #2e61ff; }
.button-white:hover { background-color: #2e61ff; color: #fff; }

.button-white.button-white-alt:hover { background-color: #fff; color: #2e61ff; }

.button-margin-top { margin-top: 2.25em; }




.button.button-arrow {
  position: relative;
  display: inline-block;
  margin: 0;
  padding-left: 106px;
  padding-right: 30px;
  min-height: 60px;
  padding-top: 0.35em;
  font-size: 2.813em;
  line-height: 0.841;
  text-transform: uppercase;
  transition: padding .25s cubic-bezier(0.2, 0.6, 0.3, 1);
  vertical-align: top;
}
.button.button-arrow:hover { padding-left: 136px; padding-right: 0; }

.button.button-arrow span {
  position: absolute; 
  display: block;
  top: 0;
  left: 0;
  width: 86px;
  height: 60px;
  overflow: hidden;
  transition: width .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}
.button.button-arrow:hover span { width: 116px; }

.button.button-arrow span svg {
  position: absolute;
  right: 0;
  top: 0;
  height: 60px;
  width: 116px;
}


.button.button-arrow.button-arrow-medium { 
  padding-left: 80px;
  padding-right: 22px;
  min-height: 45px;
  padding-top: 0.3em;
  font-size: 2.188rem;
  line-height: 0.841; 
}

.button.button-arrow.button-arrow-medium:hover { padding-left: 102px; padding-right: 0; }

.button.button-arrow.button-arrow-medium span {
  width: 65px;
  height: 45px;
}
.button.button-arrow.button-arrow-medium:hover span { width: 87px; }

.button.button-arrow.button-arrow-medium span svg {
  position: absolute;
  right: 0;
  top: 0;
  height: 45px;
  width: 88px;
}

.button-wrapper {
  position: relative;
  width: 100%;
}

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


/*
 *	 lines 
 *
 */
 
.section-line hr {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 1920px;
  height: 2px;
  border: 0;
}

.section-line hr.background-grey {
  background-color: var(--color-black);
}


/*
 *	 content - default text
 *
 */
 
.content {
  font-size: 1.563rem; /* 25px */
  line-height: 1.25;
  margin-bottom: -0.4em;
}

.content.content-introduction {
  font-size: 1.875rem; /* 30px */
  line-height: 1.25;
  margin-bottom: -0.15em;
}

.content h2 {
  margin-top: 1em;
  font-size: 3.750rem; /* 60px */
  line-height: 1.1;
}

.content h2:first-child { margin-top: -0.1em; }

.content h3 {
  margin-top: 1em;
  font-size: 3.125rem; /* 50px */
  line-height: 1.1;
}

.content h3:first-child { margin-top: -0.1em; }

.block-performance-intro .content.content-small h2 { font-size: 3rem; }
.block-performance-intro .content.content-small h3 { font-size: 2.5rem; }

.block-performance-intro .content.content-small {
  margin-top: 50px;
}


.content p, .content ul {
  margin-top: 1em;
}
/*
.content p em {
  font-size: 1rem;
  line-height: 1.25;
*/

.content p:first-child, .content ul:first-child {
  margin-top: -0.175em !important;
}

.content ul, .content ul {
  padding-left: 1.125em;
}

.content ul li, .content ul li {
  position: relative;
  margin-top: 0.5em;
}

.content ul li:before, .content ul li:before {
  position: absolute;
  top: 0;
  left: 0;
  margin-left: -0.975em;
  content: "-";  
}

.content a {
  text-decoration: underline;
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.content a:hover {
  color: #ff5a32;
}




.content.content-small h2 {
  margin-top: 1em;
  margin-left: -0.02em;
  font-size: 2.875rem;
  line-height: 0.895;
  text-transform: uppercase;
}

.content.content-small h2:first-child { margin-top: -0.1em; }

.content.content-small p {
  font-size: 1.250rem;
  line-height: 1.25;
}

.content.content-small p em {
  font-size: 1.250rem;
  line-height: 1.25;
}



.block .timetable {
  position: relative;
  width: 100%;
}

.block .timetable li {
  display: flex;
  flex-wrap: nowrap;
  font-size: 1.875rem;
  line-height: 1.1;
  text-transform: uppercase;
  margin-top: 0.5em;
}

.block .timetable li:first-child {
  margin-top: 0;
}

.block .timetable li hr {
  flex: 1 1 auto;
  height: 2px;
  background-color: #2e61ff;
  border: 0;
  margin: 0.45em 0.5em;
}

.block .timetable li span:first-child, .block .timetable li span:last-child {
  flex: 0 0 auto;
}



/*
 *	 columns - page about 
 *
 */ 

.border-left-grey {
  border-left: 2px solid #fff;
}

.columns {
  position: relative;
  width: 100%;
}

.columns .column {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 0 0 50%;
  justify-content: flex-start;
  align-items: flex-start;   
  flex-wrap: wrap;
  width: 50%;
}

.columns .column.border-top-grey { border-top: 2px solid #fff; }
.columns .column.border-top-blue { border-top: 2px solid #1d1d1d; }

.section-about .container.border-top-grey {
  border-top: 2px solid #1d1d1d;
}

.columns .block {
  padding-left: 50px;
  padding-right: 50px;
  width: 100%;
}

.column-title-large {
  padding-top: 50px;
  margin-top: 0;
  margin-bottom: -0.182em;
  font-size: 6rem;
  line-height: 0.895;
  text-transform: uppercase;  
}

.column-title-medium {
  margin-top: -0.115em;
  margin-bottom: -0.2875em;
  padding-bottom: 50px;
  font-size: 5rem;
  line-height: 1.1;
  text-transform: uppercase;  
}

.column-form {
  margin-top: 80px;
}

.columns .column.background-blue .bridge, .sidebar.background-blue .bridge {
  position: relative;
  color: #c7e8e1;
  margin-bottom: -1px;
}

.columns .column.background-blue .bridge:before, .sidebar.background-blue .bridge:before {
  position: absolute;
  display: block;
  top: 1px;
  left: 1px; 
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background-color: #fff;
  content: "";
}


.block .meta {
  padding-top: 60px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}

.block .meta p {
  position: relative;
  margin: 0;
}

.block .meta .tags {
  font-size: 1.875rem;
  line-height: 1.1;
}

.block .meta .tags ul {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  margin-top: 2px;
}

.block .meta .tags li {
  display: inline-block;
  margin-top: -2px;
  padding: 0.26em 0.3em 0.06em;
  border: 2px solid currentcolor;
}

.block.block-performance-header .meta .tags li {
  border: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
}

.block.block-performance-header .meta .tags li a, .block.block-performance-header .meta .tags li span {
  margin-right: -2px;
  padding: 0.26em 0.3em 0.06em;
  border: 2px solid currentcolor;  
}

.block .meta .price {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100px;
  width: 100px;
  font-size: 2.813rem;
  line-height: 1;
  border: 2px solid currentcolor;
  border-radius: 50%;
}

.block .meta .price.price-small {
  font-size: 1.563rem;
  line-height: 1;
}

.block .meta .location {
  position: relative;
  padding-top: 40px;
  font-size: 2.188rem;
  line-height: 1.1;
  width: 100%;
}

.block .meta .location p {
  padding-left: 30px;
}

.block .meta .location svg {
  position: absolute;
  display: block;
  left: 0;
  top: 0;
  width: 22px;
  height: 30px;
  padding: 0;
  vertical-align: top;
}



.columns .column .img {
  background-color: #c7e8e1;
}

.columns .block.align-left {
  margin-left: 0;
  margin-right: auto;
}

.columns .block.align-right {
  margin-left: auto;
  margin-right: 0;
}

.columns .column-right .block.align-right {
  margin-left: auto;
  margin-right: 0px;
}

.columns .block.align-full.align-image {
  padding-left: 0;
  padding-right: 0;
}

.columns .block.align-full {
  width: 100%;
}

.columns .column-left .block.align-left, .columns .column-left .block.align-right {
  width: 100%;
  max-width: 720px;
}

.columns .column-left .block.align-left.has-intro, .columns .column-left .block.align-right.has-intro {
  width: 100%;
  max-width: 820px; 
}

.columns .column-right .block.align-left, .columns .column-right .block.align-right {
  width: 100%;
  max-width: 700px;
}

.columns .block.has-bridge:last-child {
  margin-top: auto;
  overflow: hidden;
}

.columns .block.align-right.has-button {
  text-align: right;
  margin-right: -30px;
}



/*
 *	 sections with a bridge above
 *
 */  
.section-performance, .section-about { z-index: 2; }

.button-wrapper.button-wrapper-center, .button-wrapper.button-wrapper-bridge {
  height: 96px;
  font-size: 2.813em; /* 45px */
  line-height: 0.841;
  text-transform: uppercase;
  color: #1d1d1d;
  background-color: #fff;
}

.button-wrapper.button-wrapper-center {
  text-align: center;
  border-top: 2px solid #1d1d1d;
  margin-top: -2px;
}

.button-wrapper.background-blue {
  background-color: #c6e7e0;
  color: #1d1d1d;
}

.section-about .button-wrapper.button-wrapper-center {
  border-left: 0;
  margin-top: 0;
  height: auto !important;
}

.button-wrapper.button-wrapper-center .arrow-button-small {
  margin-top: 16px;
  margin-left: auto;
  display: inline-block;
}

.button-wrapper.button-wrapper-bridge .arrow-button-small {
  margin-left: auto;
  display: inline-block;
}


.button-wrapper-bridge-spacer {
  position: relative;
  width: 100%;
  height: 50px;
}

.button-wrapper.button-wrapper-bridge {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: nowrap;
  border-top: 2px solid #2e61ff;
  border-bottom: 2px solid #2e61ff;
  text-align: center;
  overflow: hidden;
  margin-top: auto;
  margin-bottom: -2px;
}

.button-wrapper.button-wrapper-bridge.button-wrapper-soldout > span, .button-wrapper.button-wrapper-center.button-wrapper-soldout > span {
  padding-top: 30px;
  display: inline-block;
  vertical-align: top;
}

.button-wrapper.button-wrapper-bridge > span {
  flex: 1 1 100%;
  padding-top: 16px;
  height: 96px;
}

.button-wrapper.button-wrapper-bridge .bridge {
  flex: 0 0 200px;
  width: 200px;
  height: 96px;
  padding-top: 0 !important; 
}

.button-wrapper.button-wrapper-bridge .bridge:before {
  display: none !important;
}

.button-wrapper.button-wrapper-bridge .bridge svg {
  width: 202px;
  height: 98px;
  left: -2px;
  top: -1px; 
}




/*
 *	 section introduction & text
 *
 */  

.section-text .container , .section-introduction .container {
  z-index: 1;
}

.section-text .container {
  /*margin-top: -3.875em;*/
}








/*
 *	page program
 *
 */  

.section-program .container {
  overflow: hidden;
}

.section-program .performances-grid {
  width: 100%;
  width: calc(100% + 2px);
  margin-left: -2px;
}



.split .sidebar, .split .main {
  position: relative; 
  min-height: 1px;
}


.split .main {
  width: 100%;
  flex: 0 0 100%;
}


.split .main .days, .split .main .bridge {
  border-left: 2px solid #fff;
}

.split .block.has-bridge {
  overflow: hidden;
}

.split .block.has-bridge:last-child {
  margin-top: auto;
}

.split .main .days, .split .main .days ul {
  position: relative;
  width: 100%;
}

.split .main .days ul {
  display: flex;
  padding-top: 4px;
  padding-bottom: 4px;
  justify-content: flex-start;
  align-items: stretch;
  font-size: 3.75rem;
  line-height: 1.25;
  text-transform:  lowercase;
}

.split .main .days ul li {
  display: block;
  width: calc(100% / 3);
  border-left: 2px solid #2e61ff;
  text-align: center;
}

.split .main .days ul li:first-child {
  border-left-color: #fff;
}

.split .main .days ul li a {
  position: relative;
  display: inline-block;
  padding-left: 1em; 
  padding-top: 0;
  vertical-align: middle;
}

.split .main .days ul li a:before {
  position: absolute;
  display: block;
  left: 0;
  top: 0.2875em;
  width: 0.667em;
  height: 0.667em;
  background-color: transparent;
  border-radius: 50%;
  border: 2px solid currentcolor;
  content: "";
  transition: background-color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.split .main .days ul li a:hover:before, .split .main .days ul li a.active:before {
  background-color: currentcolor;
}


/* performances - PROGRAM  */

.performances-grid {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  padding: 8px;
  background-color: var(--color-black);
}


.performances-grid .performances-grid-item {
  position: relative;
  display: flex;
  padding: 8px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  width: calc(100% / 3);
  color: var(--color-white);  
  background-color: var(--color-black);  
}
/*
.performances-grid.performances-grid-triple {
  border-top: 2px solid #1d1d1d;
  margin-bottom: -2px;
  z-index: 1;
}

.performances-grid.performances-grid-triple:before {
  display: none;
}

.performances-grid.performances-grid-triple li {
  width: calc(100% / 3);
  border-bottom: 2px solid #1d1d1d;
  border-top: 0;
}
*/

.performances-grid .image {
  position: relative;
  flex: 0 0 auto;
}

.performances-grid .image .img {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56%;
  background-color: var(--color-celeste);
}

.performances-grid .image .img .label {
  position: absolute;
  display: block;
  top: 0;
  right: 0;
  margin: 0;
  padding: 0.5em 0.5em 0.32em 0.5em;
  color: #fff;
  background-color: #1d1d1d;
  font-size: 1.875rem;
  line-height: 1;
  text-transform: uppercase;
  z-index: 2;
}

.performances-grid .image .img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: opacity .3s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.performances-grid .image a:hover .img img {
  opacity: 1;  
}


.performances-grid .image .label {
  position: absolute;
  top: 0;
  right: 0;
}

.performances-grid .link, .featured-performance .link {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: nowrap;
  height: 96px;
  font-size: 2.813em; /* 45px */
  line-height: 0.841;
  text-transform: uppercase;
}

.performances-grid .link > span {
  flex: 1 1 100%;
  padding-top: 16px;
  height: 96px;
  border-bottom: 2px solid #2e61ff;
}

.performances-grid .link .bridge {
  flex: 0 0 200px;
  width: 200px;
  height: 96px;
  padding-top: 0 !important; 
}

.performances-grid .link .bridge svg {
  width: 202px;
  height: 98px;
  left: -2px;
  top: -1px; 
}

.performances-grid .text {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;  
  padding-left: 25px;
  padding-right: 25px;
  flex: 1 1 auto;
}

.performances-grid .info {
  height: auto;
  min-height: 275px;
  width: 100%;
}

.performances-grid .button-wrapper {
  margin-top: auto;
  margin-bottom: 50px;
  padding-top: 40px;
}



.performances-grid .meta {
  position: relative;
  padding-top: 16px;
  font-size: 1.25rem;
  line-height: 1.1;
  width: 100%;
}

.performances-grid .meta:first-child {
  padding-top: 40px;
}

.performances-grid .meta:last-child {
  padding-bottom: 40px;
}

.performances-grid .meta h4 {
  display: inline-block;
  padding: 4px 5px;
  text-transform: uppercase;
  border: 2px solid currentcolor;
}

.performances-grid .meta .location, .performances-grid .meta .theme {
  position: relative;
  margin-top: 0;
}

.performances-grid .meta .theme {
  font-size: 0.938rem;
  font-weight: 400;
  line-height: 1.1;
}

.performances-grid .meta .theme a {
  display: inline-block;
  text-decoration: underline;
  vertical-align: top;
  margin-right: 8px; 
}

.performances-grid .meta .theme a:last-child {
  margin-right: 0px; 
}

.performances-grid .meta .location {
  padding-left: 20px;
}

.performances-grid .meta .location a:hover {
  text-decoration: underline;
}

.performances-grid .meta .location svg {
  position: absolute;
  display: block;
  left: 0;
  top: 0;
  width: 15px;
  height: 20px;
  padding: 0;
}

.performances-grid .shows {
  width: 100%;
  min-height: 215px;
}

.performances-grid .shows ul {
  display: table;
  width: 100%;
  padding: 11px 0 9px 0;
  border-top: 2px solid var(--color-white);
  border-bottom: 2px solid var(--color-white);
}

.performances-grid .shows li {
  display: table-row;
  
}

.performances-grid .shows li span {
  display: table-cell;
  width: auto;
  word-wrap: break-word;
  overflow-wrap: break-word;
  line-height: 1.1;
}


.performances-grid .title {
  padding-top: 30px;
  padding-bottom: 0; 
}

.performances-grid .title h2 {
  margin-left: -0.02em;
  font-size: 2.875rem;
  line-height: 0.895;
  text-transform: uppercase;
}

.performances-grid .title h3 {
  font-size: 2.188rem;
  line-height: 0.895;
  margin-top: 0.1em;
}

.performances-grid .description {
  position: relative;
  padding-bottom: 30px;
  margin-bottom: 50px;
  font-size: 1.563rem;
  line-height: 1.25;
}

.performances-grid .description p {
  display: block;
  /* Fallback for non-webkit */
  display: -webkit-box;
  margin: 0 auto;
  font-size: 1.250rem;
  line-height: 1.125;
  /*transition: all .3s cubic-bezier(0.2, 0.6, 0.3, 1);*/
}

.performances-grid .description.closed p {
  height: 68px;  /*  $font-size*$line-height*$lines-to-show;  */
  /* Fallback for non-webkit */
  margin: 0 auto;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.performances-grid .description.closed p:not(:first-child) {
  height: 0;
  -webkit-line-clamp: 0;
}

.performances-grid .description p:not(:last-of-type) {
  padding-bottom: 1em;
}

.performances-grid .description.closed p:not(:last-of-type) {
  padding-bottom: 0;
}

.button-read-more svg {
  display: block;
}



.performances-grid .button-wrapper-right .button {
  margin-right: -22px;
}

.performances-grid .description .button-read-more {
  position: absolute;
  bottom: 0px;
  left: 0;
  width: 30px;
  height: 17px;
  transform: rotate(180deg);
}

.performances-grid .description.closed .button-read-more {
  transform: rotate(0deg);
  bottom: 0px;
}


.featured-performance {
  display: flex;
  padding-top: 60px;
  padding-bottom: 40px;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: nowrap; 
  border-left: 2px solid #fff;
  margin-bottom: -1px; 
}

.featured-performance .text, .featured-performance .link {
  padding-left: 30px;
  padding-right: 30px;
  height: auto;
}

.featured-performance .link {
  display: inline-block;
  
}

.featured-performance .link a {
  white-space: nowrap;
}

.featured-performance .location {
  padding-top: 0px;
  font-size: 2.813em;
  line-height: 1.1;
}

.featured-performance .location p {
  position: relative;
  margin-top: 0;
  padding-left: 42px;
}

.featured-performance .location svg {
  width: 30px;
  height: 42px;
}

.featured-performance .title h2 {
  margin-top: 0.25em;
  font-size: 5.625rem;
  line-height: 1;
  text-transform: uppercase;
}

.featured-performance .title h4 {
  margin-top: 0.4em;
  font-size: 2.5rem;
  line-height: 1;
  text-transform: uppercase;
}

.featured-performance .title h3 {
  margin-top: 1.2em;
  font-size: 2.188rem;
  line-height: 1;
}


/*
 *	page theme
 *
 */ 
 
.split .main .title-page {
  position: relative;
  margin: 0;
  margin-top: 0.26em;
  padding-left: 20px;
  width: 100%;
  font-size: 8.75em;
  line-height: 0.895;
  text-transform: uppercase;
  z-index: 3;
}


/* fold/accordion */

.fold {
  position: relative;
  width: 100%;
  border-left: 2px solid #fff;
  margin-bottom: -2px;
  text-align: left;  
  z-index: 3;
}

.fold.fold-sub {
  border-left: 0;
}

.fold .fold-item {
  border-top: 2px solid #1d1d1d;
}

.fold .fold-item:last-child {
  border-bottom: 2px solid #1d1d1d;
}

.fold .fold-item .heading .button {
  position: relative;
  padding: 0.3em 40px;
  width: 100%;
  font-size: 3.75rem;
  line-height: 0.841;
  text-align: left;
  cursor: pointer; cursor: hand;
}

.fold .fold-item .heading .button span {
  flex: 0 0 70px;
  border-radius: 50%;
  height: 70px;
  width: 70px;
  color: #fff;
  border: 2px solid #1d1d1d;
  transform: rotate(0deg);
  transition: .3s ease-in-out;
}

.fold .fold-item .heading .button span:before, .fold .fold-item .heading .button span:after {
  position: absolute;
  display: block;
  background-color: #1d1d1d;
  content: "";
  z-index: 2;
}

.fold .fold-item .heading .button span:before {
  width: 2px;
  height: 38px;
  left: calc(50% - 1px);
  top: calc(50% - 19px);
}

.fold .fold-item .heading .button span:after {
  width: 38px;
  height: 2px;
  top: calc(50% - 1px);
  left: calc(50% - 19px);
}

.fold .fold-item > .heading .button:hover span, .fold .fold-item.active > .heading .button span { background-color: #1d1d1d; }
.fold .fold-item.active > .heading .button:hover span { background-color: #fff;  }
.fold .fold-item > .heading .button:hover span:before,
.fold .fold-item > .heading .button:hover span:after { background-color: #fff; }
.fold .fold-item.active > .heading .button span:before,
.fold .fold-item.active > .heading .button span:after { background-color: #fff; }
.fold .fold-item.active > .heading .button:hover span:before,
.fold .fold-item.active > .heading .button:hover span:after { background-color: #1d1d1d; }
.fold .fold-item.active > .heading .button span { background-color: #1d1d1d; -webkit-transform: rotate(-45deg); transform: rotate(-45deg); }

.fold .fold-item .heading h2 {
  padding-right: 40px;
  flex: 1 1 100%;
  font-size: 5rem;
  line-height: 0.841;
  padding-top: 0.1875em;
  text-transform: uppercase;
}

.fold .fold-item-child .heading .button span {
  flex: 0 0 50px;
  height: 50px;
  width: 50px;
  margin-right: 10px;
}

.fold .fold-item .heading .button span:before {
  height: 26px;
  top: calc(50% - 13px);
}

.fold .fold-item .heading .button span:after {
  width: 26px;
  left: calc(50% - 13px);
}

.fold .fold-item-child .heading h2 {
  font-size: 3.12rem;
  line-height: 0.841;
}

.fold .fold-item .article {
  display: none;
}

/*
.fold .fold-item .article {
  display: none;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s;
}
*/
/*
.fold .fold-item.active > .article {
  max-height: 10000px; 
  transition: max-height 0.8s;
}*/

.fold .fold-item-child.active, .fold .fold-item-child > .article {
  background-color: #c7e8e1;
  color: #1d1d1d;
}

.fold .fold-item-child.active > .heading .button span { background-color: #1d1d1d; border-color: #1d1d1d; }
.fold .fold-item-child.active > .heading .button:hover span { background-color: #c7e8e1;  }

.fold .fold-item-child.active > .heading .button span:before,
.fold .fold-item-child.active > .heading .button span:after { background-color: #c7e8e1; }

.fold .fold-item-child.active > .heading .button:hover span:before,
.fold .fold-item-child.active > .heading .button:hover span:after { background-color: #1d1d1d; }


/* single subitem - faq & info */

.fold .fold-item .article .content-blocks {
  padding: 50px 40px;
}

.fold .fold-item .article .content-blocks .content-blocks-text {
  font-size: 1.563rem;
  line-height: 1.25;  
}

.fold .fold-item .article .content-blocks .content-blocks-text h2, .fold .fold-item .article .content-columns .content-columns-description h2 {
  margin-top: 1.25em;
  font-size: 2em;
  line-height: 1.1;
  text-transform: uppercase;  
}

.fold .fold-item .article .content-blocks .content-blocks-text h3, .fold .fold-item .article .content-columns .content-columns-description h3 {
  margin-top: 1.25em;
  font-size: 1.4em;
  line-height: 1.1;
  text-transform: uppercase;  
}

.fold .fold-item .article .content-blocks .content-blocks-text p, .fold .fold-item .article .content-blocks .content-blocks-text ul, .fold .fold-item .article .content-blocks .content-blocks-text ol, .fold .fold-item .article .content-columns .content-columns-description p, .fold .fold-item .article .content-columns .content-columns-description ul, .fold .fold-item .article .content-columns .content-columns-description ol {
  margin-top: 0.5em;
}

.fold .fold-item .article .content-blocks .content-blocks-text h2:first-child, .fold .fold-item .article .content-blocks .content-blocks-text h3:first-child, .fold .fold-item .article .content-blocks .content-blocks-text p:first-child, .fold .fold-item .article .content-blocks .content-blocks-text ul:first-child, .fold .fold-item .article .content-blocks .content-blocks-text ol:first-child, .fold .fold-item .article .content-columns .content-columns-description p:first-child, .fold .fold-item .article .content-columns .content-columns-description ul:first-child, .fold .fold-item .article .content-columns .content-columns-description ol:first-child {
  margin-top: 0;
}

.fold .fold-item .article .content-blocks .content-blocks-text ul, .fold .fold-item .article .content-blocks .content-blocks-text ol, .fold .fold-item .article .content-columns .content-columns-description ul, .fold .fold-item .article .content-columns .content-columns-description ol {
  padding-left: 1.5em;
}

.fold .fold-item .article .content-blocks .content-blocks-text ul li , .fold .fold-item .article .content-blocks .content-blocks-text ol li, .fold .fold-item .article .content-columns .content-columns-description ul li, .fold .fold-item .article .content-columns .content-columns-description ol li {
  margin-top: 0.25em;
}

.fold .fold-item .article .content-blocks .content-blocks-text ul li:first-child , .fold .fold-item .article .content-blocks .content-blocks-text ol li:first-child, .fold .fold-item .article .content-columns .content-columns-description ul li:first-child, .fold .fold-item .article .content-columns .content-columns-description ol li:first-child {
  margin-top: 0;
}

.fold .fold-item .article .content-blocks .content-blocks-text ul, .fold .fold-item .article .content-columns .content-columns-description ul {
  list-style: outside disc;  
  
}

.fold .fold-item .article .content-blocks .content-blocks-text ol, .fold .fold-item .article .content-columns .content-columns-description ol {
  list-style: outside numeric;  
}


/* multiple subitems - theme */

.fold .fold-item .content-columns {
  position: relative;
  padding: 20px 40px 50px 40px;
  overflow: hidden;
  width: 100%;
}

.fold .fold-item .content-columns > div {
  width: 50%;
  min-height: 1px;
}

.fold .fold-item .content-columns > div:first-child {
  padding-right: 20px;
  flex: 1 1 50%;
  max-width: 1120px;
}

.fold .fold-item .content-columns > div:nth-child(2) {
  padding-left: 60px;
  padding-right: 110px;
}

.fold .fold-item .content-columns {
  font-size: 1.563rem;
  line-height: 1.25; 
}


.fold .fold-item .content-columns p {
  margin-top: 0.5em;
}

.fold .fold-item .content-columns p:first-child {
  margin-top: 0;
}


.fold .fold-item .content-columns .button.button-arrow {
  margin-top: 50px;
  padding-left: 75px;
  padding-right: 20px;
  min-height: 40px;
  padding-top: 0.35em;
  font-size: 1.2em;
  line-height: 0.841;
}

.fold .fold-item .content-columns .button.button-arrow span {
  width: 55px;
  height: 40px;
}

.fold .fold-item .content-columns .button.button-arrow:hover {
  padding-right: 0;
  padding-left: 95px;
}

.fold .fold-item .content-columns .button.button-arrow span svg {
  height: 40px;
  width: 78px;
}

.fold .fold-item .content-columns .button.button-arrow:hover span {
  width: 75px;
}




/*
 *	page legal - section introduction & text
 *
 */  
 
.page-legal .section-text .content, .page-legal .section-introduction .content,  .page-press .section-text .content, .page-press .section-introduction .content {
  width: 100%;
  max-width: 1110px;
}



/*
 *	page sponsors - section sponsors
 *
 */  

.section-sponsors .container {
  text-align: center; 
  max-width: 1440px;  
}

.section-sponsors .logos {
  margin-top: 0;
  margin-left: -25px;
  margin-right: auto;
  margin-bottom: -25px;
  width: calc(100% + 50px);
  display: flex;
  justify-content: center;
  align-items: center;  
  flex-wrap: wrap;
}

.section-sponsors .logos li {
  position: relative;
  padding: 25px;
  z-index: 2;
}

.section-sponsors .logos li span {
  position: relative;
  display: block;
  height: 120px;
  padding: 0 !important;
}

.section-sponsors .logos li a {
  display: block;
  width: auto;
  height: 100%;
}

.section-sponsors .logos li img {
  display: block;
  width: auto;
  height: 100%;
}

.section-sponsors .logos li a img {  
  -webkit-filter: grayscale(0%);
  -moz-filter: grayscale(0%);
  filter: grayscale(0%);
  transition: all .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.section-sponsors .logos li a:hover img {  
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  filter: grayscale(100%);
}



/*
 *  downloads 
 *
 */
 
.section-downloads .list {
  margin-left: -50px;
  margin-right: auto;
  width: calc(100% + 100px);
}

.section-downloads .list li {
  position: relative;
  display: flex;
  width: 100%;
  margin-top: 2px;
  padding: 35px 20px 35px 50px;
  min-height: 130px;
  justify-content: space-between;
  align-items: flex-start;  
  flex-wrap: nowrap;
  font-size: 3.125rem; /* 50px */
  line-height: 0.841;
  text-transform: uppercase;
  color: #1d1d1d;
  background-color: #c7e8e1;
  z-index: 2;
}

.section-downloads .list li p {
  margin: 0;
  padding-top: 0.24em;
}

.section-downloads .list li a, .arrow-button-small {
  position: relative;
  display: block;
  margin-left: 35px;
  padding-left: 106px;
  padding-right: 30px;
  min-height: 60px;
  padding-top: 0.285em;
  transition: padding .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.section-downloads .list li a { white-space: nowrap; }

.section-downloads .list li a:hover, .arrow-button-small:hover { padding-left: 136px; padding-right: 0; }

.section-downloads .list li a span, .arrow-button-small span {
  position: absolute; 
  display: block;
  top: 0;
  left: 0;
  width: 86px;
  height: 60px;
  overflow: hidden;
  transition: width .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}
.section-downloads .list li a:hover span, .arrow-button-small:hover span { width: 116px; }

.section-downloads .list li a span svg, .arrow-button-small span svg {
  position: absolute;
  right: 0;
  top: 0;
  height: 60px;
  width: 116px;
}

.section-downloads .buttons {
  position: relative;
  width: 100%;
}

.section-downloads .buttons li {
  position: relative;
  display: block;
  margin-top: 50px;
  font-size: 4.063rem; /* 65px */
  line-height: 0.841;
  text-transform: uppercase;
}

.section-downloads .buttons li:first-child {
  margin-top: 0px;
}

.section-downloads .buttons li a {
  position: relative;
  display: block;
  padding-left: 140px;
  padding-right: 40px;
  min-height: 80px;
  padding-top: 0.285em;
  transition: padding .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}
.section-downloads .buttons li a:hover { padding-left: 180px; padding-right: 0; }

.section-downloads .buttons li a span {
  position: absolute; 
  display: block;
  top: 0;
  left: 0;
  width: 120px;
  height: 80px;
  overflow: hidden;
  transition: width .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}
.section-downloads .buttons li a:hover span { width: 160px; }

.section-downloads .buttons li a span svg {
  position: absolute;
  right: 0;
  top: 0;
  height: 80px;
  width: 160px;
}

/*
 *  accordions 
 *
 */

.accordion .text-two-columns {
  font-size: 1.5rem; /* 24px */
  line-height: 1.25;
  margin-bottom: -0.4em;
}

.accordion .text-two-columns h3, .section-faq .accordion h3 {
  margin-top: 2.875em;
  font-size: 1.333em; /* 32px */
  line-height: 1;
  text-transform: uppercase;  
}

.accordion .text-two-columns ul {
  margin-top: 1.25em;
}

 .accordion .text-two-columns p:first-child, .accordion .text-two-columns ul:first-child {
  margin-top: -0.175em !important;
}

.accordion .text-two-columns ul {
  padding-left: 1.125em;
}

 .accordion .text-two-columns ul li {
  position: relative;
  margin-top: 0.5em;
}

.accordion .text-two-columns ul li:before {
  position: absolute;
  top: 0;
  left: 0;
  margin-left: -0.975em;
  content: "-";  
}

.accordion .main .container {
  overflow: hidden;  
}

.accordion .text-two-columns.text-two-columns {
  padding-top: 60px;
  padding-bottom: 60px;
}

.accordion .text-two-columns.text-two-columns {
  padding-top: 60px;
  padding-bottom: 60px;
}



/*
 *	 header 
 *
 */

#header {
	position: fixed;
  top: 0;
  left: 0;
  height: 100px;
	background-color: #e9e9f2;  
  border-bottom: 2px solid #1d1d1d;
  z-index: 100;	
}

#header:before {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #fff;
  z-index: 40;
  content: "";
}

#header a:hover { color: #ff5a32; }

#header .container {
	height: 100%;
	width: 100%;
}

#header .logo {
  position: relative;
  flex: 0 0 auto;
  margin-right: auto;
  z-index: 50;
}

#header .logo span, #header .date {
  display: block;
  margin-left: 0.255em;
  padding-top: 0.19em;
  font-size: 2.75rem; /* 44px */
  line-height: 1;
  opacity: 0; 
  pointer-events: none;
  transition: opacity 0.5s cubic-bezier(0.2, 0.6, 0.3, 1);
}

#header .logo span em {
  display: none;
}

#header .date {
  position: relative; 
  margin-top: 0;
  margin-left: 0;
  font-size: 2rem;
  line-height: 1;
  margin-right: 0.45em;
  text-transform: uppercase;
  z-index: 50;
}

.show-logo #header .logo span, .show-logo #header .date {
  opacity: 1; 
  pointer-events: auto;
}

.nav-active.show-logo #header .logo span, .nav-active.show-logo #header .date {
  opacity: 0 !important; 
  pointer-events: none !important;
}

#header .logo svg {
  width: 100px;
  height: 52px;
  fill: currentColor;
}



#header .languages {
  position: absolute;
  right: 107px;
  top: 23px;
  margin: 0;
  flex: 0 0 auto;
  font-size: 2.75rem; /* 44px */
  line-height: 1;
  text-transform: uppercase;
  transition: opacity 0.5s cubic-bezier(0.2, 0.6, 0.3, 1);
  z-index: 50;
}

#header .languages li {
  display: block;
}

#header .languages li:not(:first-child) {
  margin-left: 0.255em;
}

#header .languages a {
  display: block;
  padding-top: 0.19em;
}

#header .languages {
  display: none !important;
}





#header nav { 
  position: fixed;
  top: 0;
  left: 0;
  padding-top: 100px;
  width: 100%;
  height: 100%;
  display: flex;
  flex: 1 0 auto;
  flex-direction: column;	
  z-index: 8;
  color: #1d1d1d;
  background-color: #c7e8e1;
  top: -100%;
  top: -100vh;
  transform: translateY(0%);
  transition: transform 0.2s linear;
}

#header nav a { color: #1d1d1d; }
#header nav a:hover { color: #ff5a32; }
  
#header nav:before {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #1d1d1d
  content: "";
  z-index: 1;
}

#header nav .row {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 1820px;
  z-index: 2;
}

#header nav .menu {
  font-size: 5rem;
  line-height: 1;
  text-transform: uppercase;
}

#header nav .menu li a {
  display: inline-block;
  margin-top: 0.2em;
  margin-left: -0.052em;
}

#trigger-nav {
	position: relative;
	color: transparent;
	text-decoration: none;
	text-align: center;
	text-transform: uppercase;
	height: 30px; 
	padding: 0; 
	width: 44px;	
	z-index: 100;
}

#trigger-nav > span {
	position: relative;
	display: block;
	margin: 0 auto;
	width: 100%;
	height: 100%;
}

#trigger-nav > span > span {
  display: block;
  position: absolute;
  left: 0;
  height: 2px;
  width: 100%;
  background-color: #1d1d1d;
  -webkit-transform: rotate(0deg); 
  transform: rotate(0deg);
  transition: .15s ease-in-out;
}

#trigger-nav:hover > span > span { background-color: #ff5a32; }

#trigger-nav > span > span:nth-child(1) { top: 0px; }
#trigger-nav > span > span:nth-child(2), #trigger-nav > span > span:nth-child(3) { top: 14px; }
#trigger-nav > span > span:nth-child(4) { top: 28px; }


/* active menu */



.nav-active #trigger-nav > span > span:nth-child(1) { top: 6px; width: 0%; left: 50%; }
.nav-active #trigger-nav > span > span:nth-child(2) { transform: rotate(45deg); }
.nav-active #trigger-nav > span > span:nth-child(3) { transform: rotate(-45deg); }
.nav-active #trigger-nav > span > span:nth-child(4) { top: 6px; width: 0%; left: 50%; }


#header .languages, .nav-active.show-logo #header .languages { opacity: 1; pointer-events: auto; z-index: 60; }
.show-logo #header .languages { opacity: 0; pointer-events: none; z-index: -1; }

.nav-active #header nav { transform: translateY(100%); transition: transform 0.5s cubic-bezier(0.2, 0.6, 0.3, 1); }	


/*
 *	 footer 
 *
 */

footer {
  position: relative;
  z-index: 2;
}

footer a {
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

footer a:hover {
  color: #ff5a32;
}

footer .footer {
  padding-top: 70px;
  padding-bottom: 60px;
  border-top: 2px solid #1d1d1d;
}

footer .footer-col-links {
  padding-right: 40px;
}

footer .footer-col-links li a {
  display: inline-block;
  margin-top: 0.2em;
  font-size: 2.5rem; /* 40px */
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

footer .footer-col-links li:first-child a {
  margin-top: 0.01em;
}

footer .footer-col-links .partner {
  display: block;
  width: 150px;
  height: 102px;
  margin-top: 3em;
}

footer .footer-col-links .partner a {
  display: block;
}

footer .footer-col-links .partner a svg {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  fill: currentColor;
}



footer .footer-col-contact p {
  margin-top: 0.95em;
  font-size: 1.5rem;
  line-height: 1.1;
}

footer .footer-col-contact p:first-child {
  margin-top: 0;
}

footer .footer-col-contact p:first-child a {
  display: inline-block;
}




footer .partners {
  border-top: 2px solid #1d1d1d;
}

footer .partners .container {
  padding-top: 20px;
  padding-bottom: 20px; 
}

footer .partners ul {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 1240px;
  display: flex;
  justify-content: center;
  align-items: center;
}

footer .partners li {
  padding: 20px;
  flex: 1;
  height: auto;
}


footer .partners a {
  display: block;
  
}

footer .partners a svg {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  fill: currentColor;
}



footer .legal {
  text-align: center;
  font-size: 1.25em;
  line-height: 1.1;
  border-top: 2px solid #1d1d1d;
} 

footer .legal p {
  margin-top: 2em;
  margin-bottom: 2em; 
}

footer .legal p em {
  font-style: normal;
}


/*
 *	 hero
 *
 */
@media only screen and (min-width: 1440px) {

.section-program-intro .split .sidebar .block {
  padding-left: 60px;
  padding-right: 0px;
}

}

.section-hero .title-page {
  position: relative;
  margin: 0;
  width: 100%;
  font-size: 8.75em;
  line-height: 0.895;
  text-transform: uppercase;
  z-index: 3;
}

.section-hero .bridge .title-page {
  position: absolute;
  left: 0;
  bottom: 0;
  text-align: center;
}

.section-hero .bridge {
  z-index: -1;
}

/* align hero title's vertically */

/* default - windows: all, mac: firefox */
.section-hero .title-page {  margin-top: 0.355em; margin-bottom: 0.189em; /* 50px vertical before & after */ }
.section-hero.section-hero-title .title-page { margin-top: 0; margin-bottom: -0.19em; } /* 50px vertical before */
.section-hero.section-hero-legal .title-page { margin-top: 0.5em; margin-bottom: -0.19em; } /* 70px vertical before */

.section-hero.section-hero-title {
  padding-top: 30px;
  padding-bottom: 30px;
}


/* mac: chromium + safari - ios */
/*
@supports (not (-moz-appearance: none)) {
  
  .os-mac .section-hero .title-page, .os-ios .section-hero .title-page {  margin-top: 0.175em; margin-bottom: 0.145em; }
  .os-mac .section-hero.section-hero-title .title-page, .os-ios .section-hero.section-hero-title .title-page { margin-top: 0.177em; margin-bottom: -0.115em; }
  .os-mac .section-hero .bridge .title-page, .os-ios .section-hero .bridge .title-page { margin-top: 0; margin-bottom: -0.115em; }
  
  .os-mac header .logo span, .os-mac header .languages a { padding-top: .068em; }
  .os-mac .button-pill, .os-mac .cookienotice .button, .os-mac .gform_button, .os-mac .gform_save_link.button, .os-mac #gform_send_resume_link_button_1 { padding-top: 0.4em; padding-bottom: 0.35em; }
  
  .os-ios .section-hero .title-page {  margin-top: 0.175em; margin-bottom: 0.145em; }
  .os-ios .section-hero.section-hero-title .title-page { margin-top: 0.177em; margin-bottom: -0.115em; }
  .os-ios .section-hero .bridge .title-page { margin-top: 0; margin-bottom: -0.115em; }
  
}
*/

.section-hero.section-hero-home .container {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  flex-wrap: no-wrap;
  padding: 0;
}

.section-hero.section-hero-home.section-hero-home-single .container {
  justify-content: center;
}

.section-hero.section-hero-home .main {
  width: 100%;
}

.section-hero.section-hero-home.section-hero-home-single .bridge svg {
  color: #c7e8e1;
}

.section-hero.section-hero-home.section-hero-home-single .main {
  margin-top: 0 !important;
}

.section-hero.section-hero-home .side {
  position: absolute;
  top: 36px;
  right: 50px;
  width: 220px;
  text-align: right; 
  z-index: 1;
}

.section-hero .bridge .title-page { 
  margin-top: 0;
  margin-bottom: 0; 
  font-size: 13rem;
  line-height: 0.895;
}
  
.section-hero.section-hero-home .meta {
  margin: 0.2em -0.05em 0 0;
  font-size: 3.75rem;
  line-height: 0.895;
  text-transform: uppercase;
}


/*
 *	 section box
 *
 */
 
.section-box-pages ul {
  font-size: 3.75rem;
  line-height: 1.1;
  /*margin: -0.325em 0 -0.3em 0;*/
}

.section-box-pages a {
  position: relative;
  display: inline-block;
  text-transform: uppercase;
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
  z-index: 2;
}

.section-box-pages a:hover { color: #fff; }

.section-box-pages a span {
  position: relative;
  display: inline-block;
  width: 52px;
  height: 42px;
  margin-right: 16px;
  overflow: hidden;
  transition: width .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.section-box-pages a:hover span {
  width: 75px;
}

.section-box-pages a span svg {
  position: absolute;
  display: block;
  right: 0;
  top: 0;
  width: 75px;
  height: 42px; 
}


/*
 *	 section faq
 *
 */

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

.section-faq .accordion-title {
  font-size: 2.25rem;
  line-height: 0.841;
  margin-bottom: 0.5em;
  text-transform: uppercase;
}

.section-faq .accordion {
  position: relative;
  width: 100%;
  border-bottom: 2px solid #2e61ff;
}

.section-faq .accordion-item {
  border-top: 2px solid #2e61ff;
}


.section-faq .accordion-item .content-columns {
  position: relative;
  padding-top: 50px;
  padding-bottom: 50px;
  overflow: hidden;
  width: 100%;
}

.section-faq .accordion-item .content-columns > div {
  width: calc(50% - 26px);
  min-height: 1px;
}

.section-faq .accordion-item .content-columns > div:nth-child(even) { max-width: 880px; }

.section-faq .accordion-item .heading .button {
  padding: 0.385em 0;
  width: 100%;
  font-size: 3.75rem;
  line-height: 0.841;
  text-align: left;
  cursor: pointer; cursor: hand;
}

.section-faq .accordion-item .heading .button:before {
  position: absolute;
  display: block;
  left: -50vw;
  top: auto;
  width: 200vw;
  height: 100%;
  background-color: #fff;
  content: "";
  z-index: -1;
}

.section-faq .accordion-item .heading .button span {
  flex: 0 0 0.7em;
  border-radius: 50%;
  height: 0.7em;
  width: 0.7em;
  color: #fff;
  background-color: #2e61ff;
  -webkit-transform: rotate(0deg); 
  transform: rotate(0deg);
  transition: .3s ease-in-out;
}

.section-faq .accordion-item .heading .button span:before, .section-faq .accordion-item .heading .button span:after {
  position: absolute;
  display: block;
  background-color: #fff;
  content: "";
  z-index: 2;
}

.section-faq .accordion-item .heading .button span:before {
  width: 3px;
  height: 64%;
  left: calc(50% - 1.5px);
  top: calc(50% - 32%);
}

.section-faq .accordion-item .heading .button span:after {
  width: 64%;
  height: 3px;
  top: calc(50% - 1.5px);
  left: calc(50% - 32%);
}

.section-faq .accordion-item .heading .button:hover, .section-faq .accordion-item.active .heading .button { color: #fff; }
.section-faq .accordion-item .heading .button:hover:before, .section-faq .accordion-item.active .heading .button:before { background-color: #2e61ff; }
.section-faq .accordion-item .heading .button:hover span, .section-faq .accordion-item.active .heading .button:hover span { background-color: #fff; }
.section-faq .accordion-item .heading .button:hover span:before, .section-faq .accordion-item .heading .button:hover span:after, .section-faq .accordion-item.active .heading .button span:before, .section-faq .accordion-item.active .heading .button span:after { background-color: #2e61ff; }

.section-faq .accordion-item.active .heading .button span { background-color: #fff; -webkit-transform: rotate(-45deg); transform: rotate(-45deg); }


.section-faq .accordion-item .heading h2 {
  padding-right: 0.5em;
  flex: 1 1 100%;
  font-size: 1em;
  line-height: 0.841;
  padding-top: 0.1875em;
  text-transform: uppercase;
}

.section-faq .accordion-item .main {
  color: #fff;
  background-color: #2e61ff;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s;
}

.section-faq .accordion-item.active .main {
  max-height: 2000px; 
  transition: max-height 0.8s;
}

.section-faq .accordion p, .section-faq .accordion ul {
  margin-top: 1.25em;
}



/*
 *	 form styles
 *
 */

.section-register .container.border-top {
  border-top: 2px solid #1d1d1d;
  z-index: 2;
} 

.gform_wrapper, form, gform_body { position: relative; width: 100%; }

.form-register-wrapper {
  margin: 0 auto;
  max-width: 1200px;
}

fieldset.gfield {
  margin: 0;
}

.gform_required_legend { display: none; }

.gform_fields {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.gform_fields:before, .gform_fields:after { content: " "; display: table; }
.gform_fields:after { clear: both; }

.gfield_description.validation_message, .partial_entry_warning { display: none; }

.gfield, fieldset.gfield { 
  position: relative;
  width: 100%;
  margin-bottom: 44px;
}

.gfield.gform_hidden, .gform_required_legend { display:none !important; }

.gfield.gsection:not(:first-child) {
  margin-top: 20px;
}

.gfield.gsection h3 {
  font-size: 2rem;
  line-height: 1.1;
}

fieldset.gfield {
  border: 0;
  padding: 0;
  min-width: 0;
}
.gfield.gf_field_half {
  width: calc(50% - 26px);
}

#gform_wrapper_1 .gfield.gf_field_half:nth-child(odd) {
  margin-left: 50px;
}

#gform_wrapper_3 .gfield.gf_field_half:nth-child(even) {
  margin-left: 50px;
}

#gform_wrapper_3 {
  padding-top: 46px;
}

.gfield_visibility_hidden, .gf_label_hidden > label {
  display: none !important;
}

.gf_hidden_gield {
  display: none !important;
}

.ginput_container {
  display: block;
  width: 100%;
  margin-left: auto;  
  margin-right: auto;
}

.ginput_container.ginput_container_textarea {
  width: 100%;
  height: auto; 
  min-height: 10px;
}

.gform_confirmation_wrapper  { margin-bottom: 50px;}

.gfield_label {
  position: relative;
  display: block;
  margin-bottom: 0.45em;
  color: #1d1d1d;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.3;
}

.gf_hide_label > .gfield_label { display: none; } 

.gfield input, .gfield textarea {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  padding: 0.358em 0;
  width: 100%; 
  color: #1d1d1d;
  background: transparent; 
  font-family: "Ambit W01", 'Helvetica Neue',Helvetica,Arial,sans-serif;
  font-size: 1.875rem;
  font-weight: 400;
  line-height: 1.2;
  border: 0;
  border-bottom: #1d1d1d solid 2px;	
  outline: none;
  -webkit-appearance: none;	  
  border-radius: 0; 
}

.gfield input:focus, .gfield textarea:focus {
  border-bottom: #c6e7e0 solid 2px;	
}

.gfield.gfield_error input, .gfield.gfield_error textarea, .gfield.gfield_error input:focus, .gfield.gfield_error textarea:focus {
  border-color: #dc3c3c;	
}

.gfield.gfield_error .gform_drop_area {
  border-color: #dc3c3c;
}

.validation_error,.gform_validation_errors { display: none; }

.gfield textarea {
  resize: vertical;
  width: 100%;
  height: 210px;
}	 

.gfield .screen-reader-text { display: none; }	 

input::-webkit-contacts-auto-fill-button {
  visibility: hidden;
  display: none !important;
  pointer-events: none;
  position: absolute;
  right: 0;
}

.gfield input::-webkit-input-placeholder, .gfield textarea::-webkit-input-placeholder {	font-size: 30px; color: #1d1d1d; font-style: normal; opacity: 0.5; font-weight: 400; }
.gfield input:-moz-placeholder, .gfield textarea:-moz-placeholder { font-size: 30px; color: #1d1d1d; font-style: normal; opacity: 0.5; font-weight: 400; }
.gfield input::-moz-placeholder, .gfield textarea::-moz-placeholder { font-size: 30px; color: #1d1d1d; font-style: normal; opacity: 0.5; font-weight: 400; }
.gfield input:-ms-input-placeholder, .gfield textarea:-ms-input-placeholder { font-size: 30px; color: #1d1d1d; font-style: normal; opacity: 0.5; font-weight: 400; }

.gfield textarea::-webkit-input-placeholder { line-height: 36px; }
.gfield textarea:-moz-placeholder { line-height: 36px; }
.gfield textarea::-moz-placeholder { line-height: 36px; }
.gfield textarea:-ms-input-placeholder { line-height: 36px; }

.gfield.ginput_container_textfield {
    padding-top: 33px;
}

.ginput_container {
  position: relative;
} 

.gfield_description {
  margin-top: -0.5em;
}


.ginput_container_fileupload {
  color: #1d1d1d;
}


/* save link message */

.form_saved_message {
  color: #1d1d1d;  
}

#gform_resume_email {
  margin-left: 0;
  width: calc(50% - 26px);
}

#gform_send_resume_link_button_1 {
  margin-left: 0 !important;
}


/* multi file upload */
.button.gform_button_select_files {
  color: #1d1d1d;
  text-decoration: underline;
}

.button.gform_button_select_files:hover {
  color: #ff5a32;
}

.ginput_preview {
  color: #1d1d1d;
}

.gform_footer {
  position: relative;
  margin-top: 16px;
  width: 100%;
  padding: 0;
  height: 60px;
}

.gform_ajax_spinner {
  position: absolute;
  width: 60px;
  height: 60px;
  margin-top: 0;
  left: 0;
  top: 0;
  z-index: 5;
}

.form_saved_message_emailform {
  position: relative;
}

.form_saved_message_emailform .gform_ajax_spinner {
  top: auto;
  bottom: 0;
}

.gform_button, .gform_save_link.button, #gform_send_resume_link_button_1 {
  display: inline-block;
  text-decoration: none;
  cursor: hand; cursor: pointer;
  border-radius: 0;
  border: 0;
  margin: 0 auto;
  height: 60px; 
  padding: 0.5em;
  color: #1d1d1d;
  border: 2px solid #1d1d1d;
  background-color: transparent;
  font-family: "Ambit W01", 'Helvetica Neue',Helvetica,Arial,sans-serif;
  font-size: 1.875rem;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  transition: background-color .3s cubic-bezier(0.2, 0.6, 0.3, 1) color .3s cubic-bezier(0.2, 0.6, 0.3, 1);
  vertical-align: top;
}

.gform_save_link.button {
  float: left;
  margin-right: 30px;
}

.gform_save_link.button svg {
  display: none;
}

.gform_button:hover, .gform_next_button:hover, .gform_previous_button:hover, #gform_send_resume_link_button_1, .gform_save_link.button:hover {
  background-color: #1d1d1d;
  color: #fff;
}

.gform_footer.disabled .gform_button, .gform_footer.disabled .gform_save_link, .gform_fields.disabled #gform_send_resume_link_button {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}

#gform_1 .disabled #gform_send_resume_link_button_1 { 
  opacity: 0;
  pointer-events: none;
  visibility: hidden; 
}

.form_saved_message_emailform .gfield_label { display: none; }

.form_saved_message_emailform .gform_validation_message {
  color: #dc3c3c;
}

.form_saved_message_emailform { 
  position: relative;
}

.gf_custom_checkbox .gfield_label { display: none; }

fieldset.gfield.gf_custom_checkbox_newsletter {
  margin-top: 20px;
  margin-bottom: 15px;
}

.gf_custom_checkbox { 
  position: relative;
}
  
.gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"] {  
  height: 0;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  visibility: hidden;
  width: 0;
}

.gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"] + label {  
  position: relative;
  display: inline-block;
  color: #1d1d1d;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.3;
  vertical-align: top; 
  padding: 0; 
  margin: 0; 
  padding-left: 1.75em;
}

.gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"] + label a { text-decoration: underline; } 

.gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"] + label a:hover {
  color: #ff5a32;
}

.gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"] + label:before {    
  position: absolute;
  display: block;
  top: -2px;
  left: 0;
  border: #1d1d1d solid 2px;
  width: 30px;
  height: 30px;
  content: ' ';
  cursor: pointer;
  cursor: hand;
  border-radius: 0;
  vertical-align: top;
}

.gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"]:checked + label:before {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNOTMuOCAxLjVjLTMuNS0yLjEtNy42LS43LTkuNyAyLjhMMzkuNiA4MS40bC0yNS0yMi45Yy0yLjgtMi44LTctMi44LTkuNyAwcy0yLjggNyAwIDkuN2wzMiAyOS4yYzIuOCAyLjggNyAyLjggOS43IDAgLjctLjcgNTAuMS04Ni4yIDUwLjEtODYuMiAxLjMtMy41LjYtNy42LTIuOS05LjciIGZpbGw9IiMxZDFkMWQiLz48L3N2Zz4=");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 18px 18px;
}

.gfield.gf_custom_checkbox.gfield_error .gfield_checkbox .gchoice input[type="checkbox"] + label:before {  border-color: #dc3c3c; }



.gfield.gf_custom_radiobuttons { 
  position: relative;
}
  
 
.gfield.gf_custom_radiobuttons .gfield_radio .gchoice input[type="radio"] {  
  height: 0;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  visibility: hidden;
  width: 0;
}

.gfield.gf_custom_radiobuttons  .gfield_radio .gchoice {
  position:relative;
  display: block;
  width: 100%;
}

.gfield.gf_custom_radiobuttons .gfield_radio .gchoice {
  margin-top: 0.875em;
}

.gfield.gf_custom_radiobuttons .gfield_radio .gchoice:first-child {
  margin-top: 0;
}

.gfield.gf_custom_radiobuttons.gf_custom_radiobuttons_contact .gfield_required {
  display: inline;
}

.gfield.gf_custom_radiobuttons .gfield_radio label {
  vertical-align: top;
  margin-bottom: 0.45em;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.3;
  padding-left: 40px;
}

.gfield.gf_custom_radiobuttons.gf_custom_radiobuttons_contact .gfield_radio label {
  display: block;
  width: 100%;  
  line-height: 1.1;
  padding-top: 3px;
}

.gfield.gf_custom_radiobuttons .gfield_radio label:before {
  display: block;
  content: "";
  position: absolute;  
  top: -2px;
  left: 0;
  border: #fff solid 2px;
  width: 30px;
  height: 30px;
  cursor: pointer;
  cursor: hand;
  border-radius: 50%;
  vertical-align: top;  
}

.gfield.gf_custom_radiobuttons.gfield_error .gfield_radio label:before {
  border-color: #dc3c3c;	
}

.gfield.gf_custom_radiobuttons .gfield_radio label:after {
  display: none;
  content: "";
  width: 20px;
  height: 20px;
  background: #fff;
  position: absolute;
  left: 5px;
  top: 3px;
  border-radius: 50%;
}

.gfield.gf_custom_radiobuttons .gfield_radio input[type="radio"]:checked + label:after {
  display: block;
}


.gform_confirmation_message, .form_saved_message, .form_saved_message_sent {
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.3;
}

.charleft.ginput_counter {
  margin-top: 0.25em;
  font-size: 1.125rem;
}

.gf_upload_field {
  width: calc(50% - 25px);
}

.gf_upload_field:nth-child(even) {
  margin-left: 50px;
}

.gform_drop_area {
  position: relative;
  display: block;
  padding: 1.358em 1em;
  width: 100%; 
  color: #1d1d1d;
  background: transparent; 
  font-family: "Ambit W01", 'Helvetica Neue',Helvetica,Arial,sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.2;
  border: #1d1d1d dashed 2px;
  outline: none;
  -webkit-appearance: none;	  
  border-radius: 25px; 
}

.gform_fileupload_rules { display: none; }

.gf_upload_field .gfield_description {
  margin-bottom: 0.25em;
  font-size: 1.125rem;
  line-height: 1.1;
}

.gf_upload_field .validation_message { 
  margin-top: 0.5em;
  color: #1d1d1d;
  font-size: 1.125rem;
  line-height: 1.1;  
}

.form_saved_message a, .form_saved_message_sent a { text-decoration: underline; word-break: break-all; }

.ginput_preview {
  position: relative;
  margin-top: 1em;
  font-size: 1.125rem;
  line-height: 1.1;
  vertical-align: top;
}

.gform_delete_file {
  position: absolute;
  left: 0;
  top: -5px;
  color: #1d1d1d;
  height: 30px;
}

.gform_delete_file .dashicons.dashicons-trash { width: 30px; height: 30px; font-size: 26px; }

.gform_delete_file:hover {
  color: #1d1d1d;
}

.ginput_preview strong {
  display: inline-block;
  padding-left: 36px;
  word-wrap: break-word;
  width: 100%;
}

/*
.gform_drop_area .button.gform_button_select_files:after {
  display: block;
  width: 100%;
  text-align: center;
  content: "1 PDF - max. 25MB";
}*/


#gform_confirmation_wrapper_1, #gform_confirmation_wrapper_3, .form_saved_message_sent {
  padding-top: 46px;
  margin-bottom: 0;
}

.newsletter .gform_body.gform-body { position: relative; }
.newsletter .gform_fields { display: block; }
.newsletter h3 {
  font-size: 1.75rem;
  line-height: 1.1;
  margin-bottom: 0.5em;
  text-transform: uppercase;
}

.newsletter .gfield input::-webkit-input-placeholder {	font-size: 24px; color: #1d1d1d; font-style: normal; opacity: 0.5; font-weight: 400; }
.newsletter .gfield input:-moz-placeholder { font-size: 24px; color: #1d1d1d;font-style: normal; opacity: 0.5; font-weight: 400; }
.newsletter .gfield input::-moz-placeholder { font-size: 24px; color: #1d1d1d; font-style: normal; opacity: 0.5; font-weight: 400; }
.newsletter .gfield input:-ms-input-placeholder { font-size: 24px; color: #1d1d1d; font-style: normal; opacity: 0.5; font-weight: 400; }

.newsletter .gfield { margin-bottom: 0; }
.newsletter .gfield input { border: 2px solid #1d1d1d; color: #1d1d1d; height: 50px; border-radius: 0; font-size: 1.5rem; padding: 0.358em 58px 0.358em 0.5em; }
.newsletter .gfield.gfield_error input { border-color: #dc3c3c; }

.newsletter .gf_custom_checkbox_consent { margin: 14px 0 0 0; }
.newsletter .gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"] + label { color: #1d1d1d; font-size: 1rem; line-height: 1.1; padding-left: 1.55em; }
.newsletter .gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"] + label:before { border-color: #1d1d1d; width: 20px; height: 20px; border-radius: 0px; top: -3px; }
.newsletter .gfield.gf_custom_checkbox.gfield_error .gfield_checkbox .gchoice input[type="checkbox"] + label:before { border-color: #dc3c3c; }
.newsletter .gfield.gf_custom_checkbox .gfield_checkbox .gchoice input[type="checkbox"]:checked + label:before { background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNOTMuOCAxLjVjLTMuNS0yLjEtNy42LS43LTkuNyAyLjhMMzkuNiA4MS40bC0yNS0yMi45Yy0yLjgtMi44LTctMi44LTkuNyAwcy0yLjggNyAwIDkuN2wzMiAyOS4yYzIuOCAyLjggNyAyLjggOS43IDAgLjctLjcgNTAuMS04Ni4yIDUwLjEtODYuMiAxLjMtMy41LjYtNy42LTIuOS05LjciIGZpbGw9IiMxZDFkMWQiLz48L3N2Zz4=");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 12px 12px;
}

.newsletter .gform_confirmation_wrapper .gform_confirmation_message {
  font-size: 1.25em;
  line-height: 1.1;
}

.newsletter .gform_footer {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  width: auto;
  height: 50px;
  border-radius: 0 0 0 0;
  background: #1d1d1d;
}

.newsletter .gform_ajax_spinner {
  position: absolute;
  left: calc(50% - 15px);
  top: calc(50% - 15px);
  width: 30px;
  height: 30px;
  z-index: 5;
}

.newsletter .gform_button {
  width: 50px;
  height: 50px;
  border: 2px solid #1d1d1d;
  border-radius: 0;
  padding: 0 0 0 11px;
  font-size: 1.75rem;
  line-height: 1;
  background: #1d1d1d;
  color: #fff;
}

.newsletter .gform_button span {
  position:relative;
  display: block;
  width: 26px;
  height: 22px;
  overflow: hidden;
}

.newsletter .gform_button svg {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: 40px;
  height: 22px;
}

.newsletter .gform_button:hover {
  background: #fff;
  color: #1d1d1d;
}


 /* custom plyr styles */
 
.plyr {	font-family: "Ambit W01", 'Helvetica Neue',Helvetica,Arial,sans-serif; font-weight: 400; }
.plyr--video .plyr__controls { color: #fff; }
.plyr--audio .plyr__control.plyr__tab-focus,.plyr--audio .plyr__control:hover,.plyr--audio .plyr__control[aria-expanded=true]{ background: #c7e8e1 !important; }
.plyr__control--overlaid { background: #c7e8e1; color: #1d1d1d; padding: 20px; border: 3px solid #c7e8e1; }
.plyr__control--overlaid svg { height: 30px; width: 30px; left: 4px; }
.plyr__control--overlaid:focus,.plyr__control--overlaid:hover { background: transparent !important; color:#c7e8e1 !important; }
.plyr--video .plyr__controls .plyr__control.plyr__tab-focus,.plyr--video .plyr__controls .plyr__control:hover,.plyr--video .plyr__controls .plyr__control[aria-expanded=true]{ background: #c7e8e1; color: #1d1d1d; }
.plyr--audio .plyr__controls { color:#c7e8e1; }
.plyr__menu__container .plyr__control { color:#c7e8e1; }
.plyr--full-ui input[type="range"]::-moz-range-thumb { background: #fff; }
.plyr--full-ui input[type=range] { color: #c7e8e1; }
.plyr--video.plyr--stopped .plyr__controls { display: none;  } /* hide controls initally */
.plyr__poster { background-size: cover; }
.plyr__poster:before { position: absolute; width: 100%; height: 100%; background-color: #c7e8e1; opacity: 0; content: ""; }

.img-0 .plyr__poster:before { opacity: 0; }
.img-10 .plyr__poster:before { opacity: 0.1; }
.img-20 .plyr__poster:before { opacity: 0.2; }
.img-30 .plyr__poster:before { opacity: 0.3 }
.img-40 .plyr__poster:before { opacity: 0.4 }
.img-50 .plyr__poster:before { opacity: 0.5 }
.img-60 .plyr__poster:before { opacity: 0.6 }
.img-70 .plyr__poster:before { opacity: 0.7 }
.img-80 .plyr__poster:before { opacity: 0.8 }
.img-90 .plyr__poster:before { opacity: 0.9 }


.videobox {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  height: 0;
}

.videobox.videobox-vertical {
  padding-top: 177.77%;  
}


.videobox > div {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  overflow: hidden;  
}

.videobox video {
  width: 100%;
}  



/*
 *	 cookienotice
 *
 */
 
.cookienotice {
  position: fixed;
  display: none;
  left: 0;
  bottom: 0;
  width: 100%;
  background-color: #2e61ff;
  -webkit-box-shadow: 0 0 6px 0 rgba(0,0,0,0.1);
  box-shadow: 0 0 6px 0 rgba(0,0,0,0.1); 
  z-index: 80;
}

.loaded .cookienotice {
  display: block; 
}

.cookienotice .container {
  padding-top: 1.5em;
  padding-bottom: 2em;
  padding-left: 40px;
  padding-right: 40px;
  text-align: center;
}

.cookienotice p {
  margin: 0 auto 1.125em;
  width: 100%;
  max-width: 840px;
  color: #fff;
  font-size: 1.125em;
  font-weight: 400;
  line-height: 1.3;
}

.en .cookienotice p { max-width: 790px; }

.cookienotice p a {
  text-decoration: underline;
}

.cookienotice .button {
  display: inline-block;
  text-decoration: none;
  cursor: hand;
  cursor: pointer;
  -webkit-border-radius: 9999px;
  border-radius: 9999px;
  border: 0;
  margin: 0 8px;
  padding: 0.455em 0.8em 0.295em;
  height: 1.75em;
  color: #2e61ff;
  background-color: #fff;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  transition: background-color .3s cubic-bezier(0.2, 0.6, 0.3, 1);
  vertical-align: top; 
}

.cookienotice .button:hover {
  background-color: #fff;
}



/* prefooter - excerpt */

.section-excerpt {

}

.section-excerpt .container {
  background-color: var(--color-celeste);
}

.section-excerpt .content-columns {
  font-size: 1.563rem;
  line-height: 1.25; 
}

.section-excerpt .content-columns h2 {
  margin-top: 1.25em;
  margin-bottom: 0.75em;
  font-size: 2em;
  line-height: 1.1;
  text-transform: uppercase;  
}

.section-excerpt .content-columns h3 {
  margin-top: 1.25em;
  margin-bottom: 0.75em;
  font-size: 1.4em;
  line-height: 1.1;
  text-transform: uppercase;  
}

.section-excerpt .content-columns p {
  margin-top: 0.5em;
}

.section-excerpt .content-columns h2:first-child, .section-excerpt .content-columns h3:first-child, .section-excerpt .content-columns p:first-child {
  margin-top: 0;
}


.button.button-arrow.button-arrow-small {
  margin-top: 50px;
  padding-left: 75px;
  padding-right: 20px;
  min-height: 40px;
  padding-top: 0.35em;
  font-size: 1.2em;
  line-height: 0.841;
}
.button.button-arrow.button-arrow-small span { width: 55px; height: 40px; }
.button.button-arrow.button-arrow-small:hover { padding-right: 0; padding-left: 95px; }
.button.button-arrow.button-arrow-small span svg { height: 40px; width: 78px; }
.button.button-arrow.button-arrow-small:hover span { width: 75px; }


.section-excerpt .content-columns .content-columns-text {
  padding-top: 100px;
  padding-bottom: 50px;
  width: 50%;
}

.section-excerpt .content-columns .content-columns-bridge {
  color: var(--color-celeste);
  width: 50%;
  max-width: 640px;
  overflow: hidden;
}

.section-excerpt .content-columns .content-columns-bridge .bridge:before {
  position: absolute;
  display: block;
  top: 1px;
  left: 1px;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background-color: #fff;
  content: "";
}

.section-excerpt.section-excerpt-image .content-columns .content-columns-text {
  width: 44%;
}

.section-excerpt.section-excerpt-image.row .content-columns .content-columns-text {
  padding-right: 40px;
}

.section-excerpt.section-excerpt-image.row-reverse .content-columns .content-columns-text {
  padding-left: 40px;
}

.section-excerpt.section-excerpt-image.row-reverse .content-columns .content-columns-text { order: 2; }
.section-excerpt.section-excerpt-image.row-reverse .content-columns .content-columns-image { order: 1; }

.section-excerpt .content-columns .content-columns-image {
  width: 56%;
}

.section-excerpt .content-columns .content-columns-image .img {
  height: 100%;
  padding-top: 0 !important;
  object-fit: cover;
  object-position: center center;
}

.content-columns-image .img {
  background-color: #c7e8e1;
}

















/* tickets */

#tickets {
  position: fixed;
  display: none;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgb(225, 230, 255, 0.4);
  z-index: 9999999;
}

.tickets-active #tickets {
  display: flex;
}

#tickets .container {
  width: 100%;
  max-width: 460px;
  border: solid 2px #2e61ff; 
  background-color: #fff;
  padding: 0;
}

#tickets .content {
  padding: 115px 50px 50px 50px;
}

#tickets .close {
  position: absolute;
  display: block;
  right: 25px;
  top: 25px;
  width: 40px;
  height: 40px;
  transform: scale(1);
  transition: transform .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

#tickets .close:hover {
  transform: scale(1.3);
}

#tickets .close svg {
  display: block;
  width: 40px;
  height: 40px;
}


#tickets .button-wrap {
  positition: relative;
  width: 100%;
  padding: 15px 15px;
  color: #fff;
  background-color: #2e61ff;
  text-align: center;
}

#tickets .button-arrow {
  text-align: left;
}


/* carousel */

.section-carousel {
  
}

.section-carousel .container {
  overflow: hidden;
}

.section-carousel .carousel {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: nowrap;
}

.section-carousel .carousel:before {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 2px;
  height: 100%;
  background-color: #fff;
  content: "";
  z-index: 2;
}


.section-carousel .carousel-item {
  position: relative;
  display: flex;
  flex-direction: column;
  width: calc(100% / 3);
  flex: 0 0 calc(100% / 3);
}

.section-carousel .carousel-item a {
  display: block;
}

.section-carousel .carousel-item .image {
  position: relative;
  width: 100%;
  border-left: 2px solid #fff;
  flex: 0 0 auto;
}

.section-carousel .carousel-item .image .img {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 70%;
  background-color: #2e61ff;
}

.section-carousel .carousel-item .image .img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.section-carousel .carousel-item .meta {
  
}

.section-carousel .carousel-item .text {
  position: relative;
  width: 100%;
  border-left: 2px solid #2e61ff;
  padding: 30px 50px;
  flex: 1 1 100%;
}

.section-carousel .carousel-item .text:before {
  display: block;
  position: absolute;
  left: -2px;
  top: 100%;
  width: 2px;
  height: 100%;
  background-color: #2e61ff;
  content: "";
}

.section-carousel .carousel-item .text p {
  margin: 0;
}

.section-carousel .carousel-item .meta {
  font-size: 1.25rem;
  line-height: 1.1;
}

.section-carousel .carousel-item .title {
  padding-top: 30px;
  font-size: 2.188rem;
  line-height: 0.895;
}

.section-carousel .carousel-item .title strong {
  display: inline-block;
  padding: 0;
  vertical-align: top;
  margin-left: -0.02em;
  margin-bottom: 0.08em;
  font-size: 2.875rem;
  line-height: 0.895;
  text-transform: uppercase;
  font-weight: normal;
}

.section-carousel .slick-prev, .section-carousel .slick-next {
  position: absolute;
  display: block;
  width: 22px;
  height: 40px;
  top: 50%;
  margin-top: -20px;  
} 

.section-carousel .slick-prev { left: 14px; } 
.section-carousel .slick-next { right: 14px; }

.block-featured-items .slick-prev.slick-hidden, .block-featured-items .slick-next.slick-hidden { display: none; }

/* ==========================================================================
 Mapbox
 ========================================================================== */

.map {
  position: relative;
  margin-left: 2px;
  width: calc(100% - 2px);
  height: 100%;
  min-height: calc(80vh);
  z-index: 0;
  overflow: hidden;
  border-top: 2px solid #1d1d1d;
}

#mapbox {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#mapbox.active {
  display:block;
}

.mapboxgl-map {
  font-size: 16px !important; 
  line-height: 1.4 !important; 
  font-weight: 400 !important; 
  font-family: "Ambit W01", 'Helvetica Neue',Helvetica,Arial,sans-serif !important;
}

.mapbox-marker {
  width: 20px;
  height: 20px;
  background-color: var(--color-coral);
  color: var(--color-coral);
  border: 2px solid var(--color-black);
  border-radius: 50%;
  cursor: pointer;
  transition: background-color .25s cubic-bezier(0.2, 0.6, 0.3, 1);  
}

.mapbox-marker.mapbox-marker-active, .mapbox-marker:hover {
  z-index: 10;
  background-color: #fff; 
}
  
.mapboxgl-popup {
  max-width: 200px;
  z-index: 4;
  border-radius: 0;  
  
}

.mapboxgl-popup-content {
  text-align: center;
  font-size: 1.25rem;
  background-color: #fff !important;
  padding: 1em !important;
  border-radius: 0 !important;  
  border: solid 2px var(--color-black);
  text-align: left;
  width: 300px;
  overflow: hidden;
}

.mapboxgl-popup-content > h4 {
  text-align: center;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.1;
  margin: 0; 
}

.mapboxgl-popup-content > h4 svg {
  display: inline-block;
  width: 15px;
  height: 20px;
  padding: 0;
  vertical-align: top;
  margin-right: 4px;
  margin-top: -2px;
}

.mapboxgl-popup-content > p {
  margin: 2px auto 8px auto;
  text-align: center;
}

.mapboxgl-popup-content > p span {
  display: inline-block;
  margin: 2px;
  width: 24px;
  height: 24px;
  padding: 3px;
  border-radius: 50%;
  background-color: #fff;
  vertical-align: top;
}

.mapboxgl-popup-content > p svg {
  display: inline-block;
  width: 100%;
  height: 100%;
  padding: 0;
  vertical-align: top;
}

.mapboxgl-popup-content ul {
  margin-top: 0.25em;
}

.mapboxgl-popup-content li {
  margin-top: 0.75em;
  font-size: 0.875em;
  line-height: 1;
  width: 100%;  
  text-align: center;
}

.mapboxgl-popup-content li strong {
 text-transform: uppercase;
 font-size: 1.188em;
 line-height: 1.1;
}

.mapboxgl-popup-close-button {
  font-size: 2.5rem;
  line-height: 1;
  top: -5px !important;
  right: 2px !important;
  transform: scale(1);
  transition: transform .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.mapboxgl-popup-close-button:hover {
  background-color: transparent !important;
  transform: scale(1.2);
}

.mapboxgl-popup-tip {
  position: relative;
  border: 0;
  display: none;
}

.mapboxgl-popup-tip:before {
  position: absolute;
  left: -7px;
  top: -7px;
  display: block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid #1d1d1b;
  content: "";
}



/* ==========================================================================
 Timeline
 ========================================================================== */

.section-timeline {

}

.section-timeline .container {
 padding: 0 !important;
}

.section-timeline .container > .content { 
  position: relative;
  width: 100%;
  padding: 50px;
}

.section-timeline .container > .content h2 {
  font-size: 5rem;
  line-height: 0.841;
  text-transform: uppercase;
}

.section-timeline .container > .content p {
  margin-top: 0.5em;
}


#timeline, .jqTimepsaceContainer {
  position: relative;
  width: 100%;
}

#timeline {
  min-height: 440px;
  max-height: 60vh;
}

.jqTimepsaceContainer {
  --text-primary: var(--color-black);
  --border-dull: var(--color-black);
  --border-secondary: var(--color-black);
}

.jqTimepsaceContainer, .jqTimepsaceContainer .jqTimespaceDataContainer {
  color: var(--color-black);
}

.jqTimepsaceContainer .jqTimespaceDataContainer {
  margin: 0 auto;
  background-color: transparent;
  border: 0;
  box-shadow: none;
}

.jqTimepsaceContainer header {
  background-color: var(--color-celeste);
}

.jqTimepsaceContainer .jqTimespaceLine {
  background: transparent;
}

.jqTimepsaceContainer header h1 {
  font-size: 1.5rem;
  line-height: 1.1;
  text-transform: uppercase;
}

.jqTimepsaceContainer header h1:not(:first-child), .jqTimepsaceContainer header .jqTimespaceDummySpan:not(:first-child){
  border-left: 1px dotted var(--color-black);
}

.jqTimepsaceContainer header > div, .jqTimepsaceContainer header > div:last-child {
  border-bottom-width: 2px;
}

.jqTimepsaceContainer aside .jqTimespaceColumn:not(:first-child), .jqTimepsaceContainer header time:not(:first-child) {
  border-left: 1px dotted var(--color-black);
}

.jqTimespaceDisplay, .jqTimespaceEventBorder {
  display: none !important;
}

.jqTimepsaceContainer .jqTimespaceLeft, .jqTimepsaceContainer .jqTimespaceRight {
  color: var(--color-black);
  background: var(--color-celeste);
  border: 2px solid #fff;
  box-shadow: 1px 1px 5px 0px rgba(0,0,0,0.2);
  opacity: 1;
  bottom: calc(50% - 50px);
  font-size: 2rem;
  line-height: 1;
}

@media only screen and (min-width: 1900px) {
  .jqTimepsaceContainer .jqTimespaceLeft, .jqTimepsaceContainer .jqTimespaceRight { display: none !important; }
}


.jqTimepsaceContainer .jqTimespaceLeft:hover, .jqTimepsaceContainer .jqTimespaceRight:hover {
  background:  #fff;
  color: var(--color-black);
}

/* content event */

.jqTimespaceEvent p { 
  position: relative;
  padding: 0.25em 0.25em;
  background: var(--color-celeste);
  font-size: 0.938em;
  line-height: 1.1em;
  border-top: 2px solid var(--color-black);
  border-bottom: 2px solid var(--color-black);
  border-left: 2px solid transparent;
  border-right: 2px solid transparent;
  border-radius: 0;
  white-space: normal;
  overflow: auto;
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1), background-color .25s cubic-bezier(0.2, 0.6, 0.3, 1);  
}

.jqTimespaceEvent p > span { 
  left: 0 !important;
}

.jqTimespaceEvent p b { 
  text-transform: uppercase;
  font-size: 1rem;
  line-height: 1.1em;
}

.jqTimespaceEvent p small { 
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: space-between;
  font-size: 0.875rem;
  line-height: 1.2em;
  width: 100%;
}

.jqTimespaceEvent p small em { 
  display: inline-block;
  font-style: normal;
  flex: 0 0 auto;
}

.jqTimespaceEvent p small i { 
  display: inline-block;
  margin: 6px 3px 0 3px;
  width: 100%;
  height: 1px;
  flex: 1 1 auto;
  background-color: var(--color-black);
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1), background-color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.jqTimespaceEvent p:hover, .jqTimespaceEvent .jqTimespaceEventSelected {
  border: 2px solid var(--color-black);
  color: var(--color-black);
  background: var(--color-white);
}

.jqTimespaceEvent p:hover small i, .jqTimespaceEvent .jqTimespaceEventSelected p:hover small i { 
  background-color: var(--color-black);
}

.jqTimepsaceContainer .jqTimespaceEvent {
  
}

em {
  line-break: anywhere;
}

/* program menu*/
.program-menu {
  position: relative;
  width: 100%;
  border-top: 2px solid #1d1d1d;
}

.program-menu > ul {
  position: relative;
  display: flex;
  padding-top: 4px;
  padding-bottom: 4px;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  font-size: 2.188rem;
  line-height: 0.841;
}

.program-menu > ul > li {
  display: block;
  /*  width: calc(100% / 3);*/
  flex: 1 1 auto;
  padding: 14px 0px;
  border-left: 2px solid var(--color-black);
  border-left-color: var(--color-black);
  text-align: center;
}

.program-menu > ul > li:first-child {
  border-left-color: #fff;
}

.program-menu .button.button-arrow {
  text-transform: none;
}


#select-day {
  opacity: 0;
}

.select2-dropdown {
  font-size: 2.188rem;
  line-height: 0.841;
  border: var(--color-black) 2px solid;
  border-radius: 0;
  overflow: hidden;
  background-color: #fff;
  margin-left: 2px;
  overflow: visible;
}

.select2-dropdown ul {
  overflow: hidden;
}

.select2-dropdown:before {
  position: absolute;
  display: block;
  bottom: 100%;
  left: -2px;
  height: 59px;
  width: 2px;
  background-color: var(--color-black);
  content: "";
}

.select2-container--default .select2-results__option {
 font-size: 2.188rem;
 font-weight: 400;
 line-height: 0.841;
 color: var(--color-black);
 background-color: #f7f7f7;
 padding: 8px 5px;
 text-align: center;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: #f7f7f7;
  color: var(--color-black);
}

.select2-container--default .select2-results__option--selected {
  background-color: #d5daef!important;
}

.select2-container--default .select2-results__option[aria-selected="true"] {
  color: color: var(--color-black);
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: #fff !important;
}

.select2-container { width: 100% !important; }

.select2-container .select2-selection--single {
  background-color: transparent;
  min-height: 45px;
  border: 0;
  color: var(--color-black);
}

.select2-container--default.select2-container--disabled .select2-selection--single { background-color: #fff;}

.select2-container .select2-selection--single .select2-selection__rendered { position:relative; display:block; padding-top: 8px; height: 100%; font-size: 2.188rem; line-height: 1; color: var(--color-black); padding: 8px 0 0 85px;  }

.select2-container--default .select2-selection--single .select2-selection__arrow {
 
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  display: block;
  top: 10px; 
  left: 20px;
  right: auto;
  height: 24px;
  width: 45px;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0NSAyNCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+CiAgPHBhdGggZD0ibTQzLjUuMSAxLjQgMS40LTIyLjQgMjIuNEwuMSAxLjUgMS41LjFsMS40IDEuNCAxOS42IDE5LjZMNDIuMSAxLjUgNDMuNS4xeiIgZmlsbD0iIzFkMWQxZCIgLz4KPC9zdmc+Cg==");
  background-size: 45px 24px;
  background-repeat: no-repeat;
  background-position: center center;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b { display: none; }


/* image slider with slideshow - pre-footer */

/*

.splide-wrapper {
  position: relative;
  width: 100%;
}

.splide-wrapper .splide {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  visibility: visible;
}

.splide-wrapper .splide__list {
  will-change: transform;
}

.splide-wrapper .splide__slide {
  flex: 0 0 auto;
  border-left: 1px solid #fff;
  border-right: 1px solid #fff;   
  height: 100%;
  width: auto;
  cursor: grab;	
  background-color: #2e61ff;
}

.splide-wrapper .splide__slide:active {
  cursor: grabbing;
}

.splide-wrapper .splide__slide img {
  height: 100%;
  height: 250px;
  opacity: 0.7;
  transition: opacity .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.splide-wrapper .splide__slide img:hover { opacity: 1; }
*/


/* carousel */

.section-imageslider {
  border-top: 2px solid #1d1d1d;
}

.section-imageslider .container {
  overflow: hidden;
}

.section-imageslider .imageslider {
  position: relative;
  width: 100%;
  height: 350px;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: nowrap;
}

/*
.section-imageslider .imageslider:before {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 2px;
  height: 100%;
  background-color: #fff;
  content: "";
  z-index: 2;
}
*/

.section-imageslider .imageslider .slider-item {
  position: relative; 
  flex: 0 0 auto;
  border-left: 1px solid #fff;
  border-right: 1px solid #fff;   
  height: 100%;
  width: auto;
  background-color: #c7e8e1;
}

.section-imageslider .imageslider .slider-item a {
  display: block;
}

.section-imageslider .imageslider .slider-item .image {
  position: relative;
  width: 100%;
  border-left: 2px solid #fff;
  flex: 0 0 auto;
}

.section-imageslider .imageslider .slider-item .image .img {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 70%;
  background-color: #2e61ff;
}

.section-imageslider .imageslider .slider-item img {
  position: relative;
  display: block;
  height: 100%;
  height: 350px;
  opacity: 0.7;
  transition: opacity .25s cubic-bezier(0.2, 0.6, 0.3, 1);
  cursor: pointer; cursor: hand;  
}

.section-imageslider .imageslider .slider-item img:hover {
  opacity: 1;
}

.section-imageslider .slick-prev, .section-imageslider .slick-next {
  position: absolute;
  display: block;
  width: 22px;
  height: 40px;
  top: 50%;
  margin-top: -20px;  
} 

.section-imageslider .slick-prev { left: 14px; } 
.section-imageslider .slick-next { right: 14px; }

.section-imageslider .slick-prev:hover, .section-imageslider .slick-next:hover { color: #ff5a32; }

/* imageslider - slideshow */

.slideshow-wrapper .slick-next, .slideshow-wrapper .slick-prev, .slideshow-wrapper .slick-close { 
  position: absolute;
  width: 22px;
  height: 40px;
  color: #1d1d1d;
  z-index: 10;
  cursor: pointer; cursor: hand;
}

.slideshow-wrapper .slick-close { top: 10px; right: 10px; padding: 0px; width: 40px; }

.slideshow-wrapper .slick-next, .slideshow-wrapper .slick-prev { top: 50%; margin-top: -20px; }
.slideshow-wrapper .slick-next { right: 10px; padding-left: 0px; }
.slideshow-wrapper .slick-prev { left: 10px; padding-left: 0px; }

.slideshow-wrapper .slick-next:hover, .slideshow-wrapper .slick-prev:hover, .slideshow-wrapper .slick-close:hover { color: #000; }

.slideshow-wrapper .slick-close svg { display: block; width: 40px; height: 40px; }
.slideshow-wrapper .slick-next svg, .slideshow-wrapper .slick-prev svg { display: block; width: 22px; height: 40px; }

.slideshow-wrapper .slick-next:hover, .slideshow-wrapper .slick-prev:hover, .slideshow-wrapper .slick-close:hover { color: #ff5a32; }

.slideshow-wrapper {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  z-index: 120;
  background: #fff;
  overflow: hidden;
  display: none;
}


.slideshow-wrapper .slick-list {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  z-index: 1;
  overflow: hidden;
  padding: 0;
}

.slideshow-wrapper .slick-track {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
}

.slideshow-wrapper.active {
  display: block;
}

.slideshow-wrapper .container {
  position: relative;
  height: 100%;
  width: 100%;
  max-width: 2000px;	
  padding: 0 !important;
}

.slideshow-wrapper .slideshow {
  position: relative;
  height: 100%;
  width: 100%;
}

.slideshow-wrapper .slideshow-item {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 60px 60px; 
  float: left;
  white-space: nowrap;
  text-align: center;
}
/*
.slideshow-wrapper .slideshow-item:before {
    content: " ";
    display: inline-block;
    vertical-align: middle;
    height: 100%;
}*/

.slideshow-wrapper .slideshow-item img {
  border: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  opacity: 0;
}

.slideshow-wrapper .slideshow-item.slick-current img {
  opacity: 1;
/*	-webkit-transition: opacity .25s cubic-bezier(0.2, 0.6, 0.3, 1);  
  transition: opacity .25s cubic-bezier(0.2, 0.6, 0.3, 1); */			

}

.section-archive {
  z-index: 1;
}

.section-archive .columns.border-top-blue {
  border-top: 2px solid #1d1d1d;
}

.section-archive .columns .column-left .block.align-right {
  max-width: 1030px;
  padding-left: 100px;
}

.section-archive .content a {
  text-decoration: none;
}

.section-archive .content a.button:hover {
  color: #1d1d1d;
}


.page-register .section-hero-title .title-page {
  margin-bottom: 0.165em;
}

.section-program-intro .split .sidebar {
  width: calc(100% / 3);
  flex: calc(100% / 3);
}

.section-program-intro .split .sidebar .button.button-arrow {
  text-decoration: none;
}

.section-program-intro .split .sidebar .button.button-arrow:hover {
  color: #1d1d1d;
}

.section-program-intro .split .main {
  width: calc(100% / 3 * 2);
  flex: calc(100% / 3 * 2);
  background: #c7e8e1;
}

.section-program-intro .split .main .bridge {
  border-left: 0;
  color:  #c7e8e1;
  background: #fff;
}


/* open-call */

.section-extra-info {
  z-index: 2;
}

.section-extra-info .container {
  border-top: 2px solid #1d1d1d;
}

.extra-info-wrapper {
  margin: 0 auto;
  max-width: 1200px; 
  border: 2px solid  #c7e8e1;
  border-bottom: 0;
}

.extra-info-wrapper .fold {
  border-left: 0;
}

.extra-info-wrapper > h2 {
  padding: 0.5em 40px 0.3em 40px;
  font-size: 2.875rem;
  line-height: 1.1;
  text-transform: uppercase;
  background-color: #c7e8e1;
}

.fold.fold-small .fold-item:last-child, .fold.fold-small .fold-item {
  border-color: #c7e8e1;
}

.fold.fold-small .fold-item .content-columns, .fold .fold-item .heading .button { padding-left: 40px; padding-right: 40px; }

.fold.fold-small .fold-item .heading h2 { padding-right: 40px; font-size: 2.875rem; line-height: 0.841; padding-top: 0.1875em; }  
.fold.fold-small .fold-item .heading .button span { flex: 0 0 40px; height: 40px; width: 40px; }
.fold.fold-small .fold-item .heading .button span:before { height: 24px; top: calc(50% - 12px); }
.fold.fold-small.fold-item .heading .button span:after { width: 24px; left: calc(50% - 12px); }

.fold.fold-small .fold-item-child .heading h2 { font-size: 2rem; line-height: 0.841; }
.fold.fold-small .fold-item-child .heading .button span { flex: 0 0 30px; height: 30px; width: 30px; margin-right: 5px; }
.fold.fold-small .fold-item-child .heading .button span:before { height: 18px; top: calc(50% - 9px); }
.fold.fold-small .fold-item-child .heading .button span:after { width: 18px; left: calc(50% - 9px); }

.fold.fold-small .content-columns-description a {
  text-decoration: underline;
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.fold.fold-small .content-columns-description a:hover {
  color: #ff5a32;
}


/* complianz */
#cmplz-document a:focus {
  border: 0 !important;
  padding: 0 !important;
}

#cmplz-document a:hover {
  color: #ff5a32 !important;
}

#cmplz-document .cmplz-dropdown summary, #cmplz-cookies-overview .cmplz-dropdown, #cmplz-document .cmplz-dropdown,#cmplz-manage-consent-container.cmplz-manage-consent-container .cmplz-categories .cmplz-category {
  background-color: #c7e8e1;
}

#cmplz-cookies-overview .cmplz-dropdown .cookies-per-purpose, #cmplz-document .cmplz-dropdown .cookies-per-purpose { margin-bottom: 0 !important; }


.screen-reader-text {
    clip: rect(1px,1px,1px,1px);
    position: absolute!important;
    height: 1px;
    width: 1px;
    overflow: hidden;
    word-wrap: normal!important;
}

#cmplz-cookies-overview .cmplz-dropdown summary div:after, #cmplz-document .cmplz-dropdown summary div:after {
  background: url('../images/chevron-down-black.svg') no-repeat;
}

#cmplz-document {
  font-size: 1.563rem;
  line-height: 1.25;
  width: 100%;
  max-width: 100%;
}

#cmplz-document > p, #cmplz-document > h2, #cmplz-document > div { max-width: 1110px; }

#cmplz-document p, #cmplz-document ul, #cmplz-document li {
  margin-top: 1em;
  margin-bottom: 0;
  font-size: 1.563rem;
  line-height: 1.25;
}

#cmplz-document > p:first-child {
  max-width: 100%;
}

#cmplz-document > p:first-child i {
  font-style: normal;
  max-width: 1110px;
  display: block;
}

#cmplz-document > p:first-child br {
  display: none; 
}

#cmplz-document .cookies-per-purpose {
  font-size: 14px;
  margin-top: 0;
}

#cmplz-document p:first-child:after {
  position: relative;
  display: block;
  background-color: #1d1d1d;
  margin: 70px 0 70px -50px;
  width: calc(100% + 100px);
  height: 2px;
  border: 0;
  content: "";
}

#cmplz-document li {
  margin-top: 0.5em;  
}

#cmplz-document h2 {
  margin-top: 1em;
  font-size: 3.125rem;
  line-height: 1.1;
}

#cmplz-document a[target="_blank"]:after, .editor-styles-wrapper .cmplz-unlinked-mode a[target="_blank"]:after { display: none; }

#cmplz-manage-consent-container.cmplz-manage-consent-container .cmplz-categories .cmplz-category .cmplz-category-header .cmplz-always-active {
  color: #c7e8e1;
  font-weight: 700;
  text-transform: uppercase;
}

#cmplz-manage-consent .cmplz-btn.cmplz-manage-consent { display: none !important; }


/*************************************************************************************************************
 *
 *	NEW26
 *
 *************************************************************************************************************/ 


/*
 *	 section (flow) blocks
 *
 */  

.background-white { background-color: #ffffff; color: #1d1d1d; }
.background-celeste { background-color: #c6e7e0; color: #1d1d1d; }
.background-coal { background-color: #1d1d1d; color: #ffffff; }
.background-coral { background-color: #ff5a32; color: #ffffff; }


.row.border-top-grey {
  border-top: 2px solid #1d1d1d;
}

.row.border-bottom-grey {
  border-bottom: 2px solid #1d1d1d;
}



.row-full, .row-wide, .row-base, .row-narrow {
  position: relative;
  display: block;
  margin: 0 auto;
}
 
.row-full {
  padding-left: 0;
  padding-right: 0;
}
 
.row-wide {
  padding-left: 100px;
  padding-right: 100px;
}
 
.row-base {
  padding-left: 150px;
  padding-right: 150px;
}
 
.row > .inner {
  position: relative;
  display: block;
  margin: 0 auto;
  width: 100%;
} 
  
.row-carousel {
  padding-left: 100px;
  padding-right: 100px;
}
  
 .row > .inner {
   position: relative;
   display: block;
   margin: 0 auto;
   width: 100%;
 }

.title-medium {
   font-size: 4.375em;
   font-weight: 400;
   font-style: normal;
   line-height: 1.1;
 }

.block {
  position: relative;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.block.block-width-100 { width: 100%; }
.block.block-width-65 { width: 65%; }
.block.block-width-50 { width: 50%; }

.block.block-align-left{ margin-left: 0; margin-right: auto; }
.block.block-align-center { margin-left: auto; margin-right: auto; }
.block.block-align-right { margin-left: auto; margin-right: 0; }



/* block quote */

.block.block-quote {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  
}

.block.block-quote blockquote {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  padding-right: 150px;
  font-size: 5em;
  font-weight: 400;
  line-height: 1.1;
}

.block.block-quote blockquote:before {
  position: absolute;
  left: -0.375em;
  top: auto;
  content: "“";
}

.block.block-quote blockquote:after {
  content: "”";
  color: inherit;
}

.block.block-quote cite {
  align-self: flex-end;
  font-size: 1.875em;
  font-weight: 400;
  font-style: normal;
  line-height: 1.1;
}


/* block form */

.block.block-form .content {
  margin-top: 20px;
}

.block.block-form .gform_wrapper {
  margin-top: 70px;
}

.block.block-form .gform-body {
  width: calc(100% + 2em);
  font-size: 1.875rem;
  font-weight: 400;
  line-height: 1.1;
}

.block.block-form .gform_wrapper .gfield {
  width: 50%;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  padding: 0 2em 0 0;
}

.block.block-form .gform_wrapper .gfield:has(input.medium) {
  width: 50%;
}

.block.block-form .gform_wrapper .gfield:has(input.large), .block.block-form .gform_wrapper .gfield:has(textarea.large), .block.block-form .gform_wrapper .gfield.gf_custom_checkbox {
  width: 100%;
}

.block.block-form .gform_wrapper .gfield label {
  flex: 0 0 auto;
  margin: 0;
  padding: 0 1em 0 0;
  color: #1d1d1d;
  font-size: 1em;
  font-weight: 400;
  line-height: 1.1;
}

.block.block-form .gform_wrapper .gfield .ginput_container {
  flex: 1 1 auto;
}

.block.block-form .gform_wrapper .gfield .ginput_container input {
  padding: 0 1em 0 0;
}

.block.block-form .gform_wrapper .gfield textarea {
  resize: none;
  width: 100%;
  height: 38px;
  padding: 0;
  overflow-y: hidden !important;
}

.block.block-form .gform_wrapper .gfield.gf_custom_checkbox_newsletter {
  margin-top: 0;
}

.block.block-form .gform_footer {
  margin-top: 0;
}

/* block button */
.block.block-button {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

.block.block-button .title-medium {
  margin-bottom: -0.2em;
  text-transform: uppercase;
}

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

.block.block-button.block-right {
  justify-content: flex-end;
}

/* block - text + image */
.block.block-text-image {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: row;
  flex-wrap: nowrap;
}

.block.block-text-image > div {
  width: 50%;
}

.block.block-text-image .text .button {
  margin-top: 50px;
  font-size: 1.875rem;
}

.block.block-text-image .text .button.button:nth-of-type(2){
  margin-top: 20px;
}

.block.block-text-image .text {
  padding-right: 100px;
  padding-left: 0;
}

.block.block-text-image.block-text-image-reverse .text {
  padding-right: 0;
  padding-left: 100px;
}

.block.block-text-image.valign-top {
  align-items: flex-start;
}

.block.block-text-image.valign-middle {
  align-items: center;
}

.block.block-text-image.valign-bottom {
  align-items: flex-end;
}

.block.block-text-image.valign-stretch {
  align-items: stretch;
}

.block.block-text-image.valign-stretch .image .img-wrapper {
  width: 100%;
  height: 100%;
}


.block.block-text-image.valign-stretch .image .img{
  height: 100%;
  padding-top: 0 !important;
}

.block.block-text-image.valign-stretch .image .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* block - image cover */

.block.block-image-cover {
  position: relative;
  height: 0;
  padding-top: 30%;
  overflow: hidden;
  /*
  height: 40vh;
  min-height: 240px;
  max-height: 450px;*/
}

@media (max-aspect-ratio: 1/1) {
 .block.block-image-cover { padding-top: 56.25%; }
}




.block.block-image-cover .img-wrapper {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.block.block-image-cover .img{
  height: 100%;
  padding-top: 0 !important;
}

.block.block-image-cover .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* block - carousel */

.block.block-carousel {
  padding-left: 50px;
  padding-right: 50px;
}

.block.block-carousel .imageslider {
  position: relative;
  width: 100%;
  height: 350px;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: nowrap;
  overflow: hidden;
}

.block.block-carousel .imageslider .slider-item {
  position: relative; 
  flex: 0 0 auto;
  border-left: 1px solid var(--color-white);
  border-right: 1px solid var(--color-white);   
  height: 100%;
  width: auto;
  background-color: var(--color-celeste);
}

.block.block-carousel .imageslider .slider-item a {
  display: block;
}

.block.block-carousel .imageslider .slider-item .image {
  position: relative;
  width: 100%;
  border-left: 2px solid var(--color-white);
  flex: 0 0 auto;
}

.block.block-carousel .imageslider .slider-item .image .img {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 70%;
  background-color: var(--color-celeste);
}

.block.block-carousel .imageslider .slider-item img {
  position: relative;
  display: block;
  height: 100%;
  height: 350px;
  opacity: 0.7;
  transition: opacity .25s cubic-bezier(0.2, 0.6, 0.3, 1);
  cursor: pointer; cursor: hand;  
}

.block.block-carousel .imageslider .slider-item img:hover {
  opacity: 1;
}

.block.block-carousel .slick-prev, .block.block-carousel .slick-next {
  position: absolute;
  display: block;
  width: 22px;
  height: 40px;
  top: 50%;
  margin-top: -20px;  
} 

.block.block-carousel .slick-prev { left: 14px; } 
.block.block-carousel .slick-next { right: 14px; }

.block.block-carousel .slick-prev:hover, .section-imageslider .slick-next:hover { color: var(--color-coral); }


/* BLOCK FEATURED ITEMS */

.block-featured-items .button-wrapper {
  display: inline-block;
    width: auto;
    text-align: center;
    border: 2px solid currentColor;
    padding: 10px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
  
}

.block-featured-items {
  text-align: center;
}

.block-featured-items .button.button-arrow {
  margin: 0 auto;
  text-align: center;
  font-size: 1.563rem;  
}

.block-featured-items .container {
  overflow: hidden;
}

.block-featured-items .title-medium {
  text-align: center;
  text-transform: uppercase;
  margin-bottom: 65px;
}

.block-featured-items .carousel-wrapper {
  position: relative;
  width: 100%;
}

.block-featured-items .carousel {
  position: relative;
  width: calc(100% + 24px);
  margin-left: -12px;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: nowrap;
  overflow: hidden;
  text-align: left;  
}

.block-featured-items .carousel-item {
  position: relative;
  display: flex;
  flex-direction: column;
  width: calc(100% / 3);
  flex: 0 0 calc(100% / 3);
  padding: 12px; 
}

.block-featured-items .carousel-item a {
  display: block;
  transition: color .25s cubic-bezier(0.2, 0.6, 0.3, 1), background-color .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.block-featured-items .carousel-item a:hover {
  background-color: var(--color-white);
  color: var(--color-black);
}

.background-white .block-featured-items .carousel-item a:hover {
  background-color: var(--color-celeste);
}


.block-featured-items .carousel-item .image {
  position: relative;
  width: 100%;
  flex: 0 0 auto;
}

.block-featured-items .carousel-item .image .img {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}

.block-featured-items .carousel-item .image .img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.block-featured-items .carousel-item .meta {
  
}

.block-featured-items .carousel-item .text {
  position: relative;
  width: 100%;
  padding: 30px 24px;
  flex: 1 1 100%;
}

.block-featured-items .carousel-item .text p {
  margin: 0;
}
/*
.block-featured-items .carousel-item .meta {
  font-size: 1.25rem;
  line-height: 1.1;
}*/

.block-featured-items .carousel-item .title {
  padding-top: 30px;
  font-size: 1.563rem;
  line-height: 0.895;
}

.block-featured-items .carousel-item .title strong {
  display: inline-block;
  padding: 0;
  vertical-align: top;
  margin-left: -0.02em;
  margin-bottom: 0.08em;
  font-size: 2.188rem;
  line-height: 0.895;
  text-transform: uppercase;
  font-weight: normal;
}

.block-featured-items .slick-prev, .block-featured-items .slick-next {
  position: absolute;
  display: block;
  width: 22px;
  height: 40px;
  top: 50%;
  margin-top: -20px;  
  color: inherit;
} 

.block-featured-items .slick-prev { left: -64px; } 
.block-featured-items .slick-next { right: -64px; }



/// END BLOCK FEATURED ITEMS /////
















.block-video, .block-image {
  background: #
}

.block-image-grid {
  position: relative;
  display: block;
  width: 100%;
  height: 0;
  padding-top: 52%;
}

.block-image-grid:has(.image-grid-landscape) {
  padding-top: 26%;
}

.block-image-grid .image-grid {
  position: absolute;
  display: flex;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: nowrap;
  overflow: hidden;  
}

.block-image-grid .image-grid .left { width: 50%; }
.block-image-grid .image-grid .right { width: 50%; }

.block-image-grid .image-grid.image-grid-1-2 .left { width: calc(100% / 3); }
.block-image-grid .image-grid.image-grid-1-2 .right { width: calc(100% / 3 * 2); }

.block-image-grid .image-grid.image-grid-2-1 .left { width: calc(100% / 3 * 2); }
.block-image-grid .image-grid.image-grid-2-1 .right { width: calc(100% / 3); }

.block-image-grid .image-grid .split {
  display: flex;
  height: 100%;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: column;  
}

.block-image-grid .image-grid .img-wrapper {
  width: 100%;
  height: 100%;
}

.block-image-grid .image-grid .split .img-wrapper {
  width: 100%;
  height: 50%;
}

.block-image-grid .image-grid .img{
  height: 100%;
  padding-top: 0 !important;
}
.block-image-grid .image-grid .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.block-bridge .bridge {
  color: var(--color-celeste);
}

.block-bridge .bridge:before {
  position: absolute;
  display: block;
  top: 1px;
  left: 1px;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background-color: #fff;
  content: "";
}


/* block - performance header */

.block-performance-header {
  padding-top: 50px;
  padding-bottom: 100px;
}

.block.block-performance-header .meta {
  padding-top: 0;
  margin-bottom: 2.75em;
}

.block.block-performance-header .title h1 {
  margin-bottom: -0.182em;
  font-size: 6.875rem;
  line-height: 0.895;
  text-transform: uppercase;
}

.block.block-performance-header .title h2 {
  margin-top: 0.5em;
  margin-bottom: -0.182em;
  font-size: 4rem;
  line-height: 0.895;
}


.block-performance-shows .shows {
  font-size: 1.563rem;
  line-height: 1.1;
}

.block-performance-shows .shows ul {
  display: table;
  width: 100%;
}

.block-performance-shows .shows li {
  display: table-row;
}

.block-performance-shows .shows li span {
  display: table-cell;
  width: auto;
  padding-top: 3px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  line-height: 1.1;
}

.block-performance-shows .shows a, .performances-grid .shows li span a {
  position: relative;
  display: inline-block;
}

.block-performance-shows .shows a:after, .performances-grid .shows li span a:after {
  position: absolute;
  left: 0;
  top: 100%;
  margin-top: -3px;
  display: block;
  width: 100%;
  height: 1px;
  opacity: 0.2;
  background-color: var(--color-black);
  content: "";
  transition: opacity .25s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.performances-grid .shows li span a:after {
  background-color: var(--color-white);
}

.block-performance-shows .shows a:hover:after, .performances-grid .shows li span a:hover:after {
  opacity: 1;
}




/* block - performance intro */
.block-performance-intro {
  padding-top: 110px;
  padding-bottom: 100px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: nowrap;  
}

.block-performance-intro .meta {
  padding-top: 0;
  margin-bottom: 2em;
}

.block-performance-intro .meta .location {
  padding-top: 0;
  font-size: 1.563rem;
  line-height: 1.1;
}

.block-performance-intro .meta .location p {
  padding-left: 40px;
}

.block-performance-intro .meta .location svg {
  position: absolute;
  display: block;
  left: 0;
  top: -6px;
  width: 25px;
  height: 34px;
  padding: 0;
}

.block-performance-intro .text {
  postion: relative;
  flex: 1 1 auto;
  max-width: 880px;
}

.block-text-bridge .content-columns {
  
}


.block-text-bridge .content-columns .content-columns-text {
  flex: 0 1 auto;
  padding-right: 50px;
}

.block-text-bridge .content-columns .content-columns-text .text {
  max-width: 970px;
}

.block-text-bridge .content-columns .content-columns-text .button.button-arrow.button-arrow-small {
  margin-top: 50px;
  font-size: 1.875rem;
}

.block-text-bridge .content-columns .content-columns-bridge {
  margin-right: -90px;
  width: 30%;
  flex: 0 0 600px;
  color: var(--color-celeste);
  overflow: hidden;
}

.row.background-coral .block-text-bridge .content-columns .content-columns-bridge {
  color: var(--color-coral);
}

.block-text-bridge .content-columns .content-columns-bridge .bridge:before {
  position: absolute;
  display: block;
  top: 1px;
  left: 1px;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background-color: #fff;
  content: "";
}

.block-text-bridge .content-columns.order-reverse {
  flex-direction: row-reverse;
  justify-content: flex-start;
}

.block-text-bridge .content-columns.order-reverse .content-columns-text {
  padding-right: 0;
  padding-left: 50px;
}

.block-text-bridge .content-columns.order-reverse .content-columns-bridge {
  margin-right: auto;
  margin-left: -90px;
}


/* text grid - used by team */

.block-text-grid {
  
}

.block-text-grid .text-grid {
  position: relative;
  width: 100%;
  width: calc(100% + 40px);
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;  
}

.block-text-grid .text-grid li {
  position: relative;
  margin: 60px 0; 
  padding-right: 40px;
  width: calc(100% / 3);
  color: var(--color-black);
}

.block-text-grid .text-grid h2, .block-text-grid .text-grid h3 {
  margin-left: -0.02em;
  font-size: 2.188rem;
  line-height: 0.895;
  
}

.block-text-grid .text-grid h2 {
  font-weight: 700;
} 

.block-text-grid .text-grid .content {
  
}

.block-text-grid .text-grid .content p {
  margin: 0 0 0.5em 0 ;
  word-wrap: break-word;  
}


.block-text {
  font-size: 1.25rem;
}

.block-text .text-width-small .content {
  width: 100%;
  max-width: 580px;
}

.block-text .text-width-medium .content {
  width: 100%;
  max-width: 810px;
}

.block-text .text-width-large .content {
  width: 100%;
  max-width: 930px;
}

.block-text .text-width-double .content {
  width: 100%;
  column-count: 2;
  column-gap: 100px;
}

.block-text .text-width-double .content p {
  break-inside: avoid;
}

.block-text .content.content-small h2 {
  font-size: 3.125rem;
  line-height: 1.1;
  text-transform: none;
}

.block-text .content.content-small h3 {
  font-size: 2.188rem;
  line-height: 1.1;
}


.block-text .button.button-arrow.button-arrow-small {
  font-size: 1.5em;
}

.block-text .button.button-arrow.button-arrow-small.button-arrow-second {
  margin-top: 20px;
}


/* block accordion */

.block-accordion {
  
}

.block-accordion .fold {
  border-left: 2px solid var(--color-black);
  border-right: 2px solid var(--color-black);
}

.block-accordion .fold .article {
  padding: 20px 100px 100px 100px;
}

.block-accordion .fold .article > div {
  padding-top: 40px;
}

.block-accordion .fold .article .text {
  max-width: 80%;
}

.block-accordion .fold .article .image {
  max-width: 60%;
}

.block-accordion .content.content-small h2 {
  font-size: 3.125rem;
  line-height: 1.1;
  text-transform: none;
}

.block-accordion .content.content-small h3 {
  font-size: 2.188rem;
  line-height: 1.1;
}



/* overview template */


.overview-grid {
  position: relative;
  width: 100%;
  width: calc(100% + 40px);
  margin-left: -20px;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
}


.overview-grid .overview-grid-item {
  position: relative;
  display: flex;
  padding: 0px 20px 70px 20px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  width: calc(100% / 3);
  color: var(--color-black);  
}

.overview-grid .overview-grid-item > div {
  position: relative;
  width: 100%;
  border: 2px solid var(--color-black);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  flex: 1 1 auto;
}

.overview-grid .image {
  position: relative;
  flex: 0 0 auto;
}

.overview-grid .image .img {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56%;
  background-color: var(--color-celeste);
}

.overview-grid .image .img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.7;
  object-fit: cover;
  object-position: center center;
  transition: opacity .3s cubic-bezier(0.2, 0.6, 0.3, 1);
}

.overview-grid .image a:hover .img img {
  opacity: 1;  
}

.overview-grid .text {
  position: relative;
  padding: 40px 20px;
  width: 100%;
}

.overview-grid h3 {
  margin-left: -0.02em;
  font-size: 3.125rem;
  line-height: 0.895;
}

.overview-grid .description {
  position: relative;
  font-size: 1.25rem;
  line-height: 1.25;
}

.overview-grid .button-wrapper {
  margin: auto 0 0 0;
  padding: 20px;
}

.overview-grid .link {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: nowrap;
  height: 96px;
  font-size: 2.813em; /* 45px */
  line-height: 0.841;
  text-transform: uppercase;
}







/* section intro */
.section-intro {

}

.section-intro .container {
  background-color: var(--color-celeste);
  border-top: 2px solid #1d1d1d;
}

.section-intro .content-columns {
  font-size: 1.25rem;
  line-height: 1.25; 
}

.section-intro .content-columns h2, .section-intro .content-columns h3 {
  margin-top: 0.75em;
  margin-bottom: 0.25em;
  font-size: 2em;
  line-height: 1.1;
  text-transform: uppercase;  
}

.section-intro .content-columns h3 {
  font-size: 1.75em;
  line-height: 1.1;
}

.section-intro .content-columns h2:first-child, .section-intro .content-columns h3:first-child {
  margin-top: 0;
}

.section-intro .content-columns .content-columns-text {
  max-width: 650px;
}

.section-intro .content-columns p, .section-intro .content-columns ul {
  margin-top: 0.5em;
}

.section-intro .content-columns ul {
  padding-left: 1.125em;
}

.section-intro .content-columns li {
  position: relative;
  margin-top: 0.25em;
}

.section-intro .content-columns li:before {
  position: absolute;
  top: 0;
  left: 0;
  margin-left: -0.975em;
  content: "-";
}


.section-intro .content-columns h2:first-child, .section-intro .content-columns h3:first-child, .section-intro .content-columns p:first-child {
  margin-top: 0;
}

.section-intro .content-columns .button.button-arrow.button-arrow-small {
  font-size: 1.5em;
}

.section-intro .content-columns .button.button-arrow.button-arrow-small.button-arrow-second {
  margin-top: 20px;
}


.section-intro .content-columns .content-columns-text {
  padding-top: 50px;
  padding-bottom: 100px;
  width: 50%;
}

.section-intro .content-columns .content-columns-bridge {
  color: var(--color-celeste);
  width: 50%;
  overflow: hidden;
}

.section-intro .content-columns .content-columns-bridge .bridge:before {
  position: absolute;
  display: block;
  top: 1px;
  left: 1px;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background-color: #fff;
  content: "";
}

.section-intro.section-intro-image .content-columns .content-columns-text {
  width: 44%;
}

.section-intro.section-intro-image.row .content-columns .content-columns-text {
  padding-right: 40px;
}

.section-intro.section-intro-image.row-reverse .content-columns .content-columns-text {
  padding-left: 40px;
}

.section-intro.section-intro-image.row-reverse .content-columns .content-columns-text { order: 2; }
.section-intro.section-intro-image.row-reverse .content-columns .content-columns-image { order: 1; }

.section-intro .content-columns .content-columns-image {
  width: 56%;
}

.section-intro .content-columns .content-columns-image .img {
  height: 100%;
  padding-top: 0 !important;
  object-fit: cover;
  object-position: center center;
}

.section-intro .content-columns-image .img {
  background-color: var(--color-celeste);
}




