body{
  margin:0;
  font-size:16px;
  font-family:Verdana,sans-serif;
  /* background-color: #f5f5f5; */
  
  text-align: center;
}

header{
  height:48px;
  margin:0;
  /* background-color: #4763c2; */
  background-color: #009adc;
  display: flex;
  color:white;
  width:cover;
  max-width: 1000px;
  margin: 0 auto;
}

.cp_navi {
	background-color: #009adc;
	/* border: 1px solid #dedede; */
	/* border-radius: 4px; */
	/* box-shadow: 0 2px 2px -1px rgba(0, 0, 0, 0.055); */
	/* color: #888888; */
  color:white;
	display: block;
	/* margin: 1em 1%; */
	overflow: hidden;
	width: 100%;
  text-align: left;
}
.cp_navi ul {
	margin: 0;
	padding: 0;
  height:48px;
}
.cp_navi ul li {
	display: inline-block;
	list-style-type: none;
	-webkit-transition: all 0.2s;
	        transition: all 0.2s;
}
.cp_navi > ul > li > a > .caret {
	border-top: 4px solid #aaaaaa;
	border-right: 4px solid transparent;
	border-left: 4px solid transparent;
	content: '';
	display: inline-block;
	height: 0;
	width: 0;
	vertical-align: middle;
	-webkit-transition: color 0.1s linear;
	        transition: color 0.1s linear;
}
.cp_navi > ul > li > a {
	/* color: #aaaaaa; */
  color:white;
	display: block;
	line-height: 48px;
	padding: 0 10px;
	text-decoration: none;
}
.cp_navi > ul > li:hover {
	/* background-color: rgb(218, 60, 65); */
  opacity: 0.7;
  /* background-color: rgba( 0, 154, 220, 0.8); */
  background-color: #c9e7f5;
}
.cp_navi > ul > li:hover > a {
	color: rgb( 255, 255, 255 );
}
.cp_navi > ul > li:hover > a > .caret {
	border-top-color: rgb( 255, 255, 255 );
}
.cp_navi > ul > li > div {
	background-color: rgb(218, 60, 65);
	border-top: 0;
	border-radius: 0 0 4px 4px;
	box-shadow: 0 2px 2px -1px rgba(0, 0, 0, 0.055);
	display: none;
	margin: 0;
	opacity: 0;
	position: absolute;
	width: 165px;
	visibility: hidden;
	-webkit-transiton: opacity 0.2s;
	       transition: opacity 0.2s;
}
.cp_navi > ul > li:hover > div {
	display: block;
	opacity: 1;
	visibility: visible;
}
.cp_navi > ul > li > div ul > li {
	display: block;
}
.cp_navi > ul > li > div ul > li > a {
	color: #ffffff;
	display: block;
	padding: 12px 24px;
	text-decoration: none;
}
.cp_navi > ul > li > div ul > li:hover > a {
	background-color: rgba( 255, 255, 255, 0.1);
}

.heading{
  font-size: 24px;
}

.logo{
  height:48px;
}

.inq{
  line-height: 48px;
  width:220px;
  margin:0 8px 0 auto;
}

.wtl{
  font-size: 24px;
  padding-top:8px;
}

.head-container{
  background-color: #CDE6F4;
  padding-bottom:8px;
  width:cover;
  max-width:1000px;
  margin:0 auto;
}

.details-container{
  background-color: #CDE6F4;
}

.btn{
  color:white;
  background-color: #f37053;
  text-decoration: none;
  height:48px;
  width:240px;
  display: block;
  line-height: 48px;
  padding:0 5px 0 5px;
  font-weight: bold;
  cursor: pointer;
  border-radius: 4px;
  margin:8px auto 23px;
  box-shadow:0 3px rgba(246,150,121,0.8);
}

.btn:hover{
  opacity:0.8;
}

.btn:active{
  margin-top:11px;
  margin-bottom:20px;
  box-shadow: none;
}

.classes{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.classes::after{
  display: block;
  content:"";
  width:calc(33.3% - 32px);
}

.cla{
  background-color: white;
  width:calc(33.3% - 32px);
  margin-bottom:24px;
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.3);
  border-top: 10px solid #009adc;
  padding:8px 0 0;
}

.cla p:nth-child(2){
  font-weight: bold;
}

.cla p:nth-child(3){
  margin-bottom:0px;
  text-align: left;
}

.cla p:nth-child(4){
  margin-top:0px;
}

.class-container{
  margin:0 6.5px;
}

.explain-class p{
  margin-top: 4px;
}

.catch{
  width:100%;
}

.container{
  width:100%;
  margin:0 auto;
  max-width: 1000px;
}

.recommended{
  display: flex;
  justify-content: space-between;
}

.columns h2{
  margin: 0;
}

/* .recommended div{
  width:calc(50% - 32px)
} */

.detail{
  height:100px;
  line-height: 100px;
  margin:0;
  color:#009adc;
}


.details-container{
  padding-bottom:16px;
}

.features ul{
  list-style-type: none;
  padding:0;
  margin:0;
}

dl{
  display: flex;
  width:100%;
}

.enrollment dt{
  background-color: #009adc;
  line-height: 105px;
  padding: 0 20px;
  color:white;
}

.enrollment dd{
  background-color: white;
  margin:0;
  width:100%;
  padding-left:24px;
  text-align: start;
}

dl:last-child{
  margin-bottom:0;
}

.number{
  font-size:32px;
}

