
/*******************************************
	mainvisual
*******************************************/

.mainvisual{
	position: relative;
	text-align: center;
	color: #fff;
}
.mainvisual.all{
	background: #00C5CC;
}

.mainvisual__inner{
  position: relative;
}

.mainvisual__image{
	max-width: 100%;
	height: auto;
}

.mainvisual__imageAreaSp{
	text-align: center;
}
.mainvisual__imageAreaPc{
	text-align: center;
	display: none;
}

.mainvisual__qrArea{
	display: none;
}

/******
	pc
******/
@media screen and (min-width: 768px){

	.mainvisual__inner{
		max-width: 990px;
		margin: 0 auto;
		padding: 100px 0 87px;
	}

	.mainvisual__imageAreaSp{
		display: none;
	}
	.mainvisual__imageAreaPc{
		display: block;
	}



	.mainvisual__qrArea{
		display: block;
		position: absolute;
		right: -80px;
		bottom: -160px;
		background: #fff;
		padding: 20px 16px;
		box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.08);
	}

	.mainvisual__qrAreaTitle{
		color: #242323;
		font-size: 16px;
		font-weight: bold;
	}
	.mainvisual__qrImage{
		margin-top: 8px;
	}

	.mainvisual__qrAreaText{
		color: #242323;
		font-size: 10px;
		margin-top: 8px;
	}

}
/******
	pc
******/
@media screen and (max-width: 1100px){
	.mainvisual__qrArea{
		right: 0px;
    background: rgba(255,255,255,0.9);
	}
}

/****************************
	buttonArea
****************************/

.buttonArea{
	background: #fff;
	padding:24px 16px 40px;
	text-align: center;
}
.buttonArea__catch{
	font-weight: bold;
	font-size: 16px;
	color: #242323;
}

.buttonArea__mainButton{
	height: 56px;
}
.buttonArea__mainButtonInner{
	position: relative;
	display: block;
	width: auto;
	font-size: 18px;
	font-weight: bold;
	height: 56px;
	color: #fff;
	line-height: 56px;
	background: #FC6600;
	border-radius: 30px;
	letter-spacing: 0;
}
.buttonArea__mainButtonInner:after{
	content: "";
	position: absolute;
	right: 14px;
	top: 24px;
	width: 10px;
	height: 10px;
	border-right: 3px solid #fff;
	border-top: 3px solid #fff;
	display: inline-block;
	transform: rotate(45deg);
}

/******
	pc
******/
@media screen and (min-width: 768px){
	.buttonArea{
		display: none;
	}
}


/*******************************************
	mainArea
*******************************************/


.mainArea{
	padding:60px 16px;
}
.mainArea__bgOdd{
	background: #F7F7F7;
}

.mainArea__title{
	text-align: center;
	font-weight: bold;
	font-size: 24px;
	color: #242323;
}
.mainArea__titleSmall{
	font-size: 16px;
	color: #606060;
}

.mainArea__title:after{
	content:"";
	display: block;
	width: 40px;
	height: 4px;
	background: #FFB900;
	border-radius: 2px;
	margin: 17px auto 0;
}

/******
	pc
******/
@media screen and (min-width: 768px){
	.mainArea{
		padding: 120px 0;
	}

	.mainArea__inner{
		width: 770px;
		margin:0 auto;
	}

	.mainArea__title{
		font-size: 32px;
	}
	.mainArea__titleSmall{
		font-size: 24px;
	}
	.mainArea__title:after{
		content:"";
		display: block;
		width: 80px;
		height: 8px;
		background: #FFB900;
		border-radius: 4px;
		margin: 24px auto 0;
	}

}


/****************************
	recommendArea
****************************/

.recommendArea__scene{
	margin: 24px;
	padding-right: 8px;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
}

.recommendArea__sceneInner:not(:first-child){
	margin-top: 24px;
}

.recommendArea__sceneInnerSection{
	margin:0 auto;
	display: flex;
  align-items: center;
  max-width: 327px;
}
.recommendArea__sceneInnerSectionTitle{
	order: 2;
	font-weight: bold;
	font-size: 16px;
	color: #606060;
	margin-left: 12px;
}

.recommendArea__sceneInnerSectionImageArea{
	order: 1;
}


/******
	pc
******/
@media screen and (min-width: 768px){
	.recommendArea__scene{
		flex-direction: row;
		justify-content:space-between;
    max-width: 600px;
    margin: 64px auto 0;
    padding: 0;
	}
	.recommendArea__sceneInner:not(:first-child){
		margin-top: 0;
		max-width: 280px;
	}


	.recommendArea__sceneInner:not(:first-child){
		margin-top: 0;
	}

	.recommendArea__sceneInnerSection{
		flex-direction: column;
	}


	.recommendArea__sceneInnerSectionTitle{
		margin-top: 32px;
		font-size: 20px;
		text-align: center;
	}

	.recommendArea__sceneInnerSectionImage{
		width: 200px;
		height: 200px;
	}



}

