@charset "utf-8";
/*------------------------------------------------------------
	トープページ
------------------------------------------------------------*/
.mainVisualBox {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.mainVisualBox li {
	float: left;
}

.mainVisualBox .foo {
	overflow: hidden;
}

.mainVisualBox .left,
.mainVisualBox .right {
	position: absolute;
	top: 0;
	width: 50%;
	height: 310px;
	z-index: 10;
	opacity: 1;
	filter: alpha(opacity=100);
}

.mainVisualBox .left {
	left: -515px;
}

.mainVisualBox .right {
	right: -515px;
}

.mainVisualBox .foopage {
	margin-top: 10px;
	position: absolute;
	left: 73%;
	bottom: 15px;
	text-align: center;
	z-index: 100;
}

.mainVisualBox .foopage a {
	margin: 0 4px;
	width: 15px;
	height: 14px;
	display: inline-block;
	background: url(../images/common/icon01.png) no-repeat;
}

.mainVisualBox .foopage a.selected {
	background: url(../images/common/icon02.png) no-repeat;
}

.mainVisualBox .foopage a span {
	display: none;
}

.mainVisualBox .sliderInfo {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
}

.mainVisualBox .textImg {
	padding: 25px 0 9px;
	text-align: center;
	background: url(../images/index/main_img_bg.png) repeat left top;
}

.mainVisualBox .text {
	padding: 13px 0;
	font-size: 23px;
	text-align: center;
	background: url(../images/index/main_text_bg.png) repeat left top;
}

.mainVisualBox .text p {
	color: #FFF;
}

#consept {
	padding: 71px 0 0;
	background: #23BAEF url(../images/index/consept_bg.jpg) no-repeat center bottom;
}

#consept .conseptBox {
	margin: 0 auto;
	padding-bottom: 202px;
	width: 950px;
	position: relative;
	text-align: center;
}

#consept h2 {
	margin-bottom: 39px;
	background: none;
	box-shadow: none;
}

#consept .pTtl {
	margin-bottom: 48px;
}

#consept p {
	margin-left: 40px;
	color: #FFF;
	font-size: 15px;
	line-height: 2.4;
	letter-spacing: 1px;
}

#consept .text {
	margin-top: 22px;
	font-size: 19px;
	font-weight: bold;
}

#consept .img01 {
	position: absolute;
	left: -84px;
	bottom: -44px;
}

#consept .img02 {
	position: absolute;
	right: -61px;
	bottom: -38px;
}

#program {
	padding: 53px 0 65px;
	background-color: #FFF20D;
}

#program .programBox {
	margin: 0 auto;
	width: 950px;
	position: relative;
}

#program h2 {
	margin: 0 42px 60px;
	padding: 27px 0 23px;
}

#program .infoList {
	margin: 0 0 0 10px;
}
	
#program .infoList .info {
	margin-right: 31px;
	padding: 0 8px 9px;
	width: 274px;
	float: left;
	position: relative;
	box-shadow: 1px 1px 8px #EBDC0F,-1px -1px 8px #EBDC0F;
	-moz-box-shadow: 1px 1px 8px #EBDC0F,-1px -1px 8px #EBDC0F;
	-webkit-box-shadow: 1px 1px 8px #EBDC0F,-1px -1px 8px #EBDC0F;
	behavior: url(js/pie.htc);
}

#program .infoList .info .img {
	position: absolute;
	top: -38px;
	right: -18px;
}

#program .infoList .info .title {
	padding: 14px 0 13px;
	text-align: center;
}

#program .infoList .info .textBox {
	padding: 15px;
	background-color: #FFF;
	text-align: left;
}

#program .infoList .info .textBox li {
	color: #595757;
	font-size: 18px;
	line-height: 1.95;
}

#program .infoList .info01 {
	background-color: #F28D01;
}

#program .infoList .info01 .textBox {
	padding: 32px 18px 33px;
}

#program .infoList .info01 .textBox li span {
	color: #F28D01;
}

#program .infoList .info02 {
	background-color: #0083CE;
}

#program .infoList .info02 .textBox li span {
	color: #0083CE;
}

#program .infoList .info03 {
	margin: 0;
	background-color: #67B82D;
}

