@font-face {
    font-family: 'kenteken';
    src: url('/fonts/kenteken-webfont.woff2') format('woff2'), url('/fonts/kenteken-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    font-size: 17px;
    line-height: 2.5rem;
    color: #525f7f;
    background-color: #F6F9FC
}

h1,
h2,
h3 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    font-weight: 500;
}

h2 span {
    color: #32AF81
}

input,
select,
button {
    font-size: 17px;
}

h1 {
    font-size: 45px;
    line-height: 48px;
}

h2 {
    margin-bottom: 24px;
}

h4 {
    text-align: center;
    margin: 36px 0 24px 0;
    font-size: 17px;
}

h5 {
    font-size: 12px;
}

a {
    color: #6772e5;
}

a:hover {
    color: #124A66;
    text-decoration: none;
}

.bg-white {
    background-color: #fff;
    border: 1px solid #dddddd;
    border-top: none;
}

.green {
    font-size: 20px;
    color: #1DB17F
}

.orange {
    font-size: 20px;
    color: #E39F48;
}

.control-label {
    text-align: right;
}

.homepage select {
    font-size: 18px;
}

header {
    background-color: #fff;
    text-align: center;
    padding: 96px 0;
}

header p {
    max-width: 320px;
    margin: 0 auto;
}

header img {
    max-height: 80px;
    max-width: 300px;
}

footer {
    color: #fff;
    border-top: 12px solid #32345B;
    margin-top: 96px;
    background-color: #CE232E;
    padding: 96px;
}

footer a {
    color: rgba(255, 255, 255, 0.4);
    text-decoration: underline;
}

footer a:hover {
    color: rgba(255, 255, 255, 0.8);
}

footer .row div {
    padding-bottom: 24px;
}

.hpadding {
    padding: 0 24px;
}

.vpadding {
    padding: 24px 0;
}

.kenteken {
    display: inline-block;
    margin: 16px auto;
    background-image: url('/images/plaat.png');
    width: 200px;
    height: 45px;
    background-size: cover;
}

.kenteken input {
    width: 164px;
    font-family: 'kenteken';
    text-transform: uppercase;
    border: 0;
    background-color: transparent;
    color: #000;
    font-size: 22px;
    margin: 6px 0 0 36px
}

.disclaimer {
    color: #53607E;
    font-size: 12px;
    line-height: 1.2;
    border-radius: 16px;
}

.proposal {
    margin-top: 72px;
    font-size: 14px;
    color: #5B5C56;
    border-radius: 0;
    background-color: #D4E4B0;
    border: 2px solid #539630;
    padding: 24px;
    text-align: left;
    line-height: 28px;
    box-shadow: 1px 1px 5px 0 rgba(26, 26, 67, .05), 39px 62.5px 125px -25px rgba(50, 50, 93, .5), 23.4px 37.5px 75px -37.5px rgba(0, 0, 0, 0.5);
}

.proposal .table-striped>tbody>tr:nth-child(odd)>th,
.proposal .table-striped>tbody>tr:nth-child(odd)>td {
    background-color: #EBF4D6;
}

.proposal .table-striped td,
.proposal .table-striped th {
    border-top: 2px solid #539630;
}

.proposal .table-striped tr:last-child td,
.proposal .table-striped tr:last-child th {
    border-bottom: 2px solid #539630;
}

.proposal .table-striped {
    border-left: 2px solid #539630;
    border-right: 2px solid #539630;
}

.proposal .table tbody tr th {
    font-size: 10px;
    font-weight: normal;
    line-height: 24px;
    text-transform: uppercase;
    color: #23B37E;
    padding: 6px;
}

.proposal h2 {
    font-family: serif;
    text-transform: uppercase;
    font-size: 32px;
    text-align: center;
    color: #333;
    margin-top: 0;
}

