@charset "utf-8";
/* 
	
CSS base.css */



/*
base #333
main #005188
*/



/*//////////////////


Header


//////////////////*/

#header { width: 100%; z-index: 1000; position: fixed; top: 0; background: #fff; background: rgba(255,255,255,0.97); transition: 0.5s ease-out }
#header .headermainbox { display: flex; align-items: flex-end; justify-content: space-between; height: 120px; padding-right: 210px; padding-left: 60px; box-sizing: border-box; }
.sitetitlebox{ padding-bottom: 40px;  transition: 0.5s ease-out }
.sitetitlebox>.inwrap{ padding-right: 40px; position: relative; display: inline-block; }
.sitetitlebox>.inwrap:after{ content: ""; background: url(../img/common/icon_leaf.svg) no-repeat; background-size: contain; width: 32px; height: 22px; display: inline-block; position: absolute; top: 0; bottom: 0; right: 0; margin-top: auto; margin-bottom: auto; }
.sitetitlebox._leafwhite>.inwrap:after{ background: url(../img/common/icon_leaf_white.svg) no-repeat; }
.sitetitlebox .logo,
.sitetitlebox .cap{ display: inline-block; vertical-align: middle; }
.sitetitlebox .logo,
.sitetitlebox .logo>a{ line-height: 1 }
.sitetitlebox .logo>a{ width: 156px; height: 22px; margin-right: 10px; display: inline-block; }
.sitetitlebox .cap{ font-size: 1.3rem }

/* スクロール時fixed */
/*#header.fixed { animation: navfit 0.5s ease-out 0s 1 normal both; }*/
#header.scroll{ transform: translate(0px, -170px); }
#header.fixed.scroll { padding-top: 0; padding-bottom: 0; transform: translate(0px, 0px); }
#header.fixed .headermainbox { height: 80px; }
#header.fixed .logo img { width: 180px; }
#header.fixed .sitetitlebox{ padding-bottom: 20px }
@media screen and (max-width: 1310px) {
	#header .cap { display: none; }
}
@media screen and (max-width: 1280px){
	#header .headermainbox { padding-right: 210px; padding-left: 40px; }
}
@media screen and (max-width: 1040px) {
	#header{ position: static; }
	#header,
	#header .headermainbox { height: 100px; }
	#header .headermainbox { padding-right: 6%; padding-left: 6%; box-sizing: border-box; padding-bottom: 0; align-items: center; }
	.sitetitlebox{ padding-bottom: 0 }
}
@media screen and (max-width: 767px) {
	#header,
	#header .headermainbox { height: 70px; }
	.sitetitlebox>.inwrap:after{ width: 22px; height: 16px; top: 1px }
	.sitetitlebox .logo>a{ width: 120px; height: 18px; }
	.sitetitlebox>.inwrap{ padding-right: 20px }
	.sitetitlebox .cap{ display: none!important; }
}

/* スクロール時fixedのアニメーション */
@keyframes navfit {
  0% { transform: translate(0px, -50px); }
  100% { transform: translate(0px, 0px);  }
}







/*//////////////////


Nav


//////////////////*/

#gnav{ flex-shrink: 0; }
#gnav .navbox{  }
#gnav .incnt.fix{ width: 100%; margin: 0 }
#gnav>.scrollcover{  }
#gnav .sitetitlebox,
#gnav .top { display: none; }


