/* #############################################
    common parts
############################################# */


.module-image .image-wrap img{
	width: auto;
	max-width: 100%;
}

body{ background: black; color: white; }
.newitem{ color: red; }
body #main #primary,
body.search_items_page #main #primary{
	/* width:76.66%;
	float:right; */
    width: 100%;
    float: none;
}
body #main #primary.item-details{
    width: 100%;
    max-width: 960px;
    float: none;
    margin: 0 auto 30px;
    overflow: hidden;
}
body img{ height: auto; }
/* font setting no changes by m44 */
body .wrap,
body.single #content input[type="submit"],
body .wpcf7 input[type="submit"],
input{
	font-family: a-otf-midashi-mi-ma31-pr6n, serif;
	font-family: 'Nuosu SIL',"HG正楷書体-PRO",a-otf-midashi-mi-ma31-pr6n,serif;
	font-weight: normal;
	font-style: normal;
    color: white;
    font-size: 14px;
}
body.single #content input[type="submit"]{
    border-radius: 8px;
    font-family: "Fontawesome",serif;;
    color: #333;
}
.font--Time {
	font-family: "Times New Roman","游明朝", YuMincho, "ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","メイリオ", Meiryo,"ＭＳ Ｐ明朝", serif;
}
.font--Garamond{
	font-family: 'EB Garamond', serif;
}


/* links */
body .wrap a,body .wrap a:link,body .wrap a:visited{ color: white; text-decoration: underline; outline: none; }
body .wrap a:hover,body .wrap a:active{ text-decoration: none; }

/* wrapper */
body .wrap .inner,.main-navigation,.wrapper,footer .guide{ max-width: 1100px; margin-left: auto; margin-right: auto; }
.home #main, .page #main{ max-width: 1800px; margin: 0 auto; padding: 0; }
#contents{ padding: 0 2% }

#menu-button .ham-text{
    color:  black;
}

.incart-btn .total-quant{
    position: static;
}

body #memberinfo .member_submenu a:link,
body #memberinfo .member_submenu a:visited,
body #memberinfo .member_submenu a:hover,
body #memberinfo .member_submenu a:active{ color: #333; }

/* #############################################
    header & footer common
############################################# */
#masthead,#footer-heading{
    text-align: center;
    position: relative;
    background: url(../../uploads/head-bg.png) repeat-x left top;
    background-size: contain;
    background-repeat: repeat;
}
#footer-heading{
    text-align: left;
    box-sizing: border-box;
    padding: 0 7%;
    background-image: url(../../uploads/title-bg.png);
    margin-bottom: 0px;
    background-size: auto;
    background-repeat: repeat;
}
#footer-head-area #footer-img{ /*padding: 0 7%;*/ text-align: center; }
#footer-img img{ width: 100%; max-width: 1100px; height: auto }
#masthead .inner{ position: relative; z-index: 10; padding: 24px 0 20px; justify-content: center; }
#footer-heading h2{ position: relative; z-index: 10; padding: 15px 0 9px; font-size: 22px; max-width: 1100px; margin: 0 auto; font-weight: normal; }
body h1.site-title{ float: none; padding: 0; text-align: center;}
body h1.site-title img,body div.site-title img{ width: auto; height: auto }
#masthead::before,#footer-heading::before{
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
	background: rgb(0,0,0);
	background: -moz-linear-gradient(90deg, rgba(0,0,0,0.7) 0%, rgba(255,255,255,0) 73%, rgba(255,255,255,0) 100%);
	background: -webkit-linear-gradient(90deg, rgba(0,0,0,0.7) 0%, rgba(255,255,255,0) 73%, rgba(255,255,255,0) 100%);
	background: linear-gradient(90deg, rgba(0,0,0,0.7) 0%, rgba(255,255,255,0) 73%, rgba(255,255,255,0) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#000000",endColorstr="#ffffff",GradientType=1);
    z-index: 0;
}

#top-head-content{ max-width: 960px; margin: 0 auto 50px; text-align: center; }
#top-head-content h1{ font-size: 30px; font-weight: normal; }
#top-head-content ul{ margin-top: 1rem; display: flex; justify-content: space-around; list-style: none }
#top-head-content ul li a{
    display: block;
    padding: 3px 11px 2px 30px;
    line-height: 1.2;
    font-size: 17px;
    color: #af8d22;
    text-decoration: none;
    background: url(../../uploads/flower-icon2.png) 5px center no-repeat;
    border: 1px solid #af8d22;
    letter-spacing: 5px;
}
#top-head-content .head-description{
    color: #af8d22;
    font-size: 14px;
    margin-top: 1rem;
}
.head-description-echo-layout{
    margin-top: 1rem;
}

