/*========================================================
        Sattig / Architektur
        1. Allgemeine HTML-Elemente
========================================================*/
/*

## netter effekt
.galerieTitel {
    ...
    background-attachment: fixed;



#mainnavi ???

*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
    background: none repeat scroll 0 0 transparent;
    border: 0 none;
    margin: 0;
    outline: 0 none;
    padding: 0;
    vertical-align: baseline;
}
html {
    height: 100%;
    /*font-size: 16px;*/
    font-size: 20px;
    /* SPINNER */
    background-color: #fff;
    background-attachment: fixed;
    background-position: center center; 
    background-repeat: no-repeat;
    background-image: url('../pix/spinner.gif'); 
}

body {
    background-color: #fff;
    color: #000;
    font-family: 'Roboto', Arial, sans-serif;
    font-weight: 300;
    z-index: -32; /* damit body unter #heldIos liegt (sonst überdeckt bg-color von body #heldIos)*/
    height: 100%;
    line-height: 1.375;
    position: relative;
    /* bei position fixed ist schrift im safari dünner*/
    /*http://stackoverflow.com/questions/22204752/mac-safari-font-rendering-changes-thinner-when-any-element-on-the-page-gets-posi*/
    -webkit-font-smoothing: subpixel-antialiased;
}
h1, h2, h3 {
	font-family: 'Montserrat', Arial, sans-serif;
      
}

h1, h2 {
    margin: 0px;
    margin-bottom: .5em;
    font-weight: 300;
    font-size: 4rem; /* 4rem */
    text-transform: uppercase;
      
}
h1 .subline,
h2 .subline {
    display: block;
    font-size: .6em;
    padding: 0;
    margin: 0;
    margin-top: -.2em;
}   
h1 { /* titel! */
    font-size: 8rem; /* 5rem;*/
}

h2 { 
    margin-bottom: .5em; 
    text-transform: uppercase;
    font-size: 3.5rem;
    font-weight: 100;
}  /* ca. 20px  120%*/ 

h3 { 
    margin-bottom: .5em; 
    text-transform: uppercase;
    font-size: 3rem;
    font-weight: 100;
}  /* ca. 20px  120%*/ 
h3 .subline {
    display: block;
    font-size: .8rem;
    line-height: 1;
}

h4 {    
    font-size: 1.5rem;
    margin-bottom: 0em; 
    text-transform: uppercase;
    font-weight: 100;
     }  /* ca. 18px */  
h5 { font-size: 1.05rem; }   /* ca. 16px */ 
h6 { font-size: 1.02rem; }  /* ca. 14px */

ol, ul {
    list-style: none outside none;
}

div {
    overflow: visible;
}

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

a:visited { color: #000;}

a:hover, a:focus {  text-decoration: none;}

a:active{   color: #000;}

a { text-decoration: none; outline: none;}/* outline entfernt beim klicken den gepunkteten rahmen um den link*/

p, ul {
    font-size: 1.2rem; /*ex 1.2rem;  wegen zuwenig text vergrößert*/
    word-spacing: .1rem;
    margin: 0;
    text-align: left;
    margin-bottom: 1em;
}

ul ul {
    margin: 0;
    margin-left: 1em;
}

li {
    margin-top: 0;
    margin-right: 0;
    margin-bottom: 0;
    margin-left: 0;
}
img {
	border: none;
}


.kursiv {
    font-style: italic;
}
 
.fett {
    font-weight: bold; 
}

.zentriert {
    text-align: center;
}
.unterstrichen {
    text-decoration: underline;
}
 
.schatten {
    -moz-box-shadow: 0 0 25px rgba(0,0,0,0.3);
    -webkit-box-shadow: 0 0 25px rgba(0,0,0,0.3);
    box-shadow: 0 0 25px rgba(0,0,0,0.3);
}

.floatLeft {
    float: left;
}

.floatRight {
    float: right;
}
/* micro clearfix
http://nicolasgallagher.com/micro-clearfix-hack/ */
.cf:before,
.cf:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}
.cf:after {
    clear: both;
}
/**  http://nicolasgallagher.com/micro-clearfix-hack/
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */
.cf {
    *zoom: 1;
}

.lazy { /* lazy load per default ausgeblendet, wird nir bei aktivem js eingeblendet 
            in custom.js  ->  $("img.lazy").show().lazyload({... */
    display: none;
}

.unsichtbar {
    display: none;
}

/*========================================================
        2. DIV-Bereiche
========================================================*/




#header {
    z-index: 932;
    position: absolute;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100px;
    text-align: center;
    display: block;
    background-color: #fbfbfb;
       -moz-box-shadow: 0 0 25px rgba(0,0,0,0.3);
    -webkit-box-shadow: 0 0 25px rgba(0,0,0,0.3);
            box-shadow: 0 0 25px rgba(0,0,0,0.3);
}

