@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Roboto:ital,wght@0,400;0,500;0,700;1,400;1,500;1,700&display=swap');

@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@500;700;800&display=swap');


*,
*:before,
*:after {
 box-sizing: border-box;
 -webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 -o-box-sizing: border-box;
 -ms-box-sizing: border-box;
 font-feature-settings: "palt";
 letter-spacing: .1em;
}




body {
 margin: 0 auto;
 max-width: 2000px;
 font-size: 16px;
 font-family: 'Roboto', 'Noto Sans JP', "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "メイリオ", sans-serif;
 font-feature-settings: "palt";
 background-repeat: repeat;
 transition: 0.3s;
}

ul,
ol {
 list-style-type: none;
 padding: 0;
 margin: 0;
}


a {
 color: #31c382;
 transition: 0.3s;
 font-weight: 600;
 text-decoration: underline;
}

a:hover {
 opacity: .8;
 transition: 0.3s;
}


i {}

p {
 margin-top: 20px;
 line-height: 2;
 color: #444;
}

p.ex {
 text-align: center;
}


p.ex2 {
 margin-top: 10px;
}




.center {
 text-align: center;
}


img {
 max-width: 100%;
}

.center-img {
 display: block;
 margin: 60px auto;
 width: 500px;
 ;
}

.under {
 text-decoration: underline;
}

.caption {
 font-size: 15px;
 margin-top: 10px;
 color: #555;
}


/*----------------------------*/


h2 {
 font-size: 40px;
 font-weight: 600;
 margin-bottom: 40px;
 line-height: 1.5,
}

h3 {
 font-size: 30px;
 font-weight: 600;
 margin-bottom: 10px;
}

h4 {
 font-size: 44px;
 line-height: 1.5;
 font-weight: 600;
}

h4.ex {
 font-size: 28px;
 line-height: 1.5;
 font-weight: 600;

}



h4 i {
 padding-right: 5px;
 color: #000;
}

h4 span {
 font-size: 20px;
}


.btn {
 display: flex;
 justify-content: center;
 align-items: center;
 text-align: center;
 margin: 100px auto;
 text-decoration: none;
 color: #111;
 font-size: 26px;
 width: 500px;
 height: 80px;
 line-height: 80px;
 background: orange;
 border-radius: 10px;
 padding-top: 10px;
 position: relative;
 box-shadow: 10px 10px 20px 0px rgba(0, 0, 0, 0.1);
 color: #fff;
}

.btn.ex {
 margin: 0 auto;
 margin-top: 60px;
}

.btn i {
 font-size: 40px;
 margin-right: 10px;
 padding-bottom: 2px;
}

.btn .notice {
 display: block;
 position: absolute;
 top: -18px;
 background: #111;
 font-size: 18px;
 color: #fff;
 width: 280px;
 height: 30px;
 line-height: 30px;
 border-radius: 10px 10px 0 0;
}


.btn .notice span {
 font-size: 26px;
}

@keyframes shiny {
 0% {
  left: -2%;
 }

 10% {
  left: 110%;
 }

 100% {
  left: 110%;
 }
}

.btn::after {
 content: '';
 position: absolute;
 top: -0%;
 left: -0%;
 width: 30px;
 height: 80px;
 transform: scale(2) rotate(10deg);
 background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, .3) 100%, rgba(255, 255, 255, 0) 0%);
 animation-name: shiny;
 animation-duration: 3s;
 animation-timing-function: ease-in-out;
 animation-iteration-count: infinite;
}



/*----------------------------*/


section {
 width: 1000px;
 margin: 100px auto;
}

section.gray {
 width: 100%;
 background: #F1F1F1;
 margin: 0 auto;
 padding: 100px;
}




section.ex {
 width: 700px;
 margin: 100px auto;
}

.txt-box {
 width: 500px;
 margin: 0 auto;
}

.txt-box.ex {
 margin-top: 60px;
}


.flex-box {
 display: flex;
 justify-content: space-between;
 align-items: center;
 margin-top: 80px;
}

.flex-box.reverse {
 flex-direction: row-reverse;
}


.flex-box.ex {
 align-items: flex-start;
 flex-wrap: wrap;
}

.flex-box.slim {
 width: 70%;
 margin: 0 auto;
 margin-top: 80px;
}


.flex-box .item {
 width: 47.5%;
}

.flex-box .item.ex {
 width: 30%;
 margin-bottom: 60px;
}




.flex-box .item p:first-child {
 margin-top: 0;
}




.box-1 {
 display: flex;
 justify-content: space-between;
 margin-top: 30px;
}

.box-1 a {

 display: block;
 width: 31%;
}






img.sp-img {
 width: 300px;
}

img.illust-1 {
 width: 350px;
}



.seed {
 display: block;
 height: 350px;
}



