@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;700&display=swap');

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,
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,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style: normal;
	font-size: 100%;
	vertical-align: baseline;
	font-family: "Noto Sans JP","メイリオ","ms pgothic", sans-serif;
	color: #111;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
    list-style: none;
}

table{
    border-collapse: collapse; 
    border-spacing: 0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline: none;
}

body{
	line-height: 150%;
	-webkit-text-size-adjust: 100%;
}

a{
	text-decoration: none;
}

img{
	max-width: 100%;
    image-rendering: -webkit-optimize-contrast;
}

.trim img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

p,
a,
li{
	font-size: 3.5vw;
	line-height: 170%;
}

p a,
li a{
	font-size: inherit;
	font-family: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
li,
a{
	letter-spacing: 0.1em;
    word-break: break-all;
}

h1,
h2,
h3,
h4,
h5,
h6,
h7,
h7{
	line-height: 150%;
}

.tab,
.pc{
	display: none;
}

.photo{
	line-height: 0;
}

.inner{
    padding-left: 3vw;
    padding-right: 3vw;
}

.red_text{
    color: #D90000;
}

.red_text02{
    color: #E74C3C;
}

.green_text{
    color: #128F0E;
}

.under_l{
    text-decoration: underline;
}

.link_text{
    color: #2980B9;
}

.link_text:hover{
    text-decoration: underline;
}

.link_text.under_l:hover{
    text-decoration: none;
}

.yen::before{
    content: "￥";
}

.bold{
    font-weight: 700;
}

.overflow_hidden{
    overflow: hidden;
}

#wrap{
    padding: 0 0 0;
	position: relative;
}


/* header
   ================================================================== */
header{
	position: relative;
    z-index: 10;
    background: #fff;
}

header .header_contents{
    position: relative;
}
    
header .header_contents .flex{
    display: block;
}

header .site_logo{
	padding: 2vw 3vw 0;
    line-height: 0;
    width: 120px;
    z-index: 1;
    transition: .3s;
    box-sizing: content-box;
}

@media screen and (max-width : 375px){
    header .site_logo{
        width: 25vw;
        height: 55px;
        display: flex;
        align-items: center;
    }
}

.site_logo a{
    display: inline-block;
    line-height: 0;
}

