@charset "utf-8";




/* =======================================================================================
	COMMON
======================================================================================= */

/*.bg_Area{background:url("../images/share/texture_bg02.jpg") center center;}*/

/* =======================================================================================
	PAGE 
======================================================================================= */
	

/* ------------------------------------------------------------------------
 mainVisualWrap
------------------------------------------------------------------------ */
	.mainVisualWrap::after {
		content: "";
		display: block;
		height: 10px;
		width: 100%;
		background:linear-gradient(to right, #af995e 0%, #faf4e1 50%, #af995e 100%); 
	}
@media screen and (max-width: 1200px) {
	.mainVisualWrap {
		margin-top:62px;
	}
}



/*  mainVisual
------------------------------------------------------------------------ */
	.mainVisual {
		position: relative;
		width:100%;
		max-width: 1920px;
		margin: 0 auto;
		overflow: hidden;
	}
	.mainVisual img {
		max-width:100%;
	}
	.mainVisual .gaikanBox .imgcapkeep {
		right: auto;
		left: 0
	}



/*txtBox-------------------------*/
	.mainVisualWrap .mainVisual .txtBox {
		position: absolute;
		z-index: 2;
	}
	.mainVisualWrap .mainVisual .txtBox > p {
		position: absolute;
		top:0;
		left:0;
		z-index: 0;
		width: 100%;
	}
	.mainVisualWrap .mainVisual .txtBox p > span {
		position: relative;
		display: inline-block;
		/*width: 13%;*/
		padding:12% 0;
	}
	.mainVisualWrap .mainVisual .txtBox p > span::before,
	.mainVisualWrap .mainVisual .txtBox p > span::after {
		position: absolute;
		top:0;
		content:"";
		display:block;
		height:100%;
		width:1px;
		background:#000;
		box-shadow: 1px 0px 0px 0px rgba(255, 255, 255, 0.3);
		transform: scaleY(0);
		animation: txtLine 2s ease 2.8s forwards;  
	}		
	.mainVisualWrap .mainVisual .txtBox p > span::before {
		left:-30%;
		transform-origin: top;
	}
	.mainVisualWrap .mainVisual .txtBox p > span::after {
		right:-30%;
		transform-origin: bottom;
	}
@media screen and (min-width: 736.02px) {
	.mainVisualWrap .mainVisual .txtBox {
		top: clamp(50px, (50 / 1200 * 100vw), 80px);
		right: clamp(70px, (70 / 800 * 100vw), 200px);
		width: 9.636%;
	}
}
@media screen and (max-width: 1050px) { 
	.mainVisualWrap .mainVisual .txtBox {
		/*right: clamp(100px, (100 / 1050 * 100vw), 160px);*/
	}
}
@media screen and (max-width: 736px) { 
	.mainVisualWrap .mainVisual .txtBox {
		top: 7%;
		left: 50%;
		transform: translateX(-50%);
		width: 22%;
	}
}


/*txt animation-------------------------*/
	.mainVisualWrap .mainVisual.js_showTarget .txtBox [class*="txt0"] {
		opacity: 0;
		transform:translateY(-3%);
	}
	.mainVisualWrap .mainVisual.js_showTargetAnimate .txtBox [class*="txt0"] {
		opacity: 1;
		transform:translateY(0%);
		transition: all 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0s;
	}
	.mainVisualWrap .mainVisual.js_showTargetAnimate .txtBox .txt01 { transition-delay: 1.2s}
	.mainVisualWrap .mainVisual.js_showTargetAnimate .txtBox .txt02 { transition-delay: 1.8s}

@keyframes txtLine {
  0% {
		opacity: 0;
		transform: scaleY(0);
		
	}
  100% {
		opacity: 1;
		transform: scaleY(1);
		transform-origin: top;
	}
}




/*gaikanBox-------------------------*/
	.mainVisualWrap .mainVisual .gaikanBox  {
		overflow: hidden;
		width:69.02%;
		max-width: 1325px;
		position: absolute;
		bottom: clamp(40px, (40 / 1050 * 100vw), 100px);
		left: 0;
		z-index: 2;
	}
@media screen and (max-width: 1050px) {
	.mainVisualWrap .mainVisual .gaikanBox  {
		bottom: clamp(20px, (20 / 1050 * 100vw), 60px);
	}
}
@media screen and (max-width: 736px) { /*{SP}*/
	.mainVisualWrap .mainVisual .gaikanBox  {
		width:100%;
		max-width: none;
		bottom: 20px;
	}	
}

/*gaikanBox animation-------------------------*/
	.mainVisualWrap .mainVisual.js_showTarget .gaikanBox {
		opacity: 0;
	}
	.mainVisualWrap .mainVisual.js_showTargetAnimate .gaikanBox {
		animation: stretch 1.5s ease 0s forwards;
	}
@keyframes stretch {
  0% {
    opacity: 0;
	clip-path: inset(0 100% 0 0);
  }
  100% {
    opacity: 1;
	clip-path: inset(0 0 0 0);
  }
}
	.mainVisualWrap .mainVisual.js_showTarget .gaikanBox .pic {
		opacity: 0;
	}
	.mainVisualWrap .mainVisual.js_showTargetAnimate .gaikanBox  .pic{
		animation: bg 2.5s ease 0s forwards;
	}

@keyframes bg {
	0% {
		transform: scale(1.2);
		filter: blur(3px) brightness(1.8);
		opacity: 0;
	}
	30% {
		opacity: 1;
	}
	100% {
		transform: scale(1);
		filter: blur(0) brightness(1);
		opacity: 1;
	}
}





/*bgBox-------------------------*/

	.mainVisualWrap .mainVisual.js_showTarget .bgBox::before {
		
		transition: opacity 3.5s ease 0s;
	}
	.mainVisualWrap .mainVisual.js_showTargetAnimate .bgBox::before{
		content: "";
		display: block;
		position: absolute;
		width: 100%;
		height: 100%;
		z-index: 1;
		background: linear-gradient(35deg,rgba(44, 76, 64,0) 0%, rgba(44, 76, 64, 0.36) 30%,rgba(44, 76, 64, .3) 38%,rgba(44, 76, 64, 0.2) 50%,rgba(199, 255, 200, 0.1) 60%,rgba(199, 255, 200, 0) 100%);/*グラデーションを定義*/
		background-size: 150% 150%;
		animation: bggradient 14s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0s infinite;
	}

@keyframes bggradient{
	0% { background-position: 0% 50%;  }
	30% {  background-size: 300% 300%;}
	60% {  background-position: 100% 50%; /*background-size: 300% 300%;*/}
	100% {  background-position: 0% 50%; }
}
	







/* ------------------------------------------------------------------------
 conceptSection 
------------------------------------------------------------------------ */
	.conceptSection {
		position: relative;
		overflow: hidden;
		min-height:100lvh;
	}
	.conceptSection .sectionBg_Inner {
		position: absolute;
		top: 0;
		width: 100%;
		height: 100%;
		clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%); 
		z-index: 0;
		background: #fff;
	}
	.conceptSection .sectionBg_Inner::before {
		content: '';
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100lvh;
		background-image: url(../images/index/concept_bg.jpg);
		background-position: bottom center;
		background-size: cover;
		background-repeat: no-repeat;
		opacity: 0;
		transform: scale(1.5);
	}
	.conceptSection .sectionBg_Inner.js_showTargetAnimate::before {
		animation: concept 4s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0s forwards;
	}
	@keyframes concept {
	  0% { 
	  	opacity: 1; 
		transform: scale(1.5);
		}
	  100% { 
	  	opacity: 1;
		transform: scale(1);
		}
	}

	.bukkenConceptBox {
		position: relative;
		color:#fff;
		display: flex;
		flex-wrap: wrap;
		justify-content:space-around;
		align-items: center;
		width: 100%;
		margin: 0 auto;
		padding:clamp(250px, (250 / 1200 * 100vw), 380px)  4%;
	}
	.bukkenConceptTxtBox {
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
	}
	.bukkenConceptTxtBox .text-combine { /* 縦中横 */
		-webkit-text-combine: horizontal;
		-ms-text-combine-horizontal: all;
		text-combine-upright: all;
		margin-bottom: 0.25em;
		text-align: center;
	}
	.bukkenConceptTtl {
		--M-fluidFontSize-max-fontsize: 60;
		--M-fluidFontSize-min-fontsize: 46;/*36*/
		--M-fluidFontSize-max-viewport: 1200;
		--M-fluidFontSize-min-viewport: 900;
		--M-fluidFontSize-fontSize: clamp( var(--M-fluidFontSize-min-fontsize) * .1rem, (var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - (var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport))), var(--M-fluidFontSize-max-fontsize) * .1rem );
		min-height: 0.001vw;				/* for safari | font-sizeにclamp()使用時必須 */
		font-size: var(--M-fluidFontSize-fontSize);
		font-family: var(--site-font_family-serif);

		line-height: 1.5;
		text-shadow: 0 0 2px rgba(0,0,0,0.5), 0 0 5px rgba(0,0,0,0.8), 0 0 10px rgba(0,0,0,0.7);
		margin-left: 1em;
		letter-spacing: 0.2em;
		word-break: keep-all; /* タブレットのランドスケープモード等で改行されないように */
	}
	.bukkenConceptTxt {
		--M-fluidFontSize-max-fontsize: 18;
		--M-fluidFontSize-min-fontsize: 15;
		--M-fluidFontSize-max-viewport: 1200;
		--M-fluidFontSize-min-viewport: 900;
		--M-fluidFontSize-fontSize: clamp( var(--M-fluidFontSize-min-fontsize) * .1rem, (var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - (var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport))), var(--M-fluidFontSize-max-fontsize) * .1rem );
		min-height: 0.001vw;				/* for safari | font-sizeにclamp()使用時必須 */
		font-size: var(--M-fluidFontSize-fontSize);
		font-family: var(--site-font_family-serif);

		line-height: 2;
		text-shadow: 0 0 2px rgba(0,0,0,0.7), 0 0 5px rgba(0,0,0,0.9), 0 0 6px rgba(0,0,0,0.6);
		letter-spacing: 0.17em;
	}
	.bukkenConceptTxt .txtBox > [class*="row"] {
		display: block;
		margin-right: 1.4em;
	}
	.bukkenConceptPic .picBox{
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.bukkenConceptPic p {
		position: relative;
	}
	.bukkenConceptPic .imgcapkeep {
		bottom: 0;
		left: 0;
		right: auto;
		color: #fff;
		background: rgba(123,89,55, .6);
		padding: 0.25em 0.5em;
	}

@media screen and (min-width: 1000.02px) {
	.bukkenConceptPic {
		order: -1;
		width: 25.702%;
	}
	.bukkenConceptPic .picBox > *{
		width: 49%;
	}
	.bukkenConceptPic .picBox p:nth-child(2){
		margin-top: 30%;
	}
	.bukkenConceptPic .picBox p:nth-child(3){
		margin-top: -17%;
		margin-left: 9%;
	}
	.bukkenConceptTxt sup {
	  right: -.5em;
		top:0;
	}
}
@media screen and (max-width: 1400px) { /*{belowTB}*/
		.bukkenConceptTxt .txtBox > [class*="row"] {
			margin-right: 1em;
		}
	  .bukkenConceptPic {
		width: 38%;
	  }
}
@media screen and (max-width: 1000px) { 
	.bukkenConceptBox {
		justify-content: flex-start;
		padding: clamp(150px, (150 / 736 * 100vw), 250px) 8%;
	}
	.bukkenConceptTxtBox {
		-ms-writing-mode: lr-tb;
		writing-mode: horizontal-tb;
		width: 100%;
		text-align: center;
	}
	.bukkenConceptTxtBox .text-combine { /* 縦中横 */
		margin-bottom: 0;
	}
	.bukkenConceptTtl {
		margin-bottom: 1em;
		margin-left: 0;
		word-break: keep-all; /* 解除 */
	}
	.bukkenConceptTxt {
		letter-spacing: 0.08em;
	}
	.bukkenConceptTxt .txtBox > [class*="row"] {
		margin-right: 0;
	}
	.bukkenConceptPic {
		width: 85%;
		margin: 5em auto 0;
	}
	.bukkenConceptPic .picBox > *{
		width: 32%;
	}
	.bukkenConceptPic .picBox p:nth-child(2){
		margin-top: 6%;
	}

}

@media screen and (max-width: 736px) {
	.bukkenConceptPic {
		width: 100%;
	}	
}
@media screen and (max-width: 480px) { /*{SPs}*/
	.bukkenConceptTxt .txtBox > [class*="row"] {
		text-align: justify;
		text-justify: inter-ideograph; /* for IE */
	}
	.bukkenConceptTxt .txtBox .bl,
	.bukkenConceptTxt .txtBox .inbl {
		display: inline!important;
	}
	.bukkenConceptPic .picBox > *{
		width: 44%;
	}
	.bukkenConceptPic .picBox p:nth-child(2){
		margin-top: 30%;
		margin-left: auto;
	}
	.bukkenConceptPic .picBox p:nth-child(3){
		margin-top: -19%;
		margin-left: 8%;
	  }
}







/* ------------------------------------------------------------------------
 meritSection
------------------------------------------------------------------------ */
	.meritSection {
		padding: 0 0 10px;
		background-color: rgba(0,0,0,0.05);
		color: #282828;
	}
	.meritSection .contbox {
		width: 95%;
	}
	.meritSection .meritBox  {
		display: flex;
		align-items: center;
		--M-fluidFontSize-max-fontsize: 22;
		--M-fluidFontSize-min-fontsize: 20;
		--M-fluidFontSize-max-viewport: 1920;
		--M-fluidFontSize-min-viewport: 1050;
		min-height: 0.001vw; /* for safari | font-sizeにclamp()使用時必須 */
		font-size: clamp(
			calc(var(--M-fluidFontSize-min-fontsize) * .1rem),
			calc(calc(var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - calc(var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport)))),
			calc(var(--M-fluidFontSize-max-fontsize) * .1rem)
		);
		font-family: var(--site-font_family-serif);
		line-height: 1.4;
		padding:10px 0;
        text-align: center;
	}
	.meritSection .meritBox .txtColor {
		color: rgba(var(--site-themeColor-accent_1), 1);
	}	
	.meritSection .meritBox .f500 {
		font-weight: 500;
	}
	.meritSection .meritBox small {
		font-size: 1.2rem;
	}	
	.meritSection  .slash {
		position: relative;
		display: block;
		margin:0 0;
		width: 30px;
	}
	.meritSection .slash::after {
		position: absolute;
		content: "";
		top: 50%;
		left: 0%;
		width: 1px;
		height: 40%;
		background:rgba(0,0,0,0.56);
		border-radius: 3px;
		transform: rotate(45deg) translateY(-50%);
		box-shadow: 1px 1px 0px #fff;
	}
	.meritSection .meritBox .jp {
		line-height: 1.45;
	}
	.meritSection .meritBox .en{
		font-family: var(--site-font_family-en_1);
		color: rgba(var(--site-themeColor-accent_1), 1);
		line-height: 1;
	}
	.meritSection .meritBox .kana {
		letter-spacing: -.05em;
		margin-right: .05em;
	}

