@charset "UTF-8";

/* ------------------------------------------- CSS Information 
 Style Info: ブラウザスタイルのリセット設定
----------------------------------------------------------- */  
html{overflow-y: scroll;} 
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;}
.red{color:#dc3759;}
.big{font-size:20px;}
.small{font-size:14px;}
@media only screen and (max-width:750px){.big{font-size:16px;}.small{font-size:12px;}}
/*img*/
.img690{width:100%;max-width:690px;margin:0 auto;}
.pc{display:block;margin:0 auto;}
.sp{display:none;margin:0 auto;}
@media only screen and (max-width:750px){
.pc{display:none;}
.sp{display:block;}
}
/* text */
.text{margin:0;padding:0;font-size:16px;line-height:30px;}
.text p{margin:0;padding:0 0 30px 0;}
.text p:last-child{margin:0;padding:0;}
.text p.text_right{text-align:right;}
.text ul{margin:0 0 30px 0;padding:0;list-style:none;}
.text ul li{position:relative;padding:0 0 0 18px;font-weight:bold;}
.text ul li:before{content:"";position:absolute;padding:0;width:12px;height:12px;border-radius:50%;left:0;top:9px;background:#48af9e;}

@media only screen and (max-width:750px){
.text{font-size:14px;line-height:24px;}
.text p{margin:0;padding:0 0 20px 0;}
.text p:last-child{margin:0;padding:0;}
.text ul{margin:0 0 20px 0;}
.text ul li{padding:0 0 0 16px;}
.text ul li:before{top:5px;}
}
/*br*/
.br_sp{display:none;}
@media only screen and (max-width:750px){.br_sp{display:block;}}


/* ----------------------- CSS Information 
 Style Info: HTML/BODY
--------------------------------------- */
html,body{
width:100%;
height:100%;
margin:0;
padding:0;
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;
background:#f6f6f5;
letter-spacing:0em;
min-height:100%;
position:relative;
box-sizing:border-box;
}

/* ----------------------- CSS Information 
 Style Info: HEADER
--------------------------------------- */
header{
position:relative;
margin:0;
padding:0;
width:100%;
height:100%;
box-sizing:border-box;
text-align:center;
overflow:hidden;
}
.header_bg{
position:relative;
margin:0;
padding:0;
width:100%;
height:100%;
box-sizing:border-box;
text-align:center;
background:url(../img/header_left_pc.png) no-repeat left center,url(../img/header_bg_pc.png) no-repeat center;
background-size:cover,cover;
z-index:5;
}
.header_wrapper{
position:relative;
width:100%;
height:100%;
max-width:1280px;
margin:0 auto;
z-index:10;
}
img.header_img{
position:absolute;
top:0;
bottom:0;
left:0;
margin:auto auto auto 0;
padding:0 0 60px 0;
width:100%;
max-width:750px;
z-index:10;
}
img.scroll{
position:absolute;
top:0;
bottom:40px;
left:0;
right:0;
margin:auto auto 0 auto;
width:80px;
height:80px;
z-index:10;
-webkit-animation:scroll 1.5s infinite 0s linear alternate;
animation:scroll 1.5s infinite 0s linear alternate;
}
@-webkit-keyframes scroll{
0% {-webkit-transform:translate(0, 0) rotate(0deg);}
50% {-webkit-transform:translate(0, -10px) rotate(0deg);}
100% {-webkit-transform:translate(0, 0)rotate(0deg);}
}
@keyframes scroll{
0% {transform:translate(0, 0) rotate(0deg);}
50% {transform:translate(0, -10px) rotate(0deg);}
100% {transform:translate(0, 0)rotate(0deg);}
}
@media only screen and (max-width:750px){
header{}
.header_bg{
background:url(../img/header_left_pc.png) no-repeat center,url(../img/header_bg_sp.png) no-repeat center;
background-size:cover,cover;
}
.header_wrapper{}
img.header_img{}
img.scroll{
position:absolute;
top:0;
bottom:40px;
left:0;
right:0;
margin:auto auto 0 auto;
width:80px;
height:80px;
z-index:10;
-webkit-animation:scroll 1.5s infinite 0s linear alternate;
animation:scroll 1.5s infinite 0s linear alternate;
}
@-webkit-keyframes scroll{
0% {-webkit-transform:translate(0, 0) rotate(0deg);}
50% {-webkit-transform:translate(0, -10px) rotate(0deg);}
100% {-webkit-transform:translate(0, 0)rotate(0deg);}
}
@keyframes scroll{
0% {transform:translate(0, 0) rotate(0deg);}
50% {transform:translate(0, -10px) rotate(0deg);}
100% {transform:translate(0, 0)rotate(0deg);}
}

}


/* ----------------------- CSS Information 
 Style Info: VIDEO
--------------------------------------- */
.videobox{
position:absolute;
top:-50%;
left:-50%;
width:200%;
height:200%;
z-index:1;
}
.videobox video{
position:absolute;
top:0;
bottom:0;
left:0;
right:0;
margin:auto;
min-width:50%;
min-height:50%;
}
.videobox.video01{background:#000000;}
.videobox.video01 video{opacity:0.5;background:url(../video/header.png) no-repeat center;background-size:cover;}


/* ------------------------------------------- CSS Information 
 Style Info: main
----------------------------------------------------------- */
/* main -----*/
#main{}


/* ----------------------- CSS Information 
 Style Info: TITLE
--------------------------------------- */
.title{
position:relative;
width:100%;
margin:0 0 40px 0;
padding:0 0 40px 0;
opacity:0;
transition:all ease 1s;
}
.title.scrollin{opacity:1;}
.title:after{
content:"";
position:absolute;
display:block;
margin:0 auto 0 0;
padding:0;
width:0;
height:4px;
border:0;
background:#a6d7c3;
}
.title:after{bottom:0;}
.title.scrollin:after{animation:title_hr 0.5s linear both;}
@keyframes title_hr{0%{width:0%;}100%{width:100%;}}
.title h1{
display:block;
margin:0 auto;
padding:0 40px;
width:100%;
max-width:750px;
font-size:30px;
line-height:50px;
font-weight:bold;
text-align:left;
box-sizing:border-box;
}
@media only screen and (max-width:750px){
.title{
margin:0 0 30px 0;
padding:0 0 30px 0;
}
.title.scrollin{}
.title:after{margin:0 auto;}
@keyframes title_hr{0%{width:0%;}100%{width:100%;}}
.title h1{
padding:0 20px;
width:100%;
max-width:100%;
font-size:18px;
line-height:30px;
text-align:center;
}
}

/* ----------------------- CSS Information 
 Style Info: CONTENTS
--------------------------------------- */
.contents{
margin:0;
padding:0;
width:100%;
position:relative;
box-sizing:border-box;
}
#contents01{
background:#ffffff url(../img/contents01_bg_pc.png) no-repeat right top;
background-size:auto 100%;
}
#contents02{
background:#030308 url(../img/contents02_bg_pc.png) no-repeat right top;
background-size:auto 100%;
}
#contents03{
background:#ffffff url(../img/contents03_bg_pc.png) no-repeat right top;
background-size:auto 100%;
}
.contents .flexbox{
margin:0;
padding:0;
width:100%;
position:relative;
box-sizing:border-box;
display:flex;
flex-direction:reverse;
align-items:stretch;
}
.contents .textbox{
width:60%;
min-width:750px;
margin:0;
padding:80px 0;
box-sizing:border-box;
}
#contents02 .textbox{color:#f6f6f5;}
.contents .text{
margin:0 auto;
padding:0 40px;
width:750px;
text-align:left;
box-sizing:border-box;
}
#contents02 .text ul{margin:-30px 0 0 0;}
.contents .imgbox{
width:40%;
margin:0;
padding:0;
box-sizing:border-box;
position:relative;
}
.contents .imgbox img{display:none;}
@media only screen and (max-width:750px){
.contents{}
#contents01{
background:#ffffff url(../img/contents01_bg_sp.png) no-repeat center;
background-size:cover;
}
#contents02{
background:#030308 url(../img/contents02_bg_sp.png) no-repeat center;
background-size:cover;
}
#contents03{
background:#ffffff url(../img/contents03_bg_sp.png) no-repeat center;
background-size:cover;
}
.contents .flexbox{display:block;}
.contents .textbox{
width:100%;
min-width:320px;
padding:60px 0;
}
#contents02 .textbox{}
.contents .text{
padding:0 20px;
width:100%;
text-align:justify;
}
.contents .text br{display:none;}
#contents02 .text ul{margin:-20px 0 0 0;}
.contents .imgbox{display:none;}
.contents .imgbox img{display:none;}
}

