@charset "utf-8";

/**************************************
 * CSS BasicStyle forHTML5 v2.0
**************************************/
a {
	transition-duration: 0.3s;
}

area {
	border: none;
	outline: none;
}

/******************************
 All Area base
******************************/
html {
	height: 100%;
}

body {
	position: relative;
	width: 100%;
	height: 100%;
	font-family: "PT Sans", Helvetica, Arial, "YuGothic", "游ゴシック", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Verdana, sans-serif;
	word-wrap: break-word;
	letter-spacing: 0.05em;
	text-align: center;
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: 400;
	color: #333;
	background-color: #fdf7ef;
}

/* webfonts*/
.noto {
	font-family: 'Noto Sans JP', sans-serif;
}

.sourcesans {
	font-family: 'PT Sans', sans-serif;
}

.gothic {
	font-family: YuGothic, "游ゴシック", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Verdana, sans-serif;
}

.serif {
	font-family: 'Yu Mincho', '游明朝', '游明朝体', 'YuMincho', 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'HiraMinProN-W3', 'HGS明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: normal;
}

/* link */
a:link,
a:visited {
	color: #d80012;
	text-decoration: none;
}

a:hover,
a:active {
	color: #d80012;
	text-decoration: none;
	opacity: 0.7;
}

.PC {
	display: block;
}

.SP {
	display: none;
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	body {
		font-size: 14px;
	}

	.PC {
		display: none;
	}

	.SP {
		display: block;
	}

	#bg_overlay {
		position: fixed;
		z-index: 5000;
		top: -5000px;
		right: -5000px;
		bottom: -5000px;
		left: -5000px;
		display: none;
		background: #000;
		opacity: 0.6;
	}
}

/* ---/SP--- */


/* form_parts */
.select-wrap {
	display: inline-block;
	position: relative;
}

.select-wrap::before {
	z-index: 1;
	position: absolute;
	right: 20px;
	top: 1.0em;
	content: "";
	width: 7px;
	height: 4px;
	background-image: url(../img/ic_arrow_select.svg);
	background-repeat: no-repeat;
	background-size: 100%;
	pointer-events: none;
}

.select-wrap select {
	border: solid 1px #d7d7d7;
	background-color: #FFF;
	padding: 7px 30px 7px 15px;
	border-radius: 5px;
}

/* default_box */


/* ---SP--- */
@media screen and (max-width: 768px) {}

/* ---/SP--- */

/******************************
 All Area
******************************/
main,
header,
footer {
	min-width: 1200px;
	width: 100%;
}

main {
	padding-top: 156px;
}

h2 {
	position: relative;
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 1.6;
	font-weight: bold;
	margin-bottom: 50px;
}

h2::after {
	content: "";
	display: block;
	position: relative;
	width: 60px;
	height: 2px;
	background-color: #d90312;
	margin-top: 10px;
}

h2.gbl {
	font-size: 40px;
	font-size: 4rem;
	line-height: 1.0;
	letter-spacing: 0.05em;
	color: #D80D12;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	font-weight: 700;
}

h2.gbl::after {
	display: none;
}

h2.gbl .en {
	display: block;
	font-family: 'Asap Condensed', YuGothic, "游ゴシック", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Verdana, sans-serif;
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: 700;
	color: #333;
	margin-top: 10px;
	letter-spacing: 0.06em;
}

h3 {
	font-size: 22px;
	font-size: 2.2rem;
	font-weight: bold;
	color: #FFF;
	margin-top: 60px;
	margin-bottom: 40px;
	background-color: #d60d12;
	padding: 8px 18px;
	border-radius: 5px;
	line-height: 1.4;
}

section p {
	line-height: 1.8;
}

section p.lead {
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.5;
	margin-bottom: 40px;
}

/* base_box */
.base_box {
	margin-bottom: 60px;
}

.base_box::after {
	content: "";
	clear: both;
	display: block;
}

.base_box p {
	margin-bottom: 30px;
}

/* column2 */
.column2 {
	columns: 25em auto;
	-moz-columns: 25em auto;
	-webkit-columns: 25em auto;
	-o-columns: 25em auto;
	-ms-columns: 25em auto;
	column-gap: 40px;
	-moz-column-gap: 40px;
	-webkit-column-gap: 40px;
	-o-column-gap: 40px;
	-ms-column-gap: 40px;
	line-height: 1.6;
	margin-bottom: 60px;
}

.column2::after {
	content: "";
	clear: both;
	display: block;
	height: 60px;
}

/* tab01 */
.tab01 {
	width: 100%;
	background-color: #FFF;
	border-top: dotted 1px #c9c9c9;
	margin-bottom: 80px;
}

.tab01 th {
	width: 220px;
	background-color: #fcfaf8;
}

.tab01 th,
.tab01 td {
	padding: 25px 20px;
	border-bottom: dotted 1px #c9c9c9;
	line-height: 1.6;
}

/* tab02 */
.tab02 {
	width: 70%;
	margin: 0 auto 80px;
}

.tab02 th {
	width: 250px;
}

.tab02 th,
.tab02 td {
	padding: 15px 10px;
	border-bottom: dashed 1px #C9C9C9;
	line-height: 1.6;
}

/* Googlemap */
.map_box {
	clear: both;
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	margin-bottom: 20px;
	height: 0;
	overflow: hidden;
}

.map_box iframe,
.map_box object,
.map_box embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* basic_dl */
.basic_dl::after {
	content: "";
	clear: both;
	display: block;
}

.basic_dl dt {
	clear: both;
	float: left;
}

.basic_dl dd {
	border-bottom: dashed 1px #c9c9c9;
}

/* basic_ol */
.basic_ol {
	padding-left: 3.2em;
	margin-bottom: 50px;
}

.basic_ol li {
	list-style-position: inside;
	counter-increment: dnum-cnt;
	text-indent: -2.9em;
	line-height: 1.6;
	margin-bottom: 10px;
}

.basic_ol li::before {
	display: marker;
	content: counter(dnum-cnt) ". ";
	color: #999;
	font-size: 22px;
	font-size: 2.2rem;
	font-weight: bold;
	margin-right: 1.0em;
}

/* localnav */
.localnav {
	display: block;
	width: 100%;
	max-width: 1200px;
	margin: 60px auto 30px;
}

.localnav ul::after {
	content: "";
	clear: both;
	display: block;
}

.localnav ul li {
	float: left;
	background-color: #FFF;
	border-top: solid 1px #e5e3e3;
	border-bottom: solid 1px #e5e3e3;
}

.localnav ul li a {
	position: relative;
	display: block;
	vertical-align: middle;
	padding: 15px 10px;
	border-top: solid 1px #fdf7ef;
	border-bottom: solid 1px #fdf7ef;
}

.localnav ul li.current a,
.localnav ul li a:hover {
	background-color: #d80012;
	color: #FFF;
}

.localnav ul li.current a::after,
.localnav ul li a:hover::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -10px;
	left: 50%;
	margin-top: -2px;
	content: "";
	width: 5px;
	height: 5px;
	border-top: 1px solid #d70e12;
	border-right: 1px solid #d70e12;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}

/* sns_box */
.sns_box {
	padding: 40px 0;
	margin-bottom: 60px;
	background-color: #FFF;
}

.sns_box ul {
	text-align: center;
}

.sns_box li {
	display: inline-block;
	margin-left: 15px;
}

.sns_box li:first-child {
	margin-left: 0;
}

