@charset "utf-8";

/* ------------------------------------ タグ設定 ------------------------------------ */
html {
   font-size: 62.5%; 
}
body {
	margin: 0;
	padding: 0;
	line-height: 1.5;
	color: #000;
	text-align: left;
	font-family: "Hiragino Maru Gothic W4 JIS2004", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-size: 1rem; 
}
a img {
	border: none;
}
hr.dot_border {
    border-top: 2px dotted #b3b3b3;
    margin: 0;
}
.pc_block {
	display:block;
}
.sp_block {
	display:none;
}
br.pc {
	display: block;
}
br.sp {
	display: none;
}
@media screen and (max-width: 768px){
  br.pc {
		display: none;
	}
}
@media screen and (max-width: 640px){
	.pc_block {
		display:none;
	}
	.sp_block {
		display: block;
	}
}
@media screen and (max-width: 414px){
	br.sp {
		display: block;
	}
}

/* ------------------------------------ clearfix ------------------------------------ */
.cf:after {
    content:".";
    display:block;
    height:0;
    clear:both;
    visibility:hidden;
    font-size:0;
    line-height:0;
}
.cf {
    display:inline-block;
}
/* \*/
.cf {
    display:block;
}
/* */

/* --------------------------- link --------------------------- */
a {
	color: #000;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
	transition-duration: 0.5s;
	-moz-transition-duration: 0.5s;
	-webkit-transition-duration: 0.5s;
	-o-transition-duration: 0.5s;
	-ms-transition-duration: 0.5s;
}
a:hover img {
	opacity: 0.7;
	transition-duration: 0.5s;
	-moz-transition-duration: 0.5s;
	-webkit-transition-duration: 0.5s;
	-o-transition-duration: 0.5s;
	-ms-transition-duration: 0.5s;
}
a.textlinkUl {
	text-decoration: underline;
}
a img {
	border:none;
	border:0
}
a:hover img.link { 
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)";
  filter: alpha(opacity=60);
  -moz-opacity: 0.6;
  -khtml-opacity: 0.6;
  opacity: 0.6;
}

/* --------------------------- フォント --------------------------- */

.mincho {
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif;
}

/* --------------------------- 画像 --------------------------- */
@media screen and (max-width: 768px){
  img{
    max-width: 100%;
    height: auto;
    width /***/:auto;　
  }
}
.photo-type01 {
  border: 10px solid #FFF;
  box-shadow:2px 2px 5px 3px #b9b9d2;
  -moz-box-shadow:2px 2px 5px 3px #b9b9d2;
  -webkit-box-shadow:2px 2px 5px 3px #b9b9d2;
}

/* settings 
------------------------------------------------------------------ */
.important {
	font-weight: bold;
}
.mar_r0  {
	margin-right: 0px !important;
}
.mar_b0 {
	margin-bottom: 0px !important;
}
.mar_b5 {
	margin-bottom: 5px !important;
}
.mar_b10 {
	margin-bottom: 10px !important;
}
.mar_b15{
	margin-bottom: 15px !important;
}
.mar_b20{
	margin-bottom: 20px !important;
}
.mar_b25{
	margin-bottom: 25px !important;
}
.mar_b30{
	margin-bottom: 30px !important;
}
.mar_b35{
	margin-bottom: 35px !important;
}
.mar_b40{
	margin-bottom: 40px !important;
}
.mar_b45{
	margin-bottom: 45px !important;
}
.mar_b50{
	margin-bottom: 50px !important;
}
.mar_b55{
	margin-bottom: 55px !important;
}
.mar_b60{
	margin-bottom: 60px !important;
}
.mar_b65{
	margin-bottom: 65px !important;
}
.mar_b70{
	margin-bottom: 70px !important;
}
.mar_b75{
	margin-bottom: 75px !important;
}
.mar_b80{
	margin-bottom: 80px !important;
}
.mar_b85{
	margin-bottom: 85px !important;
}
.mar_b90{
	margin-bottom: 90px !important;
}
.mar_b95{
	margin-bottom: 95px !important;
}
.mar_b100{
	margin-bottom: 100px !important;
}
.mar_t15{
	margin-top: 15px !important;
}
.mar_l20 {
	margin-left: 20px !important;
}
br.sp {
	display: none;
}
.textL {
	text-align: left;
}
.bold {
	font: bold;
}
.red {
	color: #C1272D;
}
.blue {
	color: #0000cc;
}
@media screen and (max-width: 640px) {
	br.sp {
		display: block;
	}
}
@media screen and (max-width: 414px) {
	.clear {
	clear: both;
	}
}

