@charset "utf-8";

/* reset browser settings
------------------------------------------------------------------- */
div, p,
h1, h2, h3, h4, h5, h6,
tr, th, td, dl, dt, dd, a {
	margin: 0px;
	padding: 0px;
	font-size: 100%;
	line-height: 1.7;
	word-wrap: break-word;
	overflow-wrap: break-word;
	word-break: normal;
}

form {
	margin: 0px;
	padding: 0px;
}

address, article, aside, figure, figcaption, footer, header, hgroup, hr, legend, menu, nav, section, summary {
	display: block;
}

ul, ol, li {
	list-style-type: none;
	margin: 0px;
	padding: 0px;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	margin: 0;
	padding: 0;
	font-size: 100%;
}

tr {
	vertical-align: top;
}

input {
	font-size: 100%;
	margin: 0;
}

img {
	width: 100%;
	border: 0;
	margin: 0;
	padding: 0;
	vertical-align: top;
}

a {
	color: #444;
	text-decoration: none;
	-webkit-tap-highlight-color: rgba(189, 0, 151, 0.3);
}

@media only screen and (min-width: 737px) {
	a:hover {
		text-decoration: underline;
	}
}

a img {
	border: 0;
}

input, button, textarea, select {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

::-moz-selection {
	color: #fff;
	background: #a30082;
}

::selection {
	color: #fff;
	background: #a30082;
}

::-moz-selection {
	color: #fff;
	background: #a30082;
}

/* BASE STYLE
-------------------------------------------------------------------- */
html, body {
	width: 100%;
}

body {
	font-size: 16px;
	color: #444;
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'HiraKakuProN-W3';
	line-height: 1.7;
	margin: 0;
	padding: 0;
	background-color: #fff;
	-webkit-text-size-adjust: 100%;
}

body #wrapper {
	width: 100%;
	min-width: 980px;
	margin: 0;
	padding: 0;
	overflow: hidden;
}

body #wrapper #container {
	position: relative;
}

@media only screen and (max-width: 736px) {
	body {
		font-size: 15px;
		color: #444;
		line-height: 1.7;
	}

	body #wrapper {
		min-width: 100%;
	}
}

/* HEADER
-------------------------------------------------------------------- */
#header {
	width: 100%;
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	background-color: #a30082;
	position: relative;
	z-index: 10;
}

#header .header-inner {
	height: 90px;
	position: relative;
	-webkit-transition: height 0.5s;
	transition: height 0.5s;
}

#header .header-inner:before {
	display: block;
	content: '';
	width: 100%;
	height: 1px;
	box-shadow: 0px 1px rgba(0, 0, 0, 0.2);
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 12;
}

#header .header-inner:after {
	display: block;
	content: '';
	width: 163px;
	height: 42px;
	margin-left: -81.5px;
	background-image: url(/common/img/bg_header.png);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: 163px 42px;
	position: absolute;
	bottom: -42px;
	left: 50%;
	-webkit-transition: height 0.5s, bottom 0.5s;
	transition: height 0.5s, bottom 0.5s;
	z-index: 13;
}

#header .logo-kalkan {
	width: 116px;
	height: 83px;
	position: absolute;
	top: 25px;
	left: 50%;
	margin: 0 0 0 -58px;
	-webkit-transition: width 0.5s, height 0.5s, top 0.5s, left 0.5s, margin 0.5s;
	transition: width 0.5s, height 0.5s, top 0.5s, left 0.5s, margin 0.5s;
	z-index: 14;
}

#header .logo-kalkan img {
	width: 100%;
}

#header .btn-menu {
	display: none;
}

#header .gnav-wrp .gnav {
	width: 980px;
	margin-left: -490px;
	background-color: #a30082;
	position: absolute;
	top: 0;
	left: 50%;
	z-index: 11;
}

#header .gnav-wrp .gnav {
	*zoom: 1;
}

#header .gnav-wrp .gnav:before, #header .gnav-wrp .gnav:after {
	content: "";
	display: table;
}

#header .gnav-wrp .gnav:after {
	clear: both;
}

#header .gnav-wrp .gnav > li {
	float: left;
}

#header .gnav-wrp .gnav > li > a {
	display: block;
	width: 100%;
	height: 90px;
	color: #fff;
	font-size: 16px;
	text-align: center;
	text-decoration: none;
	padding-top: 54px;
	box-sizing: border-box;
	-webkit-transition: height 0.5s, padding 0.5s;
	transition: height 0.5s, padding 0.5s;
	position: relative;
}

#header .gnav-wrp .gnav > li > a .g-icn {
	display: block;
	width: 40px;
	height: 40px;
	margin-left: -20px;
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 40px 40px;
	-webkit-transform: scale(1, 1);
	transform: scale(1, 1);
	-webkit-transition: transform 0.5s;
	-webkit-transition: -webkit-transform 0.5s;
	transition: -webkit-transform 0.5s;
	transition: transform 0.5s;
	transition: transform 0.5s, -webkit-transform 0.5s;
	position: absolute;
	top: 11px;
	left: 50%;
}

#header .gnav-wrp .gnav > li#g-products {
	width: 132px;
	margin-right: 46px;
}

#header .gnav-wrp .gnav > li#g-products > a .g-icn {
	background-image: url(/common/img/gnav_products.gif);
}

#header .gnav-wrp .gnav > li#g-online {
	width: 135px;
	margin-right: 354px;
}

#header .gnav-wrp .gnav > li#g-online > a .g-icn {
	background-image: url(/common/img/gnav_online.gif);
}

#header .gnav-wrp .gnav > li#g-catguide {
	width: 120px;
	margin-right: 51px;
}

#header .gnav-wrp .gnav > li#g-catguide > a .g-icn {
	background-image: url(/common/img/gnav_catguide.gif);
}

#header .gnav-wrp .gnav > li#g-movie {
	width: 142px;
}

#header .gnav-wrp .gnav > li#g-movie > a .g-icn {
	background-image: url(/common/img/gnav_movie.gif);
}

#header .gnav-wrp .gnav > li .g-sublink {
	display: none;
	width: 100%;
	padding: 30px 100%;
	margin: 0 -100%;
	background-color: #a30082;
	position: absolute;
	top: 90px;
	left: 0;
	-webkit-transition: top 0.5s;
	transition: top 0.5s;
}

#header .gnav-wrp .gnav > li .g-sublink .inner {
	width: 980px;
	margin: 0 auto;
}

#header .gnav-wrp .gnav > li .g-sublink .inner {
	*zoom: 1;
}

#header .gnav-wrp .gnav > li .g-sublink .inner:before, #header .gnav-wrp .gnav > li .g-sublink .inner:after {
	content: "";
	display: table;
}

