/* CUSTOM CSS - this is where you add your own css rules !!

***********************************************************/ 

/* Belegungspläne Anpassungen */

.usm-4s-ssp110 {
	border-left:10px solid;
	border-color:#0000ff;
	padding-left:5px;
}

.usm-3s-ssp100 {
	border-left:10px solid;
	border-color:#ff0000;
	padding-left:5px;
}
#ds_contact_statusmeldung > p{font-weight: 600!important;color:#ff0000!important;}

.gsm-09-ssp20 {
	border-left:10px solid;
	border-color:#ffff00;
	padding-left:5px;
}

h1{
	font-size: 2.25rem!important;
	color: #dd780c!important;
	font-weight: 300!important;
	margin-bottom: 30px;
}
h3{
	font-size: 1.625rem!important;
	color: #666666!important;
	font-weight: 300!important;
}
.moduletitle {
	font-size: 1.5rem!important;
	color: #dd780c!important;
	font-weight: 600!important;
	margin-bottom: 30px;
}
p{
	font-size: 1.125rem!important;
	line-height: 1.625rem!important;
}

#demo, .demo{
	display: none!important;
}
.reiter.left{
	width: 43%;
	text-align: center;
	display: table;
	height: 350px;
	padding: 0px 2%;
}
.contentleft{
	height: 100%;
	display: table-cell;
	vertical-align: middle;
}
.reiter.right{
	width: 53%;
	text-align: center;
	overflow: hidden;
	height: 350px;
}
.vertical_tabs.tabbable .nav>li>a{
	line-height: 68px!important;
}
.reiter.right img{
	max-height: 351px;
}
.reiter.right .easy_img_caption_inner{
	display: none!important;
}
.easy_img_caption.reiter.right{
	padding: 0px!important;
}
span.reiter.right{
	width: 100%;
}

/******************************************************************************************************* Sitemap */ 

.sitemap a{
	font-size: 1.125rem!important;
	line-height: 2rem!important;
}

.sitemap > ul > li{
	margin-bottom: 20px;
}

/******************************************************************************************************* Menüleiste */ 
.logo-container{
	width: 50%!important;
	max-width: 548px;
	height: auto!important;
}
#header #logo img{
	width: 100%!important;
	max-width: 548px;
	height: auto!important;
}

#header{
	background-color: rgba(255,255,255,0.8)!important;
	border-bottom: 2px solid white;
}
header.style2 #logo a, header.style2 a#logo{
	background: none!important;
}
.logo-container.hasInfoCard::before, .topnav.navLeft{
	display: none!important;
}
header.style2 #logo a, header.style2 a#logo{
	border-top: none!important;
	border-bottom: none!important;
	padding: 2px 0px;
}
header.style2 #logo a::after, header.style2 a#logo::after{
	border-top-color: rgba(255,255,255,1)!important;
}
.topnav{
	margin-top: 0px!important;
	margin-bottom: 0px!important;
}
#user17{
	width: 230px!important;
}
#user17 .row{
	margin-bottom: 0px!important;
	height: 40px;
	margin-left: 0px!important;
}
nav#main_menu > ul.sf-menu > li > a{
	color: #666666!important;
}
nav#main_menu > ul.sf-menu > li.active > a, nav#main_menu > ul.sf-menu > li > a:hover, nav#main_menu > ul.sf-menu > li:hover > a, .social-icons li a:hover, .how_to_shop .number, .action_box, .imgboxes_style1 .hoverBorder h6, .imgboxes_style1 .hoverborder h6, .feature_box.style3 .box:hover, .services_box .box:hover .icon, .latest_posts.default-style .hoverBorder h6, .recentwork_carousel li .details > .bg, .recentwork_carousel.style2 li a .details .plus, .gobox.ok, .hover-box:hover, .circlehover, .circlehover::before, .newsletter-signup input[type="submit"], #mainbody .sidebar ul.menu li.active > a, #mainbody .sidebar ul.menu li a:hover, #map_controls, .hg-portfolio-sortable #portfolio-nav li a:hover, .hg-portfolio-sortable #portfolio-nav li.current a, .ptcarousel .controls > a:hover, .itemLinks span a:hover, .product-list-item .prod-details .actions a, .product-list-item .prod-details .actions input.addtocart-button, .product-list-item .prod-details .actions input.addtocart-button-disabled, .shop-features .shop-feature:hover, .btn-flat, .redbtn, .ca-more, ul.links li a, .title_circle, .title_circle::before, .br-next:hover, .br-previous:hover, .flex-direction-nav li a:hover, .iosSlider .item .caption.style1 .more::before, .iosSlider .item .caption.style1 .more::after, .iosSlider .item .caption.style2 .more, .nivo-directionNav a:hover, .portfolio_devices .more_details, #wowslider-container a.ws_next:hover, #wowslider-container a.ws_prev:hover, nav#main_menu > ul.sf-menu > li.active > .separator, nav#main_menu > ul.sf-menu > li > .separator:hover, nav#main_menu > ul.sf-menu > li:hover > .separator, #ctabutton, #logo.with-infocard #infocard{
	color: #ffffff!important;
}