#gnav .mainbox { text-align: right;display: flex; }
#gnav .mainbox ul{ text-align: right;display: flex; }
#gnav .mainbox li { display: flex; position: relative; margin-left: 1.3em;align-items: flex-end; padding-bottom: 40px; transition: 0.5s ease-out }
#gnav .mainbox li._1{ display: none; }
#gnav .mainbox .hassub span { }
#gnav .mainbox .hassub span._1{ font-size: 1.2rem; text-align: center }
#gnav .mainbox li.tabletblock{ display: none; }
#gnav .mainbox li a,
#gnav .mainbox li p { text-decoration: none; position: relative; vertical-align: middle; cursor: pointer; text-align: center; line-height: 1.6; transition: .3s }
#gnav .mainbox li a:hover,
#gnav .mainbox li p:hover { color: #1aa975; opacity: 1; }
#gnav .mainbox li[data-cat="contents"]::after { display: none; }


	
/* sub */
#gnav .mainbox li>div.sub { position: absolute; top: 70px; left: 50%; margin-left: -101px; min-width: 302px; box-sizing: border-box; padding: 30px 30px; z-index: 1000; background: #191919; color: #fff; text-align: center; opacity: 0; visibility: hidden; pointer-events: none; transition: .5s }
#gnav .mainbox li>div.sub>ul{ margin-left: -20px; display: block; text-align: left; }
#gnav .mainbox li>div.sub>ul>li{ display: inline-block; text-align: left; margin-left: 20px; padding-bottom: 0!important }
#gnav .mainbox li>div.sub a{ color: #fff }
#gnav .mainbox li>div.sub a:hover{ color: #1aa975; }
#gnav .mainbox li:hover>div.sub{ opacity: 1; visibility: visible; pointer-events: auto; }
#gnav .box2 .mailbox{ position: absolute; top: 0; bottom: 0; right: 0; width: 183px; }
#gnav .box2 .mailbox>a{ background: #1aa975; color: #fff;  height: 100%; width: 100%; padding: 10px 6%; text-decoration: none; box-sizing: border-box; display: flex; align-items: center; justify-content: center; }
#gnav .box2 .mailbox>a>svg{ width: 20px; height: 16px; display: inline-block; margin-right: 5px }
#gnav .box2 .mailbox>a:hover{ background: #0d0d0d; }
#gnav .box2 .telbox{ display: none; }

#gnav .bg{  }
#gnav .bg .greenbg{ position: absolute; left: 0; top: 0; width: 100vw; height: 100vh;height: 100lvh; z-index: 2; background-color: #1aa975; opacity: 0; visibility: hidden; transition: all .6s; cursor: pointer; }

#gnav.is-open{ opacity: 1; visibility: visible; }
#gnav.is-open .greenbg{ opacity: 1; visibility: visible; }
#header.fixed #gnav .mainbox li{ padding-bottom: 20px }

