/* Fonts */

@font-face {
    font-family: "FS Me";
    font-weight: 300;
    src: url('/fonts/FSMeWeb-Regular.eot');
  src: url('/fonts/FSMeWeb-Regular.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Regular.woff') format('woff');
}

@font-face {
    font-family: "FS Me";
    font-weight: 300;
    font-style: italic;
    src: url('/fonts/FSMeWeb-Regular.eot');
  src: url('/fonts/FSMeWeb-Regular.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Regular.woff') format('woff');
}

@font-face {
    font-family: "FS Me";
    font-weight: 500;
    src: url('/fonts/FSMeWeb-Regular.eot');
  src: url('/fonts/FSMeWeb-Regular.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Regular.woff') format('woff');
}

@font-face {
    font-family: "FS Me";
    font-weight: 500;
    font-style: italic;
    src: url('/fonts/FSMeWeb-Regular.eot');
  src: url('/fonts/FSMeWeb-Regular.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Regular.woff') format('woff');
}

@font-face {
    font-family: "FS Me";
    font-weight: 700;
    src: url('/fonts/FSMeWeb-Regular.eot');
  src: url('/fonts/FSMeWeb-Regular.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Regular.woff') format('woff');
}

@font-face {
    font-family: "FS Me";
    font-weight: 700;
    font-style: italic;
    src: url('/fonts/FSMeWeb-Regular.eot');
  src: url('/fonts/FSMeWeb-Regular.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Regular.woff') format('woff');
}

@font-face {
    font-family: "FS Me";
    font-weight: 900;
    src: url('/fonts/FSMeWeb-Bold.eot');
  src: url('/fonts/FSMeWeb-Bold.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Bold.woff') format('woff');
}

@font-face {
    font-family: "FS Me";
    font-weight: 900;
    font-style: italic;
    src: url('/fonts/FSMeWeb-Bold.eot');
  src: url('/fonts/FSMeWeb-Bold.eot?#iefix') format('embedded-opentype'), url('/fonts/FSMeWeb-Bold.woff') format('woff');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 400;
    src: url('/fonts/WF-029271-009748-000445.eot');
  src: url('/fonts/WF-029271-009748-000445.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000445.woff') format('woff'), url('/fonts/WF-029271-009748-000445.ttf') format('truetype');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 400;
    font-style: italic;
    src: url('/fonts/WF-029271-009748-000445.eot');
  src: url('/fonts/WF-029271-009748-000445.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000445.woff') format('woff'), url('/fonts/WF-029271-009748-000445.ttf') format('truetype');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 500;
    src: url('/fonts/WF-029271-009748-000445.eot');
  src: url('/fonts/WF-029271-009748-000445.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000445.woff') format('woff'), url('/fonts/WF-029271-009748-000445.ttf') format('truetype');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 500;
    font-style: italic;
    src: url('/fonts/WF-029271-009748-000445.eot');
  src: url('/fonts/WF-029271-009748-000445.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000445.woff') format('woff'), url('/fonts/WF-029271-009748-000445.ttf') format('truetype');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 600;
    src: url('/fonts/WF-029271-009748-000445.eot');
  src: url('/fonts/WF-029271-009748-000445.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000445.woff') format('woff'), url('/fonts/WF-029271-009748-000445.ttf') format('truetype');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 600;
    font-style: italic;
    src: url('/fonts/WF-029271-009748-000445.eot');
  src: url('/fonts/WF-029271-009748-000445.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000445.woff') format('woff'), url('/fonts/WF-029271-009748-000445.ttf') format('truetype');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 700;
    src: url('/fonts/WF-029271-009748-000447.eot');
  src: url('/fonts/WF-029271-009748-000447.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000447.woff') format('woff'), url('/fonts/WF-029271-009748-000447.ttf') format('truetype');
}

@font-face {
    font-family: "Fedra Serif";
    font-weight: 700;
    font-style: italic;
    src: url('/fonts/WF-029271-009748-000447.eot');
  src: url('/fonts/WF-029271-009748-000447.eot?#iefix') format('embedded-opentype'), url('/fonts/WF-029271-009748-000447.woff') format('woff'), url('/fonts/WF-029271-009748-000447.ttf') format('truetype');
}

/* Header */

header {
    /*border-bottom:1px solid #D9D9D9;*/
    box-shadow: 0 4px 5px 0 rgba(0,0,0,0.12), 0 1px 10px 0 rgba(0,0,0,0.10), 0 2px 4px -1px rgba(0,0,0,0.16);
    position:fixed;
    top:0px;
    left:0px;
    width:100%;
    height:95px;
    background-color:#FFFFFF;
    z-index:2000;
}
.header {
    margin:auto;
    width:100%;
    /*max-width:1440px;*/
    height:95px;
    position:relative;
    text-align:left;
    padding:0px 23px 0px 23px;
}
.header .logo img {
    width:136px;
    height:57px;
    margin-top:20px;
}
.contact-telephone {
    /*position:absolute;
    right:24px;
    top:24px;*/
}
.contact-telephone span {
    position:relative;
    padding:0px 0px 0px 32px;
    color:#8E0038;
    font-size:14px;
    font-weight:900;
}
.contact-telephone span.contact-telephone-number {
    padding:0px;
}
.contact-telefone a {
    color:#8E0038;
}
.contact-telephone img {
    position:absolute;
    top:-4px;
    left:0px;
}
.tools {
    text-align:right;
    padding:34px 0px 0px 0px;
}
.tools .button {
    margin-top:-5px;
    max-width:100%;
    min-width:auto;
}