img.arrow {
 width: 150px;
 display: block;
 margin: 60px auto;
}



.profile-box {
 border: 1px solid #ddd;
 padding: 50px;
 margin: 0 auto;
 margin-top: 50px;
}



.profile-box .logo {
 width: 150px;
 margin-bottom: 20px;
}



.profile-box .info {
 width: 100%;
 margin-right: auto;
}



.profile-box .info span {
 display: block;
 font-size: 15px;
 line-height: 1.5;
 margin-bottom: 10px;
 font-weight: 600;
}


.profile-box .info .link a {
 margin-right: 20px;
}


.profile-box .info .link img {
 height: 20px;
 margin-right: 10px;
}


.fa-twitter {
 color: #1D9BF0;
}

.fa-facebook {
 color: #1976F2;
}


.profile-box .career {
 font-size: 15px;
 line-height: 1.8;
}


.box {
 width: 750px;
 margin: 100px auto;
}

.box.ex {
 width: 48%;
 margin: 30px auto;
}


.box .head {
 background: #31c382;
 text-align: center;
 padding: 30px;
}

.box .head.ex {
 background: gray;

}



.box .head h3 {
 margin-bottom: 0;
 color: #fff;
 line-height: 1.5;
}

.box h4 {
 font-size: 24px;
 line-height: 1.5;
}

.box.ex h4 {
 font-size: 21px;
 line-height: 1.5;
}


.box h4 i {
 color: #31c382;
}

.box .inner.ex i {
 color: #000;
}


.box .item span {
 display: block;
 font-weight: normal;
 font-size: 17px;
 line-height: 1.5;
}



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







.red {
 color: red;
}




.box .inner {
 border: 1px solid #ddd;
 border-top: none;
 padding: 60px;
}


.box .item {
 margin-bottom: 45px;
}

.box.ex .item {
 margin-bottom: 30px;
}



.box .item:last-child {
 margin-bottom: 0;
}

.box p {
 margin-top: 10px;
 line-height: 1.5;
}


/*----------------------------*/



.works-box {
 margin: 0 auto;
 margin-top: 60px;
 width: 800px;
}


.works-box .item {
 padding: 45px 0;
}


.works-box.ex .item {
 border-top: 1px solid #ddd;
}


.works-box .head {
 display: flex;
 justify-content: space-between;
 align-items: center;
}

.works-box .sub-title {
 display: flex;
 justify-content: center;
 align-items: center;
 font-weight: 500;
 margin-bottom: 10px;
 background: #111;
 width: 340px;
 height: 50px;
 line-height: 50px;
 margin: 0 auto;
 color: #fff;
 font-size: 18px;
 margin-bottom: 20px;
}

.works-box .sub-title i {
 font-size: 25px;
 margin-right: 5px;
}


.works-box .tn {
 width: 35%;
 border-radius: 200px;
}

.works-box .info {
 width: 58%;
}

.works-box.ex .tn {
 width: 42%;
}

.works-box.ex .info {
 width: 50%;
}




.works-box .title {
 display: flex;
 align-items: baseline;
}

.works-box .title .sub {
 text-decoration: underline;
 margin-right: 10px;
 font-weight: 500;
}

.works-box .info p {
 line-height: 1.8;
 margin-bottom: 20px;
}

.works-box .logo {
 height: 40px;
 margin-top: 20px;
}



.works-box .foot {
 margin-top: 30px;
 display: flex;
 justify-content: space-between;
 align-items: center;
}


.works-box .profile {
 width: 650px;
 display: flex;
 align-items: center;
}

.works-box .profile .icon {
 width: 120px;
 margin-right: 20px;
}


.works-box .foot .tn-cont {
 width: 320px;
}

.works-box .profile p {
 font-size: 14px;
 margin-top: 10px;
 line-height: 1.8;
}












.ex-box {
 width: 800px;
 margin: 0 auto;
 display: flex;
 flex-wrap: wrap;
 justify-content: space-between;
}

.ex-box .item {
 width: 48%;
 text-align: center;
 margin-top: 20px;
}


.ex-box .item span {
 font-size: 18px;
 font-weight: 600;
}


.img-box {
 display: flex;
 align-items: flex-start;
 justify-content: space-between;
 margin-top: 30px;
}

.img-box img {
 width: 48%;
}

.flow-box {
 display: flex;
 justify-content: space-between;
 align-items: flex-start;
}

.flow-box .txt {
 width: 48%;
}

.flow-box .parts p {
 margin-top: 10px;
}





.flow-box .sp-img {
 width: 38%;
}

.flow-box .arrow {
 width: 30%;
}





/*----------------------------*/



.fukidashi-box {
 width: 750px;
 margin: 60px auto;
}


.fukidashi-box .item {
 display: flex;
 align-items: flex-start;
}

.fukidashi-box .icon {
 width: 120px;
}