#header .gnav-wrp .gnav > li .g-sublink .inner:after {
	clear: both;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type {
	width: 478px;
	float: left;
	background-color: #bd0097;
	border-radius: 7px;
	position: relative;
	z-index: 10;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type:nth-of-type(2n) {
	margin-left: 24px;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type .g-sublink-ttl {
	color: #fff;
	font-size: 16px;
	line-height: 50px;
	text-align: center;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul {
	padding: 0 10px 10px;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul {
	*zoom: 1;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul:before, #header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul:after {
	content: "";
	display: table;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul:after {
	clear: both;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li {
	width: 146px;
	text-align: center;
	float: left;
	background-color: #fff;
	border-radius: 7px;
	overflow: hidden;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li:nth-of-type(n+2) {
	margin-left: 10px;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li a {
	display: block;
	color: #720063;
	font-size: 14px;
	font-weight: bold;
	text-decoration: none;
	padding: 13px 13px 13px 13px;
	border: 2px solid #fff;
	border-radius: 7px;
	box-sizing: border-box;
}

#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li a .sub-txt {
	font-size: 12px;
}

/* fixed 固定 */
#header.fixed {
	position: fixed;
	top: 0;
	left: 0;
}

#header.fixed .header-inner {
	height: 60px;
}

#header.fixed .header-inner:after {
	height: 32px;
	bottom: -32px;
}

#header.fixed .logo-kalkan {
	width: 89px;
	height: 64px;
	top: 14px;
	left: 50%;
	margin: 0 0 0 -44.5px;
}

#header.fixed .gnav-wrp .gnav > li > a {
	height: 60px;
	padding-top: 20px;
	box-sizing: border-box;
}

#header.fixed .gnav-wrp .gnav > li > a .g-icn {
	-webkit-transform: scale(0, 0);
	transform: scale(0, 0);
}

#header.fixed .gnav-wrp .gnav > li .g-sublink {
	top: 60px;
}

@media only screen and (min-width: 737px) {
	#header p.logo-kalkan:hover {
		top: 20px;
    /* -5px */;
	}

	#header.fixed p.logo-kalkan:hover {
		top: 11px;
    /* -3px */;
	}

	#header .gnav-wrp .gnav > li > a:hover {
		color: #ffd33b;
	}

	#header .gnav-wrp .gnav > li#g-products > a:hover .g-icn {
		background-image: url(/common/img/gnav_products_over.gif);
	}

	#header .gnav-wrp .gnav > li#g-online > a:hover .g-icn {
		background-image: url(/common/img/gnav_online_over.gif);
	}

	#header .gnav-wrp .gnav > li#g-catguide > a:hover .g-icn {
		background-image: url(/common/img/gnav_catguide_over.gif);
	}

	#header .gnav-wrp .gnav > li#g-movie > a:hover .g-icn {
		background-image: url(/common/img/gnav_movie_over.gif);
	}

	#header .gnav-wrp .gnav > li.active > a {
		color: #ffd33b;
	}

	#header .gnav-wrp .gnav > li.active#g-products > a .g-icn {
		background-image: url(/common/img/gnav_products_on.gif);
	}

	#header .gnav-wrp .gnav > li.active#g-online > a .g-icn {
		background-image: url(/common/img/gnav_online_on.gif);
	}

	#header .gnav-wrp .gnav > li.active#g-catguide > a .g-icn {
		background-image: url(/common/img/gnav_catguide_on.gif);
	}

	#header .gnav-wrp .gnav > li.active#g-movie > a .g-icn {
		background-image: url(/common/img/gnav_movie_on.gif);
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li a:hover {
		border: 2px solid #ffb800;
	}
}

@media only screen and (max-width: 736px) {
	#header .header-inner {
		height: auto;
		position: relative;
	}

	#header .header-inner:before {
		width: 100%;
		height: 60px;
		box-shadow: 0px 1px rgba(0, 0, 0, 0.2);
		background-color: #a30082;
		position: relative;
		z-index: 12;
	}

	#header .header-inner:after {
		width: 100%;
		height: 17px;
		margin-left: 0;
		background-image: url(/common/img/sp/bg_header.png);
		background-repeat: no-repeat;
		background-position: center bottom;
		background-size: 90px 17px;
		position: absolute;
		bottom: -17px;
		left: 0;
		z-index: 13;
	}

	#header .logo-kalkan {
		width: 70px;
		height: 50px;
		position: absolute;
		top: 13px;
		left: 50%;
		margin: 0 0 0 -35px;
		z-index: 14;
	}

	#header .logo-kalkan img {
		width: 100%;
	}

	#header .gnav-wrp .btn-menu {
		display: block;
		position: absolute;
		top: 10px;
		right: 15px;
		z-index: 14;
	}

	#header .gnav-wrp .btn-menu a {
		display: block;
		width: 80px;
		height: 40px;
		text-align: center;
		padding: 14px 10px 15px;
		box-sizing: border-box;
		background-color: #860068;
		border-radius: 20px;
	}

	#header .gnav-wrp .btn-menu a > span {
		display: inline-block;
		font-size: 10px;
		line-height: 11px;
		color: #fff;
		vertical-align: middle;
		padding: 0 18px 0 0;
		background-image: url(/common/img/sp/icn_menu.png);
		background-repeat: no-repeat;
		background-position: right top;
		background-size: 11px 22px;
	}

	#header .gnav-wrp .gnav {
		display: none;
		width: 100%;
		padding: 15px 15px 49px;
		margin: 60px 0 0 0;
		background-color: #fff;
		box-shadow: 0px 2px 1px 0px rgba(0, 0, 0, 0.2);
		box-sizing: border-box;
		position: absolute;
		top: 0;
		left: 0;
		z-index: 11;
	}

	#header .gnav-wrp .gnav > li {
		width: 100%;
		margin: 0;
		float: none;
		background-image: url(/common/img/sp/bdr_g_dash.gif);
		background-repeat: repeat-x;
		background-position: left bottom;
		background-size: 8px 1px;
	}

	#header .gnav-wrp .gnav > li > a {
		display: block;
		width: 100%;
		height: auto;
		color: #000;
		font-size: 17px;
		font-weight: bold;
		text-align: left;
		text-decoration: none;
		padding: 11px 0 11px 24px;
		box-sizing: border-box;
		background-image: url(/common/img/arr_c_p_r.png);
		background-repeat: no-repeat;
		background-position: left center;
		background-size: 15px 15px;
	}

	#header .gnav-wrp .gnav > li#g-products, #header .gnav-wrp .gnav > li#g-online, #header .gnav-wrp .gnav > li#g-catguide, #header .gnav-wrp .gnav > li#g-movie {
		width: 100%;
		margin: 0;
	}

	#header .gnav-wrp .gnav > li#g-products > a, #header .gnav-wrp .gnav > li#g-online > a, #header .gnav-wrp .gnav > li#g-catguide > a, #header .gnav-wrp .gnav > li#g-movie > a {
		background-image: url(/common/img/arr_c_p_r.png);
	}

	#header .gnav-wrp .gnav > li .g-sublink {
		display: block;
		padding: 11px 0 12px 9px;
		margin: 0;
		box-sizing: border-box;
		background-color: inherit;
		background-image: url(/common/img/sp/bdr_g_dash.gif);
		background-repeat: repeat-x;
		background-position: left top;
		background-size: 8px 1px;
		position: static;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner {
		width: 100%;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner {
		*zoom: 1;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner:before, #header .gnav-wrp .gnav > li .g-sublink .inner:after {
		content: "";
		display: table;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner:after {
		clear: both;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner .product-type {
		width: 50%;
		float: left;
		background-color: inherit;
		border-radius: 0;
		position: static;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner .product-type:nth-of-type(2n) {
		margin-left: 0;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul {
		padding: 0;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li {
		width: 100%;
		text-align: left;
		float: none;
		background-color: inherit;
		border-radius: 0;
		padding: 5px 0;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li:nth-of-type(n+2) {
		margin-left: 0;
	}

	#header .gnav-wrp .gnav > li .g-sublink .inner .product-type ul li a {
		display: block;
		color: #444;
		font-size: 14px;
		font-weight: normal;
		text-decoration: none;
		padding: 3px 0 3px 15px;
		border: 0;
		border-radius: 0;
		background-image: url(/common/img/arr_t_p_r.png);
		background-repeat: no-repeat;
		background-position: left center;
		background-size: 6px 8px;
	}

	#header .gnav-wrp .gnav > li.btn-close {
		position: relative;
		background: none;
	}

	#header .gnav-wrp .gnav > li.btn-close > p {
		width: 90px;
		height: 67px;
		margin: 0 0 0 -45px;
		position: absolute;
		left: 50%;
		bottom: -67px;
	}

	#header .gnav-wrp .gnav > li.btn-close > p > a {
		display: block;
		width: 100%;
		height: 100%;
		color: #444;
		font-size: 14px;
		text-align: center;
		font-weight: normal;
		text-decoration: none;
		padding: 12px 0 0;
		box-sizing: border-box;
		background-image: url(/common/img/sp/btn_gnav_close.png);
		background-repeat: no-repeat;
		background-position: center bottom;
		background-size: 90px 28px;
	}

	#header.open .gnav-wrp .btn-menu a > span {
		background-position: right bottom;
	}
}

/* # CONTENTS
----------------------------------- */
#contents {
	width: 100%;
}

