@charset "utf-8";

/* body -------------------------- */
html, body {
	width: 100%;
	height: 100%;
	margin: 0px;
	padding: 0px;
	color: #555;
	font-size: 100%;
	-webkit-text-size-adjust: 100%; /*iPhone版Safari*/
	-ms-text-size-adjust: 100%; /*iPhone版Safari*/
	line-height: 0em;
	letter-spacing: 0.1em;
	font-family: Meiryo, メイリオ, 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', arial, helvetica, sans-serif;
}
ul,li,ol {
	list-style: none;
	margin: 0;
	padding: 0;
}
table {
	border-collapse: collapse; border-spacing: 0; border: 0;
}
img {
	border: none;
}
h1, h2, h3, h4, div, p {
	margin: 0;
	padding: 0;
}
input {
	margin: 0;
	padding: 0;
	border: 0;
}

/* margin -------------------------- */
.mt20 {margin-top:20px !important;}
.mt25 {margin-top:25px !important;}
.mt30 {margin-top:30px !important;}
.mt35 {margin-top:35px !important;}
.mt40 {margin-top:40px !important;}
.mt50 {margin-top:50px !important;}
.mt60 {margin-top:60px !important;}
.mb20 {margin-bottom:20px !important;}
.mb30 {margin-bottom:30px !important;}
.mb50 {margin-bottom:50px !important;}

/* text -------------------------- */
.txt_red{
color:#dd0000;
}

/* hover -------------------------- */
a:hover img{
opacity: 0.6;
filter: alpha(opacity=60);
-moz-opacity:0.6;
}

/* header -------------------------- */
#header {
    width: 100%;
	height: 100px;
	max-width: 1080px;
	min-width: 1080px;
	margin: 0 auto;
}
#header h1 {
	padding: 29px 0 0 10px;
	float: left;
}
#header .headercontact {
	padding: 27px 10px 0 0;
	float: right;
}
#header .headercontact ul {
	display: table;
}
#header .headercontact li {
	display: table-cell;
}
#header .headercontact li:first-child {
	padding-right: 20px;
}

/* main -------------------------- */
#main {
	width: 100%;
	min-width: 1080px;
	height: 650px;
	background: rgba(237,249,247,1.00);	
	background-repeat: no-repeat;
	background-position: center center;	
	text-align: center;
}
#main .txt {
	height: 189px;
	padding-top: 122px;
}
#main .menu {
	display: table;
	max-width: 1080px;
	min-width: 1080px;
	margin: 0 auto;
	padding-top: 123px;
}
#main .menu li{
	display: table-cell;
	width: 20%;
	margin: 0;
}
#main .menu li a {
	display: block;
	padding-top: 30px;
	text-align: center;
	height: 186px;
}
#main .menu li:nth-child(1){
	background: #ef7d67;
}
#main .menu li:nth-child(2){
	background: #edbf47;
}
#main .menu li:nth-child(3){
	background: #86bd55;
}
#main .menu li:nth-child(4){
	background: #68becb;
}
#main .menu li:nth-child(5){
	background: #7392d0;
}

/* read -------------------------- */
.read {
	width: 100%;
	max-width: 1080px;
	min-width: 1080px;
	margin: 0 auto;
	padding: 80px 0;
	text-align: center;
	line-height: 2.5em;
}

/* category -------------------------- */
.category-bg {
	width: 100%;
	min-width: 1080px;
	background-color: #86ceb4;
}
#category1 {
	width: 1080px;
	margin: 0 auto;
	background-image: url(../images/category_image1.png);
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
#category2 {
	width: 1080px;
	margin: 0 auto;
	background-image: url(../images/category_image2.png);
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
#category3 {
	width: 1080px;
	margin: 0 auto;
	background-image: url(../images/category_image3.png);
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
#category4 {
	width: 1080px;
	margin: 0 auto;
	background-image: url(../images/category_image4.png);
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
#category5 {
	width: 1080px;
	margin: 0 auto;
	background-image: url(../images/category_image5.png);
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
.category-txt1 {
	width: 520px;
	color: #FFF;
	padding: 0 0 40px 20px;
	line-height: 2.5em;
}
.category-txt2 {
	width: 510px;
	color: #FFF;
	padding: 0 0 40px 570px;
	line-height: 2.5em;
}


/* contact -------------------------- */
.contact {
	width: 100%;
	min-width: 1080px;
	margin: 0 auto;
	padding: 80px 0;
	text-align: center;
}
.contact ul {
	display: table;
	margin: 60px auto 0;
}
.contact li {
	display: table-cell;
}
.contact li:first-child {
	padding-right: 60px;
}

/* contact -------------------------- */
.contact2 {
	width: 100%;
	min-width: 1080px;
	margin: 0 auto;
	padding: 80px 0;
	text-align: center;
	background-color: #edf9f7;
}
.contact2 ul {
	display: table;
	margin: 60px auto 0;
}
.contact2 li {
	display: table-cell;
}
.contact2 li:first-child {
	padding-right: 60px;
}

