:root {
  --white: #ffffff;
  --nav-grey: #3b3b3b;
  --lol-orange: #FC4F00;
  --gold-dark: #b99000;
  --gold-light: #ecb807;
}

/* cabin-regular - latin */
@font-face {
  font-family: 'Cabin';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/cabin-v18-latin-regular.eot'); /* IE9 Compat Modes */
  src: local(''),
  url('../fonts/cabin-v18-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
  url('../fonts/cabin-v18-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
  url('../fonts/cabin-v18-latin-regular.woff') format('woff'), /* Modern Browsers */
  url('../fonts/cabin-v18-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
  url('../fonts/cabin-v18-latin-regular.svg#Cabin') format('svg'); /* Legacy iOS */
}
/* cabin-700 - latin */
@font-face {
  font-family: 'Cabin';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/cabin-v18-latin-700.eot'); /* IE9 Compat Modes */
  src: local(''),
  url('../fonts/cabin-v18-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
  url('../fonts/cabin-v18-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
  url('../fonts/cabin-v18-latin-700.woff') format('woff'), /* Modern Browsers */
  url('../fonts/cabin-v18-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
  url('../fonts/cabin-v18-latin-700.svg#Cabin') format('svg'); /* Legacy iOS */
}

/* montserrat-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/montserrat-v29-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url('/fonts/montserrat-v29-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  src: url('/fonts/montserrat-v29-latin-800.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-900 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  src: url('/fonts/montserrat-v29-latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

body,
html {
  width: 100%;
  height: 100%;
  overflow-y: scroll;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none;  /* Internet Explorer 10+ */
}

html::-webkit-scrollbar,
body::-webkit-scrollbar { /* WebKit */
  width: 0;
  height: 0;
}

body {
  font-family: 'Cabin'; /* 'Source Sans Pro'; */
  font-size: 1.1rem;
  line-height: 1.9rem;
  background-color: var(--nav-grey);
  color: white;
}

.btn-xl {
  padding: 1.25rem 2.5rem;
}

.content-section {
  padding-top: 7.5rem;
  padding-bottom: 7.5rem;
}

.content-section-heading h2 {
  font-size: 3rem;
}

.content-section-heading h3 {
  font-size: 1rem;
  text-transform: uppercase;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
}

.text-faded {
  color: rgba(255, 255, 255, 0.8);
}

/*  */

.scroll-to-top {
  position: fixed;
  right: 15px;
  bottom: 15px;
  display: none;
  width: 50px;
  height: 50px;
  text-align: center;
  color: white;
  background: rgba(52, 58, 64, 0.5);
  line-height: 45px;
}

.scroll-to-top:focus, .scroll-to-top:hover {
  color: white;
}

.scroll-to-top:hover {
  background: #343a40;
}

.scroll-to-top i {
  font-weight: 800;
}

.masthead {
  min-height: 35rem;
  position: relative;
  display: table;
  width: 100%;
  height: auto;
  padding-top: 8rem;
  padding-bottom: 8rem;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.1) 100%), url("/img/LoL-Clown-Open-Stage-Titelbild.jpg");
  background-position: 22% center;
  background-repeat: no-repeat;
  background-size: cover;
}


.masthead h1,
.masthead h3,
.masthead h2 {
  font-family: Montserrat, "Arial Black", Arial, sans-serif;
  color: white;
  text-shadow: 3px 3px 3px black;
}

.masthead h1 {
  font-size: 2.5rem;
  line-height: 2.0rem;
  font-weight: 900;
  margin: 0;
  padding: 0;
}
.masthead h3 {
  font-weight: 800;
  font-size: 0.9rem;
  margin: .5rem 0 0 -.5rem;
  padding: 0;
}
.masthead h2 {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.7rem;
  margin: 0;
  padding: 0 30px;
  position: absolute;
  width: 100%;
  bottom: 3%;
  left: 0;
  right: 0;
  text-align: center;
}

.masthead .headerH {
  position: absolute;
  top: 47%;
  left: 5%;
}

@media (min-width: 992px) {
  .masthead {
    height: 100vh;
    background-position: center center;
  }
}

@media (min-width: 992px) and (max-width: 1200px) {
  .masthead .headerH {
    position: absolute;
    top: 35%;
    left: 80%;
    transform: translate(-50%, -50%);
  }
  .masthead h1 {
    font-size: 4.0rem;
    line-height: 3.5rem;
  }
  .masthead h3 {
    font-size: 1.2rem;
    margin: .85rem 0 0 2rem;
  }
  .masthead h2 {
    font-size: 2.0rem;
    line-height: 2.0rem;
    margin-bottom: 10px;
  }
}
@media (min-width: 1200px) {
  .masthead .headerH {
    position: absolute;
    top: 27%;
    left: 80%;
    transform: translate(-50%, -50%);
  }
  .masthead h1 {
    font-size: 4.8rem;
    line-height: 3.9rem;
  }
  .masthead h3 {
    font-size: 1.8rem;
    margin: .85rem 0 0 2rem;
  }
  .masthead h2 {
    font-size: 2.5rem;
    line-height: 2.5rem;
    margin-bottom: 20px;
  }
}


/* Menü */


#mainNav {
  font-family: Montserrat, 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 0;
  text-transform: uppercase;
  background-color: rgba(0, 0, 0, 0.5);
}

#mainNav .navbar-toggler {
  font-size: 14px;
  padding: 11px;
  color: white;
  border: 2px solid white;
}

#mainNav .navbar-brand {
  display: none;
  font-weight: 700;
  position: absolute;
  top: -10px;
  text-align: center;
  width: 180px;
}