#logo {
    position: absolute;
    top: 15px;
    left: 15%;
    -webkit-transition: all 0.3s ease 0s;
       -moz-transition: all 0.3s ease 0s;
        -ms-transition: all 0.3s ease 0s;
         -o-transition: all 0.3s ease 0s;
            transition: all 0.3s ease 0s;
}


#logo a:link { }

#logo a:visited { }

#logo a:hover { }

#logo a:focus { }

#logo a:active { }

#logo a {     
    color: #fff;
}
#logo a img {
    height: 70px;
    width: auto;
    -webkit-filter: drop-shadow(0px 0px 5px rgba(255,255,255, .8));
    filter:         drop-shadow(0px 0px 5px rgba(255,255,255, .8)); 
}

#logoWortmarke {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

#logoWortmarke img {
    opacity: 0;
    height: 50px;
    width: auto;
    margin-top: 23px;

    -webkit-transition: all 0.8s ease 0s;
       -moz-transition: all 0.8s ease 0s;
        -ms-transition: all 0.8s ease 0s;
         -o-transition: all 0.8s ease 0s;
            transition: all 0.8s ease 0s;

}
#logoWortmarke.sichtbar img {
    opacity: 1;
}


#ios { /* display -IOS neben LOGO wenn ios*/
    display: none;
}

#menueHolder { 
    position: absolute; /* ex RELATIVE*/
    position: fixed;
    right: 0;
    top: 25px;
    width: 100%; 
    /*height: 100%; */
    margin-left:auto; 
    margin-right: auto; 
    /*background: #17B5EB;*/
}
#header.weiss #menueHolder { 
height: initial;
}

input#hamburger { display: none; }
label.hamburger {
    display: block;
    width: 1.3em;
    height: 1em;
    position: relative;
    position: absolute;
    right: 15%; 
    /*padding: 1em; clickbereich vergrößern*/
    cursor: pointer;
    padding: 10px;
    z-index: 100;
    text-align: center;
    margin-top: -5px;
}

.hamburger {
    text-align: right;
    font-family: "Roboto";
    color: #000;
    padding-top: .2rem;
    font-size: 2rem;
}

.hamburgerLinie { 
    display: block; 
    position: absolute; 
    right: 0;
    margin-right: 10px;
    height: 5px; /*5px*/
    width: 40px; 
    background: #000;
    /*border-radius: 2px;*/
    transition: 0.3s; 
    transform-origin: center; 
    /*box-shadow: 0 0 5px rgba(255,255,255,.8);*/
}

#hamburgerLinie1 { top: 12px; }
#hamburgerLinie2 { top: 24px; }
#hamburgerLinie3 { top: 36px; }

    
#hamburger:checked + .hamburger #hamburgerLinie1 {
    transform: translateY(12px) rotate(-45deg);
}

#hamburger:checked + .hamburger #hamburgerLinie2 {
    opacity: 0;
}

#hamburger:checked + .hamburger #hamburgerLinie3 {
    transform: translateY(-12px) rotate(45deg);
}

#menue { 
    height: 0; 
    margin-top: -3.3rem; /*-8rem;*/
    padding-top: 8rem;
    /* damit menue oben den #navi bereich überdeckt  aber logo liegt drüber*/
    max-height: 0; 
    overflow: hidden; 
    background: rgba(255,255,255,.0); /* entweder scrollIn oder fade In */
    text-align: center;
    transition: all .3s; 
}
header.weiss #menue { 
    background: rgba(255,255,255,.9); /* entweder scrollIn oder fade In */
}

#hamburger:checked + .hamburger  + #menue { 
    height: 3000px;    
    height: 100vh;
    /* krücke weil #menueholder darf nicht height:100% sein, sonst überdeckt er steuerelemete von slideshow. 
    so "dehnt" #menue den #menueholder nur bei #hamburger:checked  */
    max-height: 0;
    max-height: 100%; /* entweder scrollIn oder fade In */
    background: rgba(255,255,255,.9); 
}

#menue ul { 
    width: 12em;
    display: inline-block;
    padding: 0 20px;
    margin-bottom: 0;
}
#menue ul li { 
    text-align: center;
    list-style-type: none; 
    color: white; 
    border-top: 4px solid #000; 
    padding: .2em 0;
}
#menue ul li:last-child {
    border-bottom: 0;
}

#menue ul li a { 
    font-weight: 500;
    font-size: 1.5rem;
    text-transform: uppercase;
    text-shadow: 0 0 10px rgba(255,255,255,.5);
    color: #000; 
    text-decoration: none; 
    display: block;
    margin: 0 1em;
    margin-bottom: .3em;
    transition: all .3s;
}

#menue ul li a:link { }

#menue ul li a:visited { }

#menue ul li a:hover { 
    margin-left: 0;
}

#menue ul li a:focus { }

#menue ul li a:active { }

#menue ul li a { }

#navi { 
    position: relative;
    margin: 0 auto;
    padding-top: 10px;
    z-index: 100;
    text-align: center;
}

