@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: 1300px;
    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 {
   width: 1300px;
    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;  
    width: 1300px;
    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>span.instead span a {
    color: #2C221F;
}

#nav_area .gnav>li.current>span.instead span,
#nav_area .gnav>li>span.instead span:hover,
#nav_area .gnav>li>span.instead span a: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>a::before {
    background-image: url(../img/ic_product.svg);
}

a.blank_icon::after{
    content: "\f35d";
    font-family: "Font Awesome 5 Free";
    font-weight: bold; /*指定しないと表示されない*/
    font-size: 0.8em;
    padding-left: .6em; /*文字とアイコンの間に隙間*/
}

#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>sa::before,
#nav_area .gnav>li.product>a: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;
}

#nav_area .company{
	
	.mmd_box{
		padding: 30px 10px 30px 30px;
		> p{
			width: 132px;
			padding-right: 24px;
			margin-right: 24px;
		}
	} 

}


/* ---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%;
        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 nav {
        width: 100%;
    }

    #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%;

    &.w100{
        width: 100%;
    }
}

@media screen and (max-width: 768px) {
    footer .f_nav nav>ul ul.half li.w100{
        width:50%;
    }
}

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--- */