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

@font-face{
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 300;
	src:
		local("Noto Sans CJK JP"),
		url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff2) format('wffo2'),
		url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff) format('wffo'),
		url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.otf) format('opentype');
}


html{
	font-size: 62.5%;/*16px x 62.5%=10px*/
	background: #ffffff;
	/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#e0dfde+0,f5f5f5+27,f5f5f5+50,f5f5f5+73,e0dfde+100 */
	background: #ffffff; /* Old browsers */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e0dfde', endColorstr='#e0dfde',GradientType=1 ); /* IE6-9 */
		scroll-behavior: smooth;
}

body{
	font-family: 'Noto Sans JP', sans-serif;
    font-feature-settings: "palt";
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    font-size: 1.6rem;
	line-height: 2.4rem;
	color: #3d3a39;
}
a{
   text-decoration: none;
    transition: all .2s;    
    -webkit-transition: all .2s;
    -moz-transition: all .2s;
    -ms-transition: all .2s;
    -o-transition: all .2s;
}
a:hover{
    opacity:0.5;
}
/*-------------------------
*utility
--------------------------*/
.inner{
	text-align: center;
}
.text-end{
	text-align: end;
}

/* spで表示させるもの */
.sp-none{
	display: none;
}
.sp2-none{
	display: none;
}
/* pcで表示させるもの */

.hiden{
	visibility: hidden;
}

.spacing-bottom{
	margin-bottom: 100px;
}

.title{
	appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;	
	margin-bottom: 30px;
	font-size: 2.4rem;
	font-weight: 500;
}
.img{
	width: 100%;
	height: auto;
}
.reset{
	appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;
	color: #3d3a39;
}

.page_top_btn {
  position: fixed;
  z-index: 2000;
  width: 100px;
  height: 55px;
  bottom: 10px;
  right: 10px;
  font-weight: bold;
  padding-top: 17<px;
  text-align: center;
  background: #6CAF2F;
  color: #fff;
  font-size: 1.2rem;
  transition: 0.3s0;
}

/* マウスオーバー時 */
.page_top_btn:hover {
  background: rgb(255, 0, 0, 0.8);
  color: rgb(255, 255, 255, 0.8);
}
/*-------------------------
* /utility
--------------------------*/



/*-------------------------
* partner
--------------------------*/

.temporary{
	margin-bottom: 40px;
}
.line{
	margin: 10px auto;
	width: 50px;
	height: 1px;
	background-color: #000000;
}

.opSpacing{
	margin: 0 auto;
}
.opText{
	font-size: 1.3rem;
	font-weight: 500;
}

/*-------------------------
* popUp
--------------------------*/
.grid-OPcontainer{
	display: grid;
	max-width: 1050px;
	margin: 0 auto;
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
	
}
.grid-OPbox{
	max-width: 190px;
	height: 200px;
	padding: 10px 10px;
}
.OPlogoBox{
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	width: 160px;
	height: 110px;
}