.quote {
    border-radius: 24px;
    background-color: #fff;
    padding: 48px;
    font-size: 18px;
    font-style: italic;
    text-align: left;
    line-height: 28px;
    box-shadow: 1px 1px 5px 0 rgba(26, 26, 67, .05), 39px 62.5px 125px -25px rgba(50, 50, 93, .5), 23.4px 37.5px 75px -37.5px rgba(0, 0, 0, 0.5);
}

.modal-content {
    overflow: hidden;
    border-radius: 24px;
    box-shadow: 1px 1px 5px 0 rgba(26, 26, 67, .05), 39px 62.5px 125px -25px rgba(50, 50, 93, .5), 23.4px 37.5px 75px -37.5px rgba(0, 0, 0, 0.5);
}

.modal-header {
    border: none;
    background-color: #F2FEEF;
    text-transform: uppercase;
}

.modal-title {
    margin-top: 1px;
    font-weight: bold;
    color: #23B37E;
}

.modal-body {
    padding: 24px 24px 8px 24px;
}

.modal-footer {
    border: none;
}

.qmark {
    font-weight: bold;
    margin-left: -12px;
}

.author {
    padding-top: 48px;
    width: 300px;
    font-style: normal;
}

.author h4 {
    margin: 0;
    padding-top: 12px;
}

.author h5 {
    color: #1DB17F;
}

.avatar {
    float: left;
    width: 72px;
    height: 72px;
    border-radius: 36px;
    margin-right: 24px;
}

.row {
    margin-bottom: 96px;
}

.row.nomargin {
    margin-bottom: 0;
}

.rounded {
    border-radius: 24px;
}

.padding {
    padding: 24px;
}

.btw_valid,
.btw_necessary,
.btw_invalid {
    padding: 6px 12px;
}

.btn-default {
    white-space: nowrap;
    display: inline-block;
    height: 40px;
    line-height: 38px;
    padding: 0 14px;
    -webkit-box-shadow: 0 4px 6px rgba(50, 50, 93, .11), 0 1px 3px rgba(0, 0, 0, .08);
    box-shadow: 0 4px 6px rgba(50, 50, 93, .11), 0 1px 3px rgba(0, 0, 0, .08);
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 15px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .025em;
    background-color: #1DB17F;
    text-decoration: none;
    -webkit-transition: all .15s ease;
    transition: all .15s ease;
}

.btn-default:hover {
    white-space: nowrap;
    display: inline-block;
    height: 40px;
    line-height: 38px;
    padding: 0 14px;
    -webkit-box-shadow: 0 4px 6px rgba(50, 50, 93, .11), 0 1px 3px rgba(0, 0, 0, .08);
    box-shadow: 0 4px 6px rgba(50, 50, 93, .11), 0 1px 3px rgba(0, 0, 0, .08);
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 15px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .025em;
    background-color: #2DC28D;
    text-decoration: none;
    -webkit-transition: all .15s ease;
    transition: all .15s ease;
    transform: translateY(-2px);
}

.btn-disabled {
    background-color: #999;
    cursor: not-allowed;
    pointer-events: none;
}

.logo {
    margin-bottom: 24px;
}

.specialists {
    width: 300px;
    margin: 0 auto;
}

.specialists .image {
    width: 90px;
    height: 90px;
    margin-right: 16px;
    float: left;
    line-height: 90px;
}

.specialists img {
    max-width: 90px;
    max-height: 90px;
}

.specialists h1 {
    color: #666;
    font-size: 16px;
    line-height: 1;
    padding: 12px 0 0 0;
    margin: 0;
    font-family: serif;
    text-transform: uppercase;
}

.specialists h2 {
    color: #777;
    font-size: 14px;
    line-height: 1;
    margin: 8px 0 0 0;
}

.slogan {
    color: rgba(255, 255, 255, 0.8);
    font-style: italic;
    font-size: 18px;
}

.slogan strong {
    color: rgba(255, 255, 255, 1);
}

