@charset "utf-8";

/* CSS Document */


/* ------------------------------------------
  reset
--------------------------------------------- */

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
hr,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
main,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
    display: block;
}

body {
    line-height: 1;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after {
    content: "";
    content: none;
}

q:before,
q:after {
    content: "";
    content: none;
}

abbr {
    text-decoration: none;
}

mark {
    background: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

caption,
th {
    text-align: left;
}

img {
    vertical-align: top;
}

hr {
    height: 0;
}

html {
    font-size: 62.5%;
    box-sizing: border-box;
    scroll-padding-top: 100px;
}

*,
*:before,
*:after {
    box-sizing: inherit;
}

body {
    font-size: 14px;
    line-height: 1.5;
    font-family: 'Noto Sans JP', sans-serif;
    color: #070707;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    word-break: break-all;
    letter-spacing: 1.5px;
    -webkit-font-feature-settings: "palt";
    -moz-font-feature-settings: "palt";
    font-feature-settings: "palt";
    /*padding-top: 230px;*/
    padding-top: 110px;
    min-width: 1200px;
}

a {
    color: #070707;
    text-decoration: none;
}


/*a[href^="tel"] {
    color: #fff;
    pointer-events: none;
}*/

a:hover {
    opacity: 0.75;
    -webkit-transition: all 0.3s 0s ease;
    transition: all 0.3s 0s ease;
}

.pc-hide {
    display: none !important;
}

.sp-only {
    display: none !important;
}

.text-link {
    color: #000;
}

.text-red {
    color: #ff3434;
}

.strong {
    font-weight: 700;
}

.no-border {
    border: none !important;
}

.align-center {
    text-align: center;
}

.align-right {
    text-align: right;
}

.img-full img {
    width: 100%;
    height: auto;
}

#page-top {
    display: block;
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 100;
}

#page-top:hover {
    opacity: 0.6;
    cursor: pointer;
    -webkit-transition: all 0.3s 0s ease;
    transition: all 0.3s 0s ease;
}

.common-lead-text {
    text-align: center;
    padding-bottom: 50px;
}

.common-lead-text a{
    text-decoration: underline;
}

.common-lead-text a:hover{
    text-decoration: none;
}

.common-lead-text big{
    font-size: 20px;
}

.cmn-text-red{
    color: #ff3b3b;
    font-weight: 500;
}

.cmn-text-white{
    color: #fff;
}

.cmn-text-blue{
    color: #3f7393 !important;
}

.cmn-mark{
    background:linear-gradient(transparent 60%, #fef66f 60%);
    font-weight: 500;
}

.cmn-text-small{
    font-size: 11px;
    line-height: 1.5;
    display: inline-block;
    letter-spacing: 1px;
}


/* ------------------------------------------
  common
--------------------------------------------- */


/*header*/

.header {
    z-index: 100;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    /*height: 230px;*/
    height: 180px;
    background: #fff;
    border-bottom: 1px solid #ccc;
    transition: 0.5s;
}

.home .header {
    border-bottom: none;
}

.header .logo {
    display: flex;
    align-items: center;
}

.header-top {
    width: 1100px;
    height: 120px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
}

.header.hide {
    transform: translateY(-232px);
}

.common-sns{
    display: flex;
}

.common-sns-item {
    padding-right: 10px;
}

.common-btn-shop {
    font-size: 11px;
    color: #fff;
    background: #212121;
    border-radius: 4px;
    text-align: center;
    padding-top: 1px;
    padding: 5px 10px 5px 35px;
    position: relative;
    height: 26px;
}
.common-btn-shop:before{
    content: "";
    display: block;
    background: url(../images/icon-cart.svg) no-repeat;
    width: 16px;
    height: 15px;
    position: absolute;
    left: 9px;
    top: 6px;
}

.gnav {
    background: #fff;
}

.gnav>ul {
    width: 1100px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

.gnav>ul>li {
    display: flex;
    justify-content: center;
    padding: 0 50px 0 40px;
    height: 60px;
}

.gnav>ul>li:first-child {
}

.gnav>ul>li>a {
    line-height: 1;
    display: block;
    text-align: center;
    padding: 5px 0;
    position: relative;
}

.gnav>ul>li>a:after {
    content: "";
    display: block;
    width: 9px;
    height: 9px;
    border-top: 1px solid #070707;
    border-right: 1px solid #070707;
    -webkit-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    position: absolute;
    top: 20px;
    right: -25px;
}

.gnav>ul>li>a span{
    display: block;
    font-family: 'Yu Gothic', serif;
    font-size: 18px;
    font-weight:900;
    letter-spacing: 0.05;
}

.gnav>ul>li>a small{
    font-family: 'Yu Gothic', serif;
    font-size: 12px;
    font-weight:800;
}
@media screen and (max-width: 1140px) and (min-width: 751px){
    .gnav>ul>li>a {
        font-size: 13px;
    }    
}

.gnav>ul>li>a.gnavi-current-page {
    color: #87b1ca;
}

.gnav>ul>li>a:hover {
    opacity: 0.7;
}

.megamenu {
    -webkit-transition: all 0.3s 0s ease;
    transition: all 0.3s 0s ease;
    /*-webkit-transform: translateY(275%);
    transform: translateY(275%);*/
    -webkit-transform: translateY(100%);
    transform: translateY(100%);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    background: #fff;
    padding: 20px 0;
    list-style: none;
    box-shadow: 0px 3px 2px -2px rgba(0, 0, 0, 0.35);
    -webkit-box-shadow: 0px 3px 2px -2px rgba(0, 0, 0, 0.35);
    -moz-box-shadow: 0px 3px 2px -2px rgba(0, 0, 0, 0.35);
}

.gnav .has-megamenu:hover .megamenu {
    /*-webkit-transform: translateY(230px);
    transform: translateY(230px);*/
    -webkit-transform: translateY(170px);
    transform: translateY(170px);
}

.megamenu-inner {
    width: 830px;
    margin: 0 auto;
}

.megamenu-item{
    margin-right: 10px;
    display: inline-block;
}

.megamenu-item a {
    background: #3e3e3e;
    color: #fff;
    font-size: 12px;
    border-radius: 6px;
    padding: 5px 10px;
}


/*header-search*/
.header-search div{
    display: flex;
    position: relative;
    border-bottom: 1px solid #252525;
}

.header-search div:after{
    content: "";
    display: block;
    width: 16px;
    height: 16px;
    background: url(../images/search-icon.svg) no-repeat;
    position: absolute;
    top: 6px;
    right: 10px;
}

.header-search input[type="text"]{
    border: none;
    width: 260px;
    margin: 0;
}

.header-search input[type="submit"]{
    background: none;
    border: none;
    text-indent: -9999px;
    width: 35px;
    height: 35px;
    display: block;
    padding: 0;
    position: absolute;
    right: 0;
    z-index: 2;
}

.header-search input[type="submit"]:hover{
    cursor: pointer;
}

/* -----------------------------------------------------------------------
## Tab ##################################################
----------------------------------------------------------------------- */
.header-tab{
    display: flex;
    justify-content: space-between;
    width: 1100px;
    padding: 15px 0;
    margin: 0 auto;
    border-bottom: 1px solid #ccc;
    background: #fff;
}

.header-tab-item a{
    width: 540px;
    height: 36px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    border-radius: 4px;
}

.header-tab-shop a{
    background: #f5f5f5;
}

.header-tab-yomimono a{
    background: #f3ede1;
}

.header-tab-item span{
    position: relative;
    top: 1px;
}

.header-tab-item span:before{
    content: "";
    display: block;
    position: absolute;
}

.header-tab-shop span:before{
    width: 14px;
    height: 19px;
    background: url(../images/head-icon-shopping-gray.svg) no-repeat;
    left: -25px;
    background-size: 14px;
}

.header-tab-yomimono span:before{
    width: 20px;
    height: 18px;
    background: url(../images/head-icon-yomimono.svg) no-repeat;
    background-size: 20px;
    left: -32px;
    top: 3px;
}

#header.ph22.hide {
    transform: translateY(-197px);
}


@media screen and (max-width: 768px) {
    #header.ph22.hide {
        transform: translateY(-131px);
    }
    .header-tab {
        width: 100%;
        padding: 10px 15px;
    }   

    .header-tab-item{
        width: calc(50% - 5px);
    }
    
    .header-tab-item a {
        width: 100%;
    }
    
    .header-tab-item span {
        padding-left: 20px;
        top: 0px;
    }
    
    .header-tab-shop span:before {
        top: -3px;
        left: -4px;
    }
    
    .header-tab-yomimono span:before{
        top: 0px;
        left: -8px; 
    }

}

