@charset "utf-8";
/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
base
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

body {
	font-family: 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'Meiryo UI', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Verdana, sans-serif;
	-webkit-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	animation: fadeIn 1.2s ease 0s 1 normal;
	-webkit-animation: fadeIn 1.2s ease 0s 1 normal;
}
@-webkit-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}
@-moz-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}
@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}
body,h1,h2,h3,h4,h5,h6,p {
	font-size: 16px;
	color: #f71a46;
	margin: 0;
	padding: 0;
	line-height: 1.5;
}

a {
	text-decoration: none;
}
a:hover {
	color: #FF0000;
	text-decoration: underline;
}
a:link {color: #0000FF;}
a:active {color: #0000FF;}
a:visited {color: #990066;}

img {vertical-align: bottom;}
a img {border: none;}

input:focus,
button {
	outline: 0;
}

.clear {
	display: none;
	clear: both;
}

img.centering {position: absolute;}

::selection {
	background: #FFD7E9;
}
::-moz-selection {
	background: #FFD7E9;
}

.pcNone {display: none;}

@media (max-width: 950px) {
}
@media (max-width: 767px) {
	/* responsive none fore SP */
	.spNone {display: none;}
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
common styles
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

/* font-size */
.fs0 {font-size: 0;}
.fs10 {font-size: 10px;}
.fs11 {font-size: 11px;}
.fs12 {font-size: 12px;}
.fs13 {font-size: 13px;}
.fs14 {font-size: 14px;}
.fs15 {font-size: 15px;}
.fs16 {font-size: 16px;}
.fs17 {font-size: 17px;}
.fs18 {font-size: 18px;}
.fs20 {font-size: 20px;}
.fs22 {font-size: 22px;}
.fs24 {font-size: 24px;}
.fs26 {font-size: 26px;}
.fs28 {font-size: 28px;}
.fs30 {font-size: 30px;}
.fs32 {font-size: 32px;}
.fs34 {font-size: 34px;}
.fs36 {font-size: 36px;}
.fs38 {font-size: 38px;}
.fs40 {font-size: 40px;}
.fs42 {font-size: 42px;}
.fs44 {font-size: 44px;}
.fs46 {font-size: 46px;}
.fs48 {font-size: 48px;}
.fs50 {font-size: 50px;}
.fs60 {font-size: 60px;}

/* font-family */
.default {font-family: 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'Meiryo UI', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Verdana, sans-serif;}
.mincho {font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝', YuMincho, 'Meiryo UI', 'メイリオ', 'Meiryo', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;}
.eng {font-family: Arial, Helvetica, sans-serif;}
.gf01 {font-family: 'Lobster', cursive;}
.gf02 {font-family: 'Roboto', sans-serif;}
.gf03 {font-family: 'Righteous', cursive;}

/* font-weight */
.fwBold {font-weight: bold;}
.fwNormal {font-weight: normal;}

/* font-style */
.fstNormal {font-style: normal;}
.fstItalic {font-style: italic;}

/* color(文字色) */
.fcWhite {color: #FFF;} /* 白 */
.fcBlack {color: #333;} /* 黒 */
.fcGray01 {color: #BBB;} /* グレー */
.fcRed {color: #e60012;} /* 赤 */

/* text-align */
.taCenter {text-align: center;}
.taLeft {text-align: left;}
.taRight {text-align: right;}

/* vertical-align */
.vaBottom {vertical-align: bottom;}
.vaMiddle {vertical-align: middle;}
.vaTop {vertical-align: top;}

/* line-height */
.lh10 {line-height: 1;}
.lh12 {line-height: 1.2;}
.lh13 {line-height: 1.3;}
.lh14 {line-height: 1.4;}
.lh15 {line-height: 1.5;}
.lh20 {line-height: 2;}

/* background(背景色) */
.bgWhite {background-color: #FFF;} /* 白 */
.bgBlack {background-color: #000;} /* 黒 */
.bgGray01 {background-color: #f3f3f3;} /* グレー（薄） */
.bgGray02 {background-color: #DDD;} /* グレー（--） */
.bgGray03 {background-color: #BBB;} /* グレー（濃） */
.bgGreen {background-color: #54cc14;} /* 緑 */
.bgRed {background-color: #f71a46;} /* 赤 */
.bgPink {background-color: #fffcfd;} /* ピンク */
.bgPink02 {background-color: #fee8ec;} /* ピンク */

/* float */
.floatLeft {
	display: inline;
	float: left;
}
.floatRight {
	display: inline;
	float: right;
}

/* border-radius */
.bRadius02 {-webkit-border-radius: 2px;-moz-border-radius: 2px;border-radius: 2px;}
.bRadius03 {-webkit-border-radius: 3px;-moz-border-radius: 3px;border-radius: 3px;}
.bRadius04 {-webkit-border-radius: 4px;-moz-border-radius: 4px;border-radius: 4px;}
.bRadius05 {-webkit-border-radius: 5px;-moz-border-radius: 5px;border-radius: 5px;}
.bRadius10 {-webkit-border-radius: 10px;-moz-border-radius: 10px;border-radius: 10px;}
.bRadius15 {-webkit-border-radius: 15px;-moz-border-radius: 15px;border-radius: 15px;}
.bRadius20 {-webkit-border-radius: 20px;-moz-border-radius: 20px;border-radius: 20px;}
.bRadius25 {-webkit-border-radius: 25px;-moz-border-radius: 25px;border-radius: 25px;}
.bRadius30 {-webkit-border-radius: 30px;-moz-border-radius: 30px;border-radius: 30px;}

/* hover時半透明 */
.opacity:hover  {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
}

/* text-indent */
.ti-05 {text-indent: -5px;}
.ti-10 {text-indent: -10px;}
.ti-15 {text-indent: -15px;}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
global navigation
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

/* TOPページ */
#gNav {
	width: auto;
	margin: 50px 40px 0;
	padding: 0;
}
#gNav ul {
	margin: 0;
	padding: 0;
	list-style-type: none;
	border-top: 1px solid #EEE;
}
#gNav li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #EEE;
}
#gNav li a {
	padding: 20px 0;
	color: #f71a46;
	letter-spacing: 0.2em;
	display: block;
	transition: 0.1s linear;	
}
#gNav li a:hover {
	letter-spacing: 0;
	text-decoration: none;
	background-color: #fee8ec;
}
#gNav li a span {
	padding: 0 0 0 20px;
	background-image: url(../img/common/ar/01.png);
	background-position: left;
	background-repeat: no-repeat;
	background-size: 14px;	
}

/* SUBページ */
#subNav {
	margin: 0;
	padding: 0;
}
#subNav ul {
	height: 100px;
	overflow: hidden;
	margin: 0;
	padding: 0;
	display: inline-block;
	list-style: none;
}
#subNav ul li {
	width: 160px;
	height: 100px;
	margin: 0;
	padding: 0;
	border-left: 1px solid #EEE;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
#subNav ul li a {
	width: 100%;
	height: 100%;
	padding: 0;
	color: #f71a46;
	display: block;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
#subNav ul li a span {
	width: 100%;
	display: block;
	position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%); /* Safari用 */
  transform: translate(-50%, -50%);
}
#subNav ul li a:hover {
	text-decoration: none;
	background-color: #fee8ec;
}

@media (max-width: 950px) {
	#subNav {
		width: 100%;
		display: none;
	}
	#subNav ul {
		height: auto;
		display: block;
		border-top: 1px solid #EEE;
	}
	#subNav ul li {
		width: 100%;
		height: 50px;
		display: block;
		float: none;
		border-left: none;
		border-bottom: 1px solid #EEE;
	}
	#subNav ul li br {
		display: none;
	}
}

/* button for sp */
#btnSp {
	width: 40px;
	height: 40px;
	margin: 0;
	padding: 5px;
	position: absolute;
	top: 30px;
	right: 20px;
	display: none;
	background-color: #f7214c;
	-webkit-border-radius: 20px;
	-moz-border-radius: 20px;
	border-radius: 20px;
}
.menuTrigger,
.menuTrigger span {
	transition: all .4s;
	box-sizing: border-box;
}
.menuTrigger span {
	margin: 0 0 0 -11px;
	position: absolute;
	left: 50%;
	width: 22px;
	height: 2px;
	background-color: #FFF;
	border-radius: 4px;
}
.menuTrigger span:nth-of-type(1) {
	top: 10px;
}
.menuTrigger span:nth-of-type(2) {
	margin: -1px 0 0 -11px;
	top: 50%;
}
.menuTrigger span:nth-of-type(3) {
	bottom: 10px;
}
.menuTrigger.active span:nth-of-type(1) {
	top: -3px;
	-webkit-transform: translateY(22px) rotate(-45deg);
	transform: translateY(22px) rotate(-45deg);
}
.menuTrigger.active span:nth-of-type(2) {
	left: 50%;
	opacity: 0;
	-webkit-animation: active-menu-bar02 .8s forwards;
	animation: active-menu-bar02 .8s forwards;
}
@-webkit-keyframes active-menu-bar02 {
	100% {
		height: 0;
	}
}
@keyframes active-menu-bar02 {
	100% {
		height: 0;
	}
}
.menuTrigger.active span:nth-of-type(3) {
	bottom: 3px;
	-webkit-transform: translateY(-16px) rotate(45deg);
	transform: translateY(-16px) rotate(45deg);
}

@media (max-width: 950px) {
	#btnSp {
		display: block;
	}
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
topic path
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

#tPath {
	width: 100%;
	height: 40px;
	margin: 0;
	padding: 0;
	border-bottom: #BBB solid 1px;
}
#tPath p {
	width: 1000px;
	height: 40px;
	margin: 0 auto;
	padding: 10px 0 0;
	font-size: 13px;
}
#tPath p a {
	color: #333;
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
フリー装飾
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