.sns_box a {
	display: block;
	width: 40px;
}

.sns_box img {
	width: 100%;
}

/* num */
.num {
	padding-left: 1.5em;
	margin-bottom: 40px;
}

.num li {
	counter-increment: dnum-cnt0;
	position: relative;
	text-indent: -0.5em;
	line-height: 1.6;
}

.num li::before {
	content: counter(dnum-cnt0) ". ";
	display: inline-block;
	position: relative;
	margin-right: 5px;
}

/* annotation */
.annotation {
	padding-left: 1.5em;
	margin-bottom: 40px;
}

.annotation li {
	position: relative;
	text-indent: -0.5em;
	line-height: 1.6;
}

.annotation li::before {
	content: "※";
	display: inline-block;
	position: relative;
	margin-right: 5px;
}

/* ec */
#ec {
	position: relative;
	min-height: 330px;
	background-repeat: no-repeat;
	background-size: 145%;
	overflow: hidden;
	margin-bottom: 130px;
}

#ec h1 {
	position: relative;
	z-index: 1;
	font-size: 20px;
	font-size: 2.0rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	padding: 100px 0;
}

#ec h1::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 50%;
	z-index: -1;
	margin-left: -155px;
	width: 310px;
	height: 310px;
	background: #FFF;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}

#ec h1 .en {
	display: block;
	font-family: 'Asap Condensed', YuGothic, "游ゴシック", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Verdana, sans-serif;
	font-size: 57px;
	font-size: 5.7rem;
	font-weight: 700;
	color: #D80D12;
	margin-bottom: 10px;
	letter-spacing: 0.03em;
}

/* btn */
.btn {
	min-width: 240px;
	height: 50px;
	margin: 0 auto;
	font-size: 18px;
	font-size: 1.8rem;
	text-align: center;
}

.inputbtn,
.btn a {
	display: block;
	width: 100%;
	line-height: 50px;
	background-color: #DA0012;
	color: #FFF;
	position: relative;
	display: inline-block;
	text-align: center;
	text-decoration: none;
	border: 2px solid #DA0012;
	transition: .3s;
	border-radius: 10px;
}

.inputbtn:hover,
.btn a:hover {
	color: #DA0012;
	-webkit-animation: scale .3s ease-in-out;
	animation: scale .3s ease-in-out;
}

.inputbtn::before,
.btn a::before {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
	content: '';
	background-color: #FFF;
	transform-origin: right top;
	transform: scale(0, 1);
	transition: transform .3s;
	border-radius: 10px;
}

.inputbtn:hover::before,
.btn a:hover::before {
	transform-origin: left top;
	transform: scale(1, 1);
}

/* btn_w */
.btn_w {
	min-width: 240px;
	height: 50px;
	margin: 0 auto;
	font-size: 18px;
	font-size: 1.8rem;
	text-align: center;
}

.btn_w a {
	position: relative;
	display: block;
	width: 100%;
	line-height: 50px;
	background-color: #FFF;
	color: #282828;
	position: relative;
	display: inline-block;
	text-align: center;
	text-decoration: none;
	border: 1px solid #D8D8D8;
	transition: .3s;
	border-radius: 10px;
}

.btn_w a:hover {
	color: #DA0012;
	border: 1px solid #DA0012;
}

.btn_w a::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 20px;
	width: 15px;
	height: 15px;
	background-image: url(../img/ic_arrow01.svg);
	background-repeat: no-repeat;
	background-size: 100%;
	transform: translateY(-50%);
}

/* pagination */
.pagination {
	text-align: center;
}

.pagination .prev {
	display: inline-block;
}

.pagination .prev a {}

.pagination ul {
	display: inline-block;
}

.pagination ul li {
	display: inline-block;
	margin-left: 2px;
	margin-bottom: 10px;
}

.pagination a {
	display: inline-block;
	background-color: #FFF;
	border: solid 1px #D80012;
	border-radius: 4px;
	width: 40px;
	height: 40px;
	text-align: center;
	vertical-align: middle;
	line-height: 40px;
}

.pagination .current a,
.pagination a:hover {
	background-color: #D80012;
	color: #FFF;
}

.pagination .next {
	display: inline-block;
}

/* pager */
.pager {
	text-align: center;
	margin-bottom: 70px;
}

.pager .prev {
	display: inline-block;
	margin-right: 20px;
}

.pager .prev a {}

.pager .next {
	display: inline-block;
	margin-left: 20px;
}

.pager .prev a,
.pager .next a {
	position: relative;
	display: block;
	border: solid 1px #D80012;
	background-color: #FFF;
	padding: 10px 25px;
	width: 150px;
	border-radius: 5px;
}

.pager .prev a::before {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 10px;
	background-image: url(../img/ic_arrow01.svg);
	background-size: 100%;
	background-repeat: no-repeat;
	width: 12px;
	height: 12px;
	-webkit-transform: translateY(-50%) rotate(-180deg);
	transform: translateY(-50%) rotate(-180deg);
}

.pager .next a::after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	right: 10px;
	background-image: url(../img/ic_arrow01.svg);
	background-size: 100%;
	background-repeat: no-repeat;
	width: 12px;
	height: 12px;
	transform: translateY(-50%);
}

/* text */
.form_box input[type="text"] {
	border: solid 1px #d7d7d7;
	background-color: #FFF;
	padding: 7px 30px 7px 15px;
	border-radius: 5px;
	color: #282828;
}

/* textarea */
.form_box textarea {
	border: solid 1px #d7d7d7;
	background-color: #FFF;
	padding: 7px 30px 7px 15px;
	border-radius: 5px;
	color: #282828;
}

/* radio */
.form_box input[type="radio"] {
	display: none;
}

.form_box label.agreelabel,
.form_box label.radiolabel {
	position: relative;
	top: 0;
	left: 0;
	display: block;
	float: left;
	cursor: pointer;
	width: 90px;
	margin: 0 0 0 10px;
	padding: 10px 5px;
	border: 2px solid #BFBFBF;
	border-radius: 10px;
	background: #FFF;
	text-align: center;
	line-height: 1;
	transition: .2s;
}

.form_box label.radiolabel:nth-child(2) {
	margin: 0;
}

