@charset "utf-8";

/* --------------------------------------------------------------------------------

	スマートフォン向けcommon.css
	
-------------------------------------------------------------------------------- */


/* --------------------------------------------------------------------------------
	body
-------------------------------------------------------------------------------- */
body {
	margin: 0 auto;
	padding: 0;
	max-width: 800px;
	line-height: 1.5;
	font-size: 4vw;
	text-size-adjust: 100%;
	color: #333;
	background: url("../images/common/bg-1.jpg");
}


/* --------------------------------------------------------------------------------
	タグ
-------------------------------------------------------------------------------- */
.common {
	text-align: left;
}
.common * {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	font-family: "Noto Sans JP", sans-serif;
	box-sizing: border-box;
}

.common h1,
.common h2,
.common h3,
.common h4,
.common h5,
.common h6 {
	font-size: 1em;
}
.common ol,
.common ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.common table {
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 1em;
}
.common a,
.common a:link,
.common a:visited {
	text-decoration: none;
	color: #333;
	-webkit-tap-highlight-color:rgba(0,0,0,0.1);
	tap-highlight-color:rgba(0,0,0,0.8);
}
.common a:hover,
.common a:active {
}

img{
	max-width: 100%;
	height: auto;
}


/* --------------------------------------------------------------------------------
	共通クラス
-------------------------------------------------------------------------------- */
.clear{
	clear:both;
}
br.clear{
	display:block;
	margin:0;
	padding:0;
	clear:both;
	height:0;
	border:none;
	visibility:hidden;
	font-size:0;
}
.clearfix:after{
	content:".";
	display:block;
	clear:both;
	height:0;
	visibility:hidden;
}
.clearfix{
	min-height:1%;
}
* html .clearfix{
	height:1%;
	/*\*//*/
	height: auto;
	overflow: hidden;
	/**/
}

ul.ul{
	list-style:disc;
	padding:0 0 0 1.5em;
}
ol.ol{
	list-style:decimal;
	padding:0 0 0 1.75em;
}

.inner{
	margin: 0 3vw;
}

.serif{
	font-family: "Noto Serif JP", serif;
}

h2.heading{
	display: flex;
	align-items: center;
	color: #5a310c;
	font-size: 6.4vw;
	line-height: 1.25;
	margin-bottom: 0;
}
h2.heading::after {
	border-top: 0.4vw solid #5a310c;
	content: "";
	flex-grow: 1;
	margin-left: 2.7vw;
}
.s-heading {
	display: block;
	color: #d1ae80;
	font-size: 4.4vw;
	line-height: 1;
	margin: 1vw 0 5vw;
}


/********** プレースホルダー **********/
::-webkit-input-placeholder{
	color:#000;
}

/* --------------------------------------------------------------------------------
	デバイスごとの表示・非表示
-------------------------------------------------------------------------------- */
.device-sp{
	display:block;
}
.device-sp-inline{
	display:inline;
}
.device-pc{
	display:none;
}
.device-pc-inline{
	display:none;
}

/* --------------------------------------------------------------------------------
	container
-------------------------------------------------------------------------------- */
#container{
}


