dialog {
    background-color: var(--bg-color);
    border: none;
    border-radius: 2px;
    box-shadow: 0 0 2px 1px var(--txt-color);
    color: var(--txt-color);
    font-family: inherit;
    font-size: inherit;
    padding: var(--main-padding);
    margin: auto;
    text-align: left;
}

dialog div {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
}

dialog div * {
    flex: 1 1 auto;
}

dialog div button {
    margin-left: auto;
    margin-right: auto;
}

dialog::backdrop {
    background-color: rgba(0,0,0,0.5);
    
}

form {
    display: block;
    --form-space-bw-inputs: 0.5em;
    --form-input-margin: 2px;
    --form-input-padding: 2px;
}

div.field-container {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}

div.field-container * {
    flex: 1 1 auto;
    width: 100%;
    margin: var(--form-input-margin) 0;
    padding: var(--form-input-padding);
}

input.invalid-field, textarea.invalid-field {
    box-shadow: 0 0 2px 1px var(--invalid-input-color);
    background: var(--bg-color);
}

input.valid-field, textarea.valid-field {
    box-shadow: unset;
}

input[type='text'].valid-field, input[type='tel'].valid-field, input[type='email'].valid-field {
	background: url('/static/check.svg') no-repeat center right 5px var(--bg-color);
	background-size: auto 75%;
}

div.field-error {
    text-align: center;
    font-size: 1em;
    color: red;
}

label,div.field-error {
    margin-top: var(--form-space-bw-inputs);
}

form p {
    width: 100%;
    margin: var(--form-space-bw-inputs) 0 0;
}

input,textarea {
    max-width: calc(100% - 2 * ( var(--form-input-margin) + var(--form-input-padding)));
}

input:not(input[type='submit']):not(input[type='checkbox']), textarea, select {
    appearance: none;
    outline: none;
    font-size: 1em;
    border-radius: 2px;
    border: 1px solid grey;
    background-color: var(--bg-color);
    color: var(--txt-color);
}

@media (prefers-color-scheme: light) {
	select {
		background: url('/static/arrow_down_dark.svg') no-repeat center right 5px var(--bg-color);
	}
}

@media (prefers-color-scheme: dark) {
	select {
		background: url('/static/arrow_down_light.svg') no-repeat center right 5px var(--bg-color);
	}
}

input:not(input[type='submit']):focus, select:focus, textarea:focus {
    outline: none;
    box-shadow: 0 0 2px 1px #8888ff;
}

label.required::after {
    content: " *";
}

textarea#speech {
    min-height: 10em;
    resize: vertical;
}

div.checkbox_container {
    width: 100%;
    margin: var(--form-space-bw-inputs) 0 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
}

input[type="checkbox"] {
    width: 1.5em;
    height: 1.5em;
    margin: 0 1em 0;
    flex: 0 0 auto;
}

label[for="consent"], label[for="prospect"] {
    margin: 0;
    flex: 1 1 auto;
    max-width: 100%;
}

input[type="submit"] {
    display: block;
    margin: 2em auto 0;
    max-width: 400px;
}

div#captcha_container {
    width: 100%;
    margin: var(--form-space-bw-inputs) 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    text-align: center;
}

div#captcha_container * {
    flex: 1 1 auto;
    margin-top: 0.2em;
    margin-bottom: 0.2em;
}

div#captcha_container img {
    width: 160px;
    height: 60px;
}

div#captcha_container label {
    width: 100%;
    max-width: 100%;
}


@media (min-height: 800px){
    textarea#speech {
	min-height: 20em;
    }
}

@media (min-width: 600px){
    div.field-container {
	padding-bottom: 0.5em;
    }
    input{
	max-width: 400px;
    }
    label {
	max-width: 300px;
    }
    div.field-error {
	max-width: 400px;
	margin: 0;
	padding: 0;
    }
    select {
	max-width: calc(400px + var(--form-input-margin) * 2 + var(--form-input-padding) * 2);
    }
    textarea {
	margin-top: 0.5em;
	width: calc(100% - var(--form-input-margin) * 2 - var(--form-input-padding) * 2);
	max-width: var(--main-max-width);
    }
    div.field-error[data-id="speech"] {
	max-width: 100%;
    }
    input[type='checkbox'] {
	width: 1em;
	height: 1em;
    }

    label[for="consent"], label[for="prospect"] {
	width: calc(100% - 2.5em);
    }
    div#captcha_container label {
	width: 100%;
	max-width: 100%;
    }
    input[type="submit"] {
	margin-top: calc(var(--form-space-bw-inputs) * 2);
	width: 200px;
    }

    div.field-error {
	text-align: left;
    }
}