.form_box input[type="radio"]:checked+label {
	border: solid 2px #D70D12;
	color: #D70D12;
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	.localnav {
		margin: 30px auto 15px;
		font-size: 13px;
	}

	.localnav ul li a {
		padding: 10px 5px;
	}

	.sns_box {
		padding: 20px 0;
		margin-bottom: 30px;
	}

	.tab01 {
		margin-bottom: 40px;
	}

	.tab01 th,
	.tab01 td {
		padding: 15px 10px;
	}

	.tab01 th {
		width: 30%;
	}

	.tab02 {
		width: 100%;
		margin-bottom: 40px;
	}

	.tab02 th,
	.tab02 td {
		display: block;
		width: 100%;
		padding: 10px 5px;
	}

	.tab02 th {
		border-bottom: none;
		padding: 0 5px;
	}

	.tab02 td {
		margin-bottom: 20px;
	}

	.btn {
		min-width: 58.2%;
		height: 40px;
		margin: 0 auto 30px;
		font-size: 16px;
	}

	.btn_w {
		min-width: 58.2%;
		height: 40px;
		margin: 0 auto 30px;
		font-size: 16px;
	}

	.inputbtn,
	.btn a {
		line-height: 40px;
		border-radius: 5px;
	}

	.inputbtn::before,
	.btn a::before {
		border-radius: 5px;
	}

	main,
	header,
	footer {
		min-width: 320px;
		width: 100%;
	}

	main {
		padding-top: 50px;
	}

	section p {
		line-height: 1.6;
	}

	.top main {
		padding-top: 50px;
	}

	.base_box {
		margin-bottom: 20px;
	}

	#ec {
		background-size: 240%;
		min-height: 160px;
		margin-bottom: 50px;
	}

	#ec h1 {
		font-size: 14px;
		padding: 40px 0;
	}

	#ec h1 .en {
		font-size: 38px;
	}

	#ec h1::after {
		top: 0;
		margin-left: -77px;
		width: 155px;
		height: 155px;
	}

	h2 {
		font-size: 16px;
		font-size: 1.6rem;
		margin-bottom: 30px;
	}

	h2::after {
		width: 30px;
		height: 2px;
		margin-top: 5px;
	}

	h2.gbl {
		margin-bottom: 20px;

		font-size: 28px;
		font-size: 2.8rem;

	}

	h2.gbl .en {
		font-size: 18px;
		font-size: 1.8rem;
	}

	h3 {
		font-size: 14px;
		margin-bottom: 20px;
	}

	section p.lead {
		font-size: 14px;
		margin-bottom: 20px;
	}

	.basic_ol {
		padding-left: 2.2em;
		margin-bottom: 30px;
	}

	.basic_ol li {
		text-indent: -2.2em;
	}

	.basic_ol li::before {
		font-size: 18px;
		margin-right: 0.5em;
	}

	.pagination .prev,
	.pagination .next {
		display: block;
		margin-bottom: 10px;
	}

	.pager {
		margin-bottom: 30px;
	}

	.pager .prev,
	.pager .next {
		width: 40%;
	}

	.pager .prev {
		margin-right: 4%;
	}

	.pager .next {
		margin-left: 4%;
	}

	.pager .prev a,
	.pager .next a {
		width: 100%;
		font-size: 14px;
	}
}

/* ---/SP--- */
/******************************
 Header Area
******************************/
header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 100;
	background-color: #fdf7ef;
	border-top: solid 3px #DA0012;
}

header .inr {
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
	height: 94px;
}

header .inr::after {
	content: "";
	clear: both;
	display: block;
}

header .logo {
	float: left;
	margin-top: 24px;
}

header .logo a {
	display: block;
	width: 170px;
}

header .logo img {
	width: 100%;
	vertical-align: middle;
}

/*スクロールしたら固定する*/
header.fixed {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 100;
	width: 100%;
}

/* nav */
header .sp_nav_btn {
	display: none;
}

header nav .subnav {
	position: absolute;
	top: -94px;
	right: 0;
	/* display: inline-block;*/
	padding: 0 5px 0 0;
	margin-bottom: 14px;
	text-align: left;
	font-size: 12px;
	font-size: 1.2rem;
	font-weight: bold;
	background-color: #f0e3d1;
	border-radius: 0 0 5px 5px;
	display: flex;

}

header nav .subnav li {
	padding: 0;
	position: relative;
}

header nav .subnav li:not(:first-child)::before {

	content: "";
	position: absolute;
	width: 1px;
	height: 100%;
	background-color: #EAD7D7;
	left: 0;
	top: 0;

}

header nav .subnav a {
	display: block;
	position: relative;
	color: #2C221F;
	width: 80px;
	padding: 6px;
	text-align: center;
	font-weight: bold;
}

header nav .subnav a:hover,
header nav .subnav a.is-active {
	color: #DA0012;
}

/*
header nav .subnav a::before{
    content: "";
    display: inline-block;
    position: relative;
    width: 20px;
    height: 20px;
    background-image: url(../img/ic_info.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    vertical-align: middle;
}
header nav .subnav a:hover::before{
    background-image: url(../img/ic_info_on.svg);
}
*/
header nav .headbn {
	position: absolute;
	top: -60px;
	right: 0;
	text-align: left;
	width: 764px;
	margin-bottom: 14px;
	display: flex;
	justify-content: flex-end;
}

header nav .headbn::after {
	content: "";
	clear: both;
	display: block;
}

header nav .headbn li {
	float: left;
	margin-left: 12px;
}

header nav .headbn li:first-child {
	margin-left: 0;
}

header nav .headbn li a {
	display: block;
	width: 180px;
}

header nav .headbn li:last-child a {
	width: 188px;
}

header nav .headbn li a img {
	width: 100%;
}

/* gnav */
#nav_area {
	background-color: #f0e3d1;
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.2);
}

#nav_area nav {
	position: relative;
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
}

#nav_area .gnav {
	font-size: 17px;
	font-size: 1.7rem;
	text-align: left;
}

#nav_area .gnav::after {
	content: "";
	clear: both;
	display: block;
}

#nav_area .gnav>li {
	float: left;
	display: block;
	border-left: solid 1px #ead7d7;
}

#nav_area .gnav>li:first-child {
	border-left: none;
}

#nav_area .gnav>li>a,
#nav_area .gnav>li>span.instead span {
	position: relative;
	display: block;
	color: #2C221F;
	padding: 10px 0;
	width: 170px;
	text-align: center;
}

#nav_area .gnav>li.current>span.instead span,
#nav_area .gnav>li>span.instead span:hover {
	color: #DA0012;
}

#nav_area .gnav>li>a::before,
#nav_area .gnav>li>span.instead span::before {
	content: "";
	position: relative;
	display: inline-block;
	margin-right: 5px;
	background-repeat: no-repeat;
	background-size: 100%;
	vertical-align: middle;
	width: 40px;
	height: 40px;
}

/* 各アイコン */
#nav_area .gnav>li.home>a::before {
	background-image: url(../img/ic_home.svg);
}

#nav_area .gnav>li.product>span.instead span::before {
	background-image: url(../img/ic_product.svg);
}

#nav_area .gnav>li.recipe>a::before {
	background-image: url(../img/ic_recipe.svg);
}

#nav_area .gnav>li.recipe>span.instead span::before {
	background-image: url(../img/ic_recipe.svg);
}

#nav_area .gnav>li.learn>a::before {
	background-image: url(../img/ic_learn.svg);
}

#nav_area .gnav>li.company>span.instead span::before {
	background-image: url(../img/ic_company.svg);
}

#nav_area .gnav>li.customer>a::before {
	background-image: url(../img/ic_customer.svg);
}

#nav_area .gnav>li.recruit>a::before {
	background-image: url(../img/ic_recruit.svg);
}

/**/
#nav_area .gnav>li.home.current>a::before,
#nav_area .gnav>li.home>a:hover::before {
	background-image: url(../img/ic_home_on.svg);
}

#nav_area .gnav>li.product.current>span.instead span::before,
#nav_area .gnav>li.product>span.instead span:hover::before {
	background-image: url(../img/ic_product_on.svg);
}

#nav_area .gnav>li.recipe.current>a::before,
#nav_area .gnav>li.recipe>a:hover::before {
	background-image: url(../img/ic_recipe_on.svg);
}

#nav_area .gnav>li.learn.current>a::before,
#nav_area .gnav>li.learn>a:hover::before {
	background-image: url(../img/ic_learn_on.svg);
}

#nav_area .gnav>li.company.current>span.instead span::before,
#nav_area .gnav>li.company>span.instead span:hover::before {
	background-image: url(../img/ic_company_on.svg);
}

