@charset "UTF-8";

/* ------------------------------------------- CSS Information 
 Style Info:     ブラウザスタイルのリセット設定
----------------------------------------------------------- */  
html{overflow-y:scroll;height:100%;} 
body,div,blockquote,pre,h1,h2,h3,h4,h5,h6,dl,dt,dd,ul,ol,li,table,th,td,form,input,textarea,fieldset{margin: 0;padding:0;}
h1,h2,h3,h4,h5,h6{font-size: 100%;font-weight: normal;}
table{border-collapse: collapse;border-spacing: 0;}
caption, th{text-align: left;}   
img,abbr,acronym,fieldset{border: none;}
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;}
hr,legend{display: none;}
object,embed{vertical-align: top;} 

/* ------------------------------------------- CSS Information 
 Style Info:     基本設定
----------------------------------------------------------- */
/*A Style*/  
a:link{text-decoration:underline;color:#ffec47;}
a:visited{text-decoration:none;color:#ffec47;}
a:hover{text-decoration:underline;color:#ffec47;}
a:active{text-decoration:none;color:#ffec47;}
.b{font-weight:bold;}
.ul{text-decoration:underline;}
.bg{background-color:#fff45c;}
.red{color:#ff0000;}
.big{font-size:20px;line-height:30px;}
@media only screen and (max-width:640px){.big{font-size:16px;line-height:24px;}}
/*----- image -----*/
img.all{display:block;margin:0 auto;padding:0;width:100%;max-width:640px;}
img.pc{display:block;margin:0 auto;padding:0;width:100%;max-width:960px;}
img.sp{display:none;margin:0 auto;padding:0;width:100%;max-width:640px;}
img.img_right{float:right;padding:0 0 10px 10px;width:30%;max-width:300px;}
@media only screen and (max-width:640px){
img.pc{display:none;}
img.sp{display:block;}
img.img_right{float:none;padding:0 0 20px 0;width:75%;max-width:300px;margin:0 auto;display:block;}
}
/*----- br -----*/
br.pc{display:block;}
br.sp{display:none;}
@media only screen and (max-width:640px){
br.pc{display:none;}
br.sp{display:block;}
}

/* ------------------------------------------- CSS Information 
 Style Info:     セールスレター型ホームページ詳細設定
----------------------------------------------------------- */
body{  
font-family:"メイリオ",Osaka,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック","MS PGothic",Arial,Sans-Serif;
color:#333333;
font-size:16px;
line-height:0;
text-align:center;
letter-spacing:0em;
height:100%;
}

/*header----------*/
header{
margin:0;
width:100%;
height:100%;
text-align:center;
background:url(../img/header_bg.png) no-repeat center center fixed;
background-size:cover;
display:table;
}
.header_img{
margin:0;
padding:0;
display:table-cell;
vertical-align:middle;
text-align:center;
}
.header_img img{
width:100%;
}

/*----- title_01 -----*/
.title_01{
width:100%;
margin:0;
padding:0;
background:#242e52;
}
/*----- contents_01 -----*/
.contents_01{
width:100%;
margin:0;
padding:0 0 60px 0;
background:url(../img/contents_01.png) no-repeat center center;
background-size:cover;
}
/*----- title_03 -----*/
.title_03{
width:100%;
margin:0;
padding:0;
background:#f8da08;
}
/*----- contents_02 -----*/
.contents_02{
width:100%;
margin:0;
padding:0 0 60px 0;
background:#eeeeee url(../img/contents_02.png) no-repeat center center;
background-size:cover;
}

/*----- contents_03 -----*/
.contents_03{
width:100%;
margin:0;
padding:30px 0 60px 0;
background:url(../img/contents_03.png) no-repeat center center fixed;
}
@media only screen and (max-width:768px){
.contents_03{
width:100%;
margin:0;
padding:30px 0;
background:url(../img/contents_03_sp.png) no-repeat center;
background-size:cover;
}
}

/*----- contents_04 -----*/
.contents_04{
width:100%;
margin:0;
padding:0 0 60px 0;
background:#eeeeee url(../img/contents_04.png) no-repeat center center;
background-size:cover;
}

/*----- textbox -----*/
.textbox{
padding:30px 0;
font-size:18px;
line-height:30px;
text-align:center;
}
.textbox p{
margin:0;
padding:0 0 30px 0;
}
@media only screen and (max-width:768px){
.textbox{
font-size:14px;
line-height:20px;
text-align:center;
}
.textbox p{
margin:0;
padding:0 0 20px 0;
}
}


/*----- curriculum -----*/
.curriculum{
width:100%;
max-width:960px;
margin:0 auto;
padding:0 0 60px 0;
}
.curriculum_wrapper{
width:100%;
padding:0 3.125%;
box-sizing:border-box;
}
.curriculum_box{
display:table;
width:100%;
background:#ffec47;
border-radius:10px;
margin:0 0 30px 0;
padding:30px 3.125%;
box-sizing:border-box;
}
.curriculum_img{
display:table-cell;
width:300px;
padding:0 0 0 30px;
vertical-align:middle;
box-sizing:border-box;
}
.curriculum_img img{width:100%;}
.curriculum_text{
display:table-cell;
font-size:16px;
line-height:24px;
text-align:justify;
margin:0;
padding:0;
}
.curriculum_text dt{
margin:0 0 20px 0;
padding:0 0 10px 0;
border-bottom:1px solid #252f53;
color:#252f53;
font-size:20px;
line-height:24px;
font-weight:bold;
text-align:center;
}
@media only screen and (max-width:768px){
.curriculum{padding:0 0 40px 0;}
.curriculum_wrapper{}
.curriculum_box{
display:block;
margin:0 0 20px 0;
padding:20px 3.125%;
}
.curriculum_img{
display:block;
width:240px;
padding:20px 0 0 0;
margin:0 auto;
}
.curriculum_img img{width:100%;}
.curriculum_text{
display:block;
font-size:14px;
line-height:20px;
text-align:justify;
margin:0;
padding:0;
}
.curriculum_text dt{
margin:0 0 20px 0;
padding:0 0 10px 0;
border-bottom:1px solid #252f53;
color:#252f53;
font-size:18px;
line-height:24px;
font-weight:bold;
text-align:center;
}
}

/*----- profile -----*/
.profile{
width:100%;
max-width:960px;
margin:0 auto;
padding:0 0 40px 0;
}
.profile_wrapper{
width:100%;
padding:0 3.125%;
box-sizing:border-box;
}
.profile_text{
font-size:16px;
line-height:24px;
text-align:justify;
margin:0;
padding:0;
}
.profile_text p{
margin:0;
padding:0 0 20px 0;
}
.profile_img01{
display:inline-block;
width:260px;
padding:0 30px 10px 0;
float:left;
}
.profile_img01 img{width:100%;}
.profile_dl{
font-size:16px;
line-height:24px;
text-align:justify;
width:100%;
padding:0;
box-sizing:border-box;
}
.profile_dl dt{
color:#252f53;
font-weight:bold;
margin:30px 0 10px 0;
padding:0 0 0 5px;
border-left:5px solid #252f53;
}
.profile_img02{width:100%;}
@media only screen and (max-width:768px){
.profile{padding:0;}
.profile_wrapper{}
.profile_img01{
display:block;
width:240px;
margin:0 auto;
padding:0 0 30px 0;
float:none;
}
.profile_img01 img{}
.profile_text,.profile_dl{
display:block;
font-size:14px;
line-height:20px;
}
.profile_text p{
margin:0;
padding:0 0 20px 0;
}
.profile_text br{display:none;}
.profile_dl dt{
color:#252f53;
font-weight:bold;
margin:20px 0 10px 0;
padding:0 0 0 5px;
border-left:5px solid #252f53;
}
}

/*----- service -----*/
.title_service{
font-size:16px;
line-height:24px;
border-left:5px solid #000000;
text-align:left;
color:#252f53;
font-weight:bold;
margin:40px 0 0 0;
padding:0 0 0 5px;
}
.service_pc{
display:table;
width:100%;
margin:20px auto 0 auto;
box-sizing:border-box;
text-align:center;
}
.service_pc th{
background:#242e52;
color:#ffffff;
font-size:14px;
line-height:20px;
text-align:center;
padding:10px;
}
.service_pc td{
font-size:14px;
line-height:20px;
text-align:center;
padding:10px;
background:#ffffff;
}
.free{
box-sizing:border-box;
border:3px solid #b7282e;
}
.service_sp{display:none;}
@media only screen and (max-width:768px){
.title_service{
font-size:14px;
line-height:20px;
}
.service_pc{display:none;}
.service_sp{
display:block;
margin:20px 0 0 0;
}
.service_sp dt{
background:#242e52;
color:#ffffff;
font-size:14px;
line-height:20px;
text-align:center;
padding:10px;
}
.service_sp dd{
font-size:14px;
line-height:20px;
text-align:center;
padding:10px;
background:#ffffff;
}
}

/*----- opt -----*/
.opt{
width:100%;
margin:0;
padding:0 0 60px 0;
text-align:center;
background:#252f53;
}
.opt_box{
width:100%;
max-width:800px;
margin:0 auto;
padding:0;
}
.opt_box form{
width:100%;
padding:0 3.125% 30px 3.125%;
box-sizing:border-box;
}
.opt_box form input[type=text]{
font-family: "ヒラギノ角ゴ Pro W3",Osaka,"メイリオ","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック","MS PGothic",Arial,Sans-Serif;
font-size:16px;
line-height:20px;
width:100%;
margin:0 0 20px 0;
padding:10px;
text-align:left;
border:1px solid #333333;
box-sizing:border-box;
}
.opt_box form input[type=image]{
width:100%;
max-width:720px;
margin:20px 0 0 0;
}
.opt_box ul{
text-align:justify;
margin:0 auto;
padding:0;
max-width:900px;
font-size:12px;
line-height:20px;
}
.opt_box ul.caution{
width:100%;
padding:0 3.125%;
box-sizing:border-box;
color:#eeeeee;
}
.opt_box li{list-style:none;}
.opt_box li:before{content:"※";}
.opt_box a{color:#eeeeee;}

@media only screen and (max-width:640px){
.opt_box form input[type=text]{
font-size:14px;
padding:10px 5px;
}
.opt_box ul{
text-align:justify;
font-size:12px;
line-height:16px;
}
}

/*footer----------*/
footer{
margin:0;
padding:30px 0;
width:100%;
font-size:12px;
color:#f5f5f5;
background:#000000;
border-top:1px solid #555555;
}
nav{
margin:0 auto;
padding:0 0 30px 0;
}
nav ul{
text-align:center;
font-size:12px;
line-height:20px;
padding:0 0 0 20px;
}
nav li{
display:-moz-inline-box;
display:inline-block;
/display:inline;
/zoom:1;
list-style-type:none;
padding: 0 20px 0 8px;
background: url(../img/footer.png) no-repeat left center;
}
nav a:link{color:#ffffff;text-decoration:none;}
nav a:visited{color:#eeeeee;text-decoration:none;}
nav a:hover{color:#eeeeee;text-decoration:underline;}
nav a:active{color:#eeeeee;text-decoration:none;}
.attention{
margin:0 auto;
padding:0 10px 20px 10px;
max-width:940px;
text-align:center;
font-size:12px;
line-height:20px;
}
.attention p{margin:0;padding:10px 0;}
address{
font-size:12px;
line-height:20px;
padding: 5px 15px;
}
@media only screen and (max-width:767px){
nav{
margin:0 auto 20px auto;
padding:0 0 30px 0;
}
nav ul{
text-align:center;
font-size:12px;
line-height:30px;
padding:0 0 0 20px;
}
nav li{
display:block;
/display:block;
/zoom:1;
list-style-type:none;
padding: 0;
background:none;
}
.attention{
margin:0 auto;
padding:0 10px 20px 10px;
max-width:940px;
text-align:justify;
font-size:12px;
line-height:20px;
}
.attention br,.sp_no{display:none;}
}




/* ------------------------------------------- CSS Information 
 Style Info:     アニメーション
----------------------------------------------------------- */
.sa{opacity:0;transition:all 1s ease;}
.sa.show{opacity:1;transform:none;}
.sa-lr{transform:translate(-100px, 0);}
.sa-rl{transform:translate(100px, 0);}
.sa-up{transform: translate(0, 100px);}
.sa-down{transform: translate(0, -100px);}
.zoomout{transform: scale(1.2);}
.fadein-left:before{
background:rgba(255,255,255,0.8);
position:absolute;
left:0;
right:0;
top:0;
bottom:0;
content:'';
pointer-events:none;
z-index:1;
}

.fadein-left{
transform:translate(-100px, 0);
overflow:hidden;
position:relative;
}