/*navigation*/
header #site-navigation input#panel.on-off + div.nav-menu-open, header #site-navigation input#panel.on-off:checked + div.nav-menu-open, header #site-navigation input#panel.on-off + div.header-nav-container{
    background: transparent;
}
#masthead #site-navigation ul{ text-align: center; padding-bottom: 10px; display: flex; justify-content: space-between; align-items: center; max-width: 840px; }
#masthead #site-navigation ul li{ border: none; display: inline-block; float: none; }
#masthead #site-navigation li a{ padding: 0; }
#masthead #site-navigation li a,#masthead #site-navigation li a:link,#masthead #site-navigation li a:visited{
    color: white;
    text-decoration: none;
    transition: .3s linear;
    background: none!important;
    outline: none!important;
    font-size: 14px;
}
#masthead #site-navigation li a:hover,#masthead #site-navigation li a:active{
    opacity: .8;
    text-decoration: underline;
}

/* #############################################
    widget
############################################# */
/* incart btn */
#secondary .incart-btn{ float: none; margin: 0 auto 15px; }
.incart-btn a {	padding: 10px .714286em; }
/* incart btn end */

/* loginbox */
#secondary .widget_welcart_login{
    padding: 10px;
    border: 1px solid gray;
    border-radius: 2px;
}
.widget .loginbox input[type="text"],
.widget .loginbox input[type="password"]{ width: 100%; max-width: 100%; }
body #secondary .widget .loginbox input[type="text"],
body #secondary .widget .loginbox input[type="password"]{text-align: left;}
/* login end */

/* welcart calendar */
.widget_welcart_calendar .businessday{ background-color: red; }
/* welcart calendar end */

/* #############################################
	itemlist adjustment
############################################# */
.cat-il.type-grid .itemname,.search-li .itemname{
	height: auto;
}

/* #############################################
    item single
############################################# */
.storycontent .item-name,
.storycontent .skuname,
.storycontent .field_price,
.storycontent .taxtprice{ font-size: 16px; }
.storycontent .taxTag{ font-size: 14px; }
.storycontent .tax_rate{ padding-left: .6em; }

/* 追加 */
#itempage .item-row1,#itempage .item-row2,#itempage .item-row3{ margin-bottom: 30px; }
#itempage .item-row1 #img-box{ width: 40%; }
#itempage .item-row1 #img-box img{ width: auto; max-width: 100%; }
#itempage .item-row1 .item-info{
    width: 55%;
    float: right;
    clear: none;
    padding-top: 0;
}
.item-row3 .detail-box{
    width: 100%;
    float: none;
}

/* #############################################
    footer
############################################# */
#colophon{ padding: 0; margin-top: 105px; }
body #colophon .guide{ max-width: 1100px; margin-top: 30px; padding: 0 7%; font-size: 14px; line-height: 1.2; }
.footer-contents h3,
.shop-guide.module .module-title{ font-size: 19px; font-weight: normal; margin: 0 auto 15px; }
.shop-guide{ width: 100%; }
.shop-guide th{ width: 21%; padding: 10px 10px 10px 4.2%; position: relative; }
.shop-guide th::after{ content: "："; position: absolute; right: 10px; top: 10px; }
.shop-guide td{ width: auto; padding: 10px }
.shop-guide td p{ margin-bottom: 1rem; }
#cancel-guide,#payment-guide,#delivery-guide{ margin-top: 116px; }
#reservation-guide{ margin-top: 154px; }
#reservation-guide .with-icon{
    text-align: center;
    position: relative;
    max-width: 310px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 142px;
    background: url(../../uploads/storeinfo-banner-bg.png) no-repeat center bottom;
    transition: .3s linear;
}
#reservation-guide .btn-wrap p{ font-size: 15px; }
#reservation-guide .with-icon:hover{
    opacity: .72;
}
#reservation-guide .with-icon h3{
    margin-bottom: 0;
    font-size: 20px;
    font-weight: normal;
    line-height: 1.6;
    border-bottom: 1px solid #727171;
    margin-bottom: 8px;
}
#with-icon .width-icon p{ font-size: 12px; margin-bottom: 0; }
#reservation-guide .with-icon a{
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    text-indent: 200%;
    white-space: nowrap;
    overflow: hidden;
}
#footer-nav-area{
    box-sizing: border-box;
    margin: 100px auto 0;
    max-width: 1170px;
    text-align: center;
}
#footer-nav
#footer-nav-area #footer-nav{
    list-style: none;
}
#footer-nav-area #footer-nav li{
    display: inline-block;
    margin: 0 0 5px;
    padding: 0 0.4em 0;
    position: relative;
    float: none;
    text-align: center;
    vertical-align: top;
}
#footer-nav-area #nav-wrap{
    display: flex;
    justify-content: space-between;
    padding: 5px 0px 20px;
    border-top: 1px solid #727171;
    margin-top: 10px;
}
#footer-nav-area #footer-nav li a{
    display: block;
    font-size: 12px;
    color: white!important;
    text-decoration: none!important;
}
#footer-nav-area #footer-nav li a:hover{
    color: gray;
    text-decoration: underline;
}