@media screen and (max-width: 1040px){
	#gnav{  z-index: 100000000; opacity: 0; position: fixed; top: 0; bottom: 0; left: 0; right: 0; height: 100vh!important;height:100lvh!important;height: -webkit-fill-available;display: block; overflow: hidden; width: 100vw!important; visibility: hidden;  pointer-events: none; }
	#gnav .navbox{ position: relative; z-index: 10; display: flex; flex-direction: row; }
	#gnav>.scrollcover{  }
	#gnav .incnt.fix{ width: calc(100% - 120px); margin: 0 60px }
	#gnav.navlist .incnt>.mainlistcover{ display: flex; flex-direction: column; justify-content: center; height: 100vh; width: 100% }
	#gnav.navlist .incnt>.mainlistcover>.inwrap{ overflow: hidden; padding-top: 80px; padding-bottom: 80px; }
	#gnav.navlist .incnt>.mainlistcover>.inwrap>.inwrap{ overflow-y: scroll; height: calc(100vh - 160px);height: calc(100svh - 160px);  width: calc(100% + 20px); padding: 0 2%; box-sizing: border-box; display: flex; align-items: center; }

	#gnav .sitetitlebox,
	#gnav .top{ display: block; }
	#header #gnav .cap{ display: inline-block; color: #fff }
	#gnav .sitetitlebox{ margin-bottom: 55px; }
	#gnav .top a{ text-decoration: none; color: #fff }
	#gnav .mainbox li { padding-bottom: 0 }


	/* sub */
	#gnav .mainbox li{ margin-left: 0 }
	#gnav .mainbox li>div.sub { display: block; position: static; left: 0; margin-left: 0; min-width: 100%; padding: 0;background: transparent; color: #65d6aa; text-align: left; }
	#gnav .mainbox li>div.sub>ul{ margin-left: 0 }
	#gnav .mainbox li>div.sub a{ color: #65d6aa }
	#gnav .mainbox li>div.sub>ul,
	#gnav .mainbox li>div.sub>ul>li{ display: block; }


	#gnav .mainbox li>div.sub { position: relative; top: 0; left: 0; margin-left: 0; min-width: auto; padding: 0; background: transparent; color: inherit; text-align: left; opacity: 1; visibility: visible; }
	#gnav .mainbox li>div.sub>ul{ margin-left: 0; }
	#gnav .mainbox li>div.sub>ul>li{ display: block; margin-left: 0; }

	#gnav .mainbox li a,
	#gnav .mainbox li p { font-weight: normal; text-align: left; }
	#gnav .mainbox .hassub span._1{ font-size: 1.6rem; }

	#gnav .mainbox{ overflow: hidden; margin-top: 30px; text-align: left; display: block; color: #fff }
	#gnav .mainbox .main{ margin-left: 0; text-align: left;display: inline-block; vertical-align: top }
	#gnav .mainbox .main>li{ display: inline-block; vertical-align: top; margin-left: 40px; text-align: left; margin-bottom: 30px; position: relative; }
	#gnav .mainbox li._1{ display: inline-block; }
	#gnav .mainbox .main>li p>a,
	#gnav .mainbox .main>li a,
	#gnav .mainbox .main>li p{ text-decoration: none; color: #fff; position: relative; }
	#gnav .mainbox .main>li a+.sub>.inwrap>li,
	#gnav .mainbox .main>li p+.sub>.inwrap>li{ padding-left: 1em!important; text-indent: -1em; line-height: 2 }
	#gnav .mainbox .main>li a+.sub>.inwrap>li:before,
	#gnav .mainbox .main>li p+.sub>.inwrap>li:before{ content: "―"; color: #65d6aa }
	#gnav .mainbox .main>li a+.sub>.inwrap>li>a,
	#gnav .mainbox .main>li p+.sub>.inwrap>li>a{ text-decoration: none; font-size: 1.4rem; color: #65d6aa }
	#gnav .mainbox .main>li p>a:after,
	#gnav .mainbox .main>li a:after{ content: ""; background: #fff; display: inline-block; position: absolute; bottom: -1px; left: 0; width: 0; transition: .3s; height: 1px; }
	#gnav .mainbox .main>li p>a:hover:after,
	#gnav .mainbox .main>li a:hover:after{ width: 100% }
	#gnav .mainbox .main>li p+.sub>.inwrap>li>a:after{ background: #65d6aa; }

	#gnav .mainbox{ margin-left: -40px }
	#gnav .mainbox ul.sub{ display: inline-block; text-align: left; vertical-align: top; margin-left: 40px; }
	#gnav .mainbox ul.sub{ margin-top: -3px }
	#gnav .mainbox ul.sub>li,
	#gnav .mainbox ul.sub>li._1{ display: block; margin-left: 0; margin-bottom: 5px; }
	#gnav .mainbox .sub>li p>a,
	#gnav .mainbox .sub>li a,
	#gnav .mainbox .sub>li p{ text-decoration: none; color: #fff; position: relative; }
	#gnav .mainbox .sub>li p>a:after,
	#gnav .mainbox .sub>li a:after{ content: ""; background: #fff; display: inline-block; position: absolute; bottom: -1px; left: 0; width: 0; transition: .3s; height: 1px }
	#gnav .mainbox .sub>li p>a:hover:after,
	#gnav .mainbox .sub>li a:hover:after{ width: 100% }
	#gnav .mainbox .sub>li p+.sub>.inwrap>li>a:after{ background: #65d6aa; }

	#gnav.is-open{ pointer-events: auto; }
	#gnav .box2{ margin-top: 40px }
	#gnav .box2 .telbox{ display: block; margin-top: 20px }

	#gnav .box2 .telbox .teltxt{ display: inline-block; vertical-align: middle; line-height: 1.8 }
	#gnav .box2 .telbox .teltxt>a{ font-size: 1.5rem; color: #fff; text-decoration: none; letter-spacing: 0.1em }
	#gnav .box2 .telbox .teltxt>a>.telnum{ display: inline-block; font-size: 2.4rem; }
	#gnav .box2 .telbox .txt{ display: inline-block; vertical-align: middle; font-size: 1.4rem; color: #fff }


	#gnav .box2 .mailbox>a{ background: #fff; color: #1aa975;  height: 100%; width: 100%; padding: 17px 20px; text-decoration: none; box-sizing: border-box; display: inline-block; max-width: 240px; border-radius: 35px; text-align: center; font-size: 1.4rem; border: 1px solid #fff }
	#gnav .box2 .mailbox>a:hover{ background: #fff; }
	#gnav .box2 .mailbox>a>svg{ vertical-align: -3px }
	#gnav .box2 .mailbox>a>svg .mail_st0.st0{ stroke: #1aa975; transition: .3s }
	#gnav .box2 .mailbox>a:hover{ background: transparent; color: #fff }
	#gnav .box2 .mailbox>a:hover>svg .mail_st0.st0{ stroke: #fff; }

	#gnav .box2 .mailbox{ margin-left: 0; position: static; width: 100% }
	#gnav .mainbox .main>li p>a:after, #gnav .mainbox .main>li a:after,
	#gnav .mainbox .sub>li p>a:after, #gnav .mainbox .sub>li a:after{ content: none; }
}
@media screen and (max-width: 767px){
	#gnav.navlist .incnt>.mainlistcover>.inwrap{ padding-top: 100px; padding-bottom: 70px; font-size: 1.6rem }
	#gnav .incnt.fix{ width: 88%; margin: 0 6% }
	#gnav.navlist .incnt>.mainlistcover>.inwrap>.inwrap{ height: calc(100vh - 170px);height: calc(100svh - 170px); display: block; }
	#gnav .sitetitlebox{ height: 70px; position: absolute; top: 0; left: 6%; display: flex; align-items: center; }
	#gnav .mainbox{ margin-top: 20px }
	#gnav .mainbox .main{ margin-bottom: 0; }
	#gnav .mainbox .main>li{ margin-bottom: 20px }
	#gnav .mainbox li>div.sub{ margin-top: 5px }
	#gnav.is-open .mainbox .main>li a+.sub>.inwrap>li>a,
	#gnav.is-open .mainbox .main>li p+.sub>.inwrap>li>a{ pointer-events: auto; }
	#gnav .box2 .telbox .txt{ font-size: 1.3rem; }
	/*#header,
	#header .headermainbox { height: 70px; }
	.sitetitlebox>.inwrap:after{ width: 22px; height: 16px; }
	.sitetitlebox .logo>a{ width: 120px; height: 18px; }
	.sitetitlebox>.inwrap{ padding-right: 25px }
	.sitetitlebox .cap{ display: none!important; }*/
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}








