/*============================
基本設定
============================*/
main {
	max-width: 1440px;
	box-sizing: border-box;
	padding: 0 40px;
	margin: auto;
}

@media screen and (max-width: 768px) {
	main {
		padding: 0;
	}
}

/* 高さが650以下の場合 */
main.small_height {
	max-width: 1080px;
}
main.small_height .pc_contents .in {
	width: 100%;
	max-width: 1080px;
}
main.small_height .pc_contents .in .cont_wrap {
	min-width: 640px;
}

main.small_height .pc_contents .in .pc_mv_wrap {
	height: calc(100% - 2.80rem);
}

main.small_height .pc_contents .in .pc_bottom_cont_wrap {
	height: 2.80rem;
	padding-bottom: 0.20rem;
}

.sp_contents {
	width: 100%;
	max-width: 410px;
	position: relative;
	margin-left: auto;
	z-index: 1;
	background-color: #FFF;
	box-shadow: 0 0 0.10rem rgba(0,0,0,0.2);
}

@media screen and (max-height: 850px) {
	.sp_contents {
		max-width: 390px;
	}
}

@media screen and (max-height: 800px) {
	.sp_contents {
		max-width: 375px;
	}
}

@media screen and (max-width: 768px) {
	.sp_contents {
		max-width: 100%;
	}
}

/*============================
PC用
============================*/
.pc_contents {
	position: fixed;
	height: 100vh;
	min-height: 600px;
	width: 100%;
	left: 0;
	top: 0;
	z-index: 1;
	min-width: 1080px;
}

.pc_contents::before {
	content: "";
	width: 100%;
	background-color: var(--color-red01);
	height: 0.66rem;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}

.pc_contents .in {
	width: 100%;
	height: 100%;
	max-width: 1440px;
	margin: auto;
	position: relative;
	z-index: 0;
	padding-top: 0.95rem;
	box-sizing: border-box;
}

.pc_contents .in .cont_wrap {
	/* width: calc(100% - 4.40rem); */
	height: 100%;
	position: relative;
	box-sizing: border-box;
	padding-right: 0.40rem;
}

/* @media print,
screen and (min-width:1366px) and (max-width:1439px) {
	.pc_contents .in .cont_wrap {
		width: calc(100% - 4.90rem);
	}
}

@media print,
screen and (min-width:1280px) and (max-width:1365px) {
	.pc_contents .in .cont_wrap {
		width: calc(100% - 5.20rem);
	}
}

@media print,
screen and (min-width:769px) and (max-width:1279px) and (min-height: 771px) {
	.pc_contents .in .cont_wrap {
		width: calc(100% - 5.60rem);
	}
} */

@media print,
screen and (max-height: 770px) {
	.pc_contents .in {
		max-width: 1280px;
	}
	/* .sp_contents {
	margin-right: 0.80rem;
	} */
}