#contents .pc-br:after {
	content: '\A';
	white-space: pre;
}

#contents .sp-br:after {
	content: '';
}

.cts-wrp {
	width: 100%;
}

.cts-wrp .cts-inner {
	width: 980px;
	margin: 0 auto;
	position: relative;
}

.ff-0001 {
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
}

.txt-col {
	color: #a30082;
}

img.img-radius {
	border-radius: 20px;
}

.cfx:after {
	display: block;
	content: '';
	clear: both;
}

@media only screen and (min-width: 737px) {
	.pc-none {
		display: none !important;
	}
}

@media only screen and (max-width: 736px) {
	#contents .pc-br:after {
		content: '';
	}

	#contents .sp-br:after {
		content: '\A';
		white-space: pre;
	}

	.sp-none {
		display: none !important;
	}

	.cts-wrp {
		width: 100%;
	}

	.cts-wrp .cts-inner {
		width: 100%;
		padding: 0 15px;
		margin: 0 auto;
		box-sizing: border-box;
	}

	img.img-radius {
		border-radius: 10px;
	}
}

/* 背景パターン */
.bg-pattern-p {
	background-color: #a30082;
	background-image: url(/common/img/bg_pattern_p.png);
	background-repeat: repeat;
	background-position: center top;
	background-size: 12px 12px;
}

.bg-pattern-y {
	background-color: #fff5c9;
	background-image: url(/common/img/bg_pattern_y.png);
	background-repeat: repeat;
	background-position: center top;
	background-size: 12px 12px;
}

@media only screen and (max-width: 736px) {
	.bg-pattern-p {
		background-image: url(/common/img/sp/bg_pattern_p.png);
		background-repeat: repeat;
		background-position: center top;
		background-size: 12px 12px;
	}

	.bg-pattern-y {
		background-image: url(/common/img/sp/bg_pattern_y.png);
		background-repeat: repeat;
		background-position: center top;
		background-size: 12px 12px;
	}
}

/* 波境界 */
.bg-wave-t {
	padding-top: 38px;
	margin-top: -36px;
	background-image: url(/common/img/bg_wave_t.png);
	background-repeat: repeat-x;
	background-position: center -2px;
	background-size: 764px 42px;
	position: relative;
	z-index: 2;
}

/* Yellow */
.bg-wave-t.bg-y {
	background-image: url(/common/img/bg_wave_y_t.png);
}

.bg-wave-b {
	padding-bottom: 38px;
	margin-bottom: -36px;
	background-image: url(/common/img/bg_wave_b.png);
	background-repeat: repeat-x;
	background-position: center bottom;
	background-size: 764px 40px;
	position: relative;
	z-index: 2;
}

/* Yellow */
.bg-wave-b.bg-y {
	background-image: url(/common/img/bg_wave_y_b.png);
}

/* Gray */
.bg-wave-b.bg-g {
	background-image: url(/common/img/bg_wave_g_b.png);
}

@media only screen and (max-width: 736px) {
	.bg-wave-t {
		padding-top: 15px;
		margin-top: -15px;
		background-image: url(/common/img/sp/bg_wave_t.png);
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% 15px;
	}

	/* Yellow */
	.bg-wave-t.bg-y {
		background-image: url(/common/img/sp/bg_wave_y_t.png);
	}

	.bg-wave-b {
		padding-bottom: 15px;
		margin-bottom: -15px;
		background-image: url(/common/img/sp/bg_wave_b.png);
		background-repeat: no-repeat;
		background-position: center bottom;
		background-size: 100% 15px;
	}

	/* Yellow */
	.bg-wave-b.bg-y {
		background-image: url(/common/img/sp/bg_wave_y_b.png);
	}

	/* Gray */
	.bg-wave-b.bg-g {
		background-image: url(/common/img/sp/bg_wave_g_b.png);
	}
}

/* # WIDE MAINVISUAL
----------------------------------- */
.wide-mainvisual {
	padding-bottom: 40px;
	background-image: url(/common/img/bg_wave_wide_b.png);
	position: relative;
	z-index: 5;
}

.wide-mainvisual .cts-inner {
	width: 100%;
	background-color: #f8f2f4;
}

.wide-mainvisual .cts-inner:before {
	display: block;
	content: '';
	width: 2290px;
	height: 300px;
	margin-left: -1145px;
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 2290px 300px;
	position: absolute;
	top: 0;
	left: 50%;
	z-index: 1;
}

.wide-mainvisual .cts-inner .mod-ttl-page, .wide-mainvisual .cts-inner .mod-lead-page {
	position: relative;
	z-index: 2;
}

@media only screen and (max-width: 736px) {
	.wide-mainvisual {
		padding-bottom: 15px;
		background-image: none;
	}

	.wide-mainvisual .cts-inner:before {
		width: 100%;
		height: 0;
		padding-top: 60%;
		margin-left: 0;
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 100% auto;
		top: 0;
		left: 0;
	}
}

/* # JS STYLE
----------------------------------- */
.js-iframe {
	text-align: center;
}

.icn-play {
	position: relative;
}