/* Main */

.main {
    padding-top:95px;
}

@media (max-width: 911px) {
    header, .header {
        height:72px;
    }
    .header .logo img {
        width:100px;
        height:42px;
        margin-top:16px;
    }
    .contact-telephone-number {
        display:none;
    }
    .tools {
        padding:24px 0px 0px 0px;
    }
    .main {
        padding-top:72px;
    }
}

/* Hero */
.ergo-hero {
    width:100%;
    background-color:#f0c494;
    margin:0px 0px 96px 0px;
}
.ergo-hero:after {
  content: "";
  display: table;
  clear: both;
}
.ergo-hero-left-wrapper {
    width:50%;
    height:650px;
    background-image:url(../img/Freundschaftswerbung-ERGO-1440x810.jpg);
    background-repeat:no-repeat;
    background-size:auto 100%;
    background-position: center center;
    float:left;
}
.ergo-hero-right-wrapper {
    width:50%;
    height:650px;
    padding:0px 96px 0px 96px;
    float:right;
    position: relative;
    background-color:#f0c494;
}
.ergo-hero-right {
    display:table;
    width:100%;
    max-width:720px;
    height:650px;
}
.ergo-hero-align {
    display:table-row;
}
.ergo-hero-content {
    display:table-cell;
    vertical-align:middle;
    max-width:720px;
    height:650px;
}
.ergo-hero-content .cta-hero {
    margin-top:20px;
}
.ergo-hero-right span {
    font-size:18px;
    font-weight:900;
    text-transform:uppercase;
}
.ergo-hero-right h1 {
    font-family: "Fedra Serif";
    color:#8E0038;
    font-size:48px;
    line-height:52px;
    font-weight:700;
    margin:20px 0px 20px 0px;
    padding:0px;
}
@media screen and (max-width: 912px) {
    .ergo-hero-left-wrapper {
        height:450px;
    }
    .ergo-hero-right-wrapper {
        height:450px;
        padding:0px 28px 0px 28px;
    }
    .ergo-hero-right {
        height:450px;
    }
    .ergo-hero-content {
        height:450px;
    }
    .ergo-hero-right span {
        font-size:16px;
    }
    .ergo-hero-right h1 {
        font-size:36px;
        line-height:42px;
    }
}
@media screen and (max-width: 768px) {
    .ergo-hero {
        margin:0px 0px 48px 0px;
    }
    .ergo-hero-right h1 {
        font-size:26px;
        line-height:32px;
    }
}
@media screen and (max-width: 480px) {
    .ergo-hero-left-wrapper {
        width:100%;
        float:none;
        height:300px;
    }
    .ergo-hero-right-wrapper {
        width:100%;
        float:none;
        height:auto;
        padding:50px 20px 50px 20px;
    }
    .ergo-hero-right {
        height:auto;
    }
    .ergo-hero-content {
        display:table-cell;
        height:auto;
    }
}

/* Produktheader */