/* ----------------------- CSS Information 
 Style Info: PROFILE
--------------------------------------- */
#profile{
position:relative;
width:100%;
margin:0;
padding:60px 30px;
background:#e7eeeb url(../img/profile_bg.png) no-repeat center;
background-size:cover;
box-sizing:border-box;
}
#profile .flexbox{
position:relative;
width:100%;
max-width:1280px;
margin:0 auto;
padding:0;
box-sizing:border-box;
display:flex;
flex-direction:reverse;
align-items:stretch;
}
#profile .textbox{
margin:0;
padding:0;
box-sizing:border-box;
flex:1;
}
#profile .title{margin:0 0 20px 0;padding:0 0 20px 0;}
#profile .title h1{
padding:0 0 0 30px;
max-width:100%;
font-size:20px;
line-height:30px;
color:#f6f6f5;
}
#profile .title:after{height:2px;}
#profile .text{
margin:0 auto;
padding:0 0 0 30px;
width:100%;
font-size:14px;
line-height:24px;
color:#f6f6f5;
text-align:justify;
box-sizing:border-box;
}
#profile .text p{padding:0 0 20px 0;}
#profile .text p:last-child{padding:0;}
#profile .text ul{margin:0 0 20px 0;}
#profile .text ul li{padding:0;}
#profile .text ul li:before{display:none;}
#profile .imgbox{
position:relative;
width:300px;
margin:0;
padding:0;
}
#profile .imgbox img{width:100%;}
@media only screen and (max-width:750px){
#profile{
padding:40px 0;
background:#e7eeeb url(../img/profile_bg.png) no-repeat center;
background-size:cover;
box-sizing:border-box;
}
#profile .flexbox{display:block;}
#profile .title{margin:0 0 20px 0;padding:0 0 20px 0;}
#profile .title h1{padding:0 20px;}
#profile .text{padding:0 20px;}
#profile .imgbox{display:none;}
#profile .imgbox img{}
.profile_img{width:50%;margin:0 auto 20px auto;}
}