.icn-play:before {
	display: block;
	content: '';
	width: 68px;
	height: 48px;
	margin: -24px 0 0 -34px;
	background-image: url(/common/img/icn_play.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 68px 48px;
	position: absolute;
	top: 50%;
	left: 50%;
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: alpha(opacity=80);
	z-index: 1;
	-webkit-transition: opacity 0.2s;
	transition: opacity 0.2s;
	cursor: pointer;
}

.icn-play:after {
	display: block;
	content: '';
	width: 68px;
	height: 48px;
	margin: -24px 0 0 -34px;
	background-image: url(/common/img/icn_play_r.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 68px 48px;
	position: absolute;
	top: 50%;
	left: 50%;
	opacity: 0;
	filter: alpha(opacity=0);
	-ms-filter: alpha(opacity=0);
	z-index: 2;
	-webkit-transition: opacity 0.2s;
	transition: opacity 0.2s;
	cursor: pointer;
}

@media only screen and (min-width: 737px) {
	.icn-play:hover:before {
		opacity: 0;
		filter: alpha(opacity=0);
		-ms-filter: alpha(opacity=0);
	}

	.icn-play:hover:after {
		opacity: 1;
		filter: alpha(opacity=100);
		-ms-filter: alpha(opacity=100);
	}
}

@media only screen and (max-width: 736px) {
	.js-iframe {
		text-align: center;
	}

	.icn-play {
		position: relative;
	}

	.icn-play:before {
		display: block;
		content: '';
		width: 71px;
		height: 50px;
		margin: -25px 0 0 -35.5px;
		background-image: url(/common/img/icn_play_r.png);
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 71px 50px;
		position: absolute;
		top: 50%;
		left: 50%;
	}
}

/* BANNER AREA
-------------------------------------------------------------------- */
.bnrarea {
	padding: 60px 0 60px;
}

.bnrarea .inner {
	width: 980px;
	margin: 0 auto;
}

.bnrarea .inner {
	*zoom: 1;
}

.bnrarea .inner:before, .bnrarea .inner:after {
	content: "";
	display: table;
}

.bnrarea .inner:after {
	clear: both;
}

.bnrarea .inner .bnr {
	width: 313px;
	float: left;
	margin: 0 0 20px 0;
}

.bnrarea .inner .bnr:nth-of-type(3n+2) {
	margin-left: 20px;
}

.bnrarea .inner .bnr:nth-of-type(3n) {
	margin-left: 20px;
}

.bnrarea .inner .bnr img {
	width: 100%;
	border-radius: 20px;
}

@media only screen and (min-width: 737px) {
	.bnrarea .bnr a:hover {
		opacity: 0.7;
		filter: alpha(opacity=70);
		-ms-filter: alpha(opacity=70);
	}
}

@media only screen and (max-width: 736px) {
	.bnrarea {
		padding: 40px 0;
	}

	.bnrarea .inner {
		width: 100%;
		padding: 0 15px;
		box-sizing: border-box;
	}

	.bnrarea .inner .bnr {
		width: 100%;
		float: none;
		margin: 0 0 20px 0;
	}

	.bnrarea .inner .bnr:nth-of-type(3n+2) {
		margin-left: 0;
	}

	.bnrarea .inner .bnr:nth-of-type(3n) {
		margin-left: 0;
	}
}

/* PAGE TOP
-------------------------------------------------------------------- */
.pagetop {
	width: 50px;
	height: 50px;
	background-color: #fff;
	border-radius: 25px;
	position: absolute;
	bottom: 109px;
	right: 40px;
	opacity: 0;
	z-index: 10;
}

.pagetop.fixed {
	position: fixed;
	bottom: 50px;
}

.pagetop img {
	width: 100%;
}

@media only screen and (min-width: 737px) {
	.pagetop a:hover {
		opacity: 0.7;
		filter: alpha(opacity=70);
		-ms-filter: alpha(opacity=70);
	}
}

@media only screen and (max-width: 736px) {
	.pagetop {
		width: 100%;
		height: auto;
		padding: 0 15px;
		box-sizing: border-box;
		background-color: inherit;
		border-radius: 0;
		position: static;
		text-align: right;
		opacity: 1;
	}

	.pagetop a {
		display: inline-block;
		width: 45px;
		height: 45px;
		line-height: 1;
		padding: 0 1px 10px 0;
		position: relative;
	}

	.pagetop a:after {
		display: block;
		content: '';
		width: 62px;
		height: 45px;
		background-image: url(/common/img/sp/img_cat.png);
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 62px 45px;
		position: absolute;
		top: 0;
		right: 41px;
	}
}

/* BREADCRUMB
-------------------------------------------------------------------- */
.breadcrumb {
	width: 100%;
	border-top: 1px solid #d2d2d2;
}

.breadcrumb ul {
	width: 980px;
	font-size: 14px;
	margin: 8px auto;
	letter-spacing: -0.4em;
}

.breadcrumb ul li {
	display: inline-block;
	letter-spacing: 0;
	margin-left: 15px;
}

.breadcrumb ul li:before {
	display: inline-block;
	content: '>';
	font-size: 14px;
	color: #999;
	line-height: 1;
	vertical-align: middle;
	padding-bottom: 3px;
	margin-right: 15px;
}

.breadcrumb ul li:first-of-type {
	margin-left: 0;
}

.breadcrumb ul li a {
	color: #444;
	vertical-align: middle;
	text-decoration: none;
}

.breadcrumb ul li.home {
	padding-left: 20px;
	background-image: url(/common/img/icn_home.png);
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 12px 12px;
}

.breadcrumb ul li.home:before {
	display: none;
	content: '';
}

.breadcrumb ul li.active {
	color: #999;
}

@media only screen and (min-width: 737px) {
	.breadcrumb ul li a:hover {
		text-decoration: underline;
	}
}

@media only screen and (max-width: 736px) {
	.breadcrumb ul {
		width: 100%;
		font-size: 14px;
		padding: 0 15px;
		margin: 15px 0;
		box-sizing: border-box;
	}

	.breadcrumb ul li {
		display: inline-block;
		margin-left: 7px;
	}

	.breadcrumb ul li:before {
		font-size: 12px;
		padding-bottom: 4px;
		margin-right: 7px;
	}

	.breadcrumb ul li:first-of-type {
		margin-left: 0;
	}

	.breadcrumb ul li.home {
		padding-left: 20px;
	}
}

/* FOOTER
-------------------------------------------------------------------- */
#footer {
	width: 100%;
	background-color: #f5f5f5;
}

#footer .footer-inner {
	width: 980px;
	margin: 0 auto;
	position: relative;
}

#footer .footer-inner a {
	color: #444;
	text-decoration: none;
}

#footer .footer-cts {
	padding: 12px 0 18px;
	background-image: url(/common/img/bdr_g_dash.gif);
	background-repeat: repeat-x;
	background-position: left bottom;
	background-size: 8px 1px;
}

#footer .footer-cts .link {
	*zoom: 1;
}

#footer .footer-cts .link:before, #footer .footer-cts .link:after {
	content: "";
	display: table;
}

#footer .footer-cts .link:after {
	clear: both;
}

#footer .footer-cts .link > li {
	width: 252px;
	float: left;
	margin-left: 20px;
}

#footer .footer-cts .link > li:first-of-type {
	width: 436px;
	margin-left: 0;
}

#footer .footer-cts .link > li > p {
	padding: 17px 0 12px;
}