.produktHeader {
    background-color:#C9E6E9;
    margin:0px 0px 96px 0px;
}
.produktHeader-wrapper {
    max-width:1440px;
    width:100%;
    background-color:#C9E6E9;
    margin:0px auto 0px auto;
}
.produktHeader:after {
  content: "";
  display: table;
  clear: both;
}
.produktHeader-right-wrapper {
    width:58%;
    height:350px;
    background-image:url(../img/Technikschutz-ERGO-1440x810.jpg);
    background-repeat:no-repeat;
    background-size:auto 100%;
    background-position: center center;
    float:right;
}
.produktHeader-left-wrapper {
    width:42%;
    height:350px;
    padding:0px 48px 0px 48px;
    float:left;
    position: relative;
    background-color:#C9E6E9;
}
.produktHeader-left {
    display:table;
    width:100%;
    max-width:720px;
    height:350px;
}
.produktHeader-align {
    display:table-row;
}
.produktHeader-content {
    display:table-cell;
    vertical-align:middle;
    max-width:720px;
    height:350px;
}
.produktHeader-content .cta-hero {
    margin-top:20px;
}
.produktHeader-left span {
    font-size:18px;
    font-weight:900;
}
.produktHeader-left h1 {
    font-family: "Fedra Serif";
    color:#8E0038;
    font-size:48px;
    line-height:52px;
    font-weight:700;
    margin:15px 0px 35px 0px;
    padding:0px;
    /*-moz-hyphens: auto;
  -o-hyphens: auto;
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  hyphens: auto;*/
}
.produktHeader.produktHeader-blue,
.produktHeader-blue .produktHeader-wrapper,
.produktHeader-blue .produktHeader-left-wrapper {
    background-color:#C9E6E9;
}
.produktHeader.produktHeader-orange,
.produktHeader-orange .produktHeader-wrapper,
.produktHeader-orange .produktHeader-left-wrapper {
    background-color:#f0c494;
}
.produktHeader.produktHeader-violett,
.produktHeader-violett .produktHeader-wrapper,
.produktHeader-violett .produktHeader-left-wrapper {
    background-color:#e4d6e4;
}
.produktHeader.produktHeader-green,
.produktHeader-green .produktHeader-wrapper,
.produktHeader-green .produktHeader-left-wrapper {
    background-color:#b5d5c1;
}
.produktHeader.produktHeader-yellow,
.produktHeader-yellow .produktHeader-wrapper,
.produktHeader-yellow .produktHeader-left-wrapper {
    background-color:#f8e89d;
}
@media screen and (max-width: 912px) {
    .produktHeader-right-wrapper {
        height:450px;
    }
    .produktHeader-left-wrapper {
        height:450px;
        padding:0px 28px 0px 28px;
    }
    .produktHeader-left {
        height:450px;
    }
    .produktHeader-content {
        height:450px;
    }
    .produktHeader-left span {
        font-size:16px;
    }
    .produktHeader-left h1 {
        font-size:36px;
        line-height:42px;
    }
}
@media screen and (max-width: 768px) {
    .produktHeader {
        margin:0px 0px 48px 0px;
    }
    .produktHeader-left h1 {
        font-size:26px;
        line-height:32px;
    }
}
@media screen and (max-width: 480px) {
    .produktHeader-right-wrapper {
        width:100%;
        float:none;
        height:300px;
    }
    .produktHeader-left-wrapper {
        width:100%;
        float:none;
        height:auto;
        padding:50px 20px 50px 20px;
    }
    .produktHeader-left {
        height:auto;
    }
    .produktHeader-content {
        display:table-cell;
        height:auto;
    }
}

/* Footer */

.footer-wrap {
    width:100%;
    background:#8E0038;
    color:#ffffff;
    text-align:center;
    margin-top:20px;
}
.footer {
    text-align:left;
    margin:auto;
    width:100%;
    max-width:1440px;
    padding:24px 20px 24px 20px;
    font-size:14px;
}
.footer-left {
    float:left;
    width:50%;
}
.footer-right {
    float:right;
    width:50%;
    text-align:right;
}
.footer-right span {
    padding:0px 0px 0px 10px;
    margin:0px 0px 0px 10px;
    border-left:1px solid #FFFFFF;
}
.footer a {
    color: #FFFFFF;
}
.footer a:visited {
  color: #FFFFFF;
}
.footer:after {
  content: "";
  display: table;
  clear: both;
}
@media screen and (max-width: 400px) {
    .footer-left {
        float:none;
        width:100%;
        text-align:left;
    }
    .footer-right {
        float:none;
        width:100%;
        text-align:left;
        padding-top:20px;
    }
}


/* Beitrag */

.premiumBox-wrap {
    position:relative;
    background: #F2F2F2;
    margin: 25px 0px 68px 0px;
    padding: 17px 0px 17px 0px;
    border-radius:2px;
}
.premiumBox-border-top {
    position:absolute;
    top:15px;
    left:0px;
    width:4px;
    height:14px;
    background-color:#8E0038;
    border-radius:2px 2px 0px 0px;
}
.premiumBox-border-bottom {
    position:absolute;
    bottom:15px;
    left:0px;
    width:4px;
    height:14px;
    background-color:#8E0038;
    border-radius:0px 0px 2px 2px;
}
.premiumBox {
  display: flex;
  position: relative;
  width: 100%;
  height: auto;
  color: #333333;
  transition: all 0.3s ease-in-out;
  border-left:4px solid #8E0038;
}
.categoryProductTeaserBeitrag .premiumBox {
    margin: 10px 0px 0px 0px;
}
.premiumBox .contentWrapper.middle, .premiumBox .contentWrapper.right {
    padding: 12px 24px 4px 24px;
    flex: 1;
}
.button-align-right {
    text-align:right;
    margin:-20px 15px 72px 0px;
}
.premiumBox .contentWrapper.left {
    padding: 16px 0px 4px 24px;
    flex: 1;
    margin:0px;
}
.premiumBox p {
    margin-bottom: 15px;
    font-weight: normal;
    line-height: 20px;
}
.premiumBox .h2 {
  position: relative;
  display: flex;
  margin-bottom: 15px;
  font-size:24px;
  line-height: 24px;
  align-items: center;
}
.premiumBox .contentWrapper.left .checkmark {
  margin: 0;
}
.premiumBox .contentWrapper.left .checkmark li:last-child {
  margin-bottom: 0;
}
.premiumBox .contentWrapper.right {
    display: flex;
    /*align-items: flex-end;*/
    justify-content: flex-end;
}
.premiumBox .contentWrapper.right > div {
    margin-left: 25px;
    text-align: right;
}
.premiumBox .contentWrapper.right > div img {
  display: block;
  margin-bottom: 0;
}
.premiumBox .price {
  display: block;
  color: #333333;
}
.premiumBox .price strong {
  font-size: 36px;
  font-weight:900;
  margin-left:8px;
  white-space: nowrap;
}
.premiumBox .contentWrapper.right > div .button {
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .premiumBox .h2 {
      font-size:18px;
      line-height: 24px;
    }
    .premiumBox .price strong {
      font-size: 24px;
    }
}
@media screen and (max-width: 480px) {
    .premiumBox {
    display: block;
  }
  .button-align-right {
        text-align:left;
        margin:-20px 15px 20px 0px;
    }
    .premiumBox .contentWrapper.right {
        display: block;
    }
    .premiumBox .contentWrapper.right > div {
        margin-left: 0px;
        text-align:left;
    }
  .premiumBox .contentWrapper.right {
    flex-direction: column;
  }
  .premiumBox .contentWrapper.right > div img {
    margin-bottom: 15px;
  }
}
.price-label-2 {
    display:none;
}
@media screen and (max-width: 480px) {
    .price-label-2 {
        display:block;
        margin:-5px 0px 20px 0px;
    }
    .price-label-1 {
        display:none;
    }
}

