@charset "utf-8";

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

	PC向けcommon.css
	
-------------------------------------------------------------------------------- */


/* --------------------------------------------------------------------------------
	body
-------------------------------------------------------------------------------- */
body {
	margin: 0;
	padding: 0;
	min-width: 1160px;
	line-height: 1.5;
	font-size: 16px;
	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 {
	text-decoration: none;
}
.common a:hover img {
	opacity: 0.7;
}
.common img{
	max-width: 100%;
}


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


/* --------------------------------------------------------------------------------
	共通クラス
-------------------------------------------------------------------------------- */
.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 40px;
}
ol.ol{
	list-style: decimal;
	padding: 0 0 0 40px;
}


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

h2.heading{
	display: flex;
	align-items: center;
	color: #5a310c;
	font-size: 40px;
	line-height: 1;
	margin-bottom: 0;
}
h2.heading::after {
	border-top: 2px solid #5a310c;
	content: "";
	flex-grow: 1;
	margin-left: 12px;
}
.s-heading {
	display: block;
	color: #d1ae80;
	font-size: 20px;
	line-height: 1;
	margin: 19px 0;
}

/* --------------------------------------------------------------------------------
	container
-------------------------------------------------------------------------------- */
#container{
	width: 1160px;
	margin: 0 auto;
}


/* --------------------------------------------------------------------------------
	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: 90px;
	height: 90px;
	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: 90px;
	height: 90px;
}
#header .h-menu .h-button.active .h-bar {
	width: 36px;
}
#header .h-menu .h-button.active .h-bar1 {
	transform: rotate(35deg);
	top: 25px;
	left: 31px;
}
#header .h-menu .h-button.active .h-bar2 {
	opacity: 0;
}
#header .h-menu .h-button.active .h-bar3 {
	transform: rotate(-35deg);
	top: 46px;
	left: 29px;
}
#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: 36px;
	height: 4px;
	transition: all 0.2s;
	transform-origin: 0 0;
	left: 27px;
}
#header .h-menu .h-bar1 {
	top: 25px;
}
#header .h-menu .h-bar2 {
	top: 35px;
}
#header .h-menu .h-bar3 {
	top: 45px;
}
#header .h-menu .h-text {
	text-align: center;
	font-size: 12px;
	transform: translateY(20px);
}
#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: 300px;
	height: auto;
	transition: all 0.2s ease-in;
	position: absolute;
	top: -800px;
	left: 0;
	z-index: 1000;
	background-color:rgba(34,34,34,0.9);
}
#header .h-menu .h-nav_wrapper.open {
	top: 0;
}
#header .h-menu .h-nav {
	padding: 90px 0 20px;
	list-style: none;
}
#header .h-menu .h-nav > li > a{
	font-size: 18px;
	display: block;
	padding: 10px 20px;
	border-bottom: 1px solid #505050;
	margin:0;
	line-height: 1;
	list-style: none;
	font-family: "Noto Serif JP", serif;
}
#header .h-menu .h-nav > li:nth-child(1) > a{	
	border-top: 1px solid #505050;
}

#header .h-menu .h-nav li .h-s-btn{
	color: #fff;
	display: block;
	cursor:pointer;
	padding: 10px 20px;
	line-height: 1;
	border-bottom: 1px solid #505050;
	font-family: "Noto Serif JP", serif;
	color: #e60014;
	position: relative;
}
#header .h-menu .h-nav li .h-s-btn::after{
	content: '';
	width: 8px;
	height: 8px;
	margin-top: -6px;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: rotate(135deg);
	position: absolute;
	top: 50%;
	right: 20px;
}
#header .h-menu .h-nav li.open .h-s-btn::after{
	content: '';
	width: 8px;
	height: 8px;
	margin-top: -2px;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: rotate(-45deg);
	position: absolute;
	top: 50%;
	right: 20px;
}
#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{
	display: block;
	padding: 7px 20px;
}

/*ロゴ*/
#header h1.h-logo{
	position: absolute;
	top: 20px;
	right: 20px;
}