/*sidebar*/

.sidebar{
    width: 250px;
    background: #f9f9f9;
    padding: 1.2vw;
}

.sidebar section{
    padding-bottom: 10px;
    margin-bottom: 20px;
    border-bottom: 1px solid #ddd;
}

.sidebar section:last-child{
    border: none;
}

.sidebar-title{
    text-align: center;
    position: relative;
    padding-bottom: 1vw;
    font-size: 18px;
    letter-spacing: 3px;
    font-weight: 500;
}

/*.sidebar-title:before{
    content: "";
    display: inline-block;
    background-size: cover !important;
    width: 1.5vw;
    height: 1.5vw;
    max-width: 24px;
    max-height: 24px;
}

.sidebar-title-like:before{
    background: url(../images/side-title-like.svg) no-repeat center;
}

.sidebar-title-pickup:before{
    background: url(../images/side-title-pickup.svg) no-repeat center;
    margin-bottom: 0.2vw;
}

.sidebar-title-osusume:before{
    background: url(../images/side-title-shop.svg) no-repeat center;
    margin-bottom: 0.2vw;
}

.sidebar-title-writter:before{
    background: url(../images/side-title-writter.svg) no-repeat center;
    margin-bottom: 0.2vw;
}

.sidebar-title-tag:before{
    background: url(../images/side-title-tag.svg) no-repeat center;
    margin-bottom: 0.2vw;
}*/


.sidebar-title-en{
    display: inline-block;
    width: 100%;
    font-size: min(1.317vw, 18px);
    font-family: 'Merriweather', serif;
    font-weight: 700;
    line-height: 1; 
    letter-spacing: 0.15vw;
}

.sidebar-title-jp{
    font-size: min(0.8052vw, 11px);
    font-weight: 700;
    line-height: 1;   
}

.sidebar-postList-items{
}

.sidebar-postList-items-inner{
    padding-bottom: 10px;
}

.sidebar-postList-items-link{
    display: flex;
    justify-content: space-between;
}

.sidebar-postList-image{
    margin-right: 15px;
    width: 50px;
    height: 50px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sidebar-postList-image img{
    width: 50px;
    height: auto;

}

.sidebar-postList-text {
    width: calc(100% - 65px);
}

.sidebar-postList-title{
    font-size: min(0.8784vw, 12px);
    line-height: 1.5;
}

.sidebar-postList-items .common-postList-cat{
    margin-bottom: 0;
}

.sidebar-postList-items .common-postList-summary {
    padding-bottom: 5px;
}

.sidebar-tagList{
}

.sidebar-tagList-items{
    display: inline-block;
}

.sidebar-tagList-items a{
    display: block;
    background: #3e3e3e;
    color: #fff;
    font-size: 11px;
    border-radius: 6px;
    padding: 5px 10px;
    margin: 0 5px 10px 0;
}


/*like ranking*/
.most_liked_post li {
    padding-bottom: 15px;
    display: flex;
    align-items: flex-end;
    font-size: 12px;
    position: relative;
    line-height: 1.25;
}

.wp_ulike_style_love .wp_counter_span {
    position: absolute;
    top: 0;
    left: 55px;
    background: #3e3e3e url(../images/heart-icon.svg) 5px 2px no-repeat !important;
    color: #fff !important;
    background-size: 12px !important;
    line-height: 16px !important;
    padding: 0 5px 0 20px !important;
}

.most_liked_post li:before {
    position: absolute;
    top: 0px;
    left: 3px;
    z-index: 2;
    color: #fff;
}

.most_liked_post li:nth-child(1):before {
    content: "1";
}

.most_liked_post li:nth-child(2):before {
    content: "2";
}

.most_liked_post li:nth-child(3):before {
    content: "3";
}

.most_liked_post li:nth-child(4):before {
    content: "4";
}

.most_liked_post li:nth-child(5):before {
    content: "5";
}

.most_liked_post li:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 25px 25px 0 0;
    border-color: #3e3e3e transparent transparent transparent;
}

.most_liked_post li:nth-child(1):after {
    border-color: #ceb023 transparent transparent transparent;
}

.most_liked_post li:nth-child(2):after {
    border-color: #99a097 transparent transparent transparent;
}

.most_liked_post li:nth-child(3):after {
    border-color: #c77d4f transparent transparent transparent;
}

/*sidebar-author*/
.post-authorList .sidebar-postList-image{
    border-radius: 25px;
}

.post-author-name{
    font-weight: 500;
    text-decoration: underline;
}

