@charset "utf-8";
/*
 * home CSS
 * ---------------------------------------------
 *
 *
 */

@import 'slick.css';
@import 'slick-theme.css';

/*===================================
	layout
=====================================*/

.cont {
	overflow: hidden;
	padding: 50px 0;
	border-bottom: solid 4px #eee;
}
.cont:nth-last-of-type(1) {
	border: none;
}
.contHead {
	margin-bottom: 30px;
	padding: 0 15px;
	letter-spacing: -.40em;
}
.contHead h2,.contHead p {
	display: inline-block;
	vertical-align: middle;
	letter-spacing: normal;
}
.contHead h2 {
	margin-right: 25px;
	padding: 12px 25px 12px 0;
	border-right: solid 1px #444;
	font-size: 40px;
	font-weight: 700;
}
.contHead h2 span {
	display: inline-block;
	vertical-align: middle;
	color: #e90f0f;
	margin: -10px 0 0 15px;
	font-size: 18px;
}
@-moz-document url-prefix() {
	.contHead h2 span  {
		margin-top: -6px;
	}
}
.contHead p {
	color: #666;
	font-size: 15px;
	line-height: 1.6;
}
.contHead .brkPc {
	display: inline-block;
}
.sec li a:hover {
	opacity: .7;
}
.sec a:hover h3,
.sec a:hover p {
	color: #777;
}
.list li {
	display: inline-block;
	vertical-align: top;
	letter-spacing: normal;
}
.list li a {
	display: block;
}

/*  サムネイル配置
---------------------------------*/

/*絶対中央配置*/
.central figure {
	position: relative;
	z-index: -1;
}
.central figure img {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	max-width: 100%;
	max-height: 100%;
}

/*横100% タテ位置センタートリミング*/
.vertical_central_trimming div {
    position: relative;
	z-index: -1;
    width: 100%;
}
.vertical_central_trimming div figure {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: 0px;
    overflow: hidden;
}
.vertical_central_trimming div figure img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: auto;
}

/*  more
---------------------------------*/

.more {
	text-align: right;
}
.more a {
	color: #e90f20;
	/*font-weight: 600;*/
	font-weight: 500;
}
.more.arrow a:after {
	width: 9px;
	height: 9px;
	margin: -3px 0 0 5px;
	border-color: #e90f20;
}
.more a:hover {
	text-decoration: underline;
}

/*===================================
	keyVisual
=====================================*/

.keyVisual {
	overflow: hidden;
	min-width: 1170px;
}
.slider {
	position: relative;
	width: 100%;
	margin: auto;
}
.slick-slide {
	margin: 0 auto;
	padding: 0;
}
.slick-slide img {
	width: 1170px;
	margin: auto;
}
.slick-slide:not(.slick-center) {
	overflow: hidden;
	position: relative;
}
.slick-slide:not(.slick-center):after {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 1170px;
	height: 535px;
	background: rgba(0,0,0,.5);
}
.slick-arrow {
	display: block;
	position: absolute;
	z-index: 1;
	top: 50%;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: #eae6de;
	text-indent: -9999em;
	opacity: .8;
}
.slick-arrow.slick-prev{
	left: 30px;
}
.slick-arrow.slick-next {
	right: 30px;
}
.slick-arrow:after {
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 10px;
	height: 10px;
	border-bottom: solid 1px #000;
	border-left: solid 1px #000;
}
.slick-arrow.slick-prev:after {
	margin: -5px 0 0 -4px;
	transform: rotate(45deg);
}
.slick-arrow.slick-next:after {
	margin: -5px 0 0 -8px;
	transform: rotate(225deg);
}
.slick-dots {
	display: block;
}
.slick-dots li {
	width: 12px;
	height: 12px;
	margin: 0 5px;
	border-radius: 50%;
	background: #ccc;
}
.slick-dots li.slick-active {
	background: #666;
}

/*===================================
	ブランド
=====================================*/

.brand__list {
	margin-bottom: -30px;
}
.brand__list li {
	margin: 0 15px 30px;
}
.brand__list figure {
	width: 170px;
	height: 100px;
	border: solid 1px #ccc;
}

/*===================================
	特集
=====================================*/

.feature__list {
	margin-bottom: 20px;
}
.feature__list li {
	width: 270px;
	margin: 0 15px 30px;
}
.feature__list div {
	height: 200px;
}
.feature__list  span {
	display: block;
	margin-top: 1.5em;
	color: #666;
	font-size: 13px;
}
.feature__list p {
	margin: 0.3em 0 0.5em;
	line-height: 1.6;
}
.feature__list time {
	color: #666;
	font-size: 14px;
}