/******************************************************************************************************* Slider */ 

.iosSlider .item .caption.style1 .title_big{
	font-weight: 300;
	margin: -180px 0 0 -2000px!important;
	font-size: 2rem!important;
	color: white!important;
}
.iosSlider .item .caption.style1 .title_small{
	font-size: 2rem!important;
	padding: 15px 20px 15px 2300px!important;
	margin: -115px 0 0 -2000px!important;
	color: #fff!important;
}
.iosSlider .item .caption.style1 .title_big::before, .iosSlider .item .caption.style1 .title_small::before{
	background-color: rgba(221,120,12,0.9)!important;
}
.iosSlider .item .caption.style1 .more{
	display: none;
}
.iosSlider .item .caption .main_title{
	border-left: none!important;
	background: none!important;
	position: relative;
	z-index: 2;
	margin-bottom: -20px!important;
	margin-left: 100px!important;
}

/******************************************************************************************************* Willkommen */ 

#referenzen{
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
}

/******************************************************************************************************* Referenzen */ 

#mod238{
	text-align: center;
}
#mod251 img{
	margin-bottom: 20px!important;
}
.ptcarousel li{
	text-align: center;
}

/******************************************************************************************************* Referenzfolgeseite */ 

.caroufredsel_wrapper img{
	max-height: 352px!important;
	width: auto!important;
}

/******************************************************************************************************* Leistungen */ 

#leistungen{
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
}
#leistungen a{
	margin-bottom: 25px;
}

/******************************************************************************************************* Stellenangebote */ 

#mod240 .acc-group button {
	font-size: 1.5rem!important;
	color: #666666!important;
	font-weight: 600!important;
	margin-bottom: 30px;
	height: 67px!important;
	padding-left: 0px!important;
}
.acc-group.default-style > button::after{
	background: url(../images/jobdetails.png) no-repeat center top!important;
	width: 281px!important;
	height: 56px!important;
}
.acc-group.default-style > button:hover{
	background: none!important;
}

/******************************************************************************************************* Reiter */ 

#mod132.span12, #mod257.span12{
	margin-left: 0px!important;
	width: 100%!important;
}
.tab-content > .active, .pill-content > .active{
	display: flex!important;
	flex-flow: row wrap;
	justify-content: space-between;
}
.vertical_tabs.tabbable .nav, .vertical_tabs.tabbable .tab-content{
	height: 351px!important;
}
.vertical_tabs.tabbable .nav > li{
	height: 20%;
}
.vertical_tabs.tabbable .nav > li > a{
	height: 100%;
	font-size: 1.5rem!important;
}
.reiter_links{
	text-align: center;
	width: 55%;
	height: 236px;
	margin-top: 50px;
}
.reiter_rechts{
	width: 45%;
}
.vertical_tabs.tabbable .tab-content{
	padding: 0px!important;
}
.vertical_tabs.tabbable .tab-content p, .vertical_tabs.tabbable .tab-content li{
	margin: 0px!important;
	font-size: 1.4rem;
	line-height: 2rem!important;
	color: #dd780c!important;
}
span.anmerkung{
	color: #666;
	font-size: 1.2rem;
}
.vertical_tabs.tabbable .tab-content a{
	padding: 10px 30px;
	background: #dd780c!important;
	font-weight: 600!important;
	color: white!important;
	border-radius: 5px;
}

