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

.hiddenItem {
	display:none;
}

.ellipsis {
	text-overflow:ellipsis;
	white-space:nowrap;
	overflow:hidden;
}
.floatLeft {
	float:left;
}
.floatRight {
	float:right;
}
.alignRight {
	text-align:right;
}
.alignCenter {
	text-align:center;
}
.notes {
	margin-top:1em;
	padding-left:1em;
	text-indent:-1em;
}
.textIndent {
	text-indent:1em;
}
/*base
====================================================================================================*/
html {
	overflow-y:scroll;
	height: auto;
 	font-size: 62.5%;
}
body {
	min-width: 980px;
	height: 100%;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 14px;
	font-size: 1.4rem;
}
a {
	color: #007cbf;
	text-decoration: none;
}
a:visited {}
a:hover {
	text-decoration: underline;
}
a:active {}
img {
	vertical-align: bottom;
}

#header {
	background-image: url(../images/header_bg_01.png);
	background-repeat: repeat-x;
	border-bottom: solid 1px #d8d9eb;
}
#header .innerBox {
	width: 980px;
	height: 55px;
	margin: 0 auto;
	line-height: 55px;
}
#headerLogo {
	width: 390px;
	float: left;
}
#primaryNav {
	width: 590px;
	float: right;
	text-align: right;
}
#primaryNav li {
	display: inline-block;
	margin: 0 0 0 30px;
	vertical-align: top;
}
#primaryNav a {
	text-decoration: none;
	font-weight: inherit;
	color: #4c5266;
}
#primaryNav .thisBtn {
	font-weight: bold;
}
#primaryNav a:hover {
	color: #f39c12;
}
#contents {
	background-image: url(../images/contents_bg_01.png);
	background-repeat: repeat-x;
	margin: 0 0 70px 0;
}
#contents .innerBox {
	width: 980px;
	margin: 0 auto;
	padding: 105px 0 0 0;
	position: relative;
}
#main {
	width: 640px;
	margin: 42px 0 0 0;
	float: right;
}
#side {
	width: 300px;
	margin: 37px 0 0 0;
	float: left;
}
#globalMenu {
	margin: 0 0 35px 0;
}
#globalMenu ul {
	background-image: url(../images/side_bg_01.gif);
	color: #3f2b0a;
	font-size: 21px;
	font-size: 2.1rem;
	font-weight: bold;
}
#globalMenu>ul {
	box-shadow: 0 -2px 0 #f2d250;
}
#globalMenu ul a {
	color: inherit;
	text-decoration: none;
	display: block;
}
#globalMenu ul a:hover {
	background-color: #D4AB04;
	background-color: rgba(0,0,0,0.1);
}
#globalMenu ul li {
	border-bottom: solid 1px #d1ab14;
}
#globalMenu ul li:last-child {
	border-bottom: none;
}

#globalMenu>ul,
#globalMenu>ul>li:first-child a {
	border-top-left-radius: 3px;
	border-top-right-radius: 3px;
}
#globalMenu>ul,
#globalMenu>ul>li:last-child a {
	border-bottom-left-radius: 3px;
	border-bottom-right-radius: 3px;
}
#globalMenu ul li a,
#globalMenu ul li span {
	padding: 5px 10px 5px 25px;
	display: block;
}
#globalMenu ul ul {
	font-size: 18px;
	font-size: 1.8rem;
	border-top: solid 1px #d1ab14;
	background-image: none;
	background-color: #e3b80b;
}
#globalMenu ul ul li {
	border-bottom: none;
}
#globalMenu ul ul li a,
#globalMenu ul ul li span {
	padding-left: 67px;
	background-image: url(../images/icon_01.png);
	background-position: 46px 10px;
	background-repeat: no-repeat;
}
#footer {
	clear:both;
	background-color: #eceef1;
	color: #888888;
}
#footer .innerBox {
	width: 980px;
	margin: 0 auto;
	padding: 30px 0;
}
#footer .boxA {
	width: 510px;
	float: left;
}
#footer .boxB {
	width: 470px;
	float: right;
}
#footer address {
	font-family: 'Open Sans', sans-serif ,400;
	margin: 0 0 30px 0;
}
#footerLink {
	font-weight: bold;
	/*font-family: 'Open Sans', sans-serif,600;*/
	margin: 0 0 30px 0;
}
#footerLink a {
	color: #f1c40f;
	font-weight: inherit;
	text-decoration: none;
	margin: 0 0 0 20px;
}
#footerLink a:hover {
	color: #f39c12;
}
#footerLink a.thisBtn {
	color: #f39c12;
}

#extra {
	padding: 33px 0;
	margin: 0 0 90px 0;
	background-color: #f8f8f8;
	border-top: solid 1px #f0f0f1;
	border-bottom: solid 1px #f0f0f1;
}
#banner {
	width: 680px;
	padding: 0 0 40 0;
	margin: 0 auto;
}
#banner li {
	width: 300px;
	margin: 0 0 0 40px;
	float: left;
}
.sectionTitle {
	font-size: 28px;
	font-size: 2.8rem;
	margin: 0 0 35px 0;
}