/*===================================
	新商品
=====================================*/

.newItem__list {
	margin-bottom: 30px;
}
.newItem__list li {
	position: relative;
	width: 270px;
	margin: 0 15px 50px;
	padding-bottom: 1.6em;
}
.newItem__list figure {
	width: 270px;
	height: 270px;
	margin-bottom: 20px;
}
.newItem__list span {
	color: #666;
	font-size: 14px;
}
.newItem__list h3 {
	margin: 0.3em 0 0.8em;
	line-height: 1.4;
}
.newItem__list p {
	position: absolute;
	left: 0;
	bottom: 0;
	font-size: 12px;
}
.newItem__list p b {
	font-size: 16px;
}

/*===================================
	おすすめランキング
=====================================*/

.ranking__list {
	margin-bottom: 20px;
	counter-reset: custum-counter;
}
.ranking__list li {
	position: relative;
	width: 270px;
	margin: 0 15px 50px;
	padding-bottom: 1.6em;
}
.ranking__list li:before {
	content: counter(custum-counter);
	counter-increment: custum-counter;
	display: block;
	position: absolute;
	z-index: 20;
	top: 9px;
	left: 9px;
	width: 35px;
	height: 35px;
	line-height: 37px;
	border-radius: 50%;
	border: solid 1px #000;
	background: #fff;
	color: #000;
	font-family: Helvetica, "sans-serif";
	font-size:20px;
	text-align: center;
}
.ranking__list li:nth-of-type(1):before {
	border-color: #d2b873;
	background: #d2b873;
	color: #fff;
}
.ranking__list li:nth-of-type(2):before {
	border-color: #b5b0b0;
	background: #b5b0b0;
	color: #fff;
}
.ranking__list li:nth-of-type(3):before {
	border-color: #896a4e;
	background: #896a4e;
	color: #fff;
}
.ranking__list figure {
	width: 270px;
	height: 270px;
	margin-bottom: 20px;
}
.ranking__list span {
	color: #666;
	font-size: 14px;
}
.ranking__list h3 {
	margin: 0.3em 0 0.8em;
	line-height: 1.4
}
.ranking__list p {
	position: absolute;
	left: 0;
	bottom: 0;
	font-size: 12px;
}
.ranking__list p b {
	font-size: 16px;
}

/*===================================
	ニュース
=====================================*/

.news__cont .sec {
	position: relative;
}
.news__list {
	width: 900px;
	margin-left: 15px;
}
.news__list li {
	overflow: hidden;
	width: 420px;
	margin: 0 30px 15px 0;
	padding-bottom: 16px;
	border-bottom: solid 1px #d6d6d6;
	box-shadow: 0 1px 0 0 #f5f5f5;
}
.news__list div {
	float: left;
	width: 140px;
	height: 105px;
}
.news__list span,
.news__list time {
	display: block;
	color: #666;
}
.news__list span,
.news__list p,
.news__list time {
	margin-left: 160px;
}
.news__list span {
	margin-bottom: 0.6em;
	font-size: 13px;
}
.news__list p {
	margin-bottom: 0.7em;
	font-size: 15px;
	line-height: 1.6;
}
.news__list time {
	font-size: 12px;
}
.news__cont .more {
	width: 885px;
}

/*===================================
	バナー
=====================================*/

.banner ul {
	display: flex;
	justify-content: space-between;
	flex-direction: row;
}
.banner li {
	margin-bottom: 15px;
}

