/*===============================================================================
フォーム全体
================================================================================*/
/*===============================
共通
=================================*/
.wpcf7 {
	--cf-border-color: #707070; /* ボーダー色 */
	--cf-tr-gap: var(--g-sec--xs); /* thとtdの間の余白 */
	--cf-tr-mb: 1rem; /* 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: 0.5rem;
	vertical-align: middle; /* 要素下の余白削除 */
	border-radius: var(--bd-r--sm);
	overflow: hidden;
	background-color: var(--c-light);
	box-shadow: inset 0px 0px 4px rgba(51, 51, 51, 0.1);
}

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

/* 日付 */
input[type="date"] {
	cursor: pointer;
}
input[type="date"]::-webkit-calendar-picker-indicator {
	position: absolute;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: none;
}

/*===============================
ラジオボタン＆チェックボックス
=================================*/
.wpcf7-radio,
.wpcf7-checkbox,
.wpcf7-acceptance {
	--label-size: 1.5rem;
	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-acceptance) .wpcf7-list-item {
	margin: 0;
}
/* use_label_elementを設定した場合 */
:is(.wpcf7-radio, .wpcf7-checkbox, .wpcf7-acceptance) label {
	display: flex;
	align-items: center;
	gap: var(--cf-unit-gap);
	width: fit-content;
}
/* ラベル, テキスト部分 */
:is(.wpcf7-radio, .wpcf7-checkbox, .wpcf7-acceptance) label,
:is(.wpcf7-radio, .wpcf7-checkbox, .wpcf7-acceptance) input {
	cursor: pointer;
}
/* ラベル */
:is(.wpcf7-radio, .wpcf7-checkbox, .wpcf7-acceptance) input {
	flex: 1;
	width: var(--label-size);
	min-width: var(--label-size);
	height: var(--label-size);
	border: 1px solid var(--cf-bdc);
}
/* テキスト */
.wpcf7
:is(.wpcf7-radio, .wpcf7-checkbox, .wpcf7-acceptance)
.wpcf7-list-item
label
span {
	opacity: 1;
}

/*===============================================================================
テーブル
================================================================================*/
.cfTable,
.cfTable tbody {
	display: block;
	width: 100%;
}
/* tr */
.cfTable__row {
	display: flex;
	flex-direction: column;
	gap: .5rem var(--cf-tr-gap);
}
@media (min-width: 600px){
	.cfTable__row {
		flex-direction: row;
		align-items: center;
	}
}
.cfTable__row:not(:last-of-type) {
	margin-bottom: var(--cf-tr-mb);
}
/* 各セル */
.cfTable__head,
.cfTable__body {
	flex-grow: 1;
}
/* 1列目のセル */
.cfTable__head {
	min-width: 9rem;
}
@media (min-width: 600px) {
	.cfTable__head {
		max-width: 9rem;
	}
}

/* 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;
}
.cfGroup.--privacy{
	max-width: fit-content;
	margin-inline: auto;
	text-align: center;
}
.cfGroup.--privacy a{
	text-decoration: underline;
}



/*===============================================================================
ボタンのスタイル
================================================================================*/
.cfBtn {
	text-align: center;
}
.cfBtn .c-btn{
	padding: 1.125rem 0;
	line-height: var(--lh-md);
}
.wpcf7-spinner {
	display: none;
}
