@charset "utf-8";
/* CSS Document */

/*-------------------------------------------------------------
 *
 *						style_products.css
 *
 *-------------------------------------------------------------*/
 		#mainContents.products				{ padding-bottom: 55px; }
		#mainContents.products .right-870 .f-size90 { font-size: 90%; }

	/* ---------- ---------- ---------- ---------- ----------
	 *						productsSearchArea
	 * ---------- ---------- ---------- ---------- ---------- */
	 	#productsSearchArea					{ max-width: 1000px; margin-left: auto;  margin-right: auto; background: #a78467; box-sizing: border-box; padding: 40px 55px; border-radius: 40px; }
		#productsSearchArea > * 			{ color: #fff; }
		#productsSearchArea h3				{ font-size: clamp(19px, calc(100vw* 22 / 1300), 22px); margin-bottom: 8px; }

		.productsSearch-btnArea 				{ justify-content: space-between; margin-top: 50px; }
		.productsSearch-btnArea .btn > *		{ color: #fff; border-color: #fff; background-color: #a78467; }
		.productsSearch-btnArea .btn			{ margin: 0; width: calc( 100% / 3 - 10px); }
		.productsSearch-btnArea .btn a			{ width: 100%; margin-bottom: 15px; padding-right: 38px; }
		.productsSearch-btnArea .btn a::before	{ background: #fff; }
		.productsSearch-btnArea .btn a::after	{ border-color: #fff; }

		.productsSearch-btnArea .btn a:hover,
		.productsSearch-btnArea .btn.is-active a	{ background: #e5dbd1; color: #a78467; border-color: #a78467; }
		.productsSearch-btnArea .btn a:hover:before,
		.productsSearch-btnArea .btn.is-active a::before	{ background: #a78467; }
		.productsSearch-btnArea .btn a:hover:after,
		.productsSearch-btnArea .btn.is-active a::after	{ border-color: #a78467; }

	/* ---------- ---------- ---------- ---------- ----------
	 *						productsSortArea
	 * ---------- ---------- ---------- ---------- ---------- */
	 	#productsSortArea						{ max-width: 1000px; margin-left: auto;  margin-right: auto; background: #b99d85; box-sizing: border-box; padding: 44px 55px; border-radius: 55px; margin-bottom: 110px; }

		#productsSortArea > .productsSearch-btnArea 				{ margin-top: 0; gap: 15px; }
		#productsSortArea > .productsSearch-btnArea .btn > *		{ color: #a78467; border-color: #a78467; background-color: #fff; }
		#productsSortArea > .productsSearch-btnArea .btn a			{ margin-bottom: 0px; }
		#productsSortArea > .productsSearch-btnArea .btn a::before	{ background: #a78467; }
		#productsSortArea > .productsSearch-btnArea .btn a::after	{ border-color: #a78467; }

		#productsSortArea > .productsSearch-btnArea .btn a:hover,
		#productsSortArea > .productsSearch-btnArea .btn.is-active a	{ background: #e5dbd1; color: #a78467; border-color: #a78467; }
		#productsSortArea > .productsSearch-btnArea .btn a:hover:before,
		#productsSortArea > .productsSearch-btnArea .btn.is-active a::before	{ background: #a78467; }
		#productsSortArea > .productsSearch-btnArea .btn a:hover:after,
		#productsSortArea > .productsSearch-btnArea .btn.is-active a::after	{ border-color: #a78467; }

	/* ---------- ---------- ---------- ---------- ----------
	 *						proList
	 * ---------- ---------- ---------- ---------- ---------- */
		#mainContents .titleArea:not(:first-of-type)  > .kanit-light			{ font-size: clamp(34px, calc(100vw* 46 / 1300), 46px); }
		#mainContents .titleArea:not(:first-of-type)  .kanit-light + .sub-title				{ font-size: clamp(15px, calc(100vw * 16 / 1300), 16px); }

	 	.titleArea + .three-boxList				{ margin-top: 25px; }
	 	.three-boxList + .titleArea				{ margin-top: -90px; }
		.proList section,
		#partnerList section					{ display: flex; flex-direction: column; }
		.proList section h3,
		#partnerList section h3					{ font-size: clamp(18px, calc(100vw* 21 / 1300), 21px); line-height: 1.4; margin-bottom: 5px; }
		.proList section .category				{ font-size: 85%; margin-bottom: 20px; }
		.proList section .category + p:not(.proListImg)	,		
		.proList section .category + p:not(.proListImg)	+ .dlType03	{ margin-bottom: 30px; }
		.proList section .proListImg,
		#partnerList section .partnerLink		{ margin-top: auto; margin-bottom: 0; }
		#mainContents.products p.textCenter img{ width: 100%; height: auto; max-width: fit-content;}


	/* ---------- ---------- ---------- ---------- ----------
	 *						partnerArea
	 * ---------- ---------- ---------- ---------- ---------- */
		#partnerArea					{  }
		#partnerArea > div				{ margin-top: 25px; }
		#partnerArea div.three-boxList p			{ margin: 28px 0 20px; }

		#partnerArea div.three-boxList .partnerLink	{ display: flex; }
		#partnerArea div.three-boxList .partnerLink span	{ display: block; min-width: 50px; }

		#partnerArea div.three-boxList a			{ padding-left: 15px; }
		#partnerArea div.three-boxList a:hover		{ text-decoration: underline; }

		#partnerArea div.three-boxList section:hover	{ background-color: transparent; }

		#partnerArea section .partnerAreaImg	{ margin-top: auto; margin-bottom: 0; }

	/* ---------- ---------- ---------- ---------- ----------
	 *						製品詳細
	 * ---------- ---------- ---------- ---------- ---------- */
	 	.pro-case-caption .right-870			{ margin-left: 40px; }
		.pro-case-caption .right-870 h3			{ font-size: 27px; }
		.pro-case-caption .right-870 p			{ font-size: clamp(15px, calc(100vw* 16 / 890), 16px); }
		.pro-case-caption .right-870 p::before	{ content: attr(data-category); color: #a98667; display: block; margin: -11px 0 10px; font-size: clamp(13px, calc(100vw* 14 / 890), 14px); }

		.products .pro-case-caption + .width1300		{ margin-top: 90px; }
		.proContents							{ margin-top: 100px; }
		.subTitle01Set + .proContents			{ margin-top: 75px; }

		.proPoint_style											{ margin-bottom: 75px; }
		.proPoint_style	> section:not(.width100p)				{ display: flex; justify-content: space-between; margin-bottom: 50px; }						
		.proPoint_style	> section:not(.width100p) > article		{ width: calc( 100% / 2 - 100px); }
		.proPoint_style.threetype	> section > article			{ width: calc( 100% / 3 - 100px); }

		.products .proPoint_style	> section.width100p			{ display: block; width: 100%; margin: 50px auto 20px; }						


		.proPoint_style article span			{ display: block; font-size: clamp(25px, calc(100vw* 33 / 1100), 33px); width: 170px; height: 170px; border-radius: 50%; line-height: 170px; margin: 0 auto; }
		.proPoint_style article h4				{ font-size: clamp(18px, calc(100vw* 20 / 1100), 20px); line-height: 1.4; margin: 15px 0; }	

		.products .subTitle01Set					{ margin-bottom: 75px; }
		/* .products .subTitle01Set:last-child			{ margin-bottom: 0; } */
		.products .subTitle01Set section			{ margin-left: 30px; }
		.products .subTitle01Set section article.colBrown	{ font-size: clamp(17px, calc(100vw* 19 / 1300), 19px); }
		.products .subTitle01Set section article.indent		{ margin-left: 1.3em; }

		.products .subTitle01Set p.textCenter img		{ margin-top: 55px; }
		.products .subTitle01Set p.textCenter.mN img	{ margin-top: 0; }

		/* case 共通 */
		.casepartner					{ border-radius: 40px; padding: 30px 35px; }				

		/* case01 */
		.case01List						{ display: flex; margin-bottom: 120px; }
		.case01List dl					{ padding: 30px; }
		.case01List dl + dl				{ border-left: 1px solid #a98667; }
		.case01List dt					{ width: 107px; margin: 0 auto 25px; color: #fff; font-weight: bold; font-size: 120%; line-height: 1.5; height: 107px; display: flex; justify-content: center; align-items: center; text-align: center; }
		.case01List dt.green			{ background: #54a143; }
		.case01List dt.red				{ background: #d12a27; }
		.case01List dt.blue				{ background: #3b6fc3; }
		.case01List dt.yellow			{ background: #fe9f27; }

		.awardLink01					{ display: block; text-align: center; }
		.awardLink02					{ display: block; text-decoration:underline; margin-top: 20px; font-weight:bold; }
		.awardLink01 object .borderBrown{ color: #a78467; text-decoration:underline; font-weight:bold; }

		/* case02 */
        .case02flex						{ display: flex; flex-wrap: nowrap; align-items: center; margin-top: -15px; }
        .case02flex li:not(:first-child){ margin-left: 30px; }
        .case02flex li img				{width: 120px;}

        .subTitle01Set section.bgGray	{ margin-bottom: 40px; margin-left: 0; }
        .bgGray .case02flex				{ padding: 30px; box-sizing: border-box; justify-content: center; }
        .bgGray .case02flex p:first-child{ margin-right: 100px;}

        .case02flex .textCenter span	{ display: inline-block; margin-bottom: 1em; font-size: 120%; font-weight: 400; }

        .fontRed    					{ color: #C00000; }
        .bgGray     					{ background-color: #f6f3f0; }

		.products .pro_worksArea section		{ margin-left: 0; }
		.products .pro_worksArea h3::after		{ content: attr(data-sama); margin-left: 10px; }
		.products .pro_worksArea span			{ display: block; margin-bottom: 5px; margin-top: 3px; }
		.products .pro_worksArea span::after	{ content: attr(data-works); margin-left: 15px; }

		/* case04 */
		.cose04flex						{ display: flex; justify-content: center; }
		.gap100							{ gap: 100px; }
		.gap43							{ gap: 43px; }

		/* case05 */
		#lpBanner						{ margin: -20px 0 90px; }
		#lpBanner a:hover				{ opacity: 0.8; }
		#lpBanner img					{ width: 100%; max-width: fit-content; }
		.case05_proPoint_style			{ margin-top: 20px; }
		.case05_proPoint_style img		{ width: 100%; height: auto; }


		/* case06 */
		.case06_reason > section + section	{ margin-top: 40px; }
		.cose06flex						{ display: flex; margin-top: 40px;}

		/* case12 */
		.proFlexArea					{ display: flex; }
		.proFlexArea > div				{ margin-left: 50px; }

		/* case13 */
		.cose13flex						{ display: flex; margin-top: 40px; gap: 20px; }

		/* case14 */
		.proTable01						{ margin-top: 40px; border-width:1px 0 0 1px; width:100%; }
		.proTable01,
		.proTable01 *					{ padding: 7px 12px; border-style:solid; border-color:#a98667; }

		table.proTable01 th, table.proTable01 td	{ box-sizing:border-box; vertical-align:top; text-align:left; }

		.proTable01 th					{ background: #ddcfc2; border-width: 0 1px 1px 0; font-weight: normal; }
		.proTable01 td					{ border-width: 0 1px 1px 0; }

		/* case15 */
		.proTable01.proTable02 tr:nth-child(odd)		{ background: #ddcfc2; }
		.proTable01.proTable02 th:first-child	{ width: 46px; box-sizing: border-box; text-align: center; }
		.proTable01.proTable02 th:nth-child(2)	{ width: 215px; box-sizing: border-box; }
		.proTable01.proTable02 th:last-child	{ width: 839px; box-sizing: border-box; }
		.proTable01.proTable02 td:first-child	{ text-align: center; }
		.case1502.proTable02 td					{ background: #fff!important; }

		/* case16 */
		.proTable01.proTable02.wid5 th	{ width: calc(100% / 5); }

		/* case26 */
		.shiori02 h3.tit				{ margin-bottom: 30px; }
		.shiori02 h3.tit span 			{ display:inline-block; font-size: clamp(18px, calc(100vw* 20 / 1300), 20px); line-height:1.4; color:#FFF; padding:0.4em 1.2em; background:#a98667; border-radius:40px; }
		.shiori02 h4.customizeCap 		{ font-size: clamp(18px, calc(100vw* 20 / 1300), 20px); margin-bottom:30px; margin-top: 20px; }
		.shiori02 ul.customize 			{ width:auto; padding:30px 10px 30px 10px; border-radius:20px; margin-bottom:80px; display:flex; }
		.shiori02 ul.customize li 		{ width:calc(100% / 5); border-right:1px dotted #a98667; }
		.shiori02 ul.customize li:last-child { border-right:none; }
		.shiori02 ul.customize li img 	{ display:block; width:70px; margin:0 auto 20px auto; }
		.shiori02 ul.customize li p 	{ text-align:center; line-height:1.6; }

		.shiori02 div.support 			{ display:flex; }
		.shiori02 div.support div.step 	{ width:32%; margin-right:2%; }
		.shiori02 div.support div.step:last-child 		{ margin-right:0; }
		.shiori02 div.support div.step div.stepNumber 	{ width:100%; height:46px; background:#a98667; position:relative; }
		.shiori02 div.support div.step div.stepNumber:before { position:absolute; content:""; width: 0; height: 0; border-style: solid; border-width: 23px 0 24px 19px; border-color: transparent transparent transparent #a98667; top:0; right:-20px; }
		.shiori02 div.support div.step:nth-child(2) div.stepNumber 	{ background:#a98667; }
		.shiori02 div.support div.step:nth-child(2) div.stepNumber:before 	{ border-color: transparent transparent transparent #a98667; }
		.shiori02 div.support div.step:nth-child(3) div.stepNumber 			{ background:#a98667; }
		.shiori02 div.support div.step:nth-child(3) div.stepNumber:before 	{ display:none; }
		.shiori02 div.support div.step div.stepNumber p 			{ font-size:18px; color:#FFF; line-height:44px; text-align:center; }
		.shiori02 div.support div.step div.stepNumber p br 			{ display:none; }
		.shiori02 div.support div.step div.detail 					{ padding:25px; box-sizing: border-box; }
		.shiori02 div.support div.step div.detail img.icon 			{ display:block; width:80px; margin:0 auto 15px auto; }
		.shiori02 div.support div.step div.detail h4 				{ font-size:18px; text-align:center; line-height:1.5; margin-bottom:20px; }
		.shiori02 div.support div.step div.detail p.item 			{ margin-bottom:10px; }
		.shiori02 div.support div.step div.detail ol 				{ position: relative; margin: 0; padding: 0 0 0 6px; list-style: none; counter-reset: li; }
		.shiori02 div.support div.step div.detail ol li 			{ position: relative; margin: 12px 20px 0 24px; padding: 0; line-height: 1.5; }
		.shiori02 div.support div.step div.detail ol li:before 		{ position: absolute; counter-increment: li; content: counter(li) ""; left: -34px; top: 0; color: #fff; width: 24px; height: 24px; font-size: 14px; text-align: center; border-radius: 100%; box-sizing: border-box; line-height: 1; background: #a98667; padding: 5px 0; }

		.shiori03 div.sceneBox										{ width:auto; padding:30px 40px 30px 30px; border-radius:20px; margin-bottom:50px; display:flex; flex-wrap:wrap; align-items: center; }
		.shiori03 div.sceneBox div.left	 							{ width:30%; margin-right:5%; }
		.shiori03 div.sceneBox div.left p.num 						{ font-size:20px; text-align:center; }
		.shiori03 div.sceneBox div.left h3 							{ font-size:18px; line-height:1.6; text-align:center; margin-bottom:15px; }
		.shiori03 div.sceneBox div.left img 						{ display:block; width:160px; border-radius:50%; margin:0 auto; }
		.shiori03 div.sceneBox div.right 							{ width:65%; }

		/* case29 */
		.case29 .youtube													 { text-align: center; }
		.case29 .threetype section.section_point 							 { flex-wrap: wrap; margin: 0 auto; gap: 50px; justify-content: center; }
		.case29 .threetype section.section_point > article 					 { width: calc( 100% / 3 - 40px); }
		.case29 .threetype section.section_point > article p img 			 { width: 100%; height: auto; }
		.case29_effect section 												 { margin-bottom: 20px; }
		.case29_effect p:not(:has(img)) 									 { margin-top: 30px; }
		.case29 figure														 { margin-bottom: 30px; }
		.case29 figure figcaption											 { font-size: 110%; }
		.case29 figure img													 { width: 100%; height: auto; }

		.case29_flow 														 { flex-direction: column; gap: 30px; position: relative; width: fit-content; margin: 50px auto; }
		.case29_flow div													 { display: flex; gap: 50px; margin-left: 50px; }
		.case29_flow div.rect												 { border: 1px solid #a98667; z-index: 100; width: fit-content; position: relative; box-sizing: border-box; padding: 10px; display: block; }
		.case29_flow div.rect span 											 { display: block; font-size: 130%; }
		.case29_flow div.rect span + span									 { color: #002060; }
		.case29_flow div.rect::before										 { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: #fff; z-index: -1; }
		.case29_flow div.rect div 											 { z-index: -2; position: absolute; border: 1px solid #002060; border-right: none; width: 75px; height: 315px; top: 50%; left: -27px; margin-left: 0; }
		.case29_flow dt 													 { display: block; font-size: clamp(25px, calc(100vw* 33 / 1100), 20px); width: 100px; height: 100px; border-radius: 50%; line-height: 100px; position: relative; background-color: #fff; z-index: 100; }
		.case29_flow div dt::before 										 { content: ""; position: absolute; border: 1px solid #a98667; top: 100%; left: 50%; transform: translateX(-50%); height: 100%; z-index: 0; }
		.case29_flow div:first-of-type dt::before 							 { height: 500px; }
		.case29_flow div:last-of-type dt::before 							 {display: none; }
		/* .case29_flow div:last-of-type dt::before 							 { border: 3px solid white; height: 130px; top: 101%; } */
		.case29_flow dd 													 { width: calc(100% - 150px); }
		.case29_flow dd span												 { display: flex; font-size: 130%; margin-bottom: 10px; }

		/* case31 */
		.flexBox31						{ display: flex; flex-wrap: wrap; justify-content: space-between; }
		.tsumabirakaTitle02				{ border: 4px solid #a98667; border-radius: 10px; width: calc(100% / 2 - 20px); box-sizing: border-box; display: flex; flex-direction: column; }
		.tsumabirakaTitle02 > p			{ background: #a98667; border-radius: 3px 3px 0 0; padding: 5px; font-weight: bold; }
		.tsumabirakaTitle02 .inner		{ padding: 10px; }
		.tsumabirakaTitle02 .inner p	{ margin-bottom: 10px; }
		.products .subTitle01Set .tsumabirakaTitle02 .inner p.textCenter img	{ margin-top: 0; }
		
		/* case32 */
		.flexBox32 .tsumabirakaTitle02	{ width: calc(100% / 4 - 15px); border-color: #a98667; border-style: solid; border-width: 4px 0 0 0; }
		.flexBox32 .tsumabirakaTitle02 .inner		{ display: flex; flex-direction: column; height: 100%; box-sizing: border-box; border-color: #a98667; border-style: solid; border-width: 0 4px 4px 4px; border-radius: 0 0 10px 10px; }
		.flexBox32 .tsumabirakaTitle02 .inner p		{ margin-top: auto; }

		/* case34 */
		.case34 .merit section h4							{ font-size: clamp(18px, calc(100vw* 20 / 1100), 20px); line-height: 1.4; margin: 15px 0; }
		.case34 .merit section h4 + p						{ margin: 0 auto; } 
		.case34 .merit section:first-of-type h4 + p			{ width: 500px; }
		.case34 .merit section:nth-of-type(2) h4 + p		{ width: 750px; }
		.case34 #inspectionItem								{ padding-top: 140px; margin-top: -140px; }
		.case34 table, .case34 table *						{ border-color: #fff; }
		.case34_caption										{ caption-side: bottom; text-align: right; }
		.case34 section p.textCenter img					{ margin-bottom: 70px; }
		.case34 section:last-of-type p.textCenter img 		{ margin-bottom: 0; }
		.case34 #inspectionItem table thead * ,
		.case34 #inspectionItem table tbody *				{ text-align: center; }
		.case34 #inspectionItem table thead th 				{ background: #a98667; color: #fff; }
		.case34 #inspectionItem table tbody td				{ background: #f3f2f2; }
		.case34 .proFlexArea.resultReport					{ align-items: center; justify-content: space-evenly;  }
		.case34 .proFlexArea.resultReport section			{ display: flex; flex-direction: column; justify-content: space-between; gap: 30px; }
		.case34 .proFlexArea.resultReport h5				{ padding-left: 5px; }
		.case34 .resultReport_col1							{ border-left: 8px solid #B4C7E7; }
		.case34 .resultReport_col2							{ border-left: 8px solid #F8CBAD; }
		.case34 .resultReport_col3							{ border-left: 8px solid #FFE699; }
		.case34 .resultReport_col4							{ border-left: 8px solid #C5E0B4; }
		.case34 .proFlexArea.sample							{ justify-content: space-between; }
		.case34 .proFlexArea > div							{ margin-left: initial; }

		.case34_modal 										{ align-items: center; animation: modalFadeIn 0.3s; background-color: rgba(0,0,0,0.8); display: none; height: 100%; inset: 0; justify-content: center; overflow: auto; position: fixed; width: 100%; z-index: 1000; }
		.case34_modal img 									{ max-height: 90%; max-width: 90%; object-fit: contain; }

		/* case39 */
		.award01											{ color: #a78467; font-weight:bold; text-align: center; }
		.marginT20											{ margin-top: 20px; }
		.case39flex											{ display: flex; margin-top: 40px; gap: 20px;}
		section.flexcontents.width1100						{ display: flex; justify-content: space-evenly; margin-bottom: 50px; }

		@keyframes modalFadeIn {
			from { opacity: 0; }
			to { opacity: 1; }
		}

		@keyframes modalFadeOut {
			from { opacity: 1; }
			to { opacity: 0; }
		}



/*-------------------------------------------------------------
 *
 *						style_products.css(ver.SP)
 *
 *-------------------------------------------------------------*/

	@media screen and (max-width: 1390px) {
		.products .pro_worksArea.three-boxList > div { width: 406px; }
	}

 
	@media screen and ( max-width:1300px ) {
		.proFlexArea > *				{ width: calc(100% / 2 - 20px); }
		.proFlexArea img				{ width: 100%; max-width: fit-content; height: auto; }
	}

	@media screen and (max-width: 1025px) { .case29_flow div.rect div { height: 320px; } }

	@media screen and ( max-width:1000px ) {
	/* ---------- ---------- ---------- ---------- ----------
	 *				productsSearchArea / productsSortArea
	 * ---------- ---------- ---------- ---------- ---------- */
		.productsSearch-btnArea .btn			{ width: calc( 100% / 2 - 10px); line-height: 1.2; }


	/* ---------- ---------- ---------- ---------- ----------
	 *						製品詳細
	 * ---------- ---------- ---------- ---------- ---------- */
		.proPoint_style > section:not(.width100p) > article	{ width: calc(100% / 2 - 50px); }
		.proPoint_style.threetype > section > article	{ width: calc(100% / 3 - 50px); }

		/* case04 */
		.cose04flex								{ flex-direction: column; gap: 30px;}

		/* case06 */
		.cose06flex								{ flex-direction: column; }

		/* case13 */
		.cose13flex								{ flex-direction: column; }

		/* case39 */
		.case39flex								{ flex-direction: column; }
	}

	@media screen and (max-width: 959px) { .case29_flow div.rect div { height: 330px; } }
	@media screen and ( max-width:767px ) {

	/* ---------- ---------- ---------- ---------- ----------
	 *			productsSearchArea / productsSortArea
	 * ---------- ---------- ---------- ---------- ---------- */
		#productsSearchArea,
		#productsSortArea						{ padding: 30px; }

		.three-boxList + .titleArea				{ margin-top: -20px; }

	/* ---------- ---------- ---------- ---------- ----------
	 *						製品詳細
	 * ---------- ---------- ---------- ---------- ---------- */

		.pro-case-caption .right-870			{ margin-left: 0; }
		.proPoint_style > section:not(.width100p)				{ display: block; }
		.proPoint_style > section:not(.width100p) > article,
		.proPoint_style.threetype > section > article		{ width: 100%; margin-bottom: 50px; }

		.products .subTitle01Set section		{ margin-left: 0; }

		.proList section h3,
		#partnerList section h3					{ font-size: 22px; }

		#mainContents.products p.textCenter img, 
		#mainContents.products.case01 p.textCenter img	{ width: 100%; height: auto; margin-top: 25px; max-width: fit-content; }

		/* case01 */
		.case01List								{ display: block; }
		.case01List dl + dl						{ border-left: 0; border-top: 1px solid #a98667; }

		/* case02 */
		.bgGray .case02flex p:first-child		{ margin-right: 30px; }
		.bgGray .case02flex p:first-child img	{ width: 100%; }

		/* case12 */
		.proFlexArea							{ display: block; }
		.proFlexArea > *						{ width: 100% }
		.proFlexArea p + div					{ margin-left: 0; margin-top: 40px;}

		/* case16 */
		.proTable01								{ word-break: break-all;}

		/* case26 */
		.shiori02 ul.customize 					{ width:auto; max-width:320px; margin:0 auto; padding:10px 25px; margin-bottom:60px; flex-wrap:wrap; }
		.shiori02 ul.customize li 				{ width:100%; border-right:none; border-bottom:1px dotted #a98667; padding:25px 0; }
		.shiori02 ul.customize li:last-child 	{ border-bottom:none; }

		.shiori02 div.support 					{ max-width:320px; flex-wrap:wrap; }
		.shiori02 div.support div.step 			{ width:100%; margin-right:0; display:flex; align-items: center; margin-bottom:20px; }
		.shiori02 div.support div.step:last-child { margin-right:0; }
		.shiori02 div.support div.step div.stepNumber 	{ width:40px; height:100%; align-self: center; }
		.shiori02 div.support div.step div.stepNumber p { line-height:1; padding-top:85px; }
		.shiori02 div.support div.step div.stepNumber p br 		{ display:block; }
		.shiori02 div.support div.step div.stepNumber:before 	{ border-width: 19px 20px 0 19px; border-color: #a98667 transparent transparent transparent; top:auto; bottom:-20px; right:auto; left:0; }
		.shiori02 div.support div.step:nth-child(2) div.stepNumber:before 	{ border-color: #a98667 transparent transparent transparent; }
		.shiori02 div.support div.step div.detail { width:calc(100% - 40px); padding:30px 20px; }
		.shiori02 div.support div.step div.detail img.icon 		{ width:60px; }
		.shiori02 div.support div.step div.detail h4 			{ font-size:16px; margin-bottom:15px; }
		.shiori02 div.support div.step div.detail p.item 		{ margin-bottom:5px; }
		.shiori02 div.support div.step div.detail ol	 		{ position: relative; margin: 0; padding: 0 0 0 6px; list-style: none; counter-reset: li; }
		.shiori02 div.support div.step div.detail ol li 		{ position: relative; margin: 12px 0 0 20px; padding: 0; line-height: 1.5; }
		.shiori02 div.support div.step div.detail ol li:before 	{ left: -28px; width: 20px; height: 20px; font-size: 12px; line-height: 1; padding: 5px 0; }

		.shiori03 div.sceneBox div.left			{ float: none; width: 100%; margin-right: 0; }
		.shiori03 div.sceneBox div.right		{ float: none; width: 100%; margin-top: 25px; }

		/* case29 */
		.case29 .youtube 													{ aspect-ratio: 16 / 9; width: 100%; }
		.case29 .youtube  iframe											{ width: 100%; height: 100%; }
		.case29 .threetype section.section_point > article 					{ width: 100%; text-align: center; }
		.case29 .threetype section.section_point > article p:first-of-type 	{ text-align: left; display: inline-block; }
		#mainContents.products.case29 .subTitle01Set p.textCenter.mN img	{ margin-top: 0; }
		.case29 figure img													{ max-width: fit-content; }
		.case29_flow div 													{ gap: 30px; }
		.case29_flow div.rect div 											{ height: 360px; }
		.case29_flow div dt::before											{ height: 250px; }
		.case29_flow div:last-of-type dt::before 							{ border: 3px solid white; height: 130px; top: 101%; display: initial; }

		/* case31 */
		.flexBox31								{ display: block; }
		.tsumabirakaTitle02						{ width: 100%; }
		.tsumabirakaTitle02	+ .tsumabirakaTitle02					{ margin-top: 20px; }

		/* case32 */
		.flexBox32 .tsumabirakaTitle02			{ width: 100%; }
			
		/* case34 */
		.case34 .merit section h4 + p		{ width: 100% !important; }
		.case34_caption						{ text-align: center; }
		.case34 .proFlexArea.resultReport	{ display: flex; flex-direction: column; gap: 50px; }



	}			

	@media screen and ( max-width: 671px ) { .case29_flow div.rect div { height: 375px; } }
	@media screen and ( max-width: 621px ) { .case29_flow div.rect div { height: 390px; } }
	@media screen and ( max-width: 510px ) { .case29_flow div.rect div { height: 410px; } }

	@media screen and ( max-width:499px ) {
		/* ---------- ---------- ---------- ---------- ----------
	 *		productsSearchArea / productsSortArea
	 * ---------- ---------- ---------- ---------- ---------- */
		.productsSearch-btnArea .btn			{ width: 100% }
	 
		#productsSearchArea,
		#productsSortArea						{ padding: 30px 15px; }
		.productsSearch-btnArea .btn a			{ padding-left: 16px; font-size: 15px; }

	}

	@media screen and ( max-width: 476px ) { .case29_flow div.rect div { height: 425px; } }
	@media screen and ( max-width: 466px ) { .case29_flow div.rect div { height: 455px; } }
	@media screen and ( max-width: 425px ) {
		.case29_flow div.rect div					{ height: 475px; }
		.case29_flow div:first-of-type dt::before 	{ height: 1000px; }
	}
	@media screen and ( max-width: 389px ) {
		.case29_flow div.rect div 					{ height: 540px; }
		.case29_flow div dt::before 				{ height: 300px; }
	}
	@media screen and ( max-width: 366px ) { .case29_flow div.rect div { height: 575px; } }
	@media screen and ( max-width: 350px ) {
		.case29_flow div.rect div 					{ height: 640px; }
		.case29_flow div:first-of-type dt::before	{ height: 1900px; }
		.case29_flow div:last-of-type dt::before	{ height: 400px; }
	}
	@media screen and ( max-width: 340px ) {
		.case29_flow div.rect div 					{ height: 700px; }
		.case29_flow div:last-of-type dt::before 	{ height: 500px; }
	}