@charset "UTF-8";
/******* setting.scss *******/
/******* mixin.scss *******/
/******* reset.scss *******/


html {
  font-size: 62.5%; }

html,
body {
  font-family: 'Noto Sans JP', sans-serif;
  margin: 0;
  max-width: 100%;
  min-height: 100%;
  padding: 0;
  position: relative;
  -webkit-text-size-adjust: 100%; }

div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fildset, input, textarea, p, blockquote, table, th, td, address, textarea, input {
  color: #0E202A;
  font-size: 16px;
  font-size: 1.6rem;
  font-style: normal;
  font-weight: 500;
  /*letter-spacing: 0.05em;*/
  line-height: 160%;
  margin: 0;
  padding: 0;
  word-wrap: break-word; }

table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%; }

caption, th {
  text-align: left; }

td, th {
  vertical-align: top; }

fieldset, img, abbr {
  border: none; }

li {
  list-style-type: none; }

strong {
  font-weight: bold; }

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

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

* {
  box-sizing: border-box;
}

*:focus {
  outline: none; }

._sp {
  display: none !important; }

.mt-40 {
  margin-top: 40px;
}
.cont-1140 {
  width: 95%;
  max-width: 1140px;
  margin: 0 auto;
}
.sec-flow {
  width: 98%;
  max-width: 1320px;
  margin: 0 auto;
}
.sec-flow h2 {
  font-size: 4.5rem;
  font-weight: 700;
}