/******************************************************************************************************* Buttons */ 

#big_links{
	display: flex;
	flex-flow: row-wrap;
	justify-content: space-between;
}
.link1{
	background-image: url(../images/standortbutton.png);
}
.link2{
	background-image: url(../images/kontaktbutton.png);
}
.link3{
	background-image: url(../images/downloadbutton.png);
}
.link1, .link2, .link3{
	background-repeat: no-repeat;
	background-position: 20px center;
	width: 270px;
	height: 85px;
	padding: 25px 5px 25px 110px;
	border-radius: 10px;
}
.link1 h4, .link2 h4, .link3 h4{
	font-size: 2rem!important;
	color: white!important;
}
.link1 p, .link2 p, .link3 p{
	font-size: 0.9rem!important;
	color: white!important;
}
.link1 a, .link2 a, .link3 a{
	color: white!important;
}
.orange{
	background-color: #a1a1a1;
}
.orange:hover{
	background-color: #dd780c;
}

/******************************************************************************************************* Kalender */ 

.rahmen{
	text-align: center;
	background: white;
	border: 1px solid #666666;
	border-radius: 10px;
	height: 330px;
	margin-top: 30px;
}
.rahmentext{
	position: relative;
	padding: 30px;
	width: 34%;
}
.rahmen p{
	margin: 0px!important;
	font-size: 1.5rem!important;
	line-height: 2.25rem!important;
	color: #dd780c!important;
}
.rahmen a{
	padding: 10px 30px;
	font-size: 1.5rem!important;
	background: #dd780c!important;
	font-weight: 600!important;
	color: white!important;
	border-radius: 5px;
}
#kalenderbild{
	margin-left: 36%!important;
	margin-top: -356px!important;
	width: 64%!important;
}

/******************************************************************************************************* News */ 

#mod111.span6{
	margin-left: 0px!important;
	width: 50%!important;
}
.css3accordion {
	width: 100%!important; 
}
.css3accordion > ul > li:nth-child(2), .css3accordion > ul > li:nth-child(3){
	display: none;
}
body.res1170 .css3accordion > ul > li{
	width: 100%!important;
}

/******************************************************************************************************* Zertifikate */ 

.partners_carousel li a, .partners_carousel li > span{
	border: inherit!important;
	background: none!important;
}

/******************************************************************************************************* Footer */ 

#footer1{
	text-align: center;
}
#footerheadline{
	color: white!important;
	font-weight: 600!important;
}
.social-icons li a{
	background-color: rgba(0,0,0,0)!important;
}
.social-icons li a:hover{
	background-color: #dd780c!important;
}
/******************************************************************************************************* Cookiehint */ 

#redim-cookiehint {
    background-color: #333;
}
#redim-cookiehint .cookiebuttons .btn {
	background-color: #fff;
	color: #333;
	font-size: 14px;
	border: none;
}
#redim-cookiehint .cookiebuttons .btn:hover {
	background-color: #333;
	color: #fff!important;
}
#redim-cookiehint .btn:hover {
	transition: none!important;
    background-position: 0;
	background-image: none!important; 
	box-shadow: none;
}

/********************************************************************************************************************************************************************************** Responsivität */ 
nav#main_menu.noTopNav {
	margin-top: 0px!important;
}

@media only screen and (max-width: 1300px){
	.row{
		margin-left: 0px!important;
	}
}

