html {
    margin: 0;
    padding: 0;
    height: 100%;
}

h1 {
    line-height: 1em;
    font-size: 2.6em;
}

h1, h2, h3 {
    font-family: "displaybold", sans-serif;
    font-style: normal;
}

h4, h5, .displaylight {
    font-family: "displaylight", Arial, sans-serif;
    font-style: normal;
}

.textlight {
    font-family: "textlight", Arial, sans-serif !important;
    font-weight: normal;
}

.textbold {
    font-family: "textbold", Arial, sans-serif !important;
}

.c_textfont {
    font-family: "textbold", Arial, sans-serif !important;
}

ul {
    list-style-type: none;
}

ul li:before {
    content: '\2014';
    position: absolute;
    margin-left: -25px;
}

.text-decoration-underline {
    text-decoration: underline;
}
.serviceDetailsWrapper a:not(.serviceBtn) {
    color: #000 !important;
    text-decoration: underline;
}
select#verkehrsregelnAuswahl {
    color: #000;
    font-family: 'textbold', Arial, sans-serif !important;
}

.verkehrsregel a {
    color: #000 !important;
}

.verkehrsregel tr td:first-of-type {
    white-space: nowrap;
    vertical-align: top;
    padding-right: 15px;
    width: 100px;
}

.verkehrsregel ul {
    margin-bottom: 0 !important;
}
.reifenwechselHeadline {
    font-family: "textbold", Arial, sans-serif;
}
#serviceSection {
    max-width: 1536px;
    margin: auto;
}
.Zebra_DatePicker {
    left: 0;
    width: 0;
    top: 0;
    right: 0;
    margin: 100px auto;
    pointer-events: all;
}
button.Zebra_DatePicker_Icon {
    top: 10px !important;
}
.dp_timepicker.dp_body {
    width: 150px;
}
.Zebra_DatePicker .dp_body .dp_selected {
    background: #116EE7;
}
#cWunschtag, #cWunschzeit {
    text-align: left;
    display: flex;
}
input::-webkit-date-and-time-value {
    text-align: left;
}
input[type="date"] {
    position: relative;
}

#cWunschtag:after {
    background-image:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M152 24c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40L64 64C28.7 64 0 92.7 0 128l0 16 0 48L0 448c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-256 0-48 0-16c0-35.3-28.7-64-64-64l-40 0 0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40L152 64l0-40zM48 192l352 0 0 256c0 8.8-7.2 16-16 16L64 464c-8.8 0-16-7.2-16-16l0-256z"/></svg>');
    content: "";
    color: #555;
    padding: 0 5px;
    position: absolute;
    right: 0;
    width: 20px;
    height: 20px;
    background-repeat: no-repeat;
    /*margin: -20px 0 0 0;*/
}
input[type="time"]:after {
    background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path d="M256 0a256 256 0 1 1 0 512A256 256 0 1 1 256 0zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z"/></svg>');
    content: "";
    color: #555;
    padding: 0 5px;
    position: absolute;
    right: 0;
    width: 20px;
    height: 20px;
    background-repeat: no-repeat;
    /*margin: -20px 0 0 0;*/
}

#cWunschtag {
    position: relative;
}

#cWunschtag::-webkit-calendar-picker-indicator {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: auto;
    height: auto;
    color: transparent;
    background: transparent;
}
#cWunschzeit {
    position: relative;
}

#cWunschzeit::-webkit-calendar-picker-indicator {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: auto;
    height: auto;
    color: transparent;
    background: transparent;
}
input::placeholder {
    overflow: visible !important;
}
@media only screen and (max-width: 520px) {
    h1 {
        font-size: 2em;
    }

    h2 {
        font-size: 1.6em;
    }

    h3 {
        font-size: 1.5em;
    }

    h4 {
        font-size: 1.4em;
    }

    h5 {
        font-size: 1.4em;
    }

    .productTitle {
        font-size: 1.3em !important;
    }

    #overlay, .pendingAnswer {
        background-size: 100px !important;
    }
}

@media only screen and (max-width: 450px) {
    h1 {
        font-size: 1.7em;
    }

    h2 {
        font-size: 1.5em;
    }

    h3 {
        font-size: 1.4em;
    }

    h4 {
        font-size: 1.2em;
    }

    h5 {
        font-size: 1em;
    }

    .productTitle {
        font-size: 1.24em !important
    }

    #overlay, .pendingAnswer {
        background-size: 80px !important;
    }

}

a {
    white-space: nowrap;
    color: #fff;
}

a:focus {
    outline: none;
}

#productsSection a:not(.serviceBtn) {
    color: rgb(0, 30, 80);
    text-decoration: underline;
}

.largeText {
    font-size: 18px;
}

.cursor-pointer {
    cursor: pointer;
}