div.system-free {
	width: 680px;
	height: 100%;
	overflow: hidden;
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
ページ遷移
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

ol.transition {
	width: 100%;
	height: 29px;
	overflow: hidden;
	margin: 40px auto 0;
	padding: 0;
	text-align: center;
	list-style: none;
}
ol.transition li {
	width: 27px;
	height: 27px;
	overflow: hidden;
	margin: 0 1px;
	padding: 0;
	color: #0086dc;
	font-size: 14px;
	text-align: center;
	line-height: 1.2;
	display: inline-block;
	*display: inline;
	*zoom: 1;
	background: #FFF;
	border: #0086dc solid 1px;
}
ol.transition li a {
	width: 27px;
	height: 27px;
	margin: 0;
	padding: 0;
	color: #0086dc;
	display: block;
	text-decoration: none;
}
ol.transition li span {
	margin: 0;
	padding: 5px 0 0;
	display: block;
}
ol.transition li a:hover,
ol.transition li.current {
	color: #FFF;
	font-weight: bold;
	background: #0086dc;
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
clearfix
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

.clearfix:after{
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
	font-size:0;
}
.clearfix{
	display:inline-block;
}
/* Hides from IE-mac \*/
* html .clearfix{
	height:1px;
}
.clearfix{
	display:block;
}
/* End hide from IE-mac */


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
ページの先頭へ
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

#btn_pagetop {
	position: fixed;
	right: 20px;
	z-index: 9999;
}

@media (max-width: 950px) {
	#btn_pagetop {
		width: 35px;
		height: 35px;
	}
	#btn_pagetop img {
		width: 100%;
		height: auto;
	}
}




