#formWrap {
	width: 100%;
	margin: 0 auto;
	color: #555;
	line-height: 1.6;
	font-size: 90%;
}

table.formTable {
	width: 100%;
	margin: 0 auto;
	border-collapse: collapse;
	table-layout: fixed;
}

table.formTable td,
table.formTable th {
	border: 1px solid #ccc;
	padding: 14px 16px;
	vertical-align: top;
}

table.formTable th {
	width: 30%;
	font-weight: normal;
	background: var(--main-color);
	color: #fff;
	text-align: left;
}

table.formTable td {
	background: #fff;
}

form select,
form input[type="text"],
form input[type="tel"],
form input[type="email"],
form textarea {
	width: 95%;
	padding: 7px 10px;
	border: 1px solid #ccc;
	box-sizing: border-box;
	font-size: 15px;
	line-height: 1.4;
	background: #fff;
	font-weight: normal;
}
form textarea {
	min-height: 180px;
	resize: vertical;
}

form input[type="submit"] {
	color: #fff;
	border: none;
	padding: 12px 30px;
	background-color: #c97c3c;
	display: inline-block;
	margin: 0 auto;
	cursor: pointer;
	border-radius: 7px;
}
form input[type="submit"]:hover {
	filter: brightness(90%) contrast(120%);
}
form input[type="reset"],
form input[type="button"] {
	color: #fff;
	border: none;
	padding: 10px 30px;
	background-color: #ccc;
}

input[type="button"] {
	color: #fff;
	border: none;
	padding: 10px 30px;
	background-color: #838383;
}

/* 選択肢グループ */
.form-option-group {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px 20px;
}

.form-option-group label{
	display:flex;
	align-items:flex-start;
	gap:8px;
	line-height:1.6;
	cursor:pointer;
}

.form-option-group input[type="checkbox"],
.form-option-group input[type="radio"]{
	vertical-align: middle;
	margin-right: 1px;
	position: relative;
	top: 3px;
}

/* 選択肢が少ない項目用 */
.form-option-group-radio {
	grid-template-columns: repeat(2, 1fr);
}

/* reCAPTCHA v3　表示位置 */
.grecaptcha-badge {
	margin-bottom: 70px;
	z-index: 9999;
}

/* リンク アンダーライン */
a.m-unli {
	text-decoration: underline;
	color: #454545;
}

a.m-unli:hover {
	color: #c5c5c5;
}

@media only screen and (max-width: 767px) {
	#formWrap {
		width: 100%;
		margin: 0 auto;
		font-size: 16px;
	}

	table.formTable th,
	table.formTable td {
		width: auto;
		display: block;
	}

	table.formTable th {
		margin-top: 0;
		border-bottom: 0;
	}

	table.formTable td {
		padding: 14px;
	}

	form select,
	form input[type="text"],
	form input[type="tel"],
	form input[type="email"],
	form textarea {
		width: 100%;
		padding: 10px;
		font-size: 16px;
		display: block;
	}

	.form-option-group,
	.form-option-group-radio {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	form input[type="submit"],
	form input[type="reset"],
	form input[type="button"] {
		display: block;
		height: 44px;
		font-size: 16px;
		margin-bottom: 10px;
	}
}

@media print, screen and (min-width: 768px) {
	.form-option-group {
		grid-template-columns: repeat(2, 1fr);
	}

	.form-option-group-radio {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* TELバナー CONTACTページ用レイアウト */
.tel_bnr-contact {
	display: grid;
	grid-template-columns: 1fr 0.3fr;
	grid-template-rows: 1fr;
	grid-column-gap: 50px;
	grid-row-gap: 10px;
	max-width: 700px;
	margin: 0 auto;
}

@media only screen and (max-width: 767px) {
	.tel_bnr-contact {
		grid-template-columns: repeat(1, 1fr);
		grid-row-gap: 10px;
	}
}

/* ================================
single（見た目：白い枠だけ）
================================ */
.tel_bnr-single {
	background: #ffffff85;
	border: 1px solid #dfdfdf;
	border-radius: 7px;
	padding: 20px 40px;
	box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
}

/* ================================
ボタン制御
================================ */
.tel_bnr-single .btn-call {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	justify-self: end;
}

/* ================================
ボタンデザイン
================================ */
.btn-call {
	background: var(--main-color);
	color: #fff;
	padding: 14px 28px;
	border-radius: 8px;
	font-weight: bold;
	font-size: 15px;
	white-space: nowrap;
	text-decoration: none;
	box-shadow: 0 4px 10px rgba(68, 35, 41, 0.3);
	transition: background 0.2s, transform 0.1s;
	width: auto;
	max-width: none;
	align-self: center;
}

.btn-call:hover {
	background: var(--accent-color2);
	transform: translateY(-1px);
}

@media only screen and (max-width: 767px) {
	.btn-call {
		width: 100%;
		box-sizing: border-box;
	}

	.tel_bnr-single .btn-call {
		justify-self: center;
	}

	.tel_bnr-single {
		background: #ffffffa6;
		padding: 20px 20px;
	}
}