/* Spacer */
.spacer {
    margin: 60px 0px 0px 0px;
}
@media (max-width: 767px) {
    .spacer {
      margin: 30px 0px 10px 0px;
    }
}

/* Fortschrittsanzeige */

.stepnav {
  display: table;
  display: flex;
  overflow: hidden;
  width: 100%;
  margin: 0px 0px 40px 0px;
  padding-left: 0;
  list-style: none;
  counter-reset: stepItem;
  border-radius:9px;
}
.stepnav li {
  position: relative;
  display: table-cell;
  display: flex;
  height: 65px;
  padding-left: 36px;
  font-size:16px;
  color: #333333;
  background-color: #dddddd;
  text-align: center;
  vertical-align: middle;
  align-items: center;
  flex-grow: 1;
  flex-basis: 0;
  justify-content: center;
  line-height: 1.4em;
}
.stepnav li:after, .stepnav li:before {
  content: '';
  position: absolute;
  z-index: 1;
  top: -17px;
  display: inline-block;
  width: 0;
  height: 0;
  color: inherit;
  border-width: 50px 0 50px 20px;
  border-style: solid;
  vertical-align: middle;
}
.stepnav li:before {
  right: -18px;
  border-color: transparent transparent transparent #ffffff;
}
.stepnav li:after {
  right: -10px;
  border-color: transparent transparent transparent #dddddd;
}
.stepnav li:first-child {
  padding-left: 20px;
}
.stepnav li:last-child {
  padding-right: 10px;
}
.stepnav li:last-child:before {
    right:0px;
    border: none;
}
.stepnav li:last-child:after {
    content: normal;
    border: none;
}
.stepnav li.done {
  color: #ffffff;
  background-color: #8E0038;
}
.stepnav li.done:after {
    border-left-color: #8E0038;
}
.stepnav li.done .title:before {
    line-height: 1.70em;
    color: #FFFFFF;
    border:2px solid #FFFFFF;

  /*content: '\e607';
  color: #79b829;
  line-height: 1.5em;*/
}
.stepnav li.active {
    color: #ffffff;
  background-color: #8E0038;
}

@media screen and (min-width: 480px) {
  .stepnav li.active {
    text-align: left;
    flex-basis: 36%;
    justify-content: flex-start;
  }
}
@media (max-width: 767px) {
    .stepnav {
      margin: 30px 0px 30px 0px;
    }
    .stepnav li {
      height: 48px;
      padding-left: 36px;
      font-size:16px;
    }
    .stepnav li:after, .stepnav li:before {
      top: -25px;
    }
}
@media screen and (min-width: 980px) {
  .stepnav li.active {
    flex-basis: 0;
  }
}
.stepnav li.active:after {
  border-left-color: #8E0038;
}
.stepnav li.active .title {
  margin-left: 0;
}
@media screen and (max-width: 479px) {
    .stepnav li.active {
        padding-left: 30px;
        padding-right: 10px;
    }
    .stepnav li:after, .stepnav li:before {
        top: -35px;
      border-width: 60px 0 60px 15px;
    }
}
@media screen and (min-width: 480px) {
  .stepnav li.active .title {
    width: 100%;
    flex-grow: 1;
  }
}
.stepnav li.active .title:before {
    line-height: 1.70em;
  color: #FFFFFF;
    border:2px solid #FFFFFF;
}
.stepnav li .title {
  display: inline-block;
  overflow: hidden;
  width: 26px;
  height:26px;
  margin-left: -15px;
  vertical-align: middle;
  white-space: nowrap;
  text-overflow: ellipsis;
  flex-grow: 0;
}
@media screen and (min-width: 980px) {
  .stepnav li .title {
    width: 100%;
    margin-left: 0;
    text-align: left;
    flex-grow: 1;
    justify-content: flex-start;
  }
}
.stepnav li .title:before {
    content: counters(stepItem, '');
    font-size:14px;
    display: inline-block;
    width: 22px;
    height: 22px;
    margin-right: 10px;
    color: #8E0038;
    border:2px solid #8E0038;
    border-radius: 50%;
    background-color: transparent;
    line-height: 1.70em;
    text-align: center;
    counter-increment: stepItem;
    font-weight:900;
}