/* 上段スライドショー */
.pc_contents .in .cont_wrap .pc_mv_wrap {
	height: calc(100% - 3.50rem);
	overflow: hidden;
	position: relative;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slides {
	width: 100%;
	height: 100%;
	overflow: hidden;
	position: relative;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slides .slide {
	width: 100%;
	height: 100%;
	overflow: hidden;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slick-slider .slick-track, .slick-slider .slick-list {
	height: 100%;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slick-track {
	display: flex;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slick-track::before,
.pc_contents .in .cont_wrap .pc_mv_wrap .slick-track::after {
	content: none;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slick-slide {
	height: auto;
	float: none;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slick-slide > div {
	height:100%;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .slides .slide img {
	display: block;
	width: 100%;
	height: 100%;
	/* max-height: 7.00rem;
	min-height: 4.70rem; */
	object-fit: cover;
}

/* MVキャッチ */
.pc_contents .in .cont_wrap .pc_mv_wrap .pc_mv_catch {
	width: 84%;
	position: absolute;
	top: 0.40rem;
	left: 0.40rem;
	z-index: 1;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .pc_mv_bottom_box_wrap {
	position: absolute;
	left: 0.30rem;
	bottom: 0.30rem;
	width: calc(100% - 0.60rem);
	z-index: 1;
	display: flex;
	justify-content: space-between;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .pc_mv_bottom_box_wrap .pc_mv_bottom_box {
	width: 32%;
	background-color: var(--color-red01);
	padding: 0.15rem 0;
	border-radius: 0.15rem;
	position: relative;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .pc_mv_bottom_box_wrap .pc_mv_bottom_box::after {
	content: "";
	width: 1.00rem;
	height: 0.12rem;
	background-image: url(../img/pc_mv_box_deco.svg);
	background-position: right top;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	bottom: -0.12rem;
	right: 0.40rem;
}

.pc_contents .in .cont_wrap .pc_mv_wrap .pc_mv_bottom_box_wrap .pc_mv_bottom_box img {
	display: block;
	height: 0.50rem;
	margin: auto;
}

/* PC 下部コンテンツ */
.pc_bottom_cont_wrap {
	padding: 0.25rem 0 0.40rem;
	display: flex;
	justify-content: space-between;
	height: 3.50rem;
	box-sizing: border-box;
}

.pc_bottom_cont_wrap .pc_mov_wrap {
	width: 56.45%;
	border: 3px solid var(--color-red01);
	border-radius: 0.16rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.20rem;
	box-sizing: border-box;
}

.pc_bottom_cont_wrap .pc_mov_wrap .title {
	width: 48%;
}

.pc_bottom_cont_wrap .pc_mov_wrap .title img {
	max-height: 1.80rem;
	display: block;
	margin: auto;
	padding-right: 0.20rem;
	position: relative;
	top: -0.08rem;
}

.pc_bottom_cont_wrap .pc_mov_wrap .mov_cont {
	width: 50%;
	height: 100%;
	position: relative;
	text-align: right;
}

.pc_bottom_cont_wrap .pc_mov_wrap .mov_cont .img_wrap {
	position: relative;
	height: 100%;
	display: inline-block;
}

.pc_bottom_cont_wrap .pc_mov_wrap .mov_cont .img_wrap a {
	display: block;
	height: 100%;
}

.pc_bottom_cont_wrap .pc_mov_wrap .mov_cont .img_wrap a:hover {
	opacity: 0.7;
}

.pc_bottom_cont_wrap .pc_mov_wrap .mov_cont .img_wrap img {
	display: block;
	height: 100%;
	margin-left: auto;
	object-fit: cover;
}

.pc_bottom_cont_wrap .pc_product {
	width: 37.1%;
	height: 100%;
}


.pc_bottom_cont_wrap .pc_product .img_wrap {
	height: 100%;
}

.pc_bottom_cont_wrap .pc_product img {
	display: block;
	max-height: 100%;
	margin: auto;
}


/*============================
カラー設定
============================*/
:root {
	/* 赤 */
	--color-red01: #e50012;
	/* テキスト色 */
	--color-bk01: #231815;
}

/*============================
ヘッダー
============================*/
header {
	background-color: var(--color-red01);
	height: 0.66rem;
	position: relative;
}

header .logo {
	width: 1.20rem;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

/*============================
メインビジュアル
============================*/
.mv .top_deco {
	display: block;
	background-color: #fcf4ea;
}
.mv .middle_deco {
	position: relative;
	overflow: hidden;
	background-color: #fcf4ea;
}
.mv .middle_deco video {
	position: relative;
	top: 0%;
	left: -15%;
	width: 130%;
	height: auto;

	transform: scale(0);
}
.mv .middle_deco svg {
	position: absolute;
	top: 13%;
	left: 0;
	width: 100%;
	height: auto;
	fill: #e60012;
	opacity: 0;
}
.mv .bottom_deco {
	fill: #fcf4ea;
}

/*============================
イントロ
============================*/
.introduction {
	padding-top: 0.10rem;
	font-family: "fot-tsukubrdgothic-std", sans-serif;
	font-weight: 700;
	font-style: normal;
	text-align: center;
}

.introduction .lead {
	color: var(--color-red01);
	font-size: 0.18rem;
	line-height: 1.75;
	padding-bottom: 0.20rem;
}

.introduction .img_wrap {
	width: calc(100% - 1.10rem);
	margin: auto;
	padding-bottom: 0.20rem;
}

.introduction .bottom_deco svg {
	width: 100%;
	height: auto;
	fill: #e60012;
	display: block;
	margin-bottom: -1px;
}

/*============================
とろ活のすすめ
============================*/
.feature {
	background-color: var(--color-red01);
	padding: 0.40rem 0;
	overflow: hidden;
}

.feature .sec_title {
	width: calc(100% - 0.40rem);
	max-width: 3.20rem;
	margin: auto;
	padding-bottom: 0.30rem;
}
.feature .sec_title svg {
	display: block;
	width: 3.20rem;
	height: auto;
	fill: #FFF;
}

.feature .feature_box {
	padding-top: 0.20rem;
	position: relative;
}

.feature .feature_box .title_wrap {
	position: relative;
	width: calc(100% - 0.60rem);
	background-color: #FFF;
	border-radius: 0.20rem;
	margin: auto;
	padding: 0.20rem 0;
}

.feature .feature_box .title_wrap::after {
	content: "";
	width: 1.00rem;
	height: 0.12rem;
	background-image: url(../img/feature_cont_title_deco.svg);
	background-position: right top;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	bottom: -0.12rem;
	right: 0.40rem;
}

.feature .feature_box .title_wrap img {
	height: 0.68rem;
	display: block;
	margin: auto;
}

.feature .feature_box .text {
	font-family: "fot-tsukubrdgothic-std", sans-serif;
	font-weight: 700;
	font-size: 0.20rem;
	line-height: 1.75;
	color: #FFF;
	padding: 0.20rem 0.38rem;
	text-align: justify;
}

.feature .feature_box.type01 .before {
	width: 1.30rem;
	height: auto;
	position: absolute;
	top: -0.50rem;
	left: 0;
	z-index: 2;
}

.feature .feature_box.type02 .before {
	width: 1.10rem;
	height: auto;
	position: absolute;
	top: -0.70rem;
	right: 0;
	z-index: 2;
}

.feature .feature_box.type03 .before {
	width: 1.50rem;
	height: auto;
	position: absolute;
	top: -0.15rem;
	left: -0.7rem;
	z-index: 2;
}

/*============================
とろ活ムービー
============================*/
.movie {
	background-color: var(--color-red01);
	padding-bottom: 0.20rem;
}

.movie .sec_title {
	width: 100%;
	max-width: 2.60rem;
	margin: auto;
	padding-bottom: 0.30rem;
}

.movie .mov_wrap {
	width: calc(100% - 0.60rem);
	padding-top: calc(100% - 0.62rem);
	margin: auto;
	border: 2px solid #FFF;
	position: relative;
	box-sizing: border-box;
}

.movie .mov_wrap iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

/* @media screen and (max-width: 768px) {
	.movie .mov_wrap iframe {
		height: 5.00rem;
	}
} */

/*============================
とろ活レシピ
============================*/
.recipe {
	position: relative;
	padding-top: 1.50rem;
	font-family: "fot-tsukubrdgothic-std", sans-serif;
	font-weight: 700;
}

.recipe .before {
	content: "";
	width: 100%;
	height: auto;
	position: absolute;
	fill: #e50012;
	top: -1px;
	left: 0;
}

.recipe .sec_title svg {
	display: block;
	width: 3.20rem;
	height: auto;
	margin: auto;
	fill: #e50012;
}

.recipe .lead {
	color: var(--color-red01);
	font-size: 0.18rem;
	line-height: 1.75;
	padding: 0.20rem 0 0.40rem;
	text-align: center;
}

.recipe .recipe_box {
	padding: 0 0.40rem 0.80rem;
}

@media print, screen and (max-width:767px) {
	.recipe .recipe_box {
		padding: 0 0.30rem 0.80rem;
	}
}

.recipe .recipe_box .title {
	width: 100%;
	max-width: 2.80rem;
	margin: auto;
	padding-bottom: 0.20rem;
}
.recipe .recipe_box .title img {
	opacity: 0;
	transform: translateY(10px);
}
.recipe .recipe_box .title img.active {
	opacity: 1;
	transform: none;
	transition: 1.2s;
}

.recipe .ph_wrap {
	padding-bottom: 0.20rem;
}

.recipe .ph_wrap img {
	width: 100%;
	display: block;
}

.recipe .ingredient_title {
	background-color: var(--color-red01);
	text-align: center;
	color: #FFF;
	font-size: 0.20rem;
	padding: 0.06rem 0;
}

.recipe .ingredient_text {
	padding-top: 0.14rem;
	color: var(--color-red01);
	font-size: 0.16rem;
	line-height: 1.57;
	padding-bottom: 0.10rem;
}

.recipe .round_deco {
	display: inline-block;
	padding: 0 0.05rem 0 0.06rem;
	position: relative;
	top: -0.01rem;
}

.recipe .round_deco::before {
	content: "";
	width: 0.16rem;
	height: 0.16rem;
	border-radius: 0.15rem;
	position: absolute;
	left: 0.01rem;
	top: 0.04rem;
	border: 1px solid var(--color-bk01);
}

.recipe .ingredient_text .round_deco {
	padding: 0 0.07rem 0 0.05rem;
}

.recipe .ingredient_text .round_deco::before {
	border: 1px solid var(--color-red01);
	left: 0.00rem;
	top: 0.05rem;
}

.recipe .recipe_box .flow_box {
	padding: 0.25rem 0 0.27rem;
	background-image : linear-gradient(to right, var(--color-red01) 3px, transparent 1px);
	background-size: 6px 2px;
	background-repeat: repeat-x;
	background-position: left bottom;
	position: relative;
	min-height: 0.45rem;
}

.recipe .recipe_box .flow_box:last-child {
	background-image: none;
}

.recipe .flow_box::before {
	content: "";
	width: 0.55rem;
	height: 0.55rem;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	left: 0;
	top: 0.20rem;
}


.recipe .flow_box.no01::before {
	background-image: url(../img/recipe_num01.svg);
}

.recipe .flow_box.no02::before {
	background-image: url(../img/recipe_num02.svg);
}

.recipe .flow_box.no03::before {
	background-image: url(../img/recipe_num03.svg);
}

.recipe .flow_box.no04::before {
	background-image: url(../img/recipe_num04.svg);
}

.recipe .flow_box.no05::before {
	background-image: url(../img/recipe_num05.svg);
}

.recipe .flow_box .text {
	font-size: 0.155rem;
	line-height: 1.57;
	padding-left: 0.74rem;
}

.recipe .flow_box .caption {
	padding-top: 0.15rem;
	font-size: 0.155rem;
	line-height: 1.57;
}

/*============================
とろ活レシピ
============================*/
.sosial {
	position: relative;
	font-family: "fot-tsukubrdgothic-std", sans-serif;
	font-weight: 700;
	padding: 0 0.30rem;
}

.sosial .sec_title svg {
	display: block;
	width: 3.40rem;
	height: auto;
	margin: auto;
	fill: #e50012;
}

.sosial .lead {
	color: var(--color-red01);
	font-size: 0.18rem;
	line-height: 1.75;
	padding: 0.20rem 0 0.40rem;
	text-align: center;
}

.sosial .insta_ph_wrap {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.sosial .insta_ph_wrap .ph_box {
	position: relative;
	display: block;
	width: 50%;
	height: auto;
    z-index: 1;
}

.sosial .insta_ph_wrap .ph_box::before {
	content: "";
	display: block;
	padding-top: 100%;
}

.sosial .insta_ph_wrap .ph_box a {
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
    background-size: cover;
}

.sosial .insta_ph_wrap .ph_box a video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
}

.sosial .more_btn {
	width: 100%;
	max-width: 2.30rem;
	margin: auto;
	padding: 0.30rem 0;
}

.sosial .more_btn a {
	display: block;
	background-color: var(--color-red01);
	padding: 0.15rem;
	border-radius: 0.30rem;
	text-align: center;
	font-size: 0.18rem;
	color: #FFF;
}

.sosial .more_btn a span {
	display: inline-block
}

.sosial .more_btn a span::before {
	content: "";
	width: 0.22rem;
	height: 0.08rem;
	background-image: url(../img/link_arrow.svg);
	background-position: left center;
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	position: relative;
	top: -0.015rem;
}

/*============================
リンク
============================*/
.link {
	position: relative;
	font-family: "fot-tsukubrdgothic-std", sans-serif;
	font-weight: 700;
	padding: 0.10rem 0.30rem 0.30rem;
}

.link .link_bnr {
	padding-bottom: 0.30rem;
}

.link .link_bnr a {
	display: block;
}

.link .link_bnr a:hover {
	opacity: 0.7;
}

@media screen and (max-width: 768px) {
	.link .link_bnr a:hover {
		opacity: 1;
	}
}

.link .link_bnr img {
	display: block;
}

/*============================
フッター
============================*/
footer {
	background-color: var(--color-red01);
	text-align: center;
	padding: 0.15rem;
	color: #FFF;
}

.link .link_bnr {
	padding-bottom: 0.20rem;
}

.link .link_bnr img {
	display: block;
}

/*============================
ぱらぱら
============================*/
[data-parapara] {
	opacity: 0;
}