@charset "UTF-8";
/* Reset
-----------------------------------------------------------*/
article, aside, details, figcaption, figure, footer, header, hgroup, hr, menu, nav, section {
  display: block;
}

a, hr {
  padding: 0;
}

abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-style: normal;
  vertical-align: baseline;
  background: 0 0;
  font-weight: normal;
  font-style: normal;
}

ins, mark {
  background-color: #ff9;
  color: #000;
}

body {
  line-height: 1;
}

ul, ol {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:after, blockquote:before, q:after, q:before {
  content: "";
  content: none;
}

a {
  margin: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: 0 0;
}

ins {
  text-decoration: none;
}

mark {
  font-style: italic;
  font-weight: 700;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
}

input, select {
  vertical-align: middle;
}

/* Schriften
-----------------------------------------------------------*/
/* Variablen
-----------------------------------------------------------*/
/* Grundgerüst
-----------------------------------------------------------*/
* {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: Arial, Helvetica, "Helvetica Neue", Geneva, sans-serif;
  color: #223037;
  font-size: 18px;
  background: #fff;
  min-height: 100vh;
  padding-bottom: 4em;
  /* 	min-height: 100vh;
  	display: grid;
  	grid-template-rows: auto 1fr auto;
  */
}

.frame {
  position: relative;
  margin: 0 auto;
  width: 90%;
}

.fullscreen {
  width: 100%;
  height: 100vh;
  overflow: hidden;
  position: absolute;
}

#albin-oergeli {
  position: absolute;
  left: 15%;
  bottom: 20vh;
  width: auto;
  height: 45vh;
  transform-origin: bottom left;
}

#albin-sax {
  position: absolute;
  right: 10%;
  bottom: 0;
  width: auto;
  height: 90vh;
}

#albin-sax source, #albin-sax img {
  width: auto;
  display: inline-block;
  height: 100%;
}

.grid2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: 1fr;
  grid-column-gap: 5%;
  grid-row-gap: 0px;
}

.grid-main {
  display: grid;
  grid-template-columns: 180px 1fr;
  grid-template-rows: 1fr;
  grid-column-gap: 5%;
  grid-row-gap: 0px;
  max-width: 1200px;
}

.grid2-3 {
  display: grid;
  grid-template-columns: 2fr 3fr;
  grid-template-rows: 1fr;
  grid-column-gap: 5%;
  grid-row-gap: 0px;
}

.col2 {
  column-count: 2;
  column-gap: 40%;
  column-width: 100px;
}

.col2 p {
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  break-inside: avoid;
}

body.bg-pilatus::before {
  content: " ";
  display: block;
  background-image: url("../img/bg-pilatus-color.jpg");
  background-position: center;
  background-size: cover;
  height: 100vh;
  width: 100vw;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  position: fixed;
  z-index: -10;
}

.bg-black {
  color: #fff;
  background-color: #000;
}

.bg-dark {
  color: #fff;
  background: #0d0906;
}

/* Allgemeine Formatierungen
-----------------------------------------------------------*/
img {
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid #223037;
}

p,
.content ul {
  line-height: 1.4em;
  margin-bottom: 1.4em;
}

p:last-child,
.content ul:last-child {
  margin-bottom: 0;
}

.content ul li {
  padding: 0 0 0 1.6em;
}

.content ul li:before {
  content: "- ";
  position: relative;
  margin-left: -0.6em;
}

h1, h2 {
  font-weight: bold;
  font-size: 1.4em;
  color: #db8e2e;
  padding-bottom: 1.3em;
  line-height: 1.15em;
}

h2 {
  padding-bottom: 0.3em;
}

h3 {
  font-size: 1.2em;
  line-height: 1.4em;
  font-weight: bold;
}

