/* Neue Formulare */
form.forms {
  margin-top: 10px;
  line-height: 120%;
  font-size: 1em;
  font-weight: normal;
}

form.forms fieldset {
  margin: 0;
  padding: 0;
  margin-top: 15px;
  border: 0;
}

form.forms legend {
  padding: 0;
  font-size: 1.5em;
  padding-bottom: 1em;
  font-weight: 400;
  line-height: 120%;
  color: #666;
  text-align: left;
}

form.forms label.left, form.forms label.right, form.forms div.label-left, form.forms div.label-right {
  position: relative;
  width: 160px;
  margin: 0 10px 0 0;
  padding: 5px 0;
  vertical-align: top;
  line-height: 35px;
  text-align: left;
  display: block;
  float: left;
  box-sizing: border-box;
}
form.forms label.right {
  width: 100%;
  text-align: left;
  line-height: 40px;
  margin: 0;
}
form.forms div.label-right {
  width: 100%;
  position: relative;
  margin: 0 0 0 10px;
  text-align: left;
}
form.forms fieldset ol {
  margin: 0;
  padding: 0;
}
form.forms fieldset li {
  position: relative;
  list-style: none;
  padding: 2px 0 8px 0;
  margin: 0;
  clear: both;
}
form.forms fieldset li:after {
  position: absolute;
  bottom: 10px;
  right: 0;
  padding: 12px 10px;
  font-size: 0.9em;
  color: #999;
}

form.forms b, form.forms strong, form.forms span[style*="bold"] {
  font-weight: 600 !important;
}


form.forms fieldset li.sectiondesc {
  margin-bottom: 7px;
  line-height: 140%;
}
form.forms fieldset li.comment {
  font-size: 90%;
  padding-top: 7px;
}

form.forms fieldset li.formsp {
  display: none;
}

div.formsprolog {
  width: 100%;
  margin: 0;
  margin-top: 10px;
  padding: 0;
  font-size: 0.83em;
  clear: both;
}

div.formsprolog + fieldset {
  margin-top: 10px;
}

div.forms-headermessage {
  width: 100%;
  text-align: center;
  clear: both;
}

div.forms-buttons {
  width: 100%;
  margin-top: 5px;
  text-align: right;
}

form.forms div.readonly {
  margin: 3px;
  margin-left: 0;
  font-size: 0.93em;
  font-weight: normal;
  padding: 5px;
  height: 35px;
  line-height: 25px;
  border: 1px solid #EEE;
  font-family: 'Fira Sans';
  color: #333;
  font-size: 1rem;
  border-radius: 2px;
  box-sizing: border-box;
  width: 100%;
  transition: background 300ms;
  position: relative;
  display: block;
}
span.forms-obligate {
  color: #C00;
}

div.forms-error {
  position: relative;
  margin-top: 1px;
  padding-left: 2px;
  color: #c00;
  font-size: 0.9em;
  display: block;
}

div.forms-readonlyvalue {
  position: relative;
  width: 302px;
  line-height: 40px;
  border: 1px solid #CCCCCC;
  background-color: #EEEEEE;
  color: #000000;
  display: block;
  clear: both;
}

div.forms-warning {
  position: relative;
  margin-top: 1px;
  padding-left: 2px;
  color: rgb(208,125,42);
  display: block;
  float: left;
}

form.forms input[type="text"], form.forms input[type="date"], form.forms input[type="file"], form.forms input[type="url"], form.forms input[type="email"], form.forms select, form.forms textarea {
  margin: 3px;
  margin-left: 0;
  font-size: 0.93em;
  font-weight: normal;
  padding: 5px;
  height: 35px;
  border: 1px solid #CCC;
  font-family: 'Fira Sans';
  color: #333;
  font-size: 1rem;
  border-radius: 2px;
  box-sizing: border-box;
  width: 100%;
  transition: background 300ms;
}

form.forms select.forms-select-error,
form.forms select.forms-selectbox-error,
form.forms select.forms-selectgroups-error,
form.forms input.forms-textline-error,
form.forms input.forms-textlinelong-error,
form.forms input.forms-integer-error,
form.forms input.forms-float-error,
form.forms input.forms-password-error,
form.forms input.forms-captcha-error,
form.forms input.forms-date-error,
form.forms input.forms-datetime-error,
form.forms input.forms-time-error,
form.forms textarea.forms-textarea-error,
form.forms textarea.forms-textarealong-error,
form.forms input.forms-fileupload-error,
form.forms select.forms-textlinewithhistory-error {
  border-bottom-color: #C00;
}
form.forms select.forms-select-warning,
form.forms select.forms-selectbox-warning,
form.forms select.forms-selectgroups-warning,
form.forms input.forms-textline-warning,
form.forms input.forms-textlinelong-warning,
form.forms input.forms-integer-warning,
form.forms input.forms-float-warning,
form.forms input.forms-password-warning,
form.forms input.forms-captcha-warning,
form.forms input.forms-date-warning,
form.forms input.forms-datetime-warning,
form.forms input.forms-time-warning,
form.forms textarea.forms-textarea-warning,
form.forms textarea.forms-textarealong-warning,
form.forms input.forms-fileupload-warning,
form.forms select.forms-textlinewithhistory-warning {
  border-bottom-color: #f39200;
}