.post-author-intro{
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.sidebar-search-author li {
    margin-bottom: 15px;
}

.sidebar-search-author li:last-child {
    margin-bottom: 0;
}

.sidebar-search-author .sidebar-postList-image img {
    width: 50px;
    height: auto;
}

/*sidebar-sns*/
.sidebar-sns{
    display: flex;
    justify-content: center;
    align-items: center;
}

.sidebar-sns h4{
    font-weight: 500;
    padding-right: 0.5vw;
}

.sidebar-sns-list{
    display: flex;
}

.sidebar-sns-item {
    padding: 0 0.25vw;
}

.sidebar-sns-list img{
    width: 2vw;
    height: 2vw;
    max-width: 25px;
    max-height: 25px;
}

.sidebar-bnr{
    margin-bottom: 20px;
}

@media screen and (max-width: 750px) {
    .most_liked_post li {
        align-items: center;
    }   
    
    .most_liked_post li a{
        padding-top: 10px;
    }
}

/*footer-tag-writter*/
.footer-tag-writter{
    background: #e4e4e4;
    padding: 50px 0;
}

.footer-tag-writter .head-en{
    font-size: 30px;
    text-decoration: underline;
    padding-bottom: 20px;
}

.footer-tag-writter-inner{
    display: flex;
    justify-content: space-between;
    width: 1100px;
    margin: 0 auto;
}

.footer-tag {
    width: 530px;
}

.footer-tag .post-tagList {
    text-align: center;
}

.footer-tag .post-tagList li{
    display: inline-block;
}

.footer-writer {
    width: 530px;
}

.footer-writter-item a {
    margin: 0 40px;
    width: 450px;
    background: #fff;
    padding: 20px 30px;
    border-radius: 6px;
}

.footer-writter-item .sidebar-postList-image {
    width: 80px;
    height: 80px;
    border-radius: 40px;
}

.footer-writter-item .sidebar-postList-image img{
    width: 80px;
    height: 80px;
}

.footer-writter-item .sidebar-postList-text {
    width: calc(100% - 100px);
}

.footer-writter-item .post-author-intro {
    font-size: 12px;
}

.footer-writter-item .post-author-name {
    font-size: 16px;
    padding-bottom: 5px;
}

.footer-writer .slick-next {
    right: 15px;
}

.footer-writer .slick-next:before {
    border-top: 2px solid #212121;
    border-right: 2px solid #212121;
    width: 20px;
    height: 20px;
}

.footer-writer .slick-prev:before {
    border-bottom: 2px solid #212121;
    border-left: 2px solid #212121;
    width: 20px;
    height: 20px;
}

.footer-writer .slick-prev,
.footer-writer .slick-next {
    top: 55%;
    margin-top: 0;
}

.footer-ecBnr{
    text-align: center;
    background: #212121;    
}

@media screen and (max-width: 750px) {
    .footer-tag-writter .head-en {
        font-size: 20px;
        padding-bottom: 10px;
    }
    
    .footer-writter-item a {
        margin: 0 20px;
        width: calc(100% - 40px);
    }
    
    .footer-tag-writter {
        padding: 20px 20px;
    }
    
    .footer-writer .slick-next {
        right: 5px;
    }
    
    .footer-writer .slick-prev {
        left: -10px;
    }

}

/* -----------------------------------------------------------------------
## NEW FOOTER##################################################
----------------------------------------------------------------------- */
.footer-new{
    background: #f5f5f5;
    padding: 50px;
    text-align: center;
    line-height: 1.25;
    width: 100%;
}

.footer-new-link{
    width: 1180px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    padding-bottom: 20px;
}

.footer-new-box-ttl{
    font-size: 16px;
    font-weight: 500;
    border-bottom: 1px solid;
    padding-bottom: 15px;
    margin-bottom: 20px;
}
.footer-new-list{
    min-width: 200px;
}
.footer-new-list-ttl{
    padding-bottom: 10px;
    font-weight: 500;}

.footer-new-list-item{
    font-size: 12px;
    padding-bottom: 10px;
}
.footer-new-list-wrap{
    display: flex;
}
.footer-new-list-left{
    padding-right: 30px;
}
.footer-new-list-wrap .footer-new-list {
    padding-bottom: 15px;
}
.footer-new-contact{
    width: 1180px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    padding-bottom: 40px;
}

.footer-new-contact-bnr{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 575px;
    height: 60px;
    background: #fff;
    border-radius: 6px;
    position:relative;
}

.footer-new-contact-bnr-text{
    display: flex;
    align-items: center;
    padding-left: 35px;
}

.footer-new-contact-bnr-text span{
    font-size: 16px;
    position: relative;
    padding-right: 10px;
    margin-right: 15px;
}
.footer-new-contact-bnr-text span:before{
    content: "";
    display: block;
    position: absolute;
}

.footer-new-contact-bnr-text .contact-web:before{
    background: url(https://www.cosmosfoods.jp/client_info/COSMOS/view/userweb/assets/img/footer-contact-icon-mail.svg) no-repeat 0 0;
    width: 21px;
    height: 17px;
    top: 2px;
    left: -30px;
}

.footer-new-contact-bnr-text .contact-tel:before{
    background: url(https://www.cosmosfoods.jp/client_info/COSMOS/view/userweb/assets/img/footer-contact-icon-tel.svg) no-repeat 0 0;
    width: 16px;
    height: 18px;
    top: 2px;
    left: -24px;
}

.footer-new-contact-bnr-text span:after {
    content: "";
    display: block;
    width: 1px;
    height: 20px;
    background: #ccc;
    position: absolute;
    top: 0;
    right: 0;
}
.footer-new-contact li:first-child .footer-new-contact-bnr:after {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border-top: 1px solid #212121;
    border-right: 1px solid #212121;
    -webkit-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    position: absolute;
    top: 30px;
    right: 35px;
}
.footer-new-company{
    width: 1180px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.footer-new-company-left{
    display: flex;
}
.footer-new-company-left p{
    font-weight: 500;
    font-size: 14px;
    padding-bottom: 10px;
}
.footer-new-company-left li{
    padding-right: 30px;
}
.footer-new-company-right{
    font-size: 12px;
}
.footer-new-company-right p{
    padding-bottom: 10px;
}
.footer-new-company-info{
    display: flex;}

.footer-new-company-info li {
    position: relative;
    padding: 0 10px;
}

.footer-new-company-info li:after{
    content: "";
    display: block;
    width: 1px;
    height: 12px;
    background: #212121;
    position: absolute;
    top: 2px;
    right: 0;

}

.footer-new-company-info li:first-child:before{
    content: "";
    display: block;
    width: 1px;
    height: 12px;
    background: #212121;
    position: absolute;
    top: 2px;
    left: 0;

}

.nav-accordion,.nav-accordion-child{
    pointer-events: none;
}

.nav-contents-sp{
    display: none;
}

@media screen and (max-width: 768px) {
.footer-new {
    padding: 30px;
}
.footer-new-link{
    width: 100%;
    display: block;
    padding-bottom: 20px;
}

.footer-new-box-ttl {
    font-size: 12px;
    font-weight: 500;
    padding: 15px;
    margin-bottom: 0;
}

.footer-new-list-wrap{
    display: none;
    background: #fff;
}

.footer-new-list {
    display: none;
    border-bottom: 1px solid #212121;
    background: #fff;
    padding: 0 !important;
    overflow: hidden;
}
.footer-new-list-item {
    font-size: 12px;
    padding-bottom: 0;
    float: left;
    width: 50%;
    box-sizing: border-box;
}

.footer-new-list-item a {
    display: block;
    padding: 0 15px 0 30px;
    position: relative;
    border-bottom: 1px solid #ccc;
    border-right: 1px solid #ccc;
    height: 40px;
    display: flex;
    align-items: center;
    font-size: 11px;
    letter-spacing: 0;
}
.footer-new-list-item a:before {
    content: "";
    display: block;
    width: 5px;
    height: 5px;
    border-top: 1px solid #212121;
    border-right: 1px solid #212121;
    -webkit-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    position: absolute;
    top: 20px;
    left: 10px;
}
.footer-new-contact {
    width: calc(100% - 20px);
    margin: 0 auto;
    display: block;
    padding-bottom: 0;}

.footer-new-contact li{
    padding-bottom: 20px;
}

.footer-new-contact-bnr {
    width: 100%;
    height: 60px;
}

.footer-new-contact-bnr-text {
    display: block;
    padding-left: 15px;
}

.footer-new-contact-bnr-text span {
    font-size: 12px;
    padding-right: 0;
    margin-right: 0;
    padding-bottom: 6px;
    display: block;
}

.footer-new-contact-bnr-text .contact-web:before {
    left: -35px;
    top: 6px;
}

.footer-new-contact-bnr-text span:after {
    content: none;
}

.footer-new-contact-bnr-text small {
    display: block;
    font-size: 10px;
}

.footer-new-contact li:first-child .footer-new-contact-bnr:after {
    top: 30px;
    right: 23px;
}

.footer-new-contact-bnr-text .contact-tel:before {
    background: url(https://www.cosmosfoods.jp/client_info/COSMOS/view/userweb/assets/img/footer-contact-icon-tel.svg) no-repeat 0 0;
    width: 22px;
    height: 22px;
    top: 6px;
    left: -28px;
    background-size: 18px;
}

.footer-new-company {
    width: calc(100% - 40px);
    display: block;
}

.footer-new-company-left {
    display: flex;
    padding-bottom: 20px;
}

.footer-new-company-left p {
    font-size: 11px;
    padding-bottom: 10px;
}

.footer-new-company-right {
    font-size: 11px;
    display: flex;
    flex-direction: column-reverse;
}

.footer-new-company-info {
    padding-bottom: 10px;
    flex-wrap: wrap;
}

.footer-new-company-info li {
    position: relative;
    padding: 0 10px 10px;
    font-size: 12px;
}

.nav-accordion,.nav-accordion-child {
    position: relative;
    pointer-events: initial;
}

.nav-accordion:after,
.nav-accordion:before {
    content: "";
    display: block;
    width: 12px;
    height: 2px;
    border: 0;
    background: #212121;
    position: absolute;
    top: 50%;
    right: 20px;
    margin-top: -2px -webkit-transition: all 0.3s 0s ease;
    transition: all 0.3s 0s ease;
}

.nav-accordion:after {
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
}

.nav-accordion+.nav-accordion-contents {
    display: none;
}

.nav-accordion.is-open:after {
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    transform: rotate(180deg);
}

.nav-accordion.is-open:before {
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    transform: rotate(180deg);
}

.nav-accordion.is-open+.nav-accordion-contents {
    display: block;
}

.ph-gNavi-new-list-item-wrap{
    display: none;
    overflow: hidden;
}

.footer-new-list-left {
    padding-right: 0;
}

.footer-new-list-ttl {
    font-size: 11px;
    font-weight: 400;
    padding: 15px;
    border-bottom: 1px solid #ccc;
}

}

/*page_top*/

#page_top{
    position: fixed;
    bottom: 30px;
    right: 22px;
    height: 25px;
}

#page_top a{
    display: block;
    height: 30px;
}

#page_top a:before{
    content: "";
    width: 30px;
    height: 2px;
    background: #ccc;
    display: block;
    right: 3px;
    position: relative;
}

#page_top a:after{
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    border-top: 2px solid #ccc;
    border-right: 2px solid #ccc;
    -webkit-transform: rotate(315deg) translateY(-50%);
    transform: rotate(315deg) translateY(-50%);
    position: absolute;
    top: 20px;
    right: 0;
}


/*breadcrumb*/

.breadcrumb {
    padding: 0 0 20px 0;
    font-size: 11px;
}

.breadcrumb li{
    display: inline-block;
}

.breadcrumb a{
    text-decoration: underline;
}

/*breadcrumb new*/
.breadcrumbs{
    width: 1100px;
    margin: 20px auto 20px;
    font-size: 12px;
}

/*btn*/
.btn-wrap{
    text-align: center;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border: none;
    text-decoration: none !important;
    width: 200px;
    height: 50px;
    border-radius: 30px;
    color: #fff !important;
    background: #212121;
    font-size: 14px;
    position: relative;
    padding-bottom: 1px;
    overflow: hidden;
}

.btn:before {
    content: "";
    display: block;
    width: 24px;
    height: 1px;
    background: #fff;
    position: absolute;
    top: 26px;
    right: 35px;
}

.btn:after {
    content: "";
    display: block;
    width: 2px;
    height: 8px;
    background: #fff;
    -webkit-transform: rotate(45deg) translateY(-50%);
    transform: rotate(315deg) translateY(-50%);
    position: absolute;
    top: 23px;
    right: 35px;
}

.btn-en{
    font-family: 'Yu Gothic', serif;
    font-weight: 400;
}


.btn-large{
    width: 375px;
    height: 75px;
    font-size: 20px;

}

.btn-large:after {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    top: 34px;
    right: 35px;
    width: 11px;
    height: 11px;
}

.btn:hover::before {
  bottom: 0;
}

.btn-back:after{
    top: 17px;
    left: 25px;
    right: inherit;
    -webkit-transform: rotate(225deg) translateY(-50%);
    transform: rotate(225deg) translateY(-50%);
}

.cmn-btn-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
}

