@charset "UTF-8";
/* CSS Document */

/*--  cta-btn  --*/
  section.cta-btn {
    background: #17ADAD;
    color: #fff;
  }
  section.cta-btn .cont-inner {
    gap: 40px;
    justify-content: center;
  }
  @media screen and (max-width: 980px) {
    section.cta-btn .cont-inner {
      padding: 20px;
      display: flex;
      flex-direction: column-reverse;
      align-items: center;
      gap: 10px;
    }
  }
  section.cta-btn dt {
    font-size: 27px;
    font-weight: bold;
    margin-bottom: 30px;
    text-align: center;
    line-height: 1.4;
  }
  @media screen and (max-width: 980px) {
    section.cta-btn dt {
      font-size: 5.2vw;
      margin-bottom: 15px;
    }
  }
  section.cta-btn dt img {
    width: 160px;
  }
  @media screen and (max-width: 980px) {
    section.cta-btn dt img {
      width: 100px;
    }
  }

  section.cta-btn a {
    background: #ED8B08;
    box-shadow: 0px 5px 8px 0px #00000026;
    color: #fff;
    text-align: center;
    border-radius: 50px;
    padding: 20px 0;
    font-weight: bold;
    width: 480px;
    font-size: 24px;
    margin: 0 auto;
  }
  @media screen and (max-width: 980px) {
    section.cta-btn a {
      width: 100%;
      font-size: 20px;
    }
  }
  section.cta-btn .document {
    width: 500px;
  }
  @media screen and (max-width: 980px) {
    section.cta-btn .document {
      width: 85%;
    }
  }

/*--  mv  --*/
  #mv-content {
    width: 100%;
    margin-top: 86px;
    background: linear-gradient(180deg, rgba(244, 253, 255, 0.74) 0%, rgba(210, 231, 244, 0.74) 100%);
  }
  @media screen and (max-width: 980px) {
    #mv-content {
      margin-top: 30px;
    }
  }
  #mv-content .mv-content--inner {
    width: 1280px;
    height: 480px;
    margin: auto;
    padding: 40px 0 0;
    justify-content: space-between;
    background-image: url(../img/mv-bg.png);
    background-size: 30%;
    background-repeat: no-repeat;
    background-position: bottom 10px right 460px;
    align-items: flex-start;
    position: relative;
  }
  @media screen and (max-width: 980px) {
    #mv-content .mv-content--inner {
      width: 100%;
      height: auto;
      padding: 70px 20px 140px;
      background-position: right 2vw bottom 2vw;
      background-size: auto 160px;
    }
  }
  #mv-content .main {
    line-height: 1.8;
    text-align: left;
    font-size: 42px;
  }
  @media screen and (max-width: 980px) {
    #mv-content .main {
      font-size: 6.5vw;
    }
  }
  #mv-content #form {
    background: #fff;
    border-radius: 20px 20px 0 0;
    width: 380px;
    box-shadow: 2px 2px 20px 0px rgba(0, 0, 0, 0.25);
    position: absolute;
    right: 0;
    top: 30px;
    z-index: 1;
  }
  #mv-content #form h2 {
    font-size: 18px;
    margin-bottom: 20px;
    background-color: #17ADAD;
    color: #fff;
    border-radius: 15px 15px 0 0;
    padding: 10px 0;
  }
  #mv-content #form form {
    margin: 0 20px 20px;
  }
  #mv-content #form .form_box {
    margin-bottom: 10px;
  }  
  #mv-content #form .flex-box {
    gap: 2%;
  }
  #mv-content #form label {
    font-weight: bold;
    margin-bottom: 5px;
  }
  #mv-content #form input {
    background: #FFF;
    border: 1px solid #ccc;
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
  }
  #mv-content #form .consent {
    font-size: 14px;
  }
  #mv-content #form .consent a {
    color: #17ADAD;
    display: inline;
  }
  #mv-content #form button {
    background: none;
    border: none;
    transition: .4s;
    opacity: 0.2;
    width: 70%;
    margin: 10px auto 0;
    display: block;
  }  