#program .infoList .info03 .textBox {
	padding: 15px 5px 15px 10px;
}
	
#program .infoList .info03 .textBox li span {
	color: #67B82D;
}

#voice {
	padding: 60px 0 68px;
	background-color: #C3D608;
}

#voice .voiceBox {
	margin: 0 auto;
	width: 882px;
	position: relative;
}

#voice h2 {
	margin: 0 auto 50px;
	width: 265px;
	padding: 27px 0 23px;
	box-shadow: 1px 1px 8px #ABBD09,-1px -1px 8px #ABBD09;
	-moz-box-shadow: 1px 1px 8px #ABBD09,-1px -1px 8px #ABBD09;
	-webkit-box-shadow: 1px 1px 8px #ABBD09,-1px -1px 8px #ABBD09;
}

#voice .comWhiteBox {
	margin-bottom: 33px;
	border-radius: 5px;
}

#voice .imgBoxR .photoBox {
	float: right;
}

#voice .imgBoxR .textBox {
	padding-top: 13px;
	float: left;
	width: 710px;
}

#voice p {
	font-size: 15px;
	line-height: 1.8;
}

#voice .text {
	clear: both;
	margin-top: 21px;
	color: #595757;
	text-align: right;
}

#voice .comWhiteBox01 .text {
	margin-top: 0;
}

#overview {
	padding: 60px 0 40px;
	background-color: #FBC000;
}

#overview .overviewBox {
	margin: 0 auto;
	width: 930px;
	position: relative;
}

#overview h2 {
	margin: 0 auto 45px;
	width: 500px;
	padding: 27px 0 23px;
	box-shadow: 1px 1px 8px #DFAB00,-1px -1px 8px #DFAB00;
	-moz-box-shadow: 1px 1px 8px #DFAB00,-1px -1px 8px #DFAB00;
	-webkit-box-shadow: 1px 1px 8px #DFAB00,-1px -1px 8px #DFAB00;
}

#overview .textBox {
	margin-bottom: 46px;
	position: relative;
	text-align: center;
}

#overview .textBox .img01 {
	position: absolute;
	left: -135px;
	bottom: 66px;
}

#overview .textBox .img02 {
	position: absolute;
	right: -82px;
	bottom: 58px;
}

#overview .textBox .text {
	margin-bottom: 30px;
	font-size: 19px;
	font-weight: bold;
	line-height: 1.95;
	letter-spacing: 0.5px;
}

#overview .textBox p {
	font-size: 17px;
	line-height: 2.2;
	letter-spacing: 1px;
}

#overview .comWhiteBox {
	margin-bottom: 51px;
	padding: 31px 30px 29px;
}

#overview .comWhiteBox .title {
	margin: 0 0 41px 0;
	padding-bottom: 23px;
	text-align: center;
	background: url(../images/index/line01.gif) repeat-x left bottom;
}

#overview .comWhiteBox .inner .textImg {
	padding: 10px 0 0 13px;
	float: left;
}

#overview .comWhiteBox .inner .photoList {
	width: 577px;
	float: right;
}

#overview .photoList {
	margin-top: -17px;
}

#overview .photoList li {
	margin-top: 17px;
	width: 273px;
	float: left;
}

#overview .photoList li p {
	margin: 5px 0 0 5px;
	font-size: 12px;
}

#overview .photoList li .ttl {
	display: block;
	color: #F08800;
	font-size: 14px;
	letter-spacing: -0.5px;
	margin-left: -8px;
}

#overview .comWhiteBox01 {
	margin-bottom: 21px;
	padding: 33px 30px 53px;
}

#overview .notes {
	margin-left: 7px;
	font-size: 13px;
	line-height: 1.7;
}

#schedule {
	padding: 60px 0 53px;
	background-color: #C65299;
}

#schedule .scheduleBox {
	margin: 0 auto;
	width: 930px;
	position: relative;
}

#schedule h2 {
	margin: 0 auto 60px;
	width: 500px;
	padding: 27px 0 23px;
	box-shadow: 1px 1px 8px #B7498E,-1px -1px 8px #B7498E;
	-moz-box-shadow: 1px 1px 8px #B7498E,-1px -1px 8px #B7498E;
	-webkit-box-shadow: 1px 1px 8px #B7498E,-1px -1px 8px #B7498E;
}

