@font-face {
  font-family: 'Polo-Leicht';
  font-style: normal;
  font-weight: 300;
  src: local(''),
       url('../fonts/Polo11-Leicht.woff2') format('woff2'),
      url('../fonts/Polo11-Leicht.woff') format('woff'),
      url('../fonts/Polo11-Leicht.eot') format('eot');
}
@font-face {
  font-family: 'Polo-Krftg';
  font-style: normal;
  font-weight: 500;
  src: local(''),
       url('../fonts/Polo11-Krftg.woff2') format('woff2'),
    url('../fonts/Polo11-Krftg.woff') format('woff'),
    url('../fonts/Polo11-Krftg.eot') format('eot');
}
@font-face {
  font-family: 'Polo-Buch';
  font-style: normal;
  font-weight: 400;
  src: local(''),
       url('../fonts/Polo11-Buch.woff2') format('woff2'),
    url('../fonts/Polo11-Buch.woff') format('woff'),
    url('../fonts/Polo11-Buch.eot') format('eot');
}
:root {
  --blau: rgba(0, 128, 200, 1);
  --hell: rgb(80, 175, 245);
  --gruen: rgba(198, 213, 64, 1);
  --text: rgba(118, 118, 118, 1);
}
/* ########################### HTML Basics ########################### */

body,
html {
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale;
    overflow-y: auto;
    overflow-x: hidden;
    font-family: 'Rubik', sans-serif;
    color: var(--text);
}
::-webkit-scrollbar { width: 6px;  }/* for vertical scrollbars */
::-webkit-scrollbar-track { background: rgba(0, 0, 0, 0.1); }
::-webkit-scrollbar-thumb { background: rgba(0, 0, 0, 0.5); }

body {
  font-family: Polo-Buch,Arial,sans-serif;
  font-size: 18px;
}
strong {
  font-weight: 500;
}
#wrapper {
	max-width:1170px;
	padding-left:0;
	padding-right:0;
}
h1, h2, h3, h4, h5, h6 {
  font-family: Polo-Krftg,Arial,sans-serif;
	color: var(--blau);
	hyphens:auto;
  font-weight: 500;
}

h1 {
	font-family: Polo-Krftg,Arial,sans-serif;
  font-size: 40px;
  line-height: 1.25;
  margin-top: 15px;
  margin-bottom: 40px;
  word-break: break-word;
}
h2 {
	font-family: Polo-Krftg,Arial,sans-serif;
  font-size: 24px;
  line-height: 1.4;
  font-weight: 500;
  margin: 0 0 5px 0;
  padding: 0;
  color: var(--text);
}
h3 {
	font-family: Polo-Krftg,Arial,sans-serif;
  font-size: 18px;
  line-height: 1.4;
  font-weight: 500;
  margin: 0 0 5px 0;
  padding: 0;
  color: var(--text);
}
h4 {
	font-size: 1.2em;
	line-height: 1.6em;
	color: #fff;
	font-weight:400;
	letter-spacing: 0;
}
h5 {
	font-size: 0.9em;
	line-height: 1.5em;
}
h6 {
	font-size: 1.05em;
	line-height: 1.5em;
	font-weight:400;
	letter-spacing: 0;
}
h6 small {
	color:#000;
	font-size:0.9em;
	line-height: 1.3em;
}
h1 a, h2 a, h3 a, h4 a, h5 a {
	color: inherit;
	text-decoration: none;
}
h6 a {
	color: var(--blau);
	text-decoration: none;
}
sub {
	font-size: 0.8em;
	position: relative;
	top: 0.5em;
}

sup {
	font-size: 0.8em;
	position: relative;
	top: -0.5em;
}
p { 
	font-family: Polo-Leicht,Arial,sans-serif;
  font-size: 18px;
  line-height: 1.44;
  margin: 15px 0 15px 0;
  padding: 0;
}
a {
    color: var(--blau);
    transition: all 0.5s;
    text-decoration: none;
}
a:hover,
a:focus {
    text-decoration: none;
    color: var(--gruen);
}
a i.fa {
  font-weight: normal;
  font-size: 80%;
}