/*//////////////////


Menubtn


//////////////////*/

#menubtn {display: none; z-index: 100000000001; }
@media screen and (max-width: 1040px){
	#menubtn { position: fixed; top: 22px; right: 20px; display: block; background: transparent; width: 42px; height: 46px; cursor: pointer; }
	#menubtn a { text-decoration: none; position: relative; display: block; height: 100%; width: 100%; color: #fff; }
	#menubtn a .line {
		width: 42px; height: 2px; background: #000000; position: absolute; left: 50%; margin-left: -25px;
		-webkit-transition: all 0.3s; transition: all 0.3s;
	}
	#menubtn a #line1 { top: 15px; }
	#menubtn a #line2 { top: 50%; }
	#menubtn a #line3 { bottom: 13px; }
	#menubtn a .txt { display: none; font-size: 1.8rem; color: #fff; position: absolute; bottom: 0; top: 0; right: 75px; letter-spacing: 0.1em }
	#menubtn.active{ top: 40px }
	#menubtn.active a .txt { display: block; }
	#menubtn.active a .line { width: 40px; background: #fff }
	#menubtn.active a #line1 {
		-webkit-transform:translateY(0) translateX(-10px) rotate(-26deg);
		transform:translateY(0) translateX(-10px) rotate(-26deg);
	}
	#menubtn.active a #line2 { display: none }
	#menubtn.active a #line3 { 
		-webkit-transform:translateY(-15px) translateX(-10px) rotate(26deg);
		transform:translateY(-15px) translateX(-10px) rotate(26deg);
	}
}
@media screen and (max-width: 767px){
	#menubtn { top: 10px; right: 10px }
	#menubtn.active{ top: 20px }
}









