@charset "UTF-8";
/* Font Style
 * --------------------------------------- */
@import url("https://fonts.googleapis.com/css2?family=Oswald&display=swap");
body {
  font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, "游ゴシック Medium", YuGothic, YuGothicM, arial, helvetica, sans-serif; }

.oswald {
  font-family: 'Oswald', sans-serif;
  font-weight: 400;
  font-size: 1.85em; }

 /* Base Style
* --------------------------------------- */
html {
  font-size: 10px; }

body {
  background: #fff;
  font-size: 1.6rem;
  color: #333;
  font-feature-settings: 'palt';
  letter-spacing: 0.03em; }

a:link {
  color: #333; }

a:visited {
  color: #333; }

a:hover {
  transition: all .5s ease-in-out;
  color: #333;
  opacity: .65;
  cursor: pointer; }

img {
  max-width: 100%;
  vertical-align: middle; }

p {
  font-size: 1.6rem;
  line-height: 1.6; }

/*lightblue*/
br.pcOnly {
  display: block; }

br.spOnly {
  display: none; }

img.pcOnly {
  display: block; }

img.spOnly {
  display: none; }

li.pcOnly {
  display: block; }

li.spOnly {
  display: none; }

.txtC {
  text-align: center; }

.txtR {
  text-align: right; }

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

.anchor {
  display: block;
  padding-top: calc(100px + 2rem);
  margin-top: calc(-100px - 2rem);
  font-size: 1rem;
  /* for SP JS */ }

#pgtop_pc {
  display: none;
  position: fixed;
  right: 0;
  bottom: max(20vh, 180px);
  z-index: 1002; }

#pgtop_sp {
  display: none; }

.flexverC {
  display: flex;
  align-items: center;
  margin: 0; }

 /* parts style
* --------------------------------------- */
a.btn_apply {
  display: inline-block;
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 3em;
  padding: 0 3em 0 4em;
  background: linear-gradient(180deg, #ff8c96 0%, #ff5168 100%);
  border-radius: 6px; }
  a.btn_apply::before {
    content: "";
    position: absolute;
    width: 1.5em;
    height: 1.5em;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    background-repeat: no-repeat;
    background-position: center;
    width: 3em;
    height: 3em;
    left: .5em;
    background-image: url("/r/img/ic_btnSupport.svg"); }

.head_ontheline {
  position: relative;
  font-size: 2.6rem;
  font-weight: bold;
  width: 1000px;
  margin: 0 auto;
  letter-spacing: 0.1em;
  text-align: center; }
  .head_ontheline div {
    display: inline-block;
    padding: .8em;
    background: #fff; }
  .head_ontheline::before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    width: 100%;
    height: 1px;
    background: #999;
    z-index: -1; }
  .head_ontheline::after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 525px;
    height: 100%;
    background: #fff;
    z-index: -1; }