.enrollment{
  padding:0;
}

.feature{
  background-color: white;
  padding:16px 40px 16px 16px;
  margin-bottom:20px;
  display: flex;
  justify-content: space-between;
  text-align: start;
}

.feat{
  width:760px;
}

.feature h1{
  color:#009adc;
}

#step-btn{
  margin-top:16px;
}

#step-btn:active{
  margin-top: 19px;
}

.contents{
  font-size: 24px;
}

.gutto > h1{
  text-align: center;
  margin-top: 0;
}

.pot{
  width:calc(50% - 16px);
  height:160px;
  border:2px solid #c9e7f5;
  border-radius: 4px;
  margin-bottom:16px;
}

.content{
  display: flex;
  text-align: left;
  /* height:359px; */
}

#math{
  /* border-bottom:1px solid #009adc; */
  text-align: left;
  width:100%;
  margin:0 auto;
  max-width: 1000px;
}

#math h1{
  font-size: 24px;
  color:#009adc;
  margin:10px 0;
}

#exercise{
  width:100%;
  margin:0 auto;
  max-width: 1000px;
}

#memory{
  width:100%;
  margin:0 auto;
  max-width: 1000px;
}

.pic-memory{
  margin:56px 32px 0 0;
}

#penmanship{
  width:100%;
  margin:0 auto;
  max-width: 1000px;
}

.content h1{
  font-size: 24px;
  color:#009adc;
  margin:10px 0;
}

.pic-math{
  float:left;
}

.pic-exercise{
  float:right;
  margin:46px 0 0 32px;
}

.schedule h1{
  margin-bottom: 8px;
}

.schedule{
  padding-bottom: 20px;
}

.letter{
  overflow: hidden;
  zoom:1;
  /* letter-spacing:0.15em; */
  
  margin:0;
}

.columns{
  /* columns: 2;
	column-rule: 1px solid #cdcdcd;
	column-gap: 2em; */
  display: flex;
  justify-content: space-between;
}

.column{
  text-align: center;
  width:50%;
}

.column h2{
  font-size: 16px;
}

.teacher-name{
  text-align: right;
}

.mark{
  background-color: #Ff0;
  /* background-color: #c9e7f5; */
  font-weight: bold;
  /* color:red; */
}

.letter:first-letter{
  float: left;
  line-height: 1;
  font-size: 250%;
  padding-right: 5px;
}

.explain-class {
  margin-top:32px;
}

.explain-class h2{
  text-align: center;
  margin:32px 0 0;
}

.content-exercise{
  flex-direction: row-reverse;
}

.exe-container{
  /* border-bottom:1px solid #009adc; */
  width:cover;
  background-color: #dfdfdf;
  padding-top: 16px;
}

.content-exercise h1{
  font-size: 24px;
  color:#009adc;
  margin:10px 0;
}

.content-exercise p{
  text-align: left;
}

.explain-content>p{
  margin:0;
}

.contents-container>p{
  font-weight: bold;
  font-size: 24px;
  margin:32px auto 8px;
}

.explain-content{
  width:calc(100% - 416px);
}

.pic{
  width:400px;
}

.teachers{
  width:100%;
  margin:0 auto;
  max-width: 1000px;
}

.teacher{
  /* display: flex; */
  display: grid;
  grid-template-columns: 150px 240px 1fr;
  text-align: left;
  margin: 0 auto 24px;
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.3);
  border-top: 5px solid #009adc;
  position: relative;
}

/* .intros{
  width:110px;
  /* padding-left: 16px; */
/* } */
/* 
.intro-container{
  display: flex;
  padding:4px 0;
} */

.intro p{
  margin: 4px 4px 0 0;
}

.teachers-container{
  padding:0;  
}

.name{
  /* width:350px; */
  padding-left:16px;
}

.name h1{
  font-size: 24px;
  margin:0;
  line-height:24px;
  width:180px;
}

.name p{
  position: absolute;
  bottom: 0;
  margin-bottom:8px;
}

.furigana{
  font-size: 12px;
  padding-top: 4px;
  text-decoration: none;
}

.teacher-img{
  width:150px;
  height:150px;
}

.introduce p{
  margin:0 0 3px;
}

.access{
  display: flex;
  text-align: left;
  justify-content: space-between;
}

.access-container{
  background-color: #c9e7f5;
  padding-bottom: 1px;
}

.access-container h1{
  padding:20px 0 10px;
  margin:0;
}

.access-info dt{
  background-color: #009adc;
  padding: 0 20px;
  color:white;
  width:140px;
  padding:0 8px;
}

.access-info dd{
  background-color: #c9e7f5;
  margin:0;
  width:100%;
  padding-left:24px;
  text-align: start;
}

.access-info table{
  width:600px;
  margin-bottom:20px;
}

.access-info tr{
  padding:4px auto 4px 4px;
}

.access-info tr td:first-child{
  background-color: #009adc;
  color: white;
  /* padding:0 4px; */
}

tbody{
  background-color: white;
}

.schedule table{
  width:100%;
}

.schedule th{
    background-color: #009adc;
    color:white;
    width:14.3%;
}

.schedule td{
  background-color: #c9e7f5;
  line-height:1;
}

.time{
  font-size: 12px;
}

footer{
  background-color: grey;
  height:40px;
}

footer p{
  line-height:40px;
  font-size: 12px;
  margin-top: 0;
}

@media(max-width:1000px){
  .cla{
    width:calc(50% - 32px);
  }
}