@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%;
}
body,h1,h2,h3,h4,h5,h6,p {
	font-size: 16px;
	color: #3c3933;
	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 {outline: 0;}

.clear {
	display: none;
	clear: both;
}

::selection {
	background: #FFD7E9;
}
::-moz-selection {
	background: #FFD7E9;
}

.pcNone {display: none;}

@media (max-width: 1220px) {
	/* 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;}

/* 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;}
.engSerif {font-family: "Times New Roman", Times, serif}
.gf01 {font-family: 'Open Sans', sans-serif;} /* 英語標準 */
.gf02 {font-family: 'Baloo Chettan', cursive;} /* 日付 */
.gf03 {font-family: 'Roboto Condensed', sans-serif;} /* for english page */
.gf04 {font-family: 'Anton', sans-serif;} /* TEL NUMBER for contact page */

/* 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: #3c3933;} /* 黒 */
.fcGray01 {color: #BBB;} /* グレー */
.fcRed01 {color: #e60012;} /* 赤 */
.fcRed02 {color: #dd5252;} /* 赤 */
.fcKhaki01 {color: #c3bf93;} /* カーキ */
.fcBlue01 {color: #56758a;} /* 青 */
.fcPink {color: #d69090;} /* ピンク */

/* 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(背景色) */
.bgWhite01 {background: #FFF;} /* 白 */
.bgWhite02 {background: #f6f6ee;} /* 白 */
.bgBlack {background: #3c3933;} /* 黒 */
.bgGray01 {background: #f3f3f3;} /* グレー（薄） */
.bgGray02 {background: #DDD;} /* グレー（--） */
.bgGray03 {background: #BBB;} /* グレー（濃） */
.bgKhaki01 {background: #f0efe4;} /* カーキ（メイン背景） */
.bgKhaki02 {background: #c3bf93;} /* カーキ */
.bgKhaki03 {background: #e2e0cc;} /* カーキ */
.bgBlue {background: #274a78;} /* 青 */
.bgGreen {background: #d5efcc;} /* 緑（年表） */
.bgPink {background: #f0dae3;} /* ピンク（年表） */
.bgYellow {background: #e9e8b1;} /* 黄（年表） */

/* float */
.floatLeft {
	display: inline;
	float: left;
}
.floatRight {
	display: inline;
	float: right;
}

/* border-radius */
.bRadius02 {border-radius: 2px;-webkit-border-radius: 2px;-moz-border-radius: 2px;}
.bRadius03 {border-radius: 3px;-webkit-border-radius: 3px;-moz-border-radius: 3px;}
.bRadius04 {border-radius: 4px;-webkit-border-radius: 4px;-moz-border-radius: 4px;}
.bRadius05 {border-radius: 5px;-webkit-border-radius: 5px;-moz-border-radius: 5px;}
.bRadius10 {border-radius: 10px;-webkit-border-radius: 10px;-moz-border-radius: 10px;}
.bRadius15 {border-radius: 15px;-webkit-border-radius: 15px;-moz-border-radius: 15px;}
.bRadius20 {border-radius: 20px;-webkit-border-radius: 20px;-moz-border-radius: 20px;}
.bRadius25 {border-radius: 25px;-webkit-border-radius: 25px;-moz-border-radius: 25px;}
.bRadius30 {border-radius: 30px;-webkit-border-radius: 30px;-moz-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
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

#gNav {
	height: 60px;
	overflow: hidden;
	margin: 0;
	padding: 0;
	border-top: 1px solid #3c3933;
	border-bottom: 1px solid #3c3933;
	box-sizing: border-box;
}
#gNavList {
	margin: 0;
	padding: 0;
	list-style-type: none;
}
#gNavList li {
	height: 60px;
	margin: 0 30px;
	padding: 0;
	display: inline-block;
}
#gNavList li.pcNone {
	display: none;
}
#gNavList li a {
	height: 60px;
	color: #3c3933;
	position: relative;
	display: block;
	outline: none;
}
#gNavList li a:hover {
	text-decoration: none;
}
.cl-effect-5 a {
	overflow: hidden;
	padding: 0;
}
.cl-effect-5 a span {
	height: 60px;
	padding: 17px 0 0;
	position: relative;
	display: inline-block;
	-webkit-transition: -webkit-transform 0.3s;
	-moz-transition: -moz-transform 0.3s;
	transition: transform 0.3s;
	box-sizing: border-box;
}
.cl-effect-5 a span::before {
	height: 60px;
	padding: 17px 0 0;
	position: absolute;
	top: 100%;
	content: attr(data-hover);
	-webkit-transform: translate3d(0,0,0);
	-moz-transform: translate3d(0,0,0);
	transform: translate3d(0,0,0);
	box-sizing: border-box;
}
.cl-effect-5 a:hover span,
.cl-effect-5 a:focus span {
	-webkit-transform: translateY(-100%);
	-moz-transform: translateY(-100%);
	transform: translateY(-100%);
}


@media (max-width: 1220px) {
	#spNavBtn {
		width: 200px;
		height: 50px;
		margin: 20px auto 0;
		padding: 0;
		display: block;
	}
	#spNavBtn a {
		width: 200px;
		height: 50px;
		color: #FFF;
		padding: 15px 0 0;
		display: block;
		background-color: #dd5252;
		-webkit-border-radius: 50px;
		-moz-border-radius: 50px;
		border-radius: 50px;		
		box-sizing: border-box;
	}
	#spNavBtn a:hover {
		text-decoration: none;
	}
	#spNavBtn a img,
	#spNavBtn a span {
		margin: 0 5px;
	}
	#gNav {
		height: 100%;
		padding: 0 0 20px;
		font-size: 16px;
		border-top: none;
	}
	#gNavList {
		margin: 20px 0 0;
		border-top: 1px solid #3c3933;
	}
	#gNavList li {
		height: 50px;
		margin: 0;
		display: block;
		border-bottom: 1px solid #3c3933;
	}
	#gNavList li.pcNone {
		display: block;
	}
	#gNavList li a {
		padding: 15px 0 0;
		display: block;
		box-sizing: border-box;
	}
	#gNavList li a:hover {
		text-decoration: none;
	}
	.cl-effect-5 a span {
		height: 50px;
		padding: 0;
		-webkit-transition: none;
		-moz-transition:none;
		transition: none;
	}
	.cl-effect-5 a span::before {
		height: 50px;
		content: none;
	}
	.cl-effect-5 a:hover span,
	.cl-effect-5 a:focus span {
		-webkit-transform: none;
		-moz-transform: none;
		transform: none;
	}	
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
topic path
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

#tPath {
	width: 100%;
	height: 50px;
	margin: 0;
	padding: 0;
}
#tPath p {
	width: 1200px;
	height: 50px;
	margin: 0 auto;
	padding: 18px 0 0;
	box-sizing: border-box;
}
#tPath p a {
	color: #FFF;
}

@media (max-width: 1220px) {
	#tPath {
		height: 100%;
		padding: 0 20px;
		box-sizing: border-box;
	}
	#tPath p {
		width: 100%;
		height: auto;
		margin: 0;
		padding: 18px 0;
	}
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
フリー装飾
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

div.system-free {
	width: 780px;
	height: 100%;
	overflow: hidden;
}

@media (max-width: 767px) {
	div.system-free {
		width: 100%;
	}
	div.system-free img {
		width: 100%;
		height: auto;
	}
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
ページ遷移
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

ol.transition {
	height: 40px;
	overflow: hidden;
	margin: 0 40px 0 20px;
	padding: 0;
	text-align: center;
	list-style: none;
}
ol.transition li {
	width: 40px;
	height: 40px;
	overflow: hidden;
	margin: 0 1px 0 0;
	padding: 0;
	color: #3c3933;
	font-size: 18px;
	text-align: center;
	line-height: 1.2;
	display: inline-block;
	*display: inline;
	*zoom: 1;
	background: #c3bf93;
}
ol.transition li a {
	width: 40px;
	height: 40px;
	margin: 0;
	padding: 0;
	color: #3c3933;
	display: block;
	text-decoration: none;
}
ol.transition li span {
	margin: 0;
	padding: 8px 0 0;
	display: block;
}
ol.transition li a:hover,
ol.transition li.current {
	color: #FFF;
	font-weight: bold;
	background: #3c3933;
}

@media (max-width: 767px) {
	ol.transition {
		height: auto;
	}
}

/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
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 */


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
button settings
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

.cmnbtn01 {
	padding: 0;
}
.cmnbtn01 a {
	padding: 14px 0 0;
	color: #FFF;
	display: block;
	background-color: #dd5252; 
	border: 2px solid #dd5252;
	box-sizing: border-box;
	transition: 0.1s linear;
}
.cmnbtn01 a span {
	padding: 0 12px 0 0;
	background-image: url(../img/common/ar/01.png);
	background-position: right;
	background-repeat: no-repeat;
	background-size: 4px 7px;
}
.cmnbtn01 a:hover {
	color: #dd5252;
	text-decoration: none;
	background-color: #FFF; 
}
.cmnbtn01 a:hover span {
	background-image: url(../img/common/ar/01_on.png);
}


/* ------------------------------------------------------------------
/////////////////////////////////////////////////////////////////////
ページの先頭へ
/////////////////////////////////////////////////////////////////////
------------------------------------------------------------------ */

#btn_pagetop {
	position: fixed;
	right: 10px;
	z-index: 9999;
}

@media (max-width: 767px) {
	#btn_pagetop {
		width: 40px;
		height: 40px;
	}
	#btn_pagetop img {
		width: 40px;
		height: 40px;
	}
}