/* concept -------------------------- */
.concept {
	width: 100%;
	min-width: 1080px;
	margin: 0 auto;
	padding: 80px 0;
	text-align: center;
	line-height: 2.5em;
	background-color: #edf9f7;
	background-image: url(../images/concept_image.jpg);
	background-position: top;
	background-repeat: no-repeat;
}

/* teacher -------------------------- */
.teacher-bg {
	width: 100%;
	min-width: 1080px;
	background-color: #86ceb4;
}
.teacher-bg .teacher {
	width: 1080px;
	margin: 0 auto;
	background-image: url(../images/teacher_image.png);
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
.teacher-bg .teacher .txt{
	width: 510px;
	color: #FFF;
	padding: 60px 0 60px 570px;
	line-height: 2.5em;
}

/* point -------------------------- */
.point {
	width: 1080px;
	padding: 80px 0;
	margin: 0 auto;
	line-height: 2.5em;
}
.point ul {
	display: table;
	margin: 0 auto;
}
.point li {
	display: table-cell;
	padding-right: 75px;
}
.point li:last-child {
	padding-right: 0;
}

/* title -------------------------- */
.title {
	width: 100%;
	min-width: 1080px;
	height: 75px;
	padding: 45px 0 0;
	text-align:center;
	background-color: #86ceb4;
}

/* subtitle -------------------------- */
.subtitle {
	width: 100%;
	min-width: 1080px;
	text-align:center;
	margin-bottom: 30px;
}
.subtitle2 {
	width: 100%;
	min-width: 1080px;
	text-align:center;
	margin: 80px 0 30px;
}

/* content -------------------------- */
.content {
	width: 100%;
	max-width: 1080px;
	min-width: 1080px;
	margin: 0 auto;
	padding: 50px 0 80px;
	text-align: center;
	line-height: 2.5em;
}

/* table -------------------------- */
table {
	border-collapse: collapse;
	width: 100%;
	font-size: 90%;
}
table th,
table td {
	padding: 12px;
	border: 1px solid #d7dbe0;
	text-align:center;
	font-weight: normal;
}
table th {
	background-color: #f7f8f9;
	width: 25%;
	text-align:left;
}
.tdb {
	background-color: #edfaf5;
}
.tdl {
	text-align:left;
}
.td2 {
	background-color: #faedf2;
	text-align:center;
	color: #dd0000;
	font-size: 110%;
}

/*contactform -------------------------- */
.contact-image {
	width: 100%;
	min-width: 1080px;
	height: 250px;
	background-image: url(../images/contact_image.jpg);
	background-repeat: no-repeat;
	background-position: center center;
}
.contactform {
	width: 1080px;
	padding: 50px 0;
	margin: 0 auto;
	text-align:center;
	line-height: 2.5em;
}
.contacttable {
	border-collapse: collapse;
	width: 100%;
	font-size: 90%;
	margin-top: 30px;
}
.contacttable th,
.contacttable td {
	padding: 12px;
	border: 1px solid #d7dbe0;
	text-align:left;
	font-weight: normal;
}
.contacttable th {
	background-color: #f7f8f9;
	width: 30%;
	text-align:left;
}
.form_txt1 {
	border: 0;
	padding: 5px;
	border: solid 1px #d7dbe0;
	width: 60%;
}
.form_txt2 {
	border: 0;
	padding: 5px;
	border: solid 1px #d7dbe0;
	width: 30%;
}
.form_txt3 {
	border: 0;
	padding: 5px;
	border: solid 1px #d7dbe0;
	width: 90%;
}
.privacy {
	width: 1080px;
	height: 240px;
	border: 1px solid #d7dbe0;
    overflow-y: scroll;
	margin-top: 20px;
	font-size: 90%;
	line-height: 2.2em;
}
.privacy dl {
	margin: 20px 0 0;
	font-size: 1em;
	text-align: left;
}
.privacy dd {
	margin: 0 0 20px 10px;
}
.privacy p:first-child {
	margin-top: 0;
}

/*button -------------------------- */
.button1 {
	display: inline-block;
	padding:0 80px;
	height: 54px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;
	background-color: #3bb293;
	background-image: url(../images/arrow.png);
	background-repeat: no-repeat;
	background-position: 90%;
	color: #fff;
	margin-top: 50px;
}
.button1:hover {
	background-color: #89d1be;
}
.button2 {
	display: inline-block;
	padding:0 80px;
	height: 54px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;
	background-color: #3bb293;
	background-image: url(../images/arrow2.png);
	background-repeat: no-repeat;
	background-position: 10%;
	color: #fff;
	margin-top: 50px;
}
.button2:hover {
	background-color: #89d1be;
}


/*pagetop -------------------------- */
#fixedTop {
	text-decoration: none;
    right: 20px;
    bottom: 20px;
    width: 60px;
    height: 60px;
    line-height: 60px;
    color: #fff;
    font-size: 24px;
    text-align: center;
    display: none;
    background: #555555;
	opacity: 0.5;
    position: fixed;
    z-index: 777;
    -webkit-transform: translateZ(0);
}
#fixedTop:hover {
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    opacity: 0.3;
}

/*footer -------------------------- */
#footer {
	width: 100%;
	padding: 50px 0;
	text-align: center;
	font-size: 70%;
}