/* --------------------------------------------------------------------------------
	header
-------------------------------------------------------------------------------- */
#header{
	position: relative;
}
#header .h-menu {
	display: block;
	position: fixed;
	z-index: 100;
}
#header .h-menu * {
	margin: 0;
	padding: 0;
	outline: none;
	border: none;
	font: inherit;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	text-align: left;
	text-decoration: none;
	list-style: none;
}
#header .h-menu a {
	color: inherit;
	text-decoration: none;
	color: #fff;
}
#header .h-menu a:hover {
	color: #ddd;
}
#header .h-menu .h-button {
	display: block;
	background: none;
	border: none;
	padding: 0;
	width: 15vw;
	height: 15vw;
	letter-spacing: 0.1em;
	cursor: pointer;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1001;
	text-align: center;
	outline: none;
	color: #ffffff;
}
#header .h-menu .h-button .h-bar {
	background-color: #ffffff;
}
#header .h-menu .h-button::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	background-color:rgba(34,34,34,0.9);
	width: 15vw;
	height: 15vw;
}
#header .h-menu .h-button.active .h-bar {
	width: 9vw;
}
#header .h-menu .h-button.active .h-bar1 {
	transform: rotate(35deg);
	top: 2.5vw;
	left: 3.2vw;
}
#header .h-menu .h-button.active .h-bar2 {
	opacity: 0;
}
#header .h-menu .h-button.active .h-bar3 {
	transform: rotate(-35deg);
	top: 7.8vw;
	left: 2.7vw;
}
#header .h-menu .h-button.active .h-menu_text {
	display: none;
}
#header .h-menu .h-button.active .h-close {
	display: block;
}
#header .h-menu .h-bar {
	display: block;
	position: absolute;
	width: 9vw;
	height: 1vw;
	transition: all 0.2s;
	transform-origin: 0 0;
	left: 3vw;
}
#header .h-menu .h-bar1 {
	top: 2.5vw;
}
#header .h-menu .h-bar2 {
	top: 5vw;
}
#header .h-menu .h-bar3 {
	top: 7.5vw;
}
#header .h-menu .h-text {
	text-align: center;
	font-size: 3vw;
	transform: translateY(4vw);
}
#header .h-menu .h-close {
	letter-spacing: 0.08em;
	display: none;
}
#header .h-menu .h-menu_text {
	display: block;
}
#header .h-menu .h-nav_wrapper {
	width: 100vw;
	height: auto;
	transition: all 0.2s ease-in;
	position: absolute;
	top: -180vw;
	left: 0;
	z-index: 1000;
	background-color:rgba(34,34,34,0.9);
}
#header .h-menu .h-nav_wrapper.open {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
#header .h-menu .h-nav {
	padding: 17.8vw 0 0;
	list-style: none;
}
#header .h-menu .h-nav > li > a{
	font-size: 4.8vw;
	display: block;
	padding: 3vw 5vw;
	border-bottom: 0.2vw solid #505050;
	margin:0;
	line-height: 1;
	list-style: none;
	font-family: "Noto Serif JP", serif;
	font-weight: 600;
}
#header .h-menu .h-nav > li:nth-child(1) > a{	
	border-top: 0.2vw solid #505050;
}

#header .h-menu .h-nav li .h-s-btn{
	font-size: 4.8vw;
	display: block;
	cursor:pointer;
	padding: 3vw 5vw;
	line-height: 1;
	border-bottom: 0.2vw solid #505050;
	font-family: "Noto Serif JP", serif;
	font-weight: 600;
	color: #e60014;
	position: relative;
}
#header .h-menu .h-nav li .h-s-btn::after{
	content: '';
	width: 2vw;
	height: 2vw;
	margin-top: -2vw;
	border-top: solid 1vw #fff;
	border-right: solid 1vw #fff;
	transform: rotate(135deg);
	position: absolute;
	top: 50%;
	right: 5vw;
}
#header .h-menu .h-nav li.open .h-s-btn::after{
	content: '';
	width: 2vw;
	height: 2vw;
	margin-top: -1vw;
	border-top: solid 1vw #fff;
	border-right: solid 1vw #fff;
	transform: rotate(-45deg);
	position: absolute;
	top: 50%;
	right: 5vw;
}
#header .h-menu .h-nav li .h-s-nav{
	display: none;
}

#header .h-menu .h-nav li.open .h-s-nav{
	display: block;
	border-bottom: 1px solid #505050;
}
#header .h-menu .h-nav li .h-s-nav li a{
	font-size: 4.4vw;
	display: block;
	padding: 2.5vw 8vw;
}

/*ロゴ*/
#header h1.h-logo{
	position: absolute;
	top: 1.9vw;
	right: 1.8vw;
}
#header h1.h-logo img{
	width: 29.7vw;
}

/* --------------------------------------------------------------------------------
	wrapper
-------------------------------------------------------------------------------- */
#wrapper {
}


/* --------------------------------------------------------------------------------
	main
-------------------------------------------------------------------------------- */
#wrapper {
}


/* --------------------------------------------------------------------------------
	footer
-------------------------------------------------------------------------------- */
#footer{
	margin: 10vw 0 0;
}

