@charset "UTF-8";
@font-face {
	font-family: 'SoDoSans SemiBold';
	font-style: normal;
	font-weight: 900;
	src: url("/common/fonts/SoDoSans/SoDoSans-SemiBold.woff") format("woff");
}
@font-face {
	font-family: 'SoDoSans Bold';
	font-style: normal;
	font-weight: 700;
	src: url("/common/fonts/SoDoSans/SoDoSans-Bold.woff") format("woff");
}

@media all and (min-width: 1230px) {
	body.live footer.global { margin-left: 120px; }
	aside.welcome { margin-left: 120px; }
}

.osIcon > a > img.forPc {
	display: inline;
}

@media (max-width: 909px){
	.osIcon > a > img.forPc {
		display: none;
	}
}

html {
  scroll-behavior: smooth;
}

div.mainContents {
	min-height: 0;
}
.pc_only {
	display: inline-block;
}
.sp_only {
	display: none;
}
@media all and (max-width: 1023px) {
	.pc_only {
		display: none;
	}
	.sp_only {
		display: inline-block;
	}
}

.module-header-display {
	justify-content: center !important;
}

/* live */
.live_inner {
	max-width: 100%;
	width: 100%;
	margin: 0 auto;
	overflow-x: hidden;
}
.live_area {
	margin-top: 60px;
	margin-bottom: 72px;
	border-bottom: 8px solid #EDEBE9;
}
.live_title {
	max-width: 1200px;
	width: calc(1200/1440*100vw);
	margin: 0 auto 60px;
	font-family: 'SoDoSans Bold', sans-serif;
	font-size: 28px;
	color: #010101;
	line-height: calc(24 / 28);
	font-weight: 700;
	text-align: left;
}
.live_block {
	background-color: #D4E9E2;
	padding: 15px 0;
}

/* howto */
.howto {
	max-width: 100%;
	width: 100%;
	border-bottom: 8px solid #EDEBE9;
	padding-bottom: 54px;
}
.howto_inner {
	max-width: 1200px;
	width: calc(1200 / 1440 * 100vw);
	margin: 0 auto;
}
.howto_title {
	font-family: 'SoDoSans Bold', sans-serif;
	font-size: 28px;
	color: #010101;
	line-height: calc(34/28);
	font-weight: 500;
	text-align: left;
	margin: 0 0 48px 0;
}
.howto_block {
	display: flex;
	justify-content: center;
	gap: 92px;
}
.howto_block .howto_item {
	max-width: 360px;
	width: 100%;
}
.howto_item_title {
	font-size: 18px;
	color: #010101;
	line-height: calc(26/18);
	font-weight: 700;
	text-align: left;
	margin: 0 0 14px;
	padding: 8px 0;
}
.howto_item_text {
	font-size: 15px;
	color: #010101;
	line-height: calc(24/15);
	margin: 0 0 15px;
}
.howto_item_text._mb {
	margin-bottom: 25px;
}
.howto_item_note {
	font-size: 11px;
	color: #606266;
	line-height: calc(16/11);
	margin: 0;
	text-indent: -1em;
	padding-left: 1em;
}
.howto_link_area {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin-top: 11px;
}
.howto_link_area .btn {
	font-size: 14px;
	font-weight: 500;
	color: #FFFFFF;
	line-height: calc(20/14);
	background-color: #00754A;
	border-radius: 16px;
	padding: 6px 32px 6px 16px;
	position: relative;
	opacity: 1;
	transition: opacity 0.3s ease;
}
.howto_link_area .btn::after {
	content: "";
	position: absolute;
	display: block;
	right: 15px;
	bottom: 9px;
	width: 7.5px;
	height: 13px;
	background-image: url("/onlinestore/live/images/arrow.png");
	background-repeat: no-repeat;
	background-size: contain;
}
.howto_link_area .btn:hover {
	opacity: 0.8;
	transition: opacity 0.3s ease;
}
.howto_link_area .link {
	font-size: 15px;
	font-weight: 500;
	color: #00754A;
	line-height: calc(21/15);
	margin-top: 14px;
	position: relative;
	opacity: 1;
	transition: opacity 0.3s ease;
}
.howto_link_area .link:hover {
	opacity: 0.8;
	transition: opacity 0.3s ease;
}
.howto_image {
	margin-bottom: 23px;
	margin-top: 7px;
	width: 100%;
}

