﻿@charset "utf-8";
/* CSS Document */

/*----------------------------------
  レイアウト系
------------------------------------*/
/*
ブレイクポイントの設定用クラス .bp768 .bp480 .bp420 
を切り替えて使ってください。
.column-box 又は .float-box に設定して下さい
*/

/* ------ カラム（flex） ------- */
.column-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.column-box__2col {
  width: 48%;
}
.column-box__3col {
  width: 31%;
}
.column-box__4col {
  width: 23%;
}
/* カスタム用カラムボックス */
.column-box__80 {
  width: 80%;
}
.column-box__70 {
  width: 70%;
}
.column-box__60 {
  width: 60%;
}
.column-box__50 {
  width: 50%;
}
.column-box__40 {
  width: 40%;
}
.column-box__30 {
  width: 30%;
}
.column-box__20 {
  width: 20%;
}


/* 
最終行レイアウト維持のためのclass
コンテンツの数が変動する場合設定してください。
.column-box に設定してください。
*/
/*--------------------------------*/
/* ３カラム用 */
.column-box--3return::after {
  content:"";
  display: block;
  width: 31%;
}
/* ４カラム用 */
.column-box--4return::before {
  content:"";
  display: block;
  width:23%;
  order:1;
}
.column-box--4return::after {
  content:"";
  display: block;
  width :23%;
}
/*--------------------------------*/
/* ブレイクポイント-汎用 */
@media screen and (max-width: 768px) {
  .bp768 > [class*="column-box__"] {
    width: 100%;
    margin-bottom: 20px;
  }
	.bp768 > [class*="column-box__"]:not(:last-child) {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 480px) {
  .bp480 > [class*="column-box__"] {
    width: 100%;
  }
	.bp480 > [class*="column-box__"]:not(:last-child) {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 320px) {
  .bp320 > [class*="column-box__"] {
    width: 100%;
    margin-bottom: 20px;
  }
}
/* ブレイクポイント-中央揃え */
@media screen and (max-width: 768px) {
  .column-box.bp768-c {
    -webkit-justify-content: space-around; 
    justify-content: space-around;
  }
  .column-box.bp768-c > [class*="column-box__"] {
    width: 100%;
  }
}
@media screen and (max-width: 480px) {
  .column-box.bp480-c {
    -webkit-justify-content: space-around; 
    justify-content: space-around;
  }
  .column-box.bp480-c > [class*="column-box__"] {
    width: 100%;
  }
}
@media screen and (max-width: 320px) {
  .column-box.bp320-c {
    -webkit-justify-content: space-around; 
    justify-content: space-around;
  }
  .column-box.bp320-c > [class*="column-box__"] {
    width: 100%;
  }
}
/* android4対策 */
@media screen and (max-width: 980px) {
  body.and4 .column-box {
    display: block;
    text-align: center;
  }
  body.and4 .column-box > div {
    display: inline-block;
  }
}

.conts__cell {
  padding: 0px 0;
}
@media screen and (max-width: 800px) {
	.conts__cell {
  	padding: 60px 0 30px;
	}
}
@media screen and (max-width: 480px) {
  .conts__cell {
    padding: 5px 0;
  }
}

.conts__inner {
  max-width: 980px;
  margin: 0 auto;
}
/*@media screen and (max-width: 768px) {
  .conts__inner {
    width: 92%;
  }
}*/

/*デバイス傾け文字サイズ制御*/
body {
	-webkit-text-size-adjust: 100%;
}	

.fix {
	position: fixed;
}
.fixed__bottom {
	width: 100%;
	bottom: 0;
	background: url(https://image.rakuten.co.jp/speed-addict/cabinet/image/06310614/imgrc0071731904.jpg)repeat-x center;
  margin: auto;
  left: 0%;
  height: 64px;
  background-size: contain;
	z-index: 100;
}
.fixed__top a,.fixed__bottom a {
	display: block;
}		
.fixed__bottom a {
	height: 64px;
}		
.fixed__top {
	display: none;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 100;
}
.fixed__top,.fixed__bottom {margin: auto;line-height: 0;}
.fixed__top img,.fixed__bottom img { width: 100%; }
.fixed__top a img {
	height: 54px;
}
@media screen and (max-width: 1100px) {
	.fixed__bottom, .fixed__bottom a {
		height: 50px;
	}
}
@media screen and (max-width: 800px) {
	.fixed__bottom, .fixed__bottom a {
		height: 40px;
	}
}
@media screen and (max-width: 660px) {
	.fixed__bottom, .fixed__bottom a {
		height: 36px;
	}
}	
@media screen and (max-width: 600px) {
	/*.btn_area {
		width: 300px;
		height: 150px;
		margin-top: -75px;
    margin-left: -150px;
	}*/
	.fixed__bottom {
		display: none;
	}
	.fixed__top {
		display: block;
		height: 54px;
	}
	.header_wrapper .intro {
    margin-top: 54px;
	}
}	
footer,footer .footer {
		margin-bottom: 7%;
}
#btn_top {
	bottom: 70px !important;
}
@media screen and (max-width: 480px) {
  footer,footer .footer {
		margin-bottom: 0%;
  }
	.header_wrapper .fixed {
    top: 54px;
  }
	#btn_top {
	  bottom: 10px !important;
  }
}

/*  timer SALE時のみ使用 */	
#timer,
.header_sale_bnr {
	background-color: #fff !important;
	border: 1px solid #000;
}
#timer p {
	color: #000 !important;
}
.header_sale_bnr p {
	color: #C1272D !important; 
	letter-spacing: -1px;
}
.header_sale_bnr p a {
	text-decoration: none;
}
a .header_sale_bnr {
  padding-bottom: 0px !important;
}


.sp_button {
	display: none;
}
.sp_button {
	width: 100%;
	background: -moz-linear-gradient(top, #FFF 0%, #EEE);
	background: -webkit-gradient(linear, left top, left bottom, from(#FFF), to(#ddd));
	border: 1px solid #DDD;
	color: #fff;
	line-height: 3em;
	text-align: center;
}
.sp_button a {
	color: #666;
	display: block;
}
.sp_title a {
	color: #fff;
}
#btn_top {
	position: fixed;
	bottom: 10px;
	right: 7px;
}
#btn_top a {
	display: block;
	padding: 8px 10px 12px;
	color: #FFF;
	background: rgba(0, 0, 0, 0.7);
	text-align: center;
	font-size: 10px;
	line-height: 1.1;
	text-decoration: none;
}
 @media screen and (min-width: 480px) {
footer .cp {
	display: none;
}
}
 @media screen and (max-width: 480px) {
.sp_button {
	display: block;
}
footer .cp {
	display: block;
	text-align: center;
	padding: 20px 0;
	font-size: 14px;
}
}
/* ワッツニュー変更に伴うcss */
.new {
	margin-bottom: 0px;
	overflow: auto;
}
.headercomment {
	background-color: #000;
	padding: 10px;
	position: relative;
	color: #fff;
}
.headercomment:after {
	border-right: 12px solid #000;
	border-top: 12px solid transparent;
	border-bottom: 12px solid transparent;
	content: '';
	margin-top: -10px;
	position: absolute;
	left: -12px;
	top: 50%;
}
.headercomment ul li {
	font-size: 1.6rem;
}
.headercomment ul li > span {
	color: #cc0001;
	font-weight: bold;
}
.search-box {
	margin: 0px auto 20px;
}
.tel a {
	cursor: default;
	pointer-events: none;
}
 @media screen and (max-width: 768px) {
.tel a, .mail a {
	pointer-events: auto;
}
}


/* ------ 
2019/11/29
saleファイルにあったコードを移植 
------- */


/*  timer SALE時のみ使用 */	

#timer, a .header_sale_bnr {
	margin: 0 auto 10px;
	background: #CC0000;
	padding: 0 0 0 5px;
	overflow: hidden;
	width: 99%;
	border-radius: 6px;
	color: #fff;
	line-height: 45px;
}
a .header_sale_bnr {
	padding-bottom: 5px;
}
#timer p, .header_sale_bnr p　 {
	line-height: 45px;
}
#timer a:hover {
	　text-decoration: underline;
}
#timer p, .header_sale_bnr p, .header_sale_bnr ul li span {
	text-align: left;
	font-size: 20px;
	font-weight: bold;
	color: #fff;
}
.header_sale_bnr ul li span, .header_sale_bnr ul li img {
	float: left;
}
.header_sale_bnr ul li span {
	line-height: 35px;
}
.header_sale_bnr ul li img {
	width: 45px;
	margin-right: 10px;
}
 @media screen and (max-width: 640px) {
	#timer p,  .header_sale_bnr p,  .header_sale_bnr ul li span {
		font-size: 16px;
	}
}
@media screen and (max-width: 480px) {
	#timer p,  .header_sale_bnr p,  .header_sale_bnr ul li span {
		font-size: 14px;
		letter-spacing: -1px;
	}
	.header_sale_bnr ul li img {
		margin-right: 5px;
	}
}
@media screen and (max-width: 320px) {
	#timer p,  .header_sale_bnr p,  .header_sale_bnr ul li span {
		font-size: 14px;
	}
	.header_sale_bnr ul,  .header_sale_bnr ul li span {
		line-height: 25px;
	}
	.header_sale_bnr ul li img {
		width: 30px;
	}
}

.sp-title {
  font-size: 35px;
  background-color: #cc0001;
	margin-bottom: 30px;
	padding-left: 15px;
}
.sp-title a {
	color: #FFF !important;
	font-weight: bold;
}

.pg-link {
	text-align: right;
	font-size: 16px;
	margin: 0 auto 30px;
	width: 100%;
}

.item-set {
	margin-bottom: 30px;
}

.sp-title a,
.pg-link a,
.sp_item-inner a {
  text-decoration: none;
	-webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
}
.sp-title a:hover,
.pg-link a :hover,
.sp_item-inner a :hover{
  opacity: 0.8 ;
}

div.sp_item-inner a img {
  width: 100%;
	height: auto;
}

div.sp_item-inner a p {
	font-size: 18px;
	text-align: center;
}

@media screen and (max-width: 800px) {
	.square_btn {
		position: relative;
		display: inline-block;
		padding: 0.25em 0.5em;
		text-decoration: none;
		color: #FFF !important;
		background: #3560fd;
		border-bottom: solid 2px #000dd2;
		border-radius: 4px;
		box-shadow: inset 0 2px 0 rgba(255,255,255,0.2), 0 2px 2px rgba(0, 0, 0, 0.19);
		font-weight: bold;
		width: 95%;
	}
	.square_btn:active {
		border-bottom: solid 2px #fd9535;
		box-shadow: 0 0 2px rgba(0, 0, 0, 0.30);
	}
	.sp_item-inner {
		width: 48%;
		margin-bottom: 20px;
	}
	
  .sp_none {
		display: none;
	}
	
	.sp-title {
		font-size: 24px;
	}
	
	.item-set {
		margin-bottom: 0px;
	}
	
	.pg-link {
		text-align: center;
	}
}
@media screen and (max-width: 480px) {
	.sp-title {
		padding: 5px 0 5px 5px;
	}
}
	
span.item-red {
	color: #FF0000;
}
span.item-title,
b.price  {
  font-size: 18px;
	font-weight: bold;
}
span.default-price,
b.price > span {
  font-size: 11px;
}	

@media screen and (max-width: 480px) {
	span.item-title,
	b.price,
  .sp_item-inner a p > strong  {
    font-size: 12px;
		line-height: 1.6;
    display: inline-block;

  }
  span.default-price,
  b.price > span {
    font-size: 10px;
  }	
}
