/* ************************************************************************
* File: main.css
*
* Purpose: Project spesific css
*
* This file is part of a software by Jens Gienau.
* (c)1999 - 2021 Jens Gienau / www.gienau.com / mail@gienau.com
************************************************************************ */

/* ========================================================================
DOCUMENTATION
======================================================================== */

/*
 * Color (intensive): #04B404;
 * Color fonts: 	  #333333;
 * Color nav hover:   #f2f2f2;
 * Color nav active:  #f6f6f6;
 */



/* ========================================================================
ELEMENTS
======================================================================== */

/* ------------------------------------------------------------------------
box
------------------------------------------------------------------------ */
.flex-container.box .flex-col-1.highlight,
.flex-container.box .flex-col-2.highlight,
.flex-container.box .flex-col-3.highlight  {
	background-image: -webkit-linear-gradient(bottom, #FFFFFF , #ebf3f9);
	background-image: -moz-linear-gradient(top bottom, #FFFFFF , #ebf3f9 );
	background-image: -o-linear-gradient(top  bottom, #FFFFFF , #ebf3f9 );
	background-image: linear-gradient(top bottom, #FFFFFF , #ebf3f9 );
}


/* ------------------------------------------------------------------------
Calendar list (for calendar items)
------------------------------------------------------------------------ */
.calendar-item {
	margin: 3rem 0;
	border: 1px #fefefe solid;
	border-radius: 2px;
	-moz-box-shadow: 0 .5rem 1rem rgba(0,0,0,.15) !important;
	-webkit-box-shadow: 0 .5rem 1rem rgba(0,0,0,.15) !important;
	box-shadow: 0 .5rem 1rem rgba(0,0,0,.15) !important;
	padding:1rem;
}

.calendar-item.highlight {
	border: 1px #e32 solid;
	-moz-box-shadow: 0 .5rem 1rem rgba(247,26,50,.15) !important;
	-webkit-box-shadow: 0 .5rem 1rem rgba(247,26,50,.15) !important;
	box-shadow: 0 .5rem 1rem rgba(247,26,50,.15) !important;
}

.calendar-item:hover {
	border: 1px #2B7AAB solid;
	-moz-box-shadow: 0 .5rem 1rem rgba(0,0,0,.45) !important;
	-webkit-box-shadow: 0 .5rem 1rem rgba(0,0,0,.45) !important;
	box-shadow: 0 .5rem 1rem rgba(0,0,0,.45) !important;
}

.calendar-item .image-container-top {
	display: none;
	float:right;
	width:50%; 
	margin-left:1rem; 
}

.calendar-item .image-container-bottom {
	display: block;
	width:100%; 
	margin-top:1rem; 
}

.calendar-event-text {
	color: #e32;
	font-size: .8rem;
	line-height: 1rem;
}

.calendar-event-text {
	color: #e32;
	font-size: .8rem;
	line-height: 1rem;
	display: -webkit-flex;
  	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;
}

.calendar-title {
	font-size: 1.4rem;
	font-family: 'satoshimedium', sans-serif;
	font-weight: normal;
	line-height: 1.8rem;
	margin-bottom: .2rem;
}

.calendar-subtitle {
	font-size: 1.2rem;
	font-family: 'satoshimedium', sans-serif;
	font-weight: normal;
	line-height: 1.4rem;
	margin-bottom: .2rem;
}

.calendar-title h2 {
	cursor: pointer;
	text-decoration: underline;
	color: #2B7AAB;
	font-size: 1.4rem;
	line-height: 1.8rem;
	margin: 0;
}

.calendar-title h2:hover {
	color: #333;
}

.calendar-alert {
	margin: .25rem 0;
	background-color: #e32;
	font-size: .85rem;
	line-height: 1rem;
	color: #fff;
	padding: 0.15rem .25rem;
}


.calendar-info {
	font-size: .85rem;
}

.calendar-info i {
	margin-right: .25rem;
}

.calendar-toggle .text-small {
	margin-top:  1.1rem;
}


.calendar-toggle .content {
	padding-bottom: .25rem;
	border-bottom: 1px silver solid;
}

.calendar-toggle .share-close-container {
	margin-top: 1rem;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
}

.calendar-toggle .share-close-container>div{
	width: 50%;
}

.calendar-toggle .share-close-container>div:last-of-type{
	text-align: right;
}

.calendar-to-toggle {
	display: none;
}

.calendar-date {
	font-size: .8rem;
	line-height: 1rem;
}

.calendar-date span {
	float: right;
	display: inline;
}

.calendar-velo {
	font-size: .8rem;
	line-height: 1rem;
}

.calendar-velo span {
	float: right;
	display: inline;
}


/* ------------------------------------------------------------------------
GPX viewer
------------------------------------------------------------------------ */
.map {
	margin-top: 1rem;
	height: 300px;
}


/* ------------------------------------------------------------------------
euro-list (Beiträge)
------------------------------------------------------------------------ */
.euro-list-class {
	border: 1px gray solid;
	margin: 1rem auto;
	padding: 1rem;
	background-color: #f2f2f2;
}

.euro-list-class h2 {
	margin-top:0;
	font-size: 1.3rem;
}

.euro-list-record {
	display: -webkit-flex;
  	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;

}

/* ------------------------------------------------------------------------
division-list (Abteilungen)
------------------------------------------------------------------------ */
.division-list-class {
	border: 1px gray solid;
	margin: 1rem auto;
	padding: 1rem;
	background-color: #f2f2f2;
	overflow: hidden;
}

.division-list-class h2 {
	margin-top:0;
	font-size: 1.3rem;
}

.division-list-record {
    margin-bottom: 1rem;
}

.division-list-record i {
    margin-right: .5rem;
}

.division-list-record > div:last-child {
	text-align: left;
	margin-top:.5rem;
}

/* ========================================================================
PAGES
======================================================================== */

/* ------------------------------------------------------------------------
index
------------------------------------------------------------------------ */
#body-index .container-outside.video {
	text-align: center;
	background-color: #f2f2f2;
}


#body-index .quote-section {
	text-align: center;
}
#body-index .quote-section img {
	width: 100%;
	max-width: 80%;
	margin: 0 auto;
}

#body-index .quote-section .quote {
  font-family: Georgia, serif;
  font-size: 1rem;
  max-width: 70%;
  display: block;
  line-height: 1.4rem;
  margin: 1rem auto 0 auto;
}