button.btn-downArrow:after{
    top: 19px;
    -webkit-transform: rotate(135deg) translateY(-50%);
    transform: rotate(135deg)
}

button:hover{
    cursor: pointer;
    opacity: 0.75;
}

.btn-mini{
    height: 35px;
}

.btn-mini:after {
    top: 18px;
}

.btn-mini:before {
    width: 22px;
    top: 21px;
}


/*archive-title*/

.archive-title{
    width: 100%;
    min-height: 180px;
    padding: 20px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    position: relative;
}

.archive-title-inner{
}

.archive-title .head-en {
    padding-bottom: 10px;
}

.archive-title-lead{
    font-family: 'Noto Serif JP', serif;
}

.page-template-newposts .archive-title,
.archive-title-column{
    background: #ddf3f3;
}

.archive-title-recipe{
    background: #faf9e9;
}

.archive-title-feature{
    background: #f5f5f5;
}

.archive-title-mission,
.tag-herb .archive-title-column,
.tag-mad-scientist .archive-title-column{
    background: #e6f9d6;
}

.archive-title-foodsdiversity{
    background: #d8f1d9;
}

.archive-title-video{
    background: #f5e9f7;
}



.archive-title-tab{
    display: flex;
    align-items: center;
    padding-top: 15px;
    flex-wrap: wrap;
    justify-content: center;
}

.archive-title-tab-item{
    padding: 0 5px 5px;
}

.archive-title-tab-item a{
    display: block;
    border: 1px solid #252525;
    font-size: 11px;
    border-radius: 20px;
    padding: 5px 10px;
}

.archive-title-tab-item a:hover{
    background: #252525;
    color: #fff;
    opacity: 1;
}

