h1 {
  color: #08294d;
  text-align: center;
  margin-top: 20px;
  margin-bottom: 40px;
  font-size: 36px;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-style: normal;
	line-height: 1.4em;
}
h2 {
  font-size: 18px;
  margin-bottom: 20px;
  margin-top: 60px;
  background-color: #45688C;
  padding: 10px 20px;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #fff;
	text-align: center;
}
.lead{
	text-align: center;
font-family: source-han-sans-japanese, sans-serif;
font-weight: 500;
font-style: normal;
}
.corse_name{
	text-align: center;
	font-size: 18px;
	line-height: 1.8em;
	margin-bottom: 40px;
}
.corse_name span{
	font-size: 16px;
}
.corse_name a{
	text-decoration: underline;
	text-underline-offset:3px;
}
.corse_name_basic a{
	color: #00873c!important;
}
.corse_name_stepup a{
	color: #8f0108!important;
}

.corse_name_special a{
	color: #001c58!important;
}

.corse_name_spring a{
	color: #f792ac!important;
}


.categories{
	border: 3px #7d7db1 solid;
	border-radius: 5px;
	padding: 20px 40px;
	margin-bottom: 20px;
}
.categories dl{
	margin: 40px 0;
}
.camp_name{
	font-size: 21px;
	margin-bottom: 5px;
	border: 1px solid;
	padding: 10px 20px;
}
.category_name{
text-align: center;
	font-size: 30px;
	margin-bottom: 15px;
	margin-top: 15px;
}

.camp{
	margin-bottom: 80px;
}
.camp:last-of-type{
	margin-bottom: 40px;
}
.basic{
	border-color: #00873c;
}
.basic h3{
	color: #00873c;
}
.basic dt{
	color: #fff;
	background-color: #00873c;
}
.stepup{
	border-color: #8f0108;
}
.stepup h3{
	color: #8f0108;
}
.stepup dt{
		color: #fff;
	background-color: #8f0108;
}
.special{
	border-color: #001c58;
}
.special h3{
			color: #001c58;
}
.special dt{
			color: #fff;
	background-color: #001c58;}

.spring {
		border-color: #f792ac;
}
.spring h3{
	color: #f792ac;
}
.spring dt{
				color: #fff;
	background-color: #f792ac;
}


.camp_cation{
	border: solid 1px #000;
	padding: 10px;
	text-align: center;
	line-height: 1.6em;
	margin: 40px 0 80px;
}

.appli_ul{
	display: table;
	margin: 20px 0;
}
.appli_li{
	display: table-cell;
	padding: 0 20px 0 0;
	font-size: 16px;
	font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.appli_btn{
	background-color: #7d7db1;
	color: #fff;
	padding: 5px 20px;
}


/*オープンボックス*/
.op_box{ 
display: none; 
}

.box-open_wrp{
	text-align: center;
	margin-top: 20px;
}

.box-open{
	text-decoration: underline;
	text-underline-offset:3px;
	color:#002392;
text-align: center;
cursor: pointer;
display: block;
margin: 0 auto;
}
.box-open::after{/* 閉じている時 */
content: "▼";
position: absolute;
}
.box-open.active::after{/* 開いている時 */
content: "▲";
}

/*コース内容*/
.course_summary{
	width:100%;
	margin-top:20px;
}

.course_summary dt{
	font-size:24px;
	border:#003567 solid 1px;
	padding:5px 30px;
	color:#003567;
	display: inline-block;
}

.course_summary dd{
	font-size:18px;
	margin-bottom:1px;
	font-weight:bold;
	font-family: ヒラギノUD角ゴ W4 JIS2004;
	line-height: 2em;
}

.course_summary dd:first-of-type{
	font-size:16px;
	line-height:2em;
	margin-bottom:65px;
	font-weight: normal;
}

.calender_wrp{
	text-align: center;
	margin-bottom: 40px;
}
.calender_wrp a{
	margin: 20px;
	text-decoration: underline;
	text-underline-offset:3px;
}

/*コース日程テーブル*/
table{
	width: 100%;
}
table tr th{
	border: 1px #fff solid;
	padding: 5px 20px;
	text-align: center;
	background-color: #C7C7C7;
	line-height:1.6em;
}
table tr td{
	border: 1px #C7C7C7 solid;
	padding: 5px 10px;
	text-align: center;
	line-height:1.6em;
	height: 40px;
}
table tr td span{
	font-size: 14px;
}
/*table tr td a{
	text-decoration: underline;
	text-underline-offset:3px;
	color: #001AFF
}
*/
table tr td a{
	background-color: #002392;
	color: #fff;
	border-radius: 3px;
	padding: 3px 10px;
}
table tr td a:hover{
	opacity: 0.6;
}
.appli_cution{
	font-size: 14px;
	color: #f00;
}

@media only screen and (max-width:640px){

	.categories{
	display: inherit;
}
	.category_name{
	display: inherit;
	padding: 5px 10px;
	width: inherit;
	height: inherit;

}
.category_detail{
	display: inherit;
		padding: 5px 0px;
}
	.camp_cation{
		text-align: left;
	}
	.categories{
		padding: 20px 10px;
	}
	.calender_wrp a{
		display: block;
		margin: 10px 0;
	}
}