:focus{
	outline: -webkit-focus-ring-color auto 0;
}

.ui-page{
	position: relative;
}

#log{
	position: absolute;
	top: 0;
	left: 0;
	width: 150px;
	height: 20px;
	display: none;
}

body{
	background: #ffffff;
	color: #000;
	font-family: "VolvoSansMedium";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	padding-bottom: 20px;
	padding-top: 40px;
}

h1,h2,h3,h4{
	font-family: 'VolvoSansMedium';
	    color: #003057;
		font-weight: normal;
}
p{
	font-family: 'VolvoSansMedium';
	color:#003057;
}

h2{
	font-size: 32px;
	margin-top: 0;
}
h3{
	font-size: 20px;
	margin-top: 0;
}

h4{
	margin-top: 10px;
	margin-bottom: 10px;
}
.container-fluid{
	max-width: 1045px;
	width:100%;
	margin: auto;
}
.content{
	max-width: 750px;
	margin: auto;
	text-align: center;
}

.content p{
    font-family: "VolvoSansLight","Arial Narrow","Helvetica Neue",Arial,sans-serif;
    color: #333;
	font-size: 16px;
}

.content h2, .content h3{
    font-family: "VolvoSansLight","Arial Narrow","Helvetica Neue",Arial,sans-serif;
    color: #333;
}

#main{
	position: relative;
	overflow: hidden;
	padding-top: 50px;
}

#forum_logo{
	display: block;
	max-width: 50%;
}
.details_info h3{
	text-transform:uppercase;
}
.details_info a{
	text-decoration:underline;
}

.details_info{
	color:#007bcd;
	padding-top:10px;
}
.main_column{
	transition: width .5s, margin-left .5s;
}

#map_wrapper{
	width: 100%;
    height: auto;
    max-width: 500px;
    margin: 0 auto;
    display: block;
    position: relative;
}

#map{
	margin: auto;
	display: block;
	max-width: 100%;
}

#map_wrapper .map_label{
	position: absolute;
	color: #333333;
	font-family: "VolvoSansMedium";
	font-size: 13px;
	text-align: center;
	line-height: 13px;
}

#map_wrapper .pin{
	position: absolute;
	cursor: pointer;
	width: 26px;
	height: 31px;
	color: #007BCD;
	font-size:32px;
	text-align: center;
	font-family: "roadmap-icons";
	z-index: 999;
}
#map_wrapper .pin.active{
	color: #007BCD;
}



#map_wrapper .pin:before{
	content: '\e800';
}

#map_wrapper .pin.large{
	width: 33px;
	height: 39px;
	font-size:40px;
}
#map_wrapper .pin.large:before{
	content: '\e801';
}



#map_wrapper .pin.large .pin_inner{
	position: absolute;
	text-align: center;
	top: 5px;
	width: 33px;
	color: #000;
	font-family: "VolvoBroadProRegular";
	font-size: 24px;
	margin-top: 6px;
}
#map_wrapper .pin.large.active .pin_inner {
    color: #fff;
}




#map_wrapper .left_pane{
	width: 10px;
	height: 100%;
	background-color: transparent;
	background-image: url("../img/info_arrow.png");
	background-repeat: no-repeat;
	background-position: 0 10px;
	background-size: 100% auto;
	position: absolute;
    left: 0;
    top: 0;
	margin-left: -10px;
}


/* PIN LOCATIONS */
#map_wrapper #pin_berlin{
    bottom: 72%;
    left: 72.5%;
}
#map_wrapper #pin_kiel{
    bottom: 85.3%;
    left: 39.7%;
}
#map_wrapper #pin_hannover{
    bottom: 65.3%;
    left: 29.7%;
}
#map_wrapper #pin_duesseldorf{
    bottom: 54.3%;
    left: 7.7%;
}
#map_wrapper #pin_koblenz{
    bottom: 35.3%;
    left: 7.7%;
}
#map_wrapper #pin_frankfurt{
    bottom: 39.3%;
    left: 30.7%;
}
#map_wrapper #pin_sachsen{
    bottom: 46.3%;
    left: 56.7%;
}
#map_wrapper #pin_freiburg{
	bottom: 15.3%;
    left: 29.7%;
}
#map_wrapper #pin_muenchen{
    bottom: 18.3%;
    left: 61.7%;
}


#forum_logo_wrapper{
	display: table-cell;
    vertical-align: middle;
	text-align:center;
}


.info_column{
	position: relative;
	   
}

.info_column .details{

	width:100%;	
	display: none;
	position: relative;
	font-family: "VolvoSansRegular";
}




.info_column .details .details_content{
	background-color:#fff;
	padding:30px;
	    margin-top: 50px;
}
.info_column .details .details_content img{
width:100%;
}

.info_column .details .details_content p{
	max-width: 80%;
}

.info_column .details a.button{
	padding: 10px 40px;
	border: 1px solid #fff;
	color: #fff;
	transition: color .2s, border-color .2s;
	margin-top: 20px;
	letter-spacing: 1.75pt;
	font-family: "VolvoSansMedium";
}

.info_column .details a.button:hover{
	color: #007bcd;
	border-color: #007bcd;
	text-decoration: none;
}

.info_column .details ul{
	margin-bottom: 40px;
	list-style: none;
	padding-left: 0;
}

