@charset "utf-8";

.mv {
	background: #008422;
	text-align: center;
}

/*------------------------------------------------------

自動車塗装設備メーカーとして培った技術を、製造業へ

-------------------------------------------------------*/
.voice-list {
	display: flex;
	justify-content: center;
	gap: 0 15px;
	align-items: center;
	margin: 10px auto 30px;
}

@media screen and (min-width:768px) {
	.voice-list {
		max-width: 830px;
		margin: -10px auto 40px;
	}
}

.voice-list dt {
	width: 50%;
}

@media screen and (min-width:768px) {
	.voice-list dt {
		width: auto;
	}
}

.voice-list dd {
	font-size: clamp(14px, 1.5vw, 16px);
	letter-spacing: 1px;
	line-height: 1.4;
}

@media screen and (min-width:768px) {
	.voice-list dd {
		line-height: 1.75;
	}
}

.chbox {
	background: #f2f2f2;
	border-radius: 10px;
	width: min(100%, 550px);
	margin: 0 auto 40px;
	padding: 15px 30px;
}

.chbox dd {
	font-size: clamp(14px, 1.5vw, 16px);
	letter-spacing: 1px;
	margin: 5px 0;
	background: url(../images/voice/ch.png) no-repeat 0% 50%;
	background-size: 15px;
	padding: 5px 0px 5px 25px;
}

.manufacturer-text {
	font-size: clamp(14px, 1.5vw, 16px);
	letter-spacing: 1px;
	text-align: center;
	font-weight: 500;
	padding: 30px 0px 0px;
	line-height: 1.75;
}



/* 基本設定 */
.container {
	max-width: 1100px;
	margin: 50px auto;
}

.layout-block {
	display: flex;
	align-items: center;
	position: relative;
	margin: 60px auto;

}

.text-box {

	color: #fff;

	z-index: 1;
}

.text-box dt {
	font-size: clamp(20px, 1.5vw, 25px);
	letter-spacing: 1px;
	font-weight: 500;
	border-bottom: 1px solid #fff;
	padding: 0 0 10px;
}

.text-box dd {
	font-size: clamp(13px, 1.5vw, 14px);
	letter-spacing: 1px;
	padding: 10px 0 0px;
	line-height: 1.75;
	text-align: justify;
}

.block-1 .text-box,
.block-3 .text-box {
	margin-left: -8%;
	/* 画像に被せる */
	padding: clamp(15px, 2vw, 30px);
	width: 60%;
	background-color: rgba(52, 156, 77, 0.9);
}

.block-1 .text-box {
	min-height: 300px;
	/* 指定より低くはならないが、中身が増えれば伸びる */
	height: auto;
	/* 固定解除 */
	margin-bottom: -10%;
}

.block-3 .text-box {
	min-height: 280px;
	/* 指定より低くはならないが、中身が増えれば伸びる */
	height: auto;
	/* 固定解除 */
	margin-bottom: -10%;
}

.block-2 {
	flex-direction: row-reverse;
	margin: 80px 0 -70px;

}

.block-2 .text-box {
	margin-right: -5%;
	/* 画像に被せる */
	margin-bottom: 80px;
	/* 下に余白を作り、上に浮いているように見せる */
	padding: clamp(15px, 2vw, 30px);
	width: 60%;
	min-height: 340px;
	/* 指定より低くはならないが、中身が増えれば伸びる */
	height: auto;
	/* 固定解除 */
	background-color: rgba(51, 158, 132, 0.9);
}

@media screen and (max-width: 1000px) {

	.layout-block,
	.block-2 {
		flex-direction: column;
		/* 全て縦並びに */
		margin: 30px auto;
	}

	.image-box,
	.text-box {
		width: 100%;

	}

	.image-box {
		text-align: center;
	}

	.block-1 .text-box,
	.block-3 .text-box {
		margin-left: 0%;
		/* 画像に被せる */
		padding: 30px;
		width: 100%;
	}

	.block-1 .text-box {
		height: auto;
		min-height: auto;
		margin-bottom: 0%;
	}

	.block-3 .text-box {
		height: auto;
		min-height: auto;
		margin-bottom: 0%;
	}


	.block-2 .text-box {
		margin-right: 0%;
		/* 画像に被せる */
		margin-bottom: 0px;
		/* 下に余白を作り、上に浮いているように見せる */
		padding: 30px 30px;
		width: 100%;
		height: auto;
		min-height: auto;
	}


}