.table tbody tr td,
.table thead tr th {
    border-color: #F6F9FC;
    padding: 12px 8px 0 8px;
}

.table>thead>tr>th,
.table>tbody>tr>th,
.table>tfoot>tr>th,
.table>thead>tr>td,
.table>tbody>tr>td,
.table>tfoot>tr>td {
    border: none;
}

.table thead tr th {
    font-size: 10px;
    font-weight: normal;
    color: #23B37E;
    text-transform: uppercase;
    border-bottom: 0;
}

.table tbody tr.total td {
    color: #32335C;
    font-size: 22px;
}

.table.white {
    background-color: #fff;
    box-shadow: rgba(50, 50, 93, 0.0980392) 0px 2px 4px 0px;
    padding: 24px;
}

.prijsvoorstel {
    background-color: #fff;
    box-shadow: rgba(50, 50, 93, 0.0980392) 0px 2px 4px 0px;
    padding: 24px;
}

.prijsvoorstel small {
    color: #999;
    font-size: 10px;
}

.prijsvoorstel h2 {
    text-align: center;
    font-size: 24px;
    margin-top: 0;
}

.prijsvoorstel .details,
.voorkeuren .details {
    margin-top: 8px;
    color: #A2A4A8;
    font-size: 12px;
}

.prijsvoorstel .merk {
    padding: 12px;
    text-align: center;
}

.progressbar {
    font-family: 'Open Sans', sans-serif;
    margin: 0 auto;
    padding: 48px 0 96px 0;
}

.progressbar a {
    color: #A2A4A8
}

.progressbar li a:hover {
    color: #A2A4A8;
    text-decoration: none;
}

.progressbar ul {
    padding-left: 0;
    counter-reset: step;
}

.progressbar li {
    list-style-type: none;
    width: 25%;
    float: left;
    font-size: 12px;
    position: relative;
    text-align: center;
    color: #A2A4A8;
    line-height: 1;
}

.progressbar li:before {
    width: 24px;
    height: 24px;
    content: counter(step);
    counter-increment: step;
    line-height: 20px;
    border: 2px solid #E7EAEF;
    display: block;
    text-align: center;
    margin: 0 auto 8px auto;
    border-radius: 50%;
    background-color: white;
    font-weight: bold;
}

.progressbar li:after {
    width: 100%;
    height: 1px;
    content: '';
    position: absolute;
    background-color: #A2A4A8;
    top: 12px;
    left: -50%;
    z-index: -1;
}

.progressbar li:first-child:after {
    content: none;
}

.progressbar li.active a {
    color: #29B080;
}

.progressbar li.active:before {
    border-color: #BBF3BE;
    background-color: #BBF3BE;
    color: #29B080;
}

.progressbar li.active.done:before {
    background-color: #29B080;
    border-color: #29B080;
    color: #fff;
}

.progressbar li.active+li:after {
    background-color: #29B080;
}

table {
    border-collapse: collapse;
    width: 100%;
}

.table thead th {
    background-color: #F2FEEF;
    color: #23B37E;
}

.table thead th,
.table tbody td {
    line-height: 1.5;
    padding: 0.75em;
}

.info {
    font-size: 11px;
    text-decoration: none;
}

.voorkeuren {
    margin-bottom: 48px;
}

.voorkeuren h2 {
    font-size: 24px;
}

.voorkeuren .row {
    margin-top: 16px;
    margin-bottom: 24px;
}

.infolist {
    font-size: 14px;
    padding: 0 0 16px 24px;
}

.infolist li {
    list-style-type: none;
    padding-left: 1rem;
    margin-bottom: .4rem;
}

.info li:before {
    font-family: 'Font Awesome 5 Free';
    content: "\f05a";
    margin: 0 10px 0 -28px;
    color: #0D61A8;
}

.usp li:before {
    font-family: 'Font Awesome 5 Free';
    content: "\f00c";
    margin: 0 10px 0 -28px;
    color: #17aa1c;
}

