:root {
  --dm-blue: #0d6efd;
  --dm-indigo: #6610f2;
  --dm-purple: #6f42c1;
  --dm-pink: #d63384;
  --dm-red: #cd2628;
  --dm-orange: #fd7e14;
  --dm-yellow: #ffc107;
  --dm-green: #198754;
  --dm-teal: #20c997;
  --dm-cyan: #0dcaf0;
  --dm-white: #fff;
  --dm-gray: #868e96;
  --dm-gray-dark: #495057;
  --dm-gray-100: #f5f5f5;
  --dm-gray-200: #e9ecef;
  --dm-gray-300: #dee2e6;
  --dm-gray-400: #ced4da;
  --dm-gray-500: #adb5bd;
  --dm-gray-600: #898989;
  --dm-gray-700: #495057;
  --dm-gray-800: #343a40;
  --dm-gray-900: #212529;
  --dm-primary: #cd2628;
  --dm-secondary: #868e96;
  --dm-success: #198754;
  --dm-info: #0dcaf0;
  --dm-warning: #ffc107;
  --dm-danger: #dc3545;
  --dm-light: #f8f9fa;
  --dm-dark: #212529;
  --dm-primary-rgb: 205, 38, 40;
  --dm-secondary-rgb: 134, 142, 150;
  --dm-success-rgb: 25, 135, 84;
  --dm-info-rgb: 13, 202, 240;
  --dm-warning-rgb: 255, 193, 7;
  --dm-danger-rgb: 220, 53, 69;
  --dm-light-rgb: 248, 249, 250;
  --dm-dark-rgb: 33, 37, 41;
  --dm-white-rgb: 255, 255, 255;
  --dm-black-rgb: 0, 0, 0;
  --dm-body-color-rgb: 33, 37, 41;
  --dm-body-bg-rgb: 255, 255, 255;
  --dm-font-sans-serif: system-ui, -apple-system, Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, Liberation Sans, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
  --dm-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
  --dm-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
  --dm-body-font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, Liberation Sans, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
  --dm-body-font-size: 1.1rem;
  --dm-body-font-weight: 300;
  --dm-body-line-height: 1.5;
  --dm-body-color: #2B2A29;
  --dm-body-bg: #fff;
  --dm-link-color: #cd2628;
  --dm-link-hover-color: #b30013;
  --main-nav-classic-bg: #fff;
  --burger-color: #2B2A29;
  --site-footer-bg: #f5f5f5;
  --card-border-radius: 0;
  --border-radius: 0;
  --border-radius-sm: 0;
  --border-radius-lg: 0;
  --border-radius-pill: 0;
  --bsof-arrow-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %23fefefe; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  --bsof-arrow-black: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %2333; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  --bsof-breakpoint-min: 992px;
}

/*
Colors for dark mode
 */
body.dark {
  --dm-body-color: #fff;
  --dm-body-color-rgb: 255, 255, 255;
  --dm-body-bg: #212529;
  --dm-link-color: #fff;
  --main-nav-classic-bg: #212529;
  --site-footer-bg: $dm-gray-800;
  --burger-color: #fff;
  --dm-dark-rgb: 255, 255, 255;
  --bsof-arrow-black: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %23fefefe; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  --bsof-arrow-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %2333; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  --dm-gray-600: #e9ecef;
  --dm-gray-200: #343a40;
  --navbar-toggler-bg-dark: transparent;
}
body.dark footer {
  background-color: var(--dm-gray-200);
}

/*
media query for non mobile devices
  */