#slideshowHolder {
    position: relative;
    width: 100%;
    height: 100%;
}

#slideshow {
    position: absolute;
    position: fixed;
    top: 0 ;
    left: 0;
    width: 100%;
    height: 100%;
    z-index:0;/*-1*/
    overflow: hidden; /* sonst kommt vertikaler scrollbalken bei sliding*/
}
#slideshow.isIOS { /* bei ios kein position fixed*/
    position: absolute;
}

body.projektSeite #slideshowHolder,
body.projektSeite #slideshow {
    height: 0;
    padding-top: 33%; /* ex 25%*/
    min-height: 200px;
}

#slideshow #slideLogo {
    box-sizing: border-box;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    height: auto;
    padding: 5% 80px;
    z-index: 800;
}
#slideshow #slideLogo h1 {
    text-align: center;
    margin: 0;
}
#slideshow #slideLogo h1 img {
    width: 100%;
    max-width: 700px;
    background: rgba(0,0,0,.2);
    box-shadow: 0px 0px 85px 85px rgba(0,0,0,.2);
}

#slideshow #filmStoerer {
    width: 200px;
    position: absolute;
    right: 50px;
    bottom: 20px;
    z-index: 800;
    -moz-transform: rotate(10deg);
    -ms-transform: rotate(10deg);
    -o-transform: rotate(10deg);
    -webkit-transform: rotate(10deg);
    transform: rotate(10deg);
}
#slideshow #filmStoerer a img {
    width: 100%;
    height: auto;
}

#slideshow .slide {
    position: absolute; /*ex fixed*/
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    min-height: 100%; /*2check ob noetig*/

}

#slideshow .slide.active {
    z-index: 10;
    opacity: 1.0;
}
#slideshow .slide.last-active { /*WICHTIG sonst hakt es beim letzten Slide */
    z-index: 9;
}



/*für CHROME !!!! */
#slidesHolder.notIOS {  /*notIOS wird bei IOS entfernt und somit keine animation auf IOS */
    position: absolute;
    top: 0 ;
    left: 0;
    width: 100%;
    height: 100%;
    z-index:0;/*-1*/
    overflow: hidden; /* sonst kommt vertikaler scrollbalken bei sliding*/
}

#slideshow .nachUnten {
    position: absolute;
    bottom: 70px;
    width: 100%;  
    display: block;            
    z-index: 30;
    text-align: center;

}
#slideshow .nachUnten img {
    width: 45px;
    height: 25px;
    -webkit-filter: drop-shadow(0px 0px 8px rgba(0,0,0, .8));
    filter:         drop-shadow(0px 0px 8px rgba(0,0,0, .8)); 
}

body.noSlideshow #vor {
    display: none;
}

#vorHolder {
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
    width: 100px;
    z-index: 855;
}

#vorHolder img {
    width: auto;
    height: 100px;
    position: absolute;
    top: 50%;
    margin-top: -55px; 
    left: 40px;
    -webkit-filter: drop-shadow(0px 0px 8px rgba(0,0,0, .8));
    filter:         drop-shadow(0px 0px 8px rgba(0,0,0, .8)); 
}

body.noSlideshow #zurueck {
    display: none;
}

#zurueckHolder {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100px;
    z-index: 855;
}

#zurueckHolder img {
    width: auto;
    height: 100px;
    position: absolute;
    top: 50%;
    margin-top: -55px;
    right: 40px;
    -webkit-filter: drop-shadow(0px 0px 8px rgba(0,0,0, .8));
    filter:         drop-shadow(0px 0px 8px rgba(0,0,0, .8)); 
}

.held {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    min-height: 100%; /*2check ob noetig*/
    text-align: center;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

#inhalt {
    width: 100%;   
    position: relative;
    padding-top: 2rem; /*4rem*/
    background-color: #fff;
    text-align: center;
    z-index: 10;
}

body.projektSeite #inhalt {
    padding-top: 4rem;
}

#mainNaviHolder { 
    position: relative;

}

#inhalt #mainNavi { 
    width: 100%;
    height: 150px;
    margin-top: 0;
    background-color: #000;
    padding: 50px 0;
    z-index: 100;
    text-align: center;
}
#inhalt #mainNavi h2 { 
    font-size: 4rem;
    color: #fff;
}
#inhalt #mainNavi ul {
    position: relative;
    display: inline;
    margin: 0;
} 
#inhalt #mainNavi li {
    display: inline;
    font-size: 1.3rem; /*1.5vw*/
    font-weight: 100;
    color: #fff;
    letter-spacing: .04em;
    list-style-type: none;
    margin: 0 1rem;
    text-transform: uppercase;
}

#inhalt #mainNavi li a:link { }

#inhalt #mainNavi li a:visited { }