/* --------------------------------- CSS Information 
 Style Info: OPT
------------------------------------------------- */
.opt{
margin:0;
padding:80px 0;
box-sizing:border-box;
text-align:center;
background:#e7eeeb url(../img/opt_bg.png) no-repeat center;
background-size:cover;
position:relative;
}
.apply{
position:relative;
width:100%;
max-width:960px;
margin:0 auto;
padding:0 40px;
box-sizing:border-box;
}
.apply .flexbox{
position:relative;
width:100%;
margin:0 auto 30px auto;
padding:0;
box-sizing:border-box;
display:flex;
flex-direction:reverse;
border:1px solid #a6d7c3;
}
.apply .textbox{
margin:0;
padding:0;
box-sizing:border-box;
flex:1;
display:flex;
align-items:center;
background:#ffffff;
}
.apply .text{
margin:0 auto;
padding:20px;
width:100%;
text-align:justify;
box-sizing:border-box;
}
.apply .imgbox{
width:160px;
margin:0;
padding:0;
display:flex;
align-items:center;
}
.opt_date .imgbox{
background:#002317 url(../img/opt_date_bg.png) no-repeat center;
background-size:cover;
}
.opt_how .imgbox{
background:#002317 url(../img/opt_how_bg.png) no-repeat center;
background-size:cover;
}
.apply .imgbox h2{
display:block;
width:100%;
margin:0;
padding:0;
font-size:18px;
line-height:20px;
font-weight:bold;
color:#ffffff;
}
.opt_box{
width:100%;
max-width:750px;
margin:0 auto;
padding:40px;
background:#d5e2de;
border-radius:10px;
box-sizing:border-box;
}
.opt_box form{
width:100%;
max-width:670px;
margin:0 auto;
padding:0;
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:18px;
line-height:30px;
width:100%;
margin:0 0 20px 0;
padding:10px;
text-align:left;
background:#f6f6f5;
border:1px solid #333333;
box-sizing:border-box;
}
.opt_box form input[type=image]{
width:100%;
margin:0 auto;
border-radius:10px;
box-shadow:2px 2px 4px 0px rgba(0,0,0,0.5);
}
.opt_box form input[type=image]:hover{opacity:0.5;box-shadow:0 0 4px 0px rgba(0,0,0,0.5);}
.opt_text{
width:100%;
max-width:670px;
margin:0 auto;
padding:30px 0 0 0;
font-size:12px;
line-height:20px;
text-align:justify;
color:#333333;
box-sizing:border-box;
}