/*


.text-box dt{
	font-size:clamp(17px, 1.5vw, 22px);
	letter-spacing:1px;
	font-weight:500;
	border-bottom:1px solid #fff;
	padding:0 0 10px;
}
.text-box dd{
	font-size:clamp(13px, 1.5vw, 13px);
	letter-spacing:1px;
	padding:10px 0 0px;
	line-height:1.75;
	text-align:justify;
}
*/


/*------------------------------------------------------

塗装設備・塗装ブースをご検討の方へ

-------------------------------------------------------*/
.contactbg {
	background: #02664e;
	color: #fff;
	padding: 40px 0;
}

.contact-title {
	font-size: clamp(18px, 1.5vw, 30px);
	letter-spacing: 2px;
	text-align: center;
	font-weight: 700;
	padding: 30px 0px 20px;
	margin: 0 0 5px;
}

.contact-title span {
	background: url(../images/booth/title.png) no-repeat 50% 50%;
	background-size: 60px;
	padding: 75px 0px 0;
}

@media screen and (min-width:768px) {
	.contact-title {
		padding: 0px 0px 20px;
	}

	.contact-title span {
		background: url(../images/booth/title.png) no-repeat 0% 50%;
		background-size: 60px;
		padding: 10px 0px 10px 75px;
	}
}

.dw-inner dl {
	display: flex;
	justify-content: center;
	flex-direction: column;
	gap: 10px 10px;
	max-width: 70%;
	margin: 0 auto;
}

@media screen and (min-width:768px) {
	.dw-inner dl {
		display: flex;
		flex-direction: row;

		gap: 10px 30px;
		max-width: 100%;
	}
}

.dw-inner dl dt a {
	font-size: clamp(14px, 1.5vw, 15px);
	letter-spacing: 1px;
	text-align: center;
	font-weight: 700;
	text-decoration: none;
	color: #02664e;
	padding-left: 2px;
	display: block;
	padding: .7em 0;
}

@media screen and (min-width:768px) {
	.dw-inner dl dt a {
		padding-left: 2px;
		padding: .7em 30px .6em 45px;
	}
}

.dw-inner_dw {
	background: url(../images/booth/icon01.png) no-repeat 18px 52% #fff;
	background-size: 14px;
	border-radius: 100px;
}

.dw-inner_consultation {
	background: url(../images/booth/icon02.png) no-repeat 16px 50% #fff;
	background-size: 17px;
	border-radius: 100px;
}

.dw-inner dl dd {
	margin: 0px 0 5px;
	text-align: center;
	font-size: clamp(14px, 1.5vw, 20px);
}

.dw-inner dl dd a {
	font-size: clamp(20px, 1.5vw, 27px);
	letter-spacing: 1px;
	text-align: center;
	font-weight: 700;
	text-decoration: none;
	color: #fff;
	display: inline-block;
	padding: 0 .3em;
}

@media screen and (min-width:768px) {
	.dw-inner dl dd a {
		pointer-events: none;

	}
}

/*------------------------------------------------------

多様な業種で導入が進む、ビーエフケーの塗装・乾燥設備

-------------------------------------------------------*/
.equipment_inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px 20px;
	margin: 20px auto 40px;
}

@media screen and (min-width:768px) {
	.equipment_inner {
		max-width: 800px;
		gap: 60px 60px;
		margin: 40px auto 40px;
	}
}

.equipment_inner figure {
	margin: 0 auto;
	text-align: center;
}

.equipment_inner dl {
	margin: 10px 0 0;
}

.equipment_inner dt {
	font-size: clamp(15px, 1.5vw, 18px);
	letter-spacing: 1px;
	text-align: center;
	font-weight: 700;
	margin: 0 0 5px;
	line-height: 1.2;
}

.equipment_inner dd {
	font-size: clamp(13px, 1.5vw, 15px);
	letter-spacing: 1px;
	text-align: center;
	line-height: 1.2;
}

