@charset "utf-8";
.top_content div{
    /*text-align: center;*/
}

.wrapper {
    position: relative;
    margin: 0 auto;
    display: table;
    width: 100%;
    padding: 0;
    clear: both;
}
@media screen and (max-width: 768px) {
    .wrapper {
        margin: 0px auto;
        display: block;
        width: 100%;
        max-width: 100%;
    }
}
@media screen and (min-width: 769px) {
    .wrapper {
        /*padding: 10px 0;*/
    }
}

.header_inner{
    margin: 0 auto;
    max-width: 1400px;
    width: 100%;
}
@media screen and (min-width: 769px) {
    .pc_wrap{
    margin: 0 auto;
    max-width: 1400px;
    width: 100%;
    }
}

.header_logo{
    padding: 5px 2px 0 5px;
}
@media screen and (max-width: 768px) {
    .header_logo{
        padding: 9px 2px 0 5px;
    }
}
.header_logo img{
    height: 40px;
}
@media screen and (max-width: 768px) {
    .header_logo img{
        height: 30px;
    }
}

.header_title{
    border-bottom: 1px solid #c9c9c9;
    border-top: 1px solid #c9c9c9;
}
.header_title p{
    line-height: 60px;
    /*background: #f9f6e3;*/
}

.menu_nav {
    position: fixed;
    z-index: 20;
    top: 0;
    right: 0;
    overflow: hidden;
    width: 16.25rem;
    height: 100%;
    background-color: #fefefe;
}

.nav_title{
    position: relative;
    padding: 0 10px;
    background: #fefefe;
    color: #333333;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    height: 50px;
    text-align: center;
}
.nav_title span{
    line-height: 50px;
}

.nav_close{
    position: absolute;
    top: 4px;
    right: 5px;
    border: 1px solid #333333;
    padding: 5px 10px;
    border-radius: 0px;
}

.nav_list a {
    position: relative;
    display: block;
    width: 100%;
    border-bottom: 1px solid #333333;
    padding: 8px 10px 8px;
    font-size: 16px;
    font-size: 1rem;
    color: #333333;
}

.nav_icon{
    margin-right: 8px;
    content: " ";
    width: 30px;
    height: 30px;
    display: inline-block;
    vertical-align: middle;
}
.nav_list .i-right{
    position: absolute;
    top: 0;
    right: 15px;
    line-height: 50px;
}

.main-container {
    position: relative;
    margin: 0px auto 40px;
    padding: 0 20px;
    /*background-color: #fffde1;*/
    background-color: #fff;
}
@media screen and (max-width: 768px) {
    .main-container {
        margin: 0px auto;
        padding: 0;
    }
}
.main_image_area{
    text-align: center;
}
.nav_list i{
    width: 36px;
    text-align: center;
}

.main_bg_color{
    background-color: #fefefe;
}
.emp_bg_color{
    background-color: #fefefe;
}
.sub_bg_color{
    background-color: #f9f6e3 !important;
}
.line-bg{
    background-color: #fefefe;
}
.band_bold{
    background-color: #fefefe;
    height: 60px;
}
.band_bold p{
    line-height: 47px;
}
.band_thin{
    background-color: #fefefe;
    height: 7px;
}