body.newsSeite #inhalt #mainNavi li a#newsLink,
#inhalt #mainNavi li a:hover { 
    border-bottom: 1px solid rgba(255, 255, 255, 1);
    padding-bottom: .2rem;
}

#inhalt #mainNavi li a:focus { }

#inhalt #mainNavi li a:active {   }

#inhalt #mainNavi li a { 
    white-space: nowrap;
    color: #fff;    
    padding: 0 .2rem;
    border-bottom: 2px solid rgba(255, 255, 255, 0);
    outline: none;/* outline entfernt beim klicken den gepunkteten rahmen um den link*/

    -webkit-transition: all 0.2s ease 0s;
       -moz-transition: all 0.2s ease 0s;
        -ms-transition: all 0.2s ease 0s;
         -o-transition: all 0.2s ease 0s;
            transition: all 0.2s ease 0s;
            /*hover fehler bei safari. es bleibt nach mouseout eine helle linie unter <a>
http://stackoverflow.com/questions/9983520/webkit-animation-is-leaving-junk-pixels-behind-on-the-screen*/
            outline: 1px solid transparent;
    }

#subNavi { 
    position: relative;
    margin: 0 auto;
    z-index: 0;
    margin-bottom: 4rem;
    text-align: center;
}

#subNavi ul {
    position: relative;
    display: inline;
    margin: 0;
    z-index: 101;
} 

#subNavi li {
    display: inline;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: .04em;
    list-style-type: none;
    margin: 0 1.5rem;
    text-transform: uppercase;
}

#subNavi li a:link { }

#subNavi li a:visited { }

#subNavi li a:hover { 
    border-bottom: 3px solid rgba(0, 0, 0, 1);
    padding-bottom: .2rem;
}

#subNavi li a:focus { }

#subNavi li a:active { }

#subNavi li a {     
    padding: 0 .2rem;
    border-bottom: 3px solid rgba(0, 0, 0, 0);
    outline: none;/* outline entfernt beim klicken den gepunkteten rahmen um den link*/

    -webkit-transition: all 0.2s ease 0s;
       -moz-transition: all 0.2s ease 0s;
        -ms-transition: all 0.2s ease 0s;
         -o-transition: all 0.2s ease 0s;
            transition: all 0.2s ease 0s;

    /*hover fehler bei safari. es bleibt nach mouseout eine helle linie unter <a>
http://stackoverflow.com/questions/9983520/webkit-animation-is-leaving-junk-pixels-behind-on-the-screen*/
            outline: 1px solid transparent;
    }

.zeile {
    position: relative;
    max-width: 720px; /*ex 960 wegen wenig text verkleinert*/
    max-width: 960px;
    max-width: 1500px;
    padding: 0 2em;
    background-color: rgba(255,255,255, .0);
    margin: 0px auto;
    text-align: center;
}
body.projektSeite .zeile,
body.impressumSeite .zeile,
body.datenschutzSeite .zeile { /* wegen #projekteText */
    text-align: left;
}

.galerieHolder {
    text-align: left;
    margin-bottom: 100px;
}

.linkOffset { 
    border: 0!important;
}


#subNavi  a.linkOffset,
.zeile #portfolio.fliesstext .linkOffset,
#inhalt a.linkOffset,
#inhalt .galerieHolder a.linkOffset,
#ueberuns  a.linkOffset,
#kontakt  a.linkOffset { /* "#inhalt" wichtig um spezifizität zu erhönen. 
                                        sonst werden eigenschaften durch "#inhalt a" überschrieben */
    border: 0!important;
    padding: 0;
    border: none;
    -webkit-transition: none;
       -moz-transition: none;
        -ms-transition: none;
         -o-transition: none;
            transition: none;

    padding-top: 120px;
    margin-top: -120px;
    position: relative;
    display: block;
    visibility: hidden;
}

.galerieHolder h3 { 
    font-size: 2.5rem;
    font-weight: 300;
    padding-left: 5px;/* wegen abstand zwischen den galerie items -> li.galerie a*/
    margin-bottom: .5em;
}
.galerieHolder h3 span { 
    padding-top: .1em;
    border-top: 4px solid #000;
}

.galerieHolder ul {
    width: 100%;
    display: block;
    margin-bottom: 1em; /* weg wegen p.nachObenKlein */
}

.galerieHolder p.nachObenKlein {
    text-align: right;
    text-align: center;
    margin-bottom: 4em;

}
.galerieHolder p.nachObenKlein img {
    width: 40px;
    height: 25px;
}

li.galerie {
    width: 25%;
    margin: 0;
    display: inline-block;
    position: relative;
    overflow: hidden;
}
li.galerie a:link { }

li.galerie a:visited { }

li.galerie a:hover { 
    padding: 0px !important;
    border:0 !important;
}

