.form {
    --form-row-gap: 1.5rem;
    position: relative;
    display: flex;
    flex-direction: column;
    row-gap: 1.75rem;
}

.form__overlay {
    position: absolute;
    inset: 0;
    z-index: 20;
    display: none;
    justify-content: center;
    align-items: center;
    background-color: rgb(0, 0, 0, 30%);
}

.form.form--loading .form__overlay {
    display: flex;
}

.form__group {
    padding: 1.25rem;
    border-color: #01606638;
    border-radius: var(--border-radius);
}

.form__group legend {
    padding-left: .75rem;
    padding-right: .75rem;
    font-size: 1rem;
    font-weight: 500;
    color: var(--color-primary);
}

.form__group:not(:last-of-type) {
    /* margin-bottom: calc( var(--form-row-gap) * 2 ); */
    margin-bottom: 0;
}

.form__group > *:not(.form__group-title, :last-child) {
    margin-bottom: var(--form-row-gap);;
}

.form__group-title {
    font-size: 1.25rem;
    margin-bottom: 4px;
}

.form__input-group {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    column-gap: 1.5rem;
    row-gap: var(--form-row-gap);
}

.form__input-group > * {
    flex-grow: 1;
    min-width: fit-content;
}

.form__label {
    font-size: .875rem;
}

.form__commentary {
    font-size: .875rem;
    font-style: italic;
}

.form__required-star {
    display: inline-block;
    margin-left: .25rem;
    font-weight: 400;
    color: var(--color-error);
}

.form__notice {
    font-size: .875rem;
    font-style: italic;
}

.form__input--error {
    outline: 2px solid var(--color-on-error);
}

/* ========================================
            License plate
                [START]
========================================= */

.form__license-plate-top-wrapper {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    column-gap: 1.5rem;
    row-gap: var(--form-row-gap);
}

.form__license-plate-top-wrapper > div {
    flex-grow: 1;
    flex-basis: 25rem;
}

.form__license-plate-wrapper {
    position: relative;
    display: inline-block;
    height: fit-content;
    --license-plate-height: 60px;
    --license-plate-left-width: 60px;
    --license-plate-border-thickness: 2px;
    --license-plate-border-radius: 4px;
}

.form__license-plate-wrapper::before {
    content: 'NL';
    position: absolute;
    left: var(--license-plate-border-thickness);
    top: var(--license-plate-border-thickness);
    z-index: 9;
    display: flex;
    justify-content: center;
    align-items: center;
    width: var(--license-plate-left-width);
    height: calc( var(--license-plate-height) - (var(--license-plate-border-thickness) * 2) );
    border-top-left-radius: calc( var(--license-plate-border-radius) / 2 );
    border-bottom-left-radius: calc( var(--license-plate-border-radius) / 2 );
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
    background-color: #003caa;
}

.form__license-plate-wrapper .form__license-plate-input {
    width: fit-content;
    height: var(--license-plate-height);
    padding-left: calc( var(--license-plate-left-width) + 4px );
    border: var(--license-plate-border-thickness) solid rgb(0, 0, 0, 60%);
    box-shadow: none;
    border-radius: var(--license-plate-border-radius);
    font-size: 1.25rem !important;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 4px;
    background-color: #f3b909;
}

.form-license-plate-wrapper__note {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: .25rem;
    width: fit-content;
    margin-top: .5rem;
    padding-top: .25rem;
    padding-bottom: .25rem;
    padding-left: 1rem;
    padding-right: 1rem;
    border-radius: var(--border-radius);
    font-size: .875rem;
    font-weight: 200;
    text-align: center;
    color: var(--color-error) !important;
    background-color: var(--color-on-error);
}

.form-license-plate-wrapper__note svg {
    fill: var(--color-error);
}

/* ========================================
            License plate
                [END]
========================================= */



.form-partnership-notice-wrapper {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    column-gap: 1.25rem;
    row-gap: 1rem;
}

.form-partnership-notice-wrapper svg {
    fill: var(--color-on-surface-darker);
}

.form-partnership-notice-wrapper > p:has(.form__label) {
    padding: 1.5rem;
    border-radius: var(--border-radius);
    background-color: var(--color-surface);
}

.form-partnership-notice {
    flex-grow: 1;
    flex-basis: 22.5rem;
    padding: 1.5rem;
    border-radius: var(--border-radius);
    background-color: var(--color-surface-darker);
}

.form-partnership-notice__list {
    display: flex;
    flex-direction: column;
    row-gap: .5rem;
    margin: 0;
    padding: 0;
}

.form-partnership-notice__item {
    list-style: none;
    color: var(--color-on-surface-darker);
}

.form-partnership-notice__item h4 {
    font-size: 1rem;
    font-weight: 500;
}

.form-partnership-notice__item p {
    font-size: .875rem;
    font-weight: 300;
}

.form-partnership-notice__link {
    display: block;
    width: fit-content;
    margin-top: .5rem;
    font-size: .875rem;
}