@media only screen and (max-width: 1220px){
	
	.span6{
		width: 450px!important;
	}

/******************************************************************************************************* Reiter */ 


	.vertical_tabs.tabbable .nav, .vertical_tabs.tabbable .tab-content{
		height: 275px!important;
	}
	.vertical_tabs.tabbable .nav > li > a{
		height: 100%;
		font-size: 1.1rem!important;
	}
	.vertical_tabs.tabbable .tab-content p{
		font-size: 1.1rem!important;
		line-height: 1.8rem!important;
	}
	.reiter_links{
		height: 185px;
		margin-top: 30px;
	}

/******************************************************************************************************* Buttons */ 

	.link1, .link2, .link3{
		width: 190px;
	}
	.link1 h4, .link2 h4, .link3 h4{
		font-size: 1.5rem!important;
	}
	.link1 p, .link2 p, .link3 p{
		font-size: 0.8rem!important;
	}

}

@media only screen and (max-width: 1024px){	
	
/******************************************************************************************************* Referenzen */ 
	#mod251{
		max-width: 580px;
		width: 90%!important;
		margin: auto;
	}
	#mod251 a{
		width: 48%!important;
		max-width: 281px!important;
	}
	
/******************************************************************************************************* Leistungen */ 
	#mod239{
		max-width: 580px;
		width: 90%!important;
		margin: auto;
	}
	#leistungen a{
		width: 48%!important;
		max-width: 281px!important;
	}
	
/******************************************************************************************************* Kalender */ 
	#mod248{
		max-width: 580px;
		width: 90%!important;
		margin: auto;
	}
	#kalenderbild{
		margin-left: 0px!important;
		margin-top: -310px!important;
		width: 100%!important;
	}
	.rahmen{
		height: 565px!important;
	}
	.rahmentext{
		width: 92%!important;
		padding: 4%!important;
	}

/******************************************************************************************************* Reiter */ 

	.vertical_tabs.tabbable .nav, .vertical_tabs.tabbable .tab-content{
		width: 100%!important;
	}
	.vertical_tabs.tabbable .tab-content{
		height: inherit!important;
		margin-top: 3px!important;
	}
	.vertical_tabs.tabbable .nav > li{
		border-bottom: 1px solid #c2c2c2!important;
		margin-top: -1px!important;
	}

/******************************************************************************************************* Buttons */ 

	#big_links{
		display: block;
		max-width: 580px!important;
		width: 90%!important;
		margin: auto!important;
	}
	.orange{
		margin-bottom: 20px;
		max-width: 465px!important;
		width: 77%!important;
	}
	.link1, .link2, .link3{
		padding: 25px 5px 25px 26%!important;
	}

/******************************************************************************************************* Stellenangebote */ 
	#user4{
		width: 580px!important;
	}
	#mod240 .acc-group button{
		width: 100%!important;
		margin-left: 0px!important;
		height: 120px!important;
		padding-bottom: 70px!important;
	}
	.acc-group.default-style > button::after{
		left: 0px!important;
		top: 65px!important;
	}
	
	#user8{
		max-width: 580px!important;
		width: 95%!important;
	}
	

/******************************************************************************************************* News */ 
	
	#mod111.span6, #mod111[class*="span"], #mod111 .span6, #mod111 [class*="span"], #mod111 ul, .css3accordion > ul > li > .inner-acc{
		width: 100%!important;
		margin-left: 0px!important;
	}

/******************************************************************************************************* Zertifikate */ 
	
	#mod117.span6, #mod117[class*="span"], #mod117 .span6, #mod117 [class*="span"], .css3accordion > ul > li > .inner-acc{
		width: 100%!important;
		margin-left: 0px!important;
	}
	#partners_carousel117{
		width: 100%!important;
		margin-left: 0px!important;
	}

/******************************************************************************************************* Folgeseiten */ 

	.eBlog .items-row.cols-2 .item{
		width: 100%;
		float: none;
	}

/******************************************************************************************************* Styling Nachbesserungen */
	#mod117 .span6, #mod117[class*="span"] {
		overflow: hidden;
		height: 280px;
	}
}