#header.sticky-top .secondary-menu {
  background-color: var(--dm-body-bg);
  transition: height 0.3s;
  height: 1.5rem;
}
#header.sticky-top .secondary-menu ul {
  display: flex;
  justify-content: right;
  padding: 0;
  margin: 0;
}
#header.sticky-top .secondary-menu ul li {
  margin: 0 0 0 0.5rem;
}
#header.sticky-top .secondary-menu ul li a {
  color: var(--dm-body-color);
  text-decoration: none;
  font-weight: bold;
}
#header.sticky-top .secondary-menu ul li a:hover {
  color: var(--dm-primary);
}
#header.sticky-top .secondary-menu ul li button {
  padding: 0;
}
#header.sticky-top .secondary-menu ul li button svg {
  height: 15px;
}
#header.sticky-top .secondary-menu ul li button svg path {
  fill: var(--dm-body-color);
}
#header.sticky-top .secondary-menu .dmind-menu-search-li .toggle-search {
  margin: 0;
}
#header.sticky-top .secondary-menu .search-toggle {
  margin-left: 0 !important;
}
#header.sticky-top.sticky .navbar-brand {
  /*svg {
    display: none;
  }
  &:before {
    content: url('/wp-content/themes/bsof-child/assets/logos/small.svg');
    display: block;
    width: 40px;
    height: 40px;
  }*/
}
#header.sticky-top.sticky .secondary-menu {
  height: 0px;
}
#header.sticky-top.sticky .search-form-container {
  display: none !important;
}
#header.sticky-top.sticky #main-nav-classic {
  background-color: var(--dm-body-bg);
}
@media (min-width: 992px) {
  #header.sticky-top {
    background-color: var(--dm-body-bg);
  }
  #header.sticky-top #main-nav-classic {
    background-color: transparent;
    transition: all 0.3s;
  }
}
#header .navbar-toggler .animated-icon2 span {
  border-radius: 0;
}
#header .navbar-toggler .animated-icon2:not(.open) span {
  width: 100%;
}
@media (max-width: 991px) {
  #header > .container > .secondary-menu {
    display: none;
  }
  #header #main-nav-classic > .container .navbar-brand {
    margin-right: 0;
  }
  #header #main-nav-classic > .container > .ms-auto > .container {
    padding: 0 !important;
  }
  #header #main-nav-classic > .container > .ms-auto > .container ul li:first-child {
    margin-left: 0;
  }
  #header #main-nav-classic > .container > .ms-auto > .container ul .search-toggle {
    margin-left: 0 !important;
  }
  #header .navbar-toggler {
    display: none;
  }
  #header .secondary-menu {
    height: auto !important;
    font-size: 1.2rem !important;
  }
  #header .secondary-menu svg {
    height: 1.5rem !important;
  }
  #header #main-menu .navbar-nav {
    padding: 0 1rem;
  }
  #header #main-menu .navbar-nav .menu-item {
    padding: 0 0 0 5rem;
  }
  #header #main-menu .navbar-nav .menu-item a {
    font-size: 2rem;
    color: var(--dm-body-color);
    font-weight: var(--dm-body-font-weight);
  }
  #header #main-menu .navbar-nav .menu-item .sub-menu a {
    font-size: var(--dm-body-font-size);
    padding: 0;
  }
  #header #main-menu .navbar-nav .sub-menu {
    padding-bottom: 2rem;
  }
  #header #main-menu .navbar-nav .sub-menu .menu-item {
    padding: 0;
    margin: 0;
  }
  #header #main-menu .navbar-nav .dropdown-toggle {
    background-color: transparent !important;
    color: var(--dm-body-color);
    height: 3.65rem;
  }
  #header #main-menu .navbar-nav .dropdown-toggle:after {
    border-width: 0 0.1em 0.1em 0;
  }
}

.search-form-container {
  position: absolute;
  background: white;
  z-index: 1;
  width: 50%;
  right: 0px;
  display: block;
}