input[type="submit"],
input[type="reset"],
input[type="button"],
button,
.button {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	-moz-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	-webkit-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	-ms-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	background-color: transparent;
	border-radius: 0;
	border: 0;
	box-shadow: none;
	color: #fff;
	cursor: pointer;
	display: inline-block;
	font-weight: 500;
	height: 3em;
	line-height: 3.15em;
	padding: 0 2em;
	text-align: center;
	text-decoration: none;
	white-space: nowrap;
}
input[type="text"], input[type="email"], input[type="password"], input[type="number"] {
	border: 1px solid rgba(255,255,255,1);
  margin: 0 auto 5px auto;
  display: inline-block;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  border-radius: 30px;
}
input[readonly] {
	border:1px solid rgba(0, 128, 200, 0.3) !important;
	background:rgba(0, 128, 200, 0.075) !important;
}
input[type="number"] {
	padding:5px 20px;
	max-width:80px;
	-webkit-border-radius:0;
	-moz-border-radius:0;
	border-radius:0;
}
input[type="text"].rflat, input[type="email"].rflat, input[type="password"].rflat {
	-webkit-border-radius:30px 0 0 30px;
	-moz-border-radius:30px 0 0 30px;
	border-radius:30px 0 0 30px;
}
input[type="text"].lflat, input[type="email"].lflat, input[type="password"].lflat {
	-webkit-border-radius:0 30px 30px 0;
	-moz-border-radius:0 30px 30px 0;
	border-radius:0 30px 30px 0;
}
.formtable input[type="text"], .formtable input[type="email"], .formtable input[type="password"], .formtable textarea:not(.tinymce) {
	-webkit-border-radius:3px;
	-moz-border-radius:3px;
	border-radius:3px;
	background:rgba(0, 128, 200,0.1);
	font-size:12px;
	color:var(--text);
}
.formtable input[type="text"].rflat, .formtable input[type="email"].rflat, .formtable input[type="password"].rflat {
	-webkit-border-radius:3px 0 0 3px;
	-moz-border-radius:3px 0 0 3px;
	border-radius:3px 0 0 3px;
}
.formtable input[type="text"].lflat, .formtable input[type="email"].lflat, .formtable input[type="password"].lflat {
	-webkit-border-radius:0 3px 3px 0;
	-moz-border-radius:0 3px 3px 0;
	border-radius:0 3px 3px 0;
}
.weiss input[type="submit"].button_text {
	color: #fff;
  font-size: 16px;
	font-weight: 500;
	padding:1px 20px;
	line-height:1.5em;
	height:33px;
  border: 2px solid #fff;
  border-radius: 20px;
  font-family: Polo-Krftg,Arial,sans-serif;
}
.weiss input[type="submit"].button_text:hover {
	color: var(--blau);
  background: #fff;
}
.button_big {
	color:#fff;
	height:33px;
	padding:5px 10%;
	min-width:100px;
	border:1px solid #fff;
	border-radius:20px;
  letter-spacing: 1px;
}

.orangebg input[type="submit"] {
	background-image:url(../img/submit_blau.png);
}
textarea:not(.tinymce) {
	width:96%;
	height:auto;
	padding:5px 8px;
	font-size:14px;
	border:1px solid rgba(255,255,255,1);	
	color: #fff;
	margin:0 auto 5px auto;
	background:rgba(0, 128, 200,0.75);
	display:inline;
	-webkit-border-radius:10px;
	-moz-border-radius:10px;
	border-radius:10px;
}
.weiss input[type="text"], .weiss input[type="email"], .weiss input[type="password"], .weiss textarea:not(.tinymce) {
	color: var(--text);
  width: 90px;
  padding-left: 20px;
  padding-right: 20px;
}
input:focus, textarea:not(.tinymce):focus {
	background:rgba(0, 128, 200, 1);
	border:3px solid rgba(255,255,255,1);
	margin-top:-2px;
	margin-bottom:3px;
	-webkit-outline: none;
	outline: none;
	-webkit-box-shadow: none;
	box-shadow: none;
}
.weiss input:focus, .weiss textarea:not(.tinymce):focus {
	border:1px solid rgba(0, 128, 200, 1);	
	color: var(--text);
	background:#fff;
	margin-top:0;
	margin-bottom:5px;
}

* ::-webkit-input-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:8px;
}
* :-moz-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:8px;
}
* ::-moz-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:8px;
}
* :-ms-input-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:8px;
}

*:focus::-webkit-input-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:6px;
}
*:focus:-moz-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:6px;
}
*:focus::-moz-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:6px;
}
*:focus:-ms-input-placeholder {
	color: #fff !important;
	opacity: 1;
	padding-left:6px;
}