/*------------------------------------------------------

ビーエフケーの技術・製品ラインナップの紹介

-------------------------------------------------------*/
.lineup-title {
	font-size: clamp(15px, 1.5vw, 18px);
	letter-spacing: 1px;
	text-align: center;
	border: 1px solid #000;
	padding: .7em 0;
	font-weight: 700;
	max-width: 65%;
}

@media screen and (min-width:768px) {
	.lineup-title {
		max-width: 300px;
	}
}

.line01 {
	margin: 10px auto 20px;
}

.line02 {
	margin: 50px auto 20px;
}

@media screen and (min-width:768px) {
	.line01 {
		margin: 20px auto 30px;
	}

	.line02 {
		margin: 100px auto 30px;
	}
}

.lineup_inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px 20px;
}

@media screen and (min-width:768px) {
	.lineup_inner {
		max-width: 800px;
		margin: 0 auto;
		gap: 40px 60px;
	}
}

.lineup_inner dd {
	text-align: center;
	margin: 5px 0 0px;
	font-size: clamp(13px, 1.5vw, 14px);
	letter-spacing: 1px;
	line-height: 1.2;
}

/*------------------------------------------------------

カタログダウンロード

-------------------------------------------------------*/
.catalog-list {
	margin: 60px 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px 20px;
	align-items: center;
}

@media screen and (min-width:768px) {
	.catalog-list {
		grid-template-columns: 1fr 1fr 1fr 1fr;
		margin: 60px 0 80px;
		gap: 45px 20px;
	}
}

.catalog-list .catalog-title {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 45px;
	font-size: clamp(13px, 1.5vw, 14px);
	letter-spacing: 1px;
	text-align: center;
	line-height: 1.25;
	font-weight: 500;
}


.catalog-list dt {
	text-align: center;
	margin: 0 0 10px;
}

.catalog-list .btn {
	text-align: center;
}

.catalog-list .btn a {
	font-size: clamp(13px, 1.5vw, 14px);
	background: url(../images/catalog/dw.png) no-repeat 10% 50% #fca000;
	color: #fff;
	display: block;
	text-decoration: none;
	padding: .5em 0 .5em 1em;
	border-radius: 100px;
	max-width: 90%;
	margin: 0 auto;
	letter-spacing: 1px;
	font-weight: 500;
}

@media screen and (min-width:768px) {
	.catalog-list .btn a {
		max-width: 60%;
	}
}

/*------------------------------------------------------

なぜビーエフケイが選べばれるのか？

-------------------------------------------------------*/
.js-scrollable {
	padding: 1em 0;
}

.bfk-table {
	margin: 40px auto 0;
	border-collapse: collapse;
	min-width: 500px;
	white-space: nowrap;
	letter-spacing: 1px;
}

.js-scrollable::-webkit-scrollbar {
	background: #f2f2f2;
	width: 5px;
	height: 5px;

}

.js-scrollable::-webkit-scrollbar-thumb {
	background: #008422;
	border-radius: 50px;
}

.bfk-table th {
	background: #f2f2f2;
	padding: 20px;
	border: 1px solid #333;
	text-align: center;
	font-size: clamp(14px, 1.5vw, 16px);
	font-weight: 700;
}

.bfk-table td {
	padding: 20px;
	border: 1px solid #333;
	text-align: center;
	font-size: clamp(14px, 1.5vw, 15px);
	font-weight: 400;
}

.bfk-table td.lbl {
	background: #f2f2f2;
}

.bfk-table td.lbl-y {
	background: #fcee21;
	font-weight: 500;
}

.txt_appeal {
	text-align: center;
	margin: 20px auto 0;
	font-size: clamp(18px, 3vw, 26px);
	font-weight: 700;
	color: #333;
}

/*------------------------------------------------------

よくある質問

-------------------------------------------------------*/
.faq {
	background: #f3f3f3;
}

.qa-6 {
	max-width: 980px;
	margin: 0 auto 0px;
	border-bottom: 1px solid #333;
}

.topborder {
	margin: 30px auto 0;
}

.qa-6 summary {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	padding: 1em 0em 1em 0em;
	color: #333333;
	cursor: pointer;
	font-size: clamp(14px, 1.5vw, 16px);
	letter-spacing: 1px;

}

.qa-6 summary div dl {
	display: flex;
	gap: 10px;
	text-align: left;
	align-items: center;
}