/*--  cont1  --*/

  section.cont1 {
    position: relative;
  }
  section.cont1 .down {
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
    top: calc(100% - 60px);
    width: 200px;
  }
  @media screen and (max-width: 980px) {
    section.cont1 .down {
      width: 100px;
      top: calc(100% - 40px);
    }
  }
  section.cont1 .flex-box {
    justify-content: space-around;
  }
  section.cont1 .flex-box p {
    text-align: center;
    font-weight: bold;
    background-color: #fff;
    box-shadow: 4px 4px 8px 0px rgba(0, 0, 0, 0.25);
    border-radius: 10px;
    padding: 20px;
    line-height: 1.8;
    box-sizing: border-box;
    justify-content: center;
    align-items: center;
    flex-basis: 25%;
  }
  @media screen and (max-width: 980px) {
    section.cont1 .flex-box p {
      padding: 20px;
      text-align: left;
      position: relative;
      margin-bottom: 20px;
    }
  }
  @media screen and (max-width: 980px) {
    section.cont1 .flex-box p img {
      position: absolute;
      right: 0;
      bottom: 0;
      height: 100%;
    }
  }
  
/*--  cont2  --*/

  section.cont2 {
    background: #F5F8FA;
  }
  @media screen and (min-width: 981px) {
    section.cont2 {
      padding-top: 40px;
    }
  }
  section.cont2 h3 {
    text-align: center;
    font-size: 24px;
    margin-top: 30px;
  }
  @media screen and (max-width: 980px) {
    section.cont2 h3 {
      font-size: 20px;
      background: #fff;
      border-radius: 10px;
      padding: 10px 0;
    }
  }
  section.cont2 .flex-box {
    gap: 80px;
    margin-top: 60px;
  }
  @media screen and (max-width: 980px) {
    section.cont2 .flex-box {
      margin-top: 20px;
    }
  }
  section.cont2 dt {
    font-weight: bold;
    margin-bottom: 30px;
    font-size: 24px;
  }
  @media screen and (max-width: 980px) {
    section.cont2 dt {
      font-size: 20px;
      margin-bottom: 20px;
    }
  }
  section.cont2 img {
    width: 600px;
  }
  @media screen and (max-width: 980px) {
    section.cont2 img {
      margin-top: 20px;
    }
  }

/*--  cont3  --*/

  section.cont3 {
    background: rgba(232, 247, 246, 1);
  }
  section.cont3 .movie {
    width: 90%;
    max-width: 750px;
    margin: 0 auto;
  }
  

/*--  cont4  --*/

  @media screen and (min-width: 981px) {
    section.cont4 .summary {
      margin: 80px auto 0;
      justify-content: space-between;
    }
  }
  section.cont4 .summary dt {
    margin-bottom: 30px;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .summary dt {
      font-size: 18px;
      margin-bottom: 0;
    }
  }
  section.cont4 .summary dt span {
    color: #17ADAD;
    font-size: 45px;
  }
  section.cont4 .summary img {
    width: 360px;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .summary img {
      margin-bottom: 10px;
    }
  }
  section.cont4 .detail {
    background: #ECF4F8;
    border-radius: 10px;
    position: relative;
    padding: 80px;
    margin-top: 80px;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail {
      padding: 20px;
    }
  }
  section.cont4 .detail .no {
    position: absolute;
    color: rgba(23, 173, 173, 0.42);
    left: 30px;
    top: -70px;
    font-weight: bold;
    font-size: 80px;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail .no {
      font-size: 50px;
      left: 10px;
      top: -50px;
    }
  }
  section.cont4 .detail .top {
    gap: 80px;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail.second .top {
      display: flex;
      flex-direction: column-reverse;
      gap: 0;
    }
  }
  section.cont4 .detail .top dt {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 40px;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail .top dt {
      font-size: 18px;
      margin-bottom: 20px;
    }
  }
  section.cont4 .detail .top img {
    width: 300px;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail .top img {
      width: 65%;
      margin: 20px auto;
      display: block;
    }
  }
  section.cont4 .detail h3 {
    font-size: 20px;
    text-align: center;
    margin: 40px auto;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail h3 {
      font-size: 18px;
      margin: 20px auto;
    }
  }
  section.cont4 .detail h3.mt0 {
    margin-top: 0;
  }
  section.cont4 .detail ul {
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail ul {
      display: flex;
      gap: 5px;
    }
  }
  @media screen and (min-width: 981px) {
    section.cont4 .detail.second ul,
    section.cont4 .detail.third ul {
      align-items: stretch;
    }
  }
  section.cont4 .detail li {
    background: rgba(106, 178, 222, 1);
    color: #fff;
    text-align: center;
    flex-basis: 30%;
    font-weight: bold;
    border-radius: 10px;
    font-size: 20px;
    padding: 15px 0;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail li {
      flex-basis: 48%;
      padding: 5px 0;
      font-size: 14px;
    }
  }
  section.cont4 .detail.second li,
  section.cont4 .detail.third li {
    display: flex;
    align-items: center;
    padding: 10px 0;
    justify-content: center;
  }
  @media screen and (max-width: 980px) {
    section.cont4 .detail.second li,
    section.cont4 .detail.third li {
      padding: 5px 0;
    }
  }
  @media screen and (min-width: 981px) {
    section.cont4 .detail.second li{
      flex-basis: 18%;
    }
    section.cont4 .detail.third li {
      flex-basis: 22%;
    }
  }
  