.howto_caution {
	background-color: #F0F0F0;
	padding: 24px 24px;
	margin-top: 35px;
}
.howto_caution_title {
	font-size: 15px;
	color: #010101;
	line-height: calc(21/15);
	font-weight: 500;
	text-align: left;
	margin: 0 0 14px;
}
.howto_caution_text {
	font-size: 15px;
	color: #010101;
	line-height: calc(24/15);
	margin: 0 0 15px;
}
.howto_caution_note {
	font-size: 11px;
	color: #606266;
	line-height: calc(16/11);
	margin-top: 8px;
	margin: 0;
	text-indent: -1em;
	padding-left: 1em;
}

.sns_list {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 30px;
	margin-top: 36px;
}
.sns_item {
	width: 40px;
	height: 40px;
}
.sns_item:nth-child(2) {
	width: 35px;
	height: 35px;
}
.sns_item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.sns_item a {
	opacity: 1;
	transition: opacity 0.3s ease;
}
.sns_item a:hover {
	opacity: 0.8;
	transition: opacity 0.3s ease;
}

.archive {
	padding-bottom: 77px;
}
.archive_inner {
	max-width: 1200px;
	width: calc(1200/1440*100vw);
	margin: 0 auto;
}
.archive_title {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 24px;
	color: #010101;
	line-height: calc(35/24);
	font-weight: 700;
	text-align: left;
	margin: 64px 0 51px 0;
}

.recipe {
	background-color: #F5F5F5;	
	padding: 31px 0;
  border-bottom: 8px solid #EDEBE9;
}
.recipe_inner {
	max-width: 1200px;
	width: calc(1200/1440*100vw);
	margin: 0 auto;
}
.recipe_title {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 24px;
	color: #010101;
	line-height: calc(35/24);
	font-weight: 700;
	text-align: left;
	margin: 33px 0 51px 0;
}
.recipe_block {
	display: flex;
	gap: 92px;
}
.recipe_right {
	max-width: 340px;
	width: calc(340/1440*100vw);
}
.recipe_left {
	width: auto;
	flex: 1;
}
.recipe_item {
	margin: 0 0 26px 0;
}
.recipe_item_title {
	font-size: 15px;
	color: #010101;
	line-height: calc(24 / 15);
	margin: 0;
}
.recipe_item_text {
	font-size: 15px;
	color: #010101;
	line-height: calc(24 / 15);
	margin: 0;
}
.recipe_item_ingredients li {
	font-size: 15px;
	color: #010101;
	line-height: calc(24 / 15);
	margin: 0;
}
.recipe_item_steps li {
	font-size: 15px;
	color: #010101;
	line-height: calc(24 / 15);
	margin: 0;
}
.recipe li::before {
	content: "・";
	display: inline-block;
	width: 1em;
	color: #010101;
}

.faq {
	background-color: #fff;	
	padding: 31px 0 79px;
	border-top: 8px solid #EDEBE9;
}
.faq_inner {
	max-width: 1200px;
	width: calc(1200/1440*100vw);
	margin: 0 auto;
}
.faq_title {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 24px;
	color: #010101;
	line-height: calc(35/24);
	font-weight: 700;
	text-align: left;
	margin: 33px 0 51px 0;
}
.faq_block {
	display: flex;
	flex-direction: column;
}
.faq_item {
	display: flex;
	flex-direction: column;
  border-top: 4px solid #EDEBE980;
}
.faq_item_title_area,
.faq-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	width: 100%;
  padding: 11px 0 13px 48px;
  border-top: 4px solid #EDEBE980;
  position: relative;
}
.faq_item_title {
	font-size: 15px;
  font-weight: 700;
	color: rgba(0, 0, 0, 0.87);
	line-height: calc(20 / 15);
	margin: 0;
  position: relative;
}
.faq_item_title::after {
	content: "";
	position: absolute;
  top: -5px;
  left: -48px;
	width: 32px;
	height: 32px;
	background-image: url("/onlinestore/live/images/icon_question.png");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
}
.faq_item_title_arrow {
	width: 32px;
	height: 32px;
	transition: transform 0.2s ease-out;
  position: relative;
  top: -4px;
  left: -48px;
}
.faq_item_title_arrow img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.faq_item.is_open .faq_item_title_arrow,
.faq_item_title_area.is-active .faq_item_title_arrow,
.faq-header.is-active .faq_item_title_arrow {
	transform: rotate(180deg);
}
.faq_item_text_area,
.faq-body {
  max-height: 0;
  position: relative;
  overflow: hidden;
}
.faq-body-inner {
  padding: 11px 172px 47px 48px;
}
.faq_item.is_open .faq_item_text_area,
.faq_item_title_area.is-active + .faq_item_text_area,
.faq-header.is-active + .faq-body {
	/* padding-top: 11px;
	padding-bottom: 47px; */
}
.faq_item_text { 
  font-size: 15px;
  font-weight: 500;
  color: rgba(0, 0, 0, 0.87);
  line-height: calc(20 / 15);
  margin: 0;
  position: relative;
}
.faq_item_text::before {
	content: "";
	position: absolute;
	top: -3px;
	left: -48px;
	width: 32px;
	height: 32px;
	background-image: url("/onlinestore/live/images/icon_answer.png");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
}