/*//////////////////


Mainv.index


//////////////////*/

#mainv.index { position: relative; }
#mainv.index:after{ content: ""; width: 450px; height: 165px; background: linear-gradient(to top left, rgba(255,255,255,0) 50%, #f3f1ee 50.5%) no-repeat top left/100% 100%; position: absolute; bottom: 0; left: 0; z-index: -1 }
#mainv.index .mainbox{ position: relative; }
#mainv.index .mainbox .copybox{ display: flex; flex-direction: column; justify-content: flex-end; width: 100%; align-items: flex-start; padding-bottom: 60px; box-sizing: border-box; position: relative; z-index: 10; height: 880px; }
#mainv.index .mainbox .copybox .copytxt{ margin-bottom: 40px }
#mainv.index .mainbox .copybox .txt{  }
#mainv.index .mainbox .bgbox{  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 86%); background: #f7f7f7; position: absolute; top: 0; bottom: 0; left: 0; right: 0; }
#mainv.index .mainbox .bgbox>.inwrap{ position: absolute; right: 0; top: 0; bottom: 0; height: 100%; width: 56.6%; padding-left: 4%; padding-right: 4%; box-sizing: border-box;  }
#mainv.index .mainbox .bgbox .bg{height: 100%;width: 100%;object-fit: cover;font-family: 'object-fit: cover;'; /*IE対策*/position: absolute;top: 0;bottom: 0;right: 0;}
#mainv.index .mainbox .bgbox .bgcopy{ position: relative; z-index: 10; text-align: right; display: flex; height: 100%; align-items: center; justify-content: flex-end; }
#mainv.index .mainbox .bgbox .bgcopy>.inwrap{ background: #0d0d0d; color: #fff; line-height: 1; display: inline-block; letter-spacing: 0.1em; font-size: 2.4rem; padding: 26px 24px }
@media screen and (max-width: 1400px){
	#mainv.index .mainbox .copybox{ height: 780px }
	#mainv.index .mainbox .bgbox>.inwrap{ width: 50% }
}
@media screen and (max-width: 1200px){
	#mainv.index .mainbox .copybox{ height: 780px }
	#mainv.index .mainbox .copybox .txt {width: 44%;}
	#mainv.index .mainbox .copybox .txt br { display:none; }
	#mainv.index .mainbox .copybox .copytxt{ font-size: 3.6rem;}
	#mainv.index .mainbox .bgbox>.inwrap{ width: 50% }
	#mainv.index .mainbox .bgbox .bgcopy>.inwrap{ font-size: 1.8rem; }
}
@media screen and (max-width: 1040px){
	#mainv.index>.inwrap{  padding-left: 8%; padding-right: 8%; }
	#mainv.index .mainbox>.incnt{ max-width: 100%; width: 100% }
	#mainv.index .mainbox>.incnt>.inwrap{ display: flex; flex-direction: column-reverse; }
	#mainv.index .mainbox .bgbox{ clip-path: none; background: transparent; position: static; padding: 0 }
	#mainv.index .mainbox .bgbox>.inwrap{ width: 100%; height: 600px; padding-left: 4%; padding-right: 4%; position: relative; }
	#mainv.index .mainbox .bgbox .bg{ object-position: 0% 20%; }
	#mainv.index .mainbox .copybox{ display: block; padding-bottom: 0; z-index: 10; height: auto; padding-top: 60px; padding-left: 6%; padding-right: 6%}
	#mainv.index .mainbox .copybox:before{ content: ""; background: #f7f7f7; width: 100%; height: 145px; display: block; position: absolute; top: 0; left: 0; right: 0; z-index: -1 }
	#mainv.index .mainbox .copybox>.inwrap:before{ content: ""; width: 100%; height: 135px; background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #f7f7f7 50.5%) no-repeat top right/100% 100%; position: absolute; top: 145px; right: 0; z-index: -1 }
	#mainv.index .mainbox .copybox>.inwrap:after{ content: ""; width: 450px; height: 135px; background: linear-gradient(to top left, rgba(255,255,255,0) 50%, #f3f1ee 50.5%) no-repeat top left/100% 100%; position: absolute; top: 145px; left: 0; z-index: -2 }
	#mainv.index:after{ content: none; }
	#mainv.index .mainbox .copybox .copytxt{ font-size: 3.6rem; }
	#mainv.index .mainbox .copybox .txt {width: 100%;}
	#mainv.index .mainbox .copybox .txt br { display:none; }
	#mainv.index .mainbox .bgbox .bgcopy>.inwrap{ font-size: 2rem; padding: 20px }
}
@media screen and (max-width: 767px){
	#mainv.index .mainbox .bgbox>.inwrap { height: 400px; }
	#mainv.index .mainbox .copybox{ padding-top: 40px; }
	#mainv.index .mainbox .copybox .copytxt{ margin-bottom: 20px; font-size: 2.6rem;  }
	#mainv.index .mainbox .bgbox .bgcopy>.inwrap{ font-size: 1.8rem; padding: 18px }
}
@media screen and (max-width: 479px){
	#mainv.index .mainbox .bgbox>.inwrap { height: 300px; }
	#mainv.index .mainbox .bgbox .bgcopy>.inwrap{ font-size: 1.2rem; padding: 14px 14px }
	#mainv.index .mainbox .copybox>.inwrap:before{ height: 70px; top: 145px; }
	#mainv.index .mainbox .copybox>.inwrap:after{ width: 450px; height: 70px; top: 145px; }
	#mainv.index .mainbox .copybox .copytxt{ font-size: 2.4rem; }
}






