:root {
	--fontP: 'PT Sans', Helvetica, Arial, sans;
	--fontH: 'Oswald', Helvetica, Arial, sans;
	--colFont: #2f2f2f;
	
	--colHigh1: #232b51; /* blau */
	--colHigh2: #e97132; /* orange */
	--colHigh3: goldenrod;
	--colHigh4: #ced3e8;
	
	--colMainNaviHover: #df540b;
	
	--spacer: 1.5rem;
	--radius: .3rem;
	--navPadding: .6rem; /* Logo und UL */
}

@font-face { font-display: swap; font-family: 'Oswald'; font-style: normal; font-weight: 500; src: url('../assets/fonts/oswald-v53-latin-500.woff2') format('woff2'); }
@font-face { font-display: swap; font-family: 'PT Sans'; font-style: normal; font-weight: 400; src: url('../assets/fonts/pt-sans-v17-latin-regular.woff2') format('woff2'); }
@font-face { font-display: swap; font-family: 'PT Sans'; font-style: italic; font-weight: 400;  src: url('../assets/fonts/pt-sans-v17-latin-italic.woff2') format('woff2'); }
@font-face { font-display: swap; font-family: 'PT Sans';  font-style: normal; font-weight: 700; src: url('../assets/fonts/pt-sans-v17-latin-700.woff2') format('woff2'); }