@media screen and (min-width:768px) {
	.qa-6 summary div dl {
		width: 100%;
		display: flex;
	}
}

.qa-6 summary div dl dd {
	font-weight: 700;
	flex: 1;
}

.qa-6 summary::after {
	transform: translateY(-25%) rotate(45deg);
	width: 5px;
	height: 5px;
	margin-left: auto;
	/* 右端に寄せる */
	border-bottom: 2px solid #333;
	border-right: 2px solid #333;
	content: '';
	transition: transform .5s;
}

@media screen and (min-width:768px) {
	.qa-6 summary::after {
		transform: translateY(-25%) rotate(45deg);
		width: 7px;
		height: 7px;
	}
}

.qa-6[open] summary::after {
	transform: rotate(225deg);
}

.qa-6 p {
	position: relative;
	transform: translateY(-10px);
	opacity: 0;
	margin: 0;
	padding: 0em 0em 0em;
	color: #333;
	transition: transform .5s, opacity .5s;
	font-size: clamp(14px, 1.5vw, 16px);
}

.qa-6[open] p {
	transform: none;
	opacity: 1;
}

.answer dl {
	display: flex;
	gap: 0 10px;
	font-weight: 500;
	padding: 0 0 20px 0px;
}

@media screen and (min-width:768px) {
	.answer dl {
		padding: 0 0 20px 20px;
	}
}

.answer dd {
	flex: 1;
}

/*------------------------------------------------------

お問い合わせ

-------------------------------------------------------*/
.contact_body {
	width: min(93%, 900px);
	position: relative;
	margin: 0px auto 10px;
}

.contact_body dt {
	font-size: clamp(17px, 1.5vw, 20px);
	letter-spacing: 1px;
	font-weight: 900;
	margin: 20px 0 20px;
	text-align: center;
}

@media screen and (min-width:768px) {
	.contact_body dt {
		margin: 40px 0 20px;
	}
}

.contact_body dd {
	letter-spacing: 1px;
	font-size: clamp(13px, 1.5vw, 15px);
	text-align: center;
	line-height: 1.75;
}

.contact_body dd span {
	display: block;
	background: url(../images/contact.png) no-repeat 0 50%;
	padding-left: 12px;
	max-width: 300px;
	margin: 20px auto 0;
}

@media screen and (min-width:768px) {
	.contact_body dd span {
		max-width: 330px;
	}
}


.form-inner {
	width: min(100%, 500px);
	position: relative;
	margin: 40px auto 10px;
	background: #fff;

}

.form-inner div {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	padding: 10px;
}

.cage,
select {
	border: 1px solid #ccc;
	padding: 10px;
	width: 100%;
	font-size: clamp(13px, 1.5vw, 15px);
	color: #666;
}

.cmn-icon {
	display: inline-block;
	padding: 3px 5px;
	width: 15%;
	text-align: center;
}

@media screen and (min-width:768px) {
	.cmn-icon {
		padding: 3px 5px;
		width: 10%;

	}
}

.mast-icon {
	color: #f00;
	border: 1px solid #f00;
}

.any-icon {
	color: #000;
	border: 1px solid #000;
}

input:focus,
select:focus {
	background-color: rgba(217, 255, 255, .3);
}

.agreement-list {
	position: relative;
	margin: 10px auto 0px;
	padding-left: 70px;
}

@media screen and (min-width:768px) {
	.agreement-list {
		padding-left: 60px;
	}
}

.agreement-list li {
	display: flex;
	align-items: flex-start;
	font-size: clamp(12px, 1.5vw, 13px);
}

.agreement-list li a {
	color: blue;
}

.agreement-list label {
	cursor: pointer;
	display: flex;
	align-items: center;
	line-height: 1.3;
}

/* チェックボックスと文字の間に余白を作る */
.agreement-list input[type="checkbox"] {
	margin-right: 5px;
	width: 15px;
	height: 15px;
	cursor: pointer;
	flex-shrink: 0;
}

.input-btn {
	display: flex;
	justify-content: center;
	gap: 20px;
	margin: 30px 0 0;
}

.input-btn li {
	width: 50%;

}

