.contact-form {
	display: flex;
	flex-direction: column;
	padding: 1.5rem;
}

.contact-form__explain {
	margin: 1rem;
}

.form__field {
	margin: 0.5rem 0 0.5rem 0;
	display: flex;
	flex-direction: column;
}

.required {
	color: orange;
}

.form__control {
	border: 1px solid var(--color-border-main);
	border-radius: 1rem;
	padding: 0.75rem 1rem;
	font-size: 1rem;
	background: var(--color-form-bg);
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease;
}
.form__control:focus {
	outline: none;
	border: 2px solid var(--color-form-hover);
}

.form__textarea {
	resize: vertical;
	min-height: 8rem;
}

.form__help {
	color: var(--color-text-main);
	font-size: 0.95rem;
}

.form__meta {
	display: flex;
	justify-content: flex-end;
}

.char-count {
	font-size: 0.95rem;
	color: var(--color-text-main);
}

.char-count.is-limit {
	color: var(--color-form-error);
	font-weight: bold;
}

.form__error {
	color: var(--color-form-error);
	font-size: 0.95rem;
	min-height: 1.2rem;
}

.form__actions {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
}

.form__submit {
	width: 100%;
	border-radius: 999px;
	padding: 0.75rem 2rem;
	background-color: var(--color-primary);
	text-align: center;
	color: var(--color-text-sub);
	font-size: 1rem;
	cursor: pointer;
}
.form__submit:hover {
	background: var(--color-secondary);
	color: var(--color-text-main);
}

.form__status {
	font-size: 0.95rem;
	color: var(--color-text-main);
}

.form__status.is-success {
	color: var(--color-form-hover);
	font-weight: bold;
}

@media screen and (min-width: 1280px) {
	.form__actions {
		flex-wrap: wrap;
		align-items: center;
	}
}
