@font-face {
    font-family: 'ProximaNovaAltRgBold';
    src: url('../fonts/ProximaNovaA-Bold.eot');
    src: url('../fonts/ProximaNovaA-Bold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/ProximaNovaA-Bold.woff2') format('woff2'),
        url('../fonts/ProximaNovaA-Bold.woff') format('woff'),
        url('../fonts/ProximaNovaA-Bold.ttf') format('truetype'),
        url('../fonts/ProximaNovaA-Bold.svg#ProximaNovaA-Bold') format('svg');
    font-weight: bold;
    font-style: normal;
}

@font-face {
    font-family: '../fonts/ProximaNovaAltLt';
    src: url('../fonts/ProximaNovaA-Semibold.eot');
    src: url('../fonts/ProximaNovaA-Semibold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/ProximaNovaA-Semibold.woff2') format('woff2'),
        url('../fonts/ProximaNovaA-Semibold.woff') format('woff'),
        url('../fonts/ProximaNovaA-Semibold.ttf') format('truetype'),
        url('../fonts/ProximaNovaA-Semibold.svg#ProximaNovaA-Semibold') format('svg');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'ProximaNovaAltRg';
    src: url('../fonts/ProximaNovaA-Regular.eot');
    src: url('../fonts/ProximaNovaA-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/ProximaNovaA-Regular.woff2') format('woff2'),
        url('../fonts/ProximaNovaA-Regular.woff') format('woff'),
        url('../fonts/ProximaNovaA-Regular.ttf') format('truetype'),
        url('../fonts/ProximaNovaA-Regular.svg#ProximaNovaA-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
}

/* Variables */
:root {
    /* Primaire kleuren */
    --aqua: #009E98;
    --grasgroen: #39B04A;
    --zonniggroen: #87C13F;

    /* Secundaire kleuren */
    --dennegroen: #1DA771;
    --appelgroen: #60B945;
    --turquoise: #00C398;
    --nav2a: #71BB4E;
    --nav2b: #5AB55D;
    --nav4a: #2DAA7A;
    --nav4b: #17A489;

    /* Extra kleur */
    --lichtblauw: #d2eff4;
    --aqua-dark: #138a8f;

    /* Basis kleuren */
    --donkergroen: #005B57;
    --donkergrijs: #DADACD;
    --lichtgrijs: #F2F2ED;
    --grijs: #E6E6DB;
    --white: #FFF;
    --black: #000;

    /* Fonts */
    --font-default: 'ProximaNovaAltRg', Arial, Helvetica, sans-serif;
    --font-bold: 'ProximaNovaAltRgBold', Arial, Helvetica, sans-serif;
    --semi-bold: 600;
}

body {
    background: var(--white);
    color: var(--donkergroen);
    font-family: var(--font-default);
    font-size: 16px;
    line-height: 24px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a {
    color: var(--donkergroen);
    text-decoration: underline;
}

a:focus,
a:hover {
    color: var(--aqua)
}

a:hover {
    text-decoration: none;
}

a:focus {
    outline: 1px solid #ccc;
}

a.mail {
    word-wrap: break-word;
}

h1,
h2,
h3,
h4,
h5 {
    color: var(--donkergroen);
    font-size: 58px;
    line-height: 58px;
    font-weight: var(--semi-bold);
    margin: 0 0 0.3em 0;
    font-family: var(--font-default);
    position: relative;
}

h1 {
    font-family: var(--font-bold);
    margin: 0 0 25px 0;
}

h2 {
    font-size: 24px;
    line-height: 26px;
}

h3 {
    font-size: 20px;
    line-height: 22px;
}

h4 {
    font-size: 18px;
    line-height: 20px;
}

h5 {
    font-size: 16px;
    line-height: 18px;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
td a {
    color: var(--donkergroen);
    text-decoration: none;
}

p {
    font-size: 1em;
    margin-bottom: 1.5em;
}

p.abstract {
    font-size: 1.3em;
}

p:empty,
strong:empty {
    display: none;
}

pre,
code,
kbd,
samp {
    font-size: 1.3em;
}

pre code {
    font-size: 1em;
}

b,
strong,
.strong {
    font-weight: bold;
}

i,
em {
    font-style: italic;
}

hr {
    background: #fff;
    color: #fff;
    border: none;
    height: 1px;
    margin: 1em 0;
    padding: 0;
}

hr.green {
    background-color: var(--grasgroen);
    margin-top: 0;
}

blockquote {
    padding: 0;
    border: 0;
}

ol,
ul {
    list-style: disc;
    margin: 0 0 1.5em 0em;
    padding: 0 0 0 1em;
}

ol {
    list-style: decimal;
}

table {
    border-collapse: collapse;
    margin-bottom: 20px;
    width: 100%;
}

caption {
    text-align: left;
    margin-bottom: 5px;
}

th,
td {
    background: var(--lichtgrijs);
    padding: 0.5em 1em;
    text-align: left;
    vertical-align: top;
}

td:first-child {
    font-family: var(--font-bold);
}

th {
    background: var(--grijs)
}

.ce-table th,
.ce-table td {
    border-top: none;
}

.ce-table thead th {
    border-bottom: none;
}

.ce-table tr:nth-of-type(even) td {
    background: var(--white)
}

.ce-table thead + tbody tr:nth-of-type(even) td {
    background: var(--lichtgrijs)
}

.ce-table thead + tbody tr:nth-of-type(odd) td {
    background: var(--white)
}

th ul,
th ol,
td ul,
td ol {
    margin: 0 0 1em 1em;
}

thead th {
    background-color: var(--zonniggroen);
    color: var(--white);
}

thead th:first-of-type {
    font-size: 24px;
}

tfoot th,
tfoot td {
    background-color: var(--grijs);
}

td p {
    margin: 0 0 1em 0;
}

figure {
    margin-bottom: 1em;
}

audio,
canvas,
progress,
video {
    width: 100%;
}

.mail,
.duim,
.text,
.icon-print,
.icon-stuur,
.icon-bellen,
.phone,
.marker {
    display: inherit;
}

p a.submit {
    margin: 5px 0 0 0;
}

p.groot,
div.teaser-text {
    font-size: 20px;
}

p.marker,
p.phone {
    margin-left: 24px;
    position: relative;
}

p.marker:before,
p.phone:before {
    color: #2a4a95;
    left: -24px;
    top: 3px;
    position: absolute;
}

a.cta,
a.cta-light,
a.cta-med,
.button.cta,
.news-back a {
    background: var(--aqua);
    color: var(--white);
    margin: 0 14px 14px 0;
    padding: 8px 14px;
    display: inline-block;
    text-decoration: none;
    position: relative;
}

a.cta-med.groot {
    display: block;
    margin: 20px 0;
    width: calc(100% - 20px);
}

a.cta:hover,
a.cta-light:hover,
a.cta-med:hover,
.button.cta:hover,
.news-back a .news-back a:hover {
    background: var(--donkergroen);
}

a.cta:hover:after,
a.cta-light:hover:after,
a.cta-med:hover:after,
.button.cta:hover:after,
.news-back a:hover:after {
    border-color: transparent transparent transparent var(--donkergroen);
}

a.cta-med {
    background-color: var(--dennegroen)
}

a.cta-light {
    background-color: var(--appelgroen)
}

form ::-webkit-input-placeholder {
    /* Chrome/Opera/Safari */
    color: var(--aqua);
}

form ::-moz-placeholder {
    /* Firefox 19+ */
    color: var(--aqua);
}

form :-ms-input-placeholder {
    /* IE 10+ */
    color: var(--aqua);
}

form :-moz-placeholder {
    /* Firefox 18- */
    color: var(--aqua);
}

.aqua {
    background-color: var(--aqua);
    color: var(--white)
}

.appelgroen,
a.appelgroen {
    background-color: var(--appelgroen)
}

a.cta.appelgroen:after {
    border-color: transparent transparent transparent var(--appelgroen)
}

.dennegroen {
    background-color: var(--dennegroen)
}

.grasgroen {
    background-color: var(--grasgroen)
}

.wit {
    background-color: var(--white)
}

.donkergrijs {
    background-color: var(--donkergrijs)
}

h3.appelgroen {
    background: transparent;
    color: var(--appelgroen)
}

h3.aqua {
    background: transparent;
    color: var(--aqua)
}

h3.dennegroen {
    background: transparent;
    color: var(--dennegroen)
}

h3.grasgroen {
    background: transparent;
    color: var(--grasgroen)
}

.no-gutters {
    margin: auto;
    padding: 0;
}

.table-cell {
    display: table-cell;
    height: 100%;
    vertical-align: middle;
    position: relative;
    z-index: 1;
}