.fukidashi-box .name {
 display: block;
 font-weight: 600;
 text-align: center;
 margin-top: 5px;
 font-size: 14px;
}


.fukidashi-left {
 position: relative;
 display: inline-block;
 margin: 0 0 0 15px;
 padding: 7px 10px;
 min-width: calc(100% - 120px);
 max-width: calc(100% - 120px);
 color: #555;
 font-size: 17px;
 font-weight: 500;
 background: #FFF;
 border: solid 3px #555;
 box-sizing: border-box;
 border-radius: 10px;
 margin-bottom: 60px;
}

.fukidashi-left:before {
 content: "";
 position: absolute;
 top: 30%;
 left: -24px;
 margin-top: -12px;
 border: 12px solid transparent;
 border-right: 12px solid #FFF;
 z-index: 2;
}

.fukidashi-left:after {
 content: "";
 position: absolute;
 top: 30%;
 left: -30px;
 margin-top: -14px;
 border: 14px solid transparent;
 border-right: 14px solid #555;
 z-index: 1;
}

.fukidashi-left p {
 margin: 0;
 padding: 5px;
}

.fukidashi-right {
 position: relative;
 display: inline-block;
 margin: 0 15px 0 0;
 padding: 7px 10px;
 min-width: calc(100% - 120px);
 max-width: calc(100% - 120px);
 color: #555;
 font-size: 17px;
 font-weight: 500;
 background: #FFF;
 border: solid 3px #555;
 box-sizing: border-box;
 border-radius: 10px;
 margin-bottom: 60px;
}

.fukidashi-right:before {
 content: "";
 position: absolute;
 top: 30%;
 right: -24px;
 margin-top: -12px;
 border: 12px solid transparent;
 border-left: 12px solid #FFF;
 z-index: 2;
}

.fukidashi-right:after {
 content: "";
 position: absolute;
 top: 30%;
 right: -30px;
 margin-top: -14px;
 border: 14px solid transparent;
 border-left: 14px solid #555;
 z-index: 1;
}

.fukidashi-right p {
 margin: 0;
 padding: 0;
}




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


.schedule-box .item {
 width: 12%;
}

.schedule-box span {
 display: block;
 text-align: center;
 font-weight: 600;
 font-size: 20px;
 margin-bottom: 10px;
}



.copyright {
 display: block;
 text-align: center;
 margin: 50px 0;
 font-size: 14px;
 color: #555;
}






.img-roadmap {
 display: block;
 width: 1000px;
 margin: 0 auto;
}


.margin {
 margin-top: 100px;
}



.img-flex {
 width: 100%;
 display: flex;
 justify-content: space-between;
 margin: 50px auto;
}

.img-flex img {
 width: 48%;
}




.video-box {
 width: 1000px;
 margin: 0 auto;
 margin-top: 30px;
 display: flex;
 justify-content: space-between;
}

.video-box iframe {
 width: 48%;
}




form {
 width: 800px;
 margin: 60px auto;
}

form label {
 width: 100%;
 background: #31c382;
 color: #fff;
 text-align: center;
 height: 50px;
 font-weight: 500;
 display: flex;
 justify-content: center;
 align-items: center;
 width: 45%;
}

form .item {
 display: flex;
 align-items: center;
 margin: 0 auto;
 margin-bottom: 20px;

}

.item.message,
.item.radio {
 align-items: flex-start;
 height: auto;
}


form input {
 width: 55%;
 line-height: 50px;
 border: 1px solid #ddd;
 padding: 0 20px;
 background: #fff;
}

textarea {
 width: 55%;
 height: 200px;
 padding: 10px;
 font-size: 16px;
 border: 1px solid #ddd;
 background: #fff;
}

form button {
 text-align: center;
 display: block;
 margin: 0 auto;
 background: #31c382;
 color: #fff;
 width: 300px;
 height: 60px;
 font-size: 16px;
 font-weight: 500;
 border-radius: 50px;
 cursor: pointer;
 border: 0px;
 margin-top: 50px;
 font-size: 18px;
}

::placeholder {
 font-size: 15px;
 color: #bbb;
}


.radio .inner {
 width: 55%;
 display: flex;
 flex-direction: column;
 border: 1px solid #ddd;
 padding: 30px;
 font-weight: 500;
 background: #fff;
}

.radio .inner.ex {
 height: 160px;
}

.radio.label {
 height: 160px;
}

.message.label {
 height: 200px;
}


.radio span {
 margin-left: 5px;
}

.check {
 width: 20px;
 margin-bottom: 3px;
}

.radio .inner div {
 display: flex;
 height: 40px;
 align-items: center;
}


.label-btn {
 display: block;
 width: 40px;
 height: 20px;
 line-height: 20px;
 background: orange;
 color: #fff;
 font-size: 12px;
 border-radius: 3px;
 margin-left: 10px;
}