/********** フッターメニュー **********/
#footer .col-menu {
	background: #fff;
	padding: 3vw 0;
	margin: 0 3vw 5vw;
}
#footer .col-menu .f-menu ul{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
#footer .col-menu .f-menu ul li {
	padding: 0 0 3.8vw;
}
#footer .col-menu .f-menu ul li a{
	font-weight: bold;
	font-size: 3.6vw;
	padding: 0 5.2vw;
	border-right: 0.2vw solid #bfbfbf;
	display: block;
}
#footer .col-menu .f-menu ul li:nth-child(6),
#footer .col-menu .f-menu ul li:last-child {
	padding: 0 0 0;
}
#footer .col-menu .f-menu ul li:nth-child(5) a{
	border: none;
}
#footer .col-menu .f-menu ul li:last-child a{
	border: none;
}

/********** フッターお問い合わせ **********/
#footer .col-contact{
	margin: 0 3vw 8vw;
}

/********** フッターお問い合わせ **********/
#footer .col-info{
	background: #000000;
	border-top: 0.7vw solid #c60a13;
	color: #fff;
	padding: 5vw 3vw 15.5vw 4.6vw;
}
#footer .col-info .f-txt{
	font-size: 3.2vw;
	margin: 0 0 2.5vw;
}
#footer .col-info .f-logo-sns{
	display: flex;
	align-items: center;
}
#footer .col-info .f-logo-sns .f-logo{
	width: 36vw;
	margin: 0 7.5vw 0 0;
}
#footer .col-info .f-logo-sns .f-logo a{
	display: block;
}
#footer .col-info .f-logo-sns .f-sns ul{
	display: flex;
}
#footer .col-info .f-logo-sns .f-sns ul li{
	width: 8vw;
	margin: 0 1.7vw 0 0;
}
#footer .col-info .f-info{
	font-size: 3.6vw;
	margin: 1vw 0 0;
	line-height: 1.5;
}

/* --------------------------------------------------------------------------------
float
-------------------------------------------------------------------------------- */
.float{
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 100;
	display: flex;
}
.float .float-ecshop{
	width: 50%;
}
.float .float-contact{
	width: 50%;
}
.float img{
	display: block;
	width: 100%;
}


/* --------------------------------------------------------------------------------
pagetop
-------------------------------------------------------------------------------- */
.pagetop{
	position: fixed;
	bottom: 12vw;
	right: 0.9vw;
	z-index: 100;
}
.pagetop img{
	width: 17.8vw;
	display: block;
}




/* --------------------------------------------------------------------------------
parts-contact
お問い合わせ
-------------------------------------------------------------------------------- */
#contact .contact-box{
	display: flex;
	justify-content: space-between;
}
#contact .contact-box .btn-mail a{
	display: flex;
	align-items: center;
	justify-content: center;
	background: #c60a13;
	width: 46vw;
	height: 16vw;
	font-size: 4vw;
	color: #ffffff;
	font-weight: bold;
	line-height: 1;
}
#contact .contact-box .btn-mail a .icon{
	margin: 0 1.9vw 0 0;
}
#contact .contact-box .btn-tel{
	background: #c8a576;
	width: 46vw;
	height: 16vw;
}
#contact .contact-box .btn-tel .icon-tel{
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	padding: 3.2vw 0 0.8vw;
}
#contact .contact-box .btn-tel .icon-tel .icon{
	margin: 0 1.3vw 0 0;
	width: 4.7vw
}
#contact .contact-box .btn-tel .icon-tel .tel{
	font-size: 4.8vw;
	font-weight: bold;
	color: #fff;
}
#contact .contact-box .btn-tel .hours{
	font-size: 3vw;
	text-align: center;
	color: #fff;
}



/* --------------------------------------------------------------------------------
parts-category
カテゴリー
-------------------------------------------------------------------------------- */

#category .category-box ul{
	display: flex;
	flex-wrap: wrap;
}
#category .category-box ul li{
	width: 45vw;
	margin: 0 4vw 4vw 0;
	padding: 2.5vw;
	background: #fff;
	text-align: center;
}
#category .category-box ul li:nth-child(2n){
	margin: 0 0 4vw;
}
#category .category-box ul li img{
	display: block;
}
#category .category-box ul li .txt{
	font-size: 4.8vw;
	padding: 3vw 0 2vw;
}