@media (min-width: 992px) {
  .secondary-menu .toggleDarkmode {
    transform: scale(0.7);
  }
  .secondary-menu .toggle-search {
    margin: 0;
    text-decoration: none;
    font-weight: bold;
    height: 20px;
  }
  .secondary-menu .toggle-search:before {
    color: var(--dm-body-color);
    content: "Suche";
  }
  .secondary-menu #menu-header-mini-menue-pl .toggle-search:before {
    content: "Szukaj";
  }
  .secondary-menu #menu-header-mini-menue-en .toggle-search:before {
    content: "Search";
  }
  #main-menu .navbar-nav .nav-item.dropdown .nav-link {
    padding: 0;
  }
  #main-menu .navbar-nav > .menu-item > a {
    color: var(--dm-body-color);
    font-weight: bold;
    font-size: var(--dm-body-font-size);
    padding: 0;
    margin: 0 0 0 1.3rem;
  }
  #main-menu .navbar-nav > .menu-item .dropdown-menu {
    padding: 1.5rem;
    background-color: var(--dm-body-bg);
    border-color: var(--dm-gray-200);
  }
  #main-menu .navbar-nav > .menu-item .dropdown-menu a {
    color: var(--dm-body-color);
    display: inline;
    font-weight: normal;
    padding: 0;
    margin: 3px 6px;
  }
  #main-menu .navbar-nav > .menu-item .dropdown-menu a:hover, #main-menu .navbar-nav > .menu-item .dropdown-menu a:focus {
    background-color: transparent;
    border-bottom: 1px solid #2B2A29;
  }
  #main-menu .navbar-nav > .menu-item.current-menu-item > a, #main-menu .navbar-nav > .menu-item.current-menu-parent > a {
    border-bottom: 6px solid #cd2628;
  }
  #main-menu .navbar-nav .dropdown-toggle {
    display: none;
  }
}
/*
Mobile menu background testing / placeholder
 */
.navbar-collapse.collapsing,
.navbar-collapse.show {
  position: absolute;
  background-color: var(--dm-body-bg);
  top: 100%;
  left: 0;
  right: 0;
  overflow: scroll;
  padding: 0 0 20vh;
}

.navbar-collapse.collapsing {
  height: 0;
}

.navbar-collapse.show {
  height: 100vh;
}
.navbar-collapse.show .animated-icon2.open {
  position: absolute;
  bottom: 0;
}

.btn-primary {
  font-weight: bold;
  font-size: 1.2rem;
  line-height: 1.5rem;
  padding-right: 3rem;
  padding-left: 3rem;
}
.btn-primary:not(.plain):before {
  display: block;
  content: "";
  width: 30px;
  height: 100%;
  margin-right: 10px;
  float: left;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %23fefefe; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center;
}

footer {
  margin-top: 2rem;
  padding: 2rem 0 2rem 0;
}
footer .list-group {
  display: flex;
  justify-content: center;
}
@media (min-width: 992px) {
  footer .list-group .list-group-item {
    margin: 0;
    padding: 0 1rem;
  }
}
footer .list-group .menu-item a, footer .list-group .dm-footer-social a {
  color: var(--dm-body-color);
  text-decoration: none;
  font-weight: bold;
}
footer .list-group .menu-item a svg, footer .list-group .dm-footer-social a svg {
  height: 100%;
}
footer .list-group .menu-item a svg path, footer .list-group .dm-footer-social a svg path {
  fill: var(--dm-gray-600);
}
@media (max-width: 991px) {
  footer {
    padding: 2rem 0 2rem 0;
  }
  footer .list-group {
    flex-flow: row wrap;
  }
  footer .list-group-horizontal-md > .menu-item-social {
    display: none;
  }
}

.breadcrumb-container {
  display: none;
}

#main-nav-classic .navbar-brand {
  padding: 0;
}

/*
Search field
 */
#header .search-form-container .search-container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}
#header .search-form-container .search-container .search-field {
  height: 2rem;
}
#header .search-form-container .search-container button {
  padding: 0 0.5rem;
}
#header .search-form-container .search-container button svg {
  height: 1rem;
}
@media (max-width: 991px) {
  #header .search-form-container {
    width: 100%;
    position: fixed;
    top: 4rem;
  }
}