.info_column .details ul li:before{
	content: "- ";
}
.details.active{
	display:block ;
}
.info_column .details .close_button{
	position: absolute;
	top: 15px;
	right: 15px;
	color: #fff;
	font-family: "VolvoSansLight";
	cursor: pointer;
	font-size: 40px;
	z-index: 5;
	transition: color .5s;
	background-image: url("../img/close.png");
	height: 18px;
    width: 18px;
    background-size: 100% auto;
}

.info_column .details .close_button:hover{
	color: #007BCD;
}

.info_column .details h2{
	
	font-family: "VolvoSansLight";
}

.info_column .details h2,.info_column .details h3,.info_column .details p {
	color: #333;
	font-family: "VolvoSansLight";
}

.info_column .kmu_content{
	font-size: 12px;
	margin-top: 40px;
	display: none;
}

#telefon,#distrikt,.details_info a{
    font-family: "VolvoSansLight","Arial Narrow","Helvetica Neue",Arial,sans-serif;
    color: #333;
}

@media only screen and (max-width: 1199px) {
	#main{
		padding-top: 30px;
	}
	
	#map_wrapper{
		width: 80%;
	}
	
	#map_wrapper .map_label{
		font-size: 11px;
		line-height: 11px;
	}
	
	#timeline_wrapper {
		width: 90%;
	}
	
	.timeline_container{
		margin: 0 auto;
	}
	
	.info_column .details .details_content h2{
		font-size: 25px;
	}
	
	.info_column .details .details_content p{
		max-width: 90%;
	}
	
	.info_column .details ul{
		margin-bottom: 20px;
	}
}
@media only screen and (max-width: 1024px){
.info_column .details .details_content {
    margin-top: 20px;
}
	#main{
		padding-top: 30px;
	}
	
	#map_wrapper{
		width: 70%;
	}
	
	#map_wrapper .pin{
		width: 30px;
		height: 31px;
		font-size:30px;
	}
	
	#map_wrapper .pin.large{
		width: 35px;
		height: 37px;
		font-size:33px;
	}
	
	#map_wrapper .pin.large .pin_inner{
	    font-size: 21px;
		margin-top: 3px;
	}
	
	
/* PIN LOCATIONS */
#map_wrapper #pin_berlin{
    bottom: 72%;
    left: 72.5%;
}
#map_wrapper #pin_kiel{
    bottom: 85.3%;
    left: 39.7%;
}
#map_wrapper #pin_hannover{
    bottom: 65.3%;
    left: 29.7%;
}
#map_wrapper #pin_duesseldorf{
    bottom: 54.3%;
    left: 7.7%;
}
#map_wrapper #pin_koblenz{
    bottom: 35.3%;
    left: 7.7%;
}
#map_wrapper #pin_frankfurt{
    bottom: 39.3%;
    left: 30.7%;
}
#map_wrapper #pin_sachsen{
    bottom: 46.3%;
    left: 56.7%;
}
#map_wrapper #pin_freiburg{
	bottom: 15.3%;
    left: 29.7%;
}
#map_wrapper #pin_muenchen{
    bottom: 18.3%;
    left: 61.7%;
}

	
	.content h2{
		font-size: 30px;
	}
	
	.content p{
		font-size: 14px;
	}
}

@media only screen and (max-width: 991px){
	.info_column{
		position: absolute;
		top: 0;
		left: 0;
		background: #ffffff;
		z-index:9999;
		width: 100%;
		height: 100%;
	}
	.info_column .details .details_content {
     background: transparent;
     padding: 0px; 
	 max-width: 320px;
    margin: 0 auto;
}
.info_column .details{
	padding-bottom:100px;
	max-height: 100vh;
    overflow-y: auto;
}
.info_column .details{
		margin-top: 20px;
	}
}
@media only screen and (max-width: 891px){
#forum_logo_wrapper h2{
	display:none;
}
}

@media only screen and (max-width: 600px) and (orientation: landscape){
	body{
		position: relative;
	}
	

}
@media only screen and (max-width: 768px){
.info_column .details{
	padding-bottom:100px;
	max-height: 100vh;
    overflow-y: auto;
}
#map_wrapper .pin.large {
	transform:scale(1.2);
}
}

@media only screen and (max-width: 480px) {	
	#main{
		padding-top: 20px;
		overflow: visible;
	}
	
	#map_wrapper {
		width: 95%;
	}
	
	#map_wrapper .map_label{
		font-size: 7px;
		line-height: 7px;
	}
	
	#map_wrapper .pin{
		width: 26px;
		height: 27px;
		font-size:26px;
	}

	#map_wrapper .pin.large{
		width: 33px;
		height: 35px;
		font-size:30px;
	}
	
	#map_wrapper .pin.large .pin_inner{
	    font-size: 20px;
		margin-top: 2px;
	}
	
	.info_column{
		padding-bottom: 20px;
	}
	
	.info_column .details{
		padding: 15px;
	}
	
	.info_column .details a.button{
		padding: 10px 20px;
		letter-spacing: 1.75pt;
	}
	
	#timeline_wrapper {
		width: 100%;
	}
	
	#timeline_wrapper .item {
		padding-top: 0px;
	}
	
	#timeline_legend{
		width: 65%;
		font-size: 14px;
	}
}

/* JQUERY MOBILE RESETS */
.ui-loader.ui-corner-all.ui-body-a.ui-loader-default{
	display: none;
}