#mainNav a {
  /*color: white;*/
}

#mainNav .navbar-nav .nav-item a {
  -webkit-transition: background 0.3s ease-in-out;
  -moz-transition: background 0.3s ease-in-out;
  transition: background 0.3s ease-in-out;
  color: #EFEFEF;
  padding: 0 5px;
}

#mainNav .navbar-nav .nav-item a:hover {
  color: white;
  outline: none;
  background-color: transparent;
  text-decoration: none;
}

#mainNav .navbar-nav .nav-item:active,
#mainNav .navbar-nav .nav-item:focus {
  outline: none;
}

@media (min-width: 992px) {
  #mainNav {
    padding-top: 10px;
    padding-bottom: 10px;
    -webkit-transition: background 0.3s ease-in-out, padding-top 0.3s ease-in-out, padding-bottom 0.3s;
    -moz-transition: background 0.3s ease-in-out, padding-top 0.3s ease-in-out, padding-bottom 0.3s;
    transition: background 0.3s ease-in-out, padding-top 0.3s ease-in-out, padding-bottom 0.3s;
    letter-spacing: 1px;
  }
  #mainNav.navbar-shrink {
    padding-top: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--nav-grey);
  }
  #mainNav .nav-link.active {
    outline: 1px solid white;
    /*background-color: rgba(255, 255, 255, 0.3);*/
  }
  #mainNav .nav-link.active:hover {
    color: #1F1F1F;
  }
}

#mainNav span#logo {
  font-family: Cabin, Arial, sans-serif;
  padding: 0;
  display: inline-block;
  text-transform: none;
  font-weight: bold;
  margin: 0;
}

@media (min-width: 992px) {
  img#logo {
    width: 120px;
  }
}
@media (min-width: 576px) and (max-width: 991px) {
  #mainNav ul.navbar-nav {
    margin-top: 20px;
  }
  img#logo {
    width: 60px;
    position: fixed;
    left: 15px;
    top: 8px;
  }
}
@media (max-width: 576px) {
  #mainNav ul.navbar-nav {
    margin-top: 20px;
  }
  img#logo {
    width: 42px;
    position: fixed;
    right: 15px;
    top: 8px;
  }
}

#mainNav.navbar-shrink span#logo {
  font-size: 20px;
  line-height: 20px;
  margin: 16px 0 0 19px;
}

#mainNav.navbar-shrink ul.navbar-nav li:first-child {
  visibility: visible;
}


#mainNav ul.dropdown-menu {
  min-width: 335px;
  margin-top: 12px;
  padding: 10px 0 10px 10px;
  background-color: rgba(0,0,0,0.5);
}

#mainNav .dropdown-toggle::after {
  display: none;
}