#header.sticky .navbar-brand svg {
  height: 70px;
}
@supports not (font: -apple-system-body) {
  #header.sticky .navbar-brand svg {
    margin-bottom: -20px;
  }
}
#header.sticky .navbar-brand svg #path14 {
  transform: translate(-120%, -260%);
  transform-origin: center right;
}
#header.sticky .navbar-brand svg #path12 {
  transform: scale(0.7);
}
#header.sticky .navbar-brand svg #g8 {
  transform-origin: 0px -10%;
}
#header.sticky .navbar-brand svg #path12, #header.sticky .navbar-brand svg #path14, #header.sticky .navbar-brand svg #g8 {
  transition: transform 0.3s ease-in-out;
}

#header .navbar-brand svg {
  height: 70px;
  overflow: visible;
}
#header .navbar-brand svg #path12, #header .navbar-brand svg #path14, #header .navbar-brand svg #g8 {
  transition: transform 0.3s ease-in-out;
}

@media (min-width: 992px) {
  body {
    padding-top: 9rem;
  }
  #header.sticky-top {
    position: fixed;
    width: 100%;
  }
}
#search-form-container .search-container {
  background-color: var(--dm-body-bg);
  border-radius: 0;
}
#search-form-container .search-container input, #search-form-container .search-container #searchbutton {
  border-radius: 0;
}
#search-form-container .search-container input {
  background-color: var(--dm-gray-200);
  color: var(--dm-body-color);
}
#search-form-container .search-container input::-webkit-search-cancel-button {
  filter: grayscale(1);
  background-color: white;
}
#search-form-container .search-container #searchbutton {
  background-color: transparent;
  border-bottom: 3px solid #cd2628;
}
#search-form-container .search-container #searchbutton svg {
  fill: var(--dm-body-color);
}
@media (max-width: 991px) {
  #search-form-container .search-container {
    width: 90%;
  }
}

#header .wpml-ls-menu-item.wpml-ls-current-language a {
  color: #cd2628 !important;
}

div.bsof-inline-img-wrapper {
  container-type: inline-size;
  position: relative;
  display: inline-block;
  width: 100%;
  overflow: visible;
}
div.bsof-inline-img-wrapper img {
  display: block;
  max-width: 100%;
  height: auto;
}
div.bsof-inline-img-wrapper .bsof-img-inline-text {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  transform-origin: top left;
  transform: rotate(-90deg) translateX(-100%);
  white-space: nowrap;
  padding: 4cqw 7cqw;
  color: black;
  opacity: 0.8;
  font-family: "Inter", sans-serif;
  line-height: 1.2;
  text-align: right;
}
div.bsof-inline-img-wrapper .bsof-img-inline-text .title {
  font-weight: 700;
  font-size: 1em;
  font-size: 4.5cqw;
  display: block;
}
div.bsof-inline-img-wrapper .bsof-img-inline-text .function {
  font-size: 0.9em;
  font-size: 4.5cqw;
  color: black;
  display: block;
  margin-top: 0.2em;
  font-style: italic;
}