form.forms textarea.forms-textarea, form.forms textarea.forms-textarea-warning, form.forms textarea.forms-textarea-error {
  height: 100px;
}
form.forms textarea.forms-textarealong, form.forms textarea.forms-textarealong-warning, form.forms textarea.forms-textarealong-error {
  height: 350px;
}

form.forms input.forms-checkbox {
  margin: 0;
  margin-top: 5px;
  padding: 0;
}

form.forms input.forms-radio, form.forms input.forms-radio-error, form.forms input.forms-radio-warning {
  margin: 5px;
  vertical-align: middle;
}
form.forms div.forms-radioitem, form.forms div.forms-radioitem-error, form.forms div.forms-radioitem-warning {
}
form.forms div.forms-radioitem-error {
  background-color: rgb(255,181,181);
}
form.forms div.forms-radioitem-warning {
  background-color: rgb(246,208,143);
}

form.forms input.forms-group {
  margin: 5px;
  vertical-align: top;
}
form.forms div.forms-groupitem {
  width: calc( 40% - 20px );
  margin: 5px 10px;
  vertical-align: middle;
  display: block;
  float: left;
}
form.forms div.forms-groupitem label {
  padding: 4px 0 0 5px;
  display: inline-block;
}

form.forms input.forms-rate, form.forms input.forms-rate-error, form.forms input.forms-rate-warning {
  margin: 5px;
  vertical-align: middle;
}
form.forms div.forms-rateitem, form.forms div.forms-rateitem-error, form.forms div.forms-rateitem-warning {
}
form.forms div.forms-rateitem-error {
  background-color: rgb(255,181,181);
}
form.forms div.forms-rateitem-warning {
  background-color: rgb(246,208,143);
}

div.textlinewithhistory {
  position: relative;
  float: left;
}

form.forms input:focus, form.forms textarea:focus {
  background-color: rgb(240,240,240);
}


div.captchadesc {
  position: relative;
  margin-top: 8px;
  margin-bottom: 5px;
  font-size: 0.83em;
  line-height: 1.0;
}

form.forms input.forms-poigeo, form.forms input.forms-poigeo-error, form.forms input.forms-poigeo-warning {
  width: 120px;
  font-size: 0.83em;
  float: none;
}
form.forms input.forms-poigeo-error {
  background-color: rgb(255,181,181);
}
form.forms input.forms-poigeo-warning {
  background-color: rgb(246,208,143);
}
form.forms #map {
  width: 468px;
  height: 150px;
  margin-top: 7px;
  padding-top: 110px;
  border: 1px solid #AAA;
  font-size: 2em;
  color: #AAA;
  text-align: center;
  float: left;
}
form.forms #searchaddress {
  width: 280px;
  margin-right: 3px;
}
form.forms div.poigeo-1 {
  position: relative;
  width: 125px;
  margin-top: 5px;
  margin-left: 15px;
  float: left;
}
form.forms div.poigeo-1 label.left-left {
  float: none;
}

table.slider_table {
  border: 1px solid rgb(200,200,200);
}
td.slider_title {
  text-align: center;
  font-size: 0.78em;
  border-right: 1px solid gray;
}
td.slider_trenner {
  height: 5px;
}
td.slidercell_off {
  width: 15px;
  height: 10px;
  border-right: 1px solid rgb(200,200,200);
  background-color: rgb(230,238,230);
}
td.slidercell_on {
  width: 15px;
  height: 10px;
  border-right: 1px solid rgb(200,200,200);
  background-color: rgb(74,101,123);
}

div.comment1, div.comment2   {
  position: relative;
  font-size: 85%;
  clear: both;
}
div.comment1 {
  padding-bottom: 2px;
}
div.comment2 {
  padding-top: 2px;
}

form.forms div.container-right {
  position: relative;
  width: calc( 100% - 170px );
  float: left;
}
form.forms div.container-left {
  position: relative;
  width: calc( 100% - 170px );
  float: right;
}

@media only screen and (max-width: 800px) and (min-width: 600px) {
  form.forms label.left, form.forms label.right, form.forms div.label-left, form.forms div.label-right {
    width: auto;
    margin: 0;
    padding: 0;
    display: inline;
    float: none;
  }
  form.forms div.container-right, form.forms div.container-left {
    width: auto;
    float: none;
  }
  form.forms fieldset li {
    padding: 0 0 12px 0;
  }
}