/*//////////////////


Mainv.under


//////////////////*/

#mainv.under { position: relative; height: 360px; }
#mainv.under:before{ content: ""; background: #f7f7f7; width: 100%; height: calc(100% - 135px); display: block; position: absolute; top: 0; left: 0; right: 0; z-index: 5 }
#mainv.under>.inwrap{  padding-left: 10%; padding-right: 40px; height: 100%; box-sizing: border-box; display: flex; align-items: flex-end; padding-bottom: 40px; }
#mainv.under>.inwrap:before{ content: ""; width: 100%; height: 135px; background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #f7f7f7 50.5%) no-repeat top right/100% 100%; position: absolute; bottom: 0; right: 0; }
#mainv.under>.inwrap:after{ content: ""; width: 450px; height: 165px; background: linear-gradient(to top left, rgba(255,255,255,0) 50%, #f3f1ee 50.5%) no-repeat top left/100% 100%; position: absolute; bottom: 0; left: 0; z-index: -1 }
#mainv.under>.inwrap>.mainbox{ position: relative; z-index: 5; display: flex; justify-content: space-between; flex-direction: row; align-items: center; width: 100%;  }
#pankuzu { padding:0 0; margin-left: 40px }
#pankuzu ol { margin: 0 0; font-size: 0; text-align: right; }
#pankuzu ol li { display:inline-block; font-size: 1.3rem; }
#pankuzu ol li:before { content:""; background: url(../img/common/arr1.svg) no-repeat; background-size: contain; width: 6px; height: 10px; display: inline-block; margin: 0 20px }
#pankuzu ol li:first-child:before { display: none; }
#pankuzu ol li a{ text-decoration: none; }
#pankuzu ol li a:hover { opacity: 0.7; transition: 0.3s; }
@media screen and (max-width: 1040px){
	#pankuzu{ display: none; }
	#mainv.under { height: 280px; }
	#mainv.under>.inwrap{  padding-left: 6%; padding-right: 6%; padding-bottom: 0; align-items: center; padding-top: 40px }
	#mainv.under:before{ height: 145px; }
	#mainv.under>.inwrap:before{ bottom: auto; top: 145px }
	#mainv.under>.inwrap:after{ bottom: auto; top: 145px; height: 135px }
}
@media screen and (max-width: 767px){
}
@media screen and (max-width: 479px){
	#mainv.under { height: 210px; }
	#mainv.under>.inwrap:before{ height: 70px }
	#mainv.under>.inwrap:after{ height: 70px }
}