.header_postage{
    height: 9vw;
    font-size: 3.5vw;
    font-weight: 700;
    letter-spacing: 0.1em;
	background: #B81C25;
    color: #fff;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}

.header_postage.tab.pc{
    display: none;
}

.header_search{
	margin: 4vw 3vw;
}

.header_search .box{
    border-radius: 50px;
	display: flex;
    align-items: center;
    background: #eee;
}

.header_search input{
    padding: 8px 10px;
    font-size: 16px;
    line-height: 150%;
	width: calc(100% - 50px);
    box-sizing: border-box;
    background: transparent;
    border: none;
    box-shadow: none;
}

.header_search .search_btn{
    width: 50px;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 0;
    border: none;
    background: none;
    box-shadow: none;
}


/* icons
   ================================================================== */
header .icons{
    position: fixed;
    right: 60px;
    top: 0;
    display: flex;
    z-index: 500;
}

header .icons li{
    width: 60px;
    line-height: 0;
}

header .icons li a{
    display: block;
    line-height: 0;
}

header .icons li img{
    width: 100%;
}

header .icons li form,
header .icons li button{
    padding: 0;
    display: block;
    line-height: 0;
    width: 100%;
    height: 100%;
    background: none;
    border: none;
}

header .icons li.register{
    background: #128F0E;
}

.footer_btn li.login,
header .icons li.login{
    background: #F39C12;
}

.footer_btn li.mypage,
header .icons li.mypage{
    background: #128F0E;
}

.footer_btn li.cart,
header .icons li.cart{
    background: #D90000;
}


/* Navi
   ================================================================== */
.ham_btn{
    position: fixed;
    right: 0;
    top: 0;
    font-size: 26px;
    display: block;
    z-index: 1001;
    text-align: center;
    cursor: pointer;
    width: 60px;
    height: 60px;
    box-sizing: border-box;
    padding: 18px 20px;
	transition: ease-out 0.3s;
    background: #1E1A17;
}

.ham_btn .inner{
    padding: 20px 0 0;
    width: 20px;
    height: 24px;
    display: block;
    position: relative;
    transition: ease-out 0.8s;
    box-sizing: border-box;
}


.ham_btn .bar,
.ham_btn .bar:before,
.ham_btn .bar:after{
    transition: ease-out 0.3s;
    text-indent: -9999px;
    height: 1px;
    width: 20px;
    background: #fff;
    display: block;
}

.ham_btn .bar:before{
    content: "";
    position: absolute;
    top: 6px;
    left: 0;
}

.ham_btn .bar:after{
    content: "";
    position: absolute;
    bottom: 7px;
    left: 0;
}

.ham_btn.open{
    height: 100vh;
    background: rgba(0,0,0,1);
}

.ham_btn .bar{
    background: transparent !important;
}

.ham_btn.open .bar:before{
    transform: rotate(45deg);
    top: 12px;
}

.ham_btn.open .bar:after{
    transform: rotate(-45deg);
    bottom: 11px;
}

body.open{
    position: fixed;
    width: 100%;
}


/* slide_menu
   ================================================================== */
.slide_menu{
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100vh;
    background: rgba(255,255,255,1);
    box-sizing: border-box;
    z-index: 1000;
    transition: all cubic-bezier(0.77, 0, 0.175, 1) 0.6s;
    transition-delay: .2s;
    overflow: auto;
    opacity: 0;
    visibility: hidden;
    display: none;
}

.slide_menu.show{
    display: flex;
}

.slide_menu.open{
    opacity: 1;
    visibility: visible;
    transition-delay: 0s;
}

.slide_nav{
    width: calc(100% - 60px);
}

.slide_nav .sp ul > li li .open_close,
.slide_nav .sp ul > li li,
.slide_nav .sp > div{
    border-bottom: 1px solid #ddd;
    position: relative;
}

.slide_nav .sp ul > li > ul > li .open_close + ul{
    border-top: 1px solid #ddd;
}

.slide_nav .sp button,
.slide_nav .sp > ul > li > .open_close,
.slide_nav .sp a{
    display: block;
    transition: all ease-out 0.3s;
    z-index: 2;
    box-sizing: border-box;
    font-size: 3.8vw;
    letter-spacing: 0.1em;
    font-weight: 400;
    color: #222;
    line-height: 120%;
    position: relative;
    width: 100%;
    text-align: left;
}

.slide_nav .sp form{
    display: block;
    width: 100%;
}

.slide_nav .sp .cart a{
    padding: 5vw 3vw;
    background: #D90000;
    color: #fff;
    display: flex;
    align-items: center;
}

.slide_nav .sp .cart a img{
    padding: 0 4vw 0 0;
    width: 8vw;
}

.slide_nav .sp button,
.slide_nav .sp a{
    padding: 6vw 3vw;
    border: none;
    background: #fff;
}

.slide_nav .sp > ul > li > .open_close{
    padding: 4vw 3vw;
    background: #F5F3E9;
    border-bottom: 1px solid #ddd;
}

/* カテゴリ */
.slide_nav .sp > ul > li > ul li:last-child,
.slide_nav .sp > ul > li > ul > li .open_close{
    border-bottom: none;
}

.slide_nav .sp > ul ul ul a{
    padding-left: 5vw;
}

.slide_nav .sp > ul ul ul ul a{
    background: #F8F8F8;
}

/* 開閉ボタン */
.slide_nav .open_close div{
	width: 10vw;
	height: 100%;
	position: absolute;
    z-index: 10;
    margin: auto;
	right: 0;
	top: 0;
    bottom: 0;
    text-indent: -999999px;
}

.slide_nav .sp > ul > li > .open_close div{
	width: 100%;
}

.slide_nav .open_close div::after{
	content: "";
    background-image: url("../images/common/icon_plus.svg");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 100%;
	width: 3vw;
	height: 3vw;
	position: absolute;
    margin: auto;
	right: 3vw;
	top: 0;
    bottom: 0;
}

.slide_nav .open_close div.active::after{
	background-image: url("../images/common/icon_minus.svg");
}

.slide_nav .sp .open_close + ul{
	display: none;
}

/* nav pc */
.slide_menu .pc{
    display: none;
}

@keyframes navi_logo_animation_off{
    0% {
        transform: translateY(0);
        opacity: 1;
    }
    50% {
        opacity: 1;
    }
    100% {
        transform: translateY(20px);
        opacity: 0;
    }
}

@keyframes navi_logo_animation_open{
    0% {
        transform: translateY(-40px);
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes navi_animation_off{
    0% {
        transform: translateY(0);
        opacity: 1;
    }
    50% {
        opacity: 1;
    }
    100% {
        transform: translateY(-20px);
        opacity: 0;
    }
}

@keyframes navi_animation_open{
    0% {
        transform: translateY(30px);
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

.gnav{
    display: none;
}


/* footer
   ================================================================== */
footer{
    margin: 40vw 0 0;
	padding: 0 0 0;
    position: relative;
    z-index: 1;
}

footer::before{
    content: "";
    background-image: url("../images/common/webp/footer_item.webp");
    background-position: bottom left;
    background-repeat: repeat-x;
    background-size: 100%;
    width: 100%;
    height: 25vw;
    position: absolute;
    bottom: 100%;
    left: 0;
}

footer .bg{
    padding: 6vw 0 0;
    position: relative;
    background: #F5F3E9;
}
    
footer .bg .flex{
    display: block;
}

footer .logo{
    margin: 0 0 8vw;
	width: 50vw;
    line-height: 0;
}

footer .logo a{
    width: 100%;
    line-height: 0;
}

footer .logo img{
    width: 100%;
}

footer .footer_nav{
	margin: 0;
    line-height: 0;
}

footer .footer_nav ul{
	margin: 0 -3vw;
}

footer .footer_nav ul li{
	margin: 0;
}

footer .footer_nav ul li a{
	padding: 4vw;
	display: block;
	font-size: 4vw;
    line-height: 150%;
    font-weight: 400;
    border-top: 1px solid #C1B8A1;
}

.footer_btn{
	display: flex;
    text-align: center;
}

.footer_btn li{
    width: 50%;
}

.footer_btn li a{
    height: 16vw;
	display: flex;
    justify-content: center;
    align-items: center;
}

.footer_btn li a span{
    font-size: 4vw;
    color: #fff;
	display: flex;
    align-items: center;
}

.footer_btn li a img{
    margin: 0 4vw 0 0;
    width: 6vw;
}

footer .sns_block{
    padding: 0;
}
    
footer .sns_block .flex{
    display: block;
}

footer .sns_block h3{
    padding: 6vw 2vw;
    font-size: 4vw;
    font-weight: 400;
}

footer .sns_block .sns_btn{
    margin: 0 -3vw;
    display: flex;
    border-top: 1px solid #ddd;
}

footer .sns_block .sns_btn li{
    width: calc(100% / 4);
    border-right: 1px solid #ddd;
    line-height: 0;
}

footer .sns_block .sns_btn li:last-child{
    border-right: none;
}

footer .sns_block .sns_btn li a{
    height: 20vw;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 0;
}

footer .sns_block .sns_btn li a img{
    height: 8vw;
}

footer .bottom_box{
    padding: 10vw 3vw 30vw;
	background-image: url("../images/common/webp/footer_bg.webp");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

footer address{
	font-size: 3vw;
    text-align: right;
    color: #fff;
    font-weight: 400;
    letter-spacing: 0.1em;
}


/* page_top
   ================================================================== */
#page_top{
	position: fixed;
	bottom: 10px;
	right: 0;
	width: 40px;
    z-index: 4;
	line-height: 0;
	display: none;
}

#page_top a{
	display: block;
	height: auto;
	transition: ease-in 0.3s;
	line-height: 0;
}

#page_top img{
	width: 100%;
}


/* contents_wrap
   ================================================================== */
.contents_wrap{
    margin: 0 0 0;
    padding: 0 0 0;
    position: relative;
    z-index: 2;
    background: #fff;
}


/* page_map
   ================================================================== */
.page_map{
    padding: 6vw 0 0;
}

.page_map ul{
    font-size: 0;
}

.page_map ul li{
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
}

.page_map ul li span,
.page_map ul li a{
    font-size: 3.2vw;
    line-height: 150%;
    letter-spacing: 0.05em;
    display: inline-block;
}

.page_map ul li + li,
.page_map ul li + li{
    margin-left: 1vw;
}

.page_map ul li + li::before{
    content: ">";
    margin-right: 0;
}

.page_map.directly ul li + li::before{
    margin-right: 1vw;
}


/* common_section
   ================================================================== */	
.common_section{
	padding-top: 8vw;
}


/* page_title
   ================================================================== */	
.page_title{
	font-size: 6vw;
    text-align: center;
    font-weight: 700;
}


/* block_title
   ================================================================== */	
.block_title{
    text-align: center;
}

.block_title > span{
    display: block;
    line-height: 130%;
    letter-spacing: 0.1em;
    font-weight: 700;
}

.block_title .eng{
    font-size: 7vw;
    font-family: 'Oswald';
    letter-spacing: 0.05em;
}

.block_title .jpn{
    font-size: 3.2vw;
}


/* bg_title
   ================================================================== */	
.bg_title{
    padding: 3vw 4vw;
    font-size: 3.6vw;
    font-weight: 700;
    background: #F4F3F0;
}

.bg_title.red{
    color: #D90000;
    background: #FFEEEC;
}

.bg_title.center{
    text-align: center;
}

.bg_title.reg{
    font-weight: 400;
}


/* border_title
   ================================================================== */	
.border_title{
    margin: 0 0 7vw;
    padding: 0 3vw 3vw;
    font-size: 3.6vw;
    font-weight: 700;
    border-bottom: 1px solid #ddd;
}


/* error_message
   ================================================================== */	
.error_message{
    margin: 10vw 0;
	padding: 6vw 4vw;
    font-size: 4.0vw;
    font-weight: 700;
    border: 1px solid #ddd;
    color: #D90000;
    border-color: #D90000;
    text-align: center;
}


/* errors_txt
   ================================================================== */	
form .error,
.errors_txt{
    font-size: 14px;
    font-weight: 400;
    color: #D90000;
    text-align: left;
}


/* btn
   ================================================================== */	
.btn_box{
	text-align: center;
	line-height: 0;
}

.btn{
	padding: 4vw 2vw;
	width: 70vw;
	position: relative;
	display: inline-block;
    box-sizing: border-box;
    text-align: center;
	font-size: 4vw;
    font-family: "Noto Sans JP","メイリオ","ms pgothic", sans-serif;
    font-weight: 400;
    letter-spacing: 0.10em;
    line-height: 150%;
	color: #fff;
    border-radius: 0;
    border: none;
    box-shadow: none;
	background: #222;
}

a.btn{
    cursor: pointer;
}

button{
    cursor: pointer;
}

.btn.maxwid{
	width: 100%;
}

.btn.more{
	padding: 2.5vw 2vw;
	width: 40vw;
    font-weight: 700;
    border-radius: 50px;
}

.btn.small{
	padding: 3vw 2vw;
	width: 50vw;
	font-size: 3.5vw;
    font-weight: 700;
    border-radius: 50px;
}

.btn.mini{
	padding: 1.5vw 2vw;
	width: 15vw;
	font-size: 3.1vw;
    color: #525263;
}

.btn.red{
	background: #D90000;
}

.btn.dark{
	background: #2F2725;
}

.btn.green{
	background: #128F0E;
}

.btn.yellow{
	background: #F39C12;
}

.btn.yellow02{
	background: #F1C40F;
}

.btn.disabled_color{
	background: #ddd;
}

.btn.gray{
	background: #555;
}

.btn.gray_border{
    color: #222;
	background: #F5F7F8;
    border: 1px solid #ddd;
}


@media screen and (min-width : 500px){

	
	p,
	a,
	li{
		font-size: 1.5vw;
	}
    
    button.over,
    a.over{
    	transition: all ease-out 0.3s;
    }
    	
    button.over:hover,
    a.over:hover{
    	opacity: 0.5;
    }

	.sp{
		display: none;
	}

	.tab{
		display: inherit;
	}

    .inner{
        padding-left: 2vw;
        padding-right: 2vw;
    }

    #wrap{
        padding: 0 0 0;
    }


    /* header
       ================================================================== */
    header .header_contents{
        position: relative;
    }
    
    header .header_contents .flex{
        padding: 0 2.0vw 0 5.4vw;
        display: flex;
    }
    
    header .site_logo{
        margin: -2.1vw 0 0;
    	padding: 0;
        width: 27.8vw;
    }
    
    .header_postage{
        height: 4.0vw;
        font-size: 1.5vw;
    }
    
    .header_postage.tab.pc{
        display: flex;
    }
    
    .header_postage.sp{
        display: none;
    }
    
    .header_search{
    	margin: 7.5vw 0 2.5vw auto;
    }
    
    .header_search .box{
        width: 24.0vw;
    }
    
    .header_search input{
        padding: .6vw 1.0vw;
        font-size: 16px;
    	width: calc(100% - 5.4vw);
    }
    
    .header_search .search_btn{
        width: 5.4vw;
    }
    
    .gnav{
        margin: 0 auto;
        padding: 0;
        height: 5.0vw;
        width: auto;
        box-sizing: border-box;
        position: relative;
        right: auto;
        overflow: inherit;
        display: flex;
        align-items: center;
        background: #F5F3E9;
    }
    
    .gnav > ul{
    	margin: auto;
        padding: 0 0 0;
    	font-size: 0;
        overflow: inherit;
    }
    
    .gnav > ul > li{
        margin: 0 2.5vw;
        padding: 0;
    	text-align: center;
		width: auto;
		display: inline-block;
        transition: all cubic-bezier(0.77, 0, 0.175, 1) 0.6s;
    }
    
    .gnav > ul > li > a{
        padding: 1.0vw 0;
    	display: flex;
        align-items: center;
        justify-content: center;
    	text-align: center;
        line-height: 1;
        border: none;
        height: auto;
        position: relative;
    	font-size: 1.5vw;
        letter-spacing: 0.1em;
        font-weight: 700;
        transition: .5s ease;
        top: 0;
    }
   
	
    /* Navi
       ================================================================== */
    .ham_btn.open {
        height: 50px;
        background: #B89D50;
    }

    
    /* slide_menu
       ================================================================== */
    .slide_nav{
        width: 100%;
    }

    .slide_menu{
        z-index: 100;
        align-items: flex-start;
        background: #F5F3E9;
    }

    /* nav pc */
    .slide_menu .pc{
        padding: 5.2vw 0 0;
        display: block;
    }
    
    .slide_menu .logo{
        margin: 0 0 0;
        line-height: 0;
        width: 27.8vw;
        animation: navi_logo_animation_off 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }

    .slide_menu.open .logo{
        animation: navi_logo_animation_open 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }

    /* 閉じる時 */
    .slide_nav .pc ul li{
        animation: navi_animation_off 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }
    
    .slide_nav .pc ul.small li{
        animation-delay: .05s;
    }
    
    .slide_nav .pc .sns_btn{
        animation-delay: .1s;
    }
    
    /* 開く時 */
    .slide_menu.open .pc ul li{
        animation: navi_animation_open 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }
    
    .slide_menu.open .slide_nav ul.small l{
        animation-delay: .1s;
    }
    
    .slide_menu.open .slide_nav .pc .sns_btn{
        animation-delay: .15s;
    }

    .slide_menu ul{
        margin: 4.6vw 0 0;
        display: flex;
    }
    
    .slide_menu ul li{
        margin-right: 5.0vw;
    }
    
    .slide_menu ul a{
        font-size: 1.5vw;
        font-weight: 700;
        letter-spacing: 0.1em;
        display: block;
        transition: .3s;
    }
    
    .slide_menu ul a:hover{
        opacity: .5;
    }
    
    /* small */
    .slide_menu ul.small{
        margin: 3vw 0 0;
        padding: 2.5vw 0 0;
        display: flex;
        position: relative;
    }
    
    .slide_menu ul.small::before{
    content: "";
    background: #C1B8A1;
    width: 200vw;
    height: 1px;
    position: absolute;
    top: 0;
    left: -100vw;
}
    
    .slide_menu ul.small li{
        margin-right: 4.0vw;
    }
    
    .slide_menu ul.small a{
        font-size: 1.3vw;
    }
    
    /* sns_btn */
    .slide_menu .sns_btn{
        margin: 6.1vw 0 0;
        display: flex;
    }
    
    .slide_menu .sns_btn li{
        margin-right: 2.0vw;
        width: 4.0vw;
        line-height: 0;
    }
    
    .slide_menu .sns_btn li:first-child{
        margin-left: 0;
    }
    
    .slide_menu .sns_btn li a{
        display: block;
        line-height: 0;
    }


    /* footer
       ================================================================== */
    footer{
        margin: 28.0vw 0 0;
    }
    
    footer::before{
        background-size: 68.3vw;
        height: 15.0vw;
    }
    
    footer .bg{
        padding: 4.0vw 0;
    }
    
    footer .bg .flex{
        display: flex;
        align-items: center;
    }
    
    footer .logo{
        margin: 0;
    	width: 25vw;
    }
    
    footer .footer_nav{
    	margin: 0;
    }
    
    footer .footer_nav .right{
    	margin: 0 0 0 auto;
        width: auto;
    }
    
    footer .footer_nav ul{
    	margin: 0;
        padding: 0 0 0 2.5vw;
        display: flex;
    }
    
    footer .footer_nav ul li{
    	margin: 0 4.0vw 0 0;
    }
    
    footer .footer_nav ul li a{
    	padding: 0;
    	font-size: 1.2vw;
        font-weight: 700;
        border-top: none;
        transition: .3s;
    }
    
    footer .footer_nav ul li a:hover{
    	opacity: .5;
    }
    
    footer .footer_nav ul.small{
    	margin: 2.7vw 0 0;
        padding: 2.5vw 0 0 2.5vw;
        border-top: 1px solid #C1B8A1;
    }
    
    .footer_btn{
    	display: flex;
    }
    
    .footer_btn li a{
        height: 7.0vw;
        transition: .3s;
    }
    
    .footer_btn li a:hover{
    	opacity: .5;
    }
    
    .footer_btn li a span{
        font-size: 1.3vw;
    }
    
    .footer_btn li a img{
        margin: 0 1.7vw 0 0;
        width: 2.4vw;
    }
    
    footer .sns_block{
        padding: 0;
    }
    
    footer .sns_block .flex{
        display: flex;
        align-items: center;
    }
    
    footer .sns_block h3{
        padding: 0;
        width: 27.0vw;
        font-size: 1.3vw;
        box-sizing: border-box;
        display: flex;
    align-items: center;}
    
    footer .sns_block .sns_btn{
        margin: 0;
        display: flex;
        border-top: none;
    }
    
    footer .sns_block .sns_btn li{
        width: calc(100% / 4);
    }
    
    footer .sns_block .sns_btn li:first-child{
        border-left: 1px solid #ddd;
    }
    
    footer .sns_block .sns_btn li:last-child{
        border-right: 1px solid #ddd;
    }
    
    footer .sns_block .sns_btn li a{
        width: 7.5vw;
        height: 8.0vw;
    }
    
    footer .sns_block .sns_btn li a img{
        height: 3.0vw;
    }
    
    footer .bottom_box{
        padding: 3.0vw 0 16.0vw;
    }
    
    footer address{
    	font-size: 1.2vw;
    }


    /* page_top
       ================================================================== */
    #page_top{
    	bottom: 10px;
    	right: 0;
    	width: 40px;
    }


    /* contents_wrap
       ================================================================== */
    .contents_wrap{
        padding: 0 0 0;
    }


    /* page_map
       ================================================================== */
    .page_map{
        padding: 3.2vw 0 0;
    }
    
    .page_map ul li span,
    .page_map ul li a{
        font-size: 1.3vw;
    }
    
    .page_map ul li a:hover{
        text-decoration: underline;
    }
    
    .page_map ul li + li,
    .page_map ul li + li{
        margin-left: .5vw;
    }
    
    .page_map ul li + li::before{
        margin-right: 0;
    }
    
    .page_map.directly ul li + li::before{
        margin-right: .5vw;
    }

    
    /* common_section
       ================================================================== */	
    .common_section{
    	padding-top: 4.0vw;
    }


    /* page_title
       ================================================================== */	
    .page_title{
    	font-size: 4.0vw;
    }


    /* block_title
       ================================================================== */	
    .block_title .eng{
        font-size: 4.5vw;
    }
    
    .block_title .jpn{
        font-size: 1.6vw;
    }


    /* bg_title
       ================================================================== */	
    .bg_title{
        padding: 1.3vw 2.0vw;
        font-size: 1.6vw;
    }


    /* border_title
       ================================================================== */	
    .other_products_list h3{
        margin: 0 0 3.6vw;
        padding: 0 2.5vw 2.0vw;
        font-size: 2.0vw;
    }


    /* error_message
       ================================================================== */	
    .error_message{
        margin: 5.0vw 0;
        padding: 2.5vw 2vw;
        font-size: 2.0vw;
    }


	/* btn
	   ================================================================== */	
	.btn{
	    padding: 0;
	    width: 28vw;
        height: 6vw;
	    border: 1px solid #222;
	    display: inline-flex;
        justify-content: center;
        align-items: center;
	    font-size: 1.6vw;
        transition: .3s ease;
	}

    .btn.more{
        padding: 0;
    	width: 23vw;
        height: 5vw;
    }

    .btn.small{
    	padding: 0;
    	width: 20vw;
        height: 4vw;
    	font-size: 1.4vw;
    }

    .btn.mini{
    	padding: 0;
    	width: 8vw;
        height: 4vw;
    	font-size: 1.4vw;
    }

    .btn.red{
    	border-color: #D90000;
    }
    
    .btn.dark{
    	border-color: #2F2725;
    }
    
    .btn.green{
    	border-color: #128F0E;
    }
    
    .btn.yellow{
    	border-color: #F39C12;
    }

    .btn.yellow02{
    	border-color: #F1C40F;
    }
    
    .btn.disabled_color{
    	border-color: #ddd;
    }
    
    .btn.gray{
    	border-color: #555;
    }
    
	button.btn:hover,
	a.btn:hover{
	    color: #222;
	    background: #fff;
	}

    button.btn.red:hover,
    a.btn.red:hover{
    	color: #D90000;
    }
    
    button.btn.dark:hover,
    a.btn.dark:hover{
    	color: #2F2725;
    }
    
    button.btn.green:hover,
    a.btn.green:hover{
    	color: #128F0E;
    }
    
    button.btn.yellow:hover,
    a.btn.yellow:hover{
    	color: #F39C12;
    }

    button.btn.yellow02:hover,
    a.btn.yellow02:hover{
    	color: #F1C40F;
    }

    .favorite button.btn.yellow02:hover,
    .favorite a.btn.yellow02:hover{
        color: #fff;
    	background: #F1C40F;
    	border-color: #F1C40F;
    }

    .favorite button.btn.disabled_color:hover,
    .favorite a.btn.disabled_color:hover{
    	color: #fff;
    	background: #ddd;
    	border-color: #ddd;
    }

    button.btn.gray_border:hover,
    a.btn.gray_border:hover{
        color: #fff;
    	background: #222;
        border-color: #222;
    }
    
    
}
@media screen and (min-width : 1140px){

	
    a{
    	text-decoration: none;
    }
    
    .inner{
        padding-left: 20px;
        padding-right: 20px;
    	max-width: 1140px;
    	margin: auto;
		box-sizing: border-box;
    }
    
    .inner.max1000{
    	max-width: 1040px;
    }
	
	p,
	a,
	li{
		font-size: 15px;
	}
 
	.tab{
		display: none;
	}

	.pc{
		display: inherit;
	}

    #wrap{
        padding: 0 0 0;
    }


    /* header
       ================================================================== */    
    header .header_contents{
        position: relative;
    }
    
    header .header_contents .flex{
        padding: 0 20px 0 54px;
        display: flex;
    }
    
    header .site_logo{
        margin: -21px 0 0;
    	padding: 0;
        width: 278px;
    }
    
    .header_postage{
        height: 40px;
        font-size: 15px;
    }
    
    .header_postage.tab.pc{
        display: flex;
    }
    
    .header_postage.sp{
        display: none;
    }
    
    .header_search{
    	margin: 75px 0 25px auto;
    }
    
    .header_search .box{
        width: 240px;
    }
    
    .header_search input{
        padding: 6px 10px;
        font-size: 16px;
    	width: calc(100% - 54px);
    }
    
    .header_search .search_btn{
        width: 54px;
    }
    
    .gnav{
        margin: 0 auto;
        padding: 0;
        height: 50px;
        width: auto;
        box-sizing: border-box;
        position: relative;
        right: auto;
        overflow: inherit;
        display: flex;
        align-items: center;
        background: #F5F3E9;
    }
    
    .gnav > ul{
    	margin: auto;
        padding: 0 0 0;
    	font-size: 0;
        overflow: inherit;
    }
    
    .gnav > ul > li{
        margin: 0 25px;
        padding: 0;
    	text-align: center;
		width: auto;
		display: inline-block;
        transition: all cubic-bezier(0.77, 0, 0.175, 1) 0.6s;
    }
    
    .gnav > ul > li > a{
        padding: 10px 0;
    	display: flex;
        align-items: center;
        justify-content: center;
    	text-align: center;
        line-height: 1;
        border: none;
        height: auto;
        position: relative;
    	font-size: 15px;
        letter-spacing: 0.1em;
        font-weight: 700;
        transition: .5s ease;
        top: 0;
    }
    
    .gnav > ul > li > a:hover{
        opacity: .5;
    }
    
    
    /* icons
       ================================================================== */
    header .icons{
        right: 70px;
    }
    
    header .icons li{
        width: 70px;
    }
   
	
    /* Navi
       ================================================================== */
    .ham_btn{
        position: fixed;
        right: 0;
        top: 0;
        font-size: 26px;
        display: block;
        z-index: 500;
        text-align: center;
        cursor: pointer;
        width: 70px;
        height: 70px;
        box-sizing: border-box;
        padding: 21px 20px;
    	transition: ease-out 0.3s;
        background: #1E1A17;
    }
    
    .ham_btn.open {
        height: 70px;
        background: #B89D50;
    }
    
    .ham_btn .inner{
        padding: 10px 0 0;
        width: 30px;
        height: 29px;
        display: block;
        position: relative;
        transition: ease-out 0.8s;
        box-sizing: border-box;
    }
    
    
    .ham_btn .bar,
    .ham_btn .bar:before,
    .ham_btn .bar:after{
        transition: ease-out 0.3s;
        text-indent: -9999px;
        height: 2px;
        width: 30px;
        background: #fff;
        display: block;
    }
    
    .ham_btn .bar:before{
        content: "";
        position: absolute;
        top: 6px;
        left: 0;
    }
    
    .ham_btn .bar:after{
        content: "";
        position: absolute;
        bottom: 7px;
        left: 0;
    }
    
    .ham_btn.open{
        transform: rotate(0deg);
    }
    
    .ham_btn .bar{
        background: transparent !important;
    }
    
    .ham_btn.open .bar:before{
        transform: rotate(45deg);
        top: 13px;
    }
    
    .ham_btn.open .bar:after{
        transform: rotate(-45deg);
        bottom: 13px;
    }
    .ham_btn:hover .bar{
        width: 20px;
    }
    
    .ham_btn:hover .bar:after{
        width: 10px;
    }
    
    .ham_btn.open .bar,
    .ham_btn.open .bar:after{
        width: 30px !important;
    }

    .ham_btn.open:hover .bar:before,
    .ham_btn.open:hover .bar:after{
        width: 40px !important;
        left: -4px;
    }

    
    /* slide_menu
       ================================================================== */
    .slide_menu{
        z-index: 100;
        align-items: flex-start;
        background: #F5F3E9;
    }

    /* nav pc */
    .slide_menu .pc{
        padding: 52px 0 0;
        display: block;
    }
    
    .slide_menu .logo{
        margin: 0 0 0;
        line-height: 0;
        width: 278px;
        animation: navi_logo_animation_off 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }

    .slide_menu.open .logo{
        animation: navi_logo_animation_open 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }

    /* 閉じる時 */
    .slide_nav .pc ul li{
        animation: navi_animation_off 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }
    
    .slide_nav .pc ul.small li{
        animation-delay: .05s;
    }
    
    .slide_nav .pc .sns_btn{
        animation-delay: .1s;
    }
    
    /* 開く時 */
    .slide_menu.open .pc ul li{
        animation: navi_animation_open 1s cubic-bezier(0,.58,.42,1) 0s 1 normal both;
    }
    
    .slide_menu.open .slide_nav ul.small l{
        animation-delay: .1s;
    }
    
    .slide_menu.open .slide_nav .pc .sns_btn{
        animation-delay: .15s;
    }

    .slide_menu ul{
        margin: 46px 0 0;
        display: flex;
    }
    
    .slide_menu ul li{
        margin-right: 50px;
    }
    
    .slide_menu ul a{
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0.1em;
        display: block;
    }
    
    /* small */
    .slide_menu ul.small{
        margin: 46px 0 0;
        padding: 45px 0 0;
        display: flex;
        position: relative;
    }
    
    .slide_menu ul.small::before{
    content: "";
    background: #C1B8A1;
    width: 200vw;
    height: 1px;
    position: absolute;
    top: 0;
    left: -100vw;
}
    
    .slide_menu ul.small li{
        margin-right: 40px;
    }
    
    .slide_menu ul.small a{
        font-size: 15px;
    }
    
    /* sns_btn */
    .slide_menu .sns_btn{
        margin: 61px 0 0;
        display: flex;
    }
    
    .slide_menu .sns_btn li{
        margin-right: 20px;
        width: 40px;
        line-height: 0;
    }
    
    .slide_menu .sns_btn li:first-child{
        margin-left: 0;
    }
    
    .slide_menu .sns_btn li a{
        display: block;
        line-height: 0;
    }


    /* footer
       ================================================================== */
    footer{
        margin: 280px 0 0;
    }
    
    footer::before{
        background-size: 683px;
        height: 150px;
    }
    
    footer .bg{
        padding: 40px 0;
    }
    
    footer .bg .flex{
        display: flex;
        align-items: center;
    }
    
    footer .logo{
        margin: 0;
    	width: 278px;
    }
    
    footer .footer_nav{
    	margin: 0;
    }
    
    footer .footer_nav .right{
    	margin: 0 0 0 auto;
        width: auto;
    }
    
    footer .footer_nav ul{
    	margin: 0;
        padding: 0 0 0 25px;
        display: flex;
    }
    
    footer .footer_nav ul li{
    	margin: 0 40px 0 0;
    }
    
    footer .footer_nav ul li a{
    	padding: 0;
    	font-size: 15px;
        font-weight: 700;
        border-top: none;
    }
    
    footer .footer_nav ul.small{
    	margin: 27px 0 0;
        padding: 25px 0 0 25px;
        border-top: 1px solid #C1B8A1;
    }
    
    .footer_btn{
    	display: flex;
    }
    
    .footer_btn li a{
        height: 70px;
    }
    
    .footer_btn li a span{
        font-size: 13px;
    }
    
    .footer_btn li a img{
        margin: 0 17px 0 0;
        width: 24px;
    }
    
    footer .sns_block{
        padding: 0;
    }
    
    footer .sns_block .flex{
        display: flex;
        align-items: center;
    }
    
    footer .sns_block h3{
        padding: 0;
        width: 270px;
        font-size: 13px;
        box-sizing: border-box;
        display: flex;
    align-items: center;}
    
    footer .sns_block .sns_btn{
        margin: 0;
        display: flex;
        border-top: none;
    }
    
    footer .sns_block .sns_btn li{
        width: calc(100% / 4);
    }
    
    footer .sns_block .sns_btn li:first-child{
        border-left: 1px solid #ddd;
    }
    
    footer .sns_block .sns_btn li:last-child{
        border-right: 1px solid #ddd;
    }
    
    footer .sns_block .sns_btn li a{
        width: 75px;
        height: 80px;
    }
    
    footer .sns_block .sns_btn li a img{
        height: 30px;
    }
    
    footer .bottom_box{
        padding: 30px 0 160px;
    }
    
    footer address{
    	font-size: 12px;
    }


    /* page_top
       ================================================================== */
    #page_top{
    	bottom: 10px;
    	right: 0;
    	width: 50px;
    }


    /* contents_wrap
       ================================================================== */
    .contents_wrap{
        padding: 0 0 0;
    }


    /* page_map
       ================================================================== */
    .page_map{
        padding: 32px 0 0;
    }
    
    .page_map ul li span,
    .page_map ul li a{
        font-size: 13px;
    }
    
    .page_map ul li + li,
    .page_map ul li + li{
        margin-left: 5px;
    }
    
    .page_map ul li + li::before{
        margin-right: 0;
    }
        
    .page_map.directly ul li + li::before{
        margin-right: 5px;
    }

    
    /* common_section
       ================================================================== */	
    .common_section{
    	padding-top: 40px;
    }


    /* page_title
       ================================================================== */	
    .page_title{
    	font-size: 40px;
    }


    /* block_title
       ================================================================== */	
    .block_title .eng{
        font-size: 45px;
    }
    
    .block_title .jpn{
        font-size: 16px;
    }


    /* bg_title
       ================================================================== */	
    .bg_title{
        padding: 13px 20px;
        font-size: 16px;
    }


    /* border_title
       ================================================================== */	
    .other_products_list h3{
        margin: 0 0 36px;
        padding: 0 25px 20px;
        font-size: 20px;
    }
    

    /* error_message
       ================================================================== */	
    .error_message{
        margin: 50px 0;
        padding: 25px 20px;
        font-size: 20px;
    }


	/* btn
	   ================================================================== */	
	.btn{
	    padding: 0;
	    width: 280px;
        height: 60px;
	    font-size: 16px;
	}

    .btn.more{
    	width: 230px;
        height: 50px;
    }

    .btn.small{
    	width: 200px;
        height: 40px;
    	font-size: 14px;
    }

    .btn.mini{
    	width: 80px;
        height: 40px;
    	font-size: 14px;
    }
	
	
}