#sita-box{
    position: relative;
    padding: 20px 5px;
    background: url(../../uploads/sita-bg.png) no-repeat left top;
    background-size: cover;
    text-align: center;
    font-size: 11px;
    transition: 0.2s all linear;
}
#sita-box a{
    transition: .2s all linear;
    color: #ffffff;
    text-decoration: none;
}
#sita-box a:hover{
    opacity: .7;
    text-decoration: underline;
}
#sita-box .sita-button{
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY( -50% );
    transition: 0.2s all linear;
}
#sita-box .sita-button a{
    padding: 8px 10px;
    background: #fff;
    line-height: 1;
    font-family: "ヒラギノ角ゴ Pro W6", hiragino Kaku Gothic ProN, Hiragino Sans, "ヒラギノ角ゴシック",Yu Gothic,Yu Gothic M,"メイリオ",sans-serif, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #231f20;
    font-size: 17px;
    font-weight: normal;
}
#sita-box.show,
#sita-box .sita-button a.show{
    display: none;
}

/*追加*/
.shop_guide_rows .row_inner{
    width: 100%;
    max-width: 860px;
}

/* #############################################
    top page
############################################# */
.top-cat-links{ text-align: center; margin-top: 72px; margin-right: auto; margin-left: auto; font-size: 14px; }
.top-cat-links h2{
    font-size: 24px;
    border-bottom: 1px solid #a3a4a4;
    padding: 0 10px;
    margin: 0 auto 15px;
    font-weight: normal;
}
.top-cat-links .cat-image-wrap{ padding: 0 2%; box-sizing: border-box; }
.top-cat-links .cat-image-wrap img{ width: auto; max-width: 100%; vertical-align: bottom; }
.top-cat-links p{ margin: 5px auto; }
#cat-1{ margin-top: 0; max-width: 64%; }
#cat-2{ max-width: 58%; }
#cat-3{ max-width: 53.3%; }
#cat-4{ max-width: 58.2%; }
#cat-5{ max-width: 62%; }
    #cat-5 .cat-image-wrap{ padding: 0; }
#cat-6{ max-width: 61%; }
    #cat-6 .cat-image-wrap{ padding: 0 4.2%; }

.home #secondary .incart-btn,
.home #secondary #welcart_category-2{
    display: none;
}

/* #############################################
    page
############################################# */
body.page #main #primary, body.search_items_page #main #primary{
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    float: none;
}

#post-6142 .entry-title,
#post-6152 .entry-title,
#post-6155 .entry-title,
#post-6164 .entry-title,
.page #main h3{
    background-color: #C4181F;
    color: white;
    padding: 5px 5px 5px 5px;
    margin-bottom: 30px;
    font-size: 18px;
    text-align: center;
}

#post-6142 .entry-title,
#post-6152 .entry-title,
#post-6155 .entry-title,
#post-6164 .entry-title{
    font-size: 22px;
}

.page #main p{ margin-bottom: 15px; }

#primary figure{
    text-align: center;
    margin-bottom: 30px;
}

.page .row{
    margin-bottom: 30px;
}

.subContentTitle{
    background: url(img/side_nav_icon.png) left center no-repeat;
    padding: 2px 0 1px 25px;
    margin-bottom: 15px;
    font-size: 16px;
}

body .wrap .mailLinks{ text-align: right; font-size: 16px }
body .wrap .mailLinks a,body .wrap .mailLinks a:link,body .wrap .mailLinks a:visited{
    color: #CCCC66;
    border: none;
    text-decoration: none;
}
body .wrap .mailLinks a:hover,body .wrap .mailLinks a:active{
    text-decoration: underline;
}