/*  header
/* ======================================= */
.header {
  position: sticky;
  top: 0;
  z-index: 100;
  width: 100%;
  height: 100px;
  background: #fff;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1); }
  .header .inner {
    width: 1300px;
    height: 100%;
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto; }
    .header .inner .logo_bicG {
      position: absolute;
      top: 15px;
      right: 0; }
    .header .inner h1 {
      width: 308px; }
  .header nav ul {
    width: 817px;
    display: flex;
    justify-content: space-between;
    font-size: 1.5rem;
    font-weight: bold;
    margin-top: 30px; }
    .header nav ul a {
      position: relative; }
      .header nav ul a:hover::after {
        position: absolute;
        bottom: -20px;
        left: 50%;
        transform: translate(-50%);
        content: "";
        width: 12px;
        height: 12px;
        background-image: url("/r/img/arrow_down_lb.svg");
        background-repeat: no-repeat; }
  .header::before {
    content: "";
    position: fixed;
    top: 0;
    display: block;
    width: 100%;
    height: 5px;
    background: linear-gradient(to right, #30b5ef 0%, #0075c1 100%); }

/*  mv
/* ======================================= */
.sec_mv {
  width: 100%;
  overflow: hidden; }
  .sec_mv .mv {
    position: relative;
    width: 1400px;
    margin: 0 auto; }
    .sec_mv .mv .mv_img {
      width: 100%; }
    .sec_mv .mv h2 {
      position: absolute;
      top: 60px;
      left: 50%;
      transform: translateX(-50%); }
    .sec_mv .mv .mv_medal {
      position: absolute;
      bottom: 25px;
      right: 80px; }
    .sec_mv .mv .btn_apply {
      position: absolute;
      bottom: 70px;
      left: 50%;
      transform: translateX(-50%); }

/*  sec_about
/* ======================================= */
.sec_about {
  position: relative;
  width: 100%; }
  .sec_about::before {
    content: "";
    position: absolute;
    top: 0;
    left: calc(50% - 430px);
    transform: translateX(-50%);
    width: 683px;
    height: 417px;
    background-image: url("/r/img/bg_diag.svg");
    background-repeat: no-repeat;
    background-size: cover;
    z-index: -1; }
  .sec_about::after {
    content: "";
    position: absolute;
    bottom: -60px;
    left: calc(50% + 480px);
    transform: translateX(-50%);
    width: 683px;
    height: 417px;
    background-image: url("/r/img/bg_diag.svg");
    background-repeat: no-repeat;
    background-size: cover;
    z-index: -1; }
  .sec_about .about_deco {
    position: absolute;
    top: -20px;
    left: calc(50% + 460px);
    transform: translateX(-50%); }
  .sec_about .lead {
    font-size: 2.8rem;
    line-height: 1.6;
    text-align: center;
    margin: 0 auto;
    padding: 2em 0 1.5em; }
  .sec_about ul {
    width: 1000px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px 5%;
    margin: 30px auto 70px; }
    .sec_about ul li {
      box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
      border-radius: 6px;
      background-color: #fff;
      padding: 1.5em 2em 1em; }
      .sec_about ul li h5 {
        font-size: 1.8rem;
        font-weight: bold;
        text-align: center; }
      .sec_about ul li p {
        line-height: 1.3; }
      .sec_about ul li img {
        display: block;
        width: 230px;
        margin: 0 auto; }

/*  sec_support
/* ======================================= */
.sec_support ul {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 718px;
  margin: 15px auto 0; }
  .sec_support ul li {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    font-size: 1.5rem;
    height: calc(90px + 2em); }
    .sec_support ul li img {
      width: 90px;
      height: 90px; }
.sec_support .table_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 990px;
  margin: 50px auto 70px; }
  .sec_support .table_area h3 {
    position: relative;
    font-size: 1.8rem;
    font-weight: bold;
    width: 990px;
    margin: 0 auto 1em;
    padding-left: 1.5em; }
    .sec_support .table_area h3::before {
      content: "";
      position: absolute;
      width: 1.5em;
      height: 1.5em;
      top: 50%;
      transform: translateY(-50%);
      left: 0;
      background-repeat: no-repeat;
      background-position: center;
      width: 1em;
      height: 1em;
      border-radius: 50%;
      background: #41bbe5; }
  .sec_support .table_area .table_wrp {
    width: 475px; }
    .sec_support .table_area .table_wrp h4 {
      color: #fff;
      font-weight: bold;
      text-align: center;
      padding: .5em 0;
      background: #0068b6; }
    .sec_support .table_area .table_wrp table {
      margin-top: -15px; }
      .sec_support .table_area .table_wrp table th {
        width: 50%;
        font-size: 1.54rem;
        font-weight: normal;
        color: #0068b6;
        text-align: center;
        border-bottom: 1px solid #ddd;
        padding: .55em 0; }
      .sec_support .table_area .table_wrp table td {
        font-size: 1.5rem;
        line-height: 1.4;
        border-bottom: 1px solid #ddd;
        padding: .6em 0; }
        .sec_support .table_area .table_wrp table td:nth-child(1) {
          padding-right: 1em; }
        .sec_support .table_area .table_wrp table td:nth-child(2) {
          padding-left: 1em; }

/*  sec_step
/* ======================================= */
body {
  counter-reset: sec_step; }

.sec_step {
  margin-bottom: 50px; }
  .sec_step .ol_wrp {
    width: 1000px;
    margin: 0 auto; }
  .sec_step ol {
    position: relative;
    width: 50%;
    margin-left: 50%;
    padding: 30px 0 10px; }
    .sec_step ol::before {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 1px;
      height: calc(100% - 2em);
      background: #eee;
      z-index: -1; }
    .sec_step ol::after {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      transform: translateX(-50%);
      width: 11px;
      height: 11px;
      border-radius: 50%;
      background: #41bbe5;
      z-index: 1; }
    .sec_step ol li {
      display: flex;
      align-items: center;
      width: 100%;
      height: 150px;
      position: relative;
      padding-left: 80px; }
      .sec_step ol li p {
        font-size: 1.9rem; }
        .sec_step ol li p span {
          font-size: 1.5rem;
          display: block;
          margin-top: .3em; }
      .sec_step ol li img {
        position: absolute;
        top: 0;
        left: -305px; }
      .sec_step ol li::before {
        display: flex;
        justify-content: center;
        align-items: center;
        counter-increment: sec_step;
        content: counter(sec_step);
        color: #41bbe5;
        font-size: 4.8rem;
        font-weight: 500;
        font-style: oblique;
        font-family: Futura, "Century Gothic", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, "游ゴシック Medium", YuGothic, YuGothicM, arial, helvetica, sans-serif !important;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        left: -45px;
        width: 90px;
        height: 90px;
        border-radius: 50%;
        background: #fff;
        box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1); }
      .sec_step ol li:nth-child(2) {
        text-align: right;
        margin-left: calc(-100% + 100px); }
        .sec_step ol li:nth-child(2) img {
          left: 570px;
          top: -40px; }
        .sec_step ol li:nth-child(2)::before {
          left: calc(500px - 45px - 100px); }
      .sec_step ol li:nth-child(3) p {
        margin-top: .3em; }
      .sec_step ol li:nth-child(3) img {
        left: -372px;
        top: -25px; }
  .sec_step strong {
    display: block;
    font-size: 2rem;
    text-align: center;
    margin: 0 auto; }
