@charset "UTF-8";
/*
Theme Name: JFF-Projekt
Theme URI: https://jff.de
Author: Maximilian Greger
Author URI: https://greger.me
Version: 0.1
Requires at least: 5.0
Tested up to: 5.4
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jff
This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/
* {
  padding: 0;
  margin: 0;
  border: 0;
  box-sizing: border-box;
}

body {
  font-family: "neue-haas-grotesk-text", Helvetica, Arial, sans-serif;
  font-weight: 400;
  background-color: #ECEFF1;
  color: #000;
  overflow-x: hidden;
}

a {
  color: inherit;
}

p {
  line-height: 1.3;
}
p:not(:first-child) {
  margin-top: 1rem;
}
p:not(:last-child) {
  margin-bottom: 1rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 2.5rem;
  margin-bottom: 2rem;
  font-weight: 400;
}

h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child,
h6:first-child {
  margin-top: 0;
}

h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child {
  margin-bottom: 0;
}

h1,
h2 {
  font-size: 2rem;
  font-weight: 700;
}

img,
video {
  max-width: 100%;
  height: auto;
}

.site__header {
  background-color: #ECEFF1;
  position: relative;
  z-index: 15;
  transition: background-color 0.3s ease-out;
}
.site__header__wrapper {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: 0 auto;
  padding: 2rem 0;
  display: flex;
  gap: 3rem;
  align-items: flex-end;
}
.site__header .custom-logo {
  height: 3rem;
  width: auto;
  display: block;
  transition: filter 0.3s ease-out;
  position: relative;
  z-index: 20;
}
.site__header__navigation {
  flex-grow: 1;
}
.site__header__socials {
  display: flex;
  gap: 0.5rem;
  position: relative;
  z-index: 20;
}
.site__header__socials img,
.site__header__socials svg {
  height: 1.5rem;
  width: auto;
  display: block;
}
.site__header__hamburger {
  height: 30px;
  width: 30px;
  flex: 0 0 auto;
  position: relative;
  display: none;
  background-color: transparent;
  color: inherit;
}
.site__header__hamburger span {
  position: absolute;
  height: 3px;
  background-color: currentColor;
  width: 100%;
  left: 0;
  transition: all 0.3s ease-out;
}
.site__header__hamburger span:first-child {
  top: 8px;
}
.site__header__hamburger span:nth-child(2) {
  top: 15px;
}
.site__header__hamburger span:last-child {
  top: 22px;
}
.site__header__hamburger.active span {
  background-color: #fff;
}
.site__header__hamburger.active span:first-child {
  top: 50%;
  transform: rotate(45deg);
}
.site__header__hamburger.active span:nth-child(2) {
  opacity: 0;
}
.site__header__hamburger.active span:last-child {
  top: 50%;
  transform: rotate(-45deg);
}
.site__header.dark .custom-logo {
  filter: invert(1);
}
.site__header.dark .site__header__socials svg {
  fill: currentColor;
}

.wrapper {
  margin: 5rem auto 0 auto;
  max-width: 1200px;
  width: calc(100% - 2.5rem);
}

.site__mobilemenu {
  background-color: #000;
  color: #fff;
  position: fixed;
  top: 0;
  padding: 7rem 1.25rem 2rem 1.25rem;
  width: 100%;
  z-index: 1900;
  max-height: calc(100% - 112px);
  overflow: scroll;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-20px);
  transition: all 0.3s ease-out;
}
.site__mobilemenu.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.site__mobilemenu li {
  list-style: none;
}
.site__mobilemenu a {
  text-decoration: none;
}
.site__mobilemenu #mobile-menu > li {
  margin: 1rem 0;
}
.site__mobilemenu #mobile-menu > li:first-child {
  margin-top: 0;
}
.site__mobilemenu #mobile-menu > li > a {
  font-size: 1.5rem;
  font-weight: 700;
}
.site__mobilemenu #mobile-menu > li .sub-menu {
  padding-top: 1rem;
}
.site__mobilemenu #mobile-menu > li .sub-menu li {
  margin: 0.25rem 0;
}
.site__mobilemenu #mobile-menu > li .sub-menu a {
  font-size: 1.25rem;
}
.site__mobilemenu .site__header__socials {
  margin-top: 1.5rem;
  position: relative;
  z-index: 20;
}
.site__mobilemenu .site__header__socials svg {
  height: 1.5rem;
  fill: currentColor;
}

#primary-menu {
  display: flex;
  gap: 2.5rem;
}
#primary-menu li {
  list-style: none;
}
#primary-menu a {
  text-decoration: none;
  color: inherit;
  font-size: 1.4rem;
  position: relative;
  z-index: 20;
}
#primary-menu > li {
  position: relative;
  display: block;
}
#primary-menu > li.current-menu-item::before, #primary-menu > li.current-menu-parent::before, #primary-menu > li:hover:before {
  content: "";
  position: absolute;
  left: -15px;
  top: 5px;
  height: 10px;
  width: 10px;
  border-radius: 100%;
  background-color: currentColor;
}
#primary-menu > li > a {
  font-weight: 500;
}
#primary-menu > li > .sub-menu {
  position: absolute;
  padding: 2rem 0;
  opacity: 0;
  transform: translateY(-20px);
  visibility: hidden;
  transition: all 0.3s ease-out;
  white-space: nowrap;
}
#primary-menu > li > .sub-menu::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -100vw;
  right: -100vw;
  background-color: #ECEFF1;
  z-index: -1;
}
#primary-menu > li > .sub-menu > li:not(:last-child) {
  margin-bottom: 0.5rem;
}
#primary-menu > li > .sub-menu a {
  font-weight: 100;
}
#primary-menu > li:hover .sub-menu, #primary-menu > li:focus .sub-menu, #primary-menu > li:focus-within .sub-menu {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}

#tsparticles {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  padding: 0;
  margin: 0;
  z-index: 0;
}

.block__headerimage,
.block__headervideo {
  margin: 5rem auto 0 auto;
  position: relative;
  max-width: 1200px;
}
.block__headerimage img,
.block__headerimage video,
.block__headervideo img,
.block__headervideo video {
  max-width: 1200px;
  width: 100%;
  height: auto;
  max-height: 40rem;
  -o-object-fit: cover;
     object-fit: cover;
  margin: 0 auto;
  display: block;
}
.block__headerimage .swiper-button-prev,
.block__headerimage .swiper-button-next,
.block__headervideo .swiper-button-prev,
.block__headervideo .swiper-button-next {
  color: #fff;
  z-index: 10;
}
.block__headerimage .swiper-pagination-bullet-active,
.block__headervideo .swiper-pagination-bullet-active {
  background-color: #fff;
}
.block__headerimage .swiper-button-prev,
.block__headerimage .swiper-button-next,
.block__headerimage .swiper-pagination,
.block__headervideo .swiper-button-prev,
.block__headervideo .swiper-button-next,
.block__headervideo .swiper-pagination {
  opacity: 0;
  transition: opacity 0.3s ease-out;
}
.block__headerimage:hover .swiper-button-prev, .block__headerimage:hover .swiper-button-next.accordion, .block__headerimage:hover .swiper-pagination,
.block__headervideo:hover .swiper-button-prev,
.block__headervideo:hover .swiper-button-next.accordion,
.block__headervideo:hover .swiper-pagination {
  opacity: 1;
}

.site__mobilemenu + .block__headerimage,
.site__mobilemenu + .block__headervideo {
  margin-top: 0;
}

.block__archiveheader {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: 5rem auto 0 auto;
  display: block;
}
.block__archiveheader.flex {
  display: flex;
  align-content: center;
  justify-content: space-between;
}
.block__archiveheader select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: transparent;
  padding: 0.75rem;
  border-radius: 99px;
  border: 1px solid currentColor;
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}

.block__text {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: 5rem auto 0 auto;
  display: block;
}
.block__text__large {
  font-size: 1.75rem;
  font-weight: 700;
}

:not(.has-background) + .block__text,
.has-background + .block__text:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.btn {
  display: flex;
  align-items: start;
  flex-wrap: wrap;
  gap: 1rem;
}
.btn:not(:first-child) {
  margin-top: 2rem;
}
.btn:not(:last-child) {
  margin-bottom: 2rem;
}
.btn a,
.btn button {
  display: block;
  padding: 0.5rem 1rem;
  border: 1px solid currentColor;
  border-radius: 99px;
  text-decoration: none;
  line-height: 1;
  background-color: transparent;
  cursor: pointer;
  color: inherit;
}
.btn a:hover, .btn a.active,
.btn button:hover,
.btn button.active {
  color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  background-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  border-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
}

.block__tiles.has-background {
  padding: 5rem 0;
}
.block__tiles__inner {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__tiles__wrapper {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(250px, 100%), 1fr));
  gap: 2rem 3rem;
}
.block__tiles__tile a {
  text-decoration: none;
}
.block__tiles__tile img {
  height: auto;
}

.block__search.has-background {
  padding: 5rem 0;
}
.block__search__inner {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}

:not(.has-background) + .block__search,
.has-background + .block__search:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__newsletter.has-background {
  padding: 5rem 0;
}
.block__newsletter__inner {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__newsletter .cr_body .editable_content {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.block__newsletter .cr_body .editable_content > :first-child {
  flex: 1 1 auto;
}
.block__newsletter input {
  padding: 1.5rem;
  border-radius: 99px;
  border: 1px solid currentColor;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  background-color: transparent;
  width: 100%;
  font-size: 1rem;
}
.block__newsletter button {
  display: block;
  padding: 1.5rem;
  border: 1px solid currentColor;
  border-radius: 99px;
  text-decoration: none;
  line-height: 1;
  background-color: transparent;
  cursor: pointer;
  color: inherit;
  font-size: 1rem;
}
.block__newsletter button:hover, .block__newsletter button.active {
  color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  background-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  border-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
}

:not(.has-background) + .block__newsletter,
.has-background + .block__newsletter:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__festivalarchive.has-background {
  padding: 5rem 0;
}
.block__festivalarchive__inner {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__festivalarchive__grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
}
.block__festivalarchive__item {
  text-decoration: none;
}
.block__festivalarchive__item:hover h3 {
  color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  background-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  border-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
}
.block__festivalarchive__item img {
  display: block;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
.block__festivalarchive h3 {
  display: inline-block;
  padding: 0.5rem 1rem;
  border: 1px solid currentColor;
  border-radius: 99px;
  text-decoration: none;
  line-height: 1;
  background-color: transparent;
  cursor: pointer;
  color: inherit;
  margin-top: 1rem;
}

:not(.has-background) + .block__festivalarchive,
.has-background + .block__festivalarchive:not(.has-background) {
  margin: 5rem auto 0 auto;
}

:not(.has-background) + .block__tiles,
.has-background + .block__tiles:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__program {
  margin: 0 auto 0 auto;
  color: currentColor;
}
.block__program.has-background {
  padding: 5rem 0;
}
.block__program a {
  text-decoration: none;
}
.block__program__inner {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__program__inner h2 {
  margin-bottom: 0.5rem;
}
.block__program__inner h3 {
  margin-top: 0;
}
.block__program__inner__heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  gap: 1rem;
  flex-wrap: wrap;
}
.block__program__inner__heading h1,
.block__program__inner__heading h2,
.block__program__inner__heading h3,
.block__program__inner__heading h4,
.block__program__inner__heading h5,
.block__program__inner__heading h6 {
  margin: 0;
}
.block__program__inner__heading a {
  margin: 0;
  text-decoration: underline;
}
.block__program__grid {
  display: grid;
  gap: 3rem 2rem;
  margin-bottom: 5rem;
  grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
}
.block__program__grid__item {
  text-decoration: none;
}
.block__program__grid__item .wp-post-image {
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
.block__program__grid__item h3 {
  display: inline-block;
  padding: 0.5rem 1rem;
  border: 1px solid currentColor;
  border-radius: 99px;
  text-decoration: none;
  line-height: 1;
  background-color: transparent;
  cursor: pointer;
  color: inherit;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  white-space: nowrap;
  overflow: hidden;
  max-width: 100%;
}
.block__program__grid__item p {
  margin-top: 0;
}
.block__program__grid__item:hover h3 {
  color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  background-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  border-color: rgb(from currentColor calc(255 - r) calc(255 - g) calc(255 - b)/alpha);
  max-width: inherit;
}
.block__program__is_slider {
  padding: 0 !important;
}
.block__program__is_slider .wp-post-image {
  display: block;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
.block__program__is_slider .swiper-button-prev,
.block__program__is_slider .swiper-button-next {
  color: #fff;
}
.block__program__is_slider .swiper-slide {
  position: relative;
  cursor: pointer;
}
.block__program__is_slider .swiper-slide__overlay {
  position: absolute;
  z-index: 5;
  bottom: 0;
  left: 0;
  padding: 2rem;
  color: #fff;
  opacity: 0;
}
.block__program__is_slider .swiper-slide__overlay .btn {
  display: none;
}
.block__program__is_slider .swiper-slide__overlay a {
  text-decoration: none;
}
.block__program__is_slider .swiper-slide:hover .wp-post-image {
  filter: brightness(0.4);
}
.block__program__is_slider .swiper-slide:hover .swiper-slide__overlay {
  opacity: 1;
}
.block__program__wrapper {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__program__list {
  margin: 2rem 0;
}
.block__program__listitem {
  background-size: cover;
  background-position: center;
  padding: 1.5rem 0;
  border-bottom: 1px solid currentColor;
  text-decoration: none;
  position: relative;
}
.block__program__listitem:first-child {
  border-top: 1px solid currentColor;
}
.block__program__listitem__header {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 2rem;
  width: 100%;
  font-size: 1.75rem;
  cursor: pointer;
  background-color: transparent;
  text-align: left;
  color: currentColor;
}
.block__program__listitem__header > time {
  flex: 0 0 10rem;
  text-align: left;
}
.block__program__listitem__image {
  width: 100%;
}
.block__program__listitem__more {
  margin-top: 0;
  height: 0;
  overflow: hidden;
  opacity: 0;
}
.block__program__listitem__more__flex {
  display: flex;
  gap: 1rem 5rem;
  flex-wrap: wrap-reverse;
}
.block__program__listitem__more__flex > :first-child {
  flex: 1 1 500px;
}
.block__program__listitem__more__flex > :last-child {
  flex: 1 1 300px;
}
.block__program__listitem__more__meta__flex {
  display: flex;
  gap: 0.5rem 2rem;
  flex-wrap: wrap;
}
.block__program__listitem__more__meta__item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-style: normal;
  width: 100%;
}
.block__program__listitem__more__meta__item svg {
  flex: 0 0 auto;
}
.block__program__listitem__more__meta__item:not(:first-child) {
  margin-top: 0.5rem;
}
.block__program__listitem__more__meta__item:not(:last-child) {
  margin-bottom: 0.5rem;
}
.block__program__listitem__more .btn {
  margin-top: 1rem;
}

:not(.has-background) + .block__program,
.has-background + .block__program:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__accordion.has-background {
  padding: 5rem 0;
}
.block__accordion__wrapper {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 4rem;
}
.block__accordion__wrapper__text {
  flex: 1 1 15rem;
}
.block__accordion__wrapper__accordion {
  flex: 1 1 15rem;
}

:not(.has-background) + .block__accordion,
.has-background + .block__accordion:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.accordion:not(:first-child) {
  margin-top: 2rem;
}
.accordion:not(:last-child) {
  margin-bottom: 2rem;
}
.accordion__header {
  cursor: pointer;
  background-color: transparent;
  text-align: left;
  color: currentColor;
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 2.5rem;
}
.accordion__header svg {
  height: 30px;
  width: 30px;
  transition: transform 0.3s ease-out;
}
.accordion__content {
  margin-top: 0;
  height: 0;
  overflow: hidden;
  opacity: 0;
}
.accordion.active .accordion__header svg {
  transform: rotate(135deg);
}

.block__columns.has-background {
  padding: 5rem 0;
}
.block__columns__inner {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__columns__wrapper {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
  gap: 4rem;
}

:not(.has-background) + .block__columns,
.has-background + .block__columns:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__map__map {
  height: 30rem;
}
.block__map__map .leaflet-control-attribution {
  color: #aaa;
}
.block__map__map .leaflet-control-attribution a {
  color: inherit;
}

:not(.has-background) + .block__map,
.has-background + .block__map:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__team {
  margin: 4rem 0;
}
.block__team a {
  text-decoration: none;
}
.block__team h2 {
  margin-bottom: 0;
}

.block__team__member + .block__team__member {
  margin-top: 3rem;
}

.block__teamoverview.has-background {
  padding: 5rem 0;
}
.block__teamoverview__wrapper {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__teamoverview__grid {
  display: grid;
  gap: 3rem 2rem;
  grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
}
.block__teamoverview__item {
  text-decoration: none;
}
.block__teamoverview__item h3 {
  margin: 1rem 0 0 0;
}

:not(.has-background) + .block__teamoverview,
.has-background + .block__teamoverview:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__impressions.has-background {
  padding: 5rem 0;
}
.block__impressions__wrapper {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__impressions__grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
}
.block__impressions__item img {
  display: block;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}

:not(.has-background) + .block__impressions,
.has-background + .block__impressions:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__locations.has-background {
  padding: 5rem 0;
}
.block__locations__wrapper {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: auto;
}
.block__locations__grid {
  display: grid;
  gap: 3rem 2rem;
  grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
}
.block__locations__item {
  text-decoration: none;
}
.block__locations__item img {
  display: block;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
.block__locations__item h3 {
  margin: 1rem 0 0 0;
}

:not(.has-background) + .block__locations,
.has-background + .block__locations:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.leaflet-control-zoom-in {
  border-radius: 99px 99px 0 0 !important;
  border: 1px solid #000 !important;
  font-family: inherit;
  font-size: inherit;
}

.leaflet-control-zoom-out {
  border-radius: 0 0 99px 99px !important;
  border: 1px solid #000 !important;
  border-top: none !important;
  font-family: inherit;
  font-size: inherit;
}

.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
  border: none;
}

.site__footer {
  background-color: #fff;
  color: #000;
}
.site__footer__wrapper {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  margin: 0 auto;
  padding: 4rem 0;
  display: flex;
}
.site__footer__item {
  border-right: 1px solid currentColor;
  padding: 1rem 3rem;
  flex: 1 1 auto;
}
.site__footer__item:first-child {
  border-left: 1px solid currentColor;
}
.site__footer__item li {
  list-style: none;
  display: block;
}
.site__footer__item li:not(:last-child) {
  margin-bottom: 0.5rem;
}
.site__footer__item a {
  text-decoration: none;
}
.site__footer__item a:hover {
  text-decoration: underline;
}
.site__footer__item > img {
  width: 100%;
  height: auto;
  max-width: 300px;
}

:not(.has-background) + .site__footer,
.has-background + .site__footer:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.block__banner {
  background-color: #cee8eb;
  color: #000;
  padding: 1rem 0;
  font-size: 1.75rem;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
}
.block__banner .ticker-wrapper {
  display: flex;
  white-space: nowrap;
  will-change: transform;
}
.block__banner .ticker-text {
  display: inline-block;
  padding-right: 10px;
}
.block__banner__wrapper {
  width: 100%;
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.block__banner__box {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  position: relative;
}
.block__banner__content:before {
  content: "·";
  padding-left: 1rem;
  padding-right: 1rem;
}

.swiperGallery img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  height: auto;
}
.swiperGallery .swiper-button-prev,
.swiperGallery .swiper-button-next {
  color: #fff;
}

:not(.has-background) + .block__slider,
.has-background + .block__slider:not(.has-background) {
  margin: 5rem auto 0 auto;
}

.event__meta {
  max-width: 300px;
  width: 100%;
}
.event__meta__item {
  padding: 0.5rem 0;
  border-bottom: 1px solid currentColor;
  border-top: 1px solid currentColor;
}
.event__meta__item span {
  line-height: 1.4;
}
.event__meta__item span.icon {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.event__meta__item + .event__meta__item {
  border-top: none;
}
.event__meta__item.mt {
  border-top: 1px solid currentColor;
  margin-top: 2rem;
}
.event__meta svg {
  height: 24px;
  width: auto;
  display: block;
}

.block__archive {
  max-width: 1200px;
  width: calc(100% - 2.5rem);
  display: block;
}
.block__archive__description {
  margin: 2rem 0;
}
.block__archive__description .btn {
  margin-top: 1rem;
}
.block__archive__search {
  border: 1px solid currentColor;
  display: flex;
  gap: 0.75rem;
  align-items: center;
  border-radius: 50px;
}
.block__archive__search__term {
  flex: 1 1 auto;
  padding: 1.5rem;
  border-radius: 99px;
}
.block__archive__search select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0.75rem;
  border-radius: 99px;
  border: 1px solid currentColor;
  color: inherit;
  width: 10rem;
}
.block__archive__search__term,
.block__archive__search select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: block;
  font-size: inherit;
  font-family: inherit;
  background-color: transparent;
}
.block__archive__search__term:last-child,
.block__archive__search select:last-child {
  margin-right: 1rem;
}
.block__archive__grid {
  margin-top: 2rem;
}

:not(.has-background) + .block__archive,
.has-background + .block__archive:not(.has-background) {
  margin: 5rem auto 0 auto;
}

@media screen and (max-width: 850px) {
  body {
    font-size: 1.2em;
  }
  .block__archive__search {
    flex-wrap: wrap;
    padding: 1rem;
  }
  .block__archive__search .block__archive__search__term {
    flex: 1 1 100%;
  }
  .site__header {
    position: sticky;
    top: 0;
    z-index: 2000;
  }
  .site__header.active {
    background-color: #000 !important;
    color: #fff !important;
  }
  .site__header.active .custom-logo {
    filter: invert(1);
  }
  .site__header.scroll .site__header__wrapper {
    padding: 1rem 0;
  }
  .site__header__wrapper {
    transition: padding 0.3s ease-out;
  }
  .site__footer__wrapper {
    flex-direction: column;
  }
  .site__footer__wrapper .site__footer__item:first-child {
    border-left: none;
    border-top: 1px solid currentColor;
  }
  .site__footer__wrapper .site__footer__item > img {
    max-width: 150px;
  }
  .site__footer__wrapper .site__footer__item__sponsors > img {
    max-width: 100%;
  }
  .site__header__wrapper > .site__header__socials,
  .site__header__navigation {
    display: none;
  }
  .site__header__wrapper {
    align-items: center;
    justify-content: space-between;
  }
  .site__header__hamburger {
    display: block;
  }
  .block__program__listitem__header {
    flex-direction: column;
  }
  .block__program__listitem__header time,
  .block__program__listitem__header span {
    flex: 0 0 auto;
  }
  .site__footer__item {
    border-right: none;
    padding: 2rem 0;
    border-bottom: 1px solid #000;
  }
  .block__text.block__text__large,
  .block__program__listitem__header,
  .accordion__header {
    font-size: 1.25rem;
  }
  .block__program__listitem {
    padding: 1rem 0;
  }
  .accordion__header svg {
    height: 20px;
    width: 20px;
  }
}/*# sourceMappingURL=style.css.map */