/* ボディ 
------------------------------------------------------------------ */

body {
  position: relative;
}

/* ヘッダー上部のイントロ
------------------------------------------------------------------ */

.intro {
	background: #000;
	line-height: 25px;
	margin-bottom: 20px;
}
.intro span {
	max-width: 960px;
	width: 96%;
	margin: auto;
	font-size: 1.5rem;
	color: #fff;
	display: block;
}
@media screen and (max-width: 768px) {
	.intro {
		line-height: normal;
		padding: 5px 0;
	}
	.intro span {
		font-size: 1.3rem;
		display: block;
	}
}

/* ヘッダー
------------------------------------------------------------------ */
header {
  width: 100%;
  top: 0;
  background-color: #FFF;
}
header h1 {
	margin-bottom: 8px;
	font-size: 0px !important;
}
header .left{
	width: 400px;
}
header .right {
	width: 560px;
}
header .left .header_bnr {
	overflow: hidden;
}
header .left .header_bnr ul {
	overflow: hidden;
	display: inline-block;
}
header .left .header_bnr ul li {
	width: 185px;
	float: left;
}
header .left .header_bnr ul li img {
	width: 100%;
}
header .left .header_bnr ul li:first-child,
header .left .header_bnr ul li:nth-child(3) {
	margin-right: 10px;
}
@media screen and (max-width: 980px) {
	header .left .header_bnr {
		text-align: center;
	}
}
@media screen and (max-width: 640px) {
	header .left .header_bnr ul li.sp_block {
		width: 167px;
	}
}
@media screen and (max-width: 360px) {
	header .left .header_bnr ul li.sp_block {
		width: 140px;
	}
}
@media screen and (max-width: 320px) {
	header .left .header_bnr ul li {
		width: 140px;
	}
}

/*　本店用ＳＮＳアイコン周り　*/
header .left .header_sns {
	clear: both;
	overflow: hidden;
	margin: 10px auto;
	width: 292px;
}
header .left .header_sns ul {
  overflow: hidden;
  display: inline-block;
  margin: 0 auto;
}
header .left .header_sns ul li {
	width: 30px;
	float: left;
	margin-right: 20px;
}
header .left .header_sns ul li:last-child {
	margin-right: 0px;
}
header .left .header_sns ul li img {
	width: 100%;
}
@media screen and (max-width: 980px) {
	header .left .header_sns {
    width: 100%;
    text-align: center;
	}
}