body {
    margin: 0 auto;
    padding: 0;
    overflow-x: hidden;
    font-family: "textlight", sans-serif;
    font-size: 100%;
    height: 100%;
    width: 100%;
    color: #fff;
    background-position: top center;
    background-size: 100% auto;
    background-repeat: no-repeat;
    text-align: center;
}

.modal .modal-dialog, .modal .modal-dialog a, .modal .modal-dialog a:hover, .modal .modal-dialog a:active, .modal .modal-dialog a:visited {
    color: #000;
}

.modal-dialog {
    background-color: #fff;
}

.modal-header {
    border: none;
    padding-bottom: 5px;
}

.modal-body {
    padding-top: 0;
}

header, footer {
    margin: 0 !important;
}

header {
    color: #000;
    z-index: 9999;
}

main {
    /*display: inline-table;
    height: 100%;
    padding: 100px 25px 20px 25px;
    z-index: 0;
    max-width: 2880px;
    margin: 0 auto;*/
    padding: 0;
    max-width: none;
    display: block;
    width: 100%;
    margin: 0;
}

footer {
    margin: 0 auto !important;
    position: relative;
    bottom: 0;
    padding: 10px 25px;
    width: 100%;
    color: #fff;
    background-color: #504f4f;
    font-size: 14px;
}

header, main, footer {
    text-align: left;
}

label {
    display: inline-block;
    margin-bottom: 3px;
    margin-top: 10px;
}

footer a {
    color: #fff;
}

button:focus, button:active, button:visited {
    outline: none;
}

a, a:hover, a:active, a:visited {
    color: #fff;
    text-decoration: none;
    cursor: pointer;
}

.boldText, strong {
    font-family: "textbold", sans-serif;
    font-weight: normal;
}

.noselect {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

::placeholder {
    color: #495057;
}

input[type="number"]::-webkit-outer-spin-button, input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type="number"] {
    -moz-appearance: textfield;
}

input, select, textarea {
    border: none !important;
    background: transparent !important;
    border-bottom: 1px solid #adaeae !important;
    border-radius: 0 !important;
    transition: none !important;
    box-shadow: none !important;
    padding-left: 0 !important;
}

.form-check-input {
    -webkit-appearance: checkbox;
    -moz-appearance: checkbox;
    appearance: auto;
}

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

select {
    padding-right: 35px !important;
    background-image: linear-gradient(45deg, transparent 50%, gray 50%),
    linear-gradient(135deg, gray 50%, transparent 50%),
    linear-gradient(to right, #ccc, #ccc) !important;
    background-position: calc(100% - 20px) calc(1em + 2px),
    calc(100% - 15px) calc(1em + 2px),
    calc(100% - 2.5em) 0.5em !important;
    background-size: 5px 5px,
    5px 5px,
    0px 1.5em !important;
    background-repeat: no-repeat !important;
}

select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}

input[type=radio], input[type=checkbox] {
    width: 15px !important;
    height: 15px !important;
    position: relative !important;
    margin-top: -2px !important;
    vertical-align: middle !important;
}

.submitBtn {
    transition: background-color 0.2s ease-in-out 0s, border-color 0.2s ease-in-out 0s;
}

.submitBtn:hover, .submitBtn:active,
.serviceBtn:hover, .serviceBtn:active {
    background-color: #0040c5;
    border-color: #0040c5;
}

.submitBtn, .reqBtn {
    position: relative;
    display: inline-flex;
    text-align: center;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    align-items: center;
    min-height: 44px;
    min-width: 44px;
    padding: 0px 32px 2px 32px;
    border: 2px solid rgb(0, 30, 80);
    margin: 0px;
    border-radius: 500px;
    text-decoration: none;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: background-color 0.2s ease-in-out 0s, border-color 0.2s ease-in-out 0s;
    background: rgb(0, 30, 80);
    color: #fff;
    font-size: 16px;
}

.reqBtn {
    background-color: #fff;
    border-color: #fff;
    color: #001e50;
}

.reqBtn:hover, .reqBtn:active {
    background-color: #4cc7f4;
    border-color: #4cc7f4;
    color: #001e50;
}

#requestForm {
    padding-top: 10px;
}

.formAnswer {
    padding: 24%;
    text-align: center;
}

.pendingAnswer {
    background: url(../imgs/spinner.gif) transparent center 35% no-repeat !important;
    width: 100%;
    height: 300px;
    background-size: 100px !important;
}

.successMsg {
    font-family: "textbold", sans-serif !important;
    color: green;
}

#leadSection{
    max-width: 1536px;
    height: auto;
    z-index: 9;
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
    top: 400px;
    padding: 15px;
}
#repairserviceSection, #servicesSection  {
    max-width: 1536px;
    height: auto;
    margin: auto;
}

#productsSection {
    max-width: 1536px;
    padding: 25px 25px 0 25px;
    margin: auto;
}