@media (max-width: 991px) {
  #mainNav ul.dropdown-menu {
    border: none;
  }
}

.menu-toggle {
  position: fixed;
  right: 15px;
  top: 15px;
  width: 50px;
  height: 50px;
  text-align: center;
  color: #fff;
  background: rgba(52, 58, 64, 0.5);
  line-height: 50px;
  z-index: 999;
}

.menu-toggle:focus, .menu-toggle:hover {
  color: #fff;
}

.menu-toggle:hover {
  background: #343a40;
}

.service-icon {
  background-color: #fff;
  color: #605551;
  height: 7rem;
  width: 7rem;
  display: block;
  line-height: 7.5rem;
  font-size: 2.25rem;
  box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.1);
}

footer.footer {
  padding: 2rem 2rem;
  color: white;
  background-color: #216495;
}

footer.footer .social-link {
  display: block;
  height: 4rem;
  width: 4rem;
  line-height: 4.3rem;
  font-size: 1.5rem;
  background-color: #605551;
  transition: background-color 0.15s ease-in-out;
  box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.1);
}

footer.footer .social-link:hover {
  background-color: #155d74;
  text-decoration: none;
}

a {
  color: var(--gold-dark);
}

a:hover, a:focus, a:active {
  color: var(--gold-light);
}

.btn-primary {
  background-color: #444444 !important;
  border-color: #444444 !important;
  color: #fff !important;
}

.btn-primary:hover, .btn-primary:focus, .btn-primary:active {
  background-color: var(--nav-grey) !important;
  border-color: var(--nav-grey) !important;
}

.btn-secondary {
  background-color: #ecb807 !important;
  border-color: #ecb807 !important;
  color: #fff !important;
}

.btn-secondary:hover, .btn-secondary:focus, .btn-secondary:active {
  background-color: #ba9106 !important;
  border-color: #ba9106 !important;
}

.btn-dark {
  color: #fff !important;
}

.btn {
  box-shadow: 0px 3px 3px 0px rgba(0, 0, 0, 0.1);
  font-weight: 700;
}

.bg-primary {
  background-color: #605551 !important;
}

.text-primary {
  color: #ffffff !important;
}

.text-secondary {
  color: white !important;
}

/* ----- */

.schatten {
  text-shadow: 1px 1px 5px white;
}

/* ----- */

section#lol-open-call .container {
  padding-left:5px;
  padding-right:5px;
}

section#lol-open-call {
  padding: 80px 0;
  color: var(--nav-grey) !important;
}

section#lol-open-call .text-primary {
  color: var(--nav-grey) !important;
}

section#lol-open-call .text-secondary {
  color: var(--nav-grey) !important;
}

/* ----- */


.opengal {
  text-align: center;
  vertical-align: middle;
  cursor: pointer;
}

.opengal img {
  width: 90%;
}

.galToggler {
  height:550px;
  width:100%;
  background-color:var(--nav-grey);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  cursor:pointer;
}

@media (min-width: 1500px) {
  .galToggler {
    height: 650px;
  }
}

@media (min-width: 1900px) {
  .galToggler {
    height: 750px;
  }
}

@media (min-width: 2300px) {
  .galToggler {
    height: 850px;
  }
}

/* ---------------- */

section#kontakt {
  height: auto;
  min-height: auto;
  background-color: #E0E0E0;
}
section#kontakt .section-content {
  position: relative;
  top: 0;
  -webkit-transform: none;
  -ms-transform: none;
  transform: none;
}
section#kontakt h2,
section#kontakt .text-primary{
  padding-top: 50px;
  color: #444444 !important;
}

section#kontakt .service-box.anklickbar {
  cursor: pointer;
  margin: 50px 30px 0 30px;
  padding: 20px 20px 5px 20px;
}
section#kontakt .service-box.anklickbar i {
  padding-top: 0;
}
section#kontakt .service-box.anklickbar:hover {
  outline: 1px solid #D0D0D0;
  border-radius: 10px;
  background-color: #E4E4E4;
}

#datenschutz,
#impressum {
  display: none;
}

#datenschutz h2,
#impressum h2 {
  font-family: 'Open Sans', Arial, sans-serif;
  font-size: 32px;
  font-weight: bold;
}


/* ----- */