/* お問い合わせフォーム */
body .wpcf7 table tr td select{ background-color: white; }
body .wpcf7 table tr th{ font-size: 16px; }
.wpcf7 table tr td input[type="checkbox"]{ display: inline; width: auto; }
body .wpcf7 table tr td input, body .wpcf7 table tr td textarea{ border-radius: 8px; }
.postcode{ max-width: 120px; }
.postcode, .your-pref, .your-city{ margin-bottom: 6px; width: 100%; display: inline-block; }
body .wpcf7 input[type="submit"]{
    color: black;
    font-family: 'Fontawesome',bitter,"HG正楷書体-PRO",a-otf-midashi-mi-ma31-pr6n,serif;
}


/*固定ページ類*/
.page-template .bookpage img{
    width: auto;
    max-width: 100%;
}

/* category or archive */
.archive #content .page-header .page-title{
    background: url(img/side_nav_icon.png) left center no-repeat;
    padding: 2px 0 1px 28px;
    margin-bottom: 15px;
    font-size: 20px;
}
.archive #secondary .incart-btn,
.single #secondary .incart-btn,
.archive #secondary #welcart_category-2,
.single #secondary #welcart_category-2{
    display: none;
}

/*sidebar*/
.incart-btn span{
    font-size: 16px;
    display: inline;
    font-family: bitter,"HG正楷書体-PRO",a-otf-midashi-mi-ma31-pr6n,serif;
}
#secondary .incart-btn a{
    width: 100%;
    text-align: center;
    display: block;
    margin: 0 auto 15px;
    padding: 5px 0;
    background-color: #CCCC66;
    color: white;
    font-size: 16px;
    
}
#secondary .incart-btn .total-quant{
    line-height: 1.2;
    vertical-align: middle;
}

#secondary #welcart_login-3.widget_welcart_login{
    position: fixed;
    top: 5%;
    right: 0;
    border: none;
	z-index: 100;
}
#secondary #welcart_login-3.widget_welcart_login a,
#secondary #welcart_login-3.widget_welcart_login a:link,
#secondary #welcart_login-3.widget_welcart_login a:visited{
    color: #b08d22;
    text-decoration: none;
}
#secondary #welcart_login-3.widget_welcart_login a:hover,
#secondary #welcart_login-3.widget_welcart_login a:active{
    opacity: .7;
}

#secondary #welcart_login-3.widget_welcart_login .widget_title{
    display: none;
}
#secondary #welcart_login-3.widget_welcart_login input{
    border-radius: 8px;
}

.widget_welcart_login input#member_loginw,
.widget_welcart_login input#member_login{
    font-family: bitter,"HG正楷書体-PRO",a-otf-midashi-mi-ma31-pr6n,serif;
    padding: 3px;
    line-height: 1.7;
    background: #c6c7c7!important;
    color: #333!important;
}
.widget_welcart_login input#member_loginw:hover,
.widget_welcart_login input#member_login:hover{
    opacity: .7;
}

#wc_newmemberform .telnum{ display: none; }

/* item single */
.quantity input[type="button"]{
    border-radius: 8px;
    line-height: 2.4;
    padding: 0 24px;
    background: #c6c7c7;    
}
.quantity input[type="text"]{
    margin: 0 .6em;
    border-radius: 8px;
}

.item-option dd{ padding-bottom: 15px; }

.single .item_page_title{
    font-size: 18px;
    padding: 5px 10px 4px;
    background: #AF8D23;
    margin: 0 auto 15px;
}

h3.dc{
    font-size: 14px;
    display: inline-block;
    padding: 5px 10px 4px;
    margin: 0 auto 12px;
    background: none;
    border: 1px solid #AF8D23;
}

#itempage a{
    color: #CCCC66;
    text-decoration: underline;
}
#itempage a:hover{
    opacity: .7;
}

.single .field_price{
    margin: 0 0 30px;
    padding: 5px 5px;
    background: #333;
    text-align: right;
}
.single .field_price .field_cprice{
    font-size: 22px;
}
.single .field_price .tax{ color: white; }

#itempage table.item_option caption{
    display: inline-block;
    padding: 5px 10px;
    border: 1px solid white;
    margin-bottom: 15px;
}

.history-back-container{
    text-align: center;
}
body .wrap .history-back-container a{
    display: inline-block;
    padding: 10px 24px;
    font-size: 16px;
    text-align: center;
    background: #AF8D23;
    color: white;
    text-decoration: none;
    border-radius: 5px;
}

#itempage table.item_option{
    border: none;
    width: 100%;
    margin-bottom: 10px;
}

#itempage table.item_option tr th,
#itempage table.item_option th td{
    padding: 10px;
}

.c-box{ text-align: center; padding-top: 20px; border-top: 1px solid #ccc; }

body.single #content input[type="submit"]{
    color: white;
    background: url(../../uploads/catr_btn.png) no-repeat center center;
    background-size: cover;
    padding: 12px 42px;
}