div.form-checkbox {
  position: relative;
  display: inline-block;
  border: 1px solid #999;
  border-radius: 2px;
  width: 30px;
  height: 30px;
  margin-right: 10px;
  box-sizing: border-box;
  cursor: pointer;
  background: #FFF;
  vertical-align: middle;
}
input[type="checkbox"].styled {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
input[type="checkbox"].styled:checked + div.form-checkbox:after, input[type="checkbox"].styled:checked + div.form-checkbox:before {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%) rotate(45deg);
  width: 3px;
  height: 25px;
  background: #C00;
  content: '';
}
input[type="checkbox"].styled:checked + div.form-checkbox:before {
  transform: translate(-50%,-50%) rotate(-45deg);
}
div.form-checkbox + label {
  width: calc( 100% - 50px );
  padding: 0;
}
input[type="checkbox"].styled.error + div.form-checkbox {
  border-color: #C00;
}
form.forms div.label-left.checkbox {
  width: 40px;
}
form.forms div.label-left.checkbox + div.container-right {
  width: calc(100% - 50px);
}
form.forms div.label-right {
  width: calc( 100% - 50px );
}

div.forms-buttons input[type="button"], div.forms-buttons input[type="submit"], div.forms-buttons button {
  display: inline-block;
  width: auto;
  border: 0;
  border-radius: 2px;
  background: #C00;
  color: #FFF;
  padding: 10px 30px;
  cursor: pointer;
  text-transform: uppercase;
  font-size: 1rem;
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
  transition: 300ms;
}
div.forms-buttons input[type="button"]:hover, div.forms-buttons input[type="submit"]:hover, div.forms-buttons button:hover {
  background: #A00;
}

#forms13 {
  display: grid;
  border-top: 3px solid #C00;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  grid-column-gap: 80px;
  grid-row-gap: 30px;
  padding: 60px 30px 40px 30px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
#forms13-sectionleistung {
  grid-column: span 2;
}
#forms13-sectionleistung ol {
  display: grid;
  grid-template-columns: repeat( 3, minmax(0,200px) );
  grid-column-gap: 40px;
  grid-row-gap: 20px;
}
#forms13-sectionleistung ol li {
  padding: 5px 10px;
}
#forms13-sectionleistung label.right {
  line-height: 40px;
  font-size: 1.2em;
  cursor: pointer;
}
#forms13 div.forms-buttons {
  grid-column: span 2;
}

#forms14 {
  display: grid;
  border-top: 3px solid #C00;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  grid-column-gap: 80px;
  grid-row-gap: 30px;
  padding: 30px 30px 40px 30px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

#forms15 {
  display: grid;
  border-top: 3px solid #C00;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  grid-column-gap: 80px;
  grid-row-gap: 30px;
  padding: 30px 30px 40px 30px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
#forms15 label.left {
font-size: 0.9em;
text-align: left;
}
#forms15 div.forms-buttons {
  grid-column: span 2;
}
#form15-fieldverbrauch_zaehlerstand:after, #form15-fieldverbrauch_jahresverbrauch:after {
  content: 'kWh';
}
#form15-fieldverbrauch_personenzahl:after {
  content: 'Person(en)';
}

#forms16 {
  display: grid;
  border-top: 3px solid #C00;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  grid-column-gap: 80px;
  grid-row-gap: 30px;
  padding: 30px 30px 40px 30px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
#forms16 label.left {
font-size: 0.9em;
text-align: left;
}
#forms16 div.forms-buttons {
  grid-column: span 2;
}
#form16-fieldverbrauch_zaehlerstand:after {
  content: 'm³';
}
#form16-fieldverbrauch_jahresverbrauch:after {
  content: 'kWh';
}
#form16-fieldverbrauch_leistung:after {
  content: 'kW';
}

#forms17 {
  display: grid;
  border-top: 3px solid #C00;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  grid-column-gap: 80px;
  grid-row-gap: 30px;
  padding: 30px 30px 40px 30px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
#forms17 div.forms-buttons {
  grid-column: span 2;
}
#form17-fieldverbrauch_zaehlerstand:after, #form17-fieldverbrauch_jahresverbrauch:after {
  content: 'm³';
}

#forms18 {
  display: grid;
  border-top: 3px solid #C00;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  grid-column-gap: 80px;
  grid-row-gap: 30px;
  padding: 30px 30px 40px 30px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