/*//////////////////


Content


//////////////////*/

#main { margin-top: 80px; padding-bottom: 308px; position: relative; }
#index #main { margin-top: 80px }
#main:after{ content: ""; width: calc(100% - 210px); height: 308px; position: absolute; bottom: 0; right: 0; display: inline-block; background: linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #f9f8f6 50.5%) no-repeat top left/100% 100% }
@media screen and (max-width: 1040px) { 
	#main { padding-bottom: 200px; }
	#main:after{ height: 200px; }
}

@media screen and (max-width: 767px) { 
	#main { margin-top: 70px!important; padding-bottom: 150px; }
	#main:after{ height: 140px;  width: calc(100% - 100px); }
}
@media screen and (max-width: 479px){
	#main { padding-bottom: 120px; }
	#main:after{ height: 110px; }
}










/*//////////////////


Cntside


//////////////////*/

#side {  }













/*//////////////////


Footer


//////////////////*/


#fcontactbox{ position: relative; }
#fcontactbox>.inwrap+.bg{ position: absolute; top: 0; left: 0; right: 0; width: 100%; height: 100%; object-fit: cover; font-family: 'object-fit: cover;'; /*IE対策*/ z-index: -1 }
#fcontactbox>.inwrap{ padding-top: 185px; padding-bottom: 200px; background: rgba(13, 13, 13, .7); }
#fcontactbox .txt{ color: #fff; text-align: center; letter-spacing: 0.15em }
#fcontactbox .box{ margin-top: 20px }
#fcontactbox .box>li{ margin-bottom: 20px }
#fcontactbox .box>li:last-child{ margin-bottom: 0 }
#fcontactbox .box .telbox,
#fcontactbox .box .mailbox{ text-align: center; }
#fcontactbox .box .telbox .teltxt{ display: inline-block; vertical-align: middle; line-height: 1.8 }
#fcontactbox .box .telbox .teltxt>a{ font-size: 2.4rem; color: #fff; text-decoration: none; letter-spacing: 0.1em }
#fcontactbox .box .telbox .teltxt>a>.telnum{ display: inline-block; font-size: 3.8rem; }
#fcontactbox .box .telbox .txt{ display: inline-block; vertical-align: middle; }
#fcontactbox .box .mailbox{ margin-left: -20px;  margin-bottom: -15px; }
#fcontactbox .box .mailbox .link{ display: inline-block; vertical-align: middle; margin-left: 20px; margin-bottom: 15px; line-height: 1.8 }
#fcontactbox .box .mailbox .link>a{ display: inline-block; vertical-align: middle; }
#fcontactbox .box .mailbox .link>a{ background: #fff; padding: 17px 20px; width: 270px; border-radius: 35px; text-decoration: none; box-sizing: border-box; display: flex; align-items: center; justify-content: center; border: 1px solid #fff }
#fcontactbox .box .mailbox .link>a>svg{ width: 20px; height: 16px; display: inline-block; margin-right: 5px }
#fcontactbox .box .mailbox .link>a>svg .mail_st0.st0{ stroke: #191919; transition: .3s }
#fcontactbox .box .mailbox .link>a:hover{ background: #191919; color: #fff }
#fcontactbox .box .mailbox .link>a:hover>svg .mail_st0.st0{ stroke: #fff; }
#fcontactbox .box .mailbox .cap{ display: inline-block; vertical-align: middle; color: #fff; margin-left: 20px;  margin-bottom: 15px; }
@media screen and (max-width: 1040px){
	#fcontactbox>.inwrap{ padding-top: 120px; padding-bottom: 140px; }
	#fcontactbox .txt{ text-align: left; }
}
@media screen and (max-width: 767px){
	#fcontactbox>.inwrap{ padding-top: 90px; padding-bottom: 110px; }
	#fcontactbox .box .telbox .teltxt>a{ font-size: 1.8rem; }
	#fcontactbox .box .telbox .teltxt>a>.telnum{ font-size: 2.8rem; }
	#fcontactbox .txt{ font-size: 1.4rem }
	#fcontactbox .box .mailbox .link>a{ padding: 17px 20px; width: 270px; border-radius: 35px; }
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
	#fcontactbox>.inwrap{ padding-top: 60px; padding-bottom: 60px; }
	#fcontactbox .box .telbox .txt{ letter-spacing: 0.05em }
	#fcontactbox .box .mailbox .cap{  display: block; }
}