/****************************
	productListArea
*****************************/

.productListArea__title{
	margin-top: 48px;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
.productListArea__list{
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin: 24px auto 0;
}
.productListArea__card{
	width: calc(50% - 6px);
	background: #FFFFFF;
	border-radius: 12px;
}
.productListArea__cardLink{
	display: block;
}
.productListArea__cardInner{
	display: flex;
	flex-direction: column;
	padding: 28px 8px;
	text-align: center;
	height: 334px;
}
.productListArea__cardInnerImageArea{
	order:1;
}
.productListArea__cardInnerImage{
	width: 100px;
	height: auto;
}
.productListArea__cardInnerTitle{
	order:2;
	margin-top: 16px;
	color: #242323;
	font-size: 16px;
	font-weight: bold;
}
.productListArea__cardInnerText{
	order:3;
	margin-top: 12px;
	color: #606060;
	font-size: 12px;
	letter-spacing: 0;
	height: calc( 1.5em * 4 );
	text-align: left;
}
.productListArea__cardInnerButton{
	order:4;
	margin-top: auto;
}
.productListArea__cardInnerButtonInner{
	display: inline-block;
	background: #00C2C2;
	padding: 6px 24px;
	border-radius: 24px;
	color: #fff;;
	font-size: 16px;
}

/******
	pc
******/
@media screen and (min-width: 768px){
	.productListArea__title{
		font-size: 24px;
		margin-top: 56px;
	}
	.productListArea__list{
		gap: 24px;
		justify-content: center;
		margin: 32px auto 0;
		width: 780px;
	}
	.productListArea__list--col2{
		width: 512px;
	}
	.productListArea__card{
		width: 244px;
	}
	.productListArea__cardInner{
		height: auto;
		padding: 28px 12px;
	}
	.productListArea__cardInnerImage{
		width: 174px;
	}
	.productListArea__cardInnerTitle{
		font-size: 18px;
	}
	.productListArea__cardInnerText{
		font-size: 14px;
		height: calc( 1.5em * 3 );
	}
	.productListArea__cardInnerButton{
		margin-top: 16px;
	}
}

/******
	sp 320px
******/
@media screen and (max-width: 320px){
	.productListArea{
		padding-right: 8px;
		padding-left: 8px;
	}
	.productListArea__list{
		gap: 8px;
	}
	.productListArea__card{
		width: calc(50% - 4px);
	}
}


/****************************
	productList *削除可能（productListAreaに移行）
*****************************/

.productList__ListArea{
	margin-top: 40px;
	display: flex;
	overflow: scroll;
}

.productList__card{
	min-width: 244px;
	/*height: 400px;*/
	background: #FFFFFF;
	border-radius: 12px;
	margin-right: 24px;
}
.productList__card:last-child{
	margin-right: 0;
}
.productList__cardLink{
	display: block;
	height: 100%;
}
.productList__cardInner{
	display: flex;
	flex-wrap: wrap;
	padding:35px 14px;
	text-align: center;
}
.productList__cardInnerImage{
	order:1;
	width: 100%;
	text-align: center;
}
.productList__cardInnerTitle{
	width: 100%;
	order:2;
	margin-top: 16px;
	color: #242323;
	font-size: 18px;
	font-weight: bold;
}

.productList__cardInnerText{
	width: 100%;
	order:3;
	margin-top: 12px;
	color: #606060;
	font-size: 14px;
	letter-spacing: 0;
	height: calc( 1.5em * 3 );
}
.productList__cardInnerbutton{
	order:4;
	text-align: center;
	width: 100%;
	margin-top: 22px;
}
.productList__cardInnerbuttonInner{
	display: inline-block;
	background: #00C2C2;
	padding: 6px 24px;
	border-radius: 24px;
	color: #fff;;
	font-size: 16px;
}
.productList__controlButton{
	display: none;
}

/******
	pc
******/
@media screen and (min-width: 768px){

	.productList__inner{
		position: relative;
	}
	.productList__ListArea{
		margin-top: 80px;
		-ms-overflow-style: none;
		scrollbar-width: none;
	}
  .productList__ListArea::-webkit-scrollbar {
    display:none;
  }

	.productList__controlButton{
		display: inline-block;
		position: absolute;
		width: 68px;
		height: 68px;
		background: #00C2C2;
		border-radius: 68px;
	}
	.productList__controlButton:focus{
	    outline: none;
	    border: none;
	}

	.productList__controlButton span{
    position: absolute;
    top: -999em;
    left: -999em;
	}
	.productList__controlButton.disable{
		-webkit-filter: grayscale(100%);
		-moz-filter: grayscale(100%);
		-ms-filter: grayscale(100%);
		-o-filter: grayscale(100%);
		filter: grayscale(100%);
    opacity: 0.4;
	}

	.controlNext{
		top: calc(50% - 40px);
		right: -92px;
	}
	.controlPrev{
		top: calc(50% - 40px);
		left: -92px;
	}

	.controlNext::before, .controlNext::after, .controlPrev::before, .controlPrev::after {
	    content: "";
	    box-sizing: border-box;
	    position: absolute;
	    display: block;
	    width: 3px;
	    height: 16px;
	    border-radius: 2px;
	    background-color: #fff;
	    transform-origin: 50% 50%;
	}


	.controlNext::before, .controlNext::after {
	    right: calc(50% - 3.5px);
	}
	.controlPrev::before, .controlPrev::after {
	    left: calc(50% - 3.5px);
	}
	.controlNext::after, .controlPrev::after {
	    bottom: calc(50% - 3.5px);
	}
	.controlPrev::before, .controlPrev::after {
	    left: calc(50% - 3.5px);
	}
	.controlNext::after, .controlPrev::before {
	    transform: rotate(-45deg);
	}
	.controlNext::before, .controlPrev::after {
	    transform: rotate(45deg);
	}
	.controlNext::before, .controlPrev::before {
	    top: calc(50% - 3.5px);
	}

}


/****************************
	pointsArea
****************************/

.pointsArea__inner{
	margin-top: 40px;
	display: flex;
  flex-wrap: wrap;
}

.pointsArea__card{
	background: #F7F7F7;
	border-radius: 12px;
	width: calc(50% - 6px);
	padding:24px 12px;
	margin-bottom: 12px;
	text-align: center;
}
.pointsArea__card:nth-of-type(odd) {
	margin-right: 12px;
}
.pointsArea__card:nth-of-type(odd):last-child {
	margin-bottom: 0;
}


.pointsArea__TextAreaPoint{
	margin-top: 24px;
}
.pointsArea__TextAreaPointInner{
	display: inline-block;
	color: #fff;
	background: #FF7B46;
	padding:0 10px 0 12px;
	border-radius: 20px;
}
.pointsArea__TextAreaPointInnerText{
	font-weight: bold;
	font-size: 10px;
	margin-right: 5px;
	letter-spacing: 0;
}
.pointsArea__TextAreaPointInnerSum{
	font-weight: bold;
	font-size: 14px;
	letter-spacing: 0;
}
.pointsArea__cardImageArea{
  display: flex;
  align-items: center;
  justify-content: center;
}
.pointsArea__TextAreaTitle{
	margin-top: 8px;
	font-weight: bold;
	font-size: 16px;
	color: #242323;
}
.pointsArea__TextAreaTitleAsteriskArea{
	letter-spacing: -0.2;
  white-space: nowrap;
}
.pointsArea__TextAreaTitleAsterisk{
	font-weight: normal;
	font-size: 12px;
}
.pointsArea__TextAreaText{
	margin-top: 8px;
	font-size: 12px;
	color: #606060;
	height: calc( 1.5em * 3 );
	letter-spacing: 0;
}
/* iphone6より小さい時 */
@media screen and (max-width: 374px){
	.pointsArea{
		padding-right: 8px;
		padding-left: 8px;
	}
	.pointsArea__card{
		width: calc(50% - 4px);
		padding:24px 3px;
	}
	.pointsArea__card:nth-of-type(odd) {
		margin-right: 8px;
	}
	.pointsArea__TextAreaText{
		font-size: 11px;
	}
	.pointsArea__TextAreaTitle{
		letter-spacing: -0.6px;
	}
}
/* iphone6 plus以上の時 */
@media screen and (min-width: 414px){
	.pointsArea__TextAreaTitleAsteriskArea{
		letter-spacing: 0.5;
		white-space: normal;
	}
	}
	.pointsArea__Text{
		color: #606060;
		font-size: 12px;
	}

/******
	pc
******/
@media screen and (min-width: 768px){



	.pointsArea__inner{
		margin-top: 80px;
	}
	.pointsArea__card{
		width: calc(50% - 10px);
		margin-bottom: 20px;
	}
	.pointsArea__card:nth-of-type(odd) {
		margin-right: 20px;
	}

	.pointsArea__card{
		display: flex;
		text-align: left;
		padding:22px 32px;
	}

	.pointsArea__cardImageArea{
		flex-shrink: 0;
	}

	.pointsArea__TextArea{
		margin-left: 32px;
		letter-spacing: 0.5;
	}
	.pointsArea__TextAreaText{
		font-size: 14px;
	}
	.pointsArea__TextAreaPoint{
		margin-top: 0;
	}


	.pointsArea__Text{
		font-size: 14px;
	}
}


/****************************
	howToArea
****************************/

.howToArea{
	padding-bottom: 0;
}

.howToArea__inner{
	margin-top: 53px;
	text-align: center;
}

.howToArea__image{
	width: 100%;
	max-width:327px;
	height: auto;
}
.howToArea__text{
	color:#242323;
	margin-top:12px;
	font-size: 14px;
}
@media screen and (min-width: 768px){
	.howToArea__text{
		font-size: 18px;
	}
}