#nav_area .gnav>li.customer.current>a::before,
#nav_area .gnav>li.customer>a:hover::before {
	background-image: url(../img/ic_customer_on.svg);
}

#nav_area .gnav>li.recruit.current>a::before,
#nav_area .gnav>li.recruit>a:hover::before {
	background-image: url(../img/ic_recruit_on.svg);
}

/**/


#nav_area li>span.instead {
	transition-duration: 0.3s;
}

#nav_area li>span.instead:hover,
#nav_area li>a:hover {
	color: #DA0012;
}

#nav_area li.current>span.instead,
#nav_area li.current>a {
	color: #DA0012;
}


/* ---SP--- */
@media screen and (max-width: 768px) {
	header {
		border-top: none;
	}

	header .inr {
		position: absolute;
		top: 0;
		left: 0;
		z-index: 2;
		max-width: 100%;
		height: 50px;
		background-color: #fdf7ef;
	}

	.top header {
		position: fixed;
		top: 0;
	}

	header .logo {
		position: absolute;
		left: 10px;
		top: 5px;
		z-index: 100;
		margin-top: 0;
	}

	header .logo a {
		width: auto;
	}

	header .logo img {
		width: 116px;
	}

	#nav_area .corp {
		display: none;
	}

	/* ナビゲーション */
	header .sp_nav_btn {
		display: block;
	}

	header nav {
		display: flex;
		flex-direction: column;
		padding-bottom: 60px;
	}

	#nav_area {
		position: fixed;
		z-index: 1;
		top: 0;
		left: 0;
		color: #000;
		text-align: center;
		transform: translateY(-100%);
		transition: all 0.6s;
		background-color: #fdf7ef;
		width: 100%;
		height: 100%;
		padding: 55px 0 0;
		box-shadow: 0 0 0;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
	}

	#nav_area .gnav {
		width: 100%;
		background-color: #f0e3d1;
		order: 1;
	}

	#nav_area .gnav>li {
		font-size: 14px;
		text-align: left;
		width: 100%;
		border-bottom: 1px solid #BFBFBF;
		display: block;
		margin-left: 0;
		padding: 0;
	}

	#nav_area .gnav>li>a::before,
	#nav_area .gnav>li>span.instead span::before {
		background-size: auto 100%;
		background-position: center;
		width: 30px;
		height: 30px;
	}

	#nav_area .gnav>li>a,
	#nav_area .gnav>li>span.instead {
		display: block;
		position: relative;
		width: 100%;
		text-align: left;
		padding: 10px 20px 10px 10px;
		cursor: pointer;
	}

	#nav_area .gnav>li>span.instead span {
		display: inline-block;
		width: 100%;
		position: relative;
		padding: 0;
		text-align: left;
	}

	#nav_area .gnav li>span::before,
	#nav_area .gnav li>span::after {
		display: block;
		content: '';
		background-color: #2C221F;
		position: absolute;
		z-index: 1;
		width: 11px;
		height: 1px;
		top: 50%;
		right: 14px;
	}

	#nav_area .gnav li>span::before {
		width: 1px;
		height: 11px;
		top: 50%;
		right: 19px;
		margin-top: -5px;
	}

	#nav_area .gnav li>span.open::before {
		display: none;
	}

	/* このクラスを、jQueryで付与・削除する */
	#nav_area.active {
		transform: translateY(0%);
	}

	.sp_nav_btn {
		display: block;
		position: absolute;
		right: 13px;
		top: 5px;
		width: 40px;
		height: 40px;
		cursor: pointer;
		z-index: 3;
		text-align: center;
	}

	.sp_nav_btn span {
		display: block;
		position: absolute;
		/* .navToggleに対して */
		width: 30px;
		border-bottom: solid 3px #DA0012;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
		left: 6px;
	}

	.sp_nav_btn span::before {
		content: "";
		display: block;
		position: absolute;
		/* .navToggleに対して */
		width: 30px;
		border-bottom: solid 3px #DA0012;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
	}

	.sp_nav_btn span {
		top: 14px;
	}

	.sp_nav_btn span::before {
		top: 10px;
	}

	/* 最初のspanをマイナス45度に */
	.sp_nav_btn.active span {
		top: 18px;
		left: 6px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}

	/* 2番目と3番目のspanを45度に */
	.sp_nav_btn.active span::before {
		top: 0px;
		left: 0px;
		-webkit-transform: rotate(90deg);
		-moz-transform: rotate(90deg);
		transform: rotate(90deg);
	}



	header nav .subnav {
		position: relative;
		top: 0;
		right: 0;
		display: block;
		padding: 0;
		margin-bottom: 20px;
		font-size: 14px;
		font-weight: normal;
		background-color: #f0e3d1;
		border-radius: 0;
		display: flex;
		order: 3;
		width: calc(100% - 40px);
		margin: 0 auto;

	}

	header nav .subnav li {
		padding: 0;
		width: 33.3333%;

	}

	header nav .subnav a {
		display: block;
		position: relative;
		width: 100%;
		text-align: left;
		padding: 10px 10px 10px 10px;
		text-align: center;
	}

	header nav .subnav a::before {
		width: 30px;
		height: 30px;
		margin-right: 5px;
	}

	header nav .headbn {
		position: relative;
		top: 0;
		right: 0;
		width: 100%;
		padding: 0 20px 30px;
		text-align: center;
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		margin: 18px auto 0;
		order: 2;
	}

	header nav .headbn li {
		/*     float: none;
        display: inline-block;
        width: 47.5%;*/
		width: calc(50% - 4px);
		margin-left: 4px;
		margin-right: 4px;
		margin-bottom: 10px;
	}

	header nav .headbn li:first-child,
	header nav .headbn li:nth-child(3) {
		margin-left: 0;
	}

	header nav .headbn li:nth-child(2),
	header nav .headbn li:nth-child(4) {
		margin-right: 0;
	}

	header nav .headbn li a {
		display: block;
		width: 100%;
	}

	header nav .headbn li:last-child a {
		width: 100%;
	}

	header nav .headbn li a img {
		width: 100%;
	}
}

/* ---/SP--- */
/******************************
 mv
******************************/
#mv_area {
	width: 100%;
	height: 470px;
	background-color: #f0e3d1;
	padding: 10px 0;
}

#mv_area img {
	width: 1000px;
	height: 450px;
}

#mv_area .slick-dots {
	bottom: -40px;
}

#mv_area .slick-initialized .slick-slide {
	display: block;
	margin-left: 10px;
}

#mv_area .slick-initialized .slick-slide a {
	display: block;
}

#mv_area .slick-prev,
#mv_area .slick-next {
	position: absolute;
	z-index: 1;
	width: 53px;
	height: 53px;
	-webkit-transform: translate(0, -50%);
	-ms-transform: translate(0, -50%);
	transform: translate(0, -50%);
	cursor: pointer;
	background-color: #FFF;
	border-radius: 50%;
	box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
}

#mv_area .slick-prev {
	left: 50%;
	margin-left: -530px;
}

#mv_area .slick-next {
	right: 50%;
	margin-right: -530px;
}

#mv_area .slick-prev::before {
	position: absolute;
	top: 18px;
	left: 18px;
	content: "";
	width: 13px;
	height: 20px;
	background-image: url(../img/ic_arrow_sl_l.svg);
	background-repeat: no-repeat;
	background-size: 100%;
}