#footer .footer-cts .link > li > p > a {
	display: inline-block;
	font-size: 18px;
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	padding-left: 20px;
	background-image: url(/common/img/arr_c_p_r.png);
	background-repeat: no-repeat;
	background-position: left 7.5px;
	background-size: 15px 15px;
}

#footer .footer-cts .link > li.last > p {
	background: none;
}

#footer .footer-cts .link > li .sublink {
	padding: 3px 0 0 9px;
}

#footer .footer-cts .link > li .sublink {
	*zoom: 1;
}

#footer .footer-cts .link > li .sublink:before, #footer .footer-cts .link > li .sublink:after {
	content: "";
	display: table;
}

#footer .footer-cts .link > li .sublink:after {
	clear: both;
}

#footer .footer-cts .link > li .sublink .product-type {
	width: 50%;
	float: left;
}

#footer .footer-cts .link > li .sublink li {
	padding: 5px 0;
}

#footer .footer-cts .link > li .sublink li > a {
	display: inline-block;
	padding-left: 10px;
	background-image: url(/common/img/arr_t_p_r.png);
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 6px 8px;
}

#footer .footer-site {
	background-image: url(/common/img/bdr_g_dash.gif);
	background-repeat: repeat-x;
	background-position: left bottom;
	background-size: 8px 1px;
}

#footer .footer-site .link {
	font-size: 0;
	line-height: 0;
	text-align: center;
}

#footer .footer-site .link > li {
	display: inline-block;
	font-size: 16px;
	line-height: 1.7;
}

#footer .footer-site .link > li > a {
	display: inline-block;
	padding: 15px 0 14px;
}

#footer .footer-site .link > li > a > span {
	display: inline-block;
	padding: 0 18px;
	border-right: 1px solid #707070;
}

#footer .footer-site .link > li.last > a > span {
	border: none;
}

#footer .footer-contact {
	text-align: right;
	overflow: hidden;
}

#footer .footer-contact .box-contact {
	float:left;
	width: 61.73469387755102%;
	font-weight: bold;
	line-height: 24px;
	padding: 20px 0 27px;
}

#footer .footer-contact .box-contact .tel {
	display: inline-block;
	color: #a30082;
	font-size: 24px;
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	line-height: 1;
	padding: 0 0 0 43px;
	background-image: url(/common/img/icn_tel.png);
	background-repeat: no-repeat;
	background-position: 14px center;
	background-size: 22px 22px;
	vertical-align: top;
}

#footer .footer-contact .box-contact .time {
	display: block;
	font-size: 12px;
	font-weight: normal;
	vertical-align: top;
	text-align: right;
	padding-right: 5px;
}

#footer .footer-contact .box-contact-btn {
	float:left;
	width: 20.40816326530612%;
	font-weight: bold;
	border:1px solid #d2d2d2;
	border-radius:20px;
	box-sizing: border-box;
	text-align:center;
	margin: 20px 0 0 27px;
}
#footer .footer-contact .box-contact-btn a {
	display:block;
	background:url(/common/img/icn_blank.png) 95% center no-repeat;
	background-size:11px 11px;
	padding: 8px 0px;
	font-size:14px;	
}
#footer .footer-contact .box-contact-btn a:hover {
	opacity: 0.7;
	text-decoration:none;
}
#footer .footer-logo {
	color: #fff;
	font-size: 11px;
	padding: 28px 0 0 0;
	background-image: url(/common/img/bg_footerlogo_t.png);
	background-repeat: repeat-x;
	background-position: center top;
	background-size: 764px 30px;
}

#footer .footer-logo .bg-wide {
	background-color: #a30082;
}

#footer .footer-logo .logo_mars {
	width: 140px;
	height: 27px;
	position: absolute;
	top: -10px;
	left: 50%;
	margin: 0 0 0 -70px;
}

#footer .footer-logo .logo_mars img {
	width: 100%;
}

#footer .footer-logo .note {
	padding: 37px 0 18px;
}

#footer .footer-logo .copyright {
	position: absolute;
	bottom: 18px;
	right: 0;
}

@media only screen and (min-width: 737px) {
	#footer .footer-inner a:hover {
		text-decoration: underline;
	}

	#footer .footer-inner a > span:hover {
		text-decoration: underline;
	}
}

@media only screen and (max-width: 736px) {
	#footer .footer-inner {
		width: 100%;
		padding: 0 15px;
		box-sizing: border-box;
	}

	#footer .footer-cts {
		padding: 0;
		background-image: url(/common/img/sp/bdr_g_dash.gif);
		background-repeat: repeat-x;
		background-position: left bottom;
		background-size: 8px 1px;
	}

	#footer .footer-cts .link > li {
		width: 100%;
		float: none;
		margin-left: 0;
	}

	#footer .footer-cts .link > li:first-of-type {
		width: 100%;
	}

	#footer .footer-cts .link > li > p {
		padding: 0;
		background-image: url(/common/img/sp/bdr_g_dash.gif);
		background-repeat: repeat-x;
		background-position: left bottom;
		background-size: 8px 1px;
	}

	#footer .footer-cts .link > li > p > a {
		display: block;
		font-size: 18px;
		font-weight: bold;
		padding: 14px 0 13px 20px;
		background-image: url(/common/img/arr_c_p_r.png);
		background-repeat: no-repeat;
		background-position: left center;
		background-size: 15px 15px;
	}

	#footer .footer-cts .link > li.last > p {
		background: none;
	}

	#footer .footer-cts .link > li .sublink {
		padding: 10px 0 10px 9px;
		background-image: url(/common/img/sp/bdr_g_dash.gif);
		background-repeat: repeat-x;
		background-position: left bottom;
		background-size: 8px 1px;
	}

	#footer .footer-cts .link > li .sublink {
		*zoom: 1;
	}

	#footer .footer-cts .link > li .sublink:before, #footer .footer-cts .link > li .sublink:after {
		content: "";
		display: table;
	}

	#footer .footer-cts .link > li .sublink:after {
		clear: both;
	}

	#footer .footer-cts .link > li .sublink .product-type {
		width: 50%;
		float: left;
	}

	#footer .footer-cts .link > li .sublink li {
		padding: 10px 0;
	}

	#footer .footer-cts .link > li .sublink li > a {
		display: block;
		padding-left: 10px;
		background-image: url(/common/img/arr_t_p_r.png);
		background-repeat: no-repeat;
		background-position: left center;
		background-size: 6px 8px;
	}

	#footer .footer-site {
		background-image: url(/common/img/sp/bdr_g_dash.gif);
		background-repeat: repeat-x;
		background-position: left bottom;
		background-size: 8px 1px;
	}

	#footer .footer-site .link {
		text-align: left;
		padding: 10px 7px;
		box-sizing: border-box;
	}

	#footer .footer-site .link > li {
		font-size: 15px;
	}

	#footer .footer-site .link > li > a {
		display: block;
		line-height: 1;
		padding: 8px 0 7px;
	}

	#footer .footer-site .link > li > a > span {
		display: inline-block;
		padding: 0 7px;
		border-right: 1px solid #707070;
	}

	#footer .footer-site .link > li.last > a > span {
		border: none;
	}

	#footer .footer-contact {
		text-align: center;
	}

	#footer .footer-contact .box-contact {
		width: 100%;
		font-weight: bold;
		line-height: 1;
		padding: 20px 0 18px;
		position: relative;
	}

	#footer .footer-contact .box-contact-btn {
		width: 100%;
		margin: 0 0 20px;
		padding:0 10%;
		border:none;
	}
	#footer .footer-contact .box-contact-btn a {
		border:1px solid #d2d2d2;
		border-radius:20px;
		background-color: #fff;
	}

	#footer .footer-contact .box-contact .tel {
		display: block;
		width: 214px;
		font-size: 25px;
		text-align: left;
		line-height: 1;
		padding: 16px 0 21px 55px;
		margin: 0 auto;
		background-image: url(/common/img/icn_tel.png);
		background-repeat: no-repeat;
		background-position: left 16px;
		background-size: 45px 45px;
		vertical-align: top;
	}

	#footer .footer-contact .box-contact .time {
		display: block;
		font-size: 12px;
		font-weight: normal;
		vertical-align: top;
		position: absolute;
		bottom: 18px;
		left: 50%;
		margin-left: -80px;
	}

	#footer .footer-logo {
		font-size: 10px;
		text-align: center;
		padding: 15px 0 0 0;
		background-image: url(/common/img/sp/bg_footerlogo_t.png);
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% 15px;
	}

	#footer .footer-logo .bg-wide {
		background-color: #a30082;
	}

	#footer .footer-logo .logo_mars {
		width: 130px;
		height: 25px;
		position: static;
		margin: 0 auto;
		padding: 8px 0 0;
	}

	#footer .footer-logo .logo_mars img {
		width: 100%;
	}

	#footer .footer-logo .note {
		padding: 18px 0 7px;
	}

	#footer .footer-logo .copyright {
		position: static;
		padding: 0 0 28px;
	}
}

