/* ************************************************************************
* 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
======================================================================== */

/* ------------------------------------------------------------------------
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-item .calendar-preview-container {
	display: -webkit-flex;
  	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;
}

.calendar-item .calendar-preview-container .calendar-preview-block img {
	max-width: 250px;
	max-height: 125px;
	display: block; 
	margin: auto; 
	cursor:pointer;
}
    
.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 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;
}


/* ------------------------------------------------------------------------
historisches
------------------------------------------------------------------------ */
#body-historisches h2 {
	margin-top: 0;
	margin-bottom: 0.5rem;
}

#body-historisches h3 {
	margin-top: 0;
	margin-bottom: .5rem;
}
#body-historisches h4 {
	margin-top: 0;
	margin-bottom: .5rem;
	font-family: 'satoshilight_italic';
}

#body-historisches img.image {
	margin-top: 1rem;
}

/* ------------------------------------------------------------------------
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;
}

/* ------------------------------------------------------------------------
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 .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;
	}

}