@media screen and (max-width: 1050px) {
	.meritSection .meritBox {
		--M-fluidFontSize-max-fontsize: 22;
		--M-fluidFontSize-min-fontsize: 18;
		--M-fluidFontSize-max-viewport: 1050;
		--M-fluidFontSize-min-viewport: 480;
	}
}	
@media screen and (max-width: 736px) { /*{SP}*/

}	





/* meritWrap01
--------------------------------------*/
	.meritSection .meritWrap01 {
		display: flex;
		justify-content:space-between;
	}

@media screen and (max-width: 1050px) {
	.meritSection .meritWrap01 {
		display: block;
	}
	.meritSection .meritWrap01 .meritBox {
		display: block;
		position: relative;
		width: 100%;
		text-align: center;
		padding: 15px 0;
	}
	.meritSection .meritWrap01 .meritBox::after {
		content:"";
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		text-align: center;
		width:60px;
		height:1px;
		background: rgba(0,0,0,.5);
		box-shadow: 1px 1px 0px #fff;
	}
	.meritSection .meritWrap01 .meritBox:last-of-type::after {
		display: none;
	}

	.meritSection .meritWrap01 .slash {
		display: none;
	}
}	
	
	



/* meritWrap02
--------------------------------------*/
	.meritWrap02{
		display: block;
		border-top: 1px dotted #000;
		width: 95%;
		margin: 0 auto;
	}
	.meritWrap02 .meritBox{
		display: block;
		text-align: center;
		--M-fluidFontSize-max-fontsize: 25;
		--M-fluidFontSize-min-fontsize: 22;
		--M-fluidFontSize-max-viewport: 1920;
		--M-fluidFontSize-min-viewport: 1050;
		letter-spacing: 0.08em;
	}

	.meritWrap02 .en {
		font-family: var(--site-font_family-en_1);
		color: rgba(var(--site-themeColor-accent_1), 1);
	}