.open {
	cursor:pointer; /* マウスオーバーでカーソルの形状を変えることで、クリックできる要素だとわかりやすいように */
}
#pop-up {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up1 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up2 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up3 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up4 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up5 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up6 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up7 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up8 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up9 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up10 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up11 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up12 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up13 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up14 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up15 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up16 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up17 {
	display: none; /* label でコントロールするので input は非表示に */
}
#pop-up18 {
	display: none; /* label でコントロールするので input は非表示に */
}
.overlay {
	display: none; /* input にチェックが入るまでは非表示に */
}
#pop-up:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up1:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up2:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up3:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up4:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up5:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up6:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up7:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up8:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up9:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up10:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up11:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up12:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up13:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up14:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up15:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up16:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up17:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
#pop-up18:checked + .overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
.window {
	width: 90vw;
	max-width: 550px;
	height: auto;
	padding: 20px;
	background-color: #ffffff;
	border-radius: 6px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.text {
	font-size: 18px;
	margin: 0;
}
.close {
	cursor:pointer;
	position: absolute;
	top: 4px;
	right: 4px;
	font-size: 20px;
}
/*-------------------------
* /popUP
--------------------------*/

/*-------------------------
* product
--------------------------*/

.temporary{
	margin-bottom: 40px;
}
.line{
	margin: 10px auto;
	width: 50px;
	height: 1px;
	background-color: #000000;
}
.img100{
	width: 100%;
	height: auto;
}
.img30{
	width: 30%;
	height: auto;
}
.img50{
	width: 50%;
	height: auto;
}
.img80{
	width: 80%;
	height: auto;
}
.opSpacing{
	margin: 0 auto;
}
.opText{
	font-size: 1.3rem;
	font-weight: 500;
}






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

	.sp-none{
		display: inline-block;
	}
	.pc-none{
	display: none;
	}
	.wrapper{
		width: 100%;
		overflow: hidden;
	}
	.spCoLogo{
		margin:10px;
	}
	.nav2{
		display: none;
	}
	.nav-title{
		width: 80vw;
		margin: 0 auto;
		font-size: 1.2rem;
		line-height: 2rem;
		font-family: ;
		border-bottom: 1px solid #898886;	  
	}
	.nav-title2{
		width: 80vw;
		margin: 0 auto;
	    padding: 2em 0em;
		border-bottom: 1px solid #898886;
	}
	.navSpBox{
		display: flex;
		position: fixed;
		justify-content: space-between;
		top: 0;
		background-color: #fff;
		z-index: 1500;
		width: 100vw;
	}
	.navTitleE{
		font-size: 1.5rem;
		font-weight: 400;
	}
	.navTitleJ{
		font-size: 1.1rem;
		font-weight: 400;
		padding-left: 20px;
	}
	.cloumn{
		justify-content:flex-start;
		margin: 0 25px;
	}
	.spSpacing{
		margin-left: 10px;
	}
	.spSpacingLast{
		margin-right: 10px;
	}
	.spacing-bottom{
	margin-bottom: 130px;
	}
	/*-------------------------
	*nav-sp
	--------------------------*/
	.header {
		background: #fff;
	}
	.concept{
	width: 80vw;
	padding-top: 10px;
	margin:0 auto;
}
	.burger{
		display: flex;
		right: 10px;
		align-items: center;
	}
	/* ここから下がハンバーガーメニューに関するCSS */
	/* チェックボックスを非表示にする */
	.drawer_hidden {
	  display: none;
	}
	
	/* ハンバーガーアイコンの設置スペース */
	.drawer_open {
	  display: flex;
	  height: 60px;
	  width: 60px;
	  justify-content: center;
	  align-items: center;
	  position: relative;
	  top: 10px;
	  right: 20px;
	  z-index: 100;/* 重なり順を一番上にする */
	  cursor: pointer;
	}
	
	/* ハンバーガーメニューのアイコン */
	.drawer_open span,
	.drawer_open span:before,
	.drawer_open span:after {
	  content: '';
	  display: block;
	  height: 3px;
	  width: 25px;
	  border-radius: 3px;
	  background: #333;
	  transition: 0.5s;
	  position: absolute;
	}
	
	/* 三本線の一番上の棒の位置調整 */
	.drawer_open span:before {
	  bottom: 8px;
	}
	
	/* 三本線の一番下の棒の位置調整 */
	.drawer_open span:after {
	  top: 8px;
	}
	
	/* アイコンがクリックされたら真ん中の線を透明にする */
	#drawer_input:checked ~ .drawer_open span {
	  background: rgba(255, 255, 255, 0);
	}
	
	/* アイコンがクリックされたらアイコンが×印になように上下の線を回転 */
	#drawer_input:checked ~ .drawer_open span::before {
	  bottom: 0;
	  transform: rotate(45deg);
	}

	#drawer_input:checked ~ .drawer_open span::after {
	  top: 0;
	  transform: rotate(-45deg);
	}
	  
	/* メニューのデザイン*/
	.nav_content {
	  width: 100%;
	  height: 100%;
	  position: fixed;
	  padding: 0 10px;
	  top: 20px;
	  left: 100%; /* メニューを画面の外に飛ばす */
	  z-index: 99;
	  background: #fff;
	  transition: .5s;
	}
	
	/* メニュー黒ポチを消す */
	.nav_list {
	  list-style: none;
	  width: 100vw;
	  margin: 0;
	  padding: 0;
  }
	
	/* アイコンがクリックされたらメニューを表示 */
	#drawer_input:checked ~ .nav_content {
	  left: 0;/* メニューを画面に入れる */
	}
	.snssBox{
		display: flex;
		width: 80vw;
		margin: 0 auto;	
		margin-top: 20px;
		padding-bottom: 10px;
		border-bottom: 1px solid #898886;
	}
	
	.sns{
		width: 70px;
		height: auto;
		margin-right: 5px;
	}

	.accordion-002 {
    max-width: 849px;
    margin-bottom: 7px;
}

	.accordion-002 summary {
	    display: flex;
	    align-items: center;
	    position: relative;
	    padding: 1.5em 0em; 
	    background-image: url(../images/top/Plus.png);
	    background-position: right calc(2em - 7px) center;
	    background-size: 15px;
	    background-repeat: no-repeat;
	    cursor: pointer;
	}
	
	.accordion-002 summary::-webkit-details-marker {
	    display: none;
	}
	
	.accordion-002 summary::before,
	.accordion-002 summary::after {
	    position: absolute;
	    right: calc(2em + 2.5px);	
	    content: '';
	}
	
	
	.accordion-002 p {
	    transform: translateY(-10px);
	    opacity: 0;
	    margin: 0;
	    color: #3d3a39;
	    transition: transform .5s, opacity .5s;
	}
	
	.accordion-002[open] p {
	    transform: none;
	    opacity: 1;
	}

	

	/*-------------------------
	* /nav-sp
	--------------------------*/


	
	/*-------------------------
	* popUp
	--------------------------*/
	.grid-OPcontainer{
		display: grid;
		max-width: 420px;
		margin: 0 auto;
		grid-template-columns: 1fr 1fr;
		
	}
	

	/*-------------------------
	* /popUp
	--------------------------*/

	
	
	
}
	
@media screen and (min-width:849px){

	.colomunW{
		margin:0 auto;
	}
	.grid-OPcontainer{
		display: grid;
		max-width: 840px;
		margin: 0 auto;
		grid-template-columns: 1fr 1fr 1fr 1fr;
		
	}

	
	
	
}