/* --------------------------------------------------------------------------------
	wrapper
-------------------------------------------------------------------------------- */
#wrapper{
	width: 1160px;
	margin: 0 auto;
}


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


/* --------------------------------------------------------------------------------
	sub1
-------------------------------------------------------------------------------- */
#sub1{
}


/* --------------------------------------------------------------------------------
	footer
-------------------------------------------------------------------------------- */
#footer{
	margin: 100px 0 0;
}

/********** フッターメニュー **********/
#footer .col-menu {
	background: #fff;
	width: 100%;
	padding: 14px 0;
	margin: 0 0 40px;
}
#footer .col-menu .f-menu ul{
	display: flex;
	justify-content: center;
}
#footer .col-menu .f-menu ul li a{
	font-weight: bold;
	padding: 0 24px;
	border-right: 1px solid #bfbfbf;
}
#footer .col-menu .f-menu ul li:last-child a{
	border: none;
}

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

/********** フッターお問い合わせ **********/
#footer .col-info{
	background: #000000;
	border-top: 5px solid #c60a13;
	color: #fff;
	display: flex;
	justify-content: space-between;
	padding: 15px 85px 22px 15px;
}
#footer .col-info .f-txt{
	font-size: 14px;
	margin: 0 0 14px;
}
#footer .col-info .f-logo-sns{
	display: flex;
	align-items: center;
}
#footer .col-info .f-logo-sns .f-logo{
	width: 225px;
	margin: 0 46px 0 0;
}
#footer .col-info .f-logo-sns .f-sns ul{
	display: flex;
}
#footer .col-info .f-logo-sns .f-sns ul li{
	width: 50px;
	margin: 0 10px 0 0;
}
#footer .col-info .f-info{
	font-size: 14px;
	margin: 7px 0 0;
	line-height: 1.5;
}

/* --------------------------------------------------------------------------------
float
-------------------------------------------------------------------------------- */
.float{
	position: fixed;
	top: 100px;
	right: 0;
	z-index: 100;
}
.float img{
	display: block;
}


/* --------------------------------------------------------------------------------
pagetop
-------------------------------------------------------------------------------- */
.pagetop{
	position: fixed;
	bottom: 40px;
	right: 125px;
	z-index: 100;
}
.pagetop img{
	width: 100px;
	display: block;
}




/* --------------------------------------------------------------------------------
parts-contact
お問い合わせ
-------------------------------------------------------------------------------- */
#contact .contact-box{
	display: flex;
	justify-content: center;
}
#contact .contact-box .btn-mail a{
	display: flex;
	align-items: center;
	justify-content: center;
	background: #c60a13;
	width: 320px;
	height: 80px;
	margin: 0 20px;
	font-size: 20px;
	color: #ffffff;
	font-weight: bold;
	line-height: 1;
}
#contact .contact-box .btn-mail a:hover{
	text-decoration: none;
	opacity: 0.6;
}
#contact .contact-box .btn-mail a .icon{
	margin: 0 8px 0 0;
}
#contact .contact-box .btn-tel{
	border-top: 1px solid #333333;
	border-bottom: 1px solid #333333;
	width: 320px;
	height: 80px;
	margin: 0 20px;	
}
#contact .contact-box .btn-tel .icon-tel{
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	padding: 15px 0 4px;
}
#contact .contact-box .btn-tel .icon-tel .icon{
	margin: 0 8px 0 0;
}
#contact .contact-box .btn-tel .icon-tel .tel{
	font-size: 24px;
	font-weight: bold;
}
#contact .contact-box .btn-tel .hours{
	font-size: 15px;
	text-align: center;
}



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

#category .category-box ul{
	display: flex;
	flex-wrap: wrap;
}
#category .category-box ul li{
	width: 275px;
	margin: 0 20px 20px 0;
	padding: 8px;
	background: #fff;
	text-align: center;
}
#category .category-box ul li:nth-child(4n){
	margin: 0 0 20px;
}
#category .category-box ul li img{
	display: block;
}
#category .category-box ul li .txt{
	font-size: 20px;
	padding: 15px 0 7px;
}