#forms18-sectionpersonals {
  grid-column: 1 / 2;
  grid-row: 1 / 3;
}
#forms18-sectionlieferung {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}
#forms18-sectionbankverbindung {
  grid-column: 2 / 3;
  grid-row: 2 / 3;
}
#form18-fieldbankverbindung_sepa label.right {
  line-height: 140%;
  font-size: 0.9em;
}
#forms18 div.forms-buttons {
  grid-column: span 2;
}
#form18-fieldpersonals_strasse, #form18-fieldlieferung_strasse {
  width: calc( 100% - 100px );
  clear: none;
  float: left;
}
#form18-fieldpersonals_hausnr, #form18-fieldlieferung_hausnr {
  float: left;
  margin-left: 10px;
  clear: none;
}
#form18-fieldpersonals_hausnr div.forms-error, #form18-fieldlieferung_hausnr div.forms-error {
  display: none;
}
#form18-fieldpersonals_hausnr label, #form18-fieldlieferung_hausnr label {
  display: none;
}
#form18-fieldpersonals_hausnr div.container-right, #form18-fieldlieferung_hausnr div.container-right {
  width: 90px;
}

#forms19 {
  display: grid;
  border-top: 3px solid #C00;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  grid-column-gap: 80px;
  grid-row-gap: 30px;
  padding: 30px 30px 40px 30px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

#forms19-sectionberechnung div.comment2 {
  font-size: 1rem;
}
#forms19-sectionberechnung table {
  max-width: 600px;
  font-family: 'fira sans';
  font-weight: 300;
}
#forms19-sectionberechnung {
  grid-column: 1 / 2;
  grid-row: 1 / 5;
}
#forms19-sectionauftrag {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}
#forms19-sectionwiderrufsbelehrung {
  grid-column: 2 / 3;
  grid-row: 2 / 3;
}
#forms19-sectionbemerkung {
  grid-column: 2 / 3;
  grid-row: 3 / 4;
}
#forms19-sectiondatenschutz {
  grid-column: 2 / 3;
  grid-row: 4 / 5;
  align-self: end;
}
#forms2-sectiondatenschutz label.right,
#form3-fieldbankverbindung_sepa label.right,
#forms19-sectionauftrag label.right {
  line-height: 140%;
}
#forms19-sectiondatenschutz label.right {
  line-height: 140%;
  font-size: 0.9em;
}
#forms19-sectionwiderrufsbelehrung div.comment2,
#forms19-sectionauftrag div.comment2 {
  max-height: 150px;
  overflow: auto;
  padding: 5px;
  border: 1px solid #CCC;
  border-radius: 3px;
  font-size: 0.9em;
  font-weight: 300;
  background: #F2F2F2;
}
#forms19-sectiondatenschutz legend {
padding-bottom: 0;
}
#forms3-sectiondatenschutz div.comment, #forms3-sectiondatenschutz div.comment2,
#forms19-sectiondatenschutz div.comment, #forms19-sectiondatenschutz div.comment2 {
  font-size: 1em;
  font-weight: 300;
}
#forms19 div.forms-buttons {
  grid-column: span 2;
}


#forms21 {
max-width: 866px;
}
#forms21 fieldset {
margin-bottom: 40px;
}
#form21-fieldpersonals_vorname {
    grid-column-start: 1;
}
#form21-fieldpersonals_strasse, #form21-fieldpersonals_telefon,#form21-fieldpersonals_email {
    grid-column: span 2;
}
#forms21-sectiondienstleistungen > ol {
    display: grid;
    grid-template-columns: minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);
}
#forms21-sectionpersonals > ol, #forms21-sectionzaehlerstaende > ol {
    display: grid;
    grid-template-columns: minmax(0,1fr) minmax(0,1fr);
    column-gap: 40px;
}
#form21-fielddienstleistungen_kundennummer, #form21-fielddienstleistungen_vertrag {
    grid-column: span 3;
}

@media all and (max-width:1000px) {
  #forms13, #forms15, #forms16, #forms17, #forms18, #forms19 {
    grid-template-columns: minmax(0,1fr);
  }
  #forms13-sectionleistung {
    grid-column: auto;
  }
  #forms18-sectionpersonals, #forms18-sectionlieferung, #forms18-sectionbankverbindung, #forms18 div.forms-buttons,
  #forms19-sectionberechnung, #forms19-sectionauftrag, #forms19-sectionwiderrufsbelehrung, #forms19-sectiondatenschutz   {
    grid-column: auto;
    grid-row: auto;
  }
  #forms13 div.forms-buttons, #forms15 div.forms-buttons, #forms16 div.forms-buttons, #forms17 div.forms-buttons, #forms18 div.forms-buttons, #forms19 div.forms-buttons {
    grid-column: auto;
  }
}
@media all and (max-width:600px) {
  #forms21-sectionpersonals > ol, #forms21-sectionzaehlerstaende > ol, #forms21-sectiondienstleistungen > ol {
    display: block;
  }
  #forms13, #forms15, #forms16, #forms17, #forms18, #forms19 {
    padding: 0;
    box-shadow: none;
    border-top: 0;
  }
  #forms13-sectionleistung ol {
    grid-template-columns: minmax(0,1fr);
    grid-row-gap: 0;
  }
}