.weiss ::-webkit-input-placeholder {
	color: #aaa !important;
	opacity: 1;
	padding-left:8px;
}
.weiss :-moz-placeholder {
	color: #aaa !important;
	opacity: 1;
	padding-left:8px;
}
.weiss ::-moz-placeholder {
	color: #aaa !important;
	opacity: 1;
	padding-left:8px;
}
.weiss :-ms-input-placeholder {
	color: #aaa !important;
	opacity: 1;
	padding-left:8px;
}

.weiss :focus::-webkit-input-placeholder {
	color: #aaa !important;
	opacity: 1;
}
.weiss :focus:-moz-placeholder {
	color: #aaa !important;
	opacity: 1;
}
.weiss :focus::-moz-placeholder {
	color: #aaa !important;
	opacity: 1;
}
.weiss :focus:-ms-input-placeholder {
	color: #aaa !important;
	opacity: 1;
}

input.errorfield::-webkit-input-placeholder {
	color: var(--text) !important;
	opacity: 1;
	padding-left:8px;
}
input.errorfield:-moz-placeholder {
	color: var(--text) !important;
	opacity: 1;
	padding-left:8px;
}
input.errorfield::-moz-placeholder {
	color: var(--text) !important;
	opacity: 1;
	padding-left:8px;
}
input.errorfield:-ms-input-placeholder {
	color: var(--text) !important;
	opacity: 1;
	padding-left:8px;
}