/* Table */

.rateTableContainer {
  position: relative;
  margin-top: 50px; }
  .rateTableContainer .table-tabs {
    display: none; }
  .rateTableContainer .rate-table {
    table-layout: fixed; }
    .rateTableContainer .rate-table .tooltip {
      margin-left: 10px; }
    @media screen and (max-width: 699px) {
      .rateTableContainer .rate-table .select {
        min-width: 150px; } }
    .rateTableContainer .rate-table tr {
      border-bottom: 1px solid #d8d8d8; }
      .rateTableContainer .rate-table tr.subline {
        background-color: #e7edf3;
        font-weight: bold; }
        .rateTableContainer .rate-table tr.subline td {
          display: table-cell;
          border-width: 0;
          background-color: inherit; }
      .rateTableContainer .rate-table tr th, .rateTableContainer .rate-table tr td {
        border-left: 1px solid #d8d8d8; }
        .rateTableContainer .rate-table tr th:first-child, .rateTableContainer .rate-table tr td:first-child {
          width: auto;
          border-width: 0;
          background-color: #ffffff;
          vertical-align: middle; }
        @media screen and (max-width: 699px) {
          .rateTableContainer .rate-table tr th, .rateTableContainer .rate-table tr td {
            white-space: normal;
            word-wrap: break-word;
            word-break: break-word; } }
    .rateTableContainer .rate-table thead th {
      height: 60px;
      color: #ffffff;
      background-color: #8E0038;
      vertical-align: middle; }
      .rateTableContainer .rate-table thead th.spacer {
        background-color: #ffffff; }
      .rateTableContainer .rate-table thead th.highlight {
        background-color: #8E0038; }
      .rateTableContainer .rate-table thead th .subtitle {
        display: block;
        font-size: 0.8571428571rem;
        font-weight: normal;
        line-height: 18px; }
      @media screen and (max-width: 699px) {
        .rateTableContainer .rate-table thead th .tooltip {
          position: absolute;
          top: 19px;
          left: 11px;
          margin-left: 0; } }
    .rateTableContainer .rate-table tbody tr:last-child {
      border-bottom: none; }
    .rateTableContainer .rate-table tbody th:first-child {
      width: auto;
      max-width: 250px;
      border-width: 0;
      background-color: #ffffff; }
      @media screen and (max-width: 699px) {
        .rateTableContainer .rate-table tbody th:first-child {
          display: flex;
          flex-direction: column;
          min-width: 0;
          max-width: 250px; }
          .rateTableContainer .rate-table tbody th:first-child span {
            order: 1; }
          .rateTableContainer .rate-table tbody th:first-child .tooltip {
            margin-left: 0;
            order: 2; } }
    .rateTableContainer .rate-table tbody tr td {
      padding: 15px;
      background-color: #ffffff;
    }
    .rateTableContainer .rate-table tbody tr.table-alt td {
        background-color: #f2f2f2;
    }
      .rateTableContainer .rate-table tbody td.subline {
        color: #8E0038;
        background-color: #ffffff;
        font-size: 1.1428571429rem;
        font-weight: bold; }
      .rateTableContainer .rate-table tbody td.pricing {
        padding: 20px;
        color: #8E0038;
        background-color: #e7edf3;
        font-weight: bold; }
        .rateTableContainer .rate-table tbody td.pricing:first-child {
          color: #333333; }
        .rateTableContainer .rate-table tbody td.pricing .price {
          font-size: 26px;
          line-height: 28px; }
    .rateTableContainer .rate-table tfoot tr {
      border-top: 1px solid #d8d8d8; }
      .rateTableContainer .rate-table tfoot tr td {
        position: relative;
        padding: 15px;
        background-color: #e7edf3;
        vertical-align: bottom; }
        .rateTableContainer .rate-table tfoot tr td:first-child {
          padding: 15px 20px;
          background-color: #e7edf3;
          vertical-align: middle; }
        .rateTableContainer .rate-table tfoot tr td.highlight {
          padding-top: 40px; }
        .rateTableContainer .rate-table tfoot tr td .disclaimer {
          position: absolute;
          top: 0;
          left: 0;
          display: block;
          width: 100%;
          height: 26px;
          color: #ffffff;
          background-color: #8E0038;
          font-size: 0.8571428571rem;
          font-weight: normal; }
          .rateTableContainer .rate-table tfoot tr td .disclaimer:before {
            position: relative;
            top: 3px;
            display: inline;
            margin-right: 5px;
            font-size: 1.3em; }
        .rateTableContainer .rate-table tfoot tr td .price {
          font-size: 26px;
          line-height: 28px; }
        .rateTableContainer .rate-table tfoot tr td button {
          margin-top: 10px;
          padding-right: 30px; }
  @media screen and (max-width: 479px) {
    .rateTableContainer {
      margin-top: 20px; }
      .rateTableContainer .table-tabs {
        display: flex;
        width: 100%;
        margin: 0;
        margin-bottom: 15px;
        padding: 0;
        list-style: none;
        color: #8E0038;
        font-size: 0.8571428571rem;
        font-weight: bold;
        align-items: center; }
        .rateTableContainer .table-tabs li {
          min-height: 100%;
          padding: 11px 0;
          border: 1px solid #dddddd;
          border-left-width: 0;
          text-align: center;
          transition: all 0.3s ease-in-out;
          cursor: pointer;
          flex: 1 auto; }
          .rateTableContainer .table-tabs li.p-0 {
            display: none; }
          .rateTableContainer .table-tabs li.p-1 {
            border-left-width: 1px; }
          .rateTableContainer .table-tabs li:hover {
            background-color: #d8d8d8; }
          .rateTableContainer .table-tabs li.active-tab {
            color: #ffffff;
            background-color: #8E0038; }
      .rateTableContainer .rate-table {
        table-layout: auto;
        font-size: 0.8571428571rem; }
        .rateTableContainer .rate-table th, .rateTableContainer .rate-table td {
          width: 50%; }
        .rateTableContainer .rate-table thead th {
          background-color: #8E0038; }
        .rateTableContainer .rate-table tbody td.pricing {
          padding: 20px 10px; }
        .rateTableContainer .rate-table tbody td ul {
          padding-left: 15px; }
        .rateTableContainer .rate-table .select {
          min-width: inherit;
          height: 2.6em; }
          .rateTableContainer .rate-table .select select {
            font-size: 0.8571428571rem; }
          .rateTableContainer .rate-table .select:after {
            line-height: 2.1em; }
        .rateTableContainer .rate-table .js-is-hidden {
          display: none; }
        .rateTableContainer .rate-table tfoot tr td {
          padding: 15px 10px; } }

.p-1, .p-2 {
    text-align:center;
}
.p-2 .ergo-checkbox {
    margin:0px auto 0px auto;
    width:16px;
    padding:0px;
}

/* Tooltip */

.tooltip {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  z-index:0;
}
.tooltip.zindex {
    z-index: 3000;
}
@media screen and (min-width: 700px) {
  .tooltip {
    align-self: center;
  }
  .tooltip.zindex {
        z-index: 1000;
    }
}
@media screen and (min-width: 840px) {
  .tooltip {
    position:absolute;
    top:15px;
    right:-40px;
  }
}
@media screen and (min-width: 912px) {
  .tooltip {
    position:absolute;
    top:15px;
    right:110px;
  }
}
.tooltip .tooltip-layer {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  display: none;
  overflow: auto;
  width: 100vw;
  height: 100vh;
  padding: 44px 31px 44px 31px;
  background-color: rgba(255, 255, 255, 1);
  box-shadow: 0 100px 0 rgba(0, 0, 0, 0.1);
  font-weight: normal;
  -webkit-overflow-scrolling: touch;
}
@media screen and (min-width: 700px) {
    .tooltip .tooltip-layer {
      position: absolute;
      top: 100%;
      left: -46px;
      overflow: initial;
      width: 300px;
      height: auto;
      margin-top: 15px;
      font-size: 0.8571428571rem;
      line-height: 1.5em;
      background: #FFFFFF;
        border: 1px solid #F2F2F2;
        box-shadow: 0 8px 10px 0 rgba(0,0,0,0.15);
        border-radius: 9px;
    }
  .tooltip .tooltip-layer:before {
    content: '';
    position: absolute;
    top: 0px;
    left: 32px;
    width: 48px;
    border-top: 4px solid #8E0038;
  }
  .tooltip .tooltip-layer.right {
    left: -232px;
  }
  .tooltip .tooltip-layer.right:before {
    left: auto;
    right:32px;
    }
}
.tooltip .tooltip-layer.visible {
    display: inline-block;
}
.tooltip .tooltip-layer .close {
  position: absolute;
  background : url(img/icons/Icon_close.svg) 5px 5px no-repeat;
  top: 20px;
  right: 20px;
  display: flex;
  width: 36px;
  height: 36px;
  color: #ffffff;
  border-radius: 50%;
  font-size: 1.4rem;
  cursor: pointer;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 700px) {
  .tooltip .tooltip-layer .close {
        background : url(img/icons/Icon_close.svg) 5px 5px no-repeat;
        top: 10px;
        right: 10px;
        width: 22px;
        height: 22px;
        font-size: 1rem;
    }
}
.tooltip .title {
  display: block;
  width: 80%;
  margin-bottom: 10px;
}
.tooltip .tooltip-icon {
    background : url(img/icons/icons_info_24_grey.svg) 0px 0px no-repeat;
  position: relative;
  z-index: 0;
  display: flex;
  width: 20px;
  height: 20px;
  color: #ffffff;
  cursor: pointer;
  justify-content: center;
  align-items: center;
}
.tooltip .tooltip-icon:before {
    display: inline-block;
    height: 25px;
}
.tooltip .tooltip-icon:hover, .tooltip .tooltip-icon.active {
    background : url(img/icons/icons_info_24.svg) 0px 0px no-repeat;
    -webkit-box-shadow: 0px 0px 0px 8px rgba(142,0,56,0.08);
    -moz-box-shadow: 0px 0px 0px 8px rgba(142,0,56,0.08);
    box-shadow: 0px 0px 0px 8px rgba(142,0,56,0.08);
    background-color: rgba(142,0,56,0.08);
    border-radius:50%;
}
.tooltip.asterisk .tooltip-icon {
    width: 16px;
    height: 17px;
}
.tooltip.asterisk .tooltip-icon:before {
  height: auto;
}

/* Message */

.message {
    border-radius: 9px;
    padding:24px 54px 24px 64px;
    margin:0px 0px 30px 0px;
}
.message.message-info {
    background:url(img/icons/icons_info_24_grey.svg) 24px 28px no-repeat;
    border: 1px solid #D9D9D9;
}

/* Icons */

.icon {
    width:36px;
    height:36px;
    display:inline-block;
}
.icon.icon-check {
    background:url(img/icons/CheckIllustratedIcon.svg) 0px 0px no-repeat;
    background-size:100% 100%;
}

/* Numbered list */

.numbered-list {
    position:relative;
    padding-left:296px;
}
.numbered-list .numbered-list-headline {
    position:absolute;
    top:0px;
    left:0px;
    width:272px;
    /*padding-top:34px;*/
}
/*.numbered-list .numbered-list-headline:before {
    position:absolute;
    top:0px;
    left:0px;
    content: '';
    height:2px;
    width:124px;
    background-color:#b31767;
}*/
.numbered-list ol {
  width: 100%;
  padding-left: 0;
  list-style: none;
  counter-reset: stepItem;
}
.numbered-list li {
  position: relative;
  padding: 0px 0px 16px 0px;
}
.numbered-list li:before {
    position:absolute;
    content: counters(stepItem, '');
    font-size:18px;
    display: inline-block;
    width: 36px;
    height: 36px;
    color: #b31767;
    border-radius: 50%;
    background-color: #e4d6e4;
    line-height: 2.0em;
    text-align: center;
    counter-increment: stepItem;
    font-weight:900;
}
.numbered-list li .content {
    padding: 4px 0px 0px 59px;
}
.numbered-list.twa-icons li.twa-icon-heart:before {
    content: '';
    background : url(img/icons/HeartIcon.svg) 0px 1px no-repeat;
    background-size:32px 32px;
}
.numbered-list.twa-icons li.twa-icon-invoice:before {
    content: '';
    background : url(img/icons/ERGO_Icon_black_Rechnung.svg) 0px 1px no-repeat;
    background-size:32px 32px;
}
.numbered-list.twa-icons li.twa-icon-pig:before {
    content: '';
    background : url(img/icons/ERGO_Icon_black_Sparschwein.svg) 0px 1px no-repeat;
    background-size:32px 32px;
}
.numbered-list.twa-icons li.twa-icon-user:before {
  content: '';
  background : url(img/icons/ERGO_Icon_black_Kunde.svg) 0px 1px no-repeat;
  background-size:32px 32px;
}
.numbered-list.twa-icons li.twa-icon-globe:before {
  content: '';
  background : url(img/icons/ERGO_Icon_black_Globus2.svg) 0px 1px no-repeat;
  background-size:32px 32px;
}
@media (max-width: 911px) {
    .numbered-list {
        padding-left:248px;
    }
    .numbered-list .numbered-list-headline {
        width:224px;
        /*padding-top:32px;*/
    }
    .numbered-list li:before {
        font-size:16px;
        width: 32px;
        height: 32px;
    }
    .numbered-list li .content {
        padding: 4px 0px 0px 49px;
    }
}
@media (max-width: 767px) {
    .numbered-list {
        padding-left:0px;
    }
    .numbered-list .numbered-list-headline {
        position:static;
        padding-bottom:25px;
    }
    .numbered-list li:before {
        font-size:12px;
        width: 24px;
        height: 24px;
    }
    .numbered-list li .content {
        padding: 4px 0px 0px 44px;
    }
}

/* Navigation */

.navigation {
    position:absolute;
    bottom:0px;
    left:180px;
}
.navigation ul {
    list-style-type:none;
    margin:0px;
    padding:0px;
}
.navigation ul li {
    display:inline-block;
    font-size:14px;
    padding:0px 20px 10px 20px;
}
.navigation ul li.active {
    color:#8E0038;
    border-bottom:3px solid #8E0038;
}
.navigation ul li a {
    color:#333333;
    font-weight:900;
    display:inline-block;
    padding:10px 0px 10px 0px;
}
.navigation ul li.active a {
    color:#8E0038;
}
.navigation ul li a:hover {
    text-decoration:none;
    color:#8E0038;
}
.burger-btn {
    display:none;
    width: 24px;
  height: 24px;
  color: #ffffff;
  background-color: #ffffff;
  font-size: 0.7857142857rem;
  font-weight: bold;
  text-align: center;
  transition: all 150ms ease-out;
  margin-right:10px;
}
.burger-btn span {
  position: relative;
  top: 25%;
  display: block;
  width: 20px;
  height: 2px;
  margin: 0 auto;
  margin-bottom: 5px;
  background-color: #b1b1b1;
  transition: transform 150ms ease-out, opacity 0ms 30ms ease-out;
}
.burger-btn:hover {
    text-decoration: none;
}
.burger-btn.active {}
.burger-btn.active span {
    transform: rotate(135deg);
    background-color:#8E0038;
}
.burger-btn.active span:first-child {
    transform: rotate(45deg) translate3d(5px, 5px, 0);
}
.burger-btn.active span:last-child {
    opacity: 0;
    transform: rotate(-45deg);
}
@media (max-width: 767px) {
    .navigation {
        display:none;
    }
    .burger-btn {
        display:inline-block;
    }
}
.mainnav .overlay {
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  visibility:hidden;
  width: 100vw;
  height: 100vh;
  opacity: 0;
  background-color: rgba(0,0,0,0.72);
  transition: all 0.3s ease-in-out;
}
.mainnav .overlay .navigation-overlay {
    position:absolute;
    top:0px;
    left:-320px;
    width:100%;
    max-width:320px;
    height: 100vh;
    background-color:#FFFFFF;
    padding:22px;
    transition: all 0.5s ease-in-out;
}
@media (max-width: 767px) {
    .mainnav .overlay.visible {
      visibility:visible;
      opacity: 1;
    }
    .mainnav .overlay.visible .navigation-overlay {
        left:0px;
    }
    .navigation-overlay ul {
        list-style-type:none;
        margin:20px 0px 34px 0px;
        padding:0px 0px 34px 0px;
        border-bottom:1px solid #D9D9D9;
    }
    .navigation-overlay ul li {
        display:block;
        font-size:14px;
        padding:10px 0px 10px 0px;
    }
    .navigation-overlay ul li.active {
        color:#8E0038;
    }
    .navigation-overlay ul li a {
        color:#333333;
        font-weight:900;
        display:inline-block;
        padding:10px 0px 10px 0px;
    }
    .navigation-overlay ul li.active a {
        color:#8E0038;
    }
    .navigation-overlay ul li a:hover {
        text-decoration:none;
        color:#8E0038;
    }
}

/* Tarifauswahl */

.productTeaser-wrapper {
    clear:both;
}
.productTeaser {
    float:left;
    width:50%;
}
.container-auswahl .productTeaser {
  float:left;
  width:33%;
}
.productTeaser-grid {
    margin:0px 15px 30px 15px;
    background: #FFFFFF;
    box-shadow: 0 2px 3px 0 rgba(0,0,0,0.35);
    border-radius: 4px;
    position:relative;
}
.productTeaser-grid:hover {
    box-shadow: 0 4px 10px 0 rgba(0,0,0,0.25);
    border-radius: 4px;
}
.productTeaser-grid .button {
    position:absolute;
    bottom:24px;
    left:14px;
    max-width:100%;
}
.productTeaser-content {
    padding:24px 24px 20px 24px;
}
.productTeaser .imageWrapper {
    height:288px;
    background-size: auto 100%;
    background-position:center center;
    background-repeat:no-repeat;
    position:relative;
}
.productTeaser .imageWrapper .praemie {
    color:#FFFFFF;
    font-size:14px;
    line-height:14px;
    background:#009284;
    display:inline-block;
    position:absolute;
    right:32px;
    bottom:-16px;
    padding:9px 12px 9px 12px;
    border-radius: 16px;
}
.productTeaser .h2 {
    font-size:18px;
    -moz-hyphens: auto;
  -o-hyphens: auto;
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  hyphens: auto;
}
a.tarif-link {
    color:#333333;
}
a.tarif-link:hover {
    text-decoration:none;
}
.tarif-cta {
    position:absolute;
    bottom:24px;
    right:24px;
    text-transform:uppercase;
    text-align:right;
    color:#8E0038;
    font-weight:900;
}
@media (max-width: 1151px) {
  .container-auswahl .productTeaser {
    width: 50%;
  }
}
@media (max-width: 911px) {
    .productTeaser {
        width:33.3333333%;
    }
    .container-auswahl .productTeaser {
      width: 50%;
    }
    .productTeaser .imageWrapper {
        height:150px;
    }
    .productTeaser-content {
        padding:24px 12px 28px 12px;
    }
    .productTeaser-content.cta-tel {
        padding:24px 12px 110px 12px;
    }
    .productTeaser-content .description, .tarif-cta {
        display:none;
    }
    .productTeaser-grid .button {
        padding: 8px 14px 8px 14px;
        min-width: 160px;
    }
    .productTeaser .h2 {
        font-size:14px;
    }
    .productTeaser .imageWrapper .praemie {
        font-size:12px;
        line-height:12px;
        right:12px;
        bottom:-12px;
        padding:6px 12px 6px 12px;
        border-radius: 12px;
    }
}
@media (max-width: 767px) {
    .productTeaser {
        width:50%;
    }
    .productTeaser-content.cta-tel {
        padding:24px 12px 100px 12px;
    }
}
@media (max-width: 479px) {
    .productTeaser {
        width:100%;
        float:none;
    }
    .container-auswahl .productTeaser {
      width: 100%;
    }
}