/* Frameworks Overrides */
figure { margin: 0; }
.row.full { max-width: 100%; }
.row.broad { max-width: 95%; margin: 0 auto }
.row.wide { max-width: 85%; margin: 0 auto}
.row.padding-0 .columns { padding: 0 }
.reveal { color: #000; width: 1440px; max-width: 90%; }
.reveal-overlay { z-index: 9999 }
.invisible { height: 0 }
.fa-external-link  { transform: scale(.7667) translateY(3px) }
.fa-mobile  { transform: scale(1.4667) }
/**/

/* Anim: */
@-webkit-keyframes fadeIn {
    0% { opacity: 0; }
    100% { opacity: 1 }
}
@keyframes fadeOut {
    0% { filter: none; opacity: 1 }
	100% { filter: saturate(500%) blur(5px) brightness(300%) sepia(100%); opacity: 0; }    
}
@-webkit-keyframes fadeInBurst {
    0% { filter: saturate(500%) blur(5px) brightness(300%) sepia(100%); opacity: 0; }
	/*0% { filter: brightness(300%) sepia(100%); }*/
    100% { filter: none; opacity: 1 }
}
@keyframes blurIn {
    0% { filter: blur(10rem); }
    100% { filter: none; }
}
@keyframes MoveUpDown {
  0%, 100% { transform: translateY(0)  }
  50% { transform: translateY(-18px) }
}
@-webkit-keyframes animSlideInTop {
    0% { opacity: 0; transform: translateY(-30px); }
    100% { opacity: 1; transform: translateY(0px); }
}
@-webkit-keyframes animSlideInBottom {
    0% { opacity: 0; transform: translateY(30px); }
    100% { opacity: 1; transform: translateY(0px); }
}

.animOpacity { opacity: 0; }
.animOpacity.inVP { -webkit-animation: fadeIn .5s; -webkit-animation-fill-mode: both; }

.animSlideInTop { opacity: 0; transform: translateY(-30px); }
.animSlideInTop.inVP { -webkit-animation: animSlideInTop .5s ease-out; -webkit-animation-fill-mode: both; }

.animSlideInBottom { opacity: 0; transform: translateY(30px); }
.animSlideInBottom.inVP { -webkit-animation: animSlideInBottom .5s ease-out; -webkit-animation-fill-mode: both; }

.fadeIn { animation: fadeIn .75s; animation-fill-mode: both; }
.blurIn { animation: blurIn .5s; animation-fill-mode: both; }

.fadeInBurst { -webkit-animation: fadeIn .75s; -webkit-animation-fill-mode: both; }
.animfadeInBurst { opacity: 0; }
.animfadeInBurst.inVP { -webkit-animation: fadeIn .75s; -webkit-animation-fill-mode: both; }

html.no-js .anim { opacity: 1; transform: none; }
/**/

/* Sticky Header: Height Override */
#sec1 { --diff: 11.4rem; /*mit Top-Navi: 13rem*/ }
/*
.sticky-container { --padding-bottom: 60px; }
.sticky-container { height: initial !important; padding-bottom: var(--padding-bottom); }
section#sec1 { height: calc(100vh - var(--diff)) !important }
body.scrolling .sticky-container { height: initial !important; padding-bottom: calc((var(--padding-bottom)) - 84px); }
body.scrolling section#sec1 { height: calc(100vh - var(--diff) + 84px) !important }
@media screen and (max-width: 1024px) { .sticky-container { --padding-bottom: 160px; } #sec1 { --diff: 11rem; } }
@media screen and (max-width: 920px) { .sticky-container { --padding-bottom: 82px; } #sec1 { --diff: 5rem; } }
*/
.sticky, .sticky.is-anchored { position: sticky }
/**/

body { font-family: var(--fontP); color: var(--colFont); background: #fff }
h1, h2, h3, h4, h5, h6  { font-family: var(--fontH); color: var(--colHigh1); font-weight: 700; }
h1 { font-size: 3.9rem; margin-bottom: .6rem;  }
h2, h3 { font-size: 1.8rem; }
body:not(.page-impressum) h2 { font-size: 2.7rem;  color: var(--colHigh2) }
h3, body.page-impressum h2 { margin-bottom: 1.2rem; }
h4, h5, h6 { font-family: var(--fontP); }
h4, h5 { font-size: 1.5rem; font-weight: 700; letter-spacing: -.025em;  }
h4 { color: var(--colHigh1); }
h5 { color: #000; }
h4 + h5 { margin-top: -.9rem; }
h6 { font-size: 700; font-size: 1.2rem; text-transform: uppercase; }

p { text-rendering: auto; }
p, section ul li, .reveal ul li { font-size: 1.2667rem; }
#content a:not(.button) { color: var(--colHigh2); position: relative }
#content a:not(.button):is(:hover, :focus) { color: var(--colHigh1); }
#content p a:not(.button)::before { font-family: 'FontAwesome'; content:'\f138'; margin-right: .3rem }
#content p a[href^="http"]:not(.button)::before { content:'\f14c'; transform: scale(.9); display: inline-block; margin-right: .1rem; }
#content p a:not(.button)::after { position: absolute; inset: 0; content: ' '; display: block; border-bottom: 1px transparent solid; width: 0%; transition: .2s width }
#content p a:not(.button):is(:hover,:focus)::after { border-color: var(--colHigh1); width: 105%; }

#content p a.no-icon::before { content:'' !important; margin: 0 !important; display: initial !important }
#content p a.no-underline:is(:hover,:focus)::after { width: 0% !important; }

/* Korrekturen für Hauptnav. im main-Bereich der Startseite: */
#content nav a::before, #content nav a::after, #content nav a:is(:hover,:focus)::after { display: none }
#content nav a { color: var(--colFont) !important }
#content nav a:is(:hover,:focus) { color: var(--colMainNaviHover) !important }
/**/

#content ul, #content ol { margin-left: 1.14667rem; }

hr.left { margin-left: 0; }
hr.full { max-width:100%; }

.heading { text-align: center; text-transform: uppercase; font-weight: 700; margin-bottom: 3rem; }
.heading.-left { text-align: left; }
.heading * { line-height: 1em }
.heading h1 { font-size: 4.2rem; }
.heading h2 {  color: var(--colHigh1) }
.heading.-small h1 { font-size: 3.3rem; }
.heading span { color: var(--colHigh2); display: block;margin-top: 1rem; font-size: 2.1rem }
.heading::after { content: ""; display: inline-block; width: 21rem; height: 4px; background: var(--colHigh1); }

section a { color: var(--colHigh1); }
section a:hover, section a:focus { color: var(--colHigh2);  }

picture { display: block }
img, video, audio { max-width: 100%; height: auto; }
section a img:hover, section a img:focus { filter:brightness(1.05) }

figure figcaption { background: #ddd; padding: .6rem .9rem; font-style: italic; font-size: .9rem; }
figure video + figcaption { margin-top: -.4rem }

address { font-style: normal; }

/*****/

.secFullHeight { min-height: 100vh; }
/*section#sec1 { height: calc(100vh - 14.2rem); max-height: 100vh;  width: 100%; position: relative; top: -1px } /* crazy, I know */
/*
.arrowdown { position: absolute; z-index: 9999999999999999; left: 50%; bottom: 2.1rem; z-index: 8; animation: MoveUpDown 3s ease infinite }
.arrowdown a { color: #fff; text-shadow: 2px 2px 3px rgba(0,0,0,.3); }
.arrowdown a:hover, .arrowdown a:focus { color: var(--colHigh2); }
*/
/*****/

body.page-index #start .row.full .columns { padding: 0 }
body.page-unterstuetzung #start { background: url(../img/title/unterstuetzung_17.webp) no-repeat center; background-size: cover; min-height: 70vh;  }
body.page-unterstuetzung #start h1, body.page-unterstuetzung #start p { color: #fff; text-shadow: 0 0 10px rgba(0,0,0,.75) }
body.page-unterstuetzung #start p { text-shadow: 0 0 7px black }

.grid.unterstuetzung .item { background: rgba(255,255,255,.85); border-radius: 9px; padding: 1.5rem; transition: .1s all }
.grid.unterstuetzung .item:hover, .grid.unterstützung > a:hover { background: rgba(255,255,255,.95);}
.grid.unterstuetzung .item * { text-shadow: none !important }
.grid.unterstuetzung .item p { color: #000 !important }

.grid.unterstuetzung.buttons .item { display: flex; align-items: center; justify-content: center; cursor: pointer }
.grid.unterstuetzung.buttons .item:hover a { color: var(--colHigh1) !important; }
.grid.unterstuetzung .item > a { display: block; font-family: var(--fontH);  }
.grid.unterstuetzung .item > a i.fa-external-link { transform: none; }

.layout1 { display: grid; grid-template-columns: 2fr 3fr; grid-gap: 2rem }
.layout1 .lead { border-radius: 12px; background-repeat: no-repeat; background-size: cover; background-position: 50% 50%; position: relative; text-align: center; padding: 3rem; min-height: 75vh; max-height: 200vh }
.layout1 .lead h1 { color: #fff; text-shadow: 0 0 1rem black }
.layout1 .lead a.button { position: absolute; bottom: 3rem; left: 50%; transform: translateX(-50%); color: #fff; width: 90% }

/*****/

.partnerbuttons  { width: 900px; max-width: 100%; margin: 0 auto } 
.partnerbuttons > div { background: #e5e5e5; border-radius: 9px; padding: 1rem; cursor: pointer }
.partnerbuttons > div:is(:hover,:focus) { background: #d5d5d5;}
.partnerbuttons > div img { display: block; margin: 1rem auto; }
@media screen and (max-width: 540px) { .partnerbuttons.grid  { grid-template-columns: 1fr } }

.logos  { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); /*repeat(5, 1fr);*/ gap: 1rem;  }
.logos .item { max-width: 300px; display: flex; justify-content: center;
  align-items: center; aspect-ratio: 1 / 1; text-align: center; border: 1px #ccc solid; border-radius: 12px; overflow: hidden; padding: 1rem; cursor: pointer; transition: .1s all }
.logos .item:is(:hover,:focus) { box-shadow: 0 0 10px rgba(0,0,0,.25); }
.logos .item a::before { display: none; }
#content .logos .item a:is(:hover,:focus)::after { display: none; }
.logos .item img { object-position: center; object-fit: contain /*scale-down*/; width: 100%; height: 100%; aspect-ratio: 1/1; }

/* grid auto-fit funkioniert erst ab X Logos vernünftig, daher muss es leider so gelöst werden: */
.logos  { grid-template-columns: repeat(6, 1fr) }
@media screen and (max-width: 1380px) { .logos  { grid-template-columns: repeat(4, 1fr) } }
@media screen and (max-width: 1140px) { .logos  { grid-template-columns: repeat(3, 1fr) } }
@media screen and (max-width: 1024px) { .logos  { grid-template-columns: repeat(5, 1fr) } } /* major break point */
@media screen and (max-width: 720px) { .logos  { grid-template-columns: repeat(4, 1fr) } }	
@media screen and (max-width: 640px) { .logos  { grid-template-columns: repeat(3, 1fr) } }	
@media screen and (max-width: 420px) { .logos  { grid-template-columns: 1fr 1fr } }	

.spendenaktion2025 .logos  { grid-template-columns: repeat(5, 1fr) }
.spendenaktion2025 .logos  .item { padding: .1rem; border-radius: 6px }

.unterstuetzer .logos { grid-template-columns: repeat(4, 1fr) }
@media screen and (max-width: 640px) { .unterstuetzer .logos { grid-template-columns: repeat(3, 1fr) } }	
@media screen and (max-width: 420px) { .unterstuetzer .logos { grid-template-columns: repeat(2, 1fr) } }	

@media screen and (max-width: 1440px) { .spendenaktion2025 .logos  { grid-template-columns: repeat(4, 1fr) } }
@media screen and (max-width: 1280px) { .spendenaktion2025 .logos  { grid-template-columns: repeat(3, 1fr) } }
@media screen and (max-width: 1024px) { .spendenaktion2025 .logos  { grid-template-columns: repeat(5, 1fr) } } /* major break point */

@media screen and (max-width: 720px) { .spendenaktion2025 .logos  { grid-template-columns: repeat(4, 1fr) } }	
@media screen and (max-width: 640px) { .spendenaktion2025 .logos  { grid-template-columns: repeat(3, 1fr) } }	
@media screen and (max-width: 420px) { .spendenaktion2025 .logos  { grid-template-columns: 1fr 1fr } }	


.leuchtturmprojekte { grid-template-columns: 2fr 1fr; grid-template-rows: 1fr 1fr; }
.leuchtturmprojekte .item { display: flex; justify-content: center; align-items: center;  text-align: center; border: 1px #ccc solid; border-radius: 12px; overflow: hidden; padding: 1rem; cursor: pointer; transition: .1s all }
.leuchtturmprojekte .item:is(:hover,:fovus) { box-shadow: 0 0 10px rgba(0,0,0,.15); }
  
.leuchtturmprojekte .item img { object-position: center; object-fit: contain /*scale-down*/;  }
.leuchtturmprojekte .item:nth-child(1) { grid-row: span 2; }
.leuchtturmprojekte .item:nth-child(2) { grid-column: 2; grid-row: 1; }
.leuchtturmprojekte .item:nth-child(3) { grid-column: 2; grid-row: 2; }

.projekte a::before, .projekte a::after { display: none !important }
.projekt h2 { font-size: 1.5rem; line-height: 1; margin-bottom: .3rem; text-align: center; position: relative; text-shadow: 0 0 10px white, 0 0 10px white, 0 0 10px white, 0 0 10px white, 0 0 10px white; }
.projekt h2 { margin-top: 3rem; }
.projekt .columns > div:first-child > h2 { margin-top: .3rem }
.projekt h2::after { border: 1px var(--colHigh2) dashed; content: ' '; display: block; width: 100%; position: absolute; bottom: .5rem; z-index: -1 }
.projekt h2::before { font-family: 'FontAwesome'; margin-right: .3rem; font-weight: normal; }
.projekt .ziel h2::before { content: '\f140'; }
/*.projekt .zielgruppe h2::before { content: '\f1ae'; }*/
.projekt .zielgruppe h2::before { content: '\f182 \f1ae'; }
.projekt .laufzeit h2::before { content: '\f017'; }
.projekt .vorgehen h2::before { content: '\f085'; }

.projekte.logos .item { font-weight: 700; background: #f5f5f5 }
.projekte.logos .item span { color: var(--colHigh1) }
.projekte.logos .item:is(:hover, :focus) span { color: var(--colHigh2) }

.koepfe .item { display: inline-block; width: 300px; max-width: 100%; margin: 0 .6rem; }
.koepfe .item .name { font-weight: 700; }

/*****/

ul.inline { padding: 0; margin: 0 0 1.8rem; list-style-type: none; }
ul.inline li { display: inline; padding-right: .45rem; }
ul.inline li::before { content: '•'; margin-right: .45rem; color: var(--colHigh2); font-weight: 700; font-size: 2rem; line-height:1; position: relative; top: .35rem; }

#content ul.icons { list-style-type: none; margin-left: 0 }
ul.icons li::before { font-family: 'FontAwesome'; }
ul.icons-square li::before { content: "\f0c8"; color: var(--colHigh2); margin-left: -2em; margin-right: 1em; font-size: .9rem; }
ul.icons-check li::before { content: '\f00c'; color: var(--colHigh2); margin-right: .3em; font-size: 1.5rem; position: relative; top: -.025em }
ul.icons-chevron li::before { content: "\f138"; color: var(--colHigh2); margin-right: .6rem; }

#content ul.tabs { margin: 0; border: 0; display: flex; flex-wrap: wrap; justify-content: center; font-family: var(--fontH); }
#content ul.tabs li { border: 1px #ccc solid; margin-top: -1px; margin-left: -1px }
#content ul.tabs li a { font-size: .875rem; text-transform: uppercase; }
.tabs-title > a:focus, .tabs-title > a[aria-selected="true"] { background: var(--colHigh1); color: #fff }
.tabs-content.no-border { border: 0 }
.tabs-panel { padding: 0 }

.infobox { padding: 1.5rem; margin-bottom: 2.1rem; }
.infobox p:last-child { margin-bottom: 0 }
.infobox1 { background: #f0f0f0; }
.infobox2 { background: #e9eef9; }
.infobox3, .infobox4 { color: #fff }
.infobox3 { background: var(--colHigh1); }
.infobox4 { background: var(--colHigh2); }

.galerie img { width: 100%; }


.timeline { display: flex; overflow-x: auto; gap: 1.5rem; padding: 1rem 4.5rem; background-image: url(../img/timeline/timeline-arrow.png); background-repeat: no-repeat; background-position: center; background-size: contain }
.timeline-item { min-width: 150px; text-align: center; border: 1px solid #ccc; background-color: #fff; padding: 1rem; border-radius: 1rem;  transition: .1s filter}
.timeline-item:hover { filter: drop-shadow(0 0 5px rgba(0,0,0,.25)) }
.timeline-year { font-weight: 700; font-size: 1.5rem; }
.timeline-image img { max-width: 100px; display: block; margin: 1rem auto; }


.form1 { padding: var(--spacer); max-width: 600px; background: #ccc; background: rgba(150,150,150,.35); border-radius: 3px }
.form1 .field, .form1 .formGroup { display: block; overflow: hidden; }
.form1 .formGroup span { display: inline-block }
.form1 .field.icq, .form1 .field.website, .form1 .field.email, .form1 .field.message { display: none; }
.form1 .field.fPLZ { width: 32%; }
.form1 .field.fOrt { width: 63%; }
.form1 input, .form1 textarea { font-family: var(--fontP); font-size: 1rem; width: 90%; border: 1px var(--colFont) solid; padding: 3px; -moz-border-radius: 3px;  -webkit-border-radius: 3px; border-radius: 3px; }
.form1 input:focus, .form1 textarea:focus { -webkit-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.35); -moz-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.35); box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.35);}
.form1 input[type=submit], .form1 button.submit { padding: 6px; width: 90%; background: var(--colHigh1) !important; color: #fff !important; font-weight: bold; cursor: pointer; }
.form1 input[type=submit]:hover, .form1 input[type=submit]:focus, .form1 button.submit:hover, .form1 button.submit:focus { background: var(--colHigh2) !important; }
input#datenschutz, input#datenschutz + label { display: inline; }
.form1 input[type=submit]::before, .form1 button.submit::before { content: '' }

.anfahrt { position: relative; }
.anfahrt picture, .anfahrt img { width:100%; height: auto; }
.anfahrt img:hover, .anfahrt img:focus { filter: none; }
.anfahrt .osm { position: absolute; bottom: 0px; left: 0px; padding: .6rem .9rem; background: #fff; color: #aaa; background: rgba(0,0,0,.6); font-size: .7rem; font-weight: bold }
.anfahrt .osm a { color: #ccc }
.anfahrt .maplink { position: absolute; bottom: 15px; right: 45px }
.anfahrt .maplink a { background: darkgoldenrod }
.anfahrt .maplink a:hover, .anfahrt .maplink a:focus { background: var(--colHigh1) }

/*****/

.topnavi { display: none; color: #fff; text-transform: uppercase; font-size: .7rem; padding: .3rem 0; background: #222; position: relative; z-index: 10 }
.topnavi a { color: #fff; padding: 0 .3rem; }
.topnavi a:last-child { padding-right: 0; }
.topnavi a:hover, .topnavi a:focus { color: var(--colHigh1); }

.title-bar.is-at-top.is-stuck { z-index: 9999 !important }

.info-bar { padding-top: 1.8rem; }
.title-bar.is-at-top.is-stuck .info-bar { padding-top: 1.5rem; display: flex; }
.title-bar.is-at-top.is-stuck .info-bar a { margin-left: 1.5rem }
.title-bar.is-at-top.is-stuck .info-bar a:first-child { margin-left: 0 }
.info-bar { font-size: 1.3667rem; color: var(--colHigh1); font-weight: 600;}
.info-bar a { display: block; color: var(--colHigh1); margin-bottom: .3rem; }
.info-bar a:hover, .info-bar a:focus { color: var(--colHigh2) }

.title-bar img { max-height: 130px; width: auto; margin: .9em 0}
.title-bar.is-at-top.is-stuck img { max-height: 60px; margin: .6rem 0}

.title-bar .logo { position: absolute; top: 0; left: 1.2rem; }
.title-bar .logo img { max-height: 66px; width: auto; }

.title-bar .toggle { position: relative; top: 1rem; right: 1rem; transition: .3s all }
.title-bar.is-stuck .toggle { top: .7rem; }
.title-bar .toggle i { color: var(--colHigh1); font-size: 1.8rem; float: right; cursor: pointer; padding: 1rem; transform: translateX(1rem) translateY(-1rem); }
.title-bar .toggle i.fa-close { color: red }

.title-bar { background: #d3d3d3; color: var(--colHigh1); padding: 1rem 0; transition: .1s all }

.title-bar.is-at-top.is-stuck { /*background: rgba(255,255,255,.8); */-webkit-box-shadow: 0px 10px 13px 0px rgba(0,0,0,.45); -moz-box-shadow: 0px 10px 13px 0px rgba(0,0,0,.45); box-shadow: 0px 10px 13px 0px rgba(0,0,0,.45); }
.title-bar img  { transition: .1s all; }

.title-bar ul  { font-family: var(--fontH); list-style: none; text-align: center; margin: 0; display: flex; justify-content: center; align-items: center }
.title-bar ul  > li > a { display: block; font-weight: 400; color: var(--colFont); font-size: 1.2777rem; line-height: 1.5rem; padding: 1.2rem 1rem; margin: 0 1.5rem }
.title-bar ul  > li > a:is(:hover, :focus), .title-bar ul  > li.active  > a, .title-bar ul  > li:is(:hover, :focus) > a { color: var(--colMainNaviHover) }

.title-bar li:not(.mobile-only) a { background-repeat: no-repeat; background-size: 3rem; background-position: left center; padding-left: 3rem; transition: .1s all }
.title-bar li.home a { background-image: url('../img/layout/logo_rebound_png8.png'); text-indent: -20000em; }
.title-bar li.home:is(:hover,:focus) a { filter: brightness(1.5) }
.title-bar li.idee a { background-image: url('../img/layout/navicons/idee.png') }
.title-bar li.netzwerk a { background-image: url('../img/layout/navicons/netzwerk.png') }
.title-bar li.partner a { background-image: url('../img/layout/navicons/partner.png') }
.title-bar li.projekte a { background-image: url('../img/layout/navicons/projekte.png') }
.title-bar li.team a { background-image: url('../img/layout/navicons/team.png') }

/**/


/*****/

main > picture > img.aufmacher { margin-top: 2.2367rem; }
@media screen and (max-width: 920px) { main > picture > img.aufmacher { margin-top: 1.8667rem; } }
/*.subnav.active { position: fixed; top: 150px; left: 50%; transform: translateX(-50%); }*/

/*****/

footer  { background: var(--colHigh1); color: #fff; }
footer .copyline { background: #000; color: #fff; font-size: 11px; text-transform: uppercase; padding: .6rem; }
footer h4 { color: #fff; font-weight: 300; text-transform: uppercase; font-size: 1rem;  }
footer address strong { text-transform: uppercase }
footer address a:is(:hover,:focus) { color: var(--colHigh2) }
footer p { font-size: 1.1rem; line-height: 1.7667rem }
footer a { color: #fff; }
footer a i { color: var(--colHigh2); }
footer a:hover, footer a:focus { color: var(--colHigh3) }
#content footer ul.icons { margin-left: 0 }
footer ul.icons li { margin-bottom: 1.3rem }

footer nav ul { list-style-type: none; margin: 0; }
footer nav ul a { white-space: nowrap }

footer a.button { font-size: .9rem; background: var(--colHigh2) }
footer a.button:is(:hover,:focus) { color: var(--colHigh1) }
footer li.active a { color: var(--colHigh3) }
footer .slickFade2 { width: 300px; max-width: 100%; cursor: pointer }

.logofooter { display: flex; flex-direction: columns; justify-content: center; align-items: center; }
.logofooter img { width: 75px; margin-right: 1.5rem; }
.logofooter blockquote { color: #fff; font-style: italic; margin-left: 1rem; }

/*****/

.float_left { float: left; margin: 0 var(--spacer) var(--spacer) 0; }
.float_right { float: right; margin: 0 0 var(--spacer) var(--spacer); }
.floatbreaker { clear: both; }
.rahmen1 { border: 1px #e8e8e8 solid;}
.rahmen2 { border: 1px #777 solid;}

.para { background: no-repeat fixed 50% 50%; background-size: cover; min-height: 600px; }
.paraIMG { width: 100%; }

.bgimage { width: 100%; height: 100%; background-size:cover; background-repeat: no-repeat; }
.bgimage.bgcenter { background-position: 50% 50%; }
.bgimage.bgcontain { background-size: contain; background-position: center 40%; background-size: 90%; }
.bgimage img { visibility: hidden; }

.bg-black { background: #000; }
.bg-lightgray { background: #ccc; }
.bg-gold { background: darkgoldenrod; color: #fff }
.bg-gold h2, .bg-gold h3 { color: #fff }

.margin-top-0 { margin-top: 0 !important }
.margin-top-xxs { margin-top: calc(var(--spacer)/4) !important }
.margin-top-xs { margin-top: calc(var(--spacer)/2) !important }
.margin-top-s { margin-top: var(--spacer) !important }
.margin-top-m { margin-top: calc(var(--spacer)*2) !important }
.margin-top-l { margin-top: calc(var(--spacer)*3) !important }
.margin-top-xl { margin-top: calc(var(--spacer)*4) !important }
.margin-top-xxl { margin-top: calc(var(--spacer)*6) !important }
.margin-bottom-0 { margin-bottom: 0 !important }
.margin-bottom-xs { margin-bottom: calc(var(--spacer)/2) !important }
.margin-bottom-s { margin-bottom: var(--spacer) !important }
.margin-bottom-m { margin-bottom: calc(var(--spacer)*2) !important }
.margin-bottom-l { margin-bottom: calc(var(--spacer)*3) !important }
.margin-bottom-xl { margin-bottom: calc(var(--spacer)*4) !important }
.margin-bottom-xxl { margin-bottom: calc(var(--spacer)*6) !important }
.padding-top-0 { padding-top: 0 !important }
.padding-top-xxs { padding-top: calc(var(--spacer)/4) !important }
.padding-top-xs { padding-top: calc(var(--spacer)/2) !important }
.padding-top-s { padding-top: var(--spacer) !important }
.padding-top-m { padding-top: calc(var(--spacer)*2) !important }
.padding-top-l { padding-top: calc(var(--spacer)*3) !important }
.padding-top-xl { padding-top: calc(var(--spacer)*4) !important }
.padding-top-xxl { padding-top: calc(var(--spacer)*6) !important }
.padding-bottom-0 { padding-bottom: 0 !important }
.padding-bottom-xs { padding-bottom: calc(var(--spacer)/2) !important }
.padding-bottom-s { padding-bottom: var(--spacer) !important }
.padding-bottom-m { padding-bottom: calc(var(--spacer)*2) !important }
.padding-bottom-l { padding-bottom: calc(var(--spacer)*3) !important }
.padding-bottom-xl { padding-bottom: calc(var(--spacer)*4) !important }
.padding-bottom-xxl { padding-bottom: calc(var(--spacer)*6) !important }

.grid { display: grid; }
.grid-gap-1 { gap: 1rem; }
.grid-gap-2 { gap: 2rem; }
.grid-gap-3 { gap: 3rem; }
.grid-2  { grid-template-columns: 1fr 1fr }
.grid-3  { grid-template-columns: repeat(3,1fr) }
.grid-4  { grid-template-columns: repeat(4,1fr) }
.grid-5  { grid-template-columns: repeat(5,1fr) }
.grid-6  { grid-template-columns: repeat(6,1fr) }
.grid-7  { grid-template-columns: repeat(7,1fr) }
.grid-8  { grid-template-columns: repeat(8,1fr) }
.grid-9  { grid-template-columns: repeat(9,1fr) }
.grid-10  { grid-template-columns: repeat(10,1fr) }
.grid-11 { grid-template-columns: repeat(11,1fr) }
.grid-12  { grid-template-columns: repeat(12,1fr) }

.w25 { width: 25% }
.w33 { width: 33.3% }
.w50 { width: 50% }
.w66 { width: 66.6% }
.w75 { width: 75% }
.w100 { width: 100% }

.text-size-s { font-size: 90%; }
.text-size-xs { font-size: 70%; }
.text-size-l { font-size: 110%; }
.text-size-xl { font-size: 130%; }
.text-uppercase { text-transform: uppercase; }

.spaceme { margin: 3rem auto; }
.centerme { text-align: center; }
.hyphens { -webkit-hyphens: auto; -moz-hyphens: auto; hyphens: auto; }
.nowrap { width: 100%;  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.expanded { width: 100% }

/*****/

.button { font-family: var(--fontH); font-size: 1.2667rem; text-transform: uppercase; background-color: var(--colHigh1); color: #fff; transition: all .1s; border-radius: 9px; padding: .9rem 1.8rem .9rem 1.5rem; }
.button::before { font-family: 'FontAwesome'; content: "\f138"; color: #fff; margin-right: .6rem; }
.button.icon-down::before { content: '\f13a'; }
.button.icon-back::before { content: '\f137'; }
.button.icon-none::before { content: ''; margin-right: 0; }
.button[href^="mailto:"]::before ,.button[href^="javascript:linkTo_Faksimiliertes"]::before { content: '\f0e0'; }
.button[href^="tel:"]::before { content: '\f098'; }
.button[href^="http"]::before { content: '\f14c'; }

.button:is(:hover, :active,:focus), .clickable:is(:hover,:focus) .button { background-color: var(--colHigh2); box-shadow: 0 0 9px rgba(0,0,0,.25) }

.button.contra { background-color: #fff; color: #000 }
.button.contra:hover, .button.contra:active, .button.contra:focus { background-color: var(--colHigh2); color: #fff }

.button.small { font-size: 1rem; padding: .6rem 1.2rem; }

/*****/

.legal i { width: 1em; }
.body:not(.page-impressum)  .legal h2 { font-family: var(--fontH); text-transform: none; margin: 3rem 0 2.4rem; }

.annotations { background: maroon; color: #fff; }
.annotations p { font-size: 1.1667rem }

.fadeIn { -webkit-animation: fadeIn .75s; -webkit-animation-fill-mode: both; }
@-webkit-keyframes fadeIn {
    0% { filter: saturate(500%) blur(5px) brightness(300%) sepia(100%); opacity: 0; }
	/*0% { filter: brightness(300%) sepia(100%); }*/
    100% { filter: none; opacity: 1 }
}

/***/
.mobile-only { display: none !important; }

@media screen and (max-width: 1280px)
{
	.layout1 .lead h1 { font-size: 3rem }
	
	.title-bar ul > li > a { font-size: 1.2667rem; }
	.team .grid { grid-template-columns: repeat(3, 1fr) }
}

@media screen and (max-width: 1024px) /* Foundation Medium */
{
	.title-bar { background: #eee; }
	.title-bar.is-at-top.is-stuck { background: #fff; padding-bottom: .5rem }
	.title-bar ul > li > a { font-size: 1rem; margin-top: 0; }	
	.title-bar img { max-height: 105px;}
	.info-bar a, .info-bar span { font-size: 1rem; }
	
	/*p, section ul li, .reveal ul li, .annotations p { font-size: 1rem; }	*/
	
	.grid-3, .grid-5, .grid-6, .grid-6, .grid-7  { grid-template-columns: 1fr 1fr 1fr}
	.grid-8, .grid-9, .grid-10, .grid-11, .grid-12  { grid-template-columns: 1fr 1fr 1fr 1fr }
	.grid-gap-2, .grid-gap-3 { gap: 1rem; }
	
	.layout1 { display: block }
	.layout1 .lead { min-height: initial; max-height: initial; position: relative; padding: 6rem 0; background-position: 50% 25%; margin-bottom: 3rem; }
	.layout1 .lead a.button { position: absolute; width: auto; inset: auto -3rem 1rem auto; }
	
	.grid.unterstuetzung { grid-template-columns: 1fr }
	
	footer p, footer ul { font-size: 1rem; }
	footer .linksection { margin-top: 3rem; text-align: center}
}

@media screen and (max-width: 920px) /* navigation breakpoint */
{
	.mobile-only { display: block !important; }
	.mobile-no { display: none; }
	
	
	
	.info-bar, .title-bar.is-at-top.is-stuck .info-bar { display: none; }	
	.team .grid { grid-template-columns: 1fr 1fr; }

	/* Navi */
	.title-bar img { max-height: 82px;}
	.title-bar .toggle { display: block; }	
	
	/*.title-bar ul  { display: initial; display: none; /* !!! nur temporär */
	.title-bar ul  { position: absolute; inset: 0 0 0 -150vw; width: 80%; height: 100vh; display: initial; margin: 0; text-align: initial; background: #d3d3d3; box-shadow: 10px 0 10px rgba(0,0,0,.5); transition: .3s all }
	.title-bar ul.visible  { left: 0; box-shadow: 10px 0 10px rgba(0,0,0,.5); }	
	
	.title-bar ul  > li  { padding-bottom: 0; display: block; }
	.title-bar ul  > li > a, .title-bar ul  > li > a::after { font-family: var(--fontP); font-weight: 700; text-transform: uppercase; }
	.title-bar li:not(.mobile-only) a { background-size: 2rem }

	.title-bar li.home a { text-indent: initial }
	.title-bar li.mobile-only a { padding-left: 0 }
	.title-bar i.fa-facebook-square { color: #90aeeb; font-size: 1.2rem; }
	
	.title-bar ul > li > a:is(:hover, :focus), .title-bar ul > li.active > a, .title-bar ul > li:is(:hover, :focus) > a { color: #f25a0a /* nicht colHigh2! muss kräftiger */ }
	
}

@media screen and (max-width: 800px)
{
	.heading h1 { font-size: 3.3rem; }
	.heading.-small h1 { font-size: 2.7rem; }
	.heading span { font-size: 1.5rem; }
	.button { font-size: 1rem; }
	.herotext .buttons .button { display: block; }
	.arrowdown { display: none; }
	
	#content ul.tabs li a { font-size: .76667rem; }
}

@media screen and (max-width: 720px)
{
	.title-bar ul > li > a, .title-bar.is-at-top.is-stuck ul > li > a { font-size: .9rem; }
	.timeline { flex-direction: column;  align-items: center; overflow-x: hidden; background-image: none; padding: 0 }
	.timeline-item { display: flex; align-items: center; justify-content: flex-start; min-width: 90%; max-width: 95%; padding: 10px;       text-align: left; }

    .timeline-content { text-align: center; flex-grow: 1; }
    .timeline-image img { max-width: 75px; }
    .timeline-text { font-size: 0.9em;  }

}

@media screen and (max-width: 640px) /* Foundation Small */
{
	.heading, .heading * { -webkit-hyphens: auto; -moz-hyphens: auto; hyphens: auto; line-height: 1em }
	.heading h1 { font-size: 3rem; }	
	.heading::after { width: 15rem;}
	h2 { font-size: 2.1rem }
	main p, main ol, main ul { hyphens: auto; -webkit-hyphens: auto }
	.form1 { margin-bottom: 6rem;  }
	
	.reveal { max-width: 99%; }
	
	.bgimage { background-image: none !important; }
	.bgimage img { visibility: visible; margin-bottom: 2.1rem; }
	
	.grid { grid-template-columns: 1fr 1fr }
	
	.tabs-title > a { padding: .6rem .9rem}
}

@media screen and (max-width: 520px), (orientation: portrait)
{
	#content { padding-left: 0 }
}

@media screen and (max-width: 480px)
{
	.row.broad { max-width: 100%; }
	.row.wide { max-width: 95%; }
	
	.heading.-small h1 { font-size: 1.8rem }
	.layout1 .lead a.button { inset: auto auto 1rem auto; }
	.leuchtturmprojekte { grid-template-columns: 1fr; grid-template-rows: 1fr; }
	.leuchtturmprojekte .item { grid-column: initial !important; grid-row: initial !important }
}
@media screen and (max-width: 420px)
{
	h1 { font-size: 3rem }
	/*#content ul.tabs li, #content ul.tabs li a { display:block; width: 100% }*/
}

@media screen and (max-width: 360px)
{
	.title-bar img { max-width: 200px; }
	.grid { grid-template-columns: 1fr}
}