/* # MODULES
----------------------------------- */
/* Link Button */
.mod-txtlink {
	display: inline-block;
	color: #a30082;
	text-decoration: none;
	padding: 0 0 0 13px;
	background-image: url(/common/img/arr_t_p_r.png);
	background-repeat: no-repeat;
	background-position: left 9.5px;
	background-size: 6px 8px;
}

@media only screen and (min-width: 737px) {
	.mod-txtlink:hover {
		text-decoration: underline;
	}
}

@media only screen and (max-width: 736px) {
	.mod-txtlink {
		background-position: left 8.8px;
	}
}

.mod-btn-radius {
	display: table;
	width: 100%;
	height: 50px;
	min-height: 50px;
	color: #fff;
	font-size: 16px;
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	line-height: 1.3;
	text-align: center;
	text-decoration: none;
	border-radius: 25px;
	padding: 0 10px;
	margin: 0 auto;
	box-sizing: border-box;
	background-color: #a30082;
}

.mod-btn-radius > span {
	display: table-cell;
	vertical-align: middle;
	padding: 0 10px;
	background-image: url(/common/img/arr_w_r.png);
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 8px 14px;
}

.mod-btn-radius.bg-y {
	color: #a30082;
	background-color: #ffd33b;
}

.mod-btn-radius.bg-y > span {
	background-image: url(/common/img/arr_p_r.png);
}

.mod-btn-radius.w-auto {
	width: auto;
}

@media only screen and (min-width: 737px) {
	.mod-btn-radius:hover {
		text-decoration: none;
		background-color: #bd0097;
	}

	.mod-btn-radius.bg-y:hover {
		text-decoration: none;
		background-color: #ffe178;
	}
}

@media only screen and (max-width: 736px) {
	.mod-btn-radius {
		display: table;
		width: 100%;
		height: 50px;
		min-height: 50px;
		color: #fff;
		font-size: 15px;
		text-decoration: none;
		border-radius: 25px;
		padding: 0 10px;
		box-sizing: border-box;
		background-color: #a30082;
		-webkit-tap-highlight-color: rgba(189, 0, 151, 0.3);
	}

	.mod-btn-radius > span {
		display: table-cell;
		vertical-align: middle;
		padding: 0 10px;
		background-image: url(/common/img/arr_w_r.png);
		background-repeat: no-repeat;
		background-position: right center;
		background-size: 8px 14px;
	}

	.mod-btn-radius.w-auto {
		width: auto;
	}

	.mod-btn-radius.bg-y {
		-webkit-tap-highlight-color: rgba(255, 255, 120, 0.3);
	}
}

.mod-btn-pagelink {
	display: table;
	width: 100%;
	height: 80px;
	font-size: 18px;
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	color: #fff;
	line-height: 1.5;
	text-align: center;
	text-decoration: none;
	padding: 0 20px;
	box-sizing: border-box;
	background-color: #a30082;
	border-radius: 20px;
}

.mod-btn-pagelink > span {
	display: table-cell;
	vertical-align: middle;
	background-image: url(/common/img/arr_w_d.png);
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 12px 7px;
}

.mod-btn-pagelink > span .sub-txt {
	font-size: 14px;
}

@media only screen and (min-width: 737px) {
	.mod-btn-pagelink:hover {
		text-decoration: none;
		background-color: #bd0097;
	}
}

@media only screen and (max-width: 736px) {
	.mod-btn-pagelink {
		width: 100%;
		height: 70px;
		font-size: 16px;
		line-height: 1.5;
		text-align: center;
		padding: 0 15px;
		border-radius: 15px;
	}

	.mod-btn-pagelink > span {
		background-size: 15px 8px;
	}

	.mod-btn-pagelink > span .sub-txt {
		font-size: 12px;
	}
}

.mod-link-block {
	display: block;
	width: 100%;
	height: 100%;
	text-align: center;
	box-sizing: border-box;
	background-color: #fff;
	border: 1px solid #e5e5e5;
	border-radius: 20px;
	overflow: hidden;
}

@media only screen and (min-width: 737px) {
	.mod-link-block:hover {
		text-decoration: none;
	}

	.mod-link-block:hover img {
		opacity: 0.7;
		filter: alpha(opacity=70);
		-ms-filter: alpha(opacity=70);
	}
}

@media only screen and (max-width: 736px) {
	.mod-link-block {
		width: 100%;
		box-sizing: border-box;
		border-radius: 15px;
	}
}

.mod-link-block.icn-blank {
	position: relative;
}