header ul.ec_list {
	margin: 0px 0 15px;
	overflow: hidden;
}
header ul.ec_list li {
	width: 167px;
  text-align: center;
  float: left;
  font-size: 1.4rem;
  border: 1px solid;
  margin-right: 10px;
  padding: 5px;
  letter-spacing: -1px;
	font-weight: bold;
	/*box-sizing: content-box;*/
	
}
header ul.ec_list li a {
	display: block;
}
header ul.ec_list li:nth-child(3n) {
	margin-right: 0px;
}
header ul.ec_list li:nth-child(1),
header ul.ec_list li:nth-child(2),
header ul.ec_list li:nth-child(3) {
	margin-bottom: 7px;
}
header ul.ec_list li {
	background-size: 22px !important;
  display: inline-block;
  background-position: center left 3px !important;
}
header ul.ec_list li.company {
	background: url(../images/head_icon-home.png) no-repeat;
}
header ul.ec_list li.guide {
	background: url(../images/head_icon-guide.png) no-repeat;
}
header ul.ec_list li.cart {
	background: url(../images/head_icon-cart.png) no-repeat;
}
header ul.ec_list li.rakuten {
	background: url(../images/head_icon-rakuten.png) no-repeat;
}
header ul.ec_list li.account {
	background: url(../images/head_icon-account.png) no-repeat;
}
header ul.ec_list li.media {
	background: url(../images/head_icon-media.png) no-repeat;
}
header ul.ec_list li.login {
	background: url(../images/head_icon-login.png) no-repeat;
}
header ul.ec_list li.repair {
	background: url(../images/head_icon-helmetrepair.png) no-repeat;
	background-color: #000;
}
header ul.ec_list li.repair a {
	color: #fff !important;
}
header .contact_ec,
header .contact_repair {
	width: 48.9%;
	text-align: center;
}
header .contact_ec {
	margin-right: 10px;
}
header .contact_ec p.title,
header .contact_repair p.title{
	background: #000;
	color: #fff;
	font: 1.5rem bold;
	padding: 3px 5px;
	font-family: "Hiragino Maru Gothic W4 JIS2004", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: bold;
	line-height: 33px;
	text-align: left;
	margin-bottom: 0px !important;
	overflow: hidden;
}
header .contact_ec p.title i,
header .contact_repair p.title i {
	font-style: normal;
  line-height: 1.1;
  float: left;
}
header .contact_ec p.title span,
header .contact_repair p.title span {
	float: right;
	display: block;
	height: 33px;
}
header .contact_ec p.title span img,
header .contact_repair p.title span img {
	width: 116px;
	height: 100%;
}
header .contact_ec p.shop_name,
header .contact_repair p.shop_name {
	margin-bottom: 8px;
  background-color: #dadada;
  font-size: 1.4rem;
  font-weight: bold;
	padding: 0 5px;
  text-align: left;
  clear: both;
}
header ul.contact_list li {
	text-align: center;
	font-size: 2rem;
	font-weight: bold;
}
header ul.contact_list li.tel {
	background: url(https://www.rakuten.ne.jp/gold/speed-addict/images/contact_icon-tel.png) no-repeat;
	background-size: 30px;
}
header ul.contact_list li.mail {
	background: url(https://www.rakuten.ne.jp/gold/speed-addict/images/contact_icon-mail.png) no-repeat;
	text-align: left;
  padding-left: 40px;
}
header ul.contact_list li.tel img {
	width: 196px;
	height: 45px;
}
@media screen and (max-width: 980px) {
	header .header {
	  width: 100%;
	  z-index: 3;
	}
	header h1 {
	  text-align: center;
		width: 310px;
		margin: 20px auto 18px;
	}
	header .left,
	header .right {
		width: 100%;
	}
	header .left {
		margin-bottom: 20px;
	}
	header .right {
		float: none;
	}
	header .contact_ec, header .contact_repair {
    width: 48.9%;
    text-align: center;
		margin-bottom: 0px;
	}
	.contact_repair p.title > img {
		width: 135px;
	}
	header ul.contact_list li.tel {
		text-align: left;
		padding-left: 40px;
	}
	header ul.ec_list {
    width: 480px;
		margin: 0 auto 20px;
	}
	header ul.ec_list li {
    width: 140px;
	}
}
@media screen and (max-width: 700px) {
	header ul.ec_list li {
    margin-right: 4px;
	}
	header nav.gnav ul li {
    width: 31%;
	}
	header ul.contact_list li {
		font-size: 1.6rem;
	}
}
@media screen and (max-width: 480px) {
	header ul.ec_list li:nth-child(1),
	header ul.ec_list li:nth-child(2),
	header ul.ec_list li:nth-child(3) {
    margin-bottom: 0px;
	}
	header ul.ec_list {
    width: 100%;
		margin: 0 auto 20px;
	}
	header ul.ec_list li {
    width: 46%;
		margin-right: 0px;
		margin-bottom: 7px !important;
	}
	header ul.ec_list li:nth-child(odd) {
    float:left;
	}
	header ul.ec_list li:nth-child(even) {
    float:right;
	}
	header .contact_ec,
	header .contact_repair {
    width: 100%;
	}
	header .contact_ec {
   	margin-bottom: 20px;
		margin-right: 0px;
	
	}
	header ul.contact_list li {
    width: 80%;
    margin: auto;
	}
	header ul.contact_list li.tel {
		text-align: center;
    padding-left: 20px;
	}
	header ul.contact_list li.mail {
    text-align: center;
		background-size: contain;
		padding-left: 25px;
		font-size: 2rem;
		letter-spacing: 0px;
	}
}
@media screen and (max-width: 414px) {
	
}
@media screen and (max-width: 320px) {
	header ul.ec_list li {
    width: 45%;
	}
}
/* ロゴ */
header .header h1 {
  float: left;
}
header .header h1 span {
  padding-left: 7px;
}
header .header h1 img {
  vertical-align: top;
	width: 100%;
	text-align: center;
}

/* tel */
.header .header__heading .tel {
	margin-bottom: 10px;
	float: right;
}


@media screen and (max-width: 1300px) {
  body > header nav {
    margin-left: 380px;
  }
}
@media screen and (max-width: 1060px) {
  body > header nav {
    margin-left: 360px;
  }
}
@media screen and (max-width: 768px) {
	.header .header__heading .tel {
		margin-bottom: 0px;
		float: none;
	}
}
@media screen and (max-width: 640px) {
  header .header h1 {
    width: 55%;
    margin: auto;
    display: block;
		float: none;
		padding: 5px 0;
  }
	.header .header__heading .tel {
		display: inline-block;
    float: none;
		margin-top: 0px;
	}
}
@media screen and (max-width: 414px) {
  header .header h1 {
    width: 70%;
  }
}


/* グローバルナビの位置調整 */
header nav.gnav {
	width: 100%;
	margin: 0px auto 40px;
	clear: both;
	display: inline-block;
}
header nav.gnav ul {
	overflow: hidden;
}
header nav.gnav ul li {
	width: 192px;
	float: left;
	text-align: center;
}
header nav.gnav ul li img {
	width: 182px;
}
header nav.gnav ul li:nth-child(1),
header nav.gnav ul li:nth-child(6) {
	text-align: left;
}
header nav.gnav ul li:nth-child(5),
header nav.gnav ul li:nth-child(10) {
	text-align: right;
}
@media screen and (max-width: 980px) {
	header nav.gnav ul li {
		width: 20%;
	}
	header nav.gnav ul li img {
		width: 97%;
	}
}
@media screen and (max-width: 640px) {
	header nav.gnav ul li {
		width: 48%;
		float: none;
		display: inline-block;
	}
	header nav.gnav ul li:nth-child(odd) {
		float: left;
	}
	header nav.gnav ul li:nth-child(even) {
		float: right;
	}
	header nav.gnav ul li:nth-child(6),
	header nav.gnav ul li:nth-child(5),
	header nav.gnav ul li:nth-child(10) {
		text-align: center;
	}
}

/* メイン
------------------------------------------------------------------ */
#wrapper {
	width: 100%;
	max-width: 960px;
	margin: 10px auto 0px;
}
#contents {
	padding: 0 0 0;
}
@media screen and (max-width: 980px) {
	#wrapper {
		width: 97%;
	}
}
@media screen and (max-width: 640px) {
	#wrapper {
		width: 92%;
	}
}