#schedule .tabBox {
	width: 453px;
	float: left;
}

#main .tableType {
	width: 100%;
	border-collapse: collapse;
}

#main .tableType td,
#main .tableType th {
	padding: 11px 5px 11px;
	font-size: 16px;
	text-align: center;
	line-height: 1.6;
	vertical-align: middle;
	border: 1px solid #C8C8C8;
	background-color: #FFF;
	font-weight: normal;
}

#main .tableType th {
	background-color: #E1E5EC;
}

#schedule .tabBox .wid01 {
	width: 40%;
}

#schedule .tabBox .wid02 {
	width: 21%;
}

#schedule .tabBox .wid03 {
	width: 39%;
}

#schedule .tabBox01 {
	float: right;
}

#schedule p {
	margin: 20px 8px 0;
	color: #FFF;
	font-size: 13px;
}

#guideline {
	padding: 62px 0 63px;
	background-color: #0073C0;
}

#guideline .guidelineBox {
	margin: 0 auto;
	width: 930px;
}

#guideline h2 {
	margin: 0 auto 60px;
	width: 266px;
	padding: 27px 0 23px;
	box-shadow: 1px 1px 8px #006AB0,-1px -1px 8px #006AB0;
	-moz-box-shadow: 1px 1px 8px #006AB0,-1px -1px 8px #006AB0;
	-webkit-box-shadow: 1px 1px 8px #006AB0,-1px -1px 8px #006AB0;
}

#guideline .tableType th {
	width: 26%;
}

#guideline .tableType td {
	padding-left: 15px;
	width: 74%;
	text-align: left;
}

#guideline .tableType td .note {
	padding-left: 1em;
	display: block;
	text-indent: -1em;
}

#guideline .tableType td li {
	padding: 0 0 5px 1.5em;
	text-indent: -1.5em;
}

#entry {
	padding: 66px 0 76px;
	background-color: #EA4E59;
}

#entry .entryBox {
	margin: 0 auto;
	width: 930px;
	text-align: center;
}

#entry h2 {
	margin: 0 auto 42px;
	width: 266px;
	padding: 27px 0 23px;
	box-shadow: 1px 1px 8px #D64650,-1px -1px 8px #D64650;
	-moz-box-shadow: 1px 1px 8px #D64650,-1px -1px 8px #D64650;
	-webkit-box-shadow: 1px 1px 8px #D64650,-1px -1px 8px #D64650;
}

#entry p {
	margin-bottom: 28px;
	color: #FFF;
	font-size: 19px;
	font-weight: bold;
}

