﻿:root {
    --color-background: #99ede3;
    --color-red: #e63227;
    --color-blue: #324f93;
}

@font-face {
    font-family: Brocante;
    src: url("AEROKOCONDENSED-7006441.OTF") format("opentype");
}

@font-face {
    font-family: Brocante;
    font-weight: bold;
    src: url("AEROKOCONDENSEDMEDIUM-7006449.OTF") format("opentype");
}

body * {
    font-family: brocante;
    line-height: 1.8em;
    box-sizing: border-box;
}

strong {
		font-weight: bold;
		font-size: 1.1em;
}

.form:not(.pane1) {
    display: none;
}

.fr {
    display: none;
}

body {
    background-color: var(--color-background);
}

h1 {
    color: var(--color-red);
    line-height: 1em;
}

img {
    max-width: 100%;
}

.block { display: inline-block; }

a {
    color: black;
    font-weight: bold;
    text-decoration: none;
}

body[lang=nl] .languages a:first-child {
    text-decoration: underline;
}

body[lang=fr] .languages a:last-child {
    text-decoration: underline;
}

.languages separator {
    display: inline-block;
    margin: 0 2em;
    border-left: 2px solid black;
    height: 25px;
}

.grid {
    display: grid;
    max-width: 1200px;
    margin: auto;
    grid-template:
        "head   head    head"
        "deco1  lang    ." 100px
        "deco1  intro   ." 100px
        "deco1  intro   deco2"
        ".      form    deco2"
        "deco3  form    ."
        "deco3  form    deco4"
        ".      form    deco4"
        ".      form    .";
}

.banner {
    grid-area: head;
}

.languages {
    grid-area: lang;
    align-content: center;
    text-align: center;
    display: flex;
    align-self: center;
    justify-content: center;
    align-items: center;
    font-size: 1.2em;
}

.deco {
    max-width: 220px;
}

.deco1 {
    grid-area: deco1;
}

.deco2 {
    grid-area: deco2;
}
    .deco2 img {
        transform: scale(1.25);
        transform-origin: top right;
    }

    .deco3 {
        grid-area: deco3;
    }

.deco4 {
    grid-area: deco4;
}
.deco4 img {
    transform: scale(1.75);
    transform-origin: top right;
}

.intro {
    grid-area: intro;
    text-align: center;
    padding: 2em;
}

.extro {
    text-align: center;
}

.form {
    grid-area: form;
    padding: 1em;
}

.button {
    display: inline-block;
    padding: 0.5em 2em;
    background-color: var(--color-red);
    font-weight: 700;
    color: white;
    margin: 2em auto;
    cursor: pointer;
}

.group {
    margin: 2em 0;
}

.group .title { font-weight: 700; font-size: 1.1em; margin-bottom: 1em; }

input[type=text], select, textarea {
    border: 2px solid var(--color-blue);
    border-radius: 4px;
    background-color: white;
    height: 30px;
}

    input.error, select.error {
        border-color: var(--color-red);
    }

textarea {
    width: 75%;
    display: block;
    min-height: 120px;
    height: auto;
}
.field {
    margin: 16px 0;
}
    .field.name, .field.email, .field.phone, .field.nid {
        display: flex;
        flex-flow: row-reverse;
    }
    .field.comment {
        display: flex;
        flex-flow: column-reverse;
    }
        .field.name input, .field.email input, .field.phone input, .field.nid input {
            margin-right: auto;
            min-width: 300px;
        }
    .field.name label, .field.email label, .field.phone label, .field.nid label {
        min-width: 130px;
        margin-right: 25px;
    }
        
    input[type=checkbox], input[type=radio] {
        display: none;
    }

    input[type=checkbox] + label, input[type=radio] + label {
        display: inline-flex;
        align-items: center;
        cursor: pointer;
    }

        input[type=checkbox] + label::before, input[type=radio] + label::before {
            display: flex;
            align-items: center;
            justify-content: center;
            height: 16px;
            width: 16px;
            min-width: 16px;
            min-height: 16px;
            border: 2px solid var(--color-blue);
            border-radius: 4px;
            background-color: white;
            content: '✓';
            margin-right: .5em;
            color: transparent;
            font-size: 12px;
            font-weight: 700;
        }
    input[type=checkbox]:checked + label::before, input[type=radio]:checked + label::before {
        color: var(--color-blue);
    }
    input[type=radio] + label::before {
        border-radius: 12px;
    }

label[for=optin] {
    align-items: flex-start !important;
}

label[for=optin]::before {
    position: relative;
    top: .5em;
}

#address1num, #address2num {
    width: 50px;
    margin-left: 12px;
}

input[type="radio"] + label[for=addressrad2], input[type="radio"] + label[for=addressrad3] {
    display: flex;
}
#address2street {
    width: 200px;
    margin-left: 24px;
}

    #address2street + .block {
        margin-left: 24px;
    }

    #address3 {
        width: 300px;
        margin-left: 24px;
    }

.group.error .checkbox label::before, .group.error .radio label::before {
    border-color: var(--color-red);
}

@media all and (max-width: 640px) {
    .grid {
        grid-template:
            "head   head    head"
            "lang   lang    lang" 100px
            "intro  intro   ." 100px
            "intro  intro   deco2"
            ".      form    form"
            "deco3  form    form"
            "deco3  form    form"
            ".      form    form";
    }

    .deco.deco1, .deco.deco4 {
        display: none;
    }
}

@media all and (max-width: 500px) {
    .grid {
        grid-template:
            "head"
            "lang"
            "intro"
            "form";
    }

    .deco.deco2, .deco.deco3 {
        display: none;
    }
}

@media all and (max-width: 1280px) {
    .deco4 img {
        transform: scale(1.25);
    }
}

@media all and (max-width: 1000px) {
    .deco4 img, .deco2 img {
        transform: scale(1.0);
    }

    .field.name, .field.email, .field.phone, .field.nid {
        flex-flow: column-reverse;
    }

    textarea { width: 100%; }
}