#itempage table.item_option th::before{
    content: "●";
    padding-right: 0.6em;
}
input, textarea, select, input[type=search], button{
    background-color: #e5e4e1;
    color: black;
    border: none;
    padding: 7px 20px;
    cursor: pointer;
    border-radius: 5px;
}
body.single .item_option input[type="text"]{
    max-width: 100%;
}

#itempage .skuform .skuname{
    font-size: 16px;
    text-align: left;
    padding: 10px 20px 10px 42px;
    background: url(../../uploads/side_nav_icon.png) 15px center no-repeat;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: #333;
    margin-bottom: 30px;
}
#itempage .skuform .skuname .price{
    font-size: 22px;
}

/* cart page settings */
.customer_form th{
    background: transparent;
}
.customer_form td{
    color:  white;
}
.customer_form td label{
    color: white;
}
#wc_delivery .customer_form dd{
    color: white;
}
#cart_table th{
    background: transparent;
}
#confirm_table tr.ttl td{
    background-color: gray;
}
#confirm_table tr.ttl td h3{
    background: transparent;
    padding: 0;
    margin: 0;
    color: white;
}
#confirm_table th{
    background: #bfbfbf;
}
body #wc_ordercompletion .send a{
    color: black;
    text-decoration: none;
    background: #bfbfbf;
}
.page #main #cart_completion h3{
    background-color: #660c10;
} 

.fancy-heading{
    font-weight: normal;
}

.top-contents .module{
    margin-right: auto;
    margin-left: auto;
}

#wc_login .loginbox .new-entry, #wc_member .loginbox .new-entry{
    background: #363636;
}

/* #############################################
    media query
############################################# */
@media screen and (max-width: 1333px) {
    #secondary #welcart_login-3.widget_welcart_login{
        position: static;
    }
}

@media screen and (max-width: 768px) {

    #top-head-content{padding: 0 2%;}
    h1.site-title, div.site-title{
        float: none;
    }
    #top-head-content h1{
        font-size: 24px;
    }
    #masthead{ padding-top: 20px; }
    #head-nav li{
        display: inline-block;
        width: 320px;
        margin: 0 auto 10px;
        text-align: left;
    }
    #top-head-content ul{
        flex-direction: column;
    }
    .head-description{
        text-align: left;
        padding: 0 2%;
    }
    .head-description br{
        display: none;
    }
    #contents .top-cat-links{
        max-width: 100%;
    }
    body #main #primary, body.search_items_page #main #primary{
        float: none;
        width: 100%;
    }
    body #main #secondary{
        float: none;
        margin: 30px auto 30px;
        border: 1px solid #ccc;
        border-radius: 3px;
    }
    #footer-nav-area #nav-wrap{
        flex-direction: column;
    }
    .shop-guide th{
        width: 30%;
    }

    #itempage .item-row1 #img-box,
    #itempage .item-row1 .item-info{
        width: 100%;
        margin: 0 auto 30px;
    }

    #itempage table.item_option,
    #itempage table.item_option tbody{
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    #itempage table.item_option tr th, #itempage table.item_option th td{
        display: block;
    }

    /* incart btn */
    #secondary .incart-btn{ max-width: 280px; }
    .incart-btn a {	border-radius: 8px; }
    /* incart btn end */
	

}

/************************************ by matsuda */
@media screen and (max-width: 480px) {

	#cart_table {
    border: 1px solid#ccc;
	}
	/* thead */
	#cart_table thead {
    	display: none;
	}
	
	/* tbody */
	#cart_table tbody tr td {
     	display: flex;
		justify-content: space-between;
		padding: 10px 5px;
	}
	#cart_table tbody .unitprice::before {
		content:"単価";
		
	}
	#cart_table tbody .subtotal::before {
		content:"金額";
	}
	#cart_table td, #cart_table th {
		border: none;
		border-bottom: 1px solid #ccc;
		width: 100%;
	}
	#cart_table .quantity::before{
		content:"数量";
	
	}
	#cart_table .quantity {
    	width: 100%;
	}
	#cart .action{
		width: auto;
		justify-content: right;
	}
	
	/* tfoot */
	#cart_table tfoot{
		display: block;
	}
	
	#cart_table tfoot .aright{
		text-align: left;
	}
}
/*********************************** end matsuda */


/* 20220615 item page adjustment by m44 */
body.single .item-option input[type="text"]{
	max-width:100%;
}

/* 20220913 member page table adjustment by m44 */
#wc_member th{
    color:#363636
}