input.errorfield:focus::-webkit-input-placeholder {
	color: var(--text) !important;
	opacity: 1;
}
input.errorfield:focus:-moz-placeholder {
	color: var(--text) !important;
	opacity: 1;
}
input.errorfield:focus::-moz-placeholder {
	color: var(--text) !important;
	opacity: 1;
}
input.errorfield:focus:-ms-input-placeholder {
	color: var(--text) !important;
	opacity: 1;
}
input[type="submit"].special,
input[type="reset"].special,
input[type="button"].special,
button.special,
.button.special {
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/var(--blau)+0,356fd7+100 */

background: rgb(71,171,246); /* Old browsers */

background: -moz-linear-gradient(top,  rgb(80, 175, 245) 0%, rgba(0, 128, 200,1) 100%); /* FF3.6-15 */

background: -webkit-linear-gradient(top,  rgb(80, 175, 245) 0%,rgba(0, 128, 200,1) 100%); /* Chrome10-25,Safari5.1-6 */

background: linear-gradient(to bottom,  rgb(80, 175, 245) 0%,rgba(0, 128, 200,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */

	border-radius:0;
	font-size:1em;
	-moz-transition: all 0.25s;
	-webkit-transition: all 0.25s;
	transition: all 0.25s;
	border: 0;
	box-shadow: none;
	color: #ffffff !important;
	font-weight:normal;
	margin-bottom:20px;
}

input[type="submit"].special:hover,
input[type="reset"].special:hover,
input[type="button"].special:hover,
button.special:hover,
.button.special:hover {
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#439de8+0,185bad+100 */

background: rgb(67,157,232); /* Old browsers */

background: -moz-linear-gradient(top,  rgba(198, 213, 64, 0.5) 0%, rgba(198, 213, 64, 1) 100%); /* FF3.6-15 */

background: -webkit-linear-gradient(top,  rgba(198, 213, 64, 0.5) 0%,rgba(198, 213, 64, 1) 100%); /* Chrome10-25,Safari5.1-6 */

background: linear-gradient(to bottom,  rgba(198, 213, 64, 0.5) 0%,rgba(198, 213, 64, 1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}

input[type="submit"].special:active,
input[type="reset"].special:active,
input[type="button"].special:active,
button.special:active,
.button.special:active {
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#439de8+0,185bad+100 */

background: rgb(67,157,232); /* Old browsers */

background: -moz-linear-gradient(top,  rgb(80, 175, 245) 0%, rgba(198, 213, 64, 1) 100%); /* FF3.6-15 */

background: -webkit-linear-gradient(top,  rgb(80, 175, 245) 0%,rgba(198, 213, 64, 1) 100%); /* Chrome10-25,Safari5.1-6 */

background: linear-gradient(to bottom,  rgb(80, 175, 245) 0%,rgba(198, 213, 64, 1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}

input[type="submit"].special.icon::before,
input[type="reset"].special.icon::before,
input[type="button"].special.icon::before,
button.special.icon::before,
.button.special.icon::before {
	color: var(--blau);
  font-family: Polo-Krftg,Arial,sans-serif;
}

input[type="submit"].disabled, input[type="submit"]:disabled,
input[type="reset"].disabled,
input[type="reset"]:disabled,
input[type="button"].disabled,
input[type="button"]:disabled,
button.disabled,
button:disabled,
.button.disabled,
.button:disabled {
	background-color: var(--text) !important;
	box-shadow: none !important;
	color: #fff !important;
	cursor: default;
	opacity: 0.25;
  font-family: Polo-Krftg,Arial,sans-serif;
}
.form-control {
  font-size: 18px;
  color: var(--text)
}
.form-select {
  display: inline-block;
  width: auto;
  color: var(--text)
}

label {
	margin-bottom: 3px;
	font-weight: normal;
	display:inline;
}
ul, dl, ol {
	padding:0;
	margin:0;	
}
ul li, ol li, dl dt, dl dd {
	list-style:none;	
	margin-left:0;
}
/* ########################### Allgemeine Formatierungen ########################### */

.highlight { color: var(--blau) }
.clearfix::after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: ' ';
    clear: both;
    height: 0;
}
.clearfix { display: inline-block }
* html .clearfix { height: 1% }
.clearfix { display: block }

/* Reset */

.row.linewrap [class*="col-"]{
    margin-bottom: -99999px;
    padding-bottom: 99999px;
}

.weiss {
  background-color: #fff;
  padding: 0;
	margin: 0;
}
.blau {
    background-color: var(--blau);
    padding: 40px 0;
    color: #ffffff;
    text-align: center;
	margin: 0;
	/*min-height:150px;*/
}

.gm-style-iw p {
	text-align:left;
	font-size:16px;
	line-height:1.4;
	font-weight:400;
  color: var(--text);
}
.gm-style-iw a {
  text-align:left;
	font-size:16px;
	line-height:1.4;
	font-weight:400;
  color: var(--blau); 
}
.gm-style-iw h2 {
  font-size: 20px;
	color:var(--blau);	
	text-align:left;
}
.gm-style-iw {	 /* GMap Infowindow */
  text-align:left;
}
.blau a:hover {
	color:var(--gruen);	
}
/*.modal-content.blau {
	padding:20px;	
}

.modal-content.blau button:not(.special) {
	color:#fff;
	margin:0;
	position:absolute;
	top:-20px;
	right:20px;
	font-weight:normal;
	font-size:33px;
	text-shadow:none;
}
*/
.lightblue {
	color:var(--gruen) !important;	
}
.lightbluebg {
	background:var(--gruen) !important;	
	color:var(--blau);
}
.orange {
	color:#FF7227 !important;	
}
.orange a {
	color:#FF7227 !important;	
	font-weight:500;
}
.red {
	color:#E51C1F !important;
}
.grey {
	color:var(--text) !important;
}
.green {
	color: #7FE40E !important;
}
.errorfield {
	border-color:#FF7227 !important;
}
p.errorfield {
	display:block;
	border: 1px solid #FF7227;
	background: #FAD28D;
}
p.errorfield small {
	color:#000 !important;
}
.orangebg {
	padding:20px;
	margin:0 0 20px 0;
	background:orange !important;
	color:var(--blau);
}
.orangebg p, .orangebg a, .orangebg h4, .orangebg h5 {
	color:var(--blau) !important;	
}
div.orangebg input[type="email"] {
	color:var(--blau) !important;
	background-color:#FAD28D !important;	
}
div.orangebg input[type="email"]:hover {
	color:var(--blau) !important;
	background-color:#fff !important;	
}

div.orangebg input[type="email"].errorfield {
	border-color:#FF7227 !important;	
	border-width:3px;
	background-color:#fff !important;	
}

.white {
	color:#fff !important;
}
a.white:hover {
	color:var(--gruen) !important;
}
/*.formtable { width:100%; }*/
.formtable tr td {
	padding:3px 10px;	
}
.formtable a {
	display:inline;	
}
table.purelist {
	width:auto;
}
table.purelist tr td {
	font-size:13px;
	color:#000;	
	border-bottom:1px solid #ededed;
}
table.purelist a {
	text-decoration:underline;
}
.blau table.purelist tr td {
	font-size:13px;
	color:#fff;	
	border-bottom:1px solid var(--gruen);
}
input[type="email"].verboten {
	display:none;	
}
.blaufeld {
	background-color: var(--blau);
    padding: 20px;
    color: #ffffff;
    text-align: center;
	margin: 30px auto;
	-webkit-border-radius:20px;
	-moz-border-radius:20px;
	border-radius:20px;
}
.blaufeld * {
	color:#fff;	
}
div.error {
	cursor:pointer;
	opacity:1;
}
div.error:hover {
	opacity:0.5;
}
#plzform select {
	margin:10px 0;	
}
.newsliste {
	text-align:left;
	width:100%;
}
#antrag ul {
	 width:100%;
}
.nowrap {
	white-space: nowrap;
}
span.trenner {
	display:inline;
}
span.trenner2 {
	display:none !important;
}
.img-center {
	width:100%;
	text-align:center;
	margin:15px 0 30px 0;	
}
.img-center img {
	display: inline-block;
  	max-width: 100%;
  	height: auto;	
}

/* ########################### HANDWERKERSUCHE ########################### */

#hs-form ul li {
	height:50px;	
}
#hs-form ul li>* {
	margin-top:12px;
}
#hs-form ul li>img {
	margin-top:0;
}
#hs-form label {
	/*margin-left:6px;	*/
}
#hs-form .hs-icon {
	float:left;
	width:35px;
	margin-right:20px;
	margin-bottom:10px;
}
.resulttable {
	width:100%;
}
.resulttable tr td {
	padding:6px;
	border-bottom:1px solid #ededed;
}
.resulttable tr td.noborder {
	border-bottom:none;
}
.blau .resulttable tr td, .modal-body .resulttable tr td {
	padding:6px;
	border-bottom:1px solid var(--gruen);
}
p.maplink {
	float:left;
	display:inline-block;
}
a.maplink, button.maplink {
	padding:3px 20px;
	border-radius: 20px;
	background:	var(--blau);
	color:#fff;
	display:inline-flex;
  align-items: center;
  justify-content: center;
  height: 32px;
  line-height: 1.2;
}
a.maplink:hover, button.maplink:hover {
	background:	var(--gruen);
}
#hs-form dl {
	clear:both;
	display:inline-block;
}
#hs-form dl dt, #hs-form dl dd {
	clear:left;
}
#hs-form dl dt {
	clear:left;
	margin-right:20px;
	color: var(--blau);
	width:150px;
  font-weight: 500;
}
#hs-form dl dd {
	margin-bottom:15px;
}
#gmap_canvas {
	height:600px;
	padding-bottom:20px;
}

