@charset "utf-8";
/* CSS Document */
body{
    padding: 0;
    margin: 0;
}
.img_wrap img,
main img{
    max-width: 100%;
    height: auto;
}
.pc_only{
    display: none;
}
.sp_only{
    display: block;
}
.img_wrap{
    line-height: 0;
}
.top_nav_list_01 img,
.top_nav_list_02 img{
    max-width: 100%;
    height: auto;
    width: auto;
    max-height: calc(25vh - 2em);
}
*{
	word-break: break-all;
	line-break: strict;
	word-wrap: break-word;
	overflow-wrap: break-word;
	text-rendering: optimizeLegibility;
    box-sizing: border-box;
    font-family: 'Noto Serif JP', serif;
}
a{
    color: inherit;
    text-decoration: none;
}
a:visited{
    color: inherit;
    text-decoration: none;
}
a:hover {
    color: inherit;
    text-decoration: none;
}
a:active {
    color: inherit;
    text-decoration: none;
}

label a{
    pointer-events: none;
}
label{
    cursor: pointer;
    width: 100%;
    display: block;
}
header input,
footer input{
    display: none;
}
header{
        z-index: 1000;
}
.swiper-wrapper{
    line-height: 0;
}
.swiper-slide img{
    max-width: 100%;
    height: auto;
}
.footer_logomark img{
    max-width: 100%;
    height: auto;
}

.btnspinner{
    -ms-user-select: none;
    -moz-user-select: -moz-none;
    -khtml-user-select: none;
    -webkit-user-select: none;
    user-select: none;
}
.spinner_area{
    width: 100%;
    display: flex;
    text-align: center;
    position:relative;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 0;
    box-sizing: border-box;
    margin: 1em auto;
}
.spinner_area::before{
    content:"";
    width: 70%;
    position:absolute;
    left: 15%;
    top:0;
    height:100%;
    background:transparent;
    z-index: 2;
}
.item_form .spinner_area input{
    background: #FAFAFA;
	text-align:center;
    font-size: 1em;
    width: 15%;
    margin: auto;
    vertical-align: middle;
    padding: 15px 0;
    /* デフォルトのスピナーを消す */
    -webkit-appearance: none;
    -moz-appearance:textfield;
    border: 1px solid #F0F3F5;
}
.item_form .spinner_area input:nth-of-type(2){
    width: 70%;
    border-right: none;
    border-left: none;
}
.item_form .spinner_area input[type="button"]{
    cursor: pointer;
}


/* かごの中へ遷移しない */

.cartin-msg-pc {
	display: none;
	white-space: nowrap;
}
.cartin-msg-pc.show {
	position: relative;
	white-space: nowrap;
	background: #5d737e;
	color: #fff;
	width: 100%;
	padding: 10px 0;
	text-align: center;
	display: block; 
}
.cartin-msg-sp {
	display: none; 
	white-space: nowrap;
}
.cartin-msg-sp.show {
	position: relative;
	white-space: nowrap;
	background: #5d737e;
	color: #fff;
	width: 100%;
	padding: 10px 0;
	text-align: center;
	display: block; 
}
.cart-badge{
    margin: 0;
    position: absolute;
    top: 9px;
    right: 9px;
    background: #980b10;
    color: #fff;
    width: 28px;
    height: 28px;
    border-radius: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    line-height: 0;
}
.cart-badge.off{
    display: none;
}
/*  // かごの中へ遷移しない */