#mv_area .slick-next::before {
	position: absolute;
	top: 18px;
	right: 18px;
	content: "";
	width: 13px;
	height: 20px;
	background-image: url(../img/ic_arrow_sl_r.svg);
	background-repeat: no-repeat;
	background-size: 100%;
}

#mv_area .slick-dots {
	z-index: 2;
}

#mv_area .slick-dots,
.pickup_box .slick-dots {
	bottom: -50px;
}

#mv_area .slick-dots li,
.pickup_box .slick-dots li {
	margin: 0 2px;
}

#mv_area .slick-dots li button:before,
.pickup_box .slick-dots li button:before {
	font-size: 14px;
	color: #8e8888;
}

#mv_area .slick-dots li.slick-active button:before,
.pickup_box .slick-dots li.slick-active button:before {
	font-size: 14px;
	color: #d60d12;
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	#mv_area {
		width: 100%;
		height: 51vw;
		padding: 20px 0;
	}

	#mv_area img {
		width: calc(100vw - 20px);
		height: auto;
	}

	#mv_area .slick-prev,
	#mv_area .slick-next {
		width: 26px;
		height: 26px;
	}

	#mv_area .slick-dots {
		bottom: -13.333vw;
	}

	#mv_area .slick-prev {
		left: 0;
		margin-left: 0;
	}

	#mv_area .slick-next {
		right: 0;
		margin-right: 0;
	}

	#mv_area .slick-next::before,
	#mv_area .slick-prev::before {
		top: 9px;
		left: 9px;
		width: 6px;
		height: 10px;
	}
}

/* ---/SP--- */


/******************************
 origin_area
******************************/

#top_origin_area {
	position: relative;
	width: 100%;
	text-align: center;
	display: flex;
	justify-content: center;
	height: 502px;
	background-color: #FFF;
	padding-top: 52px;
	box-sizing: border-box;
}

#top_origin_area .origin_image_start {
	flex: 1;
}

#top_origin_area .origin_box {
	padding: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	min-width: 520px;
	margin: 0 auto;
}

#top_origin_area .origin_box .gbl {
	margin-bottom: 40px;
}

#top_origin_area .origin_box p.lead {
	margin-bottom: 42px;
	font-size: 1.8rem;
	font-size: 18px;
	letter-spacing: 0;
}

#top_origin_area .origin_image_end {
	flex: 1;
}

#top_origin_area .origin_image_start figure,
#top_origin_area .origin_image_end figure {
	height: 100%;

}

#top_origin_area .origin_image_start img,
#top_origin_area .origin_image_end img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

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

	#top_origin_area .origin_box {
		flex: 1;
	}

	#top_origin_area .origin_image_start {
		width: 31.053vw;
		flex: initial;
	}

	#top_origin_area .origin_image_end {
		width: 31.579vw;
		flex: initial;
	}
}

/* ---SP--- */
@media screen and (max-width: 768px) {

	#top_origin_area {
		flex-direction: column;
		height: auto;
		padding-top: 14.933vw;
	}

	#top_origin_area .origin_box {
		padding: 40px 20px;
		min-width: 100%;
		margin: 0 auto;
	}

	#top_origin_area .origin_box .gbl {
		margin-bottom: 20px;
	}

	#top_origin_area .origin_box p.lead {
		margin-bottom: 20px;
		font-size: 1.4rem;
		font-size: 14px;
	}

	#top_origin_area .origin_box .btn {
		margin-bottom: 0;
	}
}



/******************************
 producthead_area
******************************/
#producthead_area {
	padding-top: 100px;
}

#producthead_area .producthead_box {
	/* background-color: #f0e3d1;*/
}

#producthead_area .lead {
	margin-bottom: 0;
}

.producthead_box {
	position: relative;
	padding: 60px 0;
}

.producthead_box ul {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto 40px;
}

.producthead_box ul::after {
	content: "";
	clear: both;
	display: block;
}

.producthead_box li {
	float: left;
	display: block;
	margin-left: 4px;
	margin-bottom: 4px;
}

.producthead_box li:nth-child(4n+1) {
	margin-left: 0;
}

.producthead_box li a {
	display: table;
	background-color: #FFF;
	width: 297px;
	height: 110px;
	border-radius: 4px;
	text-align: left;
	padding: 10px;
	color: #2C221F;
}

.producthead_box li a:hover {
	color: #d80012;
}

.producthead_box li a::after {
	content: "";
	clear: both;
	display: block;
}

.producthead_box .name {
	display: table-cell;
	vertical-align: middle;
	padding: 0 0 0 10px;
	width: 145px;
	height: 90px;
	line-height: 1.6;
	font-weight: bold;
	letter-spacing: -1px;
}

.producthead_box figure {
	display: table-cell;
	vertical-align: middle;
	text-align: right;
	height: 90px;
}

.producthead_box figure img {
	height: 100%;
}

.producthead_box .subbtn {
	position: relative;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	text-align: right;
}

.producthead_box .subbtn a {
	position: absolute;
	right: 0;
	top: -35px;
	display: inline-block;
	font-weight: bold;
	color: #2C221F;
}

.producthead_box .subbtn a:hover {
	color: #d80012;
}

.producthead_box .subbtn a::before {
	content: "";
	display: inline-block;
	position: relative;
	margin-right: 10px;
	width: 15px;
	height: 15px;
	background-image: url(../img/ic_arrow01.svg);
	vertical-align: middle;
}

.producthead_box .btn {
	width: 240px;
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	#producthead_area {
		padding-top: 60px;
	}

	.producthead_box {
		padding: 30px 20px;
	}

	.producthead_box ul li {
		width: calc(50% - 10px);
		height: auto;
	}

	.producthead_box li:nth-child(4n+1) {
		margin-left: 10px;
	}

	.producthead_box li:nth-child(odd) {
		margin-left: 0;
	}

	.producthead_box ul li a {
		position: relative;
		display: block;
		width: 100%;
		height: auto;
		font-size: 14px;
	}

	.producthead_box .name {
		position: relative;
		display: block;
		padding: 0;
		width: 100%;
		height: auto;
		padding-top: 80px;
		text-align: center;
	}

	.producthead_box figure {
		position: absolute;
		top: 10px;
		left: 50%;
		display: block;
		width: 100%;
		height: 65px;
		margin-left: -50%;
		text-align: center;
	}

	.producthead_box figure img {
		height: 100%;
		width: auto;
	}

	.producthead_box .subbtn {
		text-align: center;
		font-size: 13px;
	}

	.producthead_box .subbtn a {
		position: relative;
		top: auto;
	}
}

/* ---SP--- */
/******************************
 pickup_area
******************************/
#pickup_area {
	position: relative;
	background: url(../img/bg_pickup.jpg) no-repeat;
	background-size: 140%;
	padding: 70px 0;
}

#pickup_area .inr {
	position: relative;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

/* pickup_box */
.pickup_box {
	text-align: left;
	width: 100%;
	max-width: 980px;
	margin: 0 auto;
}

.pickup_box::after {
	content: "";
	clear: both;
	display: block;
}

.pickup_box .slider {
	margin: 0 auto;
}

#pickup_area .pickup_box li.slick-slide {
	float: left;
	margin: 5px 7px;
}

.pickup_box li.slick-slide a {
	display: block;
	width: 310px;
	background-color: #FFF;
	color: #2C221F;
	border-radius: 4px;
	box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
}

.pickup_box li.slick-slide a:hover {
	color: #d80012;
}