.mod-link-block.icn-blank:after {
	display: block;
	content: '';
	width: 11px;
	height: 11px;
	background-image: url(/common/img/icn_blank.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 11px 11px;
	position: absolute;
	bottom: 9px;
	right: 9px;
}

/* Title */
.mod-ttl-page {
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	font-size: 50px;
	color: #a30082;
	line-height: 1.3;
	text-align: center;
	text-shadow: 3px 3px 4px #fff, -3px 3px 4px #fff, 3px -3px 4px #fff, -3px -3px 4px #fff;
	padding: 90px 0 15px;
}

.mod-ttl-page.col-w {
	color: #fff;
}

@media only screen and (max-width: 736px) {
	.mod-ttl-page {
		font-size: 32px;
		line-height: 1.3;
		text-shadow: 3px 3px 4px #fff, -3px 3px 4px #fff, 3px -3px 4px #fff, -3px -3px 4px #fff;
		padding: 10px 0 10px;
	}
}

.mod-lead-page {
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	font-size: 20px;
	color: #a30082;
	line-height: 1.3;
	text-align: center;
	text-shadow: 1px 1px 2px #fff, -1px 1px 2px #fff, 1px -1px 2px #fff, -1px -1px 2px #fff;
	padding: 0 0 64px;
}

.mod-lead-page.col-w {
	color: #fff;
}

@media only screen and (max-width: 736px) {
	.mod-lead-page {
		font-size: 16px;
		line-height: 1.3;
		text-shadow: 1px 1px 2px #fff, -1px 1px 2px #fff, 1px -1px 2px #fff, -1px -1px 2px #fff;
		padding: 0;
	}
}

.mod-ttl-cts {
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	font-size: 40px;
	color: #a30082;
	line-height: 1.3;
	text-align: center;
	padding: 6px 0 10px;
}

.mod-ttl-cts.col-w {
	color: #fff;
}

.mod-ttl-cts .sub-txt {
	font-size: 24px;
}

@media only screen and (max-width: 736px) {
	.mod-ttl-cts {
		font-size: 28px;
		line-height: 1.5;
		padding: 17px 0 17px;
	}

	.mod-ttl-cts .sub-txt {
		font-size: 18px;
	}
}

.mod-ttl-sub {
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	font-size: 26px;
	line-height: 1.5;
	text-align: center;
	margin: 0 0 20px;
	position: relative;
}

.mod-ttl-sub.col-w {
	color: #fff;
}

.mod-ttl-sub:after {
	display: block;
	content: '';
	width: 29px;
	height: 20px;
	margin: 0 0 0 -14.5px;
	background-color: #fff;
	background-image: url(/common/img/bg_subttl_b.png);
	background-repeat: no-repeat;
	background-position: left -2px;
	background-size: 29px 22px;
	position: absolute;
	bottom: -14px;
	left: 50%;
}

.mod-ttl-sub .line-b {
	display: inline-block;
	padding: 10px 0 20px 0;
	background-image: url(/common/img/bg_subttl.png);
	background-repeat: repeat-x;
	background-position: center bottom;
	background-size: 1px 6px;
	position: relative;
}

.mod-ttl-sub .line-b:before {
	display: block;
	content: '';
	width: 20px;
	height: 20px;
	background-color: #fff;
	background-image: url(/common/img/bg_subttl_l.png);
	background-repeat: no-repeat;
	background-position: left -2px;
	background-size: 20px 22px;
	position: absolute;
	bottom: 0;
	left: -15px;
}

.mod-ttl-sub .line-b:after {
	display: block;
	content: '';
	width: 20px;
	height: 20px;
	background-color: #fff;
	background-image: url(/common/img/bg_subttl_r.png);
	background-repeat: no-repeat;
	background-position: left -2px;
	background-size: 20px 22px;
	position: absolute;
	bottom: 0;
	right: -15px;
}

.mod-ttl-sub.bg-y:after {
	background-image: url(/common/img/bg_subttl_y_b.png);
}

.mod-ttl-sub.bg-y .line-b:before {
	background-image: url(/common/img/bg_subttl_y_l.png);
}

.mod-ttl-sub.bg-y .line-b:after {
	background-image: url(/common/img/bg_subttl_y_r.png);
}

@media only screen and (max-width: 736px) {
	.mod-ttl-sub {
		font-size: 22px;
		line-height: 1.5;
		position: relative;
	}

	.mod-ttl-sub:after {
		display: block;
		content: '';
		width: 28px;
		height: 20px;
		margin: 0 0 0 -14px;
		background-color: #fff;
		background-image: url(/common/img/sp/bg_subttl_b.png);
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 28px 20px;
		position: absolute;
		bottom: -14px;
		left: 50%;
	}

	.mod-ttl-sub .line-b {
		display: inline-block;
		padding: 0 0 22px;
		margin: 0 15px;
		background-image: url(/common/img/sp/bg_subttl.png);
		background-repeat: repeat-x;
		background-position: center bottom;
		background-size: 1px 6px;
		position: relative;
	}

	.mod-ttl-sub .line-b:before {
		display: block;
		content: '';
		width: 20px;
		height: 20px;
		background-color: #fff;
		background-image: url(/common/img/sp/bg_subttl_l.png);
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 20px 20px;
		position: absolute;
		bottom: 0;
		left: -15px;
	}

	.mod-ttl-sub .line-b:after {
		display: block;
		content: '';
		width: 20px;
		height: 20px;
		background-color: #fff;
		background-image: url(/common/img/sp/bg_subttl_r.png);
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 20px 20px;
		position: absolute;
		bottom: 0;
		right: -15px;
	}

	.mod-ttl-sub.bg-y:after {
		background-image: url(/common/img/sp/bg_subttl_y_b.png);
	}

	.mod-ttl-sub.bg-y .line-b:before {
		background-image: url(/common/img/sp/bg_subttl_y_l.png);
	}

	.mod-ttl-sub.bg-y .line-b:after {
		background-image: url(/common/img/sp/bg_subttl_y_r.png);
	}
}

.mod-ttl-index {
	font-family: 'FP-ヒラギノUD丸ゴ StdN W6';
	letter-spacing: 0.17em;
	color: #a30082;
	font-size: 22px;
	line-height: 1.5;
	text-align: center;
	padding: 25px 0 15px;
}

.mod-ttl-index.col-w {
	color: #fff;
}

@media only screen and (max-width: 736px) {
	.mod-ttl-index {
		font-size: 20px;
		line-height: 1.5;
		padding: 45px 0 15px;
	}
}

/* Slider Style */
.slider {
	position: relative;
}

.slider .slick-slide:focus {
	outline: none;
}

.slider .slick-slide a:focus {
	outline: none;
}

.slider button.slick-arrow {
	display: block;
	width: 50px;
	height: 50px;
	text-indent: -10000000px;
	margin-top: -25px;
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 50px 100px;
	position: absolute;
	top: 50%;
	z-index: 5;
	cursor: pointer;
}

.slider button.slick-arrow.slick-prev.slick-disabled {
	background-image: url(/common/img/btn_slider_disabled_l.png) !important;
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 50px 50px;
	cursor: default;
}

.slider button.slick-arrow.slick-next {
	background-image: url(/common/img/btn_slider_p_r.png);
	right: 0px;
}

.slider button.slick-arrow.slick-next.slick-disabled {
	background-image: url(/common/img/btn_slider_disabled_r.png) !important;
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 50px 50px;
	cursor: default;
}

@media only screen and (min-width: 737px) {
	.slider button.slick-arrow:hover {
		background-position: left bottom;
	}
}

@media only screen and (max-width: 736px) {
	.slider button.slick-arrow {
		width: 25px;
		height: 50px;
		margin-top: -25px;
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 25px 50px;
	}

	.slider button.slick-arrow.slick-prev.slick-disabled {
		background-image: url(/common/img/sp/btn_slider_disabled_l.png) !important;
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 25px 50px;
	}

	.slider button.slick-arrow.slick-next.slick-disabled {
		background-image: url(/common/img/sp/btn_slider_disabled_r.png) !important;
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 25px 50px;
	}
}

.slider.slider-btn-p button.slick-arrow.slick-prev {
	background-image: url(/common/img/btn_slider_p_l.png);
	left: 0px;
}

.slider.slider-btn-p button.slick-arrow.slick-next {
	background-image: url(/common/img/btn_slider_p_r.png);
	right: 0px;
}

@media only screen and (max-width: 736px) {
	.slider.slider-btn-p button.slick-arrow.slick-prev {
		background-image: url(/common/img/sp/btn_slider_p_l.png);
		left: -15px;
	}

	.slider.slider-btn-p button.slick-arrow.slick-next {
		background-image: url(/common/img/sp/btn_slider_p_r.png);
		right: -15px;
	}
}

.slider.slider-btn-y button.slick-arrow.slick-prev {
	background-image: url(/common/img/btn_slider_y_l.png);
	left: 0px;
}

.slider.slider-btn-y button.slick-arrow.slick-next {
	background-image: url(/common/img/btn_slider_y_r.png);
	right: 0px;
}

@media only screen and (max-width: 736px) {
	.slider.slider-btn-y button.slick-arrow.slick-prev {
		background-image: url(/common/img/sp/btn_slider_y_l.png);
		left: -15px;
	}

	.slider.slider-btn-y button.slick-arrow.slick-next {
		background-image: url(/common/img/sp/btn_slider_y_r.png);
		right: -15px;
	}
}

/* Slider Style */
#colorbox {
	overflow: visible;
}