.bg-grad01 {
  width: 100%;
  background-image: linear-gradient(to top, #fff, #ACDDF7);
  height: 15rem;
}
.bg-grad02 {
  width: 100%;
  background-image: linear-gradient(to bottom, #fff 25%, #ACDDF7);
  padding: 0 2.5%;
}

/******header******/
header {
  background: url("../img/mv.png") no-repeat 0 100%;
  background-size: cover;
  padding: 80px 40px 25px; }
  header img {
    max-width: 100%; }
  header .head_logo {
    position: absolute;
    top: 30px;
    left: 40px; }
  header .head_cont {
    margin: 0 auto;
    max-width: 1000px;
    position: relative;
    text-align: center; }
  header h1 {
    margin: 0 auto; }
    header h1 img {
      max-width: 100%; }
  header .head_lead {
    position: absolute;
    top: 100px;
    right: -190px; }
  header .head_lead2 {
    position: absolute;
    top: 320px;
    left: -120px; }
  header .head_txt {
    background-color: #E3068E;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    width: 100%; }
  @media screen and (max-width: 1010px) {
    header .head_cont {
      max-width: 100%; }
    header h1 {
      width: 92vw; } }

/******footer******/
footer {
  border-top: 1px solid #F4F4F4; }
  footer .footer-middle {
    padding: 65px 20px; }
    footer .footer-middle .inner {
      max-width: 1120px;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      position: relative;
      text-align: left; }
      footer .footer-middle .inner:before {
        background-color: #C2CAD6;
        content: "";
        height: 100%;
        display: block;
        margin: 0 auto;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        width: 1px; }
      footer .footer-middle .inner .pagetop {
        cursor: pointer;
        font-size: 75%;
        position: absolute;
        bottom: -115px;
        right: 0px;
        text-align: center;
        z-index: 5; }
        footer .footer-middle .inner .pagetop img {
          display: block;
          margin-bottom: 5px; }
    footer .footer-middle .footer-sitemap {
      display: flex;
      justify-content: space-between;
      padding: 20px 0;
      width: 45%; }
      footer .footer-middle .footer-sitemap ul:nth-of-type(2) {
        margin: 0 20px; }
      footer .footer-middle .footer-sitemap ul li {
        font-size: 75%;
        margin-bottom: 10px; }
        footer .footer-middle .footer-sitemap ul li:last-child {
          margin-bottom: 0; }
        footer .footer-middle .footer-sitemap ul li a {
          color: #666;
          text-decoration: none;
          transition: opacity 0.6s;
          text-decoration: none; }
          footer .footer-middle .footer-sitemap ul li a:hover {
            opacity: 0.7; }
          @media screen and (max-width: 960px) {
            footer .footer-middle .footer-sitemap ul li a:hover {
              opacity: 1; } }
    footer .footer-middle .footer-misc {
      margin: 0 60px 0 0;
      padding: 20px 0;
      width: 37%; }
      footer .footer-middle .footer-misc dt {
        font-weight: 700;
        font-size: 87.5%;
        margin-top: 20px;
        letter-spacing: -0.01em; }
        footer .footer-middle .footer-misc dt:first-of-type {
          margin-top: 0; }
      footer .footer-middle .footer-misc dd {
        font-size: 75%;
        margin-top: 15px;
        letter-spacing: -0.01em; }
  footer .footer-lower {
    background: url("../img/bg_walk-stop.png") repeat-x 50% 100% #F4F4F4;
    background-size: auto 80px;
    padding: 75px 20px 120px;
    position: relative;
    text-align: center;
  }
    footer .footer-lower .footer-logo {
      margin: 0 auto 15px; }
    footer .footer-lower .copyright {
      font-size: 75%; }

/******main******/
main {
  display: block;
  text-align: left;
  position: relative;
  overflow: hidden; }

/******index******/
.link_area {
  background: url("../img/link_bg02.png") no-repeat 50% 100%, url("../img/link_bg01.png") no-repeat 50% 0;
  background-size: 100%, cover;
  margin-bottom: 40px;
  padding: 0 20px 85px; }

.link_area2 {
  background: url("../img/link_bg04.png") no-repeat 50% 100%, url("../img/link_bg03.png") no-repeat 50% 0;
  background-size: 100%, cover;
  margin-bottom: 60px;
  padding: 20px 20px 90px; }

.link_cont {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 1020px;
  margin: 0 auto;
  padding: 10px 0 0; }
  .link_cont dl {
    width: 54%; }
    .link_cont dl dt {
      color: #967800;
      font-size: 150%;
      font-weight: 700;
      line-height: 150%;
      margin-bottom: 15px;
      text-align: center;
      width: 100%; }
      .link_cont dl dt span {
        color: #001E4B;
        display: inline-block;
        font-size: 65%; }
        .link_cont dl dt span:before, .link_cont dl dt span:after {
          background-position: 0 0;
          background-repeat: no-repeat;
          background-size: 100%;
          overflow: hidden;
          text-indent: 180%;
          white-space: nowrap;
          content: "";
          display: block;
          height: 17px;
          width: 14px;
          background-image: url("../img/link_icon2.svg");
          display: inline-block; }
        .link_cont dl dt span:before {
          margin-right: 4px;
          transform: scale(-1, 1); }
    .link_cont dl dd {
      border-radius: 5px;
      background-color: #fff; }
      .link_cont dl dd a {
        border-radius: 5px;
        box-sizing: border-box;
        cursor: pointer;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: 700;
        height: 70px;
        line-height: 140%;
        text-align: center;
        transition: opacity 0.6s;
        text-decoration: none; }
        .link_cont dl dd a:hover {
          opacity: 0.8; }
        @media screen and (max-width: 960px) {
          .link_cont dl dd a:hover {
            opacity: 1; } }
    .link_cont dl.payment dd a {
      background: #E3068E;
      color: #fff;
      font-size: 137%; }
    .link_cont dl.other {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      width: 41.2%; }
      .link_cont dl.other dd {
        width: 47.6%; }
        .link_cont dl.other dd.entry a {
          background-color: #065FE3;
          color: #fff; }
        .link_cont dl.other dd.entry2 a {
          border: 1px solid #065FE3;
          color: #065FE3; }
  .link_cont p {
    margin-top: 14px;
    text-align: right;
    width: 100%; }
  .link_cont ul {
    margin: 15px auto 0;
    width: 100%; }
    .link_cont ul li {
      text-align: center; }

.sec_cont {
  box-sizing: border-box;
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
 }
  .sec_cont h2 {
    font-size: 4.5rem;
    font-weight: 700;
    margin: 0 auto 60px;
    text-align: center;
    line-height: 1;
   }




.top-logo-img {
  width: 120px;
  position: absolute;
  top: 20px;
  left: 20px;
}


.mv {
  padding: 0 0 5rem;
  background-color: #ACDDF7;
  background-image: url(../img/top-bg.png);
  background-size: cover;
  background-position: 50% -3rem;
  background-repeat: no-repeat;
}
.mv-img {
  width: 80%;
  max-width: 885px;
  margin: 0 auto 35px;
  position: relative;
  padding-top: 3rem;
}
.mv-date-img {
  position: absolute;
  bottom: 6.5rem;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  width: 70%;
  max-width: 572px;
}






.present {
  padding-bottom: 30px;
  background-color: #fff;
  background-image: url(../img/pre-bg-l.png), url(../img/pre-bg-r.png);
  background-position: left bottom, right bottom;
  background-size: contain, contain;
  background-repeat: no-repeat, no-repeat;
  margin: 50px auto;
  position: relative;
  }

  .present .present_detail td ul li:first-child {
    width: 25%; }
  .present .present_detail td ul li:last-child {
    font-size: 100%;
    width: 33%; }
    .present .present_detail td ul li:last-child:before {
      top: 7px; }

    .present .present_detail td.note ul li {
      letter-spacing: normal; }
      .present .present_detail td.note ul li:first-child {
        font-size: 100%; }
      .present .present_detail td.note ul li:last-child {
        font-size: 2.8rem;
        width: 100%; }
        .present .present_detail td.note ul li:last-child:before {
          top: 9px; }
  .present .present_detail tr:first-of-type th.note span.note {
    font-size: 155%;
    margin-left: 15px; }

    .present .present_detail tr:nth-of-type(2) th:last-of-type span.note {
      background-color: #E3068E;
      font-size: 135%;
      margin-left: 5px; }


.present_detail {
  table-layout: fixed;
  margin-bottom: 0px;
 }
  .present_detail th {
    background-color: #F7FCFF;
    border: 1px solid #DDDDDD;
    padding: 15px 0 15px 45px;
    vertical-align: middle;
    font-weight: 500;
   }
    .present_detail th.note {
      background-color: #E2F5FF;
      font-size: 1.5rem;
     }
  .present_detail th span {
    color: #0E202A;
    font-size: 1.5rem;
  }

  .present_detail td {
    border: 1px solid #C2CAD6;
    padding: 15px 5px;
    text-align: center;
    vertical-align: middle; }
    .present_detail td ul {
      display: flex;
      align-items: center;
      justify-content: center; }
      .present_detail td ul li {
        letter-spacing: -0.05em; }
        .present_detail td ul li:first-child {
          font-size: 87.5%;
          width: 35%; }
        .present_detail td ul li:last-child {
          box-sizing: border-box;
          font-size: 87.5%;
          position: relative;
          width: 37%; }
    .present_detail td.note ul li:first-child {
      color: #065FE3;
      font-size: 87.5%; }
    .present_detail td.note ul li:last-child {
      color: #916D00;
      font-size: 1.5rem;
      font-weight: 700;
      width: 42%; }

  .present_detail tr:first-of-type th {
    text-align: left;
    padding: 20px 0 22px 45px;
   }
   .present_detail tr:first-of-type th p {
    font-size: 1rem;
    font-weight: 400;
   }

    .present_detail tr:first-of-type th.note {
      font-size: 87.5%; }
      .present_detail tr:first-of-type th.note span.note {
        background-color: #E3068E;
        color: #fff;
        font-size: 125%;
        font-weight: 700;
        margin-left: 5px; }


      .present_detail tr:nth-of-type(2) th:last-of-type span {
        background-color: #065FE3;
        color: #fff; }
        .present_detail tr:nth-of-type(2) th:last-of-type span.note {
          background-color: #E3068E;
          font-size: 115%;
          margin-top: 3px;
          display: inline-block; }

.if_start {
  margin-bottom: 55px; }
    .if_start h2:before, .if_start h2:after {
      display: none; }

  .if_start p {
    margin: 0 auto 35px;
    max-width: 720px; }
  .if_start .fig {
    max-width: 720px;
    margin: 0 auto 10px; }
    .if_start .fig img {
      max-width: 100%; }
  .if_start .notice {
    margin: 0 auto;
    max-width: 720px; }
    .if_start .notice li {
      padding-left: 0;
      text-indent: 0; }
  .if_start .more_notice {
    background-color: #fff;
    box-sizing: border-box;
    margin: 30px auto 0;
    max-width: 720px;
    padding: 30px; }
    .if_start .more_notice p {
      color: #666;
      font-size: 75%;
      margin-bottom: 15px;
      text-align: left; }
      .if_start .more_notice p:last-of-type {
        margin-bottom: 0; }
    .if_start .more_notice ul {
      margin-bottom: 15px;
      padding-left: 20px; }
      .if_start .more_notice ul li {
        color: #666;
        font-size: 75%;
        padding-left: 1em;
        text-indent: -1em; }

.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 9999; }

.modal__bg {
  background: rgba(227, 245, 254, 0.9);
  height: 100vh;
  position: absolute;
  width: 100%;
  z-index: 9999; }

.modal__content {
  background: #fff;
  box-sizing: border-box;
  left: 50%;
  padding: 60px 100px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  max-width: 800px;
  z-index: 9999; }
  .modal__content ul {
    margin: 20px 0; }
    .modal__content ul li {
      color: #535E6F;
      margin-bottom: 10px;
      position: relative;
      padding-left: 20px; }
      .modal__content ul li:last-child {
        margin-bottom: 0; }
      .modal__content ul li span {
        position: absolute;
        top: 0px;
        left: 0px; }
  .modal__content p {
    color: #535E6F; }
  .modal__content .modal_detail {
    max-height: 80vh;
    overflow-y: scroll;
    max-width: 800px;
    margin: 0 auto;
    -ms-overflow-style: none;
    scrollbar-width: none; }
    .modal__content .modal_detail::-webkit-scrollbar {
      display: none; }


.modal_detail span {
  position: relative;
  cursor: pointer;
}


.modal_detail span {
  position: absolute;
  top: -40px;
  right: 35px;
}

.modal_detail span::after {
  content: url(../img/close_btn.png);
  margin-left: 10px;
  position: absolute;
}



.js-modal-close span {
  position: absolute;
  top: 20%;
  right: 20%;
  display: inline-block;
}



.notice li, .notice-2 li {
  padding-left: 2rem;
  text-indent: -1em;
  line-height: 1.5;
  font-size: 1.5rem;
  font-weight: 400;
}
.notice-3 {
  margin: 10px 0 20px;
}
.notice-4 {
  margin: 20px 0;
}
  .notice li.note {
    color: #E3068E;
    font-weight: 700; }
.notice li a {
  color: #0E202A;
}
  .detail_info .sec_cont {
    padding: 60px 60px 30px;
    background-color: #fff;
    margin-bottom: 20px;
    border-radius: 6px;
}
.detail_info .sec_cont.type01 {
  padding-bottom: 1px;
}
.detail_info .sec_cont.type02 {
  padding-bottom: 10px;
}


  .detail_info .sec_sub {
    background-color: #fff;
    box-sizing: border-box;
    width: 100%;
  }
  .detail_info .detail_cont {
    display: flex;
    justify-content: space-between;
    margin: 0 auto 40px;
     }
     .detail_info .detail_cont dd p {
      font-size: 1.5rem;
      line-height: 1.25;
     }
     .detail_info .detail_cont dd .w-normal {
      font-weight: 400;
      font-size: 1.5rem;
     }
    .detail_info .detail_cont dt {
      font-size: 2.4rem;
      font-weight: 700;
      letter-spacing: -0.03em;
      width: 46%;
     }
    .detail_info .detail_cont dd {
      width: 100%;
     }
      .detail_info .detail_cont dd span.note {
        color: #1E5EDA; }
      .detail_info .detail_cont dd ol li {
        margin-top: 5px;
        padding-left: 20px;
        position: relative; }
        .detail_info .detail_cont dd ol li span {
          font-weight: 700;
          position: absolute;
          top: 0px;
          left: 0px; }
        .detail_info .detail_cont dd ol li:first-child {
          margin-top: 0; }
        .detail_info .detail_cont dd ol li sup {
          color: #535E6F;
          font-size: 75%;
          vertical-align: bottom; }
      .detail_info .detail_cont dd .quick_info {
        background-color: #F7F8F8;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        margin: 15px 0;
        padding: 20px;
        position: relative; }
        .detail_info .detail_cont dd .quick_info:before {
          background: linear-gradient(to bottom right, rgba(255, 255, 255, 0) 50%, #F7F8F8 50.5%) no-repeat top left/50% 100%, linear-gradient(to bottom left, rgba(255, 255, 255, 0) 50%, #F7F8F8 50.5%) no-repeat top right/50% 100%;
          content: "";
          display: block;
          height: 14px;
          width: 14px;
          position: absolute;
          top: -14px;
          left: 50px; }
        .detail_info .detail_cont dd .quick_info .pict {
          width: 49%; }
          .detail_info .detail_cont dd .quick_info .pict img {
            width: 100%; }
        .detail_info .detail_cont dd .quick_info dl {
          width: 47%; }
          .detail_info .detail_cont dd .quick_info dl dt {
            font-weight: 500; }
          .detail_info .detail_cont dd .quick_info dl dd {
            font-size: 75%;
            padding-left: 15px;
            position: relative; }
            .detail_info .detail_cont dd .quick_info dl dd span {
              position: absolute;
              top: 0px;
              left: 0px; }
        .detail_info .detail_cont dd .quick_info p {
          font-size: 75%;
          margin-top: 15px;
          width: 100%; }
  .detail_info .present_detail th {
    font-size: 100%;
    font-weight: bold;
    font-size: 1.5rem;
   }
  .detail_info .present_detail td {
    font-size: 100%;
    font-weight: bold;
    color: #916D00;
   }


  .detail_info .target_info {
    border: 2px solid #C2CAD6;
    margin-top: 10px;
    padding: 20px; }
    .detail_info .target_info dt {
      width: 100%; }
    .detail_info .target_info dd {
      margin-top: 2px;
      width: 100%; }
    .detail_info .target_info .notice {
      margin-top: 10px; }
  .detail_info .sec_notice {
    width: 100%;
    margin: 0 auto; }
    .detail_info .sec_notice h3 {
      font-size: 150%;
      font-weight: 700;
      margin-bottom: 20px; }
      .detail_info .sec_notice h3 sup {
        font-size: 50%;
        font-weight: 500;
        margin-right: 4px;
        vertical-align: 0.9em; }
    .detail_info .sec_notice p {
      font-size: 1.8rem;
      font-weight: 700;
      letter-spacing: -0.01em;
     }
    .detail_info .sec_notice dl {
      margin-top: 30px; }
      .detail_info .sec_notice dl dt {
        font-size: 1.8rem;
        font-weight: 700;
        margin-bottom: 10px;
       }
      .detail_info .sec_notice dl dd {
        color: #0E202A;
        font-size: 1.5rem;
        letter-spacing: 0;
        font-weight: 400;
      }
      .detail_info .sec_notice dl dd .notice {
        margin-top: 10px;
      }

      .detail_info .sec_notice dl:last-of-type dd .notice {
        margin-top: 20px; }

.assignment {
  padding: 100px 0;
  background-color: #F2F6F8;
 }
  .assignment h2 {
    margin: 0 auto 35px; }
  .assignment .sec_cont {
    background-color: #F7F8F8;
    padding: 30px 20px 50px; }
  .assignment .sec_sub {
    background-color: #fff;
    border: 2px solid #145296;
    border-radius: 6px;
    box-sizing: border-box;
    width: 100%;
    margin: 0 auto 20px;
    padding: 30px 20px; }
    .assignment .sec_sub h3 {
      font-size: 1.8rem;
      font-weight: 700;
      margin-bottom: 10px;
      text-align: center;
      color: #145296;
     }
    .assignment .sec_sub p {
      margin: 0 auto;
      width: 100%;
      max-width: 629px;
     }
      .assignment .sec_sub p.indent {
        font-size: 1.5rem;
        margin-top: 15px;
        text-indent: -1em;
        padding-left: 1em;
        max-width: 599px;
        font-weight: 400;
        line-height: 1.5;
       }
  .assignment .sec_notice {
    width: 100%;
    margin: 0 auto;
    padding: 6rem 6rem 4rem;
    background-color: #fff;
    border-radius: 6px;
   }
    .assignment .sec_notice h3 {
      font-size: 1.8rem;
      font-weight: 700;
      margin-bottom: 30px;
       }
    .assignment .sec_notice .notice li ul {
      margin-left: 30px; }
      .assignment .sec_notice .notice li ul li {
        padding-left: 0;
        text-indent: 0; }

.finance_info {
  margin-bottom: 100px;
  padding: 0 20px; }
  .finance_info .finance_cont {
    background-color: #EDF9FF;
    box-sizing: border-box;
    margin: 0 auto;
    max-width: 1040px;
    padding: 45px 20px; }
  .finance_info dl {
    margin: 0 auto;
    max-width: 800px; }
    .finance_info dl dt {
      color: #666;
      font-size: 75%;
      font-weight: 700; }
    .finance_info dl dd {
      color: #666;
      font-size: 75%;
      margin-top: 15px; }

.sns_area {
  background: url("../img/sns_bg02.png") no-repeat 50% 100%, url("../img/sns_bg01.png") no-repeat 50% 0;
  background-size: 100%, cover;
  min-height: 90px;
  padding: 40px 20px; }
  .sns_area h2 {
    font-size: 150%;
    font-weight: 700;
    margin: 0 auto 25px;
    text-align: center; }
  .sns_area ul {
    display: flex;
    justify-content: center; }
    .sns_area ul li {
      margin: 0 15px; }
      .sns_area ul li a {
        transition: opacity 0.6s;
        text-decoration: none; }
        .sns_area ul li a:hover {
          opacity: 0.8; }
        @media screen and (max-width: 960px) {
          .sns_area ul li a:hover {
            opacity: 1; } }
      .sns_area ul li img {
        width: 48px; }

.start_info {
  margin-bottom: 100px; }
  .start_info h2 {
    max-width: 720px;
    margin: 0 auto 15px; }
    .start_info h2:before, .start_info h2:after {
      display: none; }
  .start_info .sec_cont {
    background-color: #C3EBFF;
    padding: 55px 20px; }
  .start_info p.lead {
    margin-bottom: 70px;
    text-align: center; }
  .start_info .start_steparea {
    max-width: 920px;
    margin: 0 auto; }
  .start_info .step_cont {
    background-color: #fff;
    margin-bottom: 90px;
    padding: 0 20px 40px;
    position: relative; }
    .start_info .step_cont:after {
      background: linear-gradient(to top right, rgba(255, 255, 255, 0) 50%, #fff 50.5%) no-repeat top left/50% 100%, linear-gradient(to top left, rgba(255, 255, 255, 0) 50%, #fff 50.5%) no-repeat top right/50% 100%;
      content: "";
      display: block;
      height: 35px;
      width: 60px;
      margin: 0 auto;
      position: absolute;
      bottom: -35px;
      left: 0;
      right: 0; }
    .start_info .step_cont h3 {
      background-color: #F7F8F8;
      color: #065FE3;
      font-size: 150%;
      font-weight: 700;
      margin: 0 -20px 25px;
      padding: 35px 20px 20px;
      position: relative;
      text-align: center; }
      .start_info .step_cont h3 span {
        background-color: #065FE3;
        border-radius: 20px;
        color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        height: 40px;
        margin: 0 auto;
        position: absolute;
        top: -20px;
        left: 0;
        right: 0;
        width: 185px; }
    .start_info .step_cont .step_pict {
      display: flex;
      justify-content: center;
      margin: 0 auto 40px; }
      .start_info .step_cont .step_pict .pict {
        margin: 0 15px 0 0; }
        .start_info .step_cont .step_pict .pict img {
          max-width: 100%; }
      .start_info .step_cont .step_pict p {
        margin: 0 0 0 15px; }
    .start_info .step_cont .btn {
      margin: 0 auto;
      max-width: 475px; }
      .start_info .step_cont .btn a {
        background: #E3068E;
        border-radius: 5px;
        color: #fff;
        font-size: 135%;
        font-weight: 700;
        height: 60px;
        display: flex;
        justify-content: center;
        align-items: center;
        transition: opacity 0.6s;
        text-decoration: none; }
        .start_info .step_cont .btn a:hover {
          opacity: 0.7; }
        @media screen and (max-width: 960px) {
          .start_info .step_cont .btn a:hover {
            opacity: 1; } }
    .start_info .step_cont .notice {
      max-width: 720px;
      margin: 25px auto 0; }
    .start_info .step_cont p.step_lead {
      font-weight: 700;
      margin: 0 auto 20px;
      text-align: center; }
    .start_info .step_cont .step_logo {
      margin: 0 auto 35px;
      text-align: center; }
      .start_info .step_cont .step_logo img {
        max-width: 100%; }
    .start_info .step_cont .step_rowarea {
      display: flex;
      justify-content: space-between;
      max-width: 770px;
      margin: 0 auto; }
      .start_info .step_cont .step_rowarea .row_cont {
        width: 40%; }
        .start_info .step_cont .step_rowarea .row_cont h4 {
          font-size: 135%;
          font-weight: 700;
          margin: 0 auto 25px;
          text-align: center; }
        .start_info .step_cont .step_rowarea .row_cont ul {
          display: flex;
          justify-content: center;
          position: relative; }
          .start_info .step_cont .step_rowarea .row_cont ul:after {
            background-position: 0 0;
            background-repeat: no-repeat;
            background-size: 100%;
            overflow: hidden;
            text-indent: 180%;
            white-space: nowrap;
            content: "";
            display: block;
            height: 30px;
            width: 32px;
            background-image: url("../img/step_arrow01.png");
            margin: 0 auto;
            position: absolute;
            top: 20px;
            left: 0;
            right: 0; }
          .start_info .step_cont .step_rowarea .row_cont ul li {
            margin-right: 40px;
            max-width: 100px;
            text-align: center; }
            .start_info .step_cont .step_rowarea .row_cont ul li img {
              display: block;
              max-width: 70px;
              margin: 0 auto 5px; }
            .start_info .step_cont .step_rowarea .row_cont ul li:last-child {
              margin: 0 0 0 40px; }
              .start_info .step_cont .step_rowarea .row_cont ul li:last-child img {
                max-width: 45px; }
        .start_info .step_cont .step_rowarea .row_cont .pict {
          margin: 0 auto 13px;
          text-align: center;
          width: 70px; }
          .start_info .step_cont .step_rowarea .row_cont .pict img {
            max-width: 100%; }
        .start_info .step_cont .step_rowarea .row_cont p {
          max-width: 220px;
          margin: 0 auto; }
        .start_info .step_cont .step_rowarea .row_cont .btn {
          margin-top: 20px; }
          .start_info .step_cont .step_rowarea .row_cont .btn a {
            background-color: #fff;
            border: 2px solid #E3068E;
            color: #E3068E;
            font-size: 100%;
            height: 40px;
            padding: 0 30px;
            position: relative; }
            .start_info .step_cont .step_rowarea .row_cont .btn a:after {
              background-position: 0 0;
              background-repeat: no-repeat;
              background-size: 100%;
              overflow: hidden;
              text-indent: 180%;
              white-space: nowrap;
              content: "";
              display: block;
              height: 10px;
              width: 10px;
              position: absolute;
              top: 14px;
              right: 25px;
              background-image: url("../img/step_arrow02.png"); }
  .start_info .benefit_info {
    max-width: 750px;
    margin: 0 auto;
    text-align: center; }
    .start_info .benefit_info dt {
      background-color: #065FE3;
      box-sizing: border-box;
      color: #fff;
      font-size: 150%;
      font-weight: 700;
      height: 100px;
      padding: 34px 20px 0 70px;
      margin-bottom: 20px;
      position: relative; }
      .start_info .benefit_info dt:before {
        background-position: 0 0;
        background-repeat: no-repeat;
        background-size: 100%;
        overflow: hidden;
        text-indent: 180%;
        white-space: nowrap;
        content: "";
        display: block;
        height: 63px;
        width: 80px;
        position: absolute;
        top: 15px;
        left: 40px;
        background-image: url("../img/step_icon.png"); }
      .start_info .benefit_info dt span {
        color: #FFEA55;
        font-size: 115%; }
        .start_info .benefit_info dt span span {
          font-size: 135%; }
    .start_info .benefit_info dd {
      color: #535E6F; }

.risk_info {
  margin-bottom: 100px; }
  .risk_info h2 {
    max-width: 720px;
    margin: 0 auto 35px; }
    .risk_info h2:before, .risk_info h2:after {
      display: none; }
  .risk_info .sec_cont {
    background-color: #F7F8F8;
    padding: 55px 20px; }
  .risk_info p {
    margin: 0 auto 35px;
    max-width: 720px; }
  .risk_info .fig {
    max-width: 720px;
    margin: 0 auto 10px; }
    .risk_info .fig img {
      max-width: 100%; }
  .risk_info .notice {
    margin: 0 auto;
    max-width: 720px; }
    .risk_info .notice li {
      padding-left: 0;
      text-indent: 0; }






/* additional */

.pc-only {
  display: block;
}

.sp-only {
  display: none;
}


.font-style, .font-style h2, .font-style h3, .font-style h5{
  font-weight: bold;
}

.header {
  background-color: #FFCC79;
  background-image: url(../img/fv-bk-blue.svg), url(../img/fv-bk06@2x.png), url(../img/fv-bk05@2x.png);
  background-position: center top, left top, right top;
  background-size: cover, 20% auto, 20% auto;
  background-repeat: no-repeat, no-repeat, no-repeat;
  position: relative;
}

.img-wave-l {
  position: absolute;
  top: 0;
  left: 0;
  width: 18%;
  max-width: 260px;
  height: auto;
}
.img-wave-r {
  position: absolute;
  top: 0;
  right: 0;
  width: 15%;
  max-width: 206px;
  height: auto;
}

.img-boat {
  position: absolute;
  top: 20%;
  left: -5%;
  width: 20%;
  max-width: 280px;
  height: auto;
}

.img-chair {
  position: absolute;
  top: 50%;
  right: 0;
  width: 15%;
  max-width: 135px;
  height: auto;
}

.img-top__belt-l {
  position: absolute;
  bottom: -0.8%;
  left: 0;
  width: 10%;
  max-width: 150px;
  height: auto;
}

.img-top__belt-r {
  position: absolute;
  bottom: -0.5%;
  right: 0;
  width: 15%;
  max-width: 180px;
  height: auto;
}

.top-catch__img {
  width: 90%;
  max-width: 925px;
  margin: 0 auto 45px;
  z-index: 10;
  display: flex;
  justify-content: center;
}

.top-logo__img {
  position: absolute;
  top: 1%;
  left: 1%;
  z-index: 5;
}

.top-period__img {
  width: 50%;
  max-width: 600px;
  margin: 0 auto 77px;
}

.cont_nar {
  width: 95%;
  max-width: 1000px;
  margin: 0 auto;
 }
 .cont_nar h2 {
   font-size: 4.5rem;
   font-weight: bold;
   text-align: center;
 }

.wave__p {
  background-color: #E3F5FE;
  position: relative;
}

.bg-wave {
  position: absolute;
  left: 0;
  bottom: 0;
}

.header-belt {
  width: 100%;
  background-color: #FFF5E2;
  padding: 40px 0;
}
.header-belt__txt {
  width: 490px;
  margin: 0 auto;
}
.header-belt__txt h6 {
  font-size: 1.8rem;
  line-height: 3.6rem;
  font-weight: 600;
  color: #521F00;
  text-align: left;
}

.top-entry__txt h5{
  color: #fff;
}

.top-theo__wrap span {
  background-color: #fff;
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 600;
  color: #1E5EDA;
  margin: 45px auto 0;
  position: relative;
}
.top-theo__wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
}


.top-entry-list {
  margin-top: 40px;
  text-align: left;
  width: 90%;
  max-width: 720px;
  margin: 40px auto -5px;
}
.top-entry-list li {
  line-height: 1.8;
  font-size: 1.5rem;
}
.top-entry-list a {
  color: #0E202A;
}





.how-to {
  background-color: #ACDDF7;
  padding: 50px 0 50px;
}

.how-to h2 {
  text-align: center;
}

.how-to__wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-top: 40px;
}
.how-to__item {
  display: flex;
  flex-direction: column;
  width: 30%;
  position: relative;
}
.how-to-arrow {
  padding-top: 4rem;
}
.how-to-btn__wrap {
  position: absolute;
  bottom: -5.5rem;
  left: 50%;
  width: 95%;
  max-width: 364px;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}
.how-to__img {
  width: 80%;
  max-width: 365px;
  margin: 0 auto;
  margin-bottom: 20px;
}
.how-to__img img {
  width: 100%;
  height: auto;
}
.how-to__txt {
  width: 82%;
  margin: 0 auto 10px;
}
.how-to__txt.flow-1 {
  width: 65%;
  margin: 0 auto;
}

.how-to__txt h4 {
  font-size: 2.4rem;
  font-weight: 600;
  color: #521F00;
}
.how-to__txt p {
  color: #521F00;
}


.how-to_desc li {
  font-size: 1.5rem;
  padding-left: 1.5rem;
  text-indent: -1.5rem;
  color: #521F00;
}

.how-to__compBox {
  background-color: #fff;
  border-radius: 20px;
  display: flex;
  justify-content: space-between;
  padding: 50px 60px;
  align-items: flex-end;
}
.flow-a__img {
  width: 100px;
  margin: 25px auto 20px;
}
.flow-a__img img {
  width: 100%;
}


.compBox__img {
  width: 15%;
  max-width: 150px;
}
.compBox__img img {
  width: 100%;
  height: auto;
}
.compBox__txt {
  text-align: center;
}
.compBox__txt h3 {
  font-size: 250%;
  font-weight: bold;
  color: #FF6200;
  margin-bottom: 20px;
}
.compBox__txt h6 {
  font-size: 110%;
  font-weight: 600;
  color: #521F00;
}



.present_detail.type-2 {
  width: 76.5%;
  max-width: 765px;
  margin: 0 auto;
}
.present_detail.type-2 th {
  padding-left: 80px;
  font-size: 1.8rem;
  font-weight: 700;
}
.present_detail.type-2 tr:first-of-type th {
  padding-left: 80px;
  font-size: 2rem;
}
.present_detail.type-2 tr:first-of-type th span {
  font-weight: 700;
}

@media screen and (max-width: 900px) {
  .present_detail.type-2 th {
    padding-left: 65px;
  }
  .present_detail.type-2 tr:first-of-type th {
    padding-left: 65px;
  }
}





.present_detail.type-2 span {
  font-size: 2rem;
  font-weight: 600;
}

.present_detail td {
  background-color: #fff;
}
.present_detail td:nth-child(0) {
  font-weight: 600;
  color: #FF6200;
}

.notice.nar {
  width: 70%;
  max-width: 552px;
  margin: 0 auto;
  font-size: 1.5rem;
  margin-top: 20px;
}


.if_start h2 {
  text-align: left;
  margin-bottom: 80px;
}
.if-start__wrap {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.if-start__txtBox {
  width: 43%;
}
.if-start__txt-main h4 {
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 3.5rem;
  margin-bottom: 40px;
  text-align: justify;
}
.if-start__txt-sub li {
  font-size: 1.5rem;
  line-height: 2.4rem;
  text-align: justify;
  text-indent: -1.5rem;
  padding-left: 1.5rem;
}
.if-start__imgBox {
  width: 55%;
}
.if-start__imgBox img {
  width: 100%;
}


.law__box {
  background-color: #F2F6F8;
  padding: 38px 80px;
  margin-top: 20px;
}
.law__box h5 {
  font-weight: bold;
  font-size: 1.6rem;
  margin-bottom: 20px;
}
.law__box p {
  margin-bottom: 15px;
  font-size: 1.5rem;
  font-weight: 400;
}
.sec_sub span {
  font-weight: bold;
  color: #145296;
  font-size: 1.8rem;
}
.notice__add {
  font-weight: bold;
  margin-bottom: 30px;
}


.entry-btn__wrap {
  width: 100%;
  max-width: 1190px;
  margin: 0 auto;
  text-align: center;
  padding-bottom: 60px;
  background-color: #F0FCFF;
  border-radius: 10px;
  padding: 40px 0 30px;
}
.btn-disp__wrap h5 {
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  padding: 0 4.5rem;
  line-height: 1;
  background-image: url(../img/line-left-big.png), url(../img/line-right-big.png);
  background-position: left bottom, right bottom;
  background-repeat: no-repeat, no-repeat;
  background-size: contain;
}
.entry-btn__wrap p {
  font-size: 1.5rem;
  font-weight: 400;
  position: relative;
  margin-top: 1.5rem;
}
.btn-disp__wrap h6 {
  font-size: 1.6rem;
  font-weight: 700;
  color: #0E202A;
  margin-top: 40px;
  line-height: 1.2;
  display: inline-block;
  padding: 0 2.5rem;
  background-image: url(../img/line-left.png),url(../img/line-right.png);
  background-position: left bottom, right bottom;
  background-repeat: no-repeat, no-repeat;
  background-size: contain, contain;
}

.btn-disp__wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.btn-entry {
  margin: 15px 0;
  display: inline-block;
  color: #fff;
  border-radius: 9999px;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 90px;
  width: 420px;
  height: 90px;
  text-align: center;
  background: #FF6200 url(../img/arrow-wh.svg) no-repeat 93% center content-box;
  position: relative;
}
.btn-entry.type-s {
  width: 312px;
  height: 54px;
  font-size: 2.4rem;
  line-height: 54px;
  background: #FF6200;
  position: relative;
}
.btn-entry.type-s::after {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  position: absolute;
  top: 42%;
  right: 8%;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.btn-theo {
  margin-top: 15px;
  display: inline-block;
  color: #fff;
  border-radius: 9999px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 50px;
  width: 285px;
  height: 50px;
  text-align: center;
  background: #1E5EDA url(../img/arrow-wh.svg) no-repeat 90% center;
  background-size: 3% auto;
  position: relative;
}
.btn-pay {
  display: inline-block;
  color: #fff;
  border-radius: 9999px;
  font-size: 3rem;
  font-weight: 700;
  line-height: 74px;
  width: 500px;
  height: 74px;
  text-align: center;
  background-image: linear-gradient(to bottom, #D3CB7B 5%, #BBAA56 20%, #B09C46 50%, #D3CB7B 100%);
  position: relative;
}
.btn-flow {
  display: inline-block;
  color: #fff;
  border-radius: 9999px;
  font-size: 3rem;
  font-weight: 700;
  line-height: 74px;
  width: 100%;
  height: 74px;
  text-align: center;
  background-image: linear-gradient(to bottom, #D3CB7B 5%, #BBAA56 20%, #B09C46 50%, #D3CB7B 100%);
  position: relative;
}
.btn-pay.disabled,
.btn-flow.disabled,
.btn-entry.disabled {
	background-image: none;
	background-color: #9E9E9E;
}
.how-to-btn__wrap::before {
  display: none;
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 9999px;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #FFF;
  opacity: 1;
  }
  .how-to-btn__wrap:hover::before {
    display: block;
  }
  .how-to-btn__wrap a:hover {
    opacity: 0.8;
  }



.btn-wrap {
  width: 100%;
  text-align: center;
}


.detail_info {
  background-color: #ACDDF7;
  padding: 100px 2.5% 80px;
}

.detail_info h2 {
  font-size: 4.5rem;
  line-height: 6.6rem;
  font-weight: 600;
  text-align: center;
  margin: 0 auto 40px;
}

.detail_info .detail_cont h3 {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.5;
}
.detail-pre-list li {
  line-height: 2;
  text-indent: -2.2rem;
  padding-left: 2.2rem;
}
.detail-pre-list li span {
  color: #0E202A;
  font-weight: 400;
  font-size: 1.5rem;
}


.detail-pay__num-list dd {
  text-indent: -1.6rem;
  padding-left: 1.6rem;
  margin: 5px 0;
  font-size: 1.5rem;
  font-weight: 400;
}

.txt__att {
  color: #DA1E1E;
  font-weight: bold;
}

.note-02 {
  color: #145296;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.5;
  display: inline-block;
  margin-bottom: 8px;
}
.note-02 a {
  color: #145296;
}

.note-02 p {
  color: #1E5EDA;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 3.6rem;
  display: inline-block;
}
.note-02.ttl {
  font-size: 2.4rem;
}
.note-03 p {
  color: #0E202A;
  font-weight: bold;
  font-size: 1.5rem;
  margin-bottom: 8px;
}



.detail-pay__wrap {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
}
.pict {
  width: 50%;
  max-width: 300px;
}
.pict img {
  max-width: 100%;
  height: auto;
}
.detail-pay__txt {
  width: 50%;
  padding-right: 20px;
}
.detail-pay__txt p {
  font-weight: bold;
  font-size: 1.5rem;
  margin: 0 0 10px;
}


.c__margin-20 {
  margin-top: 20px;
}

.foot-sns-txt h3 {
  color: #023F60;
  font-size: 2.4rem;
  font-weight: 600;
  text-align: center;
  position: absolute;
  top: 3.5rem;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  z-index: 1;
}


.bg-wave__area {
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
  position: relative;
}
.wave-01 {
  background-color: #fff;
  background-image: url(../img/wave-sky.svg);
  padding: 100px 0;
}
.wave-02 {
  background-color: #E3F5FE;
  background-image: url(../img/bk-w.svg);
  padding: 60px 0;
}
.sand-01 {
  background-color: #fff;
  background-image: url(../img/wave-sand1.svg);
  padding: 100px 0;
}


.foot__sns-share {
  background-color: #ACDDF7;
  background-image: url(../img/sns-bg-l.png), url(../img/sns-bg-r.png), url(../img/sns-bg.png);
  background-position: left top, right top, 50% 2rem;
  background-size: 29%, 29%, cover;
  background-repeat: no-repeat, no-repeat, no-repeat;
  padding: 155.5px 0;
  position: relative;
}


.sns__wrap {
  display: flex;
  justify-content: center;
  width: 100%;
  position: absolute;
  top: 8.5rem;
  z-index: 1;
}
.sns__icon {
  width:48px;
  height: 48px;
  margin: 0 10px;
}
.sns__icon a {
  display: inline-block;
  width: 48px;
  height: 48px;
  border-radius: 9999px;
  text-decoration: none;
  position: relative; /* 追加 */
}
.sns__icon a:hover {
  opacity: 1;
}


.sns__icon a::before{
  display: none;
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 9999px;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #FFF;
  opacity: 0.3;
}
.sns__icon a:hover::before{
  display: block;
}





.sns__icon img {
  width: 100%;
}

.how-to__btnBox {
  text-align: center;
}

.item-center p {
  text-align: center;
}