#body-index .quote-section .curly-quotes:before, .curly-quotes:after {
  display: inline-block;
  vertical-align: top;
  height: 1.4rem;
  line-height: 38px;
  font-size: 40px;
  opacity: .2;
}

#body-index .quote-section .curly-quotes:before {
  content: '\201C';
  margin-right: 4px;
  margin-left: -8px;
}

#body-index .quote-section .curly-quotes:after {
  content: '\201D';
  margin-left: 4px;
  margin-right: -8px;
}

#body-index .quote-section .quote-by {
  display: block;
  padding-right: 10px;
  text-align: right;
  font-size: 13px;
  font-style: italic;
  color: #84775c;
}


#body-index .hero {
	background:
		/* top, transparent red, faked with gradient */
		linear-gradient(
		rgba(0, 0, 0, 0.5),
		rgba(0, 0, 0, 0.2)
		),
		/* bottom, image */
        url('../img/hero-bg.jpg') no-repeat;
	background-size: cover;
	background-position: top center;
	font-family: 'satoshiregular', sans-serif;
	color:#fff;
	position: relative;
}

#body-index .hero {
	display: -webkit-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-align-items: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

#body-index .hero .wrapper {
	width:100%;
}

#body-index .hero-text {
	padding:2rem 1rem;
	text-align: center;
	width:100%;
	z-index: 90;
	position: relative;
}

.hero-top {
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
	padding: 1rem;
	background-color: yellow;
	color: #000;
	text-align: center;
}

#body-index .hero p {
	font-size: 1.3rem;
	text-shadow: 0.1em 0.01em 0.05em #333;
	font-family: 'satoshimedium', sans-serif;
}