h3 {
  line-height: 1.4em;
  font-weight: bold;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

/* Buttons
----------------------------*/
button {
  box-shadow: 0px 0px 0px transparent;
  border: 0px solid transparent;
  text-shadow: 0px 0px 0px transparent;
  cursor: pointer;
  -webkit-appearance: none;
}

button:hover {
  box-shadow: 0px 0px 0px transparent;
  border: 0px solid transparent;
  text-shadow: 0px 0px 0px transparent;
}

button:active {
  outline: none;
  border: none;
}

button:focus {
  outline: 0;
}

/* Struktur
-----------------------------------------------------------*/
/* Home
----------------------------*/
.home-zitat {
  position: absolute;
  left: 5%;
  bottom: 4.2em;
  width: 58.4615384615%;
  max-width: 800px;
}

.home-zitat span {
  font-size: 0.66666667em;
}

/* Konzerte
----------------------------*/
.konzert {
  margin-bottom: 2.1em;
}

.konzert .zusatz {
  margin: 0 0 0.25em 0;
}

.konzert h2 {
  padding-top: 0.1em;
  color: #223037;
}

h2 .konzert-zusatz {
  display: block;
  font-weight: normal;
  font-size: 1em;
  padding-top: 0.2em;
  line-height: 1.15em;
}

/* Presse
----------------------------*/
.presse-file, .presse-text {
  margin-bottom: 2.1em;
}

.more-block {
  display: none;
}

.more-block .content {
  padding-top: 0.7em;
}

.open-link {
  display: inline-block;
  color: #db8e2e;
  font-weight: bold;
  line-height: 1.4em;
  border-bottom: none;
}

/* Presse
----------------------------*/
.diskografie-block {
  margin-bottom: 1.4em;
}

/* Header
-----------------------------------------------------------*/
.site-header {
  position: relative;
  height: 11em;
  z-index: 50;
}

.logo {
  display: block;
  width: 90%;
  border: none;
}

.logo h1 {
  padding: 1em 0 0 0;
  font-size: 2.2em;
  font-weight: bold;
  color: #db8e2e;
}

.site-header h2 {
  font-weight: bold;
  font-size: 1.2em;
  line-height: 1.35em;
  color: #223037;
}

.bg-dark .site-header a h2,
.bg-black .site-header a h2 {
  color: #9ca2a5;
}

/* Footer
-----------------------------------------------------------*/
/* Spezifische Formatierungen
-----------------------------------------------------------*/
.yellow-link {
  font-weight: bold;
  display: inline-block;
  color: #db8e2e;
  border: none;
}

.margin-top-negativ {
  margin-top: -0.7em;
}

.hidden {
  display: none;
}

.band-intro {
  margin-bottom: 2.8em;
}

.band-intro a {
  border: none;
}

.platte {
  margin-bottom: 4.2em;
}

.platte a {
  color: #db8e2e;
  border: none;
  font-weight: bold;
}

.video {
  margin-bottom: 4.2em;
}

.video h3 {
  color: #db8e2e;
  margin-top: -0.7em;
}

.video-wrapper {
  position: relative;
  padding-bottom: 56.25%;
  /* This is the aspect ratio */
  height: 0;
  overflow: hidden;
  margin: 0 0 1.4em 0;
}

.video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

.sans-margin-bottom {
  margin-bottom: 0;
}

.foto-block {
  margin-bottom: 2.1em;
}

.aktuell-block {
  margin-bottom: 2.1em;
}

/* Formular
---------------------------------*/
form {
  margin-bottom: 1.4em;
}

.form-block label {
  display: none;
}

label {
  display: block;
  line-height: 1.3em;
  font-weight: bold;
  clear: both;
}

input[type=text], input[type=tel], input[type=number], input[type=email], input[type=date], select, textarea {
  border: none;
  font-family: inherit;
  font-size: 1em;
  padding: 0.25em 0.25em;
  margin: 0 0 1em 0;
  box-sizing: border-box;
  float: left;
  width: 100%;
  max-width: 500px;
  color: #223037;
  height: 1.3em;
}

input[type=submit] {
  margin-top: 0.7em;
  font-family: inherit;
  font-size: 0.95em;
  background: #db8e2e;
  color: #fff;
  padding: 0.25em 0.5em;
  font-weight: bold;
  border: none;
}

::placeholder {
  color: #223037;
  font-size: inherit;
  padding-left: 0.25em;
}

textarea {
  display: block;
  width: 100%;
  height: 10em;
}

.wf-Surname-1 {
  display: none;
}

#form-ok, #form-error {
  display: none;
}

#form-error, #form-ok {
  max-width: 500px;
  clear: both;
}

#form-error {
  padding: 0.7em;
  border: 1px solid #223037;
  margin-bottom: 1.4em;
}

.absendenBlock {
  clear: both;
}

/* Main Navigation
-----------------------------------------------------------*/
.main-nav, .sub-nav {
  margin-top: -0.35em;
  position: relative;
  z-index: 10;
}

.main-nav li a, .main-nav li span, .sub-nav li a {
  border: none;
  font-weight: bold;
  display: inline-block;
  padding: 0.35em 0;
  margin: 0 0 0.7em 0;
  cursor: pointer;
}

.main-nav li a:hover, .main-nav li span:hover, .sub-nav li a:hover {
  color: #db8e2e;
}

.sub-nav li a.back-link {
  font-size: 0.8em;
  margin-top: 5em;
  font-weight: normal;
}

