body {
	background: #111;
}
.contact {
	position: absolute;
	top: 0;
	width: 100%;
	margin-top: 5px;
	font-family: "M PLUS Rounded 1c";
}
	.contact .canon {
		font-size: 90%;
		color: #fff;
		float: left;
	}
	.contact ul {
		float: right;
	}
	.contact ul li.obi {
		float: left;
		color: #fff;
		font-size: 85%;
	}
	.contact ul li.obi:hover {
		opacity: 0.5;
	}
	.contact ul li.obi:after {
		content:"";
		margin-right: 20px;
		margin-left: 5px;
	}
header {
	margin-top: 30px;
	background-position-y: 0px;
}

	h1 {
		position: absolute;
	}
	h1 img {
		width: 50%;
	}
	ul.headerMenu {
		position: absolute;
		right: 0;
	}
	ul.headerMenu li {
		padding: 20px 10px 20px 20px;
		text-align: center;
		color: #fff;
		float: left;
	}
	ul.headerMenu li::after {
		content:"▶";
		float: right;
		font-size: 60%;
		margin-left: 10px;
	}
	ul.headerMenu li:hover {
		opacity: 0.5;
	}
		.headerMenu-c {
			background: #00a0e8;
		}
		.headerMenu-a {
			background: #313131;
			font-family: 'Noto Serif JP', serif;
		}
	
	#contents {
		background-color: #fdf8f0;
		font-family: "M PLUS Rounded 1c";
	}
	.courseheader {
		padding: 150px 0 30px;
		border-bottom: 3px solid #63ac22;
		width: 1100px;
    margin: auto;
	}
	.courseheader h2 {
		font-size: 300%;
		text-align: center;
	}
	.courseheader p {
		text-align: center;
	}
	.coursebody {
		width: 1100px;
		margin: auto;
	}
	.course-list {
			display: flex;
			flex-direction: row;
			flex-wrap: wrap;
			justify-content: space-between;
			align-items: stretch;
			margin-top: 30px;
	}
	.detail .description h3 a {
    font-size: 24px;
    font-weight: 500;
    color: #333333;
}
	.course-list .course-item {
    width: 550px;
    border-bottom: 1px solid #cccccc;
    padding-bottom: 50px;
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: stretch;
    box-sizing: border-box;
}
.course-list .course-item .detail {
	width: 320px;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: stretch;
}
.box-wrap .course-list .course-item .detail .description h3 {
	font-size: 24px;
	font-weight: 500;
	color: #333333;
}
.course-list .course-item figure {
	margin-left: 30px;
}
.course-list .course-item figure img {
	max-width: 200px;
  max-height: 250px;
}
.course-list .course-item:nth-child(odd) figure {
	padding-right: 50px;
}
.course-list .course-item:nth-child(n + 3) {
	margin-top: 50px;
}
.course-list .course-item .detail .description h3 a {
	text-decoration: none;
	pointer-events: none;
	vertical-align: middle;
	line-height: 1;
}
.course-list .course-item .detail .description .icon-list {
	margin-top: 15px;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
}
.icon-list li.s1,
span.es01 {
	background-color: #fecb2f;
}
.icon-list li.s2,
span.es02 {
	background-color: #f8a131;
}
span.es03 {
	font-size: 90%;
}
.detail .description .icon-list li + li {
	margin-left: 2px;
}
.course-list .course-item .detail .description .icon-list li {
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	height: 20px;
	line-height: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 2px 5px;
}
.course-list .course-item .detail .description .text {
	margin-top: 10px;
	font-size: 100%;
	line-height: 1.5;
	margin-bottom: 10px;
}
p.subject {
	font-size: 90%;
}
.detail .btn a {
	background-color: #63ac22;
	box-shadow: 0px 3px 0px 0px #477b19;
	border-bottom-color: #63ac22;
}
.detail .btn a {
	width: 180px;
	height: 40px;
	border-radius: 6px;
	text-decoration: none;
	color: #fff;
	font-size: 15px;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	text-indent: -10px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
}
.detail .btn a::after {
	content: "";
	width: 6px;
	height: 6px;
	display: block;
	border-left: 2px solid #fff;
	border-top: 2px solid #fff;
	transform: rotate(135deg);
	position: absolute;
	top: 50%;
	right: 15px;
	margin-top: -3px;
}
.courseDetails:first-child {
	border-top: none;
}
.courseDetails {
	padding: 50px 0;
	border-top: 1px solid #999;
}
.course-list .course-item:nth-child(even) .detail {
	padding-left: 50px;
	border-left: 1px dotted #999999;
}
.labels {
	display: table-cell;
	vertical-align: middle;
}
.tlt h3 {
	display: table-cell;
	vertical-align: middle;
	font-size: 58px;
	color: #333;
	font-weight: normal;
	padding-right: 15px;
}
.label {
	font-size: 130%;
	font-weight: normal;
	padding: 3px 5px;
	line-height: 1;
	vertical-align: middle;
}
.courseDetails .table {
	margin-top: 30px;
}
.table .des {
	font-size: 18px;
	margin-bottom: 10px;
	font-weight: bold;
}
.table .td:first-child {
	font-weight: bold;
	background-color: #eee;
	width: 160px;
}
.table .td:last-child {
	background-color: #fff;
}
.table .tr {
	display: table;
	width: 100%;
	font-size: 14px;
	border-top: 1px solid #d6d6d6;
}
.table .tr.last {
	border-bottom: 1px solid #d6d6d6;
}
.table .td {
	display: table-cell;
	vertical-align: middle;
	font-size: 14px;
	padding: 20px;
	line-height: 2;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.table .foot {
	font-size: 12px;
	margin-top: 10px;
}
.con {
	margin: 30px 0;
}
.p-sigleMedia__body {
	display: table-cell;
	vertical-align: top;
	padding-right: 25px;
}
h3.p-sigleMedia__heading {
	color: #22ac38;
	font-size: 180%;
	margin-bottom: 10px;
}
.p-singeSchool__text,
.p-sigleMedia__text {
	font-size: 90%;
}
.p-sigleMedia__text--round {
	font-size: 14px;
	color: #333;
	line-height: 1.7;
}
.p-sigleMedia__image {
	width: 300px;
	display: table-cell;
	vertical-align: top;
	padding-top: 50px;
}
.p-sigleMedia {
	display: table;
	width: 100%;
	margin-bottom: 50px;
}
.mb50 {
	margin-bottom: 50px !important;
}
table.courseDay {
	border-collapse: collapse;
	table-layout: fixed;
	border: 1px solid #999;
	width: 100%;
	text-align: center;
	margin-bottom: 10px;
}
.courseDay td,
.courseDay th {
	border: 1px solid #999;
}
.courseDay th {
	background: #eee;
}
th.tTitle {
	font-size: 90%;
	font-weight: bold;
}
.courseDay td {
	background: #fff;
}
table.plans {
	table-layout: auto;
}
.plans td {
	text-align: left;
	padding: 20px;
}
span.st-text {
	font-size: 120%;
	color: #56AACF;
	font-weight: bold;
}
.c-shadow-right img {
	max-height: 200px;
	max-width: 300px;
}
#contactLink{
	width: 100%;
	height: 60px;
	position: fixed;
	left: 0;
	bottom: 0;
	background: #ff9933;
	opacity: 0.8;
	z-index: 3;
	}
	#contactLink a{
		display: block;
    width: 330px;
    margin: auto;
    text-align: center;
    font-size: 120%;
    color: #fff;
    text-decoration: underline;
    padding: 20px 0;
	}
	.spContact {
		display: none;
	}
	.experienceheader {
		background: url(../images/50bef1b91d1bea296bfac27db1cb5439_m.jpg) no-repeat;
    height: 600px;
		background-size: cover;
		background-position-y: -400px;
	}
	span.titlecharacter {
		background: #ff9933;
		padding: 20px 30px;
		box-shadow: 0 3px 1px #bbb;
	}
	.experienceheader h2 {
    width: auto;
    margin: auto;
    font-size: 300%;
    text-align: center;
		padding-top: 420px;
		color: #fff;
	}
	.recommendation {
    padding: 20px;
	}
	.recommendationBox {
		width: 800px;
    margin: auto;
    background: #fff;
	}
	.recommendationBox {
		padding: 20px;
	}
	.recommendation h3 {
		text-align: center;
		font-size: 150%;
    font-weight: bold;
		color: #ff9933;
		margin-bottom: 15px;
	}
	.recommendationBox ul {
		padding-left: 100px;
	}
	.recommendationBox ul li {
		position: relative;
		line-height: 180%;
		font-size: 120%;
		font-weight: bold;
	}
	.recommendationBox ul li::after {
		display: block;
		content: '';
		position: absolute;
		top: .5em;
		left: -1.3em;
		width: 8px;
		height: 3px;
		border-left: 2px solid #ff9933;
		border-bottom: 2px solid #ff9933;
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	.aboutCanon,
	.AskedQuestions {
		background: #fff;
	}
	.aboutCanonBox,
	.aboutFlow,
	.AskedQuestionsBox {
		width: 900px;
		margin: auto;
	}
	.aboutCanonBox h3,
	.aboutFlowBox h3,
	.AskedQuestionsBox h3 {
		font-size: 180%;
    text-align: center;
    padding: 50px 0 20px;
	}
	.aboutCanonBox ul {
		overflow: hidden;
		padding-bottom: 50px;
	}
	.aboutCanonBox li {
		width: 50%;
		float: left;
		overflow: hidden;
		margin-top: 10px;
	}
	.aboutCanonDes {
		float: left;
		margin-left: 20px;
		width: 75%;
	}
	figure.abouticon {
		float: left;
    width: 80px;
    height: 60px;
    font-size: 80%;
    padding-top: 20px;
    text-align: center;
	}
	figure.abouticon img {
		width: 40px;
	}
	figure.about01 {
		background: #88c139;
	}
	figure.about02 {
		background: #884ae1;
	}
	figure.about03 {
		background: #bf5fdf;
	}
	figure.about04 {
		background: #ef402b;
	}
	.about01 {
		background: #88c139;
	}
	.imgFlow img {
		border-radius: 50%;
		width: 100%;
	}
	.aboutFlowBox ul {
		overflow: hidden;
		padding-bottom: 50px;
	}
	.aboutFlowBox li {
		width: 20%;
		float: left;
		margin-right: 57px;
		position: relative;
	}
	.aboutFlowBox li:last-child {
		margin-right: 0;
	}
	.aboutFlowBox li:after {
		content: "";
		width: 0;
		height: 0;
		border-left: 15px solid #555;
		border-top: 40px solid transparent;
		border-bottom: 40px solid transparent;
		position: absolute;
		top: 100px;
    right: -35px;
	}
	.aboutFlowBox li:last-child:after {
		content: "";
		width: 0;
		height: 0;
		border-left: none;
		border-top: none;
		border-bottom: none;
		position: absolute;
	}
	.AskedQuestionsBox dt {
		color: #f65678;
		font-weight: bold;
		font-size: 150%;
		margin-bottom: 15px;
	}
	.AskedQuestionsBox dt::before {
		content: "Q";
    background: #f65678;
    border-radius: 50%;
    padding: 2px 10px;
		color: #fff;
		margin-right: 10px;
	}
	.AskedQuestionsBox dl {
    padding: 30px 0;
    border-bottom: 1px solid #ccc;
}
@media screen and (min-width:480px) {
	#nav-drawer {
		display:none;
	}
	}
	@media screen and (max-width: 479px) { /*ウィンドウ幅が0～479pxの場合にcssを適用*/
		header {
			background: none;
			height: 0;
		}
		h1 {
			display: none;
		}
		ul.headerMenu,
		.contact ul {
			display:none;
		}
		#nav-drawer {
			position: relative;
		  }
		#nav-content li {
			padding: 10px;
			border-bottom: 1px solid #eee;
		}
		#nav-content li::after {
			content: "▶";
			float: right
		}
		
		  /*チェックボックス等は非表示に*/
		  .nav-unshown {
			display:none;
		  }
		  
		  /*アイコンのスペース*/
		  #nav-open {
			display: inline-block;
			width: 30px;
			height: 22px;
			vertical-align: middle;
			right: 0;
			position: absolute;
			top: -23px;
		  }
		  
		  /*ハンバーガーアイコンをCSSだけで表現*/
		  #nav-open span, #nav-open span:before, #nav-open span:after {
			position: absolute;
			height: 3px;/*線の太さ*/
			width: 25px;/*長さ*/
			border-radius: 3px;
			background: #fff;
			display: block;
			content: '';
			cursor: pointer;
		  }
		  #nav-open span:before {
			bottom: -8px;
		  }
		  #nav-open span:after {
			bottom: -16px;
		  }
		  
		  /*閉じる用の薄黒カバー*/
		  #nav-close {
			display: none;/*はじめは隠しておく*/
			position: fixed;
			z-index: 99;
			top: 0;/*全体に広がるように*/
			left: 0;
			width: 100%;
			height: 100%;
			background: black;
			opacity: 0;
			transition: .3s ease-in-out;
		  }
		  
		  /*中身*/
		  #nav-content {
			overflow: auto;
			position: fixed;
			top: 0;
			left: 0;
			z-index: 9999;/*最前面に*/
			width: 90%;/*右側に隙間を作る（閉じるカバーを表示）*/
			max-width: 330px;/*最大幅（調整してください）*/
			height: 100%;
			background: #fff;/*背景色*/
			transition: .3s ease-in-out;/*滑らかに表示*/
			-webkit-transform: translateX(-105%);
			transform: translateX(-105%);/*左に隠しておく*/
		  }
		  
		  /*チェックが入ったらもろもろ表示*/
		  #nav-input:checked ~ #nav-close {
			display: block;/*カバーを表示*/
			opacity: .5;
		  }
		  
		  #nav-input:checked ~ #nav-content {
			-webkit-transform: translateX(0%);
			transform: translateX(0%);/*中身を表示（右へスライド）*/
			box-shadow: 6px 0 25px rgba(0,0,0,.15);
		  }
		.animation {
			display: none;
		}
		.news {
			padding: 10px 0;
		}
		.block-news {
			width: 100%;
		}
		.block-news .list-news > li dl, .block-news .list-news > li dl > dt, .block-news .list-news > li dl > dd {
			display: block;
		}
		.block-news .list-news > li {
			padding: 0;
		}
		.block-news .list-news > li dl > dt {
			margin-left: 1rem;
		}
		.contents_block02 {
			background: #eee;
			padding-top: 100px;
			padding-left: 0;
			padding-bottom: 100px;
		}
		.contents_block02_box h2 {
			font-size: 125%;
			text-shadow: 1px 2px 1px #fff;
			margin: 0;
			text-align: center;
		}
		p.about {
			font-size: 100%;
			padding: 10px 5vw 10px 5vw;
		}
		.childBox, .adultBox {
			width: 100%;
			float: none;
		}
		li.course-img {
			height: 100%;
		}
		.contents_block04_box h4 {
			width: 100%;
			top: 0;
			left: 0px;
			
			padding: 50px 0 50px;
			text-align: center;
		}
		.course-box {
			padding: 30px 50px;
		}
		.contents_block05 {
			padding: 50px 0 50px;
		}
		.contents_block05 h3 {
			font-size: 170%;
			margin-top: 20px;
		}
		.card {
			width: 100%;
			margin-right: 0;
		}
		.card_surface img {
			width: 100%;
			margin: auto;
		}
		.rss-list {
			width: auto;
			float: none;
			margin-right: 0px;
			min-height: auto;
			max-height: auto;
			height: auto;
		}
		.rss-description {
			display: none;
		}
		.rss-list-box {
			padding: 50px 5vw 50px;
		}

		a:click .card_surface {
			transform:rotateY(90deg);
			transition: transform 300ms;
		}
		a:hover .card_reverse {
			transform:rotateY(0deg);
			transition: transform 300ms 150ms;
		}
		.voice2 {
			margin-top: 0;
		}
		.card {
			margin-top: 50px;
		}
		.card_reverse {
			font-size: 90%;
		}
		.contents_block05 {
			overflow: 
		}
		.contents_block06 h3 img {
			max-width: 200%;
			position: relative;
			right: 300px;
			display: block;
		}
		.contents_block06 h3 {
			overflow: hidden;
		}
		.coursebody {
			width: 98%;
		}
		.courseheader {
			width: 100%;
			margin: auto;
		}
		.course-item figure {
			display: none;
		}
		.course-list .course-item {
			display: block;
		}
		.course-list .course-item:nth-child(even) .detail {
			padding-left: 0;
			border-left: none;
		}
		.course-list .course-item .detail {
			width: 100%;
			display: block;
		}
		.course-list .course-item {
			margin-top: 50px;
		}
		.courseheader {
			padding-top: 50px;
		}
		.detail .btn a {
			margin: auto;
		}
		.p-sigleMedia__image {
			display: none;
		}
		.p-sigleMedia__body {
			padding-right: 0;
		}
		.labels {
    　display: block;
		}
		.tlt h3 {
			display: block;
			font-size: 200%;
		}
		.label {
			font-size: 110%;
			padding: 0px 5px;
		}
		#contactLink a {
			text-align: left;
		}
		.spContact {
			display: block;
		}
		.pcContact {
			display: none;
		}
		.courseheader p {
			text-align: left;
			width: 95%;
			margin: auto;
		}
		.experienceheader {
			height: 100%;
			background-size: 100%;
			background-position-y: 0;
		}
		.experienceheader h2 {
			font-size: 100%;
			padding-top: 200px;
		}
		span.titlecharacter {
			padding: 8px 12px;
		}
		.recommendationBox {
			padding: 10px 0px;
		}
		.recommendationBox {
			width:98%;
		}
		.recommendation {
			padding: 20px 0;
		}
		.recommendationBox ul {
			padding-left: 35px;
		}
		.aboutCanonBox, .aboutFlow,
		.AskedQuestionsBox {
			width: 100%;
			margin: auto;
		}
		.aboutCanonBox li {
			float: none;
			width: 100%;
		}
		figure.abouticon {
			width: 20%;
			height: 20%;
		}
		.aboutCanonDes {
			margin-left: 5px;
			width: 78%;
		}
		.aboutCanonDes p {
			font-size: 90%;
		}
		.aboutFlowBox li {
			width: 98%;
			position: relative;
			margin: 0 auto 50px;
		}
		.imgFlow img {
			width: 35%;
			float: right;
			margin-top: 10px;
		}
		.aboutFlowDes {
			width: 60%;
			float: left;
			margin-left
		}
		.aboutFlowBox li:after {
			content: "";
			width: 0;
			height: 0;
			top: 110px;
   		left: 40%;
			text-align: center;
			border-left: 40px solid transparent;
			border-right: 40px solid transparent;
			border-top: 20px solid #555;
		}
		.AskedQuestionsBox dl {
			padding: 30px 3px;
		}
	}