.archive-title-tab-item a.selected,
.term-misoshiru .archive-title-tab-item.misoshiru a,
.term-soup .archive-title-tab-item.soup a,
.term-osuimono .archive-title-tab-item.osuimono a,
.term-fruitpowder .archive-title-tab-item.fruitpowder a,
.term-herb .archive-title-tab-item.herb a,
.term-others .archive-title-tab-item.others a{
    background: #252525;
    color: #fff;
    border: none;
}

@media screen and (max-width: 750px){
    .archive-title {
        width: 100%;
        min-height: 120px;
    }    
}

/*head*/
.head-lv1 {
    font-size: 24px;
    letter-spacing: 4px;
    padding-bottom: 20px;
    border-bottom: 1px solid #999;
}

.head-lv1 + div .post-summary-tagList{
    border-top: none !important;
}

.head-en {
    text-align: center;
    font-size: 25px;
    font-family: 'Yu Gothic', serif;
    display: inline-block;
    width: 100%;
    line-height: 1;
    padding-bottom: 30px;
    font-weight: bolder;
    letter-spacing: 0.07;
}

.head-jp {
    text-align: center;
    font-size: 32px;
    font-family: 'Noto Serif JP', serif;
    display: inline-block;
    width: 100%;
    line-height: 1;
    padding-bottom: 10px;
    font-weight: 500;
    letter-spacing: 2px;
}

.head-lv2 .jp {
    font-size: 28px;
    font-weight: 500;
    letter-spacing: 4px;
}


.head-lv2-pb-large{
    padding-bottom: 60px;
}

.head-lv3 {
    font-size: 20px;
    font-weight: 500;
    padding-bottom: 50px;
    padding-left: 20px;
    letter-spacing: 1px;
    position: relative;
}

.head-lv3:before {
    content: "";
    display: block;
    position: absolute;
    background: #aa1b49;
    width: 8px;
    height: 20px;
    top: 9px;
    left: 0;
}

.head-lv3.include-span {
    padding-right: 100px;
}

.head-lv3 span {
    top: 8px;
}

.head-lv4 {
    font-size: 18px;
    font-weight: 500;
    padding-bottom: 15px;
    color: #aa1b49;
}

.post-title {
    font-size: 24px;
    letter-spacing: 4px;
    padding-bottom: 20px;
    border-bottom: 1px solid #999;
    margin-bottom: 25px;
    width: 100%;
}

.common-sec-title{
    font-size: 24px;
    line-height: 1.5;
    letter-spacing: 2px;
    padding-bottom: 20px;
}

.title-btn [class^="head-"] {
    padding-right: 110px;
}

.contents{
    width: 1100px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0 0 80px;
}

.archive-title + .contents{
    padding: 40px 0 80px;
}

.single .contents,
.single .breadcrumbs{
    width: 750px;
}

.main{
    width: 796px;
}

.main-oneColumn{
    width: 100%;
}

.block {
    width: 100%;
    padding: 0 0 60px;
}

.block-top-overlay {
    margin-top: -250px;
    padding-top: 300px;
}

.block-above-top-overlay{
    padding-bottom: 0;
    position: relative;
}

.bg-gray {
    background: #f3f3f3;
}

.bg-white {
    background: #fff;
}

.inner {
    width: 100%;
    padding: 50px 0;
    max-width: 1100px;
    margin: 0 auto;
}

.inner.mw-800 {
    max-width: 800px !important;
}

.block .inner:last-child {
    padding: 50px 0 90px;
}

.block .inner+.inner {
    margin-top: -50px;
}

.border-top {
    border-top: 1px solid #656565;
}

.text-notice {
    padding-bottom: 40px;
    text-align: center;
}

/*pager*/
.wp-pagenavi {
    display: flex;
    align-items: center;
    justify-content: center;
}

.wp-pagenavi .current {
    background: #212121;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    margin: 0 5px;
}

.wp-pagenavi .page {
    border: 1px solid;
    color: #212121;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    margin: 0 5px;
}

.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink,
.wp-pagenavi .last,
.wp-pagenavi .first{
    text-indent: -9999px;
    position: relative;
    display: inline-flex;
    width: 20px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.wp-pagenavi .previouspostslink:before,
.wp-pagenavi .nextpostslink:before,
.wp-pagenavi .last:before,
.wp-pagenavi .last:after,
.wp-pagenavi .first:before,
.wp-pagenavi .first:after{
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    position: absolute;
    top: 14px;
}

.wp-pagenavi .nextpostslink:before,
.wp-pagenavi .last:before{
    left: 10px;
    border-top: 1px solid #212121;
    border-right: 1px solid #212121;
    -webkit-transform: rotate( 45deg) translateY(-50%);
    transform: rotate( 45deg) translateY(-50%);    
}

.wp-pagenavi .last:after{
    left: 17px;
    border-top: 1px solid #212121;
    border-right: 1px solid #212121;
    -webkit-transform: rotate( 45deg) translateY(-50%);
    transform: rotate( 45deg) translateY(-50%);    
}

.wp-pagenavi .first:before,
.wp-pagenavi .first:after,
.wp-pagenavi .previouspostslink:before{
    right: 10px;
    border-bottom: 1px solid #212121;
    border-left: 1px solid #212121;
    -webkit-transform: rotate( 45deg) translateY(-50%);
    transform: rotate( 45deg) translateY(-50%);    
}

.wp-pagenavi .first:after{
    right: 17px;
    border-bottom: 1px solid #212121;
    border-left: 1px solid #212121;
    -webkit-transform: rotate( 45deg) translateY(-50%);
    transform: rotate( 45deg) translateY(-50%);    
}


/*common-3col*/
.common-postList{
    overflow: hidden;
    margin: 0 -10px;
    display: flex;
    flex-wrap: wrap;
}

.postList-items{
    width: 252px;
    margin: 0 10px 40px;
}

.common-postList-summary{
    display: flex;
    justify-content: space-between;
    line-height: 1;
    padding-bottom: 10px;
    width: 100%;
}

.common-postList-cat{
    font-size: 10px;
    background: #3e3e3e;
    color: #fff;
    padding: 3px 5px;
}

.common-postList-date{
    font-size: 12px;
}

/*postList*/
.postList > li a{
    display: block;
}
.postList-image{
    margin-bottom: 10px;
}

.postList-image img{
    width: 100%;
    height: auto;
}

.postList-title{
    letter-spacing: 1px;
    font-weight: 500;
}

.link-gaibu span{
}

.link-gaibu span:after{
    content: "";
    display: inline-block;
    width: 14px;
    height: 14px;
    background: url(../images/icon-link.svg) no-repeat;
    margin-left: 5px;
}

.mv-items .link-gaibu span:after{
    background: url(../images/icon-link-white.svg) no-repeat;
}

/*post-tagList*/
.post-tagList{
}

 .post-tagList li{
    padding-right: 10px;
    margin-bottom: 10px;
}

.post-tagList li a{
     display: block;
    background: #3e3e3e;
    color: #fff;
    font-size: 11px;
    border-radius: 6px;
    padding: 5px 10px;
}

.sidebar-tags .post-tagList li{
    display: inline-block;
}

#post-tagList{
    display: none;
}