.spielplan-overlay-variant .spielplan-header {
  position: relative;
}
.spielplan-overlay-variant .spielplan-header div.kalender-wrapper {
  position: relative;
  display: inline;
}
.spielplan-overlay-variant .spielplan-kalender-trigger {
  cursor: pointer;
}
@media (max-width: 575px) {
  .spielplan-overlay-variant .spielplan-kalender-trigger {
    font-size: 1.3em;
  }
}
.spielplan-overlay-variant .kalender-popup {
  text-transform: uppercase;
  font-weight: bolder;
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--dm-body-bg);
  border: 1px solid var(--dm-gray-600);
  padding: 1rem;
  z-index: 1050;
  margin-top: 0.5rem;
}
.spielplan-overlay-variant .kalender-popup.show {
  display: block;
}
.spielplan-overlay-variant .kalender-popup .spielplan-minical {
  margin-bottom: 0;
}
.spielplan-overlay-variant .kalender-popup .spielplan-minical .minical-table {
  font-size: 0.8em;
}
.spielplan-overlay-variant .kalender-popup .spielplan-minical .minical-table td.minical-day {
  padding: 0.6rem 0.5rem;
}
.spielplan-overlay-variant .kalender-popup .spielplan-minical .minical-table td.minical-day.has-event {
  font-weight: bold;
}
.spielplan-overlay-variant .kalender-popup .spielplan-minical .minical-table td.minical-day.today {
  background-color: var(--dm-primary);
  color: var(--dm-white);
  font-weight: bold;
}
.spielplan-overlay-variant .kalender-popup .spielplan-minical .minical-table th.minical-weekday {
  font-weight: normal;
}
.spielplan-overlay-variant .kalender-popup .spielplan-minical .minical-table td.minical-empty {
  background-color: var(--dm-body-bg);
}
.spielplan-overlay-variant .spielplan-termin-liste {
  background-color: var(--dm-body-bg);
}
.spielplan-overlay-variant .spielplan-termin-liste .list-group-item {
  background-color: var(--dm-body-bg);
  color: var(--dm-body-color);
  border: none;
  border-bottom: 1px solid var(--dm-body-color);
  padding: 1rem 0.5rem;
}
.spielplan-overlay-variant .spielplan-termin-liste .list-group-item:last-child {
  border-bottom: none;
}
.spielplan-overlay-variant .spielplan-termin-liste .list-group-item.termin-abgesagt { /* Stile wie zuvor */ }
.spielplan-overlay-variant .spielplan-termin-liste .list-group-item.termin-abgesagt .termin-title, .spielplan-overlay-variant .spielplan-termin-liste .list-group-item.termin-abgesagt .termin-datum-zeit span {
  text-decoration: line-through;
  opacity: 0.6;
}
.spielplan-overlay-variant .spielplan-termin-liste .list-group-item.termin-abgesagt .badge {
  font-size: 0.8em;
}
.spielplan-overlay-variant .spielplan-termin-liste .list-group-item .termin-datum-zeit {
  font-size: 0.9em;
}
.spielplan-overlay-variant .spielplan-termin-liste .list-group-item .termin-title {
  margin-bottom: 0.25rem;
}
.spielplan-overlay-variant .btn.btn-primary::before {
  width: 1.5rem;
  height: 1.5rem;
}

.termin-details-single-styled .btn.btn-primary::before, .tax-veranstaltungskategorie .btn.btn-primary::before {
  width: 1.5rem;
  height: 1.5rem;
}