.pickup_box li.slick-slide figure {
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 220px;
	margin-bottom: 20px;
	background-color: #F7F2F2;
	background-image: url(../img/img_dummy.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	border-radius: 4px 4px 0 0;
}

.pickup_box li.slick-slide figure img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: auto;
	height: 100%;
	-webkit-transform: translate(-50%, -50%) scale(1);
	-ms-transform: translate(-50%, -50%) scale(1);
	transform: translate(-50%, -50%) scale(1);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}

.pickup_box li.slick-slide a:hover figure img {
	-webkit-transform: translate(-50%, -50%) scale(1.2);
	-ms-transform: translate(-50%, -50%) scale(1.2);
	transform: translate(-50%, -50%) scale(1.2);
}

.pickup_box li.slick-slide span {
	line-height: 1.6;
}

.pickup_box li.slick-slide .title {
	display: block;
	font-size: 20px;
	font-size: 2.0rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 10px;
}

.pickup_box li.slick-slide .txt {
	display: block;
	font-size: 16px;
	font-size: 1.6rem;
	padding: 0 15px 15px;
}

.pickup_box .slick-prev,
.pickup_box .slick-next {
	width: 20px;
	height: 20px;
	padding: 0;
	-webkit-transform: translate(0, -50%);
	-ms-transform: translate(0, -50%);
	transform: translate(0, -50%);
	cursor: pointer;
	color: transparent;
	border: none;
	outline: none;
	background: transparent;
}

.pickup_box .slick-prev:before,
.pickup_box .slick-next:before {
	content: "";
	position: absolute;
	top: 0;
	background-repeat: no-repeat;
	background-size: 100%;
	width: 10px;
	height: 17px;
}

.pickup_box .slick-prev:before {
	left: 0;
	background-image: url(../img/ic_arrow_sl_l.svg);
}

.pickup_box .slick-next:before {
	right: 0;
	background-image: url(../img/ic_arrow_sl_r.svg);
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	#pickup_area {
		background-position: top center;
		background-size: auto 100%;
		padding: 30px 0;
	}

	#pickup_area .pickup_box li.slick-slide {
		margin-left: 20vw;
	}

	.pickup_box li.slick-slide a {
		width: 70vw;
	}

	.pickup_box li.slick-slide figure {
		height: 50vw;
	}

	.pickup_box .slick-prev,
	.pickup_box .slick-next {
		z-index: 3;
		width: 25px;
		height: 25px;
	}

	.pickup_box .slick-prev {
		left: 25px;
	}

	.pickup_box .slick-next {
		right: 25px;
	}

	.pickup_box .slick-prev:before,
	.pickup_box .slick-next:before {
		width: 15px;
		height: 26px;
	}

	.pickup_box li.slick-slide .title {
		font-size: 17px;
		margin-bottom: 5px;
	}

	.pickup_box li.slick-slide .txt {
		font-size: 14px;
		padding: 0 15px 10px;
	}
}

/* ---/SP--- */

/******************************
 news_area
******************************/
#news_area {
	padding: 80px 0;
}

#news_area .inr {
	position: relative;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

#news_area .inr::after {
	content: "";
	clear: both;
	display: block;
}

#news_area .info_area,
#news_area .newproducts_area {
	/*width: 50%;
	float: left;*/
}

#news_area .info_area {
	width: 100%;
	max-width: 980px;
	margin: 0 auto;
}

#news_area .info_area dl {
	/*padding-right: 30px;*/
	text-align: left;
}

#news_area .newproducts_area dl {
	padding-left: 30px;
	text-align: left;
}

#news_area dl {
	margin-bottom: 40px;
}

#news_area dt {
	margin-bottom: 10px;
}

#news_area .date {
	font-size: 14px;
	font-size: 1.4rem;
	margin-right: 20px;
}

#news_area .cat {
	font-size: 12px;
	font-size: 1.2rem;
	font-weight: bold;
	color: #FFF;
	background-color: #d80012;
	border-radius: 3px;
	padding: 3px 5px;
}

#news_area dd {
	border-bottom: dotted 1px #bdbdbd;
	line-height: 1.6;
	padding-bottom: 15px;
	margin-bottom: 20px;
}

#news_area dl a {
	color: #2c221f;
}

#news_area dl a:hover {
	color: #d80012;
}

#news_area .btn {
	width: 240px;
}

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

	#news_area dl {}

	#news_area dt {
		float: left;
	}

	#news_area dd {
		padding-left: 12em;
	}
}

/* ---/SP--- */
@media screen and (max-width: 768px) {
	#news_area {
		padding: 40px 0;
	}

	#news_area .inr {
		padding: 0 20px;
	}

	#news_area .info_area,
	#news_area .newproducts_area {
		width: 100%;
		float: none;
		margin-bottom: 20px;
	}

	#news_area .info_area dl {
		padding-right: 0;
	}

	#news_area .newproducts_area dl {
		padding-left: 0;
	}

	#news_area .date {
		font-size: 12px;
		margin-right: 10px;
	}

	#news_area .cat {
		font-size: 10px;
	}

	#news_area dd {
		font-size: 14px;
		padding-bottom: 10px;
		margin-bottom: 15px;
	}
}

/* ---/SP--- */
/******************************
 recipe_area
******************************/
#recipe_area {
	position: relative;
	background: url(../img/bg_recipe.jpg) no-repeat;
	background-size: 140%;
	padding: 70px 0;
}

#recipe_area .inr {
	position: relative;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

#recipe_area h2.gbl {
	display: inline-block;
	position: relative;
}

#recipe_area h2.gbl::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: -180px;
	width: 149px;
	height: 93px;
	background-image: url(../img/ttl_recipe_l.svg);
	background-repeat: no-repeat;
	background-size: 100%;
}

#recipe_area h2.gbl::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: -180px;
	width: 149px;
	height: 93px;
	background-color: transparent;
	background-image: url(../img/ttl_recipe_r.svg);
	background-repeat: no-repeat;
	background-size: 100%;
}

/* pickup_box */
.recipe_box {
	text-align: left;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto 40px;
	padding: 40px;
	background-image: url(../img/bg_check.jpg);
	background-repeat: repeat;
	border-radius: 5px;
	box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
}

.recipe_box::after {
	content: "";
	clear: both;
	display: block;
}

.recipe_box .input_box,
.recipe_box .recipe_thumbnail {
	float: left;
	width: 50%;
}

.recipe_box .input_box {
	text-align: center;
	padding-right: 30px;
	border-right: solid 1px #bebebe;
}

.recipe_box .input_box>p {
	position: relative;
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: bold;
	letter-spacing: normal;
	margin-bottom: 20px;
}

.recipe_box .input_box>p::before,
.recipe_box .input_box>p::after {
	content: "";
	position: relative;
	display: inline-block;
	background-repeat: no-repeat;
	background-size: 100%;
	width: 13px;
	height: 20px;
}

.recipe_box .input_box>p::before {
	background-image: url(../img/lead_recipein_l.svg);
	margin-right: 5px;
}

.recipe_box .input_box>p::after {
	background-image: url(../img/lead_recipein_r.svg);
	margin-left: 5px;
}

.recipe_box .input_box .input_form {
	margin-bottom: 20px;
}

.recipe_box .input_box .input_form .select-wrap select {
	width: 200px;
}

.recipe_box .recipe_thumbnail {
	padding-left: 30px;
}