/* 追従バナー */
.faq_fixed_banner_area {
	position: relative;
}
.faq_fixed_banner {
  position: fixed;
  bottom: 24px;
  right: 24px;
  background-color: #fff;
  color: #010101;
  font-size: 16px;
  font-weight: 700;
  line-height: calc(27 / 16);
  padding: 14px 23px;
  border-radius: 28px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  text-decoration: none;
  z-index: 1000;
  opacity: 1;
  transition: opacity 0.3s ease, transform 0.3s ease;
  display: inline-block;
}
.faq_fixed_banner:hover {
	opacity: 0.8;
	transform: translateY(-2px);
	transition: opacity 0.3s ease, transform 0.3s ease;
}
.faq_fixed_banner.is_hidden {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}


/* バナー */
body.live .bnr {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 1200px;
	width: calc(1200/1440*100vw);
	margin: 0 auto 40px;
	padding-top: 64px;
	gap: min(40px,calc(40/1440*100vw));
}
body.live .bnr a {
	display: inline-block;
	max-width: 580px;
	width: calc(580/1440*100vw);
	background-color: #F5F5F5;
	border-radius: 10px;
	overflow: hidden;
	opacity: 1;
	transition: opacity 0.3s ease;
}
body.live .bnr a:hover {
	opacity: 0.8;
	transition: opacity 0.3s ease;
}

body.live .bnr img {
	border-radius: 10px;
}