#footer { background: #1aa975; padding-top: 100px; padding-bottom: 75px; color: #fff }
#footer .sitetitlebox{ margin-bottom: 20px }
#footer .faddresslist{ margin-left: -50px; margin-bottom: -20px; overflow: hidden; text-align: left; }
#footer .faddresslist>li{ margin-left: 50px; display: inline-block; vertical-align: top; letter-spacing: 0.15em; margin-bottom: 20px; width: 440px; }
#footer .faddresslist>li .officename{margin-bottom: 5px;}
#footer .faddresslist>li .officename>.inwrap{ font-size: 1.4rem; position: relative; display: inline-block; }
#footer .faddresslist>li .officename>.inwrap:before{ content: ""; background: #fff; display: inline-block; position: absolute; bottom: 0; left: 0; height: 1px; width: 100%; }
#footer .faddresslist>li .address{  }
#footer .faddresslist>li .teltxt{  }
#footer .faddresslist>li .teltxt .tel{ color: #fff }
@media screen and (max-width: 1040px){
	#footer{ padding-top: 80px; padding-bottom: 60px; }
}
@media screen and (max-width: 767px){
	#footer{ padding-top: 60px; padding-bottom: 40px; }
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
	#footer{ padding-top: 40px; padding-bottom: 40px; }
}

#footer #fnav{ overflow: hidden; margin-top: 40px }
#footer #fnav .mainlist{ margin-left: -40px; margin-bottom: -30px }
#footer #fnav .mainlist>li{ display: inline-block; vertical-align: top; margin-left: 40px; text-align: left; margin-bottom: 30px; position: relative; }
#footer #fnav .mainlist>li:last-child{ margin-bottom: 0 }
#footer #fnav .mainlist>li p>a,
#footer #fnav .mainlist>li a,
#footer #fnav .mainlist>li p{ text-decoration: none; color: #fff; position: relative; }
#footer #fnav .mainlist>li a+.sub>.inwrap>li,
#footer #fnav .mainlist>li p+.sub>.inwrap>li{ padding-left: 1em!important; text-indent: -1em; line-height: 2 }
#footer #fnav .mainlist>li a+.sub>.inwrap>li:before,
#footer #fnav .mainlist>li p+.sub>.inwrap>li:before{ content: "―"; color: #65d6aa }
#footer #fnav .mainlist>li a+.sub>.inwrap>li>a,
#footer #fnav .mainlist>li p+.sub>.inwrap>li>a{ text-decoration: none; font-size: 1.4rem; color: #65d6aa }
#footer #fnav .mainlist>li p>a:after,
#footer #fnav .mainlist>li a:after{ content: ""; background: #fff; display: inline-block; position: absolute; bottom: -1px; left: 0; width: 0; transition: .3s; height: 1px }
#footer #fnav .mainlist>li p>a:hover:after,
#footer #fnav .mainlist>li a:hover:after{ width: 100% }
#footer #fnav .mainlist>li p+.sub>.inwrap>li>a:after{ background: #65d6aa; }
@media screen and (max-width: 1040px){
	#footer #fnav{ display: none; }
}
@media screen and (max-width: 767px){
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}

#footer+#cr{ font-size: 1.3rem; padding: 20px 0; text-align: left; }
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px){
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}