.inputbtn {
	position: relative;
	z-index: 0;
	width: 240px;
	height: 50px;
	margin: 0 auto;
	font-size: 18px;
	font-size: 1.8rem;
	text-align: center;
}

.recipe_box .recipe_thumbnail a {
	position: relative;
	display: block;
	color: #2c221f;
	font-weight: bold;
}

.recipe_box .recipe_thumbnail a:hover {
	color: #d80012;
}

.recipe_box .recipe_thumbnail a::before {
	content: "";
	display: block;
	position: absolute;
	right: 0;
	top: 50%;
	width: 30px;
	height: 30px;
	border-right: 2px solid #DA0012;
	border-top: 2px solid #DA0012;
	transform: rotate(45deg) translateY(-50%);
}

.recipe_box .recipe_thumbnail a::after {
	clear: both;
	content: "";
	display: block;
}

.recipe_box .recipe_thumbnail figure {
	float: left;
	display: block;
	position: relative;
	width: 230px;
	height: 180px;
	padding: 18px;
	margin-right: 30px;
	background-image: url(../img/bg_book.png);
	background-repeat: no-repeat;
}

.recipe_box .recipe_thumbnail figure span {
	display: block;
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 128px;
	margin-bottom: 20px;
	background-color: #F7F2F2;
	background-image: url(../img/img_dummy.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	border-radius: 4px;
	border: solid 1px #FFF;
	box-shadow: 0 0 1px 1px rgba(0, 0, 0, 0.2);
}

.recipe_box .recipe_thumbnail figure img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: auto;
	-webkit-transform: translate(-50%, -50%) scale(1);
	-ms-transform: translate(-50%, -50%) scale(1);
	transform: translate(-50%, -50%) scale(1);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
	border-radius: 4px;
}

.recipe_box .recipe_thumbnail a:hover figure img {
	-webkit-transform: translate(-50%, -50%) scale(1.2);
	-ms-transform: translate(-50%, -50%) scale(1.2);
	transform: translate(-50%, -50%) scale(1.2);
}

.recipe_box .recipe_thumbnail .txt_area {
	position: relative;
	float: left;
	width: 270px;
	margin-top: 40px;
}

.recipe_box .recipe_thumbnail .txt_area::before {
	content: "";
	display: block;
	position: absolute;
	top: -70px;
	right: -30px;
	width: 90px;
	height: 58px;
	background-image: url(../img/ic_pickup.svg);
	background-repeat: no-repeat;
	background-size: 100%;
}

.recipe_box .recipe_thumbnail .title {
	line-height: 1.6;
	margin-bottom: 20px;
}

/* recipe_cat */
.recipe_cat li {
	display: inline-block;
	margin-right: 5px;
}

.recipe_cat li span {
	display: inline-block;
	color: #FFF;
	font-weight: bold;
	font-size: 12px;
	font-size: 1.2rem;
	background-color: #d65f63;
	padding: 2px 5px;
}

#recipe_area .btn {
	width: 240px;
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	#recipe_area {
		background-position: top center;
		background-size: auto 100%;
		padding: 30px 0;
	}

	#recipe_area .inr {
		padding: 0 20px;
	}

	#recipe_area h2.gbl::before {
		left: -85px;
		width: 75px;
		height: 46px;
	}

	#recipe_area h2.gbl::after {
		right: -85px;
		width: 75px;
		height: 46px;
	}

	.recipe_box {
		margin: 0 auto 20px;
		padding: 25px;
	}

	.recipe_box .input_box,
	.recipe_box .recipe_thumbnail {
		float: none;
		width: 100%;
		padding-right: 0;
	}

	.recipe_box .input_box {
		float: none;
		width: 100%;
		margin-bottom: 20px;
		padding-right: 0;
		border-right: none;
		border-bottom: solid 1px #bfbfbf;
	}

	.recipe_box .recipe_thumbnail {
		float: none;
		width: 100%;
		padding-left: 0;
	}

	.recipe_box .input_box>p {
		font-size: 16px;
		margin-bottom: 20px;
	}

	.recipe_box .input_box>p::before {
		position: absolute;
		top: 1.0em;
		left: 0;
	}

	.recipe_box .input_box>p::after {
		position: absolute;
		top: 1.0em;
		right: 0;
	}

	.recipe_box .input_box .input_form .select-wrap {
		width: 100%;
	}

	.recipe_box .input_box .input_form .select-wrap select {
		width: 100%;
		font-size: 16px;
	}

	.recipe_box .input_box .input_form>span {
		display: block;
		margin-bottom: 10px;
	}

	.inputbtn {
		width: 68%;
		height: 40px;
		margin: 0 auto 30px;
		font-size: 16px;
	}

	.recipe_box .recipe_thumbnail a::before {
		right: 10px;
		width: 15px;
		height: 15px;
	}

	.recipe_box .recipe_thumbnail figure {
		width: 115px;
		height: 90px;
		padding: 9px;
		margin-right: 15px;
		background-size: 100%;
	}

	.recipe_box .recipe_thumbnail figure span {
		height: 64px;
		margin-bottom: 10px;
	}

	.recipe_box .recipe_thumbnail .title {
		font-size: 14px;
	}

	.recipe_cat li span {
		font-size: 10px;
	}

	.recipe_box .recipe_thumbnail .txt_area::before {
		top: 0;
		left: 0;
		right: auto;
		width: 45px;
		height: 29px;
		-moz-transform: rotate(-45deg);
		-webkit-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
	}

	.recipe_box .recipe_thumbnail .txt_area {
		position: initial;
		width: 52%;
		margin-top: 0;
	}
}

/* ---/SP--- */


/******************************
 gallery_area
******************************/
#gallery_area {
	position: relative;
	padding: 70px 0;
}

#gallery_area .inr {
	position: relative;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

/* gallery_box */
.gallery_box {
	text-align: left;
}

.gallery_box::after {
	content: "";
	clear: both;
	display: block;
}

.gallery_box li {
	float: left;
	margin-left: 18px;
	margin-bottom: 40px;
	font-size: 14px;
	font-size: 1.4rem;
}

.gallery_box li:nth-child(4n+1) {
	margin-left: 0;
}

.gallery_box a {
	display: block;
	width: 286px;
	line-height: 1.6;
}

.gallery_box figure {
	display: block;
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 162px;
	margin-bottom: 20px;
	background-color: #F7F2F2;
	background-image: url(../img/img_dummy.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	border-radius: 4px;
	border: solid 1px #bdbdbd;
}

.gallery_box figure img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: auto;
	height: 100%;
	-webkit-transform: translate(-50%, -50%) scale(1);
	-ms-transform: translate(-50%, -50%) scale(1);
	transform: translate(-50%, -50%) scale(1);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}

.gallery_box a:hover figure img {
	-webkit-transform: translate(-50%, -50%) scale(1.2);
	-ms-transform: translate(-50%, -50%) scale(1.2);
	transform: translate(-50%, -50%) scale(1.2);
}

.gallery_box a {
	display: block;
}

.gallery_box a .date {
	display: block;
	font-size: 12px;
	font-size: 1.2rem;
	color: #807a79;
	margin-bottom: 10px;
}

.gallery_box a .title {
	display: block;
	color: #2c221f;
}