li.galerie a:focus { color: #000;}

li.galerie a:active { color: #000;}

li.galerie a {  
    display: block;
    padding: 0px !important;
    border: 0 !important;
    margin: 5px;
    overflow: hidden;
    box-shadow: 0 0 6px 0 rgba(0,0,0,0.3);
}

li.galerie img {
    width: 100%;
    height: auto;
}
/* Gray Scale */
li.galerie a img {
  -webkit-filter: grayscale(100%);
     -moz-filter: grayscale(100%);
      -ms-filter: grayscale(100%);
       -o-filter: grayscale(100%);
          filter: grayscale(100%);
      -webkit-transform: scale(1);
          -ms-transform: scale(1);
              transform: scale(1);
    
-webkit-transition: .2s ease-in-out;
   -moz-transition: .2s ease-in-out;
    -ms-transition: .2s ease-in-out;
     -o-transition: .2s ease-in-out;
        transition: .2s ease-in-out;

}
li.galerie a:hover img {
  -webkit-filter: grayscale(0%);
     -moz-filter: grayscale(0%);
      -ms-filter: grayscale(0%);
       -o-filter: grayscale(0%);
          filter: grayscale(0%);
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
}

li.galerie .neuBatch {  
    position: absolute;
    bottom: 5px;
    right: 5px;
    background-color: #fff;
    color: #000;
    padding: 0.05em 0.5em;
    font-weight: 400;
    font-size: 1.2rem;
    text-transform: uppercase;
    letter-spacing: .1em;

}



/* overlay */
.galerieBildOverlay {
    position: absolute;
    top: 100%;
    left: 5px;
    right: 5px;
    bottom: 5px;
    opacity: 0;
    background-color: rgba(0,0,0,.2);

-webkit-transition: .2s ease-in-out;
   -moz-transition: .2s ease-in-out;
    -ms-transition: .2s ease-in-out;
     -o-transition: .2s ease-in-out;
        transition: .2s ease-in-out;
}
li.galerie a:hover .galerieBildOverlay {
    top: 5px;
    opacity: 1;

}

.galerieBildOverlay p {
    display: table;
    color: #fff;
    font-size: .9em;
    font-weight: 400;
    font-size: 1.4rem;
    width: 100%;
    height: 100%;
    padding:0;
    margin: 0;
}
.galerieBildOverlay p span {
    display: table-cell;
    width: 100%;
    height: 100%;
    text-align: center;
    vertical-align: middle;
    text-shadow: 2px 2px 10px rgba(0,0,0,.8), -2px -2px 10px rgba(0,0,0,.8);
}



#projekte {
    position: relative;
}
#projekte h2,
body.ueberunsSeite #projekte h3 {
    margin-bottom: 0;
    font-weight: 300;
    letter-spacing: .05em;
}



#projekteText {
/*    float: left;

width: 50%;*/ /* muss noch genau ermittelt werden!! ist damit das bild nicht bei breitem screen zwischen
die gefloateten elemente #projekteText und #projekteDaten "hochrutscht" */

/* ODER */
    display: inline-block;
    margin-bottom: 2rem;
    min-height: 8em;
}
body.ueberunsSeite #projekteText {
    margin-top: 4em;
}

#projekteText #projekteName h2,
body.ueberunsSeite #projekteText #projekteName h3 {
    font-size: 1.5rem;
    text-align: left;
}
#projekteText h2 span.schmuckLinie,
body.ueberunsSeite #projekteText h3 span.schmuckLinie  {
    padding-top: .5em;
    border-top: 3px solid #000;
}

#projekteText h2 span.projekteNameKategorie,
body.ueberunsSeite #projekteText h3 span.projekteNameKategorie{
    color: #666;
}

#projekteDaten {
    float: right;
    background-color: #fff;
    padding: 1em;
    padding-top: 0;
    padding-right: 0;
    line-height: 1;
}

#projekteDaten table {
    wqqidth: 100%;
    text-align: left;
}
#projekteDaten caption {
    padding-left: 2px;
    text-align: left;
    font-weight: 500;
}

#projekteDaten td.beschreibung {
    padding-right: 3em;
}


#projektBeschreibung {
    padding-bottom: 2em;
}

.projekteBilder {
    margin-bottom: 4rem;
}
.projekteBilder img {
    max-width: 100%;
    height: auto;
    box-shadow: 0 0 25px rgba(0,0,0,0.3);
}

.projekteBilderLinks {
    text-align: left;
    padding-left: 10%;
}
.projekteBilderLinks img {/* damit projekteBilderBeschreibung etwas abstand hat von bild */
    margin-right: 1em;
}

.projekteBilderRechts {
    text-align: right;
    direction: rtl; /* damit text VOR bild angezeigt wird, aber im quelltext danach stehen kann 
                        weil im mobil soll er ja darunter angeteigt werden */
    padding-right: 10%;
}

.projekteBilderRechts img,
.projekteBilderMitte img {/* damit projekteBilderBeschreibung etwas abstand hat von bild */
    margin-left: 1em; 
}