.lg-outer .lg-item {
  background-color: #23272b;
}

.lg-outer.darkBg .lg-item {
  background-color: #000;
}

.lg-outer .lg-image {
  max-width: 100vw;
  max-height: 100vh;
  height: inherit !important;
  width: inherit !important;
  object-fit: contain;
}

#lg-zoom-in,
#lg-zoom-out,
#lg-actual-size {
  display: none;
}

.lg-toolbar {
  background-color: transparent;
}

.lg-outer .lg-thumb-item {
  border: 1px solid transparent;
}
.lg-outer .lg-thumb-item.active,
.lg-outer .lg-thumb-item:hover {
  border: 1px solid white;
}

/* ----- */

footer.footer .social-link:hover {
  background-color: var(--gold-dark);
}
footer.footer a:hover {
  color: var(--gold-light);
  text-decoration: underline;
}

.mehrToggler {
  text-decoration: underline !important;
  cursor: pointer;
  color: white !important;
}
.mehrToggler:hover {
  color: #DDDDDD !important;
}
.mehr {
  display: none;
}
.mehrToggler span:nth-child(1) {
  display: none;
}

/* ---- */

.bpgal a {
  display: inline-block;
  transition: opacity 0.2s;
}

.bpgal a:hover {
  opacity: 0.95;
}

div.bpgal {
  width: 100%;
  max-width: 1200px;
  display: table;
  margin: 0 auto;
}

div.bpgal img {
  width: 100%;
  vertical-align: bottom;
}

/* ---- */

a.cta {
  display: inline-block;
  padding: 1.0rem 1.25rem .75rem 1.25rem;
  border-radius: 10rem;
  color: #fff !important;
  text-transform: uppercase;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1.2rem;
  letter-spacing: .1rem;
  transition: all .3s;
  position: relative;
  overflow: hidden;
  z-index: 1;
  cursor: pointer;
}

a.cta:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #0d58e7;
  z-index: -2;
}
a.cta:before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0%;
  height: 100%;
  background-color: #f21405;
  transition: all .3s;
  z-index: -1;
}
a.cta:hover {
  color: #fff !important;
  text-decoration: none;
}
a.cta:hover:before {
  width: 100%;
}

.ctaFootnote {
  color: #f21405;
  font-size: 11px;
  margin: 0;
  padding: 0 0 0 10px;
}

/* ---- */

.glow {
  font-family: Montserrat, "Arial Black", Arial, sans-serif;
  font-weight: bold;
  font-size: 1rem;
  line-height: 1rem;
  width: 100px;
  height: 100px;
  border: none !important;
  outline: none !important;
  color: #fff;
  background: #f21405;
  cursor: pointer;
  position: absolute;
  top: 53%;
  left: 52%;
  z-index: 0;
  border-radius: 50px;
}

@media (max-width: 991px) {
  .glow {
    width: 80px;
    height: 80px;
    border-radius: 40px;
    font-size: .8rem;
    line-height: .8rem;
    top: 70%;
    left: 8%;
  }
}

.glow:before {
  content: '';
  background: linear-gradient(45deg, #ff0000, #ff7300, #fffb00, #48ff00, #00ffd5, #002bff, #7a00ff, #ff00c8, #ff0000);
  position: absolute;
  top: -5px;
  left:-5px;
  background-size: 400%;
  z-index: -1;
  filter: blur(5px);
  width: calc(100% + 10px);
  height: calc(100% + 10px);
  animation: glowing 20s linear infinite;
  transition: opacity .3s ease-in-out;
  border-radius: 50px;
}

@media (max-width: 991px) {
  .glow:before {
    border-radius: 40px;
  }
}

.glow:active,
.glow:hover {
  color: #000;
  border: none !important;
  outline: none !important;
}

.glow:active:after,
.glow:hover:after {
  background: transparent;
}

.glow:after {
  z-index: -1;
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  background: #f21405;
  left: 0;
  top: 0;
  border-radius: 50px;
}

@media (max-width: 991px) {
  .glow:after {
    border-radius: 40px;
  }
}

@keyframes glowing {
  0% { background-position: 0 0; }
  50% { background-position: 400% 0; }
  100% { background-position: 0 0; }
}