.tag-block .tagPage-item{
    display: none;
}

.tagPage-tagList,
.authorPage-authorList{
    display: none;
}

.postList > li.is-hidden.tagPage-item-block{
    opacity: 1;
    height: auto;
    margin: 0 10px 40px;
    display: block;
}

/*post-losding*/
.postList > li.is-hidden {
    opacity: 0;
    height: 0;
    margin: 0;
}
.list-btn {
    margin-top: 20px;
}
.list-btn.is-btn-hidden{
    display:none;
}

.postList > li.tag-display{
    opacity: 1;
    height: auto;
    display:block;
    margin: 0 10px 40px;
}


/*topics-table*/
.topics-table{
    margin-bottom: 3vh;
}

.topics-table th {
    padding: 15px;
    box-sizing: border-box;
    background: #f5f5f5;
    border: 1px solid #ccc;
    font-weight: 500;
}

.topics-table td {
    padding: 15px;
    box-sizing: border-box;
    border: 1px solid #ccc;
}

/*form*/
input[type="text"], input[type="tel"], input[type="email"], input[type="password"], input[type="url"] {
    border: 1px solid #ccc;
    padding: 6px 10px;
    margin-right: 10px;
    width: 100%;
    height: 35px;
    vertical-align: middle;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

textarea {
    border: 1px solid #ccc;
    padding: 20px 3px 20px 20px;
    height: 160px;
    width: 100%;
    position: relative;
    overflow: hidden;
}

/*comments*/
.comment-respond{
    background: #fcfcfc;
    padding: 35px 40px;
}

.comment-reply-title{
    font-size: 18px;
    font-weight: 500;
    padding-bottom: 15px;
}

.comment-form p {
    padding-bottom: 20px;
}

.comment-form p label {
    display: block;
    font-weight: 500;
    padding-bottom: 5px;
}

.comment-form p .required{
    color: #e29e9e;
}

p.comment-form-cookies-consent label{
    display: inline-block;
    font-size: inherit;
    font-weight: normal;
}

.form-submit input[type="submit"]{
    color: #fff;
    border: none;
    background: #212121;
    border-radius: 4px;
    text-align: center;
    padding-top: 1px;
    padding: 5px 15px;
    position: relative;
    height: 40px;
    font-family: 'Noto Sans JP', sans-serif;
}

.form-submit input[type="submit"]:hover{
    opacity: .75;
    cursor: pointer;
}

.comment-list {
    border: 1px dotted #ccc;
    padding: 30px;
    margin-bottom: 40px;
}

.comment-body {
    padding-bottom: 20px;
}

.comment-meta{
    font-size: 12px;
}

.comment-author img{
    border-radius: 50%;
    margin-right: 20px;
    position: absolute;
    left: -50px;
    top: 10px;
}

.reply{
    padding-left: 50px;
}

.comment-reply-link{
    font-family: 'Noto Sans JP', sans-serif;
    text-decoration: underline;
}

.comment {
    border-bottom: 1px dotted #ccc;
    padding: 0 0 30px 0;
    margin-bottom: 35px;
}

.comment .comment {
    border: none;
    padding: 0;
    margin-bottom: 0;
}

.children > .comment + .comment {
    padding: 30px 0 0px 0;
}

.children {
    padding-left: 50px;
}

.comment-body:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border: none;
}

.comment-content {
    padding: 0px 15px 15px 15px;
    background: #fcfcfc;
    margin-left: 50px;
    margin-bottom: 10px;
}

.comment-metadata {
    margin-left: 50px;
    background: #fcfcfc;
    padding: 0 15px 10px 15px;
}

.comment-author.vcard {
    background: #fcfcfc;
    position: relative;
    margin-left: 50px;
    padding: 15px 15px 0px 15px;
}

.comment:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border: none;
}

/* ========================================================
   for SP
===========================================================*/