.menu_area{
    　overflow: hidden;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.menu_area .menu_item_link{
    /*padding: 16px;*/
    width: 100%;
}
@media screen and (max-width: 768px) {
    .menu_area .menu_item_link{
        padding: 8px;
    }
}
.menu_item_link.active{
    background-color: #f9f6e3;
}
.menu_item_link.active .menu_label{
    font-weight: bold;
}

.menu_area .menu_label{
    margin: 5px -5px 0;
    font-weight: normal;
    font-size: 16px;
    font-size: 1rem;
}
@media screen and (max-width: 768px) {
    .menu_area .menu_label{
        font-size: 12px;
        font-size: 0.75rem;
    }
}
.menu_bar{
    top: 3px;
    right: 5px;
    border: 1px solid #333333;
    padding: 6px 10px;
    border-radius: 0px;
}
.header_cart{
    top: 3px;
    right: 58px;
    border: 1px solid #333333;
    padding: 6px 7px;
    border-radius: 0px;
}
.menu_user{
    top: 3px;
    right: 5px;
    border: 1px solid #333333;
    padding: 6px 10px;
    border-radius: 0px;
}
.header_name{
    top: 3px;
    right: 110px;
}


.product_desc_area{
    /*padding: 20px 15px 15px;*/
}
.h3_title{
    padding: 10px;
    background-color: #333333;
    color: #333333;
}
.h3_title_normal{
    padding: 30px 10px 10px;
    background-color: #fefefe;
    color: #333333;
    border-top: 1px solid #c9c9c9;
}
.news_item{
    padding: 10px 15px 20px;
    font-size: 14px;
    font-size: 0.875rem;
}

.news_date{
    color: #333333;
}

.news_odd{
    color: #fefefe;
}
.news_odd a{
    color: #333333;
    text-decoration: underline;
}
.news_desc{
    line-height: 1.3;
    color: #333333;
}

.btn {
    width: 300px;
    height: 60px;
    line-height: 60px;
    position: relative;
    display: inline-block;
    -moz-border-radius: 0px;
    -webkit-border-radius: 0px;
    border-radius: 0px;
    text-align: center;
    color: #fefefe;
    text-decoration: none !important;
    font-size: 16px;
    font-size: 1rem;
    cursor: pointer;
    font-weight: bold;
}
.btn.btn_more{
    line-height: 45px !important;
    height: 50px !important;
}

.btn.fk{
    line-height: 55px;
}
@media screen and (max-width: 768px) {
    .btn {
        font-size: 16px;
        font-size: 1rem;
    }
}
.btn:hover {
    opacity: 0.8;
    filter: alpha(opacity=80);
    -ms-filter: "alpha(opacity=60)";
    -khtml-opacity: 0.8;
    -moz-opacity: 0.8;
}
.btn-next{
    background: #fefefe;
}
.btn-back{
    background: #ededed;
}

@media screen and (max-width: 768px) {
    .btn{
        width: 100%;
        height: 50px;
        line-height: 50px;
    }
    .btn.fk{
        line-height: 45px;
    }
}
.btn-history {
    width: auto;
    height: auto;
    line-height: 1;
    font-weight: normal;
    font-size: 14px;
    font-size: 0.875rem;
    background-color: #F95738;
}
@media screen and (max-width: 768px) {
    .btn-history {
        width: 80%;
    }
}

.btn .i-left{
    position: absolute;
    top: 0;
    left: 25px;
    line-height: 60px;
}

.pagetop {
    margin: 10px 20px;
}
.pagetop img {
    display: block;
    width: 40px;
    height: 40px;
}
@media screen and (max-width: 768px) {
    .pagetop img {
        width: 30px;
        height: 30px;
    }
}
.item_list{
    background-color: #fefefe;
}
.item_unit{
    border-bottom: 1px solid #333333;
    padding: 5px 0px;
    color: #fefefe;
    width: 100%;
}
@media screen and (min-width: 769px) {
    .item_unit {
        margin-top:10px;
        display:inline-block;
        width: 24.5%;
        border-bottom:none;
        border-right: 1px solid #a7937b;
    }
    .feature_unit .item_unit{
        width: 100% !important;
        border-right: none;
    }
}
@media screen and (max-width: 769px) {
    .item_unit {
        width: 100%;
        display: inline-block;
    }
}
.item_detail_unit{
    color: #333;
}
@media screen and (max-width: 769px) {
    .item_detail_unit{
        padding: 10px;
    }
}
.item_detail_desc_area{
    display: inline-block;
    width: 100%;
}
@media screen and (min-width: 768px) {
    .item_detail_desc_area.option_exist{
        width: 60%;
        vertical-align: top;
        margin-right: 3%;
    }
}
.item_detail_input_area{
    display: inline-block;
    width: 100%;
}
@media screen and (min-width: 768px) {
    .item_detail_input_area.option_exist{
        width: 35%;
    }
}
.item_option_img{
    max-width: 100px;
    height: 100px;
}

.item_option_title_area{
    border-top: 1px solid #bdbdbd;
    border-bottom: 1px solid #bdbdbd;
    background: #fffde1;
    padding: 10px 10px;
    width: 100%;
    font-weight: bold;
    color: #333;
}
@media screen and (min-width: 769px) {
    .option_input_area {
        border-left: 1px solid #bdbdbd;
        border-right: 1px solid #bdbdbd;
        border-bottom: 1px solid #bdbdbd;
        margin-bottom: 10px;
    }
}
@media screen and (max-width: 768px) {
    .option_input_area {
        margin: 0 -10px;
    }
}

.item_detail_unit .title-page{
    padding: 0 0 5px 0;
}
.item_unit .item_left{
    width: 39%;
}
.item_unit .item_right{
    width: 58%;
}
@media screen and (max-width: 768px) {
    .item_unit .item_left{
        width: 35%;
    }
    .item_unit .item_right{
        padding-top: 5px;
        width: 64%;
    }
}

.item_link{
    display: block !important;
}
@media screen and (min-width: 769px) {
    .item_thumb_img {
        width: 120px;
        max-width: 120px;
    }
    .feature_unit .item_thumb_img{
        width: 360px;
        max-width: 360px;
    }
}
@media screen and (max-width: 768px) {
    .item_thumb_img{
        height: 120px;
    }
}
.item_price{
    color: #333333;
    font-weight: bold;
}

.cart_btn{
    background-color: #333333;
    color: #fefefe;
    padding: 8px 10px;
    border-radius: 0px;
}
.cart_btn.sold_out{
    background-color: #ffffff;
    color: #333333;
    border: 1px solid #333333;
}

.item_qty span{
    font-size: 16px;
    font-size: 1rem;
}
.item_qty {
    line-height: 47px;
}

.form-select {
    width: 70px;
    height: 36px;
    background-color: #FFF;
    padding: 0 0 0 10px;
    font-size: 16px;
    font-size: 1rem;
}
.input-num {
    text-align: right;
    padding-right: 5px;
}

.title-page {
    position: relative;
    padding: 5px;
    font-size: 20px;
    font-size: 1.25rem;
    text-align: left;
    border-bottom: 3px solid #fefefe;
    color: #333333;
}

@media screen and (max-width: 768px) {
    .title-page {
        width: 100%;
        font-size: 20px;
        font-size: 1.25rem;
    }
}
.title-page.title-page-small {
    font-size: 20px;
    font-size: 1.25rem;
}

.sp-mypage-menu{
    border-bottom: 1px solid #333333;
}
.sp-mypage-menu li{
    width: 25%;
}
.sp-mypage-menu li.active{
    font-weight: bold;
}
.free_ship{
    padding: 3px 5px;
    margin-left: 7px;
    font-size: 12px;
    font-size: 0.75rem;
    border: solid 1px #F95738;
    background-color: #F95738;
    color: #fff;
    font-weight: normal;
}
.noshi_enable{
    padding: 3px 5px;
    margin-left: 5px;
    font-size: 12px;
    font-size: 0.75rem;
    border: solid 1px #ededed;
    background-color: #ededed;
    color: #333;
    font-weight: normal;
}
.cashless_enable{
    padding: 2px;
    font-size: 12px;
    font-size: 0.75rem;
    border: solid 1px #e40e0e;
    background-color: #333333;
    color: #e40e0e;
    font-weight: bold;
    margin-bottom: 3px;
    display: none;
}
@media screen and (max-width: 768px) {
    .cashless_enable{
        font-size: 10px;
        font-size: 0.625rem;
    }
}
.cart-item-code .noshi_enable{
    font-size: 0.75em;
    border: none;
}
.ship_note{
    padding: 3px 5px;
    margin-left: 7px;
    font-size: 12px;
    font-size: 0.75rem;
    border: solid 1px #333333;
    background-color: #333333;
    color: #fff;
    font-weight: normal;
    display: inline-block;
    vertical-align: middle;
}
.stamp_count{
    padding: 3px 5px;
    margin-left: 7px;
    font-size: 12px;
    font-size: 0.75rem;
    border: solid 1px #fefefe;
    background-color: #333333;
    color: #fefefe;
    font-weight: normal;
}

.shipping_fee{
    padding: 3px 5px;
    margin-left: 7px;
    font-size: 12px;
    font-size: 0.75rem;
    border: solid 1px #fefefe;
    background-color: #fff;
    color: #fefefe;
    font-weight: normal;
}

@media screen and (max-width: 768px) {
    .h1_header_title p{
    line-height: 22px;
    margin-top: 4px;
    text-align: center;
    font-size: 1rem;
    }
}

.header_name p{
    line-height: 22px;
    margin-top: 1px;
    text-align: center;
    font-size: 14px;
    font-size: 0.875rem;
}
@media screen and (max-width: 768px) {
    .header_name p{
        line-height: 20px;
        font-size: 12px;
        font-size: 0.75rem;
    }
}
.member_rank img{
    height: 20px;
}
.member_rank p{
    line-height: 20px;
    margin-top: 0;
}

.point_area{
    background-color: #ededed;
}

.shipping_fee_notice{
    color: #F95738;
    text-align: center;
    font-weight: bold;
}
.stamp_unit{
    padding: 2px;
    width: 10%;
}
@media screen and (max-width: 768px) {
    .stamp_unit{
        width: 20%;
    }
}

.stamp_unit_inner{

}
.stamp_unit_inner img{

}
.stamp_number{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 30px;
    margin: auto;
    height: 0;
    color: #ccc;
}
.stamp_valid{
    color: #fefefe;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 20px;
    margin: auto;
    height: 20px;
    line-height: 20px;
}
@media screen and (max-width: 768px) {
    .stamp_valid{
        bottom: 15px;
    }
}
.stamp_complete{
    top: 4px;
    right: 8px;
    border: 2px solid #fefefe;
    padding: 2px 10px 7px;
    border-radius: 0px;
    background-color: #333333;
}
.stamp_current{
    top: 4px;
    right: 8px;
    border: 2px solid #fefefe;
    padding: 2px 10px 7px;
    border-radius: 0px;
    background-color: #333333;
    color: #fefefe;
}
.stamp_product{
    max-width: 600px;
}
@media screen and (max-width: 768px) {
    .stamp_product{
        max-width: 100%;
    }
}
.stamp_arrow{
    line-height: 216px !important;
    color: #fefefe;
}

.product_desc_area_left{
    width: 30%;
}
.product_desc_area_right{
    width: 69%;
}
@media screen and (max-width: 768px) {
    .product_desc_area_left{
        width: 100%;
    }
    .product_desc_area_right{
        width: 100%;
        padding: 5px 15px 10px;
    }
}
@media screen and (min-width: 769px) {
    .product_desc_area_right{
        padding-left: 20px;
        padding-top: 10px;
    }
    .feature_block .product_desc_area_left{
        width: 45%;
    }
    .feature_block .product_desc_area_right{
        width: 54%;
    }
}
.twitter_area{
    width: 30%;
}
.facebook_area{
    width: 35%;
}
.instagram_area{
    width: 30%;
}
@media screen and (max-width: 768px) {
    .twitter_area{
        width: 90%;
    }
    .facebook_area{
        display: none;
        width: 90%;
    }
    .instagram_area{
        width: 90%;
    }
}
@media screen and (max-width: 768px) and (min-width: 480px) {
    iframe .twitter-timeline-rendered{
        width: 490px !important;
    }
}

@media screen and (max-width: 480px) {
    iframe.twitter-timeline-rendered {
        width: 450px !important;
        margin:0 auto;/*これを入れないとめっちゃ細く200pxくらいで表示されます。以下イメージあり！*/
    }
}

.timeline-Widget {
    max-width: 300px!important;
    width:200px !important;
}

.lp_merit_area{
    padding-bottom: 15px;
}
@media screen and (max-width: 768px) {
    .lp_merit_area{
        padding-bottom: 0;
    }
}

.lp_comment_area{
    width: 49%;
}
.lp_twitter_area{
    width: 40%;
    margin-left: 30px;
}
@media screen and (max-width: 768px) {
    .lp_comment_area{
        width: 100%;
    }
    .lp_twitter_area{
        width: 90%;
        margin-left: 0;
        margin-top: 10px;
        margin-bottom: 10px;
    }
}
.lp_merit_block{
    width: 33%;
    display: inline-block;
    vertical-align: top;
    padding: 10px;
    color: #fefefe;
}
.lp_merit_body h3{
    font-size: 22px;
    font-size: 1.375rem;
    font-weight: bold;
}
.lp_merit_logo{
    padding-bottom: 10px;
}
.lp_merit_body p{
    padding-top: 5px;
    font-size: 16px;
    font-size: 1rem;
}
.lp_character{
    height: 500px;
}
@media screen and (max-width: 768px) {
    .lp_merit_block{
        width: 100%;
        padding: 10px 0;
    }
    .lp_merit_body h3{
        font-size: 20px;
        font-size: 1.25rem;
    }
    .lp_merit_logo{
        display: inline-block;
        width: 19%;
        padding-right: 10px;
        vertical-align: top;
    }
    .lp_merit_body{
        display: inline-block;
        width: 79%;
        text-align: left;
    }
    .lp_merit_body h3{
        text-align: left;
    }
    .lp_merit_body p{
        text-align: left;
    }
    .lp_bb{
        border-bottom: 1px solid #fefefe;
    }
    .lp_character{
        height: auto;
    }
}
.lp_fix_area{
    position: fixed;
    bottom: 0;
    width: 100%;
}
.att-area{
    border: 1px solid #c9c9c9;
    background: #f9f6e3;
    padding: 20px;
    width: 100%;
}
.att-title{
    font-weight: bold;
    color: #333333;
    font-size: 14px;
    font-size: 0.875rem;
}
.cycle_simulate{
    background-color: #f9f6e3;
}
.slot_area{
    margin: 0 auto;
    padding: 10px;
    background-color: #fffde1;
    border-radius: 10px;
}
.lp_option_unit{
    width: 19%;
    margin-bottom: 5px;
}
@media screen and (max-width: 768px) {
    .lp_option_unit{
        width: 49%;
    }
}
.gift_item{
    width: 33%;
    margin-bottom: 5px;
    display: inline-block;
}
@media screen and (max-width: 768px) {
    .gift_item{
        width: 100%;
    }
}
.cashless_logo{
    height: 24px;
    vertical-align: top;
    display: none;
}
.lp_bb{
    border-bottom: 1px solid #fefefe;
    padding-top: 10px;
}
.lp_bb2{
    border-bottom: 1px solid #fefefe;
}
@media screen and (min-width: 769px) {
    .lp_3_block {
        display: inline-block;
        width: 33%;
        padding: 5px;
    }
    .lp_3_block .lp_fix_height{
        height: 300px;
    }
    .lp_pc_rb{
        background-color: #fff9e0;
        border-radius: 0px;
    }
    .lp_sub_content{
        /*margin: 10px 0;*/
    }
    .lp_bb{
        border-bottom: none;
    }
    .lp_bb2{
        border-bottom: none;
    }
}
.bg_washi {
    background: url('https://image.northgrand.jp/common/lp/washi_bg2.jpg') !important;
}

.main_tav_inner{
    border-bottom: none;
}
@media screen and (max-width: 768px) {
    .main_tav_inner{
        border-left: none;
        border-right: none;
    }
}

.main_tav_inner .main_tab_elem{
    width: 33.3%;
    float: left;
    padding: 10px 0;
    border-radius: 10px 10px 0 0;
    border: 1px solid #333333;
    border-bottom: none;
}

.main_tav_inner .main_tab_elem a{
    width: 100%;
}

.main_tab_elem{
    background-color: #333333;
}
.main_tab_elem.middle{

}
.main_tab_elem a{
    color: #333333;
}

.main_tab_elem.active{
    background-color: #333333;
}

.main_tab_elem.active a{
    color: #333333;
}

.top_tab{
    width: 100%;
}
@media screen and (min-width: 769px) {
    .top_tab{
        float: right;
        width: 900px;
    }
}
.top_tab_inner{
    border-bottom: none;
}
@media screen and (max-width: 768px) {
    .top_tab_inner{
        border-left: none;
        border-right: none;
    }
}

.top_tab_inner .top_tab_elem{
    width: 33.3%;
    float: left;
}
@media screen and (max-width: 768px) {
    #top_tab_elem_1,#top_tab_elem_2{
        width: 40%;
    }
    #top_tab_elem_3{
        width: 20%;
    }
}