.common-btn {
	display: block;
	font-size: clamp(14px, 1.5vw, 17px);
	text-align: center;
	cursor: pointer;
	padding: 8px 12px;
	width: 100%;
	transition: .3s;
	border: none;
	border-radius: 100px;
	font-weight: 500;
	letter-spacing: 1px;
}

@media screen and (max-width:768px) {
	.common-btn {
		font-size: 16px;
	}
}

.btn_submit {
	background: #02664e;
	color: #fff !important;
	border: 1px solid #02664e;
	width: 200px !important;
	text-align: center;
	margin: 0 auto 0;
}

.btn_submit:hover {
	color: #02664e !important;
	background: #fff;
}

.btn_reset {
	background: #efefef;
	color: #333;
	border: 1px solid #efefef;

}

.btn_reset:hover {
	color: #333;
	background: #fff;
	border: 1px solid #333;
}

.error {
	width: 100%;
	font-size: clamp(12px, 1.5vw, 14px);
	letter-spacing: 1px;
	font-weight: 500;
	background: #b90000;
	color: #fff;
	padding: .5em 10px;
	margin: 0 0 2px;
	position: relative;
	border-radius: 5px;
}

.error:before {
	content: "";
	position: absolute;
	top: 100%;
	left: 10%;
	margin-left: -10px;
	border: 7px solid transparent;
	border-top: 7px solid #b90000;
}


.bfktable {
	width: min(100%, 700px);
	margin: 0 auto;
	font-size: clamp(14px, 1.5vw, 16px);
	letter-spacing: 1px;
}

.bfktable caption {
	font-size: clamp(17px, 1.5vw, 20px);
	letter-spacing: 1px;
	text-align: center;
	margin: 0 0 10px;
}

.bfktable th,
.bfktable td {
	padding: 15px 15px;
	border: 1px solid #ccc;
}

@media screen and (max-width:768px) {

	.bfktable th,
	.bfktable td {
		padding: 7px 15px;
		border: none;
		width: 100%;
		display: block;
	}
}

.bfktable th {
	background: #f5f5f5;
}

@media screen and (max-width:768px) {
	.bfktable td {
		padding: 7px 15px 25px 15px;
	}
}

.contact_end {
	margin: 40px auto 40px;
	width: min(90%, 500px);
	font-size: clamp(14px, 3.5vw, 18px);
	font-weight: 500;
	text-align: center;
	letter-spacing: 1px;
}

.contact_end dd {
	font-size: 16px;
}

.contact_end span {
	font-size: clamp(14px, 3.5vw, 20px);
	font-weight: 700;
	display: block;
	margin: 0 0 30px;
}



.btn:hover {
	opacity: 0.7;
}

.btn_ef {
	margin: 40px 0 0;
}

.btn_ef a {
	color: #222;
}

/* モーダル背景 */
.modal {
	display: none;
	/* 初期状態は非表示 */
	position: fixed;
	z-index: 1000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.7);
	/* 背景を暗く */
	opacity: 0;
	transition: opacity 0.3s ease;
}

/* 表示された時用のクラス */
.modal.is-show {
	display: block;
	opacity: 1;
}


/* モーダルコンテンツ */
.modal-content {
	background-color: #fff;
	margin: 10% auto;
	padding: 20px;
	width: 90%;
	max-width: 700px;
	border-radius: 8px;
	position: relative;
	transform: translateY(-20px);
	opacity: 0;
	transition: all 0.3s ease;
}

@media screen and (min-width:768px) {
	.modal-content {
		padding: 40px;
		width: 80%;
	}
}

/* 表示された時のコンテンツ状態 */
.modal.is-show .modal-content {
	transform: translateY(0);
	opacity: 1;
}

/* 閉じるボタン */
.close-btn {
	position: absolute;
	right: 10px;
	top: 5px;
	font-size: 20px;
	cursor: pointer;
}

.privacy-title {
	text-align: center;
	font-size: clamp(14px, 3.5vw, 20px);
	font-weight: 500;
	letter-spacing: 2px;
}

/* ポリシー本文のスクロール設定 */
.policy-text {
	max-height: 400px;
	overflow-y: auto;
	text-align: left;
	margin-top: 15px;
	font-size: clamp(12px, 2.5vw, 14px);
	line-height: 1.6;
}

textarea {
	resize: none;
	height: 250px;
}