.body-aktuell li#btn01 > a,
.body-konzerte li#btn02 > a,
.body-bands li#btn03 > a,
.body-videos li#btn04 > a,
.body-ueber-mich li#btn05 > span,
.body-audio li#btn06 > a,
.body-kontakt li#btn07 > a,
.body-newsletter li#btn08 > a,
.body-datenschutz li#btn09 > a,
.body-about-biografie #sub-btn01 > a,
.body-about-fotos #sub-btn02 > a,
.body-about-theatermusik #sub-btn03 > a,
.body-about-filmmusik #sub-btn04 > a,
.body-about-diskografie #sub-btn05 > a,
.body-about-presse #sub-btn06 > a,
.body-about-fundstuecke #sub-btn07 > a,
.body-about-auftrittsorte #sub-btn08 > a,
.band-videos a.videos,
.band-presse a.presse,
.band-fotos a.fotos {
  color: #db8e2e;
}

.main-nav ul ul {
  display: none;
  margin: 0 0 1.4em 1.4em;
}

.main-nav ul ul li a {
  font-weight: normal;
  display: inline-block;
  padding: 0.35em 0;
  margin: 0 0 0 0;
}

.body-ueber-mich .main-nav ul ul {
  display: block;
}

.ds-li {
  font-size: 0.8em;
  margin-top: 1.4em;
}

.hamburger {
  position: absolute;
  top: 3em;
  right: 0;
  cursor: pointer;
  display: none;
  width: 35px;
  height: 27px;
  z-index: 100;
}

.hamburger span {
  display: block;
  width: 35px;
  height: 5px;
  margin-bottom: 6px;
  position: relative;
  background: #db8e2e;
  transform-origin: 0% 0%;
  transition: transform 0.5s cubic-bezier(0.77, 0.2, 0.05, 1), background 0.5s cubic-bezier(0.77, 0.2, 0.05, 1), opacity 0.55s ease;
  z-index: 20;
}

.hamburger span:first-child {
  transform-origin: 0% 0%;
}

.hamburger span:nth-last-child(2) {
  transform-origin: 0% 100%;
}

/* Kreuz machen
---------------------------------*/
.hamburger.active span {
  opacity: 1;
  transform: rotate(45deg) translate(-2px, -2px);
  background: #fff;
}

/* Mittlerer Balken verstecken
---------------------------------*/
.hamburger.active span:nth-child(2) {
  opacity: 0;
  transform: rotate(0deg) scale(0.2, 0.2);
}

/* Letzter in die andere Richtung drehen
---------------------------------*/
.hamburger.active span:nth-child(3) {
  transform: rotate(-45deg) translate(-2px, -2px);
}

/*-----------------------------------------------------------------------------------
-------------------------------------------------------------------------------------
MediaQueries
-------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------*/
/* Ende 1200 */
@media screen and (max-width: 1000px) {
  .grid-main {
    display: block;
  }

  #albin-oergeli {
    left: 5%;
    height: 42vh;
  }

  #albin-sax {
    right: 5%;
    bottom: 0;
    width: auto;
    height: 80vh;
  }

  /* Main Navigation
  -----------------------------------------------------------*/
  .hamburger {
    display: block;
    top: 2.5em;
  }

  .main-nav input {
    display: block;
  }

  .nav-wrapper {
    position: fixed;
    width: 100%;
    height: 100%;
    background: #0d0906;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 10;
    display: none;
  }

  .nav-wrapper.open {
    display: block;
  }

  .main-nav {
    position: absolute;
    top: 10em;
    float: none;
    text-align: left;
    width: 100%;
    color: #fff;
    padding: 0 5%;
  }

  .sub-nav li a.back-link {
    margin-top: 0;
  }

  .sub-nav li {
    display: inline-block;
    margin-right: 1em;
  }

  .main-nav li a, .main-nav li span, .sub-nav li a {
    padding: 0.25em 0;
  }
}
/* Ende 1000 */
@media screen and (max-width: 700px) {
  #albin-sax {
    right: 0%;
  }
}
@media screen and (max-width: 600px) {
  body {
    font-size: 16px;
  }

  #albin-oergeli {
    height: 40vh;
    left: -15%;
  }

  #albin-sax {
    right: -10%;
    height: 70vh;
  }

  .grid2, .grid2-3, .grid-main {
    display: grid;
    grid-template-columns: 1fr;
    grid-row-gap: 2.8em;
  }

  .video {
    margin-bottom: 0;
  }

  /* Home
  ----------------------------*/
  .home-zitat {
    left: 5%;
    bottom: 2.8em;
    width: 90%;
  }

  /* Header
  -----------------------------------------------------------*/
  .site-header {
    height: 9em;
  }

  .logo h1 {
    padding: 1em 0 0 0;
    font-size: 2em;
  }

  .site-header h2 {
    font-size: 1.1em;
  }
}
/* Ende 600 */
/* Clearfix
-----------------------------------------------------------*/
.group:after {
  content: "";
  display: table;
  clear: both;
}