@media screen and (max-width: 750px) {
    /*common*/
    body {
        font-size: 11px;
        line-height: 1.5;
        /*padding-top: 117px;*/
        padding-top: 100px;
        min-width: 0;
    }
    a:hover {
        opacity: 1;
    }
    .breadcrumbs {
        width: 100%;
        margin: 0;
        font-size: 12px;
        padding: 10px 15px;
    }

    .btn-wrap {
        padding-top: 0;
    }
    .btn {
        width: 200px;
        height: 50px;
        font-size: 12px;
        padding-bottom: 0;
    }
    .btn:after {
    }
    .btn-large:after {
        right: 20px;
    }
    .btn-mini{
        width: 140px;
        height: 35px;
        max-width: 100%;
        text-align: left;
        justify-content: left;
        padding-left: 25px;
    }
    .btn-mini:before{
        top: 17px;
        right: 20px;
    }
    .btn-mini:after{
        top: 17px;
        right: 20px;
    }
    .pc-hide {
        display: block !important;
    }
    .sp-hide {
        display: none !important;
    }
    .contents,
    .main,
    .sidebar {
        width: 100%;
    }
    .contents{
        display: block;
        padding: 7vw;
    }
    .single .contents,
    .single .breadcrumbs{
        width: 100%;
    }
    .archive-title + .contents {
        padding: 20px;
    }
    .main{
        padding-bottom: 30px;
    }
    .block {
        padding: 0 0 40px;
    }
    .block-top-overlay {
        margin-top: 0;
        padding-top: 30px;
    }
    .inner {
        width: 100%;
        padding: 30px 0;
    }
    .block .inner:last-child {
        padding: 30px 0;
    }
    .block .inner+.inner {
        margin-top: -30px;
    }
    .link-more {
        padding-top: 30px;
    }
    #page-top img {
        width: 60px;
        height: 60px;
    }
    .sp-mb20 {
        margin-bottom: 20px;
    }
    .common-lead-text {
        padding: 0 30px 30px;
        letter-spacing: 1px;
    }
    .common-lead-text big{
        font-size: 14px;
    }
    .cmn-text-small{
        font-size: 10px;
    }
    /*sub-mv*/
    .sub-mv {
        height: 150px;
    }
    .page-title span {
        font-size: 20px;
    }
    .page-title small {
        font-size: 14px;
        padding-top: 10px;
    }
    /*head*/
    .head-lv1 {
        font-size: 14px;
        letter-spacing: 4px;
        padding-bottom: 15px;
    }
    .head-lv1 span {
        font-size: 10px;
        padding-top: 8px;
        display: inline-block;
    }
    button.btn-downArrow:after{
        top: 20px;
        -webkit-transform: rotate(135deg) translateY(-50%);
        transform: rotate(135deg)
    }
    .head-lv2 {
        padding-bottom: 20px;
    }
    .head-lv2 .en {
        font-size: min(7.2250vw, 34px);
        padding-bottom: 0;
    }
    .head-lv2 .jp {
        font-size: 18px;
    }
    .head-lv2 small {
        font-size: 12px;
        letter-spacing: 1px;
    }
    .head-lv2-above-lead-text {
        padding-bottom: 10px;
    }

    .head-en {
        font-size: 25px;
        padding-bottom: 20px;
    }

    .head-en + span {
        font-size: 12px;
        letter-spacing: 1px;
        margin-top: -15px;
    }

    .head-jp {
        font-size: 18px;
    }
    
    .head-lv3 {
        font-size: 14px;
        padding-bottom: 10px;
        padding-left: 15px;
    }
    .head-lv3:before {
        width: 5px;
        height: 16px;
        top: 2px;
        left: 0;
    }
    .head-lv3 span {
        top: 2px;
    }
    .head-lv4 {
        font-size: 12px;
        font-weight: 500;
        padding-bottom: 10px;
        color: #aa1b49;
    }
    .head-border {
        margin-bottom: 15px;
    }
    .common-sec-title {
        font-size: 16px;
        line-height: 1.5;
        letter-spacing: 2px;
        padding-bottom: 10px;
    }
    .cmn-two-common-txt .common-sec-title {
    }
    
    .post-title {
        font-size: 16px;
        letter-spacing: 2px;
        padding-bottom: 15px;
        margin-bottom: 20px;
    }
    
    /*header*/
    .header {
        padding-bottom: 0;
        /*height: 117px;*/
        height: 60px;
    }
    .header .logo {
        padding-top: 5px;
        height: 100%;
    }
    .header .logo img{
        width: 120px;
        height: auto;
    }
    
    .header .common-btn-shop{
        position: absolute;
        left: 12px;
        top: 13px;
        width: 36px;
        height: 36px;
        border-radius: 36px;
        padding: 0;
    }
    .header .common-btn-shop:before {
        width: 18px;
        height: 18px;
        position: absolute;
        left: 9px;
        top: 7px;
        background-size: 18px;
    }
    .header .common-btn-shop span{
        font-size: 10px;
        position: absolute;
        bottom: 0;
        left: 0;
        transform: scale(0.75);
        letter-spacing: 1px;
        display: block;
        width: 100%;
    }
    .header-top {
        width: 100%;
        height: 60px;
        justify-content: center;
        border-bottom: 1px solid #ccc;
    }
    .header.hide {
        /*transform: translateY(-117px);*/
        transform: translateY(0);
    }
    .sp-header-shop{
        background: #212121;
        width: 38px;
        height: 38px;
        border-radius: 20px;
        position: absolute;
        left: 20px;
        top: 13px;   
    }
    .sp-header-shop img{
        position: absolute;
        top: 6px;
        left: 8.5px;
    }
    .sp-header-shop span{
        position: absolute;
        color: #fff;
        font-size: 10px;
        letter-spacing: 0px;
        white-space: nowrap;
        bottom: 2px;
        left: 5px;
        font-weight: 500;
        transform: scale(0.8);
    }
    .gnav{
        position: relative;
        z-index: -1;
        -webkit-transition: all 0.3s 0s ease;
        transition: all 0.3s 0s ease;
        position: relative;
        -webkit-transform: translate3d(0, -100%, 0);
        transform: translate3d(0, -100%, 0);
        border-bottom: none;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        height: auto;
        min-width: 0;
        background: #f1f1f1;
    }
    .menu-open .gnav {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
    .gnav>ul {
        display: block;
        margin-left: 0;
        width: 100%;
    }
    .gnav>ul li {
        display: block;
        margin-left: 0;
        border-bottom: 1px solid #e2dfdf;
        color: #070707;
        padding: 0 0 0 20px;
    }
    .gnav>ul li:hover:after {
        content: none;
    }
    .gnav>ul>li>a {
        padding: 15px 0px 15px 0px;
        text-align: left;
        height: auto;
        justify-content: left;
        color: #070707;
        font-size: 11px;
        font-weight: 400;
        position: relative;
        line-height: 1;
        width: 100%;
    }
    .gnav>ul>li>a:after {
        content: "";
        display: block;
        width: 9px;
        height: 9px;
        border-top: 1px solid #212121;
        border-right: 1px solid #212121;
        -webkit-transform: rotate(45deg) translateY(-50%);
        transform: rotate(45deg) translateY(-50%);
        position: absolute;
        top: 25px;
        right: 25px;
    }

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

    .gnav>ul>li:hover a{
        color: #070707;
        background: #f1f1f1;
    }

    .menu-btn {
        position: absolute;
        /*top: 56px;*/
        top: 20px;
        right: 20px;
        width: 60px;
        height: 60px;
        cursor: pointer;
        -webkit-transition: all 0.3s 0s ease;
        transition: all 0.3s 0s ease;
    }
    .menu-btn span {
        position: absolute;
        right: 15px;
        width: 30px;
        height: 2px;
        background-color: #212121;
        display: inline-block;
        -webkit-transition: all 0.3s 0s ease;
        transition: all 0.3s 0s ease;
    }
    
    .header-topPage .menu-btn span {
        background-color: #fff;
    }
    
    .header-w .menu-btn span {
        background-color: #212121;
    }
    
    .menu-btn span:nth-of-type(1) {
        top: 19px;
    }
    .menu-btn span:nth-of-type(2) {
        top: 28px;
    }
    .menu-btn span:nth-of-type(3) {
        bottom: 20px;
    }
    .menu-btn.is-open span:nth-of-type(1) {
        -webkit-animation: open-menu-bar01 0.6s forwards;
        animation: open-menu-bar01 0.6s forwards;
    }
    .menu-btn.is-open span:nth-of-type(2) {
        opacity: 0;
    }
    .menu-btn.is-open span:nth-of-type(3) {
        -webkit-animation: open-menu-bar03 0.6s forwards;
        animation: open-menu-bar03 0.6s forwards;
    }
    .menu-btn.is-close span:nth-of-type(1) {
        -webkit-animation: close-menu-bar01 0.6s forwards;
        animation: close-menu-bar01 0.6s forwards;
    }
    .menu-btn.is-close span:nth-of-type(2) {
        -webkit-transition: all 0.3s 0s ease;
        transition: all 0.3s 0s ease;
        opacity: 1;
    }
    .menu-btn.is-close span:nth-of-type(3) {
        -webkit-animation: close-menu-bar02 0.6s forwards;
        animation: close-menu-bar02 0.6s forwards;
    }
    
    /*nav-accordion*/

    .nav-accordion-child,
    .nav-accordion {
        padding: 15px 30px 15px 15px;
        text-align: left;
        height: auto;
        justify-content: left;
        position: relative;
    }

    .nav-accordion:after,
    .nav-accordion:before,
    .nav-accordion-child:after,
    .nav-accordion-child:before{
        content: "";
        display: block;
        width: 12px;
        height: 2px;
        top: 50%;
        right: 20px;
        margin-top: -2px;
        position: absolute;
        background: #212121;    
        -webkit-transition: all 0.3s 0s ease;
        transition: all 0.3s 0s ease;
    }
    
    .nav-accordion-child:after,
    .nav-accordion:after {
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
    }

    .nav-accordion+.nav-accordion-contents {
        display: none;
    }

    .nav-accordion-child.is-open:after,
    .nav-accordion.is-open:after {
        -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
    }

    .nav-accordion-child.is-open:before,
    .nav-accordion.is-open:before {
        -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
    }

    .nav-accordion.is-open+.nav-accordion-contents {
        display: block;
    }
    
    /*megamenu*/
    .megamenu{
        display: none;
        -webkit-transition: none;
        transition: none;
        -webkit-transform: none;
        transform: none;
        position: static;
        z-index: 0;
        width: 100%;
        background: #fff;
        padding: 20px;
        list-style: none;
        box-sizing: border-box;
        box-shadow: none;
        -webkit-box-shadow: none;
        -moz-box-shadow: none;
    }
    
    .megamenu-inner {
        width: 100%;
    }
    
    .gnav .has-megamenu:hover .megamenu {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
    
    .megamenu-img{
        display: none;
    }
    
    .megamenu-link {
        display: block;
        width: 100%;
    }
    
    .gnav>ul li.megamenu-link-list {
        border-bottom: none;
        padding: 10px 0;
    }
    
    .gnav>ul li.megamenu-link-list:first-of-type{
        padding-top: 0;
    }
    
    .gnav>ul li.megamenu-link-list:last-of-type{
        padding-bottom: 0;
    }
    
    .megamenu-link-list a:before,
    .megamenu-link-list a:after{
        content: none;
    }
    
    .header-search{
        display: none;
    }
    
    .header-onlineShop small:after{
        content: "";
        display: inline-block;
        width: 11px;
        height: 11px;
        background: url(../images/icon-link-black.svg) no-repeat;
        background-size: cover;
        position: relative;
        top: 2px;
        left: 4px;
    }
    
    /*footer*/
    .footer {
        padding: 30px 20px;
    }
    .footer-inner {
        width: 100%;
        margin: 0 auto;
    }
    .footer .logo img {
        width: 120px;
        height: auto;
    }
    .footer-top {
        display: block;
    }
    .footer-left{
        padding-bottom: 15px;
    }
    .footer-bottom {
        font-size: 10px;
        color: #777;
    }
    
    /*footer-tag-writter*/
    .footer-tag-writter{
        background: #e4e4e4;
        padding: 50px 0;
    }

    .footer-tag-writter .head-en{
        font-size: 30px;
        text-decoration: underline;
        padding-bottom: 20px;
    }

    .footer-tag-writter-inner{
        display: block;
        justify-content: space-between;
        width: 100%;
        margin: 0 auto;
    }

    .footer-tag {
        width: 100%;
        padding-bottom: 20px;
    }

    .footer-tag .post-tagList {
        text-align: center;
    }

    .footer-tag .post-tagList li{
        display: inline-block;
    }

    .footer-writer {
        width: 100%;
    }
    
    .footer-tag-writter {
        padding: 20px;
    }
    
    .footer-tag-writter .head-en {
        font-size: 28px;
    }
    

    .footer-writter-item a {
        margin: 0 40px;
        width: calc(100% - 80px);
        background: #fff;
        padding: 15px;
        border-radius: 6px;
    }
    
    .footer-writter-item .sidebar-postList-image {
        width: 50px;
        height: 50px;
        border-radius: 30px;
    }
    
    .sidebar-postList-image img {
        width: 50px;
        height: auto;
    }
    
    .footer-writter-item .sidebar-postList-text {
        width: calc(100% - 65px);
    }

    /*column*/
    .common-sp-2col-items{
        width: calc(50% - 10px);
        margin: 0 5px 20px;
    }

    .common-3col{
        margin: 0 -2.5px;
    }
    
    /*post-list*/
    .common-postList{
        margin: 0;
    }
    .common-postList .postList-items {
        width: calc(50% - 7.5px);
        margin: 0px 15px 20px 0px;
    }
    .common-postList .postList-items:nth-child(even) {
        margin-right: 0;
    }
    .postList > li a{
        display: block;
        position: relative;
    }
    .postList .common-postList-cat{
        position: absolute;
        top: 0;
        left: 0;
    }
    .common-postList-summary {
        padding-bottom: 7px;
    }
    .postList-text .common-postList-summary {
        display: block;
    }
    .postList-text .common-postList-summary .common-postList-cat {
        display: inline-block;
        margin-bottom: 5px;
    }
    .common-postList-cat {
        font-size: 10px;
    }
    .common-postList-date {
        font-size: 10px;
    }
    
    .link-gaibu span:after {
        width: 11px;
        height: 11px;
    }

    .postList > li.tag-display{
        margin: 0 5px 20px;
    }

    /*topics-table*/
    .topics-table th,.topics-table td {
        padding: 10px;
    }
    
    /*comment*/
    .comment-respond{
        padding: 25px 30px;
    }
}

/*header-new*/
.home{
    padding: 0;
}
.header-topPage{
    
}

.header-new {
    z-index: 100;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    padding: 20px;
    transition: 0.5s;
    padding: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.gnav-new ul {
    display: flex;
}

.gnav-new-item + .gnav-new-item {
    padding-left: 20px;
}

.header-new .gnav-new-item a{
    font-size: 130%;    
}

.header-topPage .gnav-new-item a {
    color: #fff;
}

.header-new.header-w{
    background: #fff;
}

.header-new.header-w .gnav-new-item a {
    color: #212121;
}

.header-topPage .logo a{
    position: relative;
}

.header-topPage .logo a img{
    display: none;
}

.header-topPage .logo a:before{
    content: "";
    display: block;
    width: 178px;
    height: 70px;
    background: url(../images/logo-w.svg);
    background-size: 178px;
    transition: 0.5s;
}

.header-w .logo a:before{
    content: none;
}


.header-w .logo a img{
    display: block;
}

@media screen and (max-width: 750px) {
    .header-new .logo a img {
        width: 140px;
        height: 56px;
    }  
    
    .header-new .logo a:before{
        width: 140px;
        height: 56px;
        background: 140px;
        background: url(../images/logo-w.svg);
    }
    
    .gnav-new{
        background: #fff;
        width: 90vw;
        position: absolute;
        left: 5vw;
        top: 90px;
        border-radius: 10px;    
        opacity: 0;
        display: none;
        transition: 0.5s;
        box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.3);
    }
    
    .gnav-new ul {
        display: block;
    }
    
    .menu-open .gnav-new{
        opacity: 1;
        display: block;
    }
    
    .gnav-new-item {
        padding: 30px;
    }
    
    .gnav-new-item + .gnav-new-item {
        padding-left: 30px;
        border-top: 1px solid #ddd;
    }
    
    .header-topPage .gnav-new-item a {
        color: #212121;
    }
    
    .header-new .gnav-new-item a{
        position: relative;
        display: block;
    }
    
    .header-new .gnav-new-item a:after {
        content: "";
        display: block;
        width: 9px;
        height: 9px;
        border-top: 1px solid #212121;
        border-right: 1px solid #212121;
        -webkit-transform: rotate(45deg) translateY(-50%);
        transform: rotate(45deg) translateY(-50%);
        position: absolute;
        top: 9px;
        right: 0;
    }
}