@media all and (max-width: 1023px) {
	/* live */
	.live_inner {
		max-width: 100%;
		width: 100%;
	}
	.live_area {
		margin-top: 39.5px;
		margin-bottom: 38px;
	}
	.live_title {
		font-family: 'SoDoSans Bold', sans-serif;
		font-size: 20px;
		color: #010101;
		line-height: calc(24/20);
		font-weight: 700;
		text-align: left;
		margin-left: 16.5px;
		margin-bottom: 33.5px;
		max-width: 100%;
		width: 100%;
	}
	.live_block {
		padding: 0;
	}

	/* howto */
	.howto {
		margin-bottom: 38.5px;
		padding-bottom: 50px;
	}
	.howto_inner {
    max-width: 100%;
		width: calc(687 / 750 * 100vw);
    margin: 0 auto;
	}
	.howto_title {
		font-size: 20px;
		line-height: calc(24/20);
		margin: 0 0 40px 0;
	}
	.howto_block {
		flex-direction: column;
		gap: 54px;
	}
	.howto_block .howto_item {
		max-width: 100%;
		width: 100%;
	}
	.howto_item_title {
		font-size: 18px;
		line-height: calc(26/18);
		margin: 0 0 13.5px;
		padding: 9px 0;
	}
	.howto_item_text {
		width: calc(687/750*100vw);
		font-size: 13px;
		line-height: calc(22/13);
		margin: 0 auto 15px;
	}
	.howto_item_note {
		width: 100%;
		font-size: 11px;
		line-height: calc(16 / 11);
		margin: 0 auto;
	}
	.howto_link_area {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		margin-top: 5px;
	}
	.howto_link_area .btn {
		font-size: 15.5px;
		line-height: calc(45/31);
		border-radius: 16px;
		padding: 5px 31px 5px 16px;
	}
	.howto_link_area .btn::after {
		content: "";
		position: absolute;
		display: block;
		right: 14.5px;
		bottom: 9px;
		width: 8.5px;
		height: 14.5px;
		background-image: url("/onlinestore/live/images/arrow.png");
		background-repeat: no-repeat;
		background-size: contain;
	}
	.howto_link_area .link {
		font-size: 13px;
		line-height: calc(19/13);
		margin-top: 17.5px;
	}
	.howto_image_area {
		width: calc(687/750*100vw);
		margin: 0 auto;
	}
	.howto_image {
		margin-bottom: 22px;
	}

	.howto_caution {
		background-color: #F0F0F0;
		padding: 25px;
		margin-bottom: 0;
		margin-top: 36px;
	}
	.howto_caution_title {
		font-size: 13px;
		line-height: calc(19/13);
		margin: 0 0 12px;
	}
	.howto_caution_text {
		font-size: 13px;
		line-height: calc(22/13);
		margin: 0 0 15px;
	}
	.howto_caution_note {
		font-size: 11px;
		line-height: calc(16/11);
		margin-top: 8px;
		margin: 0;
	}

	.sns_list {
		gap: 30px;
		margin-top: 31px;
	}
	.sns_item {
		width: 40px;
		height: 40px;
	}
	.sns_item:nth-child(2) {
		width: 35px;
		height: 35px;
	}

	.archive {
		/* margin-bottom: 42.5px; */
		padding-bottom: 49px;
	}
	.archive_inner {
		max-width: 100%;
		width: 100%;
		margin: 0 auto;
	}
	.archive_title {
		font-size: 18px;
		line-height: calc(28/18);
		margin: 0 0 47.5px 17px;
	}

	.recipe {
		background-color: #F5F5F5;	
		padding: 38.5px 0 23px;
		margin-bottom: 38.5px;
	}
	.recipe_inner {
		max-width: 100%;
		width: calc(687/750*100vw);
		margin: 0 auto;
	}
	.recipe_title {
		font-size: 18px;
		line-height: calc(28/18);
		margin: 0 0 44px 0;
	}
	.recipe_block {
		display: flex;
		flex-direction: column;
		gap: 0;
	}
	.recipe_right {
		width: 100%;
	}
	.recipe_left {
		width: 100%;
    margin-top: 12px;
	}
	.recipe_item {
		margin: 0 0 23.5px 0;
	}
	.recipe_item_title {
		font-size: 13px;
		line-height: calc(22 / 13);	
	}
	.recipe_item_text {
		font-size: 13px;
		line-height: calc(22 / 13);	
	}
	.recipe_item_ingredients li {
		font-size: 13px;
		line-height: calc(22 / 13);	
	}
	.recipe_item_steps li {
		font-size: 13px;
		line-height: calc(22 / 13);	
	}
	.recipe li::before {
		content: "・";
		display: inline-block;
		width: 1em;
		color: #010101;
	}

  .faq {
    padding: 47px 0 49px;
    overflow: hidden;
  }
  .faq_inner {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
  }
  .faq_title {
    font-size: 18px;
    line-height: calc(28/18);
    margin: 0 0 49px 0;
    padding-left: 15px;
  }
  .faq_block {
    display: flex;
    flex-direction: column;
  }
  .faq_item {
    display: flex;
    flex-direction: column;
    border-top: 4px solid #EDEBE980;
  }
  .faq_item_title_area,
  .faq-header {
    padding: 14px 0 15px 61px;
    border-top: 4px solid #EDEBE980;
  }
  .faq_item_title {
    font-size: 13px;
    line-height: calc(22 / 13);
  }
  .faq_item_title_arrow {
    width: 32px;
    height: 32px;
    top: -1px;
    left: -80px;
  }
  .faq_item_text_area,
  .faq-body {
    max-height: 0;
    overflow: hidden;
  }
  .faq_item_text {
    font-size: 13px;
    line-height: calc(22 / 13);
  }
  .faq_item_text::before {
    width: 32px;
    height: 32px;
  }
  .faq_item.is_open .faq_item_text_area,
  .faq_item_title_area.is-active + .faq_item_text_area,
  .faq-header.is-active + .faq-body {
    /* padding-top: 20px;
    padding-bottom: 38px; */
  }
  .faq-body-inner {
    padding: 20px 16px 38px 61px;
  }

  .faq_fixed_banner {
    bottom: 24px;
    right: 15px;
  }
  .faq_fixed_banner:hover {
    opacity: 1;
  }

body.live .bnr {
		max-width: 100%;
		width: calc(667/750*100vw);
		gap: calc(40/750*100vw);
		padding-top: 0;
		margin: 0 auto calc(100/750*100vw);
	}
	body.live .bnr a {
		max-width: 100%;
		width: 100%;
	}
	body.live .bnr img {
		border-radius: 10px;
		width: 100%;
	}
}