@media only screen and (max-width: 769px){
	#mod117 .span6, #mod117[class*="span"] {
		overflow: hidden;
		height: 270px;
	}
}

@media only screen and (max-width: 600px){

	h1{
		font-size: 1.7rem!important;
	}
	h3{
		font-size: 1.3rem!important;
	}
	p{
		font-size: 1rem!important;
	}
	
	#mod239, #mod251, #mod259{
		max-width: 450px!important;
	}
	
	.iosSlider .item .caption.style1 .title_small, .iosSlider .item .caption.style1 .title_big{
		font-size: 1.5rem!important;
	}
	
	.iosSlider .item .caption.style1 .title_small{
		margin: -85px 0 0 -2030px !important;
	}
	
	.iosSlider .item .caption.style1 .title_big{
		margin: -150px 0 0 -1950px !important;
	}

/******************************************************************************************************* Logo */ 

	.logo-container, .logo-container img{
		width: 90%!important;
		height: auto!important;
	}

/******************************************************************************************************* Reiter */ 

	#user5{
		max-width: 450px!important;
	}
	.tab-content > .active, .pill-content > .active{
		display: block!important;
	}
	.reiter_links{
		margin-bottom: 30px;
	}
	.reiter.left{
		width: 94%;
		text-align: center;
		padding: 20px 3% 40px 3%;
	}
	.reiter.left li, .reiter.left span.anmerkungen{
		font-size: 1rem!important;
	}
	.reiter.right{
		width: 100%;
		text-align: center;
	}
	.reiter_links, .reiter_rechts, .reiter_rechts img{
		width: 100%!important;
	}
	.vertical_tabs.tabbable .nav, .vertical_tabs.tabbable .tab-content{
		width: 100%!important;
	}
	.vertical_tabs.tabbable .tab-content{
		height: inherit!important;
		margin-top: 3px!important;
	}
	.vertical_tabs.tabbable .nav > li > a{
		font-size: 1rem!important;
	}
	.vertical_tabs.tabbable .tab-content p{
		font-size: 1rem!important;
	}

/******************************************************************************************************* Stellenangebote */ 
	#user4{
		width: 90%!important;
	}
	#mod240 .acc-group button{
		font-size: 1rem!important;
	}
	.acc-group.default-style > button::after{
		width: 100%!important;
	}

/******************************************************************************************************* Buttons */ 

	#user6{
		max-width: 450px!important;
	}
	#big_links{
		display: block;
		max-width: 580px!important;
		width: 100%!important;
		margin: auto!important;
	}
	.orange{
		margin-bottom: 20px;
		max-width: 465px!important;
		width: 77%!important;
	}
	.link1, .link2, .link3{
		padding: 100px 0px 25px 0px !important;
		width: 100%!important;
		background-position: center 15px!important;
		text-align: center;
	}
	
/******************************************************************************************************* Kalender */ 
	#mod248{
		max-width: 280px;
	}
	.rahmen{
		height: 385px !important;
	}
	.rahmen a{
		padding: 10px 10%;
		font-size: 1.2rem !important;
	}
	.rahmen p{
		font-size: 1rem!important;
	}
	#kalenderbild{
		margin-top: -170px!important;
	}
	
/******************************************************************************************************* News */ 

	#user8{
		max-width: 450px!important;
	}
	.css3accordion > ul > li .thumb{
		width: 100%!important;
		max-width: inherit!important;
	}
	
	
	.span6{
		width: 100%!important;
	}

	#mod117 .span6, #mod117[class*="span"] {
		height: 220px;
	}
}

@media only screen and (max-width: 480px){
	#mod117 .span6, #mod117[class*="span"] {
		height: 210px;
	}
}

@media only screen and (max-width: 420px){
	#mod117 .span6, #mod117[class*="span"] {
		height:	190px;
	}
}
@media only screen and (max-width: 370px){
	#mod117 .span6, #mod117[class*="span"] {
		height:	175px;
	}
}