/* ちっちゃいモニタ */

/* スマホ */
@media screen and (max-width: 480px) {
	body {

	}
	header h1 {
		padding: 20px 0 0;
		margin: auto;
		text-align: center;
	}
}
@media screen and (max-width: 320px) {
	header h1 {
		width: 290px;
	}
}



/* フッター
------------------------------------------------------------------ */
footer {
	clear: both;
	padding: 20px 0px 0px;
	text-align: left;
	overflow: hidden;
}
footer .footer {
	margin: auto;
	width: 960px;
	overflow: hidden; 
}
#contents .half h3,
footer .footer h3 {
	font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 10px;
  background: #dadada;
  padding: 4px 10px;
}
footer .footer h4 {
	font-size: 1.5rem;
}
#contents .half,
footer .footer p {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.8em;
	padding-left: 10px;
}
footer .footer p.more {
	float: right;
	padding: 4px 10px;
}

#contents .half,
.footer .half,
.footer .full {
	border: solid 5px #666;
	padding: 10px;    
}
.footer .half {
	width: 440px;
	float: left;
	margin-bottom: 17px;
}
.footer .half:nth-child(2n) {
	margin-right: 17px;
}

.footer .full {
	width: 927px;
	clear: both;
}

footer .footer .section {
	margin-bottom: 40px;
}
footer .footer .section:last-child {
	margin-bottom: 0px;
}

