html, body {
  margin: 0;
  padding: 0;
}

body {
  background-color: #fff;
  margin: 0;
  font-family: Arial, sans-serif;
  font-size: 12px;
  font-weight: normal;
  line-height: 13px;
  color: #404040;
}

a { text-decoration: none; color: #000}
a:hover { text-decoration: none; color: #000}

h1 {
  font-family: Georgia;
  font-size: 18px;
  text-transform: uppercase;
  line-height: 20px;
  margin: 0;
}

h2 {
  font-size: 18px;
  line-height: 20px;
  font-weight: normal;
  margin: 0;
}

ul {
  margin: 0;
  padding: 10px 12px;
  font-size: 18px;
  line-height: 20px;
  list-style-type: "* ";
}


section { 
  float: left;
  margin: 50px 0; 
  /*padding: 5%;*/
}

/* images */

.imgz img {
  max-width: 100%;
  height: auto;
}

.description,
.description-top,
.description-right,
.description-bottom {
  margin: 0;
  padding: 0;
}

.description p, .description h1, .description h2, .description h3, .description h4, .description h5, .description h6,
.description-top p, .description-top h1, .description-top h2, .description-top h3, .description-top h4, .description-top h5, .description-top h6,
.description-right p, .description-right h1, .description-right h2, .description-right h3, .description-right h4, .description-right h5, .description-right h6,
.description-bottom p, .description-bottom h1, .description-bottom h2, .description-bottom h3, .description-bottom h4, .description-bottom h5, .description-bottom h6 {
  margin: 0;
  padding: 0;
}

.description-top {
  margin-bottom: 5px;
}

.logo {
  text-align: center;
  margin: 5% 0;
  padding: 0 5% 0 0;
}

.logo img {
  /*width: 90%;*/
  /*max-width: 400px;*/
}

.text-fx {
  /*margin: 5% 0;*/
  text-align: center;
  font-size: 18px;
  line-height: 23px;
  text-transform: uppercase;
}

.lang {
  text-align: center;
  font-size: 18px;
  line-height: 23px;
  text-transform: uppercase;
  margin-top: 20px;
}

.lang a { color: #404040 }

.hidden-caption {
  display: none;
}

.frame {
  clear:both;
  padding-left: 5%;
  padding-right: 5%;
  padding-top: 40px;
  padding-bottom: 20px;
  margin-bottom: 50px;
}

.admin {position: fixed; top: 0; width: 100%; height: 40px; background-color: coral; text-align: center; z-index: 100000}

.thumb img {
  max-width: 200px;
}

.bordered-table {
  border: 1px solid #ddd;
  border-collapse: separate;
  *border-collapse: collapse;
  /* IE7, collapse table to remove spacing */

  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
}
.bordered-table th + th, .bordered-table td + td, .bordered-table th + td {
  border-left: 1px solid #ddd;
}
.bordered-table thead tr:first-child th:first-child, .bordered-table tbody tr:first-child td:first-child {
  -webkit-border-radius: 4px 0 0 0;
  -moz-border-radius: 4px 0 0 0;
  border-radius: 4px 0 0 0;
}
.bordered-table thead tr:first-child th:last-child, .bordered-table tbody tr:first-child td:last-child {
  -webkit-border-radius: 0 4px 0 0;
  -moz-border-radius: 0 4px 0 0;
  border-radius: 0 4px 0 0;
}
.bordered-table tbody tr:last-child td:first-child {
  -webkit-border-radius: 0 0 0 4px;
  -moz-border-radius: 0 0 0 4px;
  border-radius: 0 0 0 4px;
}
.bordered-table tbody tr:last-child td:last-child {
  -webkit-border-radius: 0 0 4px 0;
  -moz-border-radius: 0 0 4px 0;
  border-radius: 0 0 4px 0;
}
table .span1 {
  width: 20px;
}
table .span2 {
  width: 60px;
}
table .span3 {
  width: 100px;
}
table .span4 {
  width: 140px;
}
table .span5 {
  width: 180px;
}
table .span6 {
  width: 220px;
}
table .span7 {
  width: 260px;
}
table .span8 {
  width: 300px;
}
table .span9 {
  width: 340px;
}
table .span10 {
  width: 380px;
}
table .span11 {
  width: 420px;
}
table .span12 {
  width: 460px;
}
table .span13 {
  width: 500px;
}
table .span14 {
  width: 540px;
}
table .span15 {
  width: 580px;
}
table .span16 {
  width: 620px;
}
.zebra-striped tbody tr:nth-child(odd) td, .zebra-striped tbody tr:nth-child(odd) th {
  background-color: #f9f9f9;
}
.zebra-striped tbody tr:hover td, .zebra-striped tbody tr:hover th {
  background-color: #f5f5f5;
}

/* Kleine Screens: Header-Bereiche zentrieren */
@media only screen and (max-width: 799px) {
  .header-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .header-line {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 20px;
    padding-right: 0;
  }

  .logo {
    padding: 0;
  }

  .header-line {
    width: 100vw;
    box-sizing: border-box;
  }

  .text-fx,
  .text-fx.text-fx--narrow {
    max-width: none;
    width: 100%;
    text-align: center;
  }

  .lang {
    text-align: center;
  }

  #js-rotating {
    display: block;
    width: 100%;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Portrait and Landscape */
@media only screen 
  and (min-device-width: 320px) 
  and (max-device-width: 667px) 
  and (-webkit-min-device-pixel-ratio: 2) { 
    
    .logo {
      padding: 0;
    }

    .logo img {
      width: 90%;
      margin: 0 auto;
      /*max-width: 400px;*/
    }

    section { 
      float: left;
      margin: 25px 0; 
      /*padding: 5%;*/
    }
    
}

@media only screen and (min-width: 800px) {

.frame {
      clear:both;
      padding-left: 0;
      padding-right: 0;
      padding-top: 10px;
      padding-bottom: 20px;
      margin-bottom: 50px;
    }

    #container {
      clear: both;
      padding-left: 60px;
      padding-right: 60px;
      padding-top: 40px;
      padding-bottom: 20px;
      margin-bottom: 50px;
    }

    section { 
      margin: 0;
      margin-right: 40px;
      margin-bottom: 30px;
      padding: 0;
    }

    .width100px { width: 100px }
    .width150px { width: 150px }
    .width200px { width: 200px }
    .width250px { width: 250px }
    .width300px { width: 300px }
    .width350px { width: 350px }
    .width400px { width: 400px }
    .width500px { width: 500px }
    .width600px { width: 600px }
    .width700px { width: 700px }
    .width800px { width: 800px }
    .width900px { width: 900px }
    .width1000px { width: 1000px }
    
    section img {
      width: 100%;
      margin: 0;
      max-width: 100%;
    }

    .imgz img {
      width: 100%;
      float: left;
      margin-right: 5px;
      margin-bottom: 4px;
    }

    .description,
    .description-top,
    .description-right,
    .description-bottom,
    .description p, .description h1, .description h2, .description h3, .description h4, .description h5, .description h6,
    .description-top p, .description-top h1, .description-top h2, .description-top h3, .description-top h4, .description-top h5, .description-top h6,
    .description-right p, .description-right h1, .description-right h2, .description-right h3, .description-right h4, .description-right h5, .description-right h6,
    .description-bottom p, .description-bottom h1, .description-bottom h2, .description-bottom h3, .description-bottom h4, .description-bottom h5, .description-bottom h6 {
      margin: 0;
      padding: 0;
    }

    .description-top {
      margin-bottom: 5px;
    }

    a:hover .hidden-caption{
      display: inline;
      font-size: 9px;
      font-family: 'Droid Sans', Arial, sans-serif;
      text-transform: uppercase;
    }
    
    .hidden-caption.top-left{
      top: -15px;
      bottom: 0px;
      left: -10px;
    }
    
    .hidden-caption.top-right{
      top: -15px;
      bottom: 0px;
      right: -10px;
    }
    
    .hidden-caption.bottom-left{
      bottom: -15px;
      left: -10px;
    }
    
    .hidden-caption.bottom-right{
      bottom: -15px;
      right: -10px;
    }
    
    .hidden-caption{
      display: none;
      position: absolute;
      color: #000;
    }

    .header-wrap {
      display: flex;
      align-items: flex-start;
      flex-wrap: wrap;
    }

    .header-line {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      margin-top: 50px;
      flex: 1;
      min-width: 0;
      padding-right: 60px;
      box-sizing: border-box;
    }

    .logo {
      float: none;
      text-align: left;
      margin: 30px 0 0 60px;
    }

    .text-fx {
      float: none;
      display: inline;
      text-align: left;
      padding: 0;
      margin: 0;
    }

    .text-fx.text-fx--narrow {
      max-width: 100px;
    }

    .lang {
      position: static;
      display: block;
      margin-top: 0;
      margin-left: auto;
      text-align: right;
    }


}