#body-index .hero h1 {
	font-size: 1.5rem;
	color:#fff;
	line-height: 1.9rem;
	margin-top:0;
	margin-bottom: 1.5rem;
	text-shadow: 0.1em 0.01em 0.05em #333;
	font-family: 'satoshiblack', sans-serif;
}

#body-index .hero h2 {
	font-size: 1.3rem;
	line-height: 1.8rem;
	text-shadow: 0.1em 0.01em 0.05em #333;
}

#body-index .hero .participant {
	background-color: #e32;
	display: inline-block;
	padding: 0 1rem;
	margin-bottom: .2rem;
}
#body-index .hero .btn {
	background-color:rgba(227, 46, 50, 0.80);
	font-size: 1rem;
	border: 3px #fff solid;
	text-shadow: none;
	margin-bottom: 0;
	padding: .3rem .5rem;
}

#body-index .hero .btn.btn-second {
	background-color:rgba(0, 0, 0, 0.50);
}

#body-index .hero a,
#body-index .hero a:link,
#body-index .hero a:hover {
	color:#fff;
	text-decoration: underline;
}

#body-index .hero a.btn,
#body-index .hero a.btn:link,
#body-index .hero a.btn:hover {
	color:#fff;
	text-decoration: none;
	border: 3px #fff solid;
}

#body-index .hero a.btn:hover {
	background-color:#e32;
	border: 3px #fff solid;
}

#body-index .hero a.btn.btn-second:hover {
	background-color:#000;
	border: 3px #fff solid;
}

.arrow {
  text-align: center;
  margin: 0;
  position: absolute;
  bottom: 1rem;
  left:50%;
  margin-left:-75px;
  opacity: 0.7;
  width: 150px;
  height: auto;
}

.arrow:hover {
	opacity: 1;
}

.bounce {
  -moz-animation: bounce 3s infinite;
  -webkit-animation: bounce 3s infinite;
  animation: bounce 3s infinite;
}

@keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-60px);
  }
  60% {
    transform: translateY(-30px);
  }
}

#body-index img.breakingnews {
	max-width: 50%;	
}

#body-index .leitspruch {
	color: #fff;
	background-color: #2B7AAB;
	padding: 3rem 0;
}

#body-index .leitspruch blockquote{
	color: #fff;
	font-size: 1.3rem;
	line-height: 1.8rem;
}

#body-index .leitspruch.big blockquote{
	font-size: 2.3rem;
	line-height: 2.8rem;
}

#body-index .leitspruch blockquote cite{
	color: #fff;
	font-size: 1.1rem;
	line-height: 1.5rem;
	padding-top: 1rem;
}

#body-index .leitspruch blockquote:before {
	color: #fff;
	font-size: 90px;
	left: -10px;
	top: 19px;
}

#body-index .leitspruch blockquote cite:before {
	color: #fff;
}

/* ------------------------------------------------------------------------
impressum
------------------------------------------------------------------------ */
#body-impressum main .container-outside:last-of-type {
	text-align: center;
}

/* ------------------------------------------------------------------------
faq
------------------------------------------------------------------------ */
#body-faq .faq-class {
	font-size: .85rem;
	color: gray;
}

#body-faq h2.faq-question {
	font-size: 1.1rem;
	line-height: 145%;
	margin: 0;
}

#body-faq .faq-answer {
	position: relative;
	padding-bottom: 1.5rem;
	padding-top: .5rem;
}

#body-faq .faq-answer .close-toggle{
	position: absolute;
	bottom: 0;
	right: 0;
}

#body-faq .faq-block {
	margin: 1rem 0;
	border-radius: 2px;
	padding: .5rem;
	background-color: #f2f2f2;
	border: 1px solid #f2f2f2;
}

#body-faq .faq-block:hover {
	border-color: #2B7AAB;
}


/* ------------------------------------------------------------------------
mitglieder
------------------------------------------------------------------------ */
#body-mitglieder form hr {
	margin: 1.5rem auto 1rem auto;
}