/*boxStyle
====================================================================================================*/
.boxStyleA {
	margin: 0 0 50px 0;
	padding: 0 0 0 70px;
	position: relative;
}
.boxStyleA .photo{
	width: 570px;
	height: 200px;
	margin: 0 0 20px 0;
	overflow: hidden;
	position: relative;
}
.boxStyleA .photo img{
	width: 100%;
	position: absolute;
	left:0;
	top:0;
}
.boxStyleA .title {
	font-size: 21px;
	font-size: 2.1rem;
	margin: 0 0 20px 0;
	font-weight: bold;
}
.boxStyleA .summary {
	color: #666666;
	position: relative;
}
.boxStyleA .more {
	color: #f39c12;
	position: absolute;
	right:0;
	bottom:0;
}
.boxStyleA .time {
	display: block;
	width: 56px;
	text-align: center;
	position: absolute;
	left:0;
	top:0;
	color: #34495e;
	font-size: 12px;
	font-size: 1.2rem;
}
.boxStyleA .time span {
	display: block;
	background-color: #d2dbff;
	font-weight: bold;
}
.boxStyleA .time .month {
	padding: 5px 0 0 0;
	line-height: 23px;
	font-size: 14px;
	font-size: 1.4rem;
}
.boxStyleA .time .day {
	padding: 0 0 3px 0;
	margin: 0 0 5px 0;
	line-height: 25px;
	font-size: 12px;
	font-size: 1.2rem;
}

/*listStyle
====================================================================================================*/
.listStyleA {
	list-style-type: disc;
	margin: 0 0 0 30px;
}
/*btnStyle
====================================================================================================*/
.btnStyleA {
	display: block;
	width: 130px;
	height: 33px;
	line-height: 33px;
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, .3);
	text-decoration: none;
	background-color: #2ecc71;
	border-radius: 3px;
	box-shadow: 0 -2px 0 #77dea3;
	text-align: center;
}
.btnStyleA:hover {
	text-decoration: none;
}

/*tableStyle
====================================================================================================*/
.tableStyleA {
	width: 640px;
	background-color: #fafbff;
}
.tableStyleA tr {}
.tableStyleA tr th {
	border: solid 1px #809799;
	text-align: center;
	vertical-align: middle;
}
.tableStyleA tr td {
	border: solid 1px #809799;
	vertical-align: middle;
}
.tableStyleA .styleA {
	width: 50px;
	background-color: #bdd1fe;
}
.tableStyleA .styleB {
	width: 220px;
	padding: 5px 10px;
}
.tableStyleA .styleC {
	width: 170px;
	padding: 5px 10px;
}
.tableStyleA .styleE {
	padding-top: 10px;
	padding-bottom: 10px;
	font-weight: bold;
}
.tableStyleA .styleF{
	padding: 20px 10px
}
.tableStyleA .styleF .title {
	font-weight: bold;
	display: block;
	text-align: center;
	margin: 0 0 20px 0;
}


.tableStyleB {
	background-color: #fafbff;
}
.tableStyleB tr {}
.tableStyleB tr th {
	border: solid 1px #809799;
	text-align: center;
	background-color: #bdd1fe;
	padding: 10px;
}
.tableStyleB tr td {
	border: solid 1px #809799;
	padding: 10px;
}

/*list
====================================================================================================*/
#mainTitle {
	width: 980px;
	height: 105px;
	line-height: 105px;
	text-align: center;
	font-size: 38px;
	font-size: 3.8rem;
	font-weight: bold;
	position: absolute;
	left:0;
	top:0;
}

/*home
====================================================================================================*/
.home {}
.home #contents {
	background-image: url(../images/contents_bg_02.png);
}
.home #contents .innerBox {
	padding-top: 357px;
}
.home #main {
	margin-top: 35px;
}
#topTitle {
	position: absolute;
	left:0;
	top:69px;
}
#keyvisualWrap {
	width: 470px;
	height: 329px;
	background-image: url(../images/keyvisual_bg_01.png);
	background-repeat: no-repeat;
	position: absolute;
	left:510px;
	top:0;
}
#keyvisual {
	width: 353px;
	height: 215px;
	overflow: hidden;
	margin: 54px 0 0 52px
}
#slider {
	width: 353px;
	height: 215px;
	overflow: hidden;
	margin: 54px 0 0 52px
}
#description {
	width: 445px;
	position: absolute;
	left:25px;
	top:185px;
	font-size: 15px;
	font-size: 1.5rem;
}
.home #side {
	margin-top: -43px;
}

.home .boxStyleA {
	width: 230px;
	float: left;
}
.home .boxStyleA.entry1 {
	width: auto;
}
.home .boxStyleA .title {
	margin-bottom: 15px;
}
.home .boxStyleA:nth-of-type(odd) {
	margin-right: 40px;
}
.home .boxStyleA.nth-of-type-odd {
	margin-right: 40px;
}
.home .boxStyleA .more {
	display: block;
	position: static;
	text-align: right;
}

#news {}
#newsTitle {
	width: 510px;
	float: left;
}
#news .boxStyleA .title {
	line-height: 1.4;
}
#news .btnStyleA {
	float: right;
	margin-top: 7px;
}

/*detail
====================================================================================================*/

.detail #main h3 {
	margin: 0 0 10px 0;
	padding: 5px 5px 5px 20px;
	background-color: #ECBE04;
	background-color: rgba(236, 190, 4, 0.66);
	color: #3F2B0A;
	border-radius: 3px;
}
.detail #main h4 {
	margin: 0 0 10px 0;
	padding: 0 0 0 17px;
	border-left: solid 3px #ECBE04;
	color: #3F2B0A;
}
.detail #main h5 {
	margin: 0 0 10px 0;
	font-weight: bold;
	color: #3F2B0A;
}
.detail #main p {
	margin: 0 0 10px 0;
	line-height: 1.6;
}

.detail .time {
	position: static;
	width: auto;
	margin-bottom: 10px;
	text-align: right;
	font-size: 14px;
	font-size: 1.4rem;
}
.detail .time span {
	display: inline;
	padding: 0;
	background-color: transparent;
	font-weight: normal;
}
.detail .time .day {
	font-size: 14px;
	font-size: 1.4rem;
}
.detail .boxStyleA {
	padding-left: 0;
}
.detail .boxStyleA .title {
	margin-bottom: 10px;
}