/*===============================================================================
フォーム全体
================================================================================*/
/*===============================
共通
=================================*/
.wpcf7 {
	--cf-border-color: #707070; /* ボーダー色 */
	--cf-tr-gap: 1rem; /* thとtdの間の余白 */
	--cf-tr-mb: var(--g-sec--xs); /* tr下の余白 */
	--cf-cell-vertical-pad: 0.25rem; /* セルの上下のパディング */
	--cf-cell-side-pad: 1rem; /* セルの左右のパディング */
	--cf-unit-gap: 0.25rem; /* ｲﾝﾌﾟｯﾄｴﾘｱと単位の余白 */
}
/*===============================
input要素
=================================*/
/* input要素の親 */
.wpcf7-form-control-wrap {
	display: inline-block;
	width: 100%;
}
/* 各input要素 */
.wpcf7-text,
.wpcf7-textarea,
.wpcf7-select,
.wpcf7-number,
.wpcf7-date {
	width: 100%;
	min-height: 2.75rem; /* 最低限高さを保つ */
	padding: 1rem;
	vertical-align: middle; /* 要素下の余白削除 */
	border-radius: var(--bd-r--sm);
	overflow: hidden;
}

/* プレースホルダー内のテキストカラー */
:is(input, textarea)::placeholder {
	color: var(--c-gray);
}

/*===============================
ラジオボタン＆チェックボックス
=================================*/
.wpcf7-radio,
.wpcf7-checkbox {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1.5rem;
}
/* 縦積み */
.wpcf7-radio.--column,
.wpcf7-checkbox.--column {
	flex-direction: column;
}
:is(.wpcf7-radio, .wpcf7-checkbox) .wpcf7-list-item {
	margin: 0;
}
/* use_label_elementを設定した場合 */
:is(.wpcf7-radio, .wpcf7-checkbox) label {
	display: flex;
	gap: var(--cf-unit-gap);
	accent-color: #2a918b; /* ボタンの色 */
}
/* ラベル, テキスト部分 */
:is(.wpcf7-radio, .wpcf7-checkbox, .wpcf7-acceptance) label,
:is(.wpcf7-radio, .wpcf7-checkbox, .wpcf7-acceptance) input {
	cursor: pointer;
}
/* 円 */
.wpcf7-radio input {
	width: 1.25rem;
	aspect-ratio: 1;
}
/* 文字関連 */
.wpcf7 :is(.wpcf7-radio, .wpcf7-checkbox) .wpcf7-list-item label span {
	font-weight: bold;
	font-size: 1rem;
	color: var(--c-light);
	opacity: 1;
}

/*===============================================================================
テーブル
================================================================================*/
.cfForm{
	padding: clamp(1.75rem, 0.504rem + 3.33vw, 3.5rem);
	background: var(--c-light);
	border-radius: var(--bd-r--xl);
	overflow: hidden;
	border: 4px solid #FBE8F2;
}

.cfTable,
.cfTable tbody {
	display: block;
	width: 100%;
}
/* tr */
.cfTable__row {
	display: flex;
	flex-direction: column;
	gap: var(--cf-tr-gap);
}
.cfTable__row:not(:last-of-type) {
	margin-bottom: var(--cf-tr-mb);
}
/* 各セル */
.cfTable__head{
	font-size: 1.25rem;
	font-weight: var(--fw-lg);
}
.cfTable__head,
.cfTable__body {
	flex-grow: 1;
}

/* 1つのセルに複数の要素が入った場合 */
.cfTable__body > *:not(:last-child) {
	margin-bottom: 0.25rem;
}

/* .cfTable__bodyの中身 */
.cfTable__list {
	display: flex;
	gap: 1rem;
}
/* 単位有りフォーム */
.cfList__unit {
	display: flex;
	gap: var(--cf-unit-gap);
	align-items: flex-end;
}
/* 単位有りフォーム */
.cfList__unit .wpcf7-form-control-wrap {
	max-width: fit-content;
}
/* 注釈 */
.cfTable__note {
	font-size: 0.75rem;
}

/*===============================
* 常に縦並び
* =================================*/
.cfTable.--pc-column .cfTable__row {
	flex-direction: column;
}
.cfTable.--pc-column :is(.cfTable__head, .cfTable__body) {
	width: 100%;
	padding: 0;
}
/*===============================
* SP時縦並び
* =================================*/
@media not all and (min-width: 600px) {
	.cfTable.--sp-column .cfTable__row {
		flex-direction: column;
	}
}
/*===============================
* 全方位ボーダー
* =================================*/
.cfTable.--full-border {
	--bd-width: 1px;
	--bd-style: solid;
	--bd-color: var(--cf-border-color);
	border-top: var(--bd-width) var(--bd-style) var(--bd-color);
	border-left: var(--bd-width) var(--bd-style) var(--bd-color);
}
/* 1列目のセル */
.cfTable.--full-border .cfTable__head {
	border-bottom: var(--bd-width) var(--bd-style) var(--bd-color);
}
/* 2列目のセル */
.cfTable.--full-border .cfTable__body {
	border-right: var(--bd-width) var(--bd-style) var(--bd-color);
	border-bottom: var(--bd-width) var(--bd-style) var(--bd-color);
}

/*===============================================================================
各フォーム
================================================================================*/
/* CF7のショートコード内のグループ */
.cfGroup:not(:last-child) {
	margin-bottom: var(--g-sec--sm);
}
/* CF7のショートコード内の行間 */
.cfGroup > *:not(:last-of-type) {
	margin-bottom: 2rem;
}

/*===============================================================================
ラベル
================================================================================*/
.cfLabel {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
}
.cfLabel::before {
	min-width: fit-content;
	padding: 0 0.75em;
	border: 1px solid var(--c-main);
	border-radius: var(--bd-r--xs);
	overflow: hidden;
	color: var(--c-main);
	font-size: 1rem;
	font-weight: var(--fw-lg);
	font-family: inherit;
}
.cfLabel.--required::before {
	content: "必須";
	background: var(--c-light);
}


/*===============================================================================
プライバシーポリシー
================================================================================*/
.wpcf7-acceptance a{
	color: var(--c-dark);
	text-decoration: underline;
}

/*===============================================================================
ボタンのスタイル
================================================================================*/
.cfBtn {
	text-align: center;
}
.cfBtn input[type=submit]{
	padding: 1em .75em;
	color: var(--c-light);
}
.wpcf7-spinner {
	display: none;
}

