@charset "utf-8";

/* 表面処理サービス
========================================================= */

/* コーティングの特徴
--------------------------------------------------------- */


/* アンカーリンク
--------------------------------------------------------- */

.serviceAnch { width: 100%; border-bottom: solid 1px #c9c9c9; }
.serviceAnch ul { width: 100%; max-width: 1200px; display: table; table-layout: fixed; margin: 0 auto; }
.serviceAnch ul li { display: table-cell; text-align: center; }
.serviceAnch ul li a {
	display: inline-block;
	color: #000000;
	font-size: 1.8rem;
	line-height: 2.2rem;
	position: relative;
	padding-top: 5px;
}
.serviceAnch ul li a p { height: 110px; display: table-cell; vertical-align: middle; }
.serviceAnch ul li a p span { display: inline-block; }
.serviceAnch ul li a:after {
	content: "";
	width: 8px;
	height: 8px;
	display: block;
	border-top: solid 2px #787878;
	border-right: solid 2px #787878;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
	position: absolute;
	top: 0;
	right: 0;
	bottom: -60px;
	left: 0;
	margin: auto;
	-webkit-transition: all 0.2s;
	transition: all 0.2s;
}



@media screen and (min-width: 769px) {
	.serviceAnch ul li a:hover:after { top: 10px; }
}

@media screen and (max-width: 960px) {
	.serviceAnch ul li a p { height: 70px; }
	.serviceAnch ul li a { font-size: 1.5rem; line-height: 1.8rem; }
	.serviceAnch ul li a:after { top: 0; }
}

@media screen and (max-width: 768px) {
	.serviceAnch ul li {
		display: block;
		text-align: left;
		padding: 0 25px;
		-webkit-transition: all 0.3s;
		transition: all 0.3s;
	}
	.serviceAnch ul li + li { border-top: solid 1px #c9c9c9; }
	.serviceAnch ul li a { display: block; }
	.serviceAnch ul li a p { height: 40px; }
	.serviceAnch ul li a:after {
		position: absolute;
		top: 0;
		right: 10px;
		left: auto;
		bottom: 0;
		margin: auto;
		-webkit-transition: all 0.2s;
		transition: all 0.2s;
	}
}



.moldingList { margin-top: 50px; }
.moldingItem { background: #fff; padding: 50px; display: flex; flex-wrap: wrap; gap: 20px 30px; align-items: center; }
.moldingItem:nth-child(n+2) { margin-top: 40px; }

.moldingImg { max-width: 300px; width: 100%; }
.moldingImgWide { flex: 0 1 auto; width: 100%; aspect-ratio: 16/9; }
.moldingImgWide video { width: 100%; aspect-ratio: 16/9; }
.moldingImgWideIn { max-width: 480px; margin: 0 auto; }
.moldingEx { flex: 1; }

.moldingLabel { position: relative; font-size: 3.8rem; line-height: 1.25; font-weight: 700; margin-bottom: 35px; }
.moldingLabel::before { content: ""; width: 40px; height: 40px; border-radius: 20px; position: absolute; top: 0; bottom: 0; left: 0; margin: auto; }

.partsContent { margin: 100px auto 0; max-width: 1400px; padding: 0 30px; }
.partsList { margin: 60px auto 0; display: flex; flex-wrap: wrap; gap: 80px; }
.partsItem { border: 2px solid #ccc; inline-size: calc((100% - 80px) / 2); padding: 30px 20px 40px; box-sizing: border-box; background: #fff; box-shadow: 20px 20px 0px 0 rgba(0,0,0,.25); cursor: pointer; transition: .25s; }
.partsListLavel { text-align: center; font-weight: 700; font-size: 2.4rem; }
.partsImg { margin-top: 20px; }
.partsIns { display: flex; flex-wrap: wrap; gap: 30px; align-items: center; max-width: 1000px; margin: 0 auto; }
.partsIns2 { display: flex; flex-wrap: wrap; gap: 30px; align-items: center; max-width: 1000px; margin: 90px auto 0; }
.partsInsEx { flex: 1; }
.partsInsLabel { font-weight: 700; font-size: 2.4rem; margin-bottom: 30px; }
.partsInsImg { max-width: 360px; width: 100%; margin: 0 auto; }

@media (min-width: 769px) {
	.partsItem:hover { transform: translate(10px,10px); box-shadow: 10px 10px 0px 0 rgba(0, 0, 0, .75); }
}

@media (max-width: 767px) {
	.moldingItem { padding: 30px 20px; gap: 30px; }
	.moldingImg { margin: 0 auto; }
	.moldingEx { flex: 0 1 auto; }
	.moldingLabel { font-size: 2.4rem; margin-bottom: 25px; }

	.partsContent { margin: 60px auto 0; padding: 0 20px; }
	.partsList { margin: 60px auto 0; max-width: 500px; gap: 40px; }
	.partsItem { inline-size: 100%; padding: 25px 15px 30px; box-shadow: 10px 10px 0px 0 rgba(0,0,0,.25); }
	.partsItem:nth-child(odd) { transform: translateY(0px); }
	.partsListLavel { font-size: 1.8rem; }
	.partsInsEx { flex: 0 1 auto; }
	.partsInsLabel { font-size: 1.8rem; margin-bottom: 15px; }
}

.durType { padding-bottom: 110px; }
.durTypeWrap { display: flex; flex-wrap: wrap; gap: 30px clamp(30px,calc(4.75vw + -7px),60px); max-width: 1460px; padding: 0 30px; margin: 0 auto; }
.durTypeItem { inline-size: calc((100% - (clamp(30px,calc(4.75vw + -7px),60px) * 2)) / 3); box-shadow: 10px 10px 0px 0 rgba(0,0,0,.25); background: #222; }
.durTypeEx { color: #fff; padding: 35px 15px 15px; box-sizing: border-box; }
.durTypeName { font-weight: 700; font-size: 4rem; letter-spacing: 0.05em; line-height: 1; }
.durTypeLabel { font-weight: 700; font-size: 1.8rem; line-height: 1.31; font-weight: 700; margin-top: 25px; }
.durTypeTxt { margin-top: 10px; }
.durTypeCap { position: relative; text-align: right; font-size: 1.4rem; margin-top: 10px; padding-right: 1em; }
.durTypeCap::after { position: absolute; content: ""; inset: 0 0 0 auto; margin: auto 0; width:0; height:0; border-style:solid; border-width: 5px 0 5px 8.7px; border-color: transparent transparent transparent #FFFFFF; }

@media (min-width: 769px) {
	.durTypeItem { position: relative; transition: .25s; }
	.durTypeItem:hover { box-shadow: 5px 5px 0px 0 rgba(0,0,0,.25); transform: translate(5px,5px); }
	.durTypeItem::before { transition: .25s; position: absolute; content: ""; inset: 0 auto auto 0; width: 100%; height: 100%; background: rgba(0,0,0,.25); opacity: 0; }
	.durTypeItem:hover::before { opacity: 1; }
}
@media (max-width: 767px) {
	.durType { padding-bottom: 65px; }
	.durTypeWrap { padding: 0 15px; }
	.durTypeItem { display: flex; flex-wrap: wrap; width: 100%; align-items: center; }
	.durTypeImg { position: relative; width: 45%; background: #222; padding: 20px 0 20px 20px; display: flex; flex-wrap: wrap; align-items: center; box-sizing: border-box; }
	.durTypeEx { width: 55%; padding: 20px; }
}
@media (max-width: 500px) {
	.durTypeItem { width: 100%; align-items: center; }
	.durTypeImg { width: 100%; padding: 0; }
	.durTypeEx { width: 100%; padding: 25px 15px 20px; }
}




.functionWrap { margin-top: 50px; }
.functionEx { text-align: center; }
.functionImg { max-width: 330px; margin: 40px auto 0; }

.color { padding: 0 30px; }
.colorContent { max-width: 1400px; margin: 40px auto 0; }

.colorTitle { font-size: 3.2rem; line-height: 1.5; font-weight: 700; text-align: center; padding: 15px; max-width: 420px; margin: 0 auto; text-align: center; background: #fff; border: 1px solid #000; }
.colorTitle2 { font-size: 3.2rem; line-height: 1.5; font-weight: 700; text-align: center; }
.colorLabel { width: 240px; margin: 0 auto; }
.colorNav { position: relative; display: flex; flex-wrap: wrap; gap: 15px; justify-content: center; margin-top: 40px; background: #fff; max-width: 800px; margin: 40px auto; padding: 30px 10px 40px; border: 1px solid #000; }
.colorTitle + .colorNav::before { position: absolute; content: ""; inset: -40px 0 auto 0; margin: 0 auto; width: 1px; height: 40px; background: #666; }
.colorNavItem { position: relative; width: 80px; cursor: pointer; transition: .25s; }
.colorNavItemBox { transition: .25s; }
.colorNavItem.active .colorNavItemBox,
.colorNavItem:hover .colorNavItemBox { box-shadow: 0px 0px 0px 5px #ff927c; }
.colorNavItemLabel { text-align: center; margin-bottom: 3px; font-size: 1.3rem; line-height: 1.2; height: 45px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; align-content: center; }
.colorVisual { position: relative; margin: 20px auto 0; max-width: 800px; }
.colorVisualItem { position: relative; opacity: 0; transition: .25s; pointer-events: none; }
.colorVisualItem:not(:first-child) { position: absolute; content: ""; inset: 0 auto auto 0; }
.colorVisualItem.active { opacity: 1; z-index: 100; pointer-events: all; }
.colorVisualName { position: absolute; content: ""; inset: 0 auto auto 0; text-align: center; font-size: 2.4rem; font-weight: 700; background: #222; padding: 12px 20px; color: #fff; }
.colorVisualWatch { margin: 20px auto 0; display: flex; flex-wrap: wrap; align-items: center; gap: 30px 0; padding: 30px 0 30px 120px; background: #fff; }
.colorVisualWatchLabel { width: 100%; text-align: center; padding-right: 120px; font-size: 2rem; font-weight: 700; }
.colorVisualWatchImg { width: 160px; }
.colorVisualWatchEx { flex: 1; text-align: center; }
.colorVisualWatchName { font-size: 2.8rem; font-weight: 700; margin-top: 30px; }
.colorVisualWatchBuy { font-size: 1.5rem; margin-top: 10px; }
.colorVisualWatchBuy span { font-size: .8em; }
.colorVisualEx { padding: 30px; background: #fff; margin-top: 30px; }
.colorVisualWatchLogo { margin: 0 auto; }
.logoAtt { aspect-ratio: 1030/161; max-width: 50%; max-width: 200px; }
.logoXC { aspect-ratio: 379/546; max-width: 25%;  max-width: 50px;}
.logoProm { aspect-ratio: 1126/135; max-width: 50%; max-width: 200px; }

.colorAside { background: #f5f5f5; margin-top: 90px; padding: 0 30px 35px; }
.colorAsideLabel { text-align: center; font-size: 2.4rem; font-weight: 700; margin-bottom: 30px; }
.colorAsideTxt { max-width: 800px; margin: 0 auto; }
.colorAsideImg { max-width: 800px; margin: 40px auto 0; }
.colorAsideCap { max-width: 800px; margin: 20px auto 0; }

.lineup { padding: 90px 30px 0; }
.lineupList { margin-top: 30px; }
.lineupItem { background: #fff; padding: 60px 60px 40px; display: flex; flex-wrap: wrap; gap: 20px 40px; }
.lineupItem:nth-child(n+2) { margin-top: 60px; }
.lineupImg { max-width: 300px; width: 100%; margin: 0 auto; }
.lineupEx { flex: 1; }
.lineupName { font-weight: 700; font-size: 2.4rem; }
* + .lineupState { margin-top: 20px; }
.lineupStateItem { display: flex; flex-wrap: wrap; gap: 0 1em; font-size: 1.6rem; }
.lineupStateLabel { font-weight: 700; }
.lineupTxt { margin-top: 20px; }

.lineupOtherList { display: flex; flex-wrap: wrap; gap: 30px; margin-top: 60px; }
.lineupOtherItem { inline-size: calc((100% - 30px) / 2); background: #fff; padding: 20px 20px 15px; box-sizing: border-box; }
.lineupOtherName { text-align: center; margin-top: 10px; font-size: 1.4rem; }


.applyWrap { margin-top: 40px; }
.applyList { display: flex; flex-wrap: wrap; gap: 80px; }
.applyItem { background: #fff; box-shadow: 15px 15px 0px 0 rgba(0,0,0,.25); inline-size: calc((100% - 80px) / 2); padding: 30px 40px 40px; box-sizing: border-box; border: 2px solid #ccc; }
.applyLabel { font-weight: 700; font-size: 1.8rem; }
.applyImg { margin-top: 25px; }


@media (max-width: 767px) {
	.functionEx { text-align: left; }
	
	.color { padding: 0 15px; }
	.colorNav { gap: 10px; }
	.colorNavItem { width: 60px; }
	.colorNavItemLabel { font-size: 1rem; }
	.colorVisualWatch { margin: 20px auto 0; padding: 30px 0; max-width: 400px; }
	.colorVisualWatchLabel { padding-right: 0px; }
	.colorVisualWatchImg { width: 100px; flex: 0 1 auto; margin: 0 auto; }
	.colorVisualWatchEx { width: 100%; flex: 0 1 auto; }
	.colorVisualEx { padding: 15px; }
	.colorVisualName { font-size: 1.7rem; padding: 5px 10px; }
	.colorAside { margin-top: 60px; padding: 0 15px 20px; }
	.colorAsideImg { margin: 30px auto 0; }
	.colorAsideCap { margin: 15px auto 0; }
	
	.lineup { padding: 45px 15px 0; }
	.lineupItem { padding: 40px 15px 30px; margin: 0 auto; max-width: 500px; }
	.lineupItem:nth-child(n+2) { margin-top: 40px; }
	.lineupEx { flex: 0 1 auto; }
	.lineupName { font-size: 1.8rem; }
	* + .lineupState { margin-top: 15px; }
	.lineupStateItem { font-size: 1.4rem; }
	.lineupTxt { margin-top: 15px; }
	
	
	.lineupOtherItem { inline-size: 100%; }
	
	.apply { margin-top: 60px; }
	.applyList { gap: 40px; margin: 0 auto; max-width: 500px; }
	.applyItem { box-shadow: 10px 10px 0px 0 rgba(0,0,0,.5); inline-size: 100%; padding: 15px 20px 20px; }
	.applyLabel { font-size: 1.5rem; }
	.applyImg { margin-top: 15px; }
}
