/*--------------------------------------------------------------
# Contact Form 7
--------------------------------------------------------------*/
/* 色の設定
--------------------------------------------- */
:root {
	--form-text-color: var(--color-text-primary);
	--form-color-danger: var(--color-danger);
	--form-color-input-background: var(--color-background-tertiary);
	--form-border-color: #E0E0E0;
	--form-color-outline: var(--color-primary);
	--form-submit-background: var(--color-text-primary);
	--form-submit-color: #fff;
	--form-submit-border: var(--color-text-primary);
}

/* 送信ボタンを押した時のみバリデーションメッセージ表示
--------------------------------------------- */
.wpcf7-form-control-wrap .wpcf7-not-valid-tip {
	display: none;
	margin-top: .5rem;
}

.is-show.wpcf7-form-control-wrap .wpcf7-not-valid-tip {
	display: block;
}

/* 汎用
--------------------------------------------- */
.form__wrapper {
	display: grid;
	gap: 2rem;
	color: var(--form-text-color);
	font-weight: 500;
}

.form__wrapper br {
	display: none;
}

.form__wrapper ::placeholder {
	opacity: .75;
}

.form__wrapper p {
	margin: 0;
}

.form__wrapper .form__row,
.form__wrapper .form__row > * {
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.form__wrapper .form__label {
	display: flex;
	align-items: center;
	gap: .25rem;
}

.form__wrapper .required .form__label::after {
	content: '必須';
	color: var(--form-color-danger);
	font-size: .75rem;
	font-weight: 500;
	line-height: 1em;
	height: fit-content;
	padding: .25em;
	border: 1px solid var(--form-color-danger);
	border-radius: 4px;
}

.form__wrapper input[type="text"],
.form__wrapper input[type="email"],
.form__wrapper input[type="tel"],
.form__wrapper textarea,
.form__wrapper select {
	padding: .75rem;
	width: 100%;
	background: var(--form-color-input-background);
	border: 2px solid var(--form-border-color);
	border-radius: .5rem;
}

.form__wrapper input[type="text"]:focus-visible,
.form__wrapper input[type="email"]:focus-visible,
.form__wrapper input[type="tel"]:focus-visible,
.form__wrapper textarea:focus-visible,
.form__wrapper select:focus-visible {
	outline-color: var(--form-color-outline);
}

.form__wrapper select {
	cursor: pointer;
}

.form__wrapper input[readonly="readonly"] {
	outline: none;
}

.form__wrapper input[type="submit"] {
	display: block;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--form-submit-color);
	background: var(--form-submit-background);
	width: 240px;
	max-width: 80%;
	margin: 0 auto;
	padding: 1em 1.25em;
	border: 1px solid var(--form-submit-border);
	border-radius: 2rem;
	transition: all .2s ease-out;
	cursor: pointer;
}

.form__wrapper input[type="submit"]:disabled {
	background: #bbb;
	border: 1px solid #bbb;
	cursor: not-allowed;
}

.form__wrapper input[type="submit"]:enabled:hover {
	transform: translateY(2px);
}

.form__wrapper input[type="checkbox"] {
	display: none;
}

.form__wrapper .wpcf7-list-item {
	display: block;
	margin-left: 0;
}

.form__wrapper .wpcf7-free-text {
	margin-top: .25rem;
}

.form__wrapper input[type="checkbox"] + .wpcf7-list-item-label {
	display: flex;
	justify-content: center;
	align-items: center;
	width: fit-content;
	margin: 1rem auto;
	cursor: pointer;
}

.form__wrapper input[type="checkbox"] + .wpcf7-list-item-label::before {
	content: '\f0c8';
	font-family: var(--fontawesome-sharp);
	font-size: 1.5rem;
	font-weight: 300;
	color: var(--form-text-color);
	margin-right: .5rem;
	cursor: pointer;
}

.form__wrapper input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
	content: '\f14a';
	font-family: var(--fontawesome-sharp);
	font-size: 1.5rem;
	color: var(--form-text-color);
	font-weight: 300;
}

.form__wrapper input[type="checkbox"] + .wpcf7-list-item-label a {
	color: var(--form-text-color);
	text-decoration: underline;
}

.form__wrapper .wpcf7-not-valid-tip {
	color: var(--form-color-danger);
}

.form__wrapper .wpcf7-not-valid-tip::before {
	content: '\f06a';
	font-family: var(--fontawesome-sharp);
	font-weight: 400;
	color: var(--form-color-danger);
	margin-right: .25em;
}

.form__wrapper .wpcf7-spinner {
	display: none;
	margin: 0 auto;
}

.form__wrapper form.submitting .wpcf7-spinner {
	display: block;
}