#gallery_area .btn {
	width: 240px;
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	#gallery_area {
		padding: 40px 0;
	}

	#gallery_area .inr {
		padding: 0 20px;
	}

	.gallery_box li {
		width: 48.35%;
		margin-left: 3.3%;
		margin-bottom: 20px;
	}

	.gallery_box li:nth-child(4n+1) {
		margin-left: 3.3%;
	}

	.gallery_box li:nth-child(odd) {
		margin-left: 0;
	}

	.gallery_box li a {
		width: 100%;
	}

	.gallery_box li figure {
		height: 28vw;
		margin-bottom: 10px;
	}

	.gallery_box a .title {
		font-size: 14px;
	}
}

/* ---/SP--- */


/******************************
 footer
******************************/
footer {
	position: relative;
	text-align: left;
	background: #f0e3d1;
}

footer .f_nav {
	border-bottom: solid 1px #e3d2cd;
	padding: 40px 0;
}

footer .f_nav nav {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

footer .f_nav nav::after {
	content: "";
	clear: both;
	display: block;
}

footer .f_nav nav>ul {
	float: left;
	width: 175px;
	border-left: solid 1px #e3d2cd;
	padding-left: 30px;
	margin-left: 30px;
}

footer .f_nav nav>ul:first-child {
	border-left: none;
	padding-left: 0;
	margin-left: 0;
}

footer .f_nav nav>ul:nth-child(1) {
	width: 70px;
}

footer .f_nav nav>ul:nth-child(3) {
	width: 120px;
}

footer .f_nav nav>ul:nth-child(5) {
	width: 320px;
}

footer .f_nav nav>ul:nth-child(6) a {
	color: #2C221F;
}

footer .f_nav li {
	font-weight: bold;
	line-height: 1.6;
	font-size: 14px;
	font-size: 1.4rem;
	letter-spacing: normal;
	color: #DA0012;
	margin-bottom: 15px;
}

footer .f_nav li a {
	color: #DA0012;
}

footer .f_nav nav>ul ul {
	margin-top: 20px;
}

footer .f_nav li li {
	position: relative;
	font-weight: normal;
	margin-left: 0.7em;
	margin-bottom: 5px;
	color: #2C221F;
}

footer .f_nav nav>ul ul.half::after {
	content: "";
	clear: both;
	display: block;
}

footer .f_nav nav>ul ul.half li {
	float: left;
	width: 45%;
}

footer .f_nav li li a {
	color: #2C221F;
}

footer .f_nav nav .interview_column {
	width: 480px;
}

footer .f_nav nav .interview_column::after {
	content: "";
	clear: both;
	display: block;
}

footer .f_nav nav .interview_column li {
	float: left;
	width: 150px;
}

/* bn_nav */
footer .bn_nav {
	border-top: solid 1px #fdeeef;
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 30px 0;
}

footer .bn_nav nav {
	width: 1150px;
	margin: 0 auto;
}

footer .bn_nav nav ul::after {
	content: "";
	clear: both;
	display: block;
}

footer .bn_nav nav li {
	float: left;
	width: 280px;
	margin-left: 10px;
	margin-bottom: 10px;
}

footer .bn_nav nav li:nth-child(4n+1) {
	margin-left: 0;
}

footer .bn_nav nav li a {
	display: block;
}


/* basic_box */
footer .basic_box {
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 30px 0;
	background-color: #fdf7ef;
}

footer .basic_box .inr {
	position: relative;
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

footer .basic_box::after {
	content: "";
	clear: both;
	display: block;
}

footer .basic_box p {
	line-height: 1.6;
}

footer .logo {
	width: 140px;
	float: left;
	margin-right: 20px;
}

footer .logo a {
	display: block;
}

footer .logo img {
	width: 100%;
	vertical-align: top;
}

footer .txt {
	font-size: 14px;
	font-size: 1.4rem;
}

footer .copy {
	background-color: #DA0012;
	color: #FFF;
	text-align: center;
	padding: 1.2em;
	font-size: 12px;
	font-size: 1.2rem;
}

.gotop {
	position: fixed;
	right: 10px;
	bottom: 70px;
	z-index: 12;
}

.gotop a {
	display: block;
	width: 50px;
}

.gotop img {
	width: 100%;
}

/* ---SP--- */
@media screen and (max-width: 768px) {
	footer .f_nav {
		padding: 0;
		border-bottom: none;
	}

	footer .f_nav nav>ul {
		width: 100%;
		float: none;
		border-left: none;
		padding-left: 0;
		margin-left: 0;
	}

	footer .f_nav nav>ul:nth-child(1) {
		width: 100%;
	}

	footer .f_nav nav>ul:nth-child(3) {
		width: 100%;
	}

	footer .f_nav nav>ul:nth-child(5) {
		width: 100%;
	}

	footer .f_nav nav>ul ul li:nth-child(odd) a {
		border-right: solid 1px #e3d2cd;
	}

	footer .f_nav nav>ul.ulhalf::after {
		content: "";
		clear: both;
		display: block;
	}

	footer .f_nav nav>ul.ulhalf li {
		float: left;
		width: 50%;
	}

	footer .f_nav nav>ul.ulhalf li:nth-child(odd) span,
	footer .f_nav nav>ul.ulhalf li:nth-child(odd) a {
		border-right: solid 1px #e3d2cd;
	}

	footer .f_nav li {
		margin-bottom: 0;
	}

	footer .f_nav li span,
	footer .f_nav li a {
		display: block;
		padding: 10px 20px;
		border-bottom: solid 1px #e3d2cd;
		letter-spacing: -0.05em;
	}

	footer .f_nav li span {
		position: relative;
		cursor: pointer;
	}

	footer .f_nav li span::before,
	footer .f_nav li span::after {
		display: block;
		content: '';
		background-color: #2C221F;
		position: absolute;
		z-index: 1;
		width: 11px;
		height: 1px;
		top: 50%;
		right: 14px;
	}

	footer .f_nav li span::before {
		width: 1px;
		height: 11px;
		top: 50%;
		right: 19px;
		margin-top: -5px;
	}

	footer .f_nav li span.open::before {
		display: none;
	}

	footer .f_nav nav>ul ul {
		display: none;
		background-color: #fdf7ef;
		margin-top: 0;
	}

	footer .f_nav nav ul ul::after {
		content: "";
		clear: both;
		display: block;
	}

	footer .f_nav nav .interview_column {
		width: 100%;
	}

	footer .f_nav nav .interview_column li,
	footer .f_nav nav ul ul li {
		float: left;
		width: 50%;
		margin-left: 0;
		margin-bottom: 0;
	}

	footer .f_nav nav>ul ul.half li {
		width: 50%;
	}

	footer .f_nav li li::before {
		left: 0;
		top: 0.7em;
	}

	footer .f_nav nav {
		width: 100%;
	}

	footer .bn_nav {
		padding: 15px 20px;
	}

	footer .bn_nav nav {
		width: 100%;
	}

	footer .bn_nav nav li {
		width: 48.35%;
		margin-left: 3.3%;
		margin-bottom: 10px;
	}

	footer .bn_nav nav li a {
		display: block;
	}

	footer .bn_nav nav li:nth-child(odd) {
		margin-left: 0;
	}

	footer .bn_nav nav li img {
		width: 100%;
	}

	footer .basic_box .inr {
		padding: 0 20px;
		font-size: 12px;
	}

	footer .logo {
		width: 100px;
		float: none;
		margin-right: 0;
	}

	footer .copy {
		font-size: 10px;
	}

	.gotop a {
		width: 40px;
	}
}

/* ---/SP--- */