.serviceWrapper {
    color: #000;
    padding-top: 100px;
    margin: 0;
}

.productImageWrapper {
    padding: 0 50px 0 0;
}

.serviceDetailsWrapper {
    padding: 0 0 0 50px;
    hyphens: auto;
}

.productTitleWrapper {
    padding: 10px 25px 25px 25px;
}

.productInfoWrapper {
    padding: 15px 0 25px 0;
}

.productPriceWrapper {
    padding: 0 0 25px 0;
    font-family: textbold, Arial, sans-serif;
}

.productPriceWrapperSmall {
    font-size: 0.8em;
    padding-bottom: 25px !important;
}

/*.productCheckbox + .productLabel {
float: left;
}*/

.productSelect {
    margin-top: -6px;
    margin-bottom: -6px;
}

.partnerAdresseWrapper {
    padding: 50px 0 20px 0;
}

.partnerAdresseWrapper, .partnerAdresseWrapper a, .partnerAdresseWrapper a:hover, .partnerAdresseWrapper a:active, .partnerAdresseWrapper a:visited {
    color: #000;
    font-size: 14px;
}

.partnerAdresseWrapper p {
    font-size: 16px;
}

.light {
    color: rgba(0, 0, 0, 0.5);
}

#productsSection {
    max-width: 1536px;
}

.partnerAdresseWrapper {
    padding: 50px 5px;
    width: 100%;
}

#errorMsg {
    color: red;
}

.leadVisual {
    width: 100%;
}

.disclaimerWrapper {
    color: #000;
    padding: 20px 0 50px 0;
}

footer .partnerAdresseWrapper {
    padding: 50px 0 0 0;
    width: 100%;
    color: #fff;
}

footer .partnerAdresseWrapper a, footer .partnerAdresseWrapper a:hover, footer .partnerAdresseWrapper a:active, footer .partnerAdresseWrapper a:visited {
    color: #fff;
}

footer hr {
    border-top: 1px solid #fff;
    opacity: 1;
}

#impressumModal {
    text-align: left;
}

select#partnerID:disabled {
    color: #999;
}

.productSelect {
    margin-left: 23px !important;
}

html[lang="de"] .productLabel[for="p_8"], html[lang="de"] .productLabel[for="p_10"] {
    float: left !important;
    margin-right: -10px !important;
}

.c_topinfoWrapper {
    padding-bottom: 150px;
}

a.disabled {
    pointer-events: none !important;
    opacity: 0.5 !important;
}
#partnerSelectionModal .modal-dialog {
    background: transparent;
}
button.close {
    padding: 0;
    background-color: transparent;
    border: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    margin-top: -15px;
}
.close {
    float: right;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    color: #000;
    text-shadow: 0 1px 0 #fff;
    opacity: .5;
}
.service {
    padding-bottom: 10px;
}
.serviceImage {
    width: 100%;
}
.serviceHeadline {
    font-family: 'textbold', sans-serif;
    font-size: 1em;
    padding: 25px 0;
    margin: 0;
}
.serviceRequest {
    padding: 25px 0;
}
input.serviceCheckbox {
    float: left;
    margin: 5px 5px 0 0 !important;
}
.modal {
    z-index: 9999;
}
@media (min-width: 576px) {
    .modal-dialog {
        max-width: 650px;
        margin: 1.75rem auto;
    }
}
@media all and (max-width: 991px) {
    .Zebra_DatePicker {
        left: 0 !important;
        right: 30vw !important;
    }
    .c_topinfoWrapper {
        padding-bottom: 70px;
    }

    body {
        background-size: cover !important;
    }

    main {
        margin-left: auto;
    }

    footer {
        text-align: center;
    }

    .productImageWrapper {
        padding: 0;
    }
    .serviceDetailsWrapper, .servicesWrapper {
        padding: 50px 25px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .productTitleWrapper h1 {
        font-size: 28px;
    }

    .serviceWrapper, #servicesSection {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    .servicesWrapper .service {
        padding-left: 0;
        padding-right: 0;
    }
    .contentWrapper {
        vertical-align: top;
        color: #fff;
        padding: 0 15px;
        width: 100%;
    }

    .partnerAdresseWrapper {
        padding: 15px;
        width: 100%;
    }

    #leadSection {
        top: 200px;
    }
}

input.productCheckbox {
    float: left !important;
    margin-top: 5px !important;
    margin-right: 0.5rem !important;
}

label.productLabel {
    display: flex !important;
    margin: 0 !important;
    padding: 0 !important;
}

.modalSpacer {
    margin-top: -15px;
}

.modalSpacer hr {
    border-color: #adaeae !important;
}

.additional-html-wrapper {
    color: #000;
}

.productSelectAdditionalResult {
    font-family: "textlight", Arial, sans-serif;
}