@charset "utf-8";
.page_title {
  background: url(../img/page_title.png) no-repeat center;
  background-size: cover;
  h1 {margin-bottom: 0;}
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    width: 600px;
    padding: 1em 20px;
  }
}

.intro_block {
  padding: 64px 0;
  p {
    font-size: 2rem;
    letter-spacing: 1px;
  }
  @media screen and (max-width: 767px) {
    padding: 40px 5%;
  }
}

.reason_block {
  &:last-of-type {
    margin-bottom: 88px;
  }
  @media screen and (max-width: 767px) {
    margin-bottom: 32px;
  }
}

.reason_ttl {
  text-transform: uppercase;
  font-family: var(--font-en);
  font-size: 12.8rem;
  letter-spacing: 6.4px;
  font-weight: 700;
  color: rgba(185, 241, 255, 0.50);
  margin-bottom: -65px;
  @media screen and (max-width: 767px) {
    font-size: 6.4rem;
    letter-spacing: 3.2px;
    margin-bottom: -34px;
  }
}

.reason_art {
  background: rgba(185, 241, 255, 0.50);
  padding: 40px 56px 64px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px 36px;
  hgroup {
    display: flex;
    align-items: center;
    gap: 32px;
    margin-bottom: 32px;
  }
  hgroup p {
    text-transform: capitalize;
    background: var(--orange);
    color: #fff;
    width: 76px;
    min-width: 76px;
    height: 76px;
    border-radius: 50%;
    font-family: var(--font-en);
    font-size: 2rem;
    letter-spacing: 1px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-top: 8px;
    span {
      display: block;
      font-size: 3.2rem;
      letter-spacing: 1.6px;
      margin-top: -20px;
    }
  }
  h2 {
    color: var(--main-color);
    line-height: 1.7;
    font-size: 3.6rem;
    letter-spacing: 1.8px;
  }
  @media screen and (max-width: 767px) {
    padding: 40px 5% 64px;
    flex-direction: column;
    align-items: center;
    hgroup {
      gap: 10px;
    }
    h2 {
      font-size: 2.4rem;
      letter-spacing: 1.2px;
      line-height: 1.5;
    }
  }
}
.intro_block + .reason_block .reason_art {
  flex-direction: column;
}

#block_02 h2 {
  font-size: 2.8rem;
  letter-spacing: 1.4px;
  @media screen and (max-width: 767px) {
    font-size: 2rem;
    letter-spacing: 1px;
  }
}

.reason_figure {
  position: relative;
  width: 100%;
  background: #fff;
  border: 1px solid #22BCE6;
  padding: 0 56px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  margin-top: 3em;
  h3 {
    color: #fff;
    text-align: center;
    font-size: 2rem;
    letter-spacing: 1px;
    min-height: 104px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  figure {
    margin-top: 20px;
    display: flex;
    justify-content: center;
  }
  li:first-child {
    margin-top: -3em;
    width: 100%;
    max-width: 240px;
    h3 {background: #22BCE6;}
  }
  li:last-child {
    width: 100%;
    max-width: 810px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 48px;
    div {
      width: 100%;
      max-width: 240px;
    }
    div:nth-child(1) h3 {background: #11238C;}
    div:nth-child(2) h3 {background: #1651A7;}
    div:nth-child(3) h3 {background: #1C87C7;}
  }
  @media screen and (max-width: 767px) {
    padding: 0 2.5% 32px;
    h3 {
      font-size: 1.6rem;
      letter-spacing: 0.8px;
      min-height: 72px;
      padding: 0 4px;
    }
    li:last-child {
      gap: 6px;
      div {
        width: calc(33.3% - 4px);
      }
      h3 {
        font-size: min(14px, 3vw);
      }
    }
  }
}

.reason_art--txt {
  & + figure {
    min-width: 411px;
    figcaption {text-align: right;font-size: 1.4rem;}
  }
  @media screen and (max-width: 767px) {
    & + figure {
      min-width: initial;
      figcaption {text-align: left;}
    }
  }
}