/* ------------------------------------------------------------------------
news
------------------------------------------------------------------------ */
#body-news .news-section {
	margin-bottom: 2rem;
}

#body-news .news-section.highlight {
	background-color: #2B7AAB;
	padding: 2rem;
	color:#fff;
}
#body-news .news-section.highlight .image-credits {
	color:#f2f2f2;
}

#body-news .news-section.highlight a,
#body-news .news-section.highlight a:link {
	color:yellow;
}

#body-news .news-section.highlight .btn {
	color:#333;
	background-color:#fff;
	border-color:#fff;
}

#body-news .news-section.highlight .btn:hover {
	color:#333;
	background-color:yellow;
	border-color:yellow;
}

/* ------------------------------------------------------------------------
page
------------------------------------------------------------------------ */
.page hr:last-of-type {
	display: none;
}
.page-section.highlight {
	background-color: #2B7AAB;
	padding: 2rem;
	color:#fff;
}
.page-section.highlight .image-credits {
	color:#f2f2f2;
}
.page-section.highlight a,
.page-section.highlight a:link {
	color:yellow;
}

.page-section.highlight .btn {
	color:#333;
	background-color:#fff;
	border-color:#fff;
}

.page-section.highlight .btn:hover {
	color:#333;
	background-color:yellow;
	border-color:yellow;
}

/* ========================================================================
MEDIA QUERY: DESKTOP SMALL
======================================================================== */

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

	.division-list-record {
		display: -webkit-flex;
	  	display: -ms-flexbox;
		display: flex;
		-webkit-justify-content: space-between;
	    justify-content: space-between;
	}

	.division-list-record > div:last-child {
		text-align: right;
		margin-top:0;
	}

	/* ------------------------------------------------------------------------
	MQ: index
	------------------------------------------------------------------------ */
	#body-index .video .wrapper {
		padding-left:1rem;
		padding-right:1rem;
	}

	#body-index .quote-section img {
		width: 70%;
		max-width: 600px;
		margin-top:2rem;
		margin-bottom:2rem;
	}

	#body-index .quote-section .quote {
		font-size: 1.5rem;
		line-height: 2rem;
	}

	#body-index .quote-section .curly-quotes:before, .curly-quotes:after {
	  height: 2rem;
	  line-height: 48px;
	  font-size: 50px;
	}

	#body-index .hero-text {
		padding: 2rem;
	}

	#body-index .hero h1 {
		font-size: 2.5rem;
		line-height: 3.2rem;
		margin-bottom: 2rem;
	}

	#body-index .hero h2 {
		font-size: 2rem;
		line-height: 2.6rem;
	}

	#body-index .hero p {
		font-size: 2rem;
		line-height: 2.5rem;
	}

	#body-index .hero .btn {
		font-size: 1.1rem;
		padding: 0rem 3rem;
	}

	#body-index .leitspruch blockquote{
		font-size: 1.8rem;
		line-height: 2.2rem;
	}

	#body-index .leitspruch.big blockquote{
		font-size: 2.8rem;
		line-height: 3.4rem;
	}
	
	#body-index .leitspruch blockquote cite{
		font-size: 1.4rem;
		line-height: 1.7rem;
		padding-top: 1.2rem;
	}
	
	
	

	/* ------------------------------------------------------------------------
	MQ: termine
	------------------------------------------------------------------------ */
	.calendar-date span {
		float: right;
		display: inline;
	}

	.calendar-date {
		font-size: 1.1rem;
		line-height: 145%;
	}

	.calendar-item .image-container-top {
		display: block;
	}
	
	.calendar-item .image-container-bottom {
		display: none;
	}
	
	.termine-flex-container {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
	}

	.termine-flex-col {
		margin: 0 1rem;
	}

	.termine-flex-col:first-of-type {
		width:70%;
		margin-left:0;
	}
	.termine-flex-col:last-of-type {
		width:30%;
		margin-top: 1.2rem;
		margin-right:0;
	}

}


