@charset "utf-8";

.c-hdg--lv1,
.c-detail-hdg--lv2 { color: #e4002b; }

.c-detail-visual-main__img {
	/*background: #FCFBF4;*/
	background: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.c-detail-visual-main__img img { max-width: 100%; }

@media screen and (min-width: 769px) {
	/* top */
	.slick-slider,
	.slick-track,
	.slick-list,
	.slick-slide {
		all: initial;
		font-size: 26px;
	}
	#top-visual {
		width: 774px;
		height: 360px;
		margin: 0 auto;
		position: relative;
		background: #fff;
		overflow: hidden;
	}
	#top-visual .slide {
		margin: 0 10px;
		position: relative;
		transition: opacity .2s;
	}
	#top-visual .slide:hover { opacity: .7; }
	#top-visual .slide.mayonnaise::after {
		content: "";
		width: 63px;
		height: 138px;
		background: url("../../../assets/img/project/products/recipes/common/mayonnaise450.png") no-repeat center / 100%;
		display: block;
		position: absolute;
		left: 56px;
		top: 200px;
	}
	#top-visual .slide.sesame::after {
		content: "";
		width: 53px;
		height: 138px;
		background: url("../../../assets/img/project/products/recipes/common/deep-roasted-sesame-dressing.png") no-repeat center / 100%;
		display: block;
		position: absolute;
		left: 56px;
		top: 200px;
	}
	#top-visual .slide img { width: 100%; }
	.slick-prev {
		width: 30px;
		height: 30px;
		position: absolute;
		bottom: 15px;
		left: 130px;
		transform: rotate(180deg);
		z-index: 2;
	}
	.slick-next {
		width: 30px;
		height: 30px;
		position: absolute;
		bottom: 15px;
		right: 130px;
		z-index: 2;
	}
	
	#top-sort-products {
		width: 774px;
		height: 72px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		flex-wrap: wrap;
		margin: 24px 0;
	}
	#top-sort-products span {
		width: 245px;
		height: 72px;
		border: 1px solid #ddd;
		position: relative;
		font-size: 15px;
		font-weight: bold;
		line-height: 1.4;
		color: #E4002B;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
		text-align: center;
		letter-spacing: 0;
		cursor: pointer;
		transition: opacity .2s;
	}
	#top-sort-products span:hover { opacity: .7; }
	#top-sort-products span:nth-of-type(2) {
		text-align: left;
		padding: 0 32px 0 48px;
	}
	#top-sort-products span:nth-of-type(3) {
		text-align: left;
		padding: 0 26px 0 54px;
	}
	#top-sort-products span::after {
		content: "";
		width: 8px;
		height: 8px;
		border-top: 1px solid #E4002B;
		border-right: 1px solid #E4002B;
		transform: rotate(45deg);
		position: absolute;
		right: 16px;
		top: calc(50% - 4px);
	}
	#top-sort-products span:nth-of-type(2)::before {
		content: "";
		width: 27px;
		height: 60px;
		background: url("../../../assets/img/project/products/recipes/common/mayonnaise450.png") no-repeat center / 100%;
		position: absolute;
		left: 16px;
		top: calc(50% - 30px);
	}
	#top-sort-products span:nth-of-type(3)::before {
		content: "";
		width: 23px;
		height: 60px;
		background: url("../../../assets/img/project/products/recipes/common/deep-roasted-sesame-dressing.png") no-repeat center / 100%;
		position: absolute;
		left: 16px;
		top: calc(50% - 30px);
	}
	#top-sort-cat {
		width: 774px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		flex-wrap: wrap;
	}
	#top-sort-cat span {
		width: 183px;
		height: 38px;
		border: 1px solid #E4002B;
		border-radius: 19px;
		color: #E4002B;
		font-size: 13px;
		font-weight: bold;
		position: relative;
		text-align: center;
		line-height: 36px;
		margin: 8px 0;
		letter-spacing: 0;
		cursor: pointer;
		transition: opacity .2s;
	}
	#top-sort-cat span:hover { opacity: .7; }
	#top-sort-cat span::after {
		content: "";
		width: 4px;
		height: 4px;
		border-top: 1px solid #E4002B;
		border-right: 1px solid #E4002B;
		transform: rotate(45deg);
		position: absolute;
		right: 16px;
		top: calc(50% - 2px);
	}
	#top-recipe {
		width: 774px;
		display: flex;
		justify-content: flex-start;
		align-items: flex-start;
		flex-wrap: wrap;
	}
	#top-recipe .recipe {
		width: 230px;
		margin-top: 24px;
	}
	#top-recipe .recipe:nth-of-type(3n - 1) { margin: 24px 42px 0; }
	#top-recipe .recipe a {
		display: block;
		transition: opacity .2s;
	}
	#top-recipe .recipe a .img {
		width: 230px;
		height: 145px;
		overflow: hidden;
		margin-bottom: 8px;
	}
	#top-recipe .recipe a .img img { width: 100%; }
	#top-recipe .recipe a:hover img { opacity: .7; }
	#top-recipe .recipe a .recipe_title {
		padding-left: 16px;
		width: 230px;
		line-height: 1.4;
		position: relative;
	}
	#top-recipe .recipe a .recipe_title::before {
		content: "";
		width: 4px;
		height: 4px;
		border-top: 1px solid #E4002B;
		border-right: 1px solid #E4002B;
		transform: rotate(45deg);
		display: block;
		position: absolute;
		left: 0;
		top: 0.5em;
	}
	#top-recipe .recipe .tag {
		height: 26px;
		border: 1px solid #E4002B;
		border-radius: 13px;
		line-height: 24px;
		padding: 0 8px;
		color: #E4002B;
		font-size: 13px;
		font-weight: bold;
		display: inline-block;
		margin-top: 8px;
		cursor: pointer;
		transition: opacity .2s;
	}
	#top-recipe .recipe .tag:hover { opacity: .7; }
	
	
	/* recipe detail */
	.c-detail-hdg--lv2 {
		margin: 0;
		font-size: 20px;
		line-height: 1.6;
	}
	.content-wrapper { padding: 24px 0; }
	.c-detail-visual-main {
		width: 774px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		flex-wrap: wrap;
	}
	.c-detail-visual-main__img {
		order: 1;
		width: 560px;
		height: 370px;
		overflow: hidden;
	}
	.c-detail-visual-main__detail {
		width: 180px;
		height: 370px;
		border-top: 1px dashed #e4002b;
		border-bottom: 1px dashed #e4002b;
		padding: 112px 0 16px;
		font-size: 12px;
		display: flex;
		justify-content: center;
		align-items: flex-end;
		flex-wrap: wrap;
		text-align: center;
		order: 2;
	}
	.c-detail-visual-main__detail p { margin: 0; }
	.c-detail-visual-main__detail .products {
		width: 180px;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
		text-align: center;
	}
	.c-detail-visual-main__detail .products a img {
		display: inline-block;
		height: 162px;
	}
	.c-detail-visual-main__detail .products a + a { margin-left: 16px; }
	.c-detail-visual-main__txt {
		order: 3;
		padding: 16px 0 0;
	}
	
	.c-detail-info-list {
		background: #f9f9f9;
		line-height: 1.7;
		margin-top: 24px;
	}
	.c-detail-info-list .c-detail-info-flex_itm { padding: 0 35px; }
	.c-detail-info-list .c-detail-info-flex_itm:nth-child(odd) { border-right: solid 1px #dddddd; }
	.c-detail-info-list .c-detail-info-cont {
		border-top: solid 2px #e4002b;
		padding-top: 10px;
		width: 320px;
	}
	
	.c-detail-info-list .p-recipe-tbl tr {
		display: table-row;
		border-bottom: dashed #dedede 1px;
	}
	.c-detail-info-list .p-recipe-tbl { font-size: 15px; }
	.c-detail-info-list .p-recipe-tbl tr { height: 45px; }
	.c-detail-info-list .p-recipe-tbl th { width: 167px; padding-right: 10px; }
	.c-detail-info-list .p-recipe-tbl .c-detail-data {
		width: 85px;
		border-right: dashed #dedede 1px;
		vertical-align: middle;
		padding-right: 5px;
		font-size: 80%;
	}
	.c-detail-info-list .p-recipe-tbl .c-detail-sub {
		padding-left: 8px;
		font-size: 80%;
	}
	.c-detail-lyt p { margin: 10px 0; }
	.p-recipe-txt {
		width: 100%;
		padding-left: 30px;
		font-size: 15px;
		line-height: 1.6;
	}
	.p-recipe-txt .r-num { font-size: 24px; }
	.p-recipe-txt.no_none { padding-left: 0; }
	
	.other_recipe {
		width: 100%;
		background: url("/en/assets/img/project/products/recipes/common/dot-background.png") repeat left / 12px;
		padding: 24px 0;
	}
	#other_recipe_random + h2 {
		padding-top: 24px;
		margin-top: 24px;
		border-top: 24px solid #fff;
	}
	.other_recipe h2 {
		font-size: 19px;
		text-align: center;
		margin: 0;
		color: #E4002B;
	}
	#other_recipe_random {
		width: 560px;
		margin: 24px auto 0;
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		flex-wrap: wrap;
	}
	#other_recipe_random a {
		width: 128px;
		display: block;
	}
	#other_recipe_random a:nth-of-type(5) { display: none; }
	#other_recipe_random a .img {
		width: 128px;
		height: 88px;
		overflow: hidden;
		margin: 0 0 8px;
	}
	#other_recipe_random a .img img { width: 100%; }
	#other_recipe_random a span {
		font-size: 12px;
		padding-left: 16px;
		position: relative;
		display: block;
		line-height: 1.6;
	}
	#other_recipe_random a span::before {
		content: "";
		width: 5px;
		height: 5px;
		border-top: 1px solid #E4002B;
		border-right: 1px solid #E4002B;
		transform: rotate(45deg);
		position: absolute;
		top: 6px;
		left: 0;
	}
	.c-btn-list__itm__link {
		position: relative;
		font-weight: bold;
		width: 240px;
		height: 32px;
		border-radius: 16px;
		display: block;
		margin: 0 auto;
	}
}
@media (max-width: 768px) {
	/* top */
	.slick-slider,
	.slick-track,
	.slick-list,
	.slick-slide {
		all: initial;
		font-size: 2vw;
	}
	#top-visual {
		width: 100vw;
		height: 50vw;
		margin-left: -5.33333vw;
		position: relative;
		background: #fff;
		overflow: hidden;
	}
	#top-visual .slide {
		margin: 0 2vw;
		position: relative;
	}
	#top-visual .slide.mayonnaise::after {
		content: "";
		width: 9.6vw;
		height: 21vw;
		background: url("../../../assets/img/project/products/recipes/common/mayonnaise450.png") no-repeat center / 100%;
		display: block;
		position: absolute;
		left: 11vw;
		top: 27vw;
	}
	#top-visual .slide.sesame::after {
		content: "";
		width: 8.1vw;
		height: 21vw;
		background: url("../../../assets/img/project/products/recipes/common/deep-roasted-sesame-dressing.png") no-repeat center / 100%;
		display: block;
		position: absolute;
		left: 11vw;
		top: 27vw;
	}
	#top-visual .slide img {
		width: 100%;
		display: block;
	}
	.slick-prev {
		width: 8vw;
		height: 8vw;
		position: absolute;
		bottom: 2vw;
		left: 12vw;
		transform: rotate(180deg);
		z-index: 2;
	}
	.slick-next {
		width: 8vw;
		height: 8vw;
		position: absolute;
		bottom: 2vw;
		right: 12vw;
		z-index: 2;
	}
	
	#top-sort-products {
		width: 100%;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		flex-wrap: wrap;
		margin: 6.4vw 0;
	}
	#top-sort-products span {
		width: 43.5vw;
		height: 12.8vw;
		border: 0.4vw solid #ddd;
		position: relative;
		font-size: 3.2vw;
		font-weight: bold;
		line-height: 1.4;
		color: #E4002B;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
		text-align: center;
		letter-spacing: 0;
		cursor: pointer;
	}
	#top-sort-products span:nth-of-type(even) { margin-left: 2.33vw; }
	#top-sort-products span:nth-of-type(2) {
		text-align: left;
		padding: 0 4vw 0 8vw;
		margin-top: 2vw;
	}
	#top-sort-products span:nth-of-type(3) {
		text-align: left;
		padding: 0 2vw 0 10vw;
		margin-top: 2vw;
	}
	#top-sort-products span::after {
		content: "";
		width: 1.6vw;
		height: 1.6vw;
		border-top: 0.4vw solid #E4002B;
		border-right: 0.4vw solid #E4002B;
		transform: rotate(45deg);
		position: absolute;
		right: 2vw;
		top: calc(50% - 1vw);
	}
	#top-sort-products span:nth-of-type(2)::before {
		content: "";
		width: 4.68vw;
		height: 10.4vw;
		background: url("../../../assets/img/project/products/recipes/common/mayonnaise450.png") no-repeat center / 100%;
		position: absolute;
		left: 2vw;
		top: calc(50% - 5.2vw);
	}
	#top-sort-products span:nth-of-type(3)::before {
		content: "";
		width: 3.98vw;
		height: 10.4vw;
		background: url("../../../assets/img/project/products/recipes/common/deep-roasted-sesame-dressing.png") no-repeat center / 100%;
		position: absolute;
		left: 2vw;
		top: calc(50% - 5.2vw);
	}
	#top-sort-cat {
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
		flex-wrap: wrap;
	}
	#top-sort-cat span {
		width: 43.5vw;
		height: 9vw;
		border: 0.24vw solid #E4002B;
		border-radius: 4.5vw;
		color: #E4002B;
		font-size: 3.2vw;
		font-weight: bold;
		position: relative;
		text-align: center;
		line-height: 8.52vw;
		margin: 1.5vw 0;
		letter-spacing: 0;
		cursor: pointer;
	}
	#top-sort-cat span::after {
		content: "";
		width: 1vw;
		height: 1vw;
		border-top: 0.32vw solid #E4002B;
		border-right: 0.32vw solid #E4002B;
		transform: rotate(45deg);
		position: absolute;
		right: 3.2vw;
		top: calc(50% - 0.66vw);
	}
	#top-recipe {
		width: 100%;
		display: flex;
		justify-content: flex-start;
		align-items: flex-start;
		flex-wrap: wrap;
	}
	#top-recipe .recipe {
		width: 41.6vw;
		margin-top: 8vw;
	}
	#top-recipe .recipe:nth-of-type(even) { margin-left: 6.1vw; }
	#top-recipe .recipe a { display: block; }
	#top-recipe .recipe a .img {
		width: 41.6vw;
		height: 26vw;
		overflow: hidden;
		margin-bottom: 2.4vw;
	}
	#top-recipe .recipe a .img img { width: 100%; }
	#top-recipe .recipe a .recipe_title {
		padding-left: 4.26vw;
		width: 41.6vw;
		line-height: 1.4;
		position: relative;
	}
	#top-recipe .recipe a .recipe_title::before {
		content: "";
		width: 1vw;
		height: 1vw;
		border-top: 0.32vw solid #E4002B;
		border-right: 0.32vw solid #E4002B;
		transform: rotate(45deg);
		display: block;
		position: absolute;
		left: 0;
		top: 0.5em;
	}
	#top-recipe .recipe .tag {
		height: 6.4vw;
		border: 0.24vw solid #E4002B;
		border-radius: 3.2vw;
		line-height: 5.92vw;
		padding: 0 2vw;
		color: #E4002B;
		font-size: 3.2vw;
		font-weight: bold;
		display: inline-block;
		margin-top: 2.4vw;
		cursor: pointer;
	}
	
	
	/* recipe detail */
	.c-detail-hdg--lv2 {
		margin: 0;
		font-size: 4.8vw;
		line-height: 1.6;
	}
	.content-wrapper { padding: 8vw 0; }
	.c-detail-visual-main__img { width: 100%; }
	.c-detail-visual-main__detail {
		border-top: 0.24vw dashed #e4002b;
		border-bottom: 0.24vw dashed #e4002b;
		padding: 4vw 0;
		font-size: 3.2vw;
		position: relative;
	}
	.c-detail-visual-main__detail p {
		width: 24vw;
		margin: 0;
		position: absolute;
		left: 0;
		top: 2.4vw;
	}
	.c-detail-visual-main__detail .products {
		width: 100%;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
	}
	.c-detail-visual-main__detail .products a + a { margin-left: 2vw; }
	.c-detail-visual-main__detail a img {
		display: inline-block;
		height: 42vw;;
	}
	.c-detail-visual-main__txt { padding: 2.4vw 0; }
	
	.c-detail-info-list {
		background: #f9f9f9;
		line-height: 1.7;
		margin-top: 6.4vw;
	}
	.c-detail-info-list .c-detail-info-flex_itm { padding: 6vw 4vw; }
	.c-detail-info-list .c-detail-info-cont {
		border-top: solid 0.5vw #e4002b;
		width: 80vw;
		padding-top: 4.8vw;
	}
	
	.c-detail-info-list .p-recipe-tbl tr {
		display: table-row;
		border-bottom: dashed #dedede 0.25vw;
	}
	.c-detail-info-list .c-detail-info-flex_itm { padding: 6vw 4vw; }
	.c-detail-info-list .p-recipe-tbl { font-size: 3.2vw; }
	.c-detail-info-list .p-recipe-tbl tr { height: 13vw; }
	.c-detail-info-list .p-recipe-tbl th { width: 56vw; padding-right: 2.4vw; }
	.c-detail-info-list .p-recipe-tbl .c-detail-data {
		width: 28vw;
		padding-right: 0;
		border-right: dashed #dedede 0.25vw;
		vertical-align: middle;
		font-size: 80%;
	}
	.c-detail-info-list .p-recipe-tbl .c-detail-sub {
		width: 18vw;
		padding-left: 2.4vw;
		font-size: 80%;
	}
	.c-detail-lyt p { margin: 0 0 4vw; }
	.p-recipe-txt {
		width: 100%;
		padding-left:4vw;
	}
	.p-recipe-txt .r-num {
		font-size:4.2vw;
		top: 0.8vw;
	}
	.p-recipe-txt.no_none { padding-left: 0; }
	
	.other_recipe {
		width: 100vw;
		background: url("/en/assets/img/project/products/recipes/common/dot-background.png") repeat left / 4vw;
		padding: 8vw 0;
		margin: 0 0 0 -5vw;
	}
	#other_recipe_random + h2 {
		padding-top: 8vw;
		margin-top: 8vw;
		border-top: 4vw solid #fff;
	}
	.other_recipe h2 {
		width: 100vw;
		font-size: 5vw;
		text-align: center;
		margin: 0;
		padding: 0 5vw;
		color: #E4002B;
	}
	#other_recipe_random {
		width: 90vw;
		margin: 8vw auto 0;
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		flex-wrap: wrap;
	}
	#other_recipe_random a {
		width: 43vw;
		display: block;
	}
	#other_recipe_random a:nth-of-type(5) { display: none; }
	#other_recipe_random a:nth-of-type(3),
	#other_recipe_random a:nth-of-type(4) { margin-top: 6.4vw; }
	#other_recipe_random a .img {
		width: 43vw;
		height: 28vw;
		overflow: hidden;
		margin: 0 0 1vw;
	}
	#other_recipe_random a .img img { width: 100%; }
	#other_recipe_random a span {
		font-size: 3.6vw;
		padding-left: 3.6vw;
		position: relative;
		display: block;
		line-height: 1.6;
	}
	#other_recipe_random a span::before {
		content: "";
		width: 1.36vw;
		height: 1.36vw;
		border-top: 0.24vw solid #E4002B;
		border-right: 0.24vw solid #E4002B;
		transform: rotate(45deg);
		position: absolute;
		top: 1.8vw;
		left: 0;
	}
}

.c-detail-lyt {
	display: flex;
	flex-wrap: wrap;
}
.c-detail-info-list .p-recipe-tbl {
	width: 100%;
	vertical-align: middle;
}
.c-detail-info-list .p-recipe-tbl a { text-decoration: underline; }
.c-detail-info-list .p-recipe-tbl tr:last-child { border-bottom: 0; }
.c-detail-info-list .p-recipe-tbl th {
	text-align: left;
	font-weight: normal;
	vertical-align: middle;
}
.p-recipe-txt {
	position: relative;
	box-sizing: border-box;
}
.p-recipe-txt .r-num {
	color: #e4002b;
	position: absolute;
	left: 0;
	line-height: 1;
}


