:root {
    --form-gap: 0.75rem;
    --field-gap: 0.375rem;
    --option-gap: 0.5rem;
}

form {
    display: grid;
    gap: var(--form-gap);
    max-width: 44rem;
}

.form-field {
    display: grid;
    gap: var(--field-gap);
}

.form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="number"],
input[type="tel"],
textarea,
select {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

textarea {
    resize: vertical;
}

label {
    font-weight: 600;
}

button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
    justify-self: start;
}

fieldset {
    margin: 0;
    padding: 0.75rem 1rem;
    border: 1px solid #d0d7de;
    border-radius: 0.5rem;
    display: grid;
    gap: var(--option-gap);
}

fieldset legend {
    font-weight: 600;
    padding: 0 0.25rem;
}

fieldset label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 500;
}