.projekteBilderMitte {
    text-align: center;
    direction: rtl; /* damit text VOR bild angezeigt wird, aber im quelltext danach stehen kann 
                        weil im mobil soll er ja darunter angeteigt werden */
}
.projekteBilderGanzeBreite {
    text-align: left;
    padding:0 10%;
}
.projekteBilderGanzeBreite img {/* damit projekteBilderBeschreibung etwas abstand hat von bild */
    margin-bottom: 1em;
    width: 100%;
}

.projekteBilder .projekteBilderBeschreibung {
    display: inline-block;
    width: 12em;
    padding-top: .5em;
}
#projekte .zeile .projekteBilder .projekteBilderBeschreibung p {/* .projekte etc um spezifität zu erhöhen */
    font-size: .8em;
    font-weight: 500;
}
.projekteBilderLinks .projekteBilderBeschreibung p {
    text-align: left;
}
.projekteBilderRechts .projekteBilderBeschreibung p,
.projekteBilderMitte .projekteBilderBeschreibung p {
    text-align: right;
}


#projekte .fliesstext {
    float: left;
    padding: 0;
    padding-top: 6rem;
    padding-bottom: 6rem;
}

#projekte .zeile h2 {
    text-align: left;
}
body.ueberunsSeite #projekte .zeile h2 {
    text-align: center;
    /*margin-bottom: 1em;*/
}

#projekte .zeile p {
    font-size: 1.1rem;
    letter-spacing: .03rem;
}





#ueberuns {
    position: relative;
    z-index: 10;
    overflow-x: hidden;
}

#ueberunsText {
    opacity:   1;
}

#ueberunsText h2 {
    font-size: 2rem;
    text-align: left;
}
#ueberunsText h2 span {
    padding-top: .5em;
    border-top: 3px solid #000;
}

#ueberuns #ueberunsSpalteRechts p {
    padding-right: 6rem; /* so wie bei #ueberunsText h2 */
}
#ueberuns #ueberunsSpalteLinks {
   width: 33.333333%
}
#ueberuns #ueberunsSpalteRechts {
   width: 66.666666%
}
#ueberuns .fliesstext {
    float: left;
    padding: 0;
    padding-top: 6rem;
    padding-bottom: 6rem;
}

#ueberuns .zeile h2 {
    padding-right: 40%;
    text-align: left;
}

#ueberuns .zeile p {
    font-size: 1.1rem;
    letter-spacing: .03rem;
}



#kontakt {
    position: relative;
    z-index: 10;
    overflow-x: hidden;
    background-color: #f2f2f2;
}

#kontaktText {
    opacity:   1;
}

#kontaktText p {
	font-weight: 400;
}

#kontaktText h2 {
    font-size: 2rem;
    text-align: left;
    /*padding-left: 6rem;  so wie bei #kontakt #kontaktSpalteRechts p */
}
#kontaktText h2 span {
    padding-top: .5em;
    border-top: 3px solid #000;
}

#kontakt #kontaktSpalteLinks #kontaktLogo {
    text-align: left;
    margin-top: -1.5em;
}
#kontakt #kontaktSpalteLinks #kontaktLogo img {
    width: 200px;
    height: auto;
}



#kontakt #kontaktSpalteRechts p {
    padding-right: 6rem; /* so wie bei #kontaktText h2 */
}
#kontakt #kontaktSpalteLinks {
    /*width: 33.333333%;*/
    width: 25%;
}
#kontakt #kontaktSpalteRechts {
    /*width: 66.666666%;*/
    width: 75%;
}
#kontakt #kontaktSpalteRechts p {
    width: 33.333333%;
    float: right;
    padding: 0;
    text-align: right;
}

#kontakt #kontaktSpalteRechts p#spalte2 {
    text-align: center;
}
#kontakt #kontaktSpalteRechts p#spalte3 {
    text-align: left;
}

#kontakt #kontaktSpalteRechts #kontaktText p span {
    display: inline-block;
    border-top: 3px solid #000;
    padding-top: .8em;
}




#kontakt .fliesstext {
    float: left;
    padding: 0;
    padding-top: 6rem;
    padding-bottom: 6rem;
}

#kontakt .zeile h2 {
    padding-right: 40%;
    text-align: left;
}

#kontakt .zeile p {
    font-size: 1.1rem;
    letter-spacing: .03rem;
}





#footer {
    position: relative;
    z-index: 10;
    background-color: #f2f2f2;
    color: #0000;
    font-size: .8rem;
    font-weight: 300;
    margin: 0;
    padding: 0;  
}
#footer .zeile {
    border-top: 3px solid #000;
    padding-top: 2rem;
    padding-bottom: 2rem
}



#footer p {
    margin: 0;
    color: #000;
    font-size: .8rem;
    font-weight: 400;
    letter-spacing: .06rem;
    text-align: center;
    vertical-align: center;
}