footer .copyright {
	text-align: center;
  margin-bottom: 1rem;
  letter-spacing: 0.1rem;
  margin-top: 1rem;
}
.bottom_link ul li a > span {
	display: inline-block;
	float: right;
}
@media screen and (max-width: 960px) {
  footer .footer {
    margin: auto;
    width: 96%;
    padding: 0 2%;
		overflow: hidden;
  }
	.footer .half {
		width: 44%;
		margin: 0 auto 15px;
	}
	.footer .full {
		width: 96%;
	}
	.footer .half:nth-child(2n) {
		float: right;
		margin-right: 0px;
	}
}
@media screen and (max-width: 640px) {
	.footer .tel {
		display: block;
		float: right;
		margin-bottom: 10px;
	}
	.footer .half,
	.footer .half:nth-child(2n) {
		float: none;
		margin: 0px;
		margin-bottom: 20px;
		height: auto !important;
	}
	.footer .half,
	.footer .full {
		width: 95%;
	}
}
@media screen and (max-width: 480px) {
	#contents .half,
	.footer .half,
	.footer .full {
		width: 90%;
	}
	#contents .half,
	.footer .half {
		height: auto !important;
	}
	#contents .half {
		margin-bottom: 20px;
	}
}
@media screen and (max-width: 414px) {
	footer .footer {
    margin: auto;
		overflow: hidden;
		width: 100%;
    padding: 0%;
  }
	.footer .tel {
		float: none;
		margin: 20px auto;
		text-align: center;
	}
}
footer .footer_nav {
	float: left;
}
footer .footer nav a {
  color: #666;
}
footer .footer nav ul {
  text-align: left;
	float: left;
	margin-right: 55px;
}

footer .footer nav ul li {
  list-style: none;
	margin-bottom: 15px;
}
footer .footer .footer_logo {
	float: right;
}

@media screen and (max-width: 480px) {
  footer .footer nav.footer_nav_sns ul {
    margin-top: 15px;
    text-align: left;
  }
  footer .copyright {
    margin-top: 15px;
    text-align: left;
  }
}
@media screen and (max-width: 470px) {
	footer .footer nav ul,
	footer .footer nav.footer_nav_sns ul,
	footer .footer_logo,
	footer .copyright  {
	  text-align: center;
	}
}
@media screen and (max-width: 414px) {
	footer .footer .footer_logo {
		float: none;
	}
}
@media screen and (min-width: 480px) {
	.bottom_link {
		display: none;
	}
}
@media screen and (max-width: 480px) {
	.bottom_link {
		display: block;
	}
	footer {
		display: none;
	}
}
.bottom_link .copyright {
	text-align: center;
  margin-bottom: 1rem;
  letter-spacing: 0.1rem;
  margin-top: 1rem;
	font-size: 1rem;
} 
.bottom_link {
	background-color: #e6e6e6;
	padding: 15px 0;
}
.bottom_link ul {
	width: 96%;
	margin: auto;
}
.bottom_link ul li {
    width: 48%;
    display: inline-block;
    font-size: 1.2rem;
    margin-bottom: 15px;
    padding: 0px 2px;
		letter-spacing: -1px;
}
.bottom_link ul li > span {
	display: inline-block;
	float: right;
}
.bottom_link .cp {
    text-align: center;
    padding: 20px 0;
    font-size: 14px;
}
.bottom_link .cp a {
    text-decoration: underline;
}