#colorbox #cboxWrapper {
	overflow: visible;
}

#colorbox #cboxContent {
	margin: 0;
}

#cboxClose {
	display: block;
	width: 62px;
	height: 60px;
	text-indent: -9999px;
	background-image: url(/common/img/btn_close.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 60px 60px;
	position: absolute;
	top: -90px;
	right: -2px;
	overflow: visible;
}


/* SNS
-------------------------------------------------------------------- */
.mod-list-sharebtn {
	width: 700px;
	margin: 0 auto;
}

.mod-list-sharebtn li {
	float: left;
	width: 220px;
	height: 50px;
	margin-right: 20px;
	text-align: center;
}

.mod-list-sharebtn li:last-child {
	margin-right: 0;
}

.mod-list-sharebtn li a {
	display: table;
	width: 100%;
	height: 50px;
	border-radius: 12px;
}

.mod-list-sharebtn li span {
	display: table-cell;
	vertical-align: middle;
}

.mod-list-sharebtn li img {
	width: 37px;
}

.mod-list-sharebtn .btn-tw a {
	background-color: #50abf1;
}

.mod-list-sharebtn .btn-fb a {
	background-color: #3b5998;
}

.mod-list-sharebtn .btn-line a {
	background-color: #00b900;
}


@media only screen and (max-width: 736px) {
	.mod-sharebtn {
		padding: 0 15px;
	}
	
	.mod-list-sharebtn {
		width: 100%;
	}
	
	.mod-list-sharebtn li {
		float: left;
		width: 32%;
		height: 70px;
		margin-right: 0;
		text-align: center;
	}
	
	.mod-list-sharebtn li:nth-child(3n-1) {
		margin: 0 2%;
	}
	
	.mod-list-sharebtn li a {
		display: table;
		width: 100%;
		height: 70px;
		border-radius: 12px;
	}
	
	.mod-list-sharebtn li span {
		display: table-cell;
		vertical-align: middle;
	}
	.mod-list-sharebtn li img {
		width: 37px;
	}
}


/* # PRODUCT ONLINE
----------------------------------- */
.mod-product-online {
	padding: 40px 0 80px;
}

.mod-product-online .cts-inner:after {
	display: block;
	content: '';
	width: 242px;
	height: 230px;
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 242px 230px;
	position: absolute;
	top: -52px;
	left: -1px;
	z-index: 2;
}

.mod-product-online .mod-ttl-index {
	width: 730px;
	text-align: center;
	padding: 17px 0 22px 15px;
	margin: 0 0 0 auto;
	box-sizing: border-box;
}

.mod-product-online .txt {
	width: 175px;
	position: absolute;
	top: -41px;
	right: 32px;
	z-index: 2;
}

.mod-product-online .list-shop {
	width: 730px;
	margin: 0 0 0 auto;
}

.mod-product-online .list-shop {
	*zoom: 1;
}

.mod-product-online .list-shop:before, .mod-product-online .list-shop:after {
	content: "";
	display: table;
}

.mod-product-online .list-shop:after {
	clear: both;
}

.mod-product-online .list-shop > li {
	width: 230px;
	height: 80px;
	float: left;
}

.mod-product-online .list-shop > li:nth-of-type(n+2) {
	margin-left: 20px;
}

.mod-product-online .list-shop > li .mod-link-block {
	border: none;
}

.mod-product-online .list-shop > li .mod-link-block .logo-online {
	display: inline-block;
	width: 196px;
	padding: 9px 0;
}

.mod-product-online .cts-inner:after {
	background-image: url(/products/common/img/img_kitten.png);
}

/* 製品情報別 */
.product-kitten .mod-product-online .cts-inner:after {
	background-image: url(/products/common/img/img_kitten.png);
}

.product-adult .mod-product-online .cts-inner:after {
	background-image: url(/products/common/img/img_adult.png);
}

.product-senior .mod-product-online .cts-inner:after {
	background-image: url(/products/common/img/img_senior.png);
}

.product-pouch .mod-product-online .cts-inner:after {
	background-image: url(/products/common/img/img_pouch.png);
}

.product-dry .mod-product-online .cts-inner:after {
	background-image: url(/products/common/img/img_dry.png);
}

.product-can .mod-product-online .cts-inner:after {
	background-image: url(/products/common/img/img_can.png);
}

@media only screen and (max-width: 736px) {
	.mod-product-online {
		padding: 15px 0 15px;
	}

	.mod-product-online .cts-inner {
		padding-top: 45px;
		padding-bottom: 20px;
	}

	.mod-product-online .cts-inner:after {
		display: block;
		content: '';
		width: 121PX;
		height: 115px;
		margin: 0 0 0 -60.5px;
		background-repeat: no-repeat;
		background-position: left top;
		background-size: 121px 115px;
		position: absolute;
		top: -76px;
		left: 50%;
		z-index: 2;
	}

	.mod-product-online .mod-ttl-index {
		width: auto;
		text-align: center;
		padding: 0 0 13px;
		margin: 0;
	}

	.mod-product-online .txt {
		width: auto;
		font-size: 16px;
		color: #ffd33b;
		text-align: center;
		padding: 0 0 12px;
		position: static;
	}

	.mod-product-online .list-shop {
		width: 100%;
		margin: 0;
	}

	.mod-product-online .list-shop > li {
		width: 100%;
		height: 70px;
		float: none;
		margin: 0 0 15px;
	}

	.mod-product-online .list-shop > li:nth-of-type(n+2) {
		margin-left: 0;
	}

	.mod-product-online .list-shop > li .mod-link-block .logo-online {
		width: 167px;
		padding: 8px 0 9px;
	}
}





