@charset "UTF-8";
html { 
	font-size: 62.5%;
}
body {
	font-size: 12px;
	font-size: 1.2rem;
	font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
	color: #FFF;
	line-height: 200%;
	margin: 0 auto;
	padding: 0;
	background-position: center center;
	background-repeat: no-repeat;
	background-attachment: fixed;
	background-size: cover;
	background-color: #fff;
}
a {
	text-decoration: none;
	color: #f6399f;
	-webkit-transition: all 300ms linear;
	-moz-transition: all 300ms linear;
	-o-transition: all 300ms linear;
	-ms-transition: all 300ms linear;
	transition: all 300ms linear;
}
a img {
	-moz-opacity: 1.00;
	opacity: 1.00;
	-webkit-transition: all 300ms linear;
	-moz-transition: all 300ms linear;
	-o-transition: all 300ms linear;
	-ms-transition: all 300ms linear;
	transition: all 300ms linear;
}
.attention {
	font-size: 12px;
	font-size: 1.2rem;
}
.copyrightText {
	width: 100%;
	padding: 10px auto;
	font-size: 10px;
	font-size: 1.0rem;
	color: #fff;
	text-align: center;
}
.copyrightMark {
	font-family: "Times New Roman", "Times";
}
article {
	width: 100%;
	margin: 20px 0 0;
	padding: 0;
	overflow: hidden;
}
.headerBlock {
	margin: 20px auto;
	overflow: hidden;
	clear: both;
}
.headerBlock .mainImageBlock {
	position: relative;
	color: #fff;
	overflow: hidden;
}
.headerBlock .mainImageBlock h1 {
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0;
	border-bottom: none;
	overflow: hidden;
}
.headerBlock .mainImageBlock h1 img {
}
.headerBlock .mainImageBlock aside {
	position: absolute;
	top: 0;
	right: 0;
	text-align: right;
}
.headerBlock .mainImageBlock aside img {
}
.headerBlock .mainImageBlock p.focusArrow {
	width: 100%;
	height: 100%;
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	position: absolute;
	top: 0;
	opacity: 0;
	-webkit-transition: all 300ms linear;
	-moz-transition: all 300ms linear;
	-o-transition: all 300ms linear;
	-ms-transition: all 300ms linear;
	transition: all 300ms linear;
}
.headerBlock .mainImageBlock p.focusArrow a {
	width: 100%;
	height: 100%;
	color: #fff;
	display: block;
}
.headerBlock .mainImageBlock p.focusArrow a img {
	width: 7%;
	height: auto;
	padding-top: 22%;
	-webkit-transition: all 300ms linear;
	-moz-transition: all 300ms linear;
	-o-transition: all 300ms linear;
	-ms-transition: all 300ms linear;
	transition: all 300ms linear;
}
.headerBlock .mainImageBlock:hover p.focusArrow {
	opacity: 1;
}
.headerBlock .mainImageBlock:hover p.colorOrange {
	background-color: rgba( 255, 125, 26, 0.70 );
}
.headerBlock .mainImageBlock:hover p.colorBlue {
	background-color: rgba( 14, 166, 230, 0.70 );
}
.headerBlock .mainImageBlock:hover p.colorPink {
	background-color: rgba( 255, 78, 120, 0.70 );
}
.headerBlock .mainImageBlock p.focusArrow a:hover img {
	width: 9%;
	height: auto;
	padding-top: 20%;
	opacity: 1;
}
.headerBlock .mainSpecTextBlock {
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	flex-direction: column;
	
	color: #000;
	background-color: rgba( 255, 255, 255, 0.60 );
	overflow: hidden;
}
.headerBlock .mainSpecTextBlock h2 {
	font-size: 20px;
	font-size: 2.0rem;
	font-weight: bold;
}
.headerBlock .mainSpecTextBlock p {
	font-size: 16px;
	font-size: 1.6rem;
}
.headerBlock .mainSpecTextBlock p.spec {
	font-size: 11px;
	font-size: 1.1rem;
	padding-bottom: 5px;
	padding-left: 1em;
	text-indent: -1em;
	line-height: 140%;
}
.headerBlock .mainSpecTextBlock p.spec .small {
	font-size: 10px;
	font-size: 1rem;
}
.headerBlock .mainSpecTextBlock p.price {
	margin-bottom: 1em;
}
.headerBlock .mainSpecTextBlock p.price + p.linkBtn {
	margin-top: auto;
}
.headerBlock .mainSpecTextBlock p.linkBtn {
	text-align: center;
	margin-bottom: 1em;
}
.btnOrange a {
	background-color: #ff7d1a;
}
.btnBlue a {
	background-color: #0ea6e6;
}
.btnPink a {
	background-color: #ff6d90;
}
.btnEnd > span {
	background-color: #666;
}
.headerBlock .mainSpecTextBlock p.linkBtn > span,
.headerBlock .mainSpecTextBlock p.linkBtn a {
	display: block;
	color: #fff;
	padding: 10px 0;
	border-radius: 2px;
	vertical-align: middle;
}
.headerBlock .mainSpecTextBlock p.linkBtn a span.linkBtnArrow img {
	width: 20px;
	height: auto;
	padding-left: 5px;
}
/*contents*/
.contents {
	margin: 20px auto;
	overflow: hidden;
	clear: both;
}
.contents .thumb {
	position: relative;
	float: left;
	overflow: hidden;
}
.contents .thumb .image {
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.contents .thumb .image img {
	width: 200%;
	height: 200%;
	margin: -50%;
}
.contents .thumb .imageL img {
	width: 120%;
	height: 120%;
	margin: -10%;
}
.contents .thumb .imageLL img {
	width: 100%;
	height: 100%;
	margin: 0;
}
.contents .thumb p.focusArrow {
	width: 100%;
	height: 100%;
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	position: absolute;
	top: 0;
	opacity: 0;
	-webkit-transition: all 300ms linear;
	-moz-transition: all 300ms linear;
	-o-transition: all 300ms linear;
	-ms-transition: all 300ms linear;
	transition: all 300ms linear;
}
.contents .thumb p.focusArrow a {
	width: 100%;
	height: 100%;
	color: #fff;
	display: block;
}
.contents .thumb p.focusArrow a img {
	width: 26%;
	height: auto;
	padding-top: 37%;
	-webkit-transition: all 300ms linear;
	-moz-transition: all 300ms linear;
	-o-transition: all 300ms linear;
	-ms-transition: all 300ms linear;
	transition: all 300ms linear;
}
.contents .thumb:hover p.focusArrow {
	opacity: 1;
}
.contents .thumb:hover p.colorOrange {
	background-color: rgba( 255, 125, 26, 0.70 );
}
.contents .thumb:hover p.colorBlue {
	background-color: rgba( 14, 166, 230, 0.70 );
}
.contents .thumb:hover p.colorPink {
	background-color: rgba( 255, 78, 120, 0.70 );
}
.contents .thumb p.focusArrow a:hover img {
	width: 32%;
	height: auto;
	padding-top: 34%;
	opacity: 1;
}
.btnBack a {
	margin: 10px auto 20px;
	padding: 1% 0;
	color: #fff;
	font-size: 18px;
	font-size: 1.8rem;
	text-align: center;
	text-decoration: none;
	border-radius: 2px;
	vertical-align: middle;
	display: block;
}
.btnBack a:hover {
	color: #fff;
}
.btnBack a img {
	width: 22px;
	height: auto;
	padding: 0 8px 4px 0;
	vertical-align: middle;
}
.btnBanner a {
	width: 85%;
	max-width: 622px;
	margin: 10px auto 20px;
	padding: 0;
	text-align: center;
	text-decoration: none;
	border-radius: 2px;
	vertical-align: middle;
	display: block;
}
.btnBanner a img {
	width: 94%;
	max-width: 600px;
	height: auto;
	margin: 3%;
	border: 1px solid #fff;
	vertical-align: middle;
}

/*mediaQuery*/
@media screen and (max-width: 500px){
	.dispPc {
		display: none;
	}
	.dispSp {
		display: block;
	}
	.headerBlock {
		width: 90%;
		height: auto;
	}
	.headerBlock .mainImageBlock {
		width: 100%;
		height: 40%;
		clear: both;
	}
	.headerBlock .mainImageBlock h1 img {
		width: 100%;
		height: 100%;
		margin: -20% 0;
	}
	.headerBlock .mainImageBlock h1#mainImageM img {
		width: 100%;
		height: 100%;
		margin: -10% 0 -30%;
	}
	.headerBlock .mainImageBlock h1#mainImageL img {
		width: 100%;
		height: 100%;
		margin: 0 0 -40%;
	}
	.headerBlock .mainImageBlock aside img {
		width: 30%;
		height: auto;
	}
	.headerBlock .mainSpecTextBlock {
		width: 92%;
		height: auto;
		padding: 4%;
		margin: 20px auto 0;
		clear: both;
	}
	.headerBlock .mainSpecTextBlock p.linkBtn {
		position: relative;
		width: 100%;
		margin: 10px 0;
	}
	.headerBlock .mainSpecTextBlock p.copyright {
		position: relative;
	}
	.contents {
		width: 95%;
	}
	.contents .thumb {
		width: 46%;
		height: 46%;
		margin: 0 2% 4%;
	}
	.snsBlock {
		width: 97%;
	}
	.btnBack a {
		width: 85%;
	}
}
@media screen and (min-width: 501px) and (max-width: 800px) {
	.dispPc {
		display: block;
	}
	.dispSp {
		display: none;
	}
	.headerBlock {
		width: 90%;
		height: auto;
	}
	.headerBlock .mainImageBlock {
		width: 100%;
		height: 40%;
		clear: both;
	}
	.headerBlock .mainImageBlock h1 img {
		width: 100%;
		height: 100%;
		margin: -20% 0;
	}
	.headerBlock .mainImageBlock h1#mainImageM img {
		width: 100%;
		height: 100%;
		margin: -10% 0 -30%;
	}
	.headerBlock .mainImageBlock h1#mainImageL img {
		width: 100%;
		height: 100%;
		margin: 0 0 -40%;
	}
	.headerBlock .mainImageBlock aside img {
		width: 40%;
		height: auto;
	}
	.headerBlock .mainSpecTextBlock {
		width: 92%;
		height: auto;
		padding: 4%;
		margin: 20px auto 0;
		clear: both;
	}
	.headerBlock .mainSpecTextBlock p.linkBtn {
		position: relative;
		width: 100%;
		margin: 10px 0;
	}
	.headerBlock .mainSpecTextBlock p.copyright {
		position: relative;
	}
	.contents {
		width: 95%;
	}
	.contents .thumb {
		width: 46%;
		height: 46%;
		margin: 0 2% 4%;
	}
	.snsBlock {
		width: 90%;
	}
	.btnBack a {
		width: 75%;
	}
}
@media screen and (min-width: 801px) and (max-width: 1240px) {
	.dispPc {
		display: block;
	}
	.dispSp {
		display: none;
	}
	.headerBlock {
		width: 90%;
		height: auto;
	}
	.headerBlock .mainImageBlock {
		width: 100%;
		height: 40%;
		clear: both;
	}
	.headerBlock .mainImageBlock h1 img {
		width: 100%;
		height: 100%;
		margin: -20% 0;
	}
	.headerBlock .mainImageBlock h1#mainImageM img {
		width: 100%;
		height: 100%;
		margin: -10% 0 -30%;
	}
	.headerBlock .mainImageBlock h1#mainImageL img {
		width: 100%;
		height: 100%;
		margin: 0 0 -40%;
	}
	.headerBlock .mainImageBlock aside img {
		width: 50%;
		height: auto;
	}
	.headerBlock .mainSpecTextBlock {
		width: 92%;
		height: auto;
		padding: 4%;
		margin: 20px auto 0;
		clear: both;
	}
	.headerBlock .mainSpecTextBlock p.linkBtn {
		position: relative;
		width: 100%;
		margin: 10px 0;
	}
	.headerBlock .mainSpecTextBlock p.copyright {
		position: relative;
	}
	.contents {
		width: 92%;
	}
	.contents .thumb {
		width: 23%;
		height: 23%;
		margin: 0 1% 4%;
	}
	.snsBlock {
		width: 90%;
	}
	.btnBack a {
		width: 65%;
	}
}
@media screen and (min-width: 1241px){
	.dispPc {
		display: block;
	}
	.dispSp {
		display: none;
	}
	a:hover {
		text-decoration: none;
		color: #fc87c6;
	}
	a:hover img {
		-moz-opacity: 0.75;
		opacity: 0.75;
	}
	.headerBlock {
		width: 1220px;
		height: 476px;
	}
	.headerBlock .mainImageBlock {
		width: 972px;
		height: 476px;
		float: right;
	}
	.headerBlock .mainImageBlock h1 img {
		width: 100%;
		height: auto;
		margin-top: -250px;
	}
	.headerBlock .mainImageBlock h1#mainImageM img {
		width: 100%;
		height: auto;
		margin-top: -125px;
	}
	.headerBlock .mainImageBlock h1#mainImageML img {
		width: 100%;
		height: auto;
		margin-top: -200px;
	}
	.headerBlock .mainImageBlock h1#mainImageL img {
		width: 100%;
		height: auto;
		margin-top: -50px;
	}
	.headerBlock .mainImageBlock aside img {
		width: 50%;
		height: auto;
	}
	.headerBlock .mainSpecTextBlock {
		width: 198px;
		padding: 15px;
		/*
		height: 446px;
		*/
		margin: 0 auto;
		float: left;
	}
	/*
	.headerBlock .mainSpecTextBlock p.linkBtn {
		position: absolute;
		bottom: 40px;
		width: 198px;
	}
	.headerBlock .mainSpecTextBlock p.linkBtnLongCP {
		position: absolute;
		bottom: 60px;
		width: 198px;
	}
	.headerBlock .mainSpecTextBlock p.copyright {
		position: absolute;
		bottom: 10px;
	}
	*/
	.contents {
		width: 1240px;
	}
	.contents .thumb {
		width: 228px;
		height: 228px;
		margin: 0 10px 20px;
	}
	.snsBlock {
		width: 1220px;
	}
	.btnBack a {
		width: 65%;
	}
}
/*backBtn*/
#goBack {
	position: fixed;
	bottom: 40px;
	right: 15px;
}
#goBack a {
	background: #750000;
	color: #fff;
	text-decoration: none;
	width: 50px;
	padding: 15px 0;
	text-align: center;
	display: block;
	border-radius: 5px;
}
#goBack a:hover {
	background: #350000;
	text-decoration: none;
	color: #fff;
}
/* SNS */
.snsBlock {
	height: 40px;
	margin: 0 auto;
	padding: 0;
}
.snsBlock .snsTwitter {
	width: 75px;
	height: 20px;
	margin: 4px 0 0;
	padding: 0 4px 0 0;
	float: left;
}
.snsBlock .snsFb {
	height: 20px;
	padding: 0 3px 0 0;
	float: left;
}
.snsBlock .snsLine {
	width: 88px;
	height: 20px;
	margin: 4px 0 0;
	padding: 0;
	float: left;
}