@charset "UTF-8";

html { font-size: 62.5%; }

body{
    font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
    font-size:1.6rem; font-weight: 500; font-style: normal; -webkit-text-size-adjust:100%; color: #00397a; -webkit-font-smoothing: antialiased; overflow-x: hidden;
}

.raleway{font-family: 'Raleway', sans-serif;}

a{ color:#00397a; text-decoration: none; transition: .2s cubic-bezier(0.44, 0.18, 0.49, 0.99); }
/*a:visited {color: #555; text-decoration: none;}*/

* {box-sizing: border-box; /*min-height: 0; min-width: 0;*/}
.sp{ display: none; }
.sp_main_copy{ display: none; }
.pc{ display: block; }
.menu_sp{ display: none; }

.red_txt{color: #cb000f;}
.pink_txt{color: #e63273;}
.yellow_txt{color: #ff0;}

.fadein_l{opacity: 0; transition: all 1s;}
.fadeInLeft{ opacity: 1; animation: fadeL .8s ease-in-out;}
@keyframes fadeL {
   0% { opacity: 0; transform: translateX(2rem); }
  100% { opacity: 1; transform: translateX(0); }
}

.fadein_r{opacity: 0; transition: all 1s;}
.fadeInRight{opacity: 1; animation: fadeR .8s ease-in-out;}
@keyframes fadeR {
   0% { opacity: 0; transform: translateX(-2rem); }
  100% { opacity: 1; transform: translateX(0); }
}

.fadein_u{opacity: 0; transition: all 1s;}
.fadeInUp{ opacity: 1; animation: fadeU 1.2s ease-in-out;}
@keyframes fadeU {
   0% { opacity: 0; transform: translateY(-2rem); }
  100% { opacity: 1; transform: translateY(0); }
}


/* header ======================================================================================================================== */

header { position: relative; width: 100%; height: 79px; background-color: #fff; }
header .inner { display:flex; }
header .inner .logo img { position: absolute; top: 49%; transform: translateY(-50%); left: 30px; width: 190px; height:auto; }
header .inner .logo_top img { left: 50%; transform: translate(-50%,-50%);}
header nav{ position: absolute; right: 0; display: flex; }
header nav .navi{ display: flex; align-items: center; width:auto; height: 74px; }
header nav .navi .navi-inner{ margin-right: 12px;}
header nav .navi .navi-inner a{ position: relative; display: flex; margin-right: 20px; color: #00397a; text-decoration: none; letter-spacing: 0.1rem; font-size: 1.5rem; transition: .5s; }
header nav .navi .navi-inner a:hover{ color: #119bde; transition: .5s;	}

.entry_btn { position: fixed; bottom: 30px; right: 40px; width: 190px; height: 190px; border-radius: 50%; z-index: 90; transition: .4s;}
.invisivle{ opacity: 0; z-index: 0; transition: .4s; }
.invisivle a{ pointer-events: none; }
.entry_btn a{ position: relative; display: inline-block; width:190px; height: 190px; color: #fff; background: #f141a9; font-size:3.2rem; border-radius: 50%; line-height: 1;}
.entry_btn a:hover{ background: #00afd9; }
.entry_btn a .btn_inner{ position: absolute; top:50%; left: 50%; transform: translate(-50%,-50%); text-align: center; }
.entry_btn a .s_txt{ font-size:1.8rem; font-weight: bold; font-feature-settings: "palt" 1; letter-spacing: 0.1rem;}


/* footer ======================================================================================================================== */

footer { padding-top: 170px;}
footer.top_footer { padding-top:0 ; }
footer .ft_inner { background-color: #00397a; padding: 65px 70px 55px; }
footer .ft_inner .wrapper{ position: relative; width: 100%; max-width: 1400px; margin:0 auto;}
footer .ft_inner .ft_menu { display:flex; margin-bottom: 170px; width: 100%; align-items: center; }
footer .ft_inner .ft_menu nav.fnav { display:inline-block; }
footer .ft_inner .ft_menu nav.fnav ul { position: relative; }
footer .ft_inner .ft_menu nav.fnav ul li { display: inline; line-height:2.2; letter-spacing: 0.2rem; margin-right: 30px;  }
footer .ft_inner .ft_menu nav.fnav ul li a{ color:#fff; font-size: 1.6rem; transition: .5s; }
footer .ft_inner .ft_menu nav.fnav ul li a:hover{ opacity:0.5; transition: .5s; }

footer .ft_inner .ft_address .ft_logo { margin-bottom: 17px; width: 200px; height: auto;}
footer .ft_inner .ft_address .ft_logo img{ width: 100%; height: auto; }
footer .ft_inner .ft_address p.fadd { display: inline; font-size: 1.3rem; line-height: 1.8; color:#fff;}
footer .ft_inner .copyright { display: inline; position: absolute; right: 0; bottom: 0;}
footer .ft_inner .copyright p { text-align: right; font-size: 1.1rem; color:#fff; }

footer #page_top { width: 55px; height: 55px; position: absolute; right:0; top: 0;}
footer #page_top a { position: relative; display: inline-block; width: 55px; height: 55px; background:#1c61a5; transition: .5s; }
footer #page_top a:hover { background:#1c61a5; }
footer #page_top a img{ position: absolute; width:13px; height: auto; top: 50%; left: 50%; transform: translate(-50%,-50%); }


/* TOP ======================================================================================================================== */

#main_contents{ width: 100%; }
#main_contents #container{ position:relative; width:100%; height:auto; }

.main_img { width: 100%; height: auto; min-height: 800px; /*object-fit:cover;*/ display: flex; justify-content: center; align-items: center; margin:0 auto; background: #e0eed0; }
.main_img img { width: 100%; height: auto; min-height: 770px; object-fit:cover; margin:0 auto;}


#main_contents section .wrapper{ width: 100% ; max-width: 1400px; padding: 0 100px; margin:0 auto; } 
#main_contents section h2{ font-size: 5.6rem; letter-spacing: 0.3rem; font-weight: 800; text-align: center;}
#main_contents section .jpn_ttl{ font-size: 1.7rem; line-height: 1.4; text-align: center; letter-spacing: 0.3rem; margin-top: 20px; }

#main_contents .cont_area{ position: relative; margin:60px auto 0; display: block; width: 100%;}
.cont_area .copy_area{ width: 100%;}
.cont_area .main_txt{ font-size: 5.8rem; line-height: 1.6; letter-spacing: 0.5rem; text-align: center; font-weight: 700;}
.cont_area .sub_txt{ font-size: 2rem; line-height: 1.9; margin-top: 50px; text-align: center;}
.highlight{ background: linear-gradient(transparent 85%, #ffff52 70%); }

.more_btn{ width:420px; height: 70px; margin: 70px auto 0;}
.more_btn a{ display: inline-block; width:420px; height: 70px; color: #fff; background: #e63273; font-size: 1.8rem; padding: 25px 10px 27px; text-align: center; border-radius: 10px; }
.more_btn a:hover{ opacity: .7; transition: .3s;}

.wide_btn {
margin:60px auto 0; 
width :100%; 
max-width:920px; 
display: -ms-grid; 
display: grid; 
grid-gap: 30px 3.5%; 
-ms-grid-columns: 1fr 3.5% 1fr; 
grid-template-columns: repeat(2, 1fr); 
-ms-grid-rows: auto; 
grid-template-rows: repeat(1, auto);
}.wide_btn > *:nth-child(1) {
-ms-grid-row:1;
-ms-grid-column:1;
}.wide_btn > *:nth-child(2) {
-ms-grid-row:1;
-ms-grid-column:3;
}

.wide_btn a{ display: inline-block; width:100%; height: 240px; color: #fff; background: #006f9c; font-size: 2.4rem; padding: 106px 10px 112px; text-align: center; border-radius: 10px; }
.wide_btn a.student{ background: #05a966; }
.wide_btn a:hover{ opacity: .7; transition: .3s;}


.form_btn a{ background: #adadad; pointer-events: none; }
._check a{ background: #e63273; pointer-events: auto; }
.copy_area a{ color:#00a7c3; text-decoration: underline; }

.service_area{display: flex; padding: 0 110px;}
.service_box{display: flex; }


#main_contents #about{ padding:180px 0 150px ; display: block; background: #fff7d2;}

.movie_area { text-align: center; margin: 100px auto 0; }
.movie_box { position: relative; width: 100%; padding-top: 56.25%; }
.movie_box iframe { position: absolute; top: 0; right: 0; width: 100%; height: 100%; }

.chirashi_box{width: 80%; height: auto; text-align: center; margin: 100px auto 0;}
.chirashi_img{margin-top: 40px;}
.chirashi_box img{width: 100%; height: auto;}


#main_contents #company {padding: 150px 0 150px; display: block; background: #fbf4b9;}
/*#main_contents #company .wrapper{ padding: 0 40px; }*/
.company_block{
margin:60px auto 0; 
width :100%; 
display: -ms-grid; 
display: grid; 
grid-gap: 30px 3.5%; 
-ms-grid-columns: 1fr 3.5% 1fr; 
grid-template-columns: repeat(2, 1fr); 
-ms-grid-rows: auto; 
grid-template-rows: repeat(1, auto);
}.company_block > *:nth-child(1){
-ms-grid-row:1;
-ms-grid-column:1;
}.company_block > *:nth-child(2){
-ms-grid-row:1;
-ms-grid-column:3;
}
.company_box{ padding: 60px 50px 72px; background: #019fec; border-radius: 10px; }
.bg_orange{ background: #eb6100 ;}
.company_ttl{ font-size: 2.8rem; line-height: 1.6; letter-spacing: 0.3rem; font-weight: 700; color: #fff; text-align: center; }
.small_ttl{ font-size: 1.6rem; letter-spacing: 0.1rem;}
.company_box .sub_txt{ color:#fff; text-align: left; margin-top: 40px;}


#main_contents #entry{ padding:180px 40px 150px ; display: block; background: #ffd9e4;}
#entry .policy_box{ margin-top:50px; padding: 20px 0; background: #fff6b8; text-align: center; border-radius: 10px; }
#main_contents #entry .wrapper{ padding: 100px 100px; background: #fff; border-radius: 10px; }




#main_contents #merit{ padding:150px 0 0; display: block; }
#main_contents #merit .cont_area .copy_area .ttl_img{ width: 50%; min-width: 560px; height: auto; }
#main_contents #merit .cont_area .copy_area .ttl_img img{ width: 100%; height: auto;}
#main_contents #merit .cont_area .merit_area{ width: 100%; height: auto; display: flex; margin-top:100px; }
#main_contents #merit .cont_area .merit_box{ position: relative; width: 31%; height: auto; margin-right: 3.5%; transition: .5s;}
#main_contents #merit .cont_area .merit_box:hover{ opacity: .7;}
#main_contents #merit .cont_area .merit_box:last-child{ margin-right: 0;}
#main_contents #merit .cont_area .merit_box .box_num{ position: absolute; width: 75px; height: auto; top:0; left: 50%; transform: translate(-50%,-48%);}
#main_contents #merit .cont_area .merit_box img{ width: 100%; height: auto; }
#main_contents #merit .cont_area .merit_box .box_img{ width: 100%; height: auto; line-height: 0;}
#main_contents #merit .cont_area .merit_box .box_txt{ background: #cb000f; }
#main_contents #merit .cont_area .merit_box .box_txt p{ padding: 30px 10px 35px 10px; font-size: 2.2rem; line-height: 1.6; text-align: center; color: #fff; }

#main_contents #bg_color{ position: relative; overflow: hidden; width: 100%; height: 100%; }
#main_contents #bg_color::before{ content: ''; position: absolute; bottom: 30%; left: 50%; width: 250%; height: 37%; background: #fcf0f1; transform-origin: left center; transform: rotate(-30deg) translateX(-50%); z-index: -1; }




/* KASO ======================================================================================================================== */

#main_contents_kaso #main_img { position: relative; width:100%; height:600px; margin-bottom: 150px;}
#main_contents_kaso #main_img:after {position: absolute; bottom: 0; left: 0; background: linear-gradient(180deg,transparent 80%,#333 100%,#333); display: block; content: ""; width: 100%; height: 100%;}
#main_contents_kaso #main_img img{ width:100%; height:auto; max-height: 600px ; /*object-fit: cover;*/ /*background-position: center center;*/}
#main_contents_kaso #main_img .ttl_area{ position: absolute; bottom: 60px; left:60px; z-index: 2;}
#main_contents_kaso #main_img .jpn_ttl{ position: relative; display: inline-block; font-size: 1.7rem; line-height: 1.4; color:#fff; background: #cb000f; letter-spacing: 0.3rem; margin-bottom: 11px; padding: 0 7px 1px 13px; }
#main_contents_kaso #main_img .jpn_ttl::after{ content: ""; position: absolute; top: 0; left: 100%; width: 0; height: 0; border-left:10px solid #cb000f; border-top:12px solid transparent; border-bottom:12px solid transparent; }
#main_contents_kaso #main_img .eng_ttl{ color: #fff; font-size: 5rem; letter-spacing: 0.3rem;}

#main_contents_kaso .under{ padding:120px 0 0 ; display: block; border-top: 1px solid #efefef; margin-top: 110px;}
#main_contents_kaso section .wrapper{ width: 100% ; max-width: 1400px; padding: 0 100px; margin:0 auto; } 
#main_contents_kaso section .wrapper .ttl_area{text-align: center;}
#main_contents_kaso section h2{ font-size: 5.6rem; color:#cb000f; letter-spacing: 0.3rem;}
#main_contents_kaso section .cont_area .copy_area{ text-align: center;}
#main_contents_kaso section .copy_area .main_txt{ font-size: 2.6rem; line-height: 1.6; margin-top:60px;}
#main_contents_kaso section .copy_area .sub_txt{ margin-top:40px; }
#main_contents_kaso section .cont_area p{ font-size: 1.8rem; line-height: 2; letter-spacing: 0.1rem;}
#main_contents_kaso section .jpn_ttl{ position: relative; display: inline-block; font-size: 1.7rem; line-height: 1.4; color:#cb000f; letter-spacing: 0.3rem; margin-top: 25px; }