.spielplan-header-img .copyright-wrapper, .termin-image-container .copyright-wrapper {
  z-index: 10;
  position: relative;
}
.spielplan-header-img .copyright-wrapper .copyright-overlay, .termin-image-container .copyright-wrapper .copyright-overlay {
  transition: width 0.3s, opacity 0.3s;
  opacity: 0.95;
}
.spielplan-header-img .copyright-wrapper .copyright-overlay.show, .termin-image-container .copyright-wrapper .copyright-overlay.show {
  display: block !important;
}
.spielplan-header-img .copyright-wrapper .copyright-content, .termin-image-container .copyright-wrapper .copyright-content {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.spielplan-header-img .copyright-wrapper .copyright-overlay, .spielplan-header-img .copyright-wrapper .copyright-btn, .termin-image-container .copyright-wrapper .copyright-overlay, .termin-image-container .copyright-wrapper .copyright-btn {
  background-color: rgba(0, 0, 0, 0.7);
  color: var(--dm-white);
}
.spielplan-header-img .copyright-wrapper .copyright-btn, .termin-image-container .copyright-wrapper .copyright-btn {
  display: inline-block;
}
.spielplan-header-img .copyright-wrapper .copyright-overlay, .termin-image-container .copyright-wrapper .copyright-overlay {
  display: none;
}
.spielplan-header-img .copyright-wrapper.show .copyright-btn, .termin-image-container .copyright-wrapper.show .copyright-btn {
  display: none;
}
.spielplan-header-img .copyright-wrapper.show .copyright-overlay, .termin-image-container .copyright-wrapper.show .copyright-overlay {
  display: block;
}

.ticket-button-wrapper {
  z-index: 10;
}

/*
Override
 */
body.dark .text-muted {
  --dm-text-opacity: 1;
  color: var(--dm-gray-300) !important;
}
body.dark .border-dark {
  border-color: var(--dm-gray-600) !important;
}

@media (min-width: 992px) {
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-current-page-ancestor > a, #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-current-menu-ancestor > a {
    border-bottom: 6px solid var(--dm-primary) !important;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item {
    padding: 0 0 0 0.8rem;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item > a.mega-menu-link {
    padding: 0;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item > a.mega-menu-link span {
    margin: 0 !important;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item:not(:nth-child(1)):not(:nth-child(2)).mega-menu-flyout ul.mega-sub-menu ul.mega-sub-menu {
    right: 100% !important;
    left: unset !important;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item.mega-menu-flyout ul.mega-sub-menu {
    border: 1px solid var(--dm-gray-200);
    padding-bottom: 1rem;
    padding-top: 1rem;
    width: auto;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item.mega-menu-flyout ul.mega-sub-menu.flyout-left {
    right: 0 !important;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item > a.mega-menu-link {
    padding: 0 !important;
    line-height: 1rem;
    font-size: 0.938rem;
    margin: 0.3rem 1rem;
    white-space: nowrap;
    display: inline-flex;
  }
  #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item:hover > a.mega-menu-link {
    border-bottom: 1px solid var(--dm-primary);
  }
  /*
  Indicators
   */
  #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item-has-children > a.mega-menu-link > span.mega-indicator:after {
    content: " ";
  }
  #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-flyout li.mega-menu-item a.mega-menu-link > span.mega-indicator:after {
    content: " ";
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %2333; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center;
    width: 0.6em;
    height: 0.6em;
    margin-left: 0.5rem;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media (max-width: 991px) {
  body:not(.mega-menu-primary-mobile-open) #mega-menu-wrap-primary.mega-menu-wrap .mega-menu-toggle .mega-toggle-block-0 .mega-toggle-animated-slider .mega-toggle-animated-inner::before {
    top: 13px;
  }
  body:not(.mega-menu-primary-mobile-open) #mega-menu-wrap-primary.mega-menu-wrap .mega-menu-toggle .mega-toggle-block-0 .mega-toggle-animated-slider .mega-toggle-animated-inner::after {
    top: 26px;
  }
  #mega-menu-wrap-primary.mega-menu-wrap .mega-menu-toggle .mega-toggle-block-0 .mega-toggle-animated-slider .mega-toggle-animated-inner, #mega-menu-wrap-primary.mega-menu-wrap .mega-menu-toggle .mega-toggle-block-0 .mega-toggle-animated-slider .mega-toggle-animated-inner::before, #mega-menu-wrap-primary.mega-menu-wrap .mega-menu-toggle .mega-toggle-block-0 .mega-toggle-animated-slider .mega-toggle-animated-inner::after {
    border-radius: 0;
    background-color: var(--dm-body-color);
  }
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary {
    overflow: scroll;
    position: fixed;
    top: 1rem;
    left: 0;
    right: 0;
    z-index: -1;
    height: 100vh;
    width: 100%;
    background-color: var(--dm-body-bg);
    padding-top: 70px;
    padding-left: 1rem;
    padding-right: 1rem;
  }
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary > li > a.mega-menu-link {
    font-size: 2rem;
    color: var(--dm-body-color);
    font-weight: var(--dm-body-font-weight);
    border-bottom: 1px solid var(--dm-body-color);
    padding-top: 1rem;
    padding-bottom: 1rem;
    padding-left: 10vw;
    height: auto;
  }
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary > li.mega-menu-item.mega-toggle-on > a.mega-menu-link {
    background-color: transparent;
  }
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-flyout ul.mega-sub-menu ul.mega-sub-menu {
    padding-left: 1rem;
  }
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-flyout ul.mega-sub-menu ul.mega-sub-menu ul.mega-sub-menu {
    padding-left: 1rem;
  }
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item a.mega-menu-link {
    padding-left: 10vw;
  }
  /*
  Indicators
   */
  #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item-has-children > a.mega-menu-link > span.mega-indicator {
    height: 3rem;
  }
  #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item-has-children > a.mega-menu-link > span.mega-indicator:after {
    content: " ";
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %2333; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat bottom;
    width: 1rem;
    height: 1rem;
    margin-left: 0.5rem;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
  }
  #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item-has-children.mega-toggle-on > a.mega-menu-link > span.mega-indicator:after {
    content: " ";
    transform: translateY(-50%) rotate(270deg);
  }
  #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-flyout li.mega-menu-item a.mega-menu-link > span.mega-indicator {
    float: unset;
    height: 2.3rem;
  }
  #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-flyout li.mega-menu-item a.mega-menu-link > span.mega-indicator:after {
    content: " ";
    width: 0.5rem;
    height: 0.5rem;
  }
}
/*
Very small devices
 */