/*--  cont5  --*/

  section.cont5 .flex-box {
    justify-content: space-between;
  }
  section.cont5 dl {
    border: 3px solid rgba(23, 173, 173, 1);
    box-shadow: 0px 4px 8px 0px rgba(0, 0, 0, 0.25);
    border-radius: 20px;
    flex-basis: 24%;
  }
  @media screen and (max-width: 980px) {
    section.cont5 dl {
      margin-top: 20px;
    }
  }
  section.cont5 dl dt {
    color: #fff;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
    background-color: rgba(23, 173, 173, 1);
    border-radius: 16px 16px 0 0;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  @media screen and (max-width: 980px) {
    section.cont5 dl dt {
      padding: 10px 0;
      height: auto;
      font-size: 18px
    }
  }
  section.cont5 dl dd {
    padding: 20px;
    font-weight: bold;
  }
  @media screen and (max-width: 980px) {
    section.cont5 dl dd {
      padding: 15px;
    }
  }
  section.cont5 dl dd li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
  }
  @media screen and (min-width: 981px) {
    section.cont5 dl dd li img {
      width: 30%;
      max-height: 65px;
    }
  }
  @media screen and (max-width: 980px) {
    section.cont5 dl dd li img {
      width: 25%
    }
  }
  section.cont5 dl dd li.down img {
    height: 60px;
    width: auto;
    padding: 10px 0 10px 30px;
  }
  @media screen and (max-width: 980px) {
    section.cont5 dl dd li.down img {
      padding: 5px 0 5px 35px;
      height: 40px;
    }
  }
  



/*--  cont6  --*/

  section.cont6 {
    background: #F5F8FA;
  }
  section.cont6 .flex-box {
    gap: 80px;
  }
  section.cont6 dt {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 40px;
  }
  @media screen and (max-width: 980px) {
    section.cont6 dt {
      font-size: 20px;
      margin: 40px auto 20px;
    }
  }
  section.cont6 img {
    width: 38%;
  }
  @media screen and (max-width: 980px) {
    section.cont6 img {
      width: 65%;
      display: block;
      margin: 0 auto 20px;
    }
  }