@media screen and (max-width: 736px) { /*{belowTBs}*/
	.meritSection{
		padding: 5px 0 15px;
	}
	.meritWrap02 .meritBox{
		--M-fluidFontSize-max-fontsize: 22;
		--M-fluidFontSize-min-fontsize: 18.5;
		--M-fluidFontSize-max-viewport: 1050;
		--M-fluidFontSize-min-viewport: 480;
		line-height: 1.4;
	}

}








/* ------------------------------------------------------------------------
 informationSection
------------------------------------------------------------------------ */

	.informationSection .subTxt {
		--M-fluidFontSize-max-fontsize: 14;
		--M-fluidFontSize-min-fontsize: 12;
		--M-fluidFontSize-max-viewport: 1920;
		--M-fluidFontSize-min-viewport: 736;
		min-height: 0.001vw; 
		font-size: clamp(
			calc(var(--M-fluidFontSize-min-fontsize) * .1rem),
			calc(calc(var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - calc(var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport)))),
			calc(var(--M-fluidFontSize-max-fontsize) * .1rem)
		);
		line-height: 1.8;
	}





/* ------------------------------------------------------------------------
 entryMeritSection
------------------------------------------------------------------------ */
	.entryMeritSection .featuredContent02{
		padding: var(--site-marpad-M) 0;
	}
	.entryMeritSection .entryMeritBox{
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		color: rgba(var(--site-themeColor-accent_2), 1);
		margin-top: var(--site-marpad-S);
	}
	.entryMeritSection .entryMeritBox > *{
		width: 38%;
		margin: 0 20px;
		border-radius:10px;
		padding: 2em 1.5em;
		position: relative;
	}
	.entryMeritSection .entryMeritItem{
		border: 1px solid rgba(var(--site-themeColor-accent_2), 1); 
	}
	.entryMeritSection .entryMeritItem .ja {
		--M-fluidFontSize-max-fontsize: 15;
		--M-fluidFontSize-min-fontsize: 14;
		--M-fluidFontSize-max-viewport: 1600;
		--M-fluidFontSize-min-viewport: 1000;
		min-height: 0.001vw; /* for safari | font-sizeにclamp()使用時必須 */
		font-size: clamp(
			calc(var(--M-fluidFontSize-min-fontsize) * .1rem),
			calc(calc(var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - calc(var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport)))),
			calc(var(--M-fluidFontSize-max-fontsize) * .1rem)
		);
		display: block;
		line-height: 1.6;
	}
	.entryMeritSection .entryMeritItem .en {
		--M-fluidFontSize-max-fontsize: 36;
		--M-fluidFontSize-min-fontsize: 32;
		--M-fluidFontSize-max-viewport: 1600;
		--M-fluidFontSize-min-viewport: 1200;
		min-height: 0.001vw; /* for safari | font-sizeにclamp()使用時必須 */
		font-size: clamp(
			calc(var(--M-fluidFontSize-min-fontsize) * .1rem),
			calc(calc(var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - calc(var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport)))),
			calc(var(--M-fluidFontSize-max-fontsize) * .1rem)
		);
		font-family: var(--site-font_family-en_2);
		position: absolute;
		top: -.75em;
		left: .3em;
		line-height: 1;
	}