#footer span.floatLeft {
    font-family: 'Montserrat', Arial, sans-serif;
    font-weight: 300;
    text-transform: uppercase;
    margin: 0;
    padding: 0;
}
#footer span.floatLeft span {
    margin: 0 .1rem;
}

#footer a:link { color: #000;}

#footer a:visited { color: #000;}

#footer a:hover { 
    color: #000;
    text-decoration: underline;
}
#footer a:focus { color: #000;}

#footer a:active { color: #000;}

#footer a {  
    color: #000;
    outline: none;/* outline entfernt beim klicken den gepunkteten rahmen um den link*/

}


#nachOben {
    position: absolute;
    position: fixed;
    z-index: 9658;
    bottom: 50px;
    right: 50px;

}
#nachOben a img {
    width: 60px;
    height: auto;
}

#inhalt #nachOben a:link { }

#inhalt #nachOben a:visited { }

#inhalt #nachOben a:hover { 
    border-bottom: none;
    padding-bottom: 0;
}

#inhalt #nachOben a:focus { }

#inhalt #nachOben a:active {   }

#inhalt #nachOben a { 
    padding: 0;
    border-bottom: none;
    outline: none;/* outline entfernt beim klicken den gepunkteten rahmen um den link*/
    -webkit-transition: none;
       -moz-transition: none;
        -ms-transition: none;
         -o-transition: none;
            transition: none;
    }


body.impressumSeite #slideshowHolder, 
body.impressumSeite #slideshow,
body.datenschutzSeite #slideshowHolder, 
body.datenschutzSeite #slideshow
 {
    height: 0;
    padding-top: 20%;
    min-height: 200px;
}
body.impressumSeite #slideshowHolder .nachUnten,
body.impressumSeite #slideshowHolder .nachUnten {
    display: none;
}

body.impressumSeite #projekteText #projekteName h2,
body.datenschutzSeite #projekteText #projekteName h2 {
    font-size: 2rem;
    text-align: left;
}


body.impressumSeite h3,
body.datenschutzSeite h3  {
    font-size: 1.3rem;
    text-align: left;
    text-transform: none;
    font-weight: 400;

}

body.impressumSeite h4,
body.datenschutzSeite h4  {
    font-size: 1.2rem;
    text-align: left;
    text-transform: none;
    font-weight: 600;
    margin-top: 2em;


}
body.impressumSeite h5,
body.datenschutzSeite h5  {
    font-size: 1rem;
    text-align: left;
    text-transform: none;
    font-weight: 600;
}
body.impressumSeite ol,
body.datenschutzSeite ol  {
    margin-bottom: 1em;
    font-size: 1.1rem;
    text-align: left;
    text-transform: none;
    /*font-weight: 600;*/
}
body.impressumSeite ol li,
body.datenschutzSeite ol li  {
    margin-left: 2em;
    list-style-type: decimal;
}




body.ueberunsSeite ul li {
    list-style-type: disc;
    margin-left: 2em;
    margin-bottom: .3em;
}
body.ueberunsSeite ul li ul li  {
    list-style-type: circle;
    margin-left: 0;

}
body.ueberunsSeite ul.letzte {
    margin-bottom: 6rem;

}






/* background-position fixed in IE 10+ abschalten weil scroll bug */
/* http://www.impressivewebs.com/ie10-css-hacks/ */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {

    .held {
        background-attachment: scroll !important; 
    }

}






/*========================================================
        3. media query
========================================================*/

@media only screen and (min-width: 0px) and (max-width: 1500px) { /* max-width von zeile */

    .galerieBildOverlay p {
        font-size: 1.3rem;
    }

}


@media only screen and (min-width: 0px) and (max-width: 1300px) { 


    li.galerie {
        width: 33.33%;
    }

    .projekteBilderLinks {
        padding-left: 0;
    }

    .projekteBilderRechts {
        padding-right: 0;
    }

	.projekteBilderGanzeBreite {
	    padding: 0;
	}

    #kontakt .zeile p {
        font-size: 1rem;
    }


}

@media only screen and (min-width: 0px) and (max-width: 1200px) { /* max-width von zeile */

    #kontakt #kontaktSpalteLinks {
        width: 20%;
    }
    #kontakt #kontaktSpalteLinks #kontaktLogo img {
        width: 80%;  
    }

    #kontakt #kontaktSpalteRechts {
        width: 80%;
    }

    #kontakt .zeile p {
        font-size: .9rem;
    }


}



@media only screen and (min-width: 0px) and (max-width: 1000px) { 
  html {

        font-size: 16px;
    }


    #logoWortmarke img {
        height: 40px;
        margin-top: 25px;
    }
    

    li.galerie {
        width: 50%;
    }

    .galerieBildOverlay p {
        font-size: 1.7rem;
        /*color: green;*/
    }

    #kontakt #kontaktSpalteLinks {
        width: 15%;
    }
    #kontakt #kontaktSpalteLinks #kontaktLogo img {
        width: 80%;
        
    }

    #kontakt #kontaktSpalteRechts {
        width: 85%;
    }


    #kontakt .zeile p {
        font-size: 1.1rem;
        /*letter-spacing: .03rem;*/
    }




}