/*--  cont7  --*/

  section.cont7 .flow {
    background: #F5F8FA;
    border-radius: 10px;
    box-shadow: 0px 5px 8px 0px #00000026;
    padding: 10px 10px 10px 30px;
    width: 65%;
    margin: 0 auto 35px;
    gap: 30px;
  }
  @media screen and (max-width: 980px) {
    section.cont7 .flow {
      display: flex;
      padding: 10px;
      gap: 10px;
      align-items: center;
      width: 100%;
    }
  }
  section.cont7 .flow .img {
    width: 20%;
    position: relative;
  }
  @media screen and (max-width: 980px) {
    section.cont7 .flow .img {
      width: 55%;
    }
  }
  section.cont7 .flow .img:after {
    content: "";
    position: absolute;
    display: block;
    height: 30px;
    width: 6px;
    background-size: 2px 6px;
    background-repeat: repeat-y;
    bottom: -45px;
    left: 50%;
    background-image: linear-gradient(to top, #c5cbd3, #c5cbd3 4px, transparent 4px, transparent 10px);
    background-position: center;
  }
  @media screen and (max-width: 980px) {
    section.cont7 .flow .img:after {
      bottom: -42px;
    }
  }
  section.cont7 .flow .img img {
    vertical-align: top;
  }
  section.cont7 .flow.flow-last .img:after {
    content: none;
  }
  section.cont7 .flow dt {
    font-size: 20px;
    margin-bottom: 10px;
    font-weight: bold;
  }
  @media screen and (max-width: 980px) {
    section.cont7 .flow dt {
      font-size: 16px;
      margin-bottom: 5px;
    }
  }
  @media screen and (max-width: 980px) {
    section.cont7 .flow dd {
      font-weight: normal;
    }
  }

/*--  cont8  --*/

  section.cont8 dl {
    border-bottom: dotted 3px #959595;
    margin: 0 auto 20px;
  }
  @media screen and (min-width: 981px) {
    section.cont8 dl {
      width: 80%;
      margin: 0 auto 30px;
      padding: 0 30px;
    }
  }
  section.cont8 dt {
    background: #E8F7F6;
    font-size: 18px;
    font-weight: bold;
    border-radius: 100px;
    color: #17ADAD;
    padding: 20px 10px 20px 80px;
    background-image: url(../img/cont8-bg-Q.png);
    background-repeat: no-repeat;
    background-size: 50px;
    background-position: left 10px center;
  }
  @media screen and (max-width: 980px) {
    section.cont8 dt {
      padding: 10px 10px 10px 60px;
      font-size: 16px;
      background-size: 40px;
    }
  }
  section.cont8 dd {
    font-weight: bold;
    padding: 30px 0 40px 80px;
    background-image: url(../img/cont8-bg-A.png);
    background-repeat: no-repeat;
    background-size: 50px;
    background-position: left 10px center;
  }
  @media screen and (max-width: 980px) {
    section.cont8 dd {
      font-weight: normal;
      padding: 20px 0 20px 60px;
      background-size: 40px;
    }
  }

  
/*--  form_sp  --*/
  #form_sp {
    padding: 30px;
  }
  #form_sp .form_box {
    margin-bottom: 10px;
  }  
  #form_sp .flex-box {
    gap: 2%;
  }
  #form_sp label {
    font-weight: bold;
    margin-bottom: 5px;
  }
  #form_sp input {
    background: #FFF;
    border: 1px solid #ccc;
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
  }
  #form_sp .consent {
    font-size: 14px;
  }
  #form_sp .consent a {
    color: #17ADAD;
    display: inline;
  }
  #form_sp button {
    background: none;
    border: none;
    transition: .4s;
    opacity: 0.2;
    width: 70%;
    margin: 10px auto 0;
    display: block;
  }
  @media screen and (max-width: 980px) {
    #form_sp button {
      width: 90%;
    }
  }

  /*--  thanks  --*/
  @media screen and (max-width: 980px) {
    #wrap.thanks #mv-content {
      margin-top: 45px;
    }
  }
  #wrap.thanks .cont-inner {
    padding: 30px 0;
  }
  @media screen and (max-width: 980px) {
    #wrap.thanks .cont-inner {
      padding: 20px;
    }
  }
  #wrap.thanks h2 {
    text-align: left;
    margin-bottom: 0;
  }
  #wrap.thanks h3 {
    border-left: solid 8px #00B29E;
    padding: 0 0 0 28px;
    margin: 30px 0;
    font-size: 22px;
  }
  @media screen and (max-width: 980px) {
    #wrap.thanks h3 {
      font-size: calc(30 *(100vw/750));
      padding: 0 0 0 15px;
      margin: 15px 0;
    }
  }
  #wrap.thanks .DL-content .flex-box {
    justify-content: space-between;
    gap: 15%;
    padding: 0 0 30px;
  }
  #wrap.thanks .DL-content .flex-box > img {
    width: 400px;
  }
  @media screen and (max-width: 980px) {
    #wrap.thanks .DL-content .flex-box > img {
      width: 75%;
      margin: 0 auto;
      display: block;
    }
  }
  #wrap.thanks .DL-content .btn-area {
    background: #F7F7F7;
    padding: 30px 40px;
    border-radius: 10px;
    text-align: center;
  }
  @media screen and (max-width: 980px) {
    #wrap.thanks .DL-content .btn-area {
      padding: 20px;
    }
  }
  #wrap.thanks .DL-content .btn-area .dltext {
    padding-bottom: 10px;
  }


  /*--  footer  --*/
  footer a {
    color: #fff;
  }
  footer .cont-inner {
    align-items: center;
    adding: 20px 0 0;
  }
  footer ul {
    gap: 30px;
  }