@media screen and (min-width: 0) and (max-width: 750px)  {
	.mainVisualBox .foo li img {
		width: 100%;
		height: auto;
	}
	
	.mainVisualBox .textImg {
		padding: 9px 0 2px;
		background-size: 17px 9px;
	}
	
	.mainVisualBox .text {
		padding: 5px 5px 3px 0;
		font-size: 10px;
	}
	
	.mainVisualBox .foopage {
		margin: 0;
		bottom: 3px;
		left: 85%;
	}
	
	.mainVisualBox .textImg img {
		width: 78%;
		height: auto;
	}
	
	.mainVisualBox .foopage a {
		margin: 1px;
		width: 5px;
		height: 5px;
		background-size: 5px 5px;
	}
	
	.mainVisualBox .foopage a.selected {
		background-size: 5px 5px;
	}
		
	.spBrSpan {
		display: block;
	}
	
	#consept {
		padding: 20px 15px 0;
		background: #23BAEF url(../images/index/sp_consept_bg.jpg) no-repeat center bottom;
		background-size: 575px 377px;
	}
	
	#consept .conseptBox {
		padding-bottom: 68px;
		width: auto;
	}
	
	#consept img {
		width: 100%;
	}

	#consept h2 {
		margin-bottom: 21px;
		background: none;
		box-shadow: none;
	}
	
	#consept .pTtl {
		margin-bottom: 10px;
	}
	
	#consept p {
		margin: 0 5px;
		font-size: 10px;
		line-height: 2.4;
	}

	#consept .text {
		margin-top: 17px;
		font-size: 10px;
	}
	
	#consept .img01 {
		position: absolute;
		left: -52px;
		bottom: -13px;
	}
	
	#consept .img01 img {
		width: 98px;
	}
	
	#consept .img02 {
		position: absolute;
		right: -15px;
		bottom: -8px;
	}
	
	#consept .img02 img {
		width: 45px;
	}

	#program {
		padding: 26px 20px 28px;
	}

	#program .programBox {
		width: auto;
	}

	#program h2 {
		margin: 0 0 29px;
		padding: 12px 0;
	}

	#program .infoList {
		margin: 0 12px;
	}
		
	#program .infoList .info {
		margin: 0 0 15px;
		padding: 2%;
		width: auto;
		float: none;
		display: table;
		width: 96%;
	}
	
	#program .infoList .info .img {
		margin-top: -25px;
		top: 50%;
		right: auto;
		left: -25px;
	}
	
	#program .infoList .info .img img {
		width: 50px;
	}
	
	#program .infoList .info .title {
		width: 39%;
		padding: 0 0 0 4%;
		text-align: left;
		display: table-cell;
		vertical-align: middle;
	}
	
	#program .infoList .info .title img {
		margin-left: 15px;
	}
	
	#program .infoList .info .textBox {
		padding: 0;
		text-align: left;
		display: table-cell;
		vertical-align: middle;
	}

	#program .infoList .info .textBox ul {
		padding: 4px 4px;
	}
	
	#program .infoList .info .textBox li {
		font-size: 10px;
		line-height: 1.8;
	}

	#program .infoList .info01 .textBox {
		padding: 0;
	}
	
	#program .infoList .info03 {
		margin: 0;
	}
	
	#program .infoList .info03 .textBox {
		padding: 0;
	}
	
	#voice {
		padding: 27px 18px 25px;
	}

	#voice .voiceBox {
		width: auto;
	}

	#voice h2 {
		margin-bottom: 26px;
		width: auto;
		padding: 13px 0 7px;
	}
	
	#voice h2 img {
		width: 70px;
	}
	
	#voice .comWhiteBox {
		margin-bottom: 15px;
		padding: 10px 10px 7px;
		border-radius: 3px;
	}
	
	#voice .imgBoxR .photoBox {
		float: none;
		text-align: right;
	}
	
	#voice .imgBoxR .photoBox img {
		width: 28px;
	}
	
	#voice .imgBoxR .textBox {
		padding-top: 0;
		float: none;
		width: auto;
	}

	#voice p {
		font-size: 10px;
		line-height: 1.8;
	}
	
	#voice .text {
		margin: -12px 30px 0 0;
	}

	#voice .comWhiteBox01 .text {
		margin: -12px 30px 0 0;
	}

	#overview {
		padding: 30px 18px 25px;
	}
	
	#overview .overviewBox {
		width: auto;
	}
	
	#overview h2 {
		margin-bottom: 30px;
		width: auto;
		padding: 12px 0 8px;
	}
	
	#overview h2 img {
		width: 102px;
	}
	
	#overview .textBox {
		margin: 0 0 66px;
	}

	#overview .textBox .img01 {
		position: absolute;
		left: -39px;
		bottom: -115px;
		z-index: 100;
	}
	
	#overview .textBox .img01 img {
		width: 120px;
	}

	#overview .textBox .img02 img {
		width: 75px;
	}
	
	#overview .textBox .img02 {
		position: absolute;
		right: -18px;
		bottom: -105px;
		z-index: 100;
	}

	#overview .textBox .text {
		margin: 0 -9px 15px;
		font-size: 12px;
		line-height: 1.8;
	}

	#overview .textBox p {
		margin: 0 -5px;
		font-size: 10px;
		line-height: 2.4;
	}

	#overview .comWhiteBox {
		margin-bottom: 18px;
		padding: 15px 12px 13px;
	}
		
	#overview .comWhiteBox .title {
		margin: 0 0 17px;
		padding-bottom: 11px;
		background: url(../images/index/line01.gif) repeat-x left bottom;
		background-size: 2px 1px;
	}
	
	#overview .comWhiteBox .title img {
		width: 49px;
	}
	
	#overview .comWhiteBox .inner .textImg {
		margin: 0 34px 44px 93px;
		padding: 0;
		float: none;
	}

	#overview .comWhiteBox .inner .textImg img {
		width: 100%;
	}

	#overview .comWhiteBox .inner .photoList {
		width: auto;
		float: none;
	}
		
	#overview .photoList {
		margin-top: -12px;
	}
	
	#overview .photoList li {
		margin-top: 12px;
		width: 100%;
		float: none;
		display: table;
	}

	#overview .photoList li p {
		margin-top: 0;
		padding-top: 12px;
		font-size: 10px;
		display: table-cell;
		width: 47%;
		vertical-align: top;
	}
	
	#overview .photoList li .ttl {
		margin-bottom: 2px;
		font-size: 11px;
		letter-spacing: 0;
	}

	#overview .photoList li .line {
		padding-left: 7px;
		display: block;
		float: left;
	}

	#overview .photoList li .line2 {
		clear: both;
		display: block;
	}

	#overview .photoList li .photo {
		padding-right: 2%;
		display: table-cell;
		width: 55%;
		vertical-align: middle;
	}
	
	#overview .photoList li img {
		width: 100%;
	}
	
	#overview .photoList li:nth-child(2n) {
		float: none !important;
	}
	
	#overview .comWhiteBox01 .inner .textImg {
		margin-bottom: 35px;
	}

	#overview .comWhiteBox01 {
		margin-bottom: 7px;
	}
	
	#overview .notes {
		margin: 0 0 5px 15px;
		padding-left: 1em;
		text-indent: -1em;
		font-size: 9px;
		line-height: 1.5;
	}
	
	#overview .notes:last-child {
		margin-bottom: 0;
	}

	#schedule {
		padding: 35px 18px 15px;
	}
	
	#schedule .scheduleBox {
		width: auto;
	}

	#schedule h2 {
		margin-bottom: 27px;
		width: auto;
		padding: 12px 0 8px;
	}
	
	#schedule h2 img {
		width: 115px;
	}
	
	#schedule .section {
		margin: 0 13px;
	}

	#schedule .tabBox {
		width: auto;
		float: none;
	}

	#main .tableType td,
	#main .tableType th {
		padding: 7px 5px 8px;
		font-size: 10px;
		color: #595757;
		line-height: 1.5;
	}

	#schedule .tabBox01 {
		float: none;
	}
	
	#schedule .tabBox01 tr:first-child {
		display: none;
	}
	
	#schedule .tabBox01 tr:nth-child(2) td {
		border-top: none;
	}
	
	#schedule p {
		margin: 8px -5px 0;
		font-size: 9px;
	}

	#guideline {
		padding: 34px 18px 30px;
	}
	
	#guideline .guidelineBox {
		width: auto;
	}

	#guideline h2 {
		margin-bottom: 25px;
		width: auto;
		padding: 12px 0 8px;
	}
	
	#guideline h2 img {
		width: 60px;
	}

	#guideline .section {
		margin: 0 13px;
	}
		
	#guideline .tableType td,
	#guideline .tableType th {
		padding: 6px 10px 6px;
	}

	#guideline .tableType th {
		width: 100%;
		float: left;
		box-sizing: border-box;
		border-bottom: none;
	}
	
	#guideline .tableType td {
		width: 100%;
		float: left;
		box-sizing: border-box;
		border-bottom: none;
	}
	
	#guideline .tableType td li:last-child {
		padding-bottom: 3px;
	}

	#entry {
		padding: 35px 18px 19px;
	}

	#entry .entryBox {
		width: auto;
	}

	#entry h2 {
		margin-bottom: 23px;
		width: auto;
		padding: 12px 0 8px;
	}
	
	#entry h2 img {
		width: 60px;
	}
	
	#entry p {
		margin-bottom: 8px;
		font-size: 11px;
	}

	#entry .link {
		margin: 0 58px;
	}
	
	#entry .link img {
		width: 100%;
	}

}