.top_tab_inner .top_tab_elem a{
    width: 100%;
}

@media screen and (min-width: 769px) {
    .top_tab_elem a {
        line-height: 40px;
    }
}

.btn-regular{
    text-align: center;
    padding: 14px 10px;
    border: 1px solid #c9c9c9;
    color: #333333;
    position: relative;
}
@media screen and (min-width: 769px) {
    .btn-regular{
        max-width: 400px;
        padding: 20px 10px;
    }
}

.search_box{
    padding: 5px 5px 7px 5px;
    background-color: #ededed;
    width: 100%;
}

.menu_prepare{
    opacity: 0.5;
}

.point_reward{
    max-width: 480px;
}
@media screen and (max-width: 768px) {
    .point_reward{
        max-width: 90%;
    }
}
.category_area{
    background: url('https://image.northgrand.jp/common/header/category_bg.jpg');
}

.top_menu_list img{
    border: 1px solid #333333;
}

@media screen and (min-width: 769px) {
    .slick-slide {
        margin: 0px;
    }
}

@media screen and (min-width: 769px) {
    .top_menu_icon{
        width: 140px;
        height: 140px;
    }
    .top_menu_icon i {
        font-size: 72px;
    }
}
@media screen and (max-width: 768px) {
    .top_menu_icon{
        width: 48px;
        height: 48px;
    }
    .top_menu_icon i {
        font-size: 28px;
    }
}
.top_menu_icon i{
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    width: 100%;
    background: #000;
    color: #fff;
}
.link-underline.link-stamp{
    color: #fff !important;
}

.video_dots{
    list-style-type: none;
    padding: 0;
    display: flex;
    justify-content: center;
}

.video_dots li{
    margin: 10px 15px;
}
.video_dots button{
    outline: none;
    border: none;
    background-color: #bfbdbd;
    width: 12px;
    height: 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 12px;
    overflow: hidden;
    text-indent: -10000px;
    cursor: pointer;
    font-size:12px !important;
}

.slick-active button{
    background-color: #000;
    color: #fff;
}
.slick-dotted.slick-slider {
    margin-bottom: 0 !important;
}