@media (max-width: 480px) {
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary > li > a.mega-menu-link {
    font-size: 1.4rem;
  }
}
@media (max-width: 320px) {
  body.mega-menu-primary-mobile-open #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary > li > a.mega-menu-link {
    font-size: 1.2rem;
  }
}
/*
Darkmode
 */
body.dark #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-item-has-children > a.mega-menu-link > span.mega-indicator:after {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %23fefefe; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center;
}
body.dark #mega-menu-wrap-primary.mega-menu-wrap #mega-menu-primary li.mega-menu-flyout li.mega-menu-item a.mega-menu-link > span.mega-indicator:after {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %23fefefe; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center;
}

body {
  color: var(--dm-body-color);
  background-color: var(--dm-body-bg);
  height: auto;
}

a {
  color: var(--dm-link-color);
}
a:hover {
  color: var(--dm-link-hover-color);
}

.btn-primary {
  color: var(--dm-white);
  background-color: var(--dm-primary);
  border-color: var(--dm-primary);
}
.btn-primary:hover {
  color: var(--dm-white);
  background-color: #771617;
  border-color: #611213;
}
.btn-primary:focus, .btn-primary.btn-check:focus + .btn-primary {
  color: var(--dm-white);
  background-color: #771617;
  border-color: #611213;
  box-shadow: 0 0 0 0.25rem rgba(205, 38, 40, 0.5);
}
.btn-primary.active, .btn-primary:active, .btn-primary.btn-check:checked + .btn-primary, .btn-primary.btn-check:active + .btn-primary, .btn-primary.dropdown-toggle.show {
  color: var(--dm-white);
  background-color: #611213;
  border-color: #4c0e0f;
}
.btn-primary.active:focus, .btn-primary:active:focus, .btn-primary.btn-check:checked + .btn-primary:focus, .btn-primary.btn-check:active + .btn-primary:focus, .btn-primary.dropdown-toggle.show:focus {
  box-shadow: 0 0 0 0.25rem rgba(205, 38, 40, 0.5);
}
.btn-primary.disabled, .btn-primary:disabled {
  color: var(--dm-white);
  background-color: var(--dm-primary);
  border-color: var(--dm-primary);
}