/* guideBtnWrap
----------------------*/
	.guideBtnWrap {
		max-width: 900px;
		padding: 50px 0;
	}
	/* btn_guide */
	.btn_guide [class*="generalBtnUnit"]  {
		text-align: left;
		padding: 15px 45px 15px 20px;
		--M-fluidFontSize-max-fontsize: 17;
		--M-fluidFontSize-min-fontsize: 13;
		letter-spacing: 0.05em;
	}
	.btn_guide [class*="generalBtnUnit"] .en {
		display: inline-block;
		margin-right:0.5em;
		font-size:1.5em;
		letter-spacing: 0.1em;
	}
@media screen and (max-width: 736px) {
	.entryMeritSection .entryMeritBox > *{
		width: 100%;
		margin: 0 auto;
		max-width: 500px;
	}
	.entryMeritSection .entryMeritBox .entryMeritItem:first-child{
		margin-bottom: 4em;
	}
	
}








/* ------------------------------------------------------------------------
innerpageLinkWrap
------------------------------------------------------------------------ */

	.innerpageLinkWrap{
		background-color: rgba(0,0,0,0.1);
	}
	.innerpageLinkWrap::before{
		content: "";
		display: block;
		height: 6px;
		width: 100%;
		background: linear-gradient(to right, #af995e 0%, #faf4e1 50%, #af995e 100%);
	}
	.innerpageLinkUnit {
		position: relative;
		width: 90%;
		max-width:1760px;
	}
	.innerpageLinkUnit:last-of-type {
		padding-bottom: clamp(160px, (200 / 1900 * 100vw), 200px);
	}

@media screen and (max-width: 900px) {
	.innerpageLinkUnit {
		width: 83%;
	}
	.innerpageLinkUnit:last-of-type {
		padding-bottom: clamp(80px, (160 / 900 * 100vw), 160px)
	}
}
@media screen and (max-width: 480px) { /*{SPs}*/

}



	/*innerpageLinkInner---------------------------------------*/
	.innerpageLinkInner {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: flex-start;
		margin-top: clamp(160px, (200 / 1900 * 100vw), 200px);
	}
@media screen and (max-width: 900px) { 
	.innerpageLinkInner {
		margin-top: clamp(80px, (160 / 900 * 100vw), 160px);
	}
}

	/*innerpageLinkPic------------*/
	.innerpageLinkInner .innerpageLinkPic {
		position: relative;
		width: 70%;
	}

@media screen and (min-width: 900.02px) and (max-width: 1200px) { /*{TBl}*/
	.innerpageLinkInner .innerpageLinkPic img {
		object-fit: cover;
		min-height:450px;
	}
}
@media screen and (max-width: 900px) { 
	.innerpageLinkInner .innerpageLinkPic {
		width: 100%;
	}
}
@media screen and (max-width: 736px) { /*{SP}*/
	.innerpageLinkInner .innerpageLinkPic img {
		object-fit: cover;
		min-height:clamp(300px, (400 / 736 * 100vw), 400px);
	}
}

	/*innerpageLinkTxt------------*/
	.innerpageLinkInner .innerpageLinkTxt {
		width: 23%;
	}
	.innerpageLinkInner .innerpageLinkTxt .heading {
		--M-fluidFontSize-max-fontsize: 36;
		--M-fluidFontSize-min-fontsize: 25;
		--M-fluidFontSize-max-viewport: 1900;
		--M-fluidFontSize-min-viewport: 1050;
		min-height: 0.001vw; /* for safari | font-sizeにclamp()使用時必須 */
		font-size: clamp(
			calc(var(--M-fluidFontSize-min-fontsize) * .1rem),
			calc(calc(var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - calc(var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport)))),
			calc(var(--M-fluidFontSize-max-fontsize) * .1rem)
		);
		line-height: 1;
		font-family: var(--site-font_family-en_1);
		color: rgba(var(--site-themeColor-accent_1), 1);
	}
	.innerpageLinkInner .innerpageLinkTxt .heading::after{
		content: "";
		display: block;
		height: 1px;
		width: 100%;
		background:  rgba(var(--site-themeColor-accent_1), 1);
		margin-top: -5px;
		margin-bottom: 1em;
		transform: scaleX(0);		/*	X軸方向を×0％に	*/
		transform-origin:left;
	}
	.innerpageLinkInner .innerpageLinkTxt .heading.js_showTarget.js_showTargetAnimate::after {
		transform: scaleX(1);		/*	X軸方向を×100％に	*/
		transition: 1s all ease-in 0s;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt{
		  -ms-writing-mode: tb-rl;
		  writing-mode: vertical-rl;
		letter-spacing: 0.18em;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .ttl{
		--M-fluidFontSize-max-fontsize: 26;
		--M-fluidFontSize-min-fontsize: 20;
		--M-fluidFontSize-max-viewport: 1900;
		--M-fluidFontSize-min-viewport: 1050;
		min-height: 0.001vw; /* for safari | font-sizeにclamp()使用時必須 */
		font-size: clamp(
			calc(var(--M-fluidFontSize-min-fontsize) * .1rem),
			calc(calc(var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - calc(var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport)))),
			calc(var(--M-fluidFontSize-max-fontsize) * .1rem)
		);
		line-height: 1.5;
		margin-left: 1.5em;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .ttl span{
		display: block;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .txt{
		--M-fluidFontSize-max-fontsize: 16;
		--M-fluidFontSize-min-fontsize: 14;
		--M-fluidFontSize-max-viewport: 1900;
		--M-fluidFontSize-min-viewport: 1050;
		min-height: 0.001vw; /* for safari | font-sizeにclamp()使用時必須 */
		font-size: clamp(
			calc(var(--M-fluidFontSize-min-fontsize) * .1rem),
			calc(calc(var(--M-fluidFontSize-min-fontsize) * .1rem) + (1vw - calc(var(--M-fluidFontSize-min-viewport) / 100 * .1rem)) * (100 * (var(--M-fluidFontSize-max-fontsize) - var(--M-fluidFontSize-min-fontsize)) / (var(--M-fluidFontSize-max-viewport) - var(--M-fluidFontSize-min-viewport)))),
			calc(var(--M-fluidFontSize-max-fontsize) * .1rem)
		);
		line-height: 1.8;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .text-combine { /* 縦中横 */
		-webkit-text-combine: horizontal;
		-ms-text-combine-horizontal: all;
		text-combine-upright: all;
		/*margin-bottom: 0.25em;*/
		text-align: center;
	}

@media screen and (min-width: 900.02px) {
	.innerpageLinkInner .innerpageLinkTxt sup {
		right: -.5em;
	  }
}
@media screen and (max-width: 900px) { 
	.innerpageLinkInner .innerpageLinkTxt {
		width: 100%;
		margin: 0 auto;
	}
	.innerpageLinkInner .innerpageLinkTxtInner {
		width: 100%;
		padding: clamp(15px, (20 / 1050 * 100vw), 20px) 0em clamp(30px, (40 / 1050 * 100vw), 40px) 2em;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt {
		writing-mode: horizontal-tb;
		text-align: left;
		padding-right: 2.5em;
	}
	.innerpageLinkInner .innerpageLinkTxt .heading::after {
		margin-top: -3px;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .ttl{
		margin-left: 0;
		margin-bottom: 1em;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .ttl span{
		display: inline-block;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .txt{
		line-height: 1.6;
	}
	.innerpageLinkInner .innerpageLinkTxt .subTxt .txt br{
		display: none;
	}
}
@media screen and (max-width: 736px) { /*{SP}*/
	.innerpageLinkInner .innerpageLinkTxt .subTxt .ttl{
		--M-fluidFontSize-max-fontsize: 20;
		--M-fluidFontSize-min-fontsize: 18;
		--M-fluidFontSize-max-viewport: 736;
		--M-fluidFontSize-min-viewport: 480;
	}
}

	/*innerpageLinkbtn*/
	a.innerpageLinkbtn {
		display: block;
		margin-top:50px;
		width: 100%;
		max-width: 200px;
	}
	.innerpageLinkbtn .btn {
		display: block;
		background:  rgba(var(--site-themeColor-accent_1), 1);
		padding: 0.8em 0.5em;
		color: #fff;
		font-family: var(--site-font_family-en_1);
		border-radius: 100vh;	
		font-size: 1.8rem;
		line-height: 1;
		letter-spacing: 0.1em;
		margin-top: 1.5em;
		border: 1px solid rgba(var(--site-themeColor-accent_1), 1);
		text-align: center;
		transition: all .3s ease-out;
	}
	@media (hover: hover) and (pointer: fine) {
		a[href].innerpageLinkbtn:hover .btn { background-color: rgba(26, 85, 59,0.00); color: rgba(var(--site-themeColor-accent_1), 1);}
	}
	a[href].innerpageLinkbtn:focus-visible .btn {	background-color: rgba(26, 85, 59,0.00); color: rgba(var(--site-themeColor-accent_1), 1);}


@media screen and (max-width: 900px) {
	.innerpageLinkbtn {
		margin-top: clamp(20px, (25 / 1050 * 100vw), 25px);
		max-width:250px;
		padding-right: 2.5em;
	}
}
@media screen and (max-width: 736px) { /*{SP}*/
	a.innerpageLinkbtn {
		margin-top:30px;
	}
}





/*even------------------------------------------------------------------------------------*/
	.innerpageLinkUnit:nth-of-type(even) {
		margin-left: auto;
	}
	
	.innerpageLinkUnit:nth-of-type(even)::after {
		left:0;
		right:auto;
	}
	.innerpageLinkUnit:nth-of-type(even) .innerpageLinkInner {
		flex-direction: row-reverse;
	}
	
@media screen and (max-width: 736px) { /*{SP}*/
	.innerpageLinkUnit:nth-of-type(even) {
		margin-left:calc(15% - 7%);
		width:  calc(85% + 7%);
		padding-left:7%;
	}
	.innerpageLinkUnit:nth-of-type(even) .innerpageLinkInner .innerpageLinkTxtInner {
		margin-right:auto;
		margin-left:0;
	}
}
@media screen and (max-width: 480px) { /*{SPs}*/
	.innerpageLinkUnit:nth-of-type(even) {
		margin-left:calc(15% - 10%);
		width:  calc(85% + 10%);
		padding-left:10%;
	}
}









/* ------------------------------------------------------------------------
apologyBox
------------------------------------------------------------------------ */
	.apologyWrap {
		max-width: 1000px;
		padding: 20px 0;
		margin-top: 1em;
        border: 1px solid rgba(0,0,0,0.2);
	}
	.apologyBox {
		line-height: 1.65;
		font-size: 1.4rem;
		font-family: var(--site-font_family-sans);
		letter-spacing: .03em;
		margin-left: auto;
		margin-right: auto;
		width: 92%;
	}
	.apologyBoxTtl {
		font-weight: bold;
	}
@media screen and (max-width: 1200px) {
	.apologyBox {
		font-size: 1.3rem;
	} 
}
@media screen and (max-width: 736px) {
	.apologyWrap {

	}
	.apologyBox {
		font-size: 1.2rem;
	}
}