/* sp menu*/
@media(max-width: 768px){
    body{
        padding-top: 104px;
    }
    header > div > div.cart_btn > a > picture > img{
        height: 60px;
    }
    header > div > nav > ul > li:nth-child(2) > label{
        display: none;
    }
    .header_inner{
        width: 100%;
        height: 100%;
        transform: translateZ(0);
    }
    .top_nav img{
        max-width: 100%;
        height: auto;
    }
    header nav ul.top_nav_list_01{
        opacity: 1;
        visibility: visible;
        height: auto;
        width: 100%;
        flex-direction: column;
    }
    header nav ul.top_nav_list_01 li{
        padding: 16px 15px;
        height: auto;
    }
    header nav ul.top_nav_list_01 li a{
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: center;
        width: 100%;
        padding: 0;
    }
    header nav ul.top_nav_list_01 li a .img_wrap{
        width: 127px;
        height: auto;
        max-width: 30%;
        margin: 0 10px 0 0;
    }
    li input ~ label{
        position: relative;
    }
    li input ~ label::before,
    li input ~ label::after{
        content:"";
        width: 11px;
        height: 11px;
        display: block;
        position: absolute;
    }
    li input ~ label::before{
        right: 21px;
        top: 16px;
        border-right: 1px solid #fff;
        transition: .3s all;
    }
    li input:checked ~ label::before{
        height: 0;
        top: 30px;
        transition: .3s all;
    }
    li input ~ label::after{
        right: 16px;
        top: 21px;
        border-top: 1px solid #fff;
    }
    /* top menu*/
    header > nav > ul.top_nav > li:nth-child(5),
    header > nav > ul.top_nav > li:nth-child(6){
        display: none;
    }
    h1{
        margin: 0;
    }
    header{
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 104px;
        background: #fff;
        transform: translateZ(0);
    }
    header nav,
    header ul{
        width: 0;
        padding: 0;
        margin: 0;
    }
    header li{
        list-style: none;
    }
    .top_info_wrap{
        padding: 16.9px 0 0;
        text-align: center;
    }
    header nav ul{
        opacity: 0;
        visibility: hidden;
        height: auto;
        width: 0;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-start;
    }
    .top_nav{
        opacity: 0;
        visibility: hidden;
        height: calc(100vh + 60px);
        padding-top: 104px;
        width: 0;
        transition: .3s all;
        background: #fff;
        position: fixed;
        top: 0;
        left: 0;
        overflow-y: auto;    
    }
    .top_nav li{
        width: 100%;
        height: 0;
        transition: .3s all;
    }
    .top_nav > li{
        height: auto;
    }
    .top_nav > li > a{
        padding: 10px 15px;
        display: block;
    }
    #top_nav_check ~ label{
        width: 42px;
        height: 36px;
        box-sizing: border-box;
        border-top: 5px solid #727C8E;
        border-bottom: 5px solid #727C8E;
        display: block;
        position: fixed;
        top: 26px;
        left: 15px;
        z-index: 2;
    }
    #top_nav_check ~ label::before{
        content:"";
        width: 42px;
        height: 1px;
        border-top: 5px solid #727C8E;
        position: absolute;
        top: 10px;
        left: 0;
    }
    #top_nav_check:checked ~ label{
        left: auto;
        top: 0;
        right: 0;
        width: 82px;
        height: 105px;
        background: #000;
        border-top: none;
        border-bottom: none;
    }
    #top_nav_check:checked ~ .top_info_wrap{
        display: none;
    }
    #top_nav_check:checked ~ label::before{
        content: "x";
        width: auto;
        height: auto;
        border-top: none;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        color: #F1E5D0;
        font-size: 30px;
        font-weight: bold;
        font-family: sans-serif;
    }
    header > div > nav > ul > li:nth-child(5) > a,
    header > div > nav > ul > li:nth-child(6) > a{
        padding: 0;
    }
    #top_nav_check:checked ~ nav{
        opacity: 1;
        width: 100%;
        height: 100%;
        transform: translateZ(0);
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(5) img,
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(6) img,
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(7) img,
    header > div > #top_nav_check:checked ~ .cart_btn img{
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate3D(-50% , -50% , 0);
        height: auto;
        max-height: calc(100% - 20px);
        opacity: 1;
        visibility: visible;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(5){
        order: 5;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(6){
        order: 6;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(7){
        order: 7;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(5),
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(6),
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(7),
    header > div > #top_nav_check:checked ~ .cart_btn{
        position: fixed;
        top: 0;
        left: 0;
        display: block;
        width: calc(26vw - 20.5px);
        background: #fff;
        border-top: 1px solid #727C8E;
        border-bottom: 1px solid #727C8E;
        opacity: 1;
        z-index: 1001;
        transform: translateZ(0);
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(5) a,
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(6) a,
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(7) a{
        padding: 0;
        width: 100%;
        height: 100%;
        opacity: 1;
        visibility: visible;
        transform: translateZ(0);
    }
    header > div > #top_nav_check ~ nav > ul > li:nth-child(5),
    header > div > #top_nav_check ~ nav > ul > li:nth-child(6),
    header > div > #top_nav_check ~ nav > ul > li:nth-child(7),
    header > div > #top_nav_check ~ .cart_btn{
        transition: none;
        opacity: 1;
    }
    header > div > #top_nav_check ~ .cart_btn a{
        width: 100%;
        height: 100%;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(5){
        right: calc(45vw - 20.5px + 82px);
        left: auto;
        height: 105px;
        transition: none;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(6){
        right: calc(25vw - 20.5px + 82px);
        left: auto;
        height: 105px;
        transition: none;
    }
    header > div > #top_nav_check ~ nav > ul > li:nth-child(7){
        right: calc(25vw - 20.5px + 82px);
        left: auto;
        height: 105px;
        transition: none;
        border-left: 1px solid #727C8E;
    }
    header > div > #top_nav_check:checked ~ .cart_btn{
        left: auto;
        right: 82px;
        height: 105px;
        transition: none;
        border-right: 1px solid #727C8E;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(1){
        order: 4;
        background: #AEAEAE;
        color: #fff!important;
        border: 1px solid #707070;
        border-collapse: collapse;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(3){
        order: 3;
        background: #AEAEAE;
        color: #fff!important;
        border-left: 1px solid #707070;
        border-right: 1px solid #707070;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(2){
        order: 1;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(4){
        order: 2;
        background: #AEAEAE;
        color: #fff!important;
        border: 1px solid #707070;
        border-collapse: collapse;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(4) label{
        padding: 10px 15px;
        color: #fff;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(1) a,
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(3) a{
        color: #fff;
    }
    header > div > nav > ul > li:nth-child(2) > ul > li:nth-child(13),
    header > div > nav > ul > li:nth-child(2) > ul > li:nth-child(14),
    header > div > nav > ul > li:nth-child(2) > ul > li:nth-child(15){
        display: none;
    }
    .cart_btn{
        position: absolute;
        top: 23px;
        right: 15px;
    }
    header input:checked ~ nav,
    header input:checked ~ nav > ul{
        opacity: 1;
        width: calc(100vw - 82px);
        visibility: visible;
        transition: .3s all;
    }
    .top_nav input:checked ~ ul,
    .top_nav input:checked ~ ul li{
        opacity: 1;
        width: 100vw;
        visibility: visible;
        height: auto;
        transition: .3s all;
    }
    .top_nav input:checked ~ ul.top_nav_list_02{
        width: 100%;
        border-top: 1px solid #707070;
    }
    .top_nav input:checked ~ ul.top_nav_list_02 li{
        width: 100%;
        border-bottom: 1px solid #707070;
    }
    .top_nav input:checked ~ ul.top_nav_list_02 li:last-of-type{
        border-bottom: none;
    }
    .top_nav input:checked ~ ul.top_nav_list_02 li a{
        width: 100%;
        padding: 16px 15px;
        display: block;
    }
    /* footer */
    .footer_wrap{
        background: #AEAEAE;
        color: #fff;
    }
    .footer_wrap ul,
    .footer_wrap ul li{
        padding: 0;
        margin: 0;
        width: 100%;
    }
    .footer_nav{
        border: 1px solid #707070;
    }
    .footer_nav > li{
        border-bottom: 1px solid #707070;
    }
    .footer_nav ul li:last-of-type{
        border-bottom: none;
    }
    .footer_nav ul li a{
        display: block;
    }
    .footer_nav > nav > ul > li > a,
    .footer_nav > nav > ul > li > label{
        padding: 10px 4%;
        font-weight: bold;
    }
    .bottom_nav_list_01 ul li,
    .bottom_nav_list_02 ul li{
        border-bottom: none;
    }
    input:checked ~ .bottom_nav_list_01,
    input:checked ~ .bottom_nav_list_02{
        border-top: 1px solid #707070;
    }
    input:checked ~ .bottom_nav_list_01 > li,
    input:checked ~ .bottom_nav_list_02 > li{
        border-bottom: 1px solid #707070;
    }
    input:checked ~ .bottom_nav_list_01 > li:last-of-type,
    input:checked ~ .bottom_nav_list_02 > li:last-of-type{
        border-bottom: none;
    }
    .bottom_nav_list_01 li a,
    .bottom_nav_list_02 li a{
        padding: 0 4%;
        opacity: 0;
        visibility: hidden;
        height: 0;
        transition: .3s all;
    }
    input:checked ~ .bottom_nav_list_01 li a,
    input:checked ~ .bottom_nav_list_02 li a{
        padding: 10px 4%;
        opacity: 1;
        visibility: visible;
        height: auto;
        transition: .3s all;
    }
    .footer_info{
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-start;
        width: 100%;
    }
    .footer_logomark{
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        width: 30%;
        padding: 1.4em;
    }
    .footer_logomark img{
        width: 100%;
        height: auto;
        max-width: 56px;
    }
    .footer_text{
        width: 70%;
        padding: 1em 10px;
    }
    .footer_text p{
        font-size: 1.2em;
        margin: 0;
    }
    .pc_footer_menu{
        display: none;
    }
}
@media(max-width: 500px){
    header > div > nav > ul > li:nth-child(7) > a > img{
        width: 35px;
    }
    header > div > nav > ul > li:nth-child(5) > a > img{        
        width: 44px;
    }
    header > div > nav > ul > li:nth-child(6) > a > img{
        width: 55px;
    }
    header > div > div.cart_btn > a > picture > img{
        width: 35px;
    }
    header > div > #top_nav_check:checked ~ nav > ul > li:nth-child(5) {
        right: calc(44vw - 20.5px + 82px);
    }
    .footer_text p {
        font-size: .9em;
    }
}
/* 768px for table*/
@media (min-width: 769px) {
    body{
        padding-top: 84px;
    }
    .cart_btn{
        position: relative;
    }
    .sp_only{
        display: none;
    }
    .pc_only{
        display: block;
    }
    .pc_only.inline{
        display: inline;
    }
    body > header > div > nav > ul > li:nth-child(7){
        display: none;
    }
    header{
        position: fixed;
        top: 0;
        left: 50%;
        width: 100%;
        transform:translate(-50% , 0);
        background: #fff;
    }
    .site_title{
        margin: 0;
    }
    .header_inner{
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-end;
        position: relative;
    }
    .top_info_wrap{
        position: absolute;
        top: 15px;
        left: 15px;
    }
    header nav{
        width: auto;
        list-style: none;
        margin: 0 0 0 auto;
        padding: 0 0 0 55px;
    }
    .cart_btn{
        margin: 0 10px 0 0;
    }
    #top_nav_check,
    #top_nav_check ~ label{
        display: none;
    }
    .top_nav{
        height: auto;
        width: 100%;
        max-width: 1920px;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: center;
        margin: 0;
        padding: 0;
        list-style: none;
    }
    .top_nav > li{
        font-weight: bold;
        margin: 0 20px;
        height: 84px;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
    }
    header > div > nav > ul > li:nth-child(5) > a > img{
        max-width: 37px;
    }
    header > div > nav > ul > li:nth-child(6) > a > img{
        max-width: 47px;
    }
    header > div > div.cart_btn > a > picture > img{
        max-width: 86px;
    }
    .top_nav_list_01,
    .top_nav_list_02{
        list-style: none;
        position: absolute;
        bottom: 0;
        left: 50%;
        width: 100vw;
        padding: 0;
        height: auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-start;
        opacity: 0;
        visibility: hidden;
        transition: .3s all;
        transform: translate(-50% , calc(100% + 25px));
        max-width: 1360px;
    }
    .top_nav_list_01{
        transform: translate(-50% , calc(100% + 10px));
    }
    header > div > nav > ul > li:nth-child(4){
        position: relative;
    }
    .top_nav_list_02{
        width: calc(100% + 40px);
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-start;
        padding: 25px;
        background: rgba(255,255,255,.87);
        min-width: 220px;
        transform: translate(-20px , 90%);
        position: absolute;
        left: 0;
        bottom: 0;
    }
    .top_nav_list_02 li{
        width: 100%;
        margin: 0 0 1em;
    }
    .top_nav_list_01::before{
        content:"";
        height: calc(100% + 20px);
        width: 100vw;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50% , -50%);
        background: rgba(255,255,255,.87);
        z-index: -1;
    }
    .top_nav_list_01 li{
        width: 18%;
        margin: 0 1.25% 1em;
        text-align: center;
        max-height: calc(100vh / 4);
    }
    .top_nav_list_01 li:nth-child(5n+1){
        margin: 0 1.25% 1em 0;
    }
    .top_nav_list_01 li:nth-child(5n+5){
        margin: 0 0 1em 1.25%;
    }
    li:hover > label ~ .top_nav_list_01{
        opacity: 1;
        visibility: visible;
        transition: .3s all;
        padding: 20px 25px 10px;
    }
    li:hover > label ~ .top_nav_list_02{
        opacity: 1;
        visibility: visible;
        transition: .3s all;
        background: rgba(255,255,255,.87);
        height: auto;
        position: absolute;
        left: 0;
        bottom: 0;
        transform: translate(-20px , 100%);
    }
    
    
    /* footer */
    footer{
        width: 100%;
        background: #AEAEAE;
        padding: 50px 15px 20px;
        margin: 100px auto 0;
    }
    .footer_nav{
        color: #fff;
        list-style: none;
        padding: 0 0 10px;
        border-bottom: 1px solid #fff;
    }
    .footer_nav .footer_nav{
        border-bottom: none;
    }
    .footer_nav li,
    .footer_nav label{
        margin: 0 0 1em;
    }
    ul.footer_nav{
        font-weight: bold;
    }
    ul.footer_nav ul{
        font-weight: normal;
    }
    ul.footer_nav ul{
        list-style: none;
        padding: 0;
    }
    .footer_nav nav{
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-start;
        width: 100%;
        padding: 0;
        margin: 0;
    }
    .footer_nav nav ul.footer_nav{
        width: 75%;
        display: grid; 
        grid-template-columns: 1fr 1fr 1fr; 
        grid-template-rows: 60px 1fr 1fr 1fr;
        gap: 0px 0px; 
        grid-template-areas: 
            "a c d"
            "b c d"
            ". c d"
            ". c d"; 
    }
    .footer_nav nav ul.footer_nav li:nth-child(0){ 
        grid-area: a; 
    }
    .footer_nav nav ul.footer_nav li:nth-child(1){ 
        grid-area: c; 
    }
    .footer_nav nav ul.footer_nav li:nth-child(2){ 
        grid-area: d; 
    }
    .footer_nav nav ul.footer_nav li:nth-child(3){ 
        grid-area: b; 
    }
    .pc_footer_menu{
        width: 25%;
        padding: 0;
        list-style: none;
    }
    .pc_footer_menu img{
        max-width: 40%;
        height: auto;
    }
    .footer_info{
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: center;
        width: 100%;
        margin: 0;
        padding: 10px 0 0;
        border-top: 1px solid #8C8C8C;
    }
    .footer_logomark{
        width: 140px;
        padding: 0 42px;
        text-align: center;
    }
    .footer_text{
        color: #fff;
        width: calc(100% - 140px);
        font-size: 1em;
        padding: 0 30px 0;
    }
}

/* 992px for pc*/
@media (min-width: 992px) {
}

/* 1200px for wide pc */
@media (min-width: 1200px) {
}