.excl li:before {
    font-family: 'Font Awesome 5 Free';
    content: "\f071";
    margin: 0 10px 0 -28px;
    color: #f0bb2a;
}

.usp {
    padding: 16px 0 16px 24px;
}

.excl {
    padding: 16px 0 16px 24px;
}

.warning {
    border-radius: 8px;
    background-color: #F4E6E5;
    padding: 16px;
    margin: 16px 0;
}

.warning h2 {
    margin: 0;
    color: #ff0000;
    font-size: 18px;
}

footer .logos {
    margin-top:30px;
    display: flex;
    justify-content: left;
    color:#fff;
}
footer .eu {
    flex-direction: column;
    justify-content: center;
    padding:15px;
    text-align: center;
    font-size: 12px;;
    width:120px;
    line-height: 1;
}
footer .eu img {
    margin-bottom: 15px;;
}


/* Stack labels vertically on smaller screens */

@media only screen and (max-width:768px) {
    .padding {
        padding: 24px;
    }
    /* Hide column labels */
    .table-responsive thead tr {
        position: absolute;
        top: -9999em;
        left: -9999em;
    }
    /* Leave a space between table rows */
    .table-responsive tbody tr+tr {
        margin-top: 1.5em;
    }
    /* Get table cells to act like rows */
    .table-responsive tbody tr,
    .table-responsive tbody tr td {
        display: block;
    }
    .table-responsive tbody tr td {
        border: none;
        /* Leave a space for data labels */
        padding: 6px 6px 6px 50%;
    }
    /* Add data labels */
    .table-responsive tbody tr td:before {
        content: attr(data-label);
        display: inline-block;
        font-weight: bold;
        line-height: 1.5;
        margin-left: -100%;
        width: 100%;
    }
    .table-responsive tbody td {
        padding-left: 0.75em;
    }
    .table-responsive tbody td:before {
        display: block;
        margin-left: 0;
    }
    .table-responsive tbody tr {
        border-bottom: 1px solid #D3D5D8;
    }
    .table-responsive tbody tr:last-child {
        border-bottom: none;
    }
    .prijsvoorstel {
        margin-bottom: 24px;
    }
    .padding {
        padding: 24px;
    }
    .hpadding {
        padding-left: 16px;
        padding-right: 16px;
    }
    .quote {
        padding-top: 48px;
        font-size: 17px;
        line-height: 22px;
    }
    .progressbar {
        margin: 0 auto;
        padding: 24px 0 48px 0;
    }
    .voorkeuren {
        padding: 24px;
    }
}

@media only screen and (max-width:31.25em) {
    body {
        font-size: 17px;
    }
    h1 {
        font-size: 32px;
    }
    h2 {
        font-size: 20px;
    }
    footer {
        padding: 24px;
    }
    header {
        padding: 24px;
    }
    header p {
        text-align: left;
    }
    .row {
        margin-bottom: 24px;
    }
    .quote {
        padding: 24px;
    }
    .avatar {
        float: left;
        width: 48px;
        height: 48px;
        border-radius: 24px;
        margin-right: 16px;
    }
    .prijsvoorstel h2 {
        font-size: 18px;
    }
    .prijsvoorstel {
        padding: 12px;
    }
    .orange,
    .green {
        font-size: 17px;
    }
}

@media only screen and (max-width:480px) {
    input[type="color"],
    input[type="date"],
    input[type="datetime"],
    input[type="datetime-local"],
    input[type="email"],
    input[type="month"],
    input[type="number"],
    input[type="password"],
    input[type="search"],
    input[type="tel"],
    input[type="text"],
    input[type="time"],
    input[type="url"],
    input[type="week"],
    select:focus,
    select,
    textarea {
        font-size: 17px !important;
    }
    .adresregel {
        margin-bottom: 0;
    }
    .postcoderegel {
        margin-top: 0;
    }
}