@media only screen and (min-width: 0px) and (max-width: 900px) { 
        #header {
        height: 80px;
    }

    label.hamburger {
        margin-top: -16px;
    } 

    .hamburgerLinie {
        width: 35px;
    }



    #logo a img {
        height: 50px;
    }
    #logoWortmarke img {
        height: 40px;
        margin-top: 18px;
    }
    


    #kontakt .fliesstext {
        float: initial;
        padding: 0;
    }   

    #kontakt #kontaktSpalteLinks {
        width: initial;
    }
    #kontakt #kontaktSpalteLinks #kontaktLogo {
        text-align: center;
        margin: 3rem 0;
    }

    #kontakt #kontaktSpalteLinks #kontaktLogo img {
        width: 20%;
        
    }

    #kontakt #kontaktSpalteRechts {
        width: 100%;
    }


    #kontakt .zeile #kontaktSpalteRechts p { /* #kontaktSpalteRechts um spezifität zu erhöhen */
        font-size: 1.1rem;
        padding-bottom: 4em;
        /*letter-spacing: .03rem;*/
    }
}

@media only screen and (min-width: 0px) and (max-width: 800px) { /*881 1000*/

    #logo {
        display: none;
    }

    #logoWortmarke  {
        left: 15%;
        transform: translateX(0);
    }
    #logoWortmarke img {
        opacity: 1 !important;
    }
    
    .galerieBildOverlay p {
        font-size: 1.3rem;
        /*color: yellow;*/
    }

    #projekteText {
        min-height: initial;
    }

    #projekteDaten {
        float: initial;
        padding: 0;
        margin-bottom: 2em;

    }







    #kontakt #kontaktSpalteLinks {
        float: left;
        width: 33.333333%;
        padding-top: 3rem;
    }
    #kontakt #kontaktSpalteRechts {
        float: left;
        width: 66.666666%;
        padding: 3rem 0;
    }
    #kontakt #kontaktSpalteLinks #kontaktLogo {
        margin: 0;
    }
    #kontakt #kontaktSpalteLinks #kontaktLogo img {
        width: 100%; 
    }

    #kontakt .zeile #kontaktSpalteRechts p { /*.zeile um spezifität zu erhöhen*/
        width: initial;
        float: initial;
        text-align: center;
        padding-bottom: 0;
    }

    #kontakt #kontaktSpalteRechts p#spalte2 {
        text-align: center;
    }
    #kontakt #kontaktSpalteRechts p#spalte3 {
        text-align: center;
        margin-bottom: 0;
    }

    #kontakt #kontaktSpalteRechts p#spalte2 span,
    #kontakt #kontaktSpalteRechts p#spalte3 span {
        border: none;
        padding: 0;
    }

}
@media only screen and (min-width: 0px)  and (max-width: 600px) { /*881 1000*/

    #logo {
        display: initial;
    }
    
    #logoWortmarke  {
        display: none;
    }




    #slideshow #filmStoerer {
        width: 130px;
        right: 20px;
        bottom: 70px;
    }

    .galerieBildOverlay p {
        font-size: 1.2rem;
    }

}
@media only screen and (min-width: 0px)  and (max-width: 900px) and (orientation: landscape){ /*881 1000*/

    #slideshow #filmStoerer {
        width: 100px;
        right: 70px;
        bottom: 50px;
    }

}


@media only screen and (min-width: 0px)  and (max-width: 500px) { /*881 1000*/
    
    li.galerie {
        width: 100%;
    }

    .galerieBildOverlay p {
        font-size: 6vw;
        /*color: teal;*/
    }

    #projekteText #projekteName h2,
    body.ueberunsSeite #projekteText #projekteName h3 {
        border-top: 3px solid #000;
    }
    #projekteText h2 span.schmuckLinie,
    body.ueberunsSeite #projekteText h3 span.schmuckLinie  {
        border: none;
    }



    #kontakt #kontaktSpalteLinks {
        float: initial;
        width: initial;
        padding-top: 3rem;
    }
    #kontakt #kontaktSpalteRechts {
        float: initial;
        width: initial;
        padding: 3rem 0;
    }
    #kontakt #kontaktSpalteLinks #kontaktLogo {
        margin: 0;   
    }
    #kontakt #kontaktSpalteLinks #kontaktLogo img {
        width: 120px;
    }

    #footer span.floatLeft,
    #footer span.floatRight {
        display: block;
        float: initial;
    }
    }
}

@media only screen and (min-width: 0px)  and (max-width: 260px) { /*881 1000*/


}


/* HEIGHT */

@media only screen and (min-height: 0px)  and (max-height: 400px) { /*881 1000*/


}

/* PSICOs ND */