.label-btn.ex {
 background: #eee;
 color: #999;
}

.form_btn {
 position: relative;
 background: orange;
}


.form-btn {
 display: flex;
 justify-content: center;
 align-items: center;
 text-align: center;
 margin: 0 auto;
 text-decoration: none;
 color: #fff;
 font-size: 20px;
 width: 500px;
 height: 80px;
 line-height: 80px;
 background: #0B133B;
 border-radius: 100px;
 position: relative;
 box-shadow: 10px 10px 20px 0px rgba(0, 0, 0, 0.1);
}




.thanks .wrap {
 width: 500px;
 height: 500px;
 position: absolute;
 top: 0;
 left: 0;
 bottom: 0;
 right: 0;
 margin: auto;
 color: #fff;
 display: flex;
 justify-content: center;
 align-items: center;

}

.thanks .inner {
 text-align: center;
}

.thanks .inner img {
 width: 70%;
 margin-bottom: 50px;
}

.thanks .inner h2 {
 font-size: 40px;
 font-weight: bold;
 color: #000;
}

.thanks .inner a {
 display: block;
 font-weight: bold;
 margin-top: 50px;
}



/*----------------------------*/

.table-company {
 color: #333;
 width: 650px;
 margin: 0 auto;
}

.table-company tr {
 border-bottom: 1px solid #ddd;
}

.table-company td {
 padding-top: 60px;
 padding-bottom: 20px;
 line-height: 1.3;
 letter-spacing: 1.5px;
}

.table-company td:first-child {
 width: 30%;
 text-align: center;
 font-weight: 600;
}

/*----------------------------*/


.q-box {
 width: 600px;
 margin: 0 auto;
}

.q-box .item {
 margin-top: 90px;
}


.q-box .item h3 {
 margin-bottom: 30px;
}



/*----------------------------*/

.sp {
 display: none;
}

.tab {
 display: none;
}


.sp-only {
 display: none;
}


.pc {
 display: block;
}




/*----------------------------*/


#pageTop {
 position: fixed;
 bottom: 40px;
 right: 30px;
 z-index: 9999;
}

#pageTop a {
 display: flex;
 justify-content: center;
 align-items: center;
 margin: 0;
 padding: 0;
 width: 50px;
 height: 50px;
 background: #333;
 color: #fff;
 text-decoration: none;
 text-align: center;
 border-radius: 30px;
}

#pageTop i {
 font-size: 22px;
 font-weight: bold;
 margin-left: 3px;
}

#pageTop a:hover {
 text-decoration: none;
 opacity: 0.7;
}


/*----------------------------*/

.fade_in_box {
 overflow: hidden;
 transition: .8s;
}


.fade_in {
 transition: 1s;
 opacity: 0;
 transform: translate(0, 60px);
 -webkit-transform: translate(0, 60px);
}

.in {
 opacity: 1.0;
 transform: translate(0, 0);
 -webkit-transform: translate(0, 0);
}


.fade_in.two {
 -moz-transition-delay: 200ms;
 -webkit-transition-delay: 200ms;
 -o-transition-delay: 200ms;
 -ms-transition-delay: 200ms;
}


.fade_in.three {
 -moz-transition-delay: 300ms;
 -webkit-transition-delay: 300ms;
 -o-transition-delay: 300ms;
 -ms-transition-delay: 300ms;
}

.fade_in.four {
 -moz-transition-delay: 400ms;
 -webkit-transition-delay: 400ms;
 -o-transition-delay: 400ms;
 -ms-transition-delay: 400ms;
}

.fade_in.five {
 -moz-transition-delay: 500ms;
 -webkit-transition-delay: 500ms;
 -o-transition-delay: 500ms;
 -ms-transition-delay: 500ms;
}

.fade_in.six {
 -moz-transition-delay: 600ms;
 -webkit-transition-delay: 600ms;
 -o-transition-delay: 600ms;
 -ms-transition-delay: 600ms;
}

.fade_in.seven {
 -moz-transition-delay: 700ms;
 -webkit-transition-delay: 700ms;
 -o-transition-delay: 700ms;
 -ms-transition-delay: 700ms;
}

.fade_in.eight {
 -moz-transition-delay: 800ms;
 -webkit-transition-delay: 800ms;
 -o-transition-delay: 800ms;
 -ms-transition-delay: 800ms;
}

.fade_in.nine {
 -moz-transition-delay: 900ms;
 -webkit-transition-delay: 900ms;
 -o-transition-delay: 900ms;
 -ms-transition-delay: 900ms;
}

.fade_in.ten {
 -moz-transition-delay: 1000ms;
 -webkit-transition-delay: 1000ms;
 -o-transition-delay: 1000ms;
 -ms-transition-delay: 1000ms;
}