.btn-outline-primary {
  color: var(--dm-primary);
  border-color: var(--dm-primary);
}
.btn-outline-primary:hover {
  color: var(--dm-white);
  background-color: var(--dm-primary);
  border-color: var(--dm-primary);
}
.btn-outline-primary:focus, .btn-outline-primary.btn-check:focus + .btn-outline-primary {
  box-shadow: 0 0 0 0.25rem rgba(205, 38, 40, 0.5);
}
.btn-outline-primary.active, .btn-outline-primary:active, .btn-outline-primary.btn-check:checked + .btn-outline-primary, .btn-outline-primary.btn-check:active + .btn-outline-primary, .btn-outline-primary.btn-outline-primary.dropdown-toggle.show {
  color: var(--dm-white);
  background-color: var(--dm-primary);
  border-color: var(--dm-primary);
}
.btn-outline-primary.active:focus, .btn-outline-primary:active:focus, .btn-outline-primary.btn-check:checked + .btn-outline-primary:focus, .btn-outline-primary.btn-check:active + .btn-outline-primary:focus, .btn-outline-primary.btn-outline-primary.dropdown-toggle.show:focus {
  box-shadow: 0 0 0 0.25rem rgba(205, 38, 40, 0.5);
}
.btn-outline-primary.disabled, .btn-outline-primary:disabled {
  color: var(--dm-primary);
  background-color: transparent;
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
  font-weight: bolder;
  color: var(--dm-primary);
  margin-bottom: revert;
  -webkit-hyphens: none; /* Safari & Chrome */
  -ms-hyphens: none; /* IE & Edge */
  hyphens: none; /* Standard */
}

.media-copyright {
  display: none;
}

.arrow-before {
  padding-left: 2.5rem;
  position: relative;
}
.arrow-before::before {
  position: absolute;
  left: 0;
  content: "";
  width: 2rem;
  height: 100%;
  background: var(--bsof-arrow-black) no-repeat center;
}

i.bsof-arrow {
  background: var(--bsof-arrow-black) no-repeat center;
  width: 1rem;
  height: 1rem;
  display: inline-block;
  margin-right: 0.5rem;
}
i.bsof-arrow.left {
  transform: rotate(180deg);
}
i.bsof-arrow.light {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %23fefefe; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center;
}
i.bsof-arrow.black {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %2333; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center;
}
i.bsof-arrow.red {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 100 93'%3E%3Cdefs%3E%3Cstyle%3E.cls-1 %7B fill: %23cd2628; %7D%3C/style%3E%3C/defs%3E%3Cg%3E%3Cg id='Ebene_1'%3E%3Cpolygon class='cls-1' points='99 46 54.1 90.9 41.5 90.9 81.9 50.5 1.1 50.5 1.1 41.6 81.9 41.6 41.5 1.2 54.1 1.2 99 46'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center;
}
i.bsof-arrow.small {
  width: 0.5rem;
  height: 0.5rem;
}
i.bsof-arrow.x2 {
  width: 1.5rem;
  height: 1.5rem;
}
i.bsof-arrow.x3 {
  width: 2rem;
  height: 2rem;
}

.badge-xl {
  padding: 0.5rem 1rem;
  font-size: 1rem;
}

/*
Header image aspect ratio on mobile devices (16:9)
 */
@media (max-width: 575px) {
  .aspect-md-16-9 img {
    aspect-ratio: 16/10;
    width: 100%;
    height: auto;
    object-fit: cover;
  }
}
/*
Every image on mobile, except the orchestra image, should have 16:9 on mobile and 21:9 on desktop
 */
img.bsof-header-image, .is-style-cropped-header-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}
@media (max-width: 575px) {
  img.bsof-header-image, .is-style-cropped-header-image img {
    aspect-ratio: 16/10;
  }
}
@media (min-width: 576px) {
  img.bsof-header-image, .is-style-cropped-header-image img {
    aspect-ratio: 21/9;
  }
}

/*
Video Block styling
 */
.custom-video-message {
  position: absolute;
  bottom: 20px;
  left: 20px;
  right: 20px;
  background: rgba(0, 0, 0, 0.7);
  color: white;
  padding: 8px;
  z-index: 10;
}
@media (max-width: 575px) {
  .custom-video-message {
    font-size: 0.8rem;
    padding: 6px;
    bottom: 10px;
    left: 10px;
    right: 10px;
  }
}

.videoWrapper .custom-play-icon-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.videoWrapper .custom-play-icon-wrapper svg {
  max-width: 7vw;
  max-height: 7vw;
}
.videoWrapper .opacity-50 {
  opacity: 1 !important;
}

.otgs-development-site-front-end {
  display: none;
}

/*# sourceMappingURL=bsof.css.map */