/* ########################### KONTAKT ########################### */

#map {
    position: relative;
    width: 100%;
    height: 400px;
}
#hp-contact .blau, #hs-form .blau {
	padding-top:40px;
	padding-left:20px;	
	padding-right:20px;
}
#contact-form {
	margin-bottom:20px;
}

.contact-detail {
    text-align: center;
    margin: 60px 0;
}
.contact-detail i.fa {
    text-align: center;
    font-size: 30px;
    background-color: var(--blau);
    color: #ffffff;
    padding: 25px 0;
    border-radius: 50px;
    border-top-left-radius: 0;
    margin: 0 10px;
    margin-right: 20px;
    width: 82px;
    height: 80px;
    transition: background-color 0.5s;
}
.contact-detail:hover i.fa { background-color: #333333 }

p.help-block.text-danger ul li {
    display: block;
    margin-left: -30px;
    color: #fb8c09;
}
#success .alert-danger {
    color: #fb8c09;
    background-color: #FDFDFD;
    border-color: var(--blau);
    margin-bottom: 10px;
}

#detail { display:none }

#treffer {
	height:1px;
}
table.hist {
	margin-bottom:30px;
	width:100%;
}
table.hist td {
	border-bottom:1px solid #ddd;
}
table.hist tr:first-child td {
	font-size:11px;
	font-weight:500;
}
#search_postcode {
  background: var(--blau);
  padding: 12px 24px;
  display: flex;
  align-items: center;
}
#search_postcode p, #search_postcode label {
  color: #fff; 
}
.formdiv {
  white-space: nowrap;
  display: inline-block;
  margin-right: 24px;
}
.formdiv label {
  margin-right: 6px;
}