/************************************************************************************
smaller than 750px
*************************************************************************************/
@media screen and (max-width: 752px) {

	/*===================================
		layout
	=====================================*/

	.cont {
		border-bottom-width: 5px;
	}
	.contHead {
		margin-bottom: 40px;
		padding: 0 20px;
	}
	.contHead h2,.contHead p {
		display: block;
	}
	.contHead h2 {
		margin: 0 0 20px;
		padding: 0;
		border: none;
		font-size: 60px;
	}
	.contHead h2 span {
		margin: -12px 0 0 29px;
		font-size: 30px;
	}
	@-moz-document url-prefix() {
		.contHead h2 span  {
			margin-top: -6px;
		}
	}
	.ranking__cont .contHead h2 {
		font-size: 55px;
	}
	.contHead p {
		font-size: 24px;
	}
	.contHead .brkPc {
		display: none;
	}

	/*  more
	---------------------------------*/

	.more {
		margin: 0 80px;
		border: solid 2px #e0e0e0;
		text-align: center;
	}
	.more a {
		display: block;
		padding: 34px 0;
		line-height: 1.2;
		font-size: 28px;
	}
	.more.arrow a:after {
		width: 15px;
		height: 15px;
		border-width: 2px;
	}
	.more a:hover {
		text-decoration: none;
	}

	/*===================================
		keyVisual
	=====================================*/

	.keyVisual {
		min-width: inherit;
		margin-bottom: 10px;
	}
	.slick-slide:not(.slick-center):after {
		display: none;
	}
	.slick-list {
		padding-bottom: 10px;
	}
	.slick-arrow {
		width: 50px;
		height: 50px;
		margin-top: -29px;
	}
	.slick-arrow.slick-prev{
		left: 9px;
	}
	.slick-arrow.slick-next {
		right: 9px;
	}
	.slick-arrow:after {
		width: 13px;
		height: 13px;
		border-width: 2px;
	}
	.slick-arrow.slick-prev:after {
		margin: -6px 0 0 -4px;
	}
	.slick-arrow.slick-next:after {
		margin: -6px 0 0 -10px;
	}
	.slick-dots li {
		width: 16px;
		height: 16px;
		margin: 0 7px;
	}

	/*===================================
		ブランド
	=====================================*/

	.brand__list {
		margin: 0 10px -20px;
	}
	.brand__list li {
		margin: 0 10px 20px;
	}
	.brand__list figure {
		width: 223px;
		height: 131px;
	}

	/*===================================
		特集
	=====================================*/

	.feature__list {
		margin: 0 10px;
	}
	.feature__list li {
		width: 345px;
		margin: 0 10px 40px;
	}
	.feature__list div {
		height: 255px;
	}
	.feature__list  span {
		font-size: 24px;
	}
	.feature__list p {
		font-size: 28px;
	}
	.feature__list time {
		color: #444;
		font-size: 24px;
	}

	/*===================================
		新商品
	=====================================*/

	.newItem__list {
		margin: 0 10px 20px;
	}
	.newItem__list li {
		width: 345px;
		margin: 0 10px 50px;
	}
	.newItem__list figure {
		width: 345px;
		height: 345px;
		margin-bottom: 20px;
	}
	.newItem__list span {
		font-size: 24px;
	}
	.newItem__list h3 {
		margin: 0.5em 0;
		font-size: 28px;
		font-weight: normal;
	}
	.newItem__list p {
		font-size: 18px;
	}
	.newItem__list p b {
		font-size: 28px;
	}

	/*===================================
		おすすめランキング
	=====================================*/

	.ranking__list {
		margin: 0 10px 20px;
	}
	.ranking__list li {
		width: 345px;
		margin: 0 10px 50px;
	}
	.ranking__list li:before {
		top: 12px;
		left: 12px;
		width: 48px;
		height: 48px;
		line-height: 50px;
		font-size: 32px;
	}
	.ranking__list figure {
		width: 345px;
		height: 345px;
		margin-bottom: 20px;
	}
	.ranking__list span {
		font-size: 24px;
	}
	.ranking__list h3 {
		margin: 0.5em 0;
		font-size: 28px;
		font-weight: normal;
	}
	.ranking__list p {
		font-size: 18px;
	}
	.ranking__list p b {
		font-size: 28px;
	}

	/*===================================
		ニュース
	=====================================*/

	.news__list {
		float: none;
		width: auto;
		margin: 0 20px 40px;
	}
	.news__list li {
		width: auto;
		margin: 0 0 20px;
		padding-bottom: 20px;
		box-shadow: none;
	}
	.news__list div {
		width: 225px;
		height: 167px;
	}
	.news__list span,
	.news__list time {
		display: block;
		color: #444;
	}
	.news__list span,
	.news__list p,
	.news__list time {
		margin-left: 245px;
	}
	.news__list span {
		margin-bottom: 0.4em;
		font-size: 24px;
	}
	.news__list p {
		margin-bottom: 0.4em;
		font-size: 28px;
		line-height: 1.4;
	}
	.news__list time {
		font-size: 24px;
	}
	.news__cont .more {
		width: auto;
	}

	/*===================================
		バナー
	=====================================*/

	.banner {
		position: relative;
		top: inherit;
		right: inherit;
		width: auto;
		margin: 50px 20px 4px;
	}
	.banner ul {
		display: block;
	}
	.banner li {
		margin-bottom: 30px;
	}
}