@media only screen and (max-width:768px){
.opt{
margin:0;
padding:20px 0 0 0;
box-sizing:border-box;
text-align:center;
background:#e7eeeb url(../img/opt_bg.png) no-repeat center;
background-size:cover;
position:relative;
}
.apply{padding:0 20px;}
.apply .flexbox{
display:block;
margin:0 auto 20px auto;
border:1px solid #a6d7c3;
}
.apply .textbox{
width:100%;
display:block;
background:#ffffff;
}
.apply .text{}
.apply .imgbox{
display:block;
width:100%;
padding:20px;
box-sizing:border-box;
}
.opt_date .imgbox{
background:#002317 url(../img/opt_date_bg_sp.png) no-repeat center;
background-size:cover;
}
.opt_how .imgbox{
background:#002317 url(../img/opt_how_bg_sp.png) no-repeat center;
background-size:cover;
}
.apply .imgbox h2{font-size:14px;line-height:20px;}
.opt_box{
max-width:100%;
padding:20px;
border-radius:0;
}
.opt_box form{}
.opt_box form input[type=text]{
font-family: "ヒラギノ角ゴ Pro W3",Osaka,"メイリオ","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック","MS PGothic",Arial,Sans-Serif;
font-size:15px;
line-height:30px;
width:100%;
margin:0 0 10px 0;
padding:10px;
}
.opt_box form input[type=image]{border-radius:8px;}
.opt_box form input[type=image]:hover{}
.opt_text{padding:20px 0 0 0;}
}



/* ---------------------- CSS Information 
 Style Info: FOOTER
--------------------------------------- */
footer{
width:100%;
margin:0;
padding:0;
color:#d1d1d1;
background:#121212;
font-size:12px;
}
#fnav a{color:#d1d1d1;text-decoration:none;}
#fnav a:hover{color:#d1d1d1;text-decoration:underline;}
dl.disclaim{
width:100%;
max-width:720px;
margin:0 auto;
padding:40px 20px 0 20px;
box-sizing:border-box;
}
dl.disclaim dt{
margin:0 0 10px 0;
padding:0 0 0 8px;
text-align:left;
font-size:12px;
line-height:20px;
border-left:2px solid #cc9900;
}
dl.disclaim dd{
text-align:left;
font-size:12px;
line-height:20px;
}
#fnav{
margin:0 20px;
padding:40px 0;
}
#fnav ul{list-style-type:none;}
#fnav li{
display:inline-block;
margin:0 40px 20px 0;
padding:0 0 0 8px;
text-align:left;
font-size:12px;
line-height:20px;
border-left:2px solid #008c55;
}
#fnav li:last-child{margin:0 0 20px 0;}
address{
display:block;
margin:0 20px;
padding:40px 0;
border-top:1px solid #404040;
text-align:center;
font-size:12px;
line-height:20px;
}
@media only screen and (max-width:959px){
footer{}
dl.disclaim{max-width:960px;}
dl.disclaim dt{}
dl.disclaim dd{}
#fnav{
margin:0 20px;
padding:40px 0;
}
#fnav ul{list-style-type:none;}
#fnav li{
display:block;
margin:0 0 20px 0;
}
#fnav li:last-child{margin:0;}
address{}
dl.disclaim dd br{display:none;}
.sp_no{display:none;}
}

/* --------------------------------- CSS Information 
 Style Info: fadein
------------------------------------------------- */
.fadein{opacity:0;transition:all ease 1s;}
.fadein.scrollin{opacity:1;}
/*左から----------*/
.fadein_left{
opacity:0;
transform:translateX(-40px);
transition:all 1s;
}
.fadein_left.scrollin{
opacity:1;
transform:translateX(0);
}
/*右から----------*/
.fadein_right{
opacity:0;
transform:translateX(40px);
transition:all 1s;
}
.fadein_right.scrollin{
opacity:1;
transform:translateX(0);
}
/*上から----------*/
.fadein_top{
opacity:0;
transform:translateY(-20px);
transition:all 1s;
}
.fadein_top.scrollin{
opacity:1;
transform:translateY(0);
}
/*下から----------*/
.fadein_bottom{
opacity:0;
transform:translateY(20px);
transition:all 1s;
}
.fadein_bottom.scrollin{
opacity:1;
transform:translateY(0);
}