@charset "utf-8";
.page_title {
  background: url(../img/page_title.png) no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    width: 600px;
    padding: 1em 20px;
  }
}

.intro_block {
  padding: 56px 0 64px;
  background: rgba(231, 231, 231, 0.7);
  h2 {
    color: var(--main-color);
    font-size: 3.6rem;
    letter-spacing: 1.8px;
  }
  span.bold_txt {
    color: #1651A7;
    font-size: 2rem;
    letter-spacing: 1px;
  }
  p:last-of-type {
    text-align: center;
    font-size: 2.4rem;
    letter-spacing: 1.2px;
  }
  @media screen and (max-width: 767px) {
    padding: 48px 0 56px;
    h2 {
      font-size: 2.4rem;
      letter-spacing: 1.2px;
    }
    span.bold_txt {
      font-size: 1.6rem;
      letter-spacing: 0.8px;
    }
    p:last-of-type {
      text-align: center;
      font-size: 1.8rem;
      letter-spacing: 0.9px;
    }
  }
}

.feature_point {
  position: relative;
  background: #fff;
  padding: 80px 0 64px;
  &::before {
    content: '';
    position: absolute;
    background: url(../img/arrow.svg)no-repeat center;
    background-size: contain;
    width: 149px;
    height: 98px;
    top: -2em;
    right: 0;
    left: 0;
    margin: auto;
  }
  h2 {
    font-size: 3.6rem;
    letter-spacing: 1.8px;
    color: var(--main-color);
    margin-bottom: 32px;
    text-align: center;
    span {
      font-size: 6.4rem;
      letter-spacing: 3.2px;
    }
  }
  @media screen and (max-width: 767px) {
    h2 {
      font-size: 2.4rem;
      letter-spacing: 1.2px;
      line-height: 1.5;
      span {
        font-size: 4rem;
        letter-spacing: 2px;
      }
    }
  }
}
.feature_list {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
  li {
    position: relative;
    width: calc(33.3% - 13.3px);
    min-height: 280px;
    background: rgba(185, 241, 255, 0.50);
    border-radius: 3px;
    padding: 20px;
    p:first-child {
      background: var(--main-color);
      border-radius: 3px;
      color: #fff;
      font-weight: bold;
      font-size: 2.4rem;
      letter-spacing: 1.2px;
      text-align: center;
      padding: 16px;
      margin-bottom: 24px;
    }
  }
  figure {
    position: absolute;
    width: 100%;
    right: 0;
    left: 0;
    margin: auto;
    bottom: -6em;
    display: flex;
    justify-content: center;
  }
  @media screen and (max-width: 767px) {
    flex-direction: column;
    gap: 64px;
    li {
      width: 100%;
      min-height: initial;
      padding: 20px;
      padding-bottom: 128px;
      p:first-child {
        font-size: 1.8rem;
        letter-spacing: 0.9px;
        padding: 8px;
      }
      p:nth-child(2) {
        min-height: 56px;
      }
    }
    figure {
      bottom: -3.5em;
    }
  }
}
.feature_list + p {
  margin-top: 144px;
  @media screen and (max-width: 767px) {
    margin-top: 96px;
  }
}


.image_sec {
  padding: 56px 0 104px;
  background: linear-gradient(133deg, #DCF8FF 7.5%, #D5FFFA 51.68%, #84C3FF 95.87%);
  h2 {
    font-size: 3.6rem;
    letter-spacing: 1.8px;
    color: var(--main-color);
    margin-bottom: 40px;
    text-align: center;
  }
  h3 {
    font-size: 2.4rem;
    letter-spacing: 1.2px;
    color: var(--main-color);
    line-height: 1.7;
    text-align: center;
  }
  @media screen and (max-width: 767px) {
    padding: 48px 0 64px;
    h2 {
      margin-bottom: 24px;
      font-size: 2.4rem;
      letter-spacing: 1.2px;
      line-height: 1.5;
    }
    h3 {
      font-size: 2rem;
      letter-spacing: 1px;
      line-height: 1.5;
    }
  }
}
.image_sec--inner {
  padding: 48px 64px 64px;
  width: 100%;
  background: #fff;
  @media screen and (max-width: 767px) {
    padding: 40px 5%;
  }
}


.price_sec {
  padding: 56px 0 104px;
  background: linear-gradient(101deg, rgba(17, 35, 140, 0.60) 4.87%, rgba(89, 187, 228, 0.60) 49.65%, rgba(34, 188, 230, 0.60) 94.43%);
  h2 {
    font-size: 3.6rem;
    letter-spacing: 1.8px;
    color: var(--main-color);
    margin-bottom: 40px;
    text-align: center;
  }
  h2 + div {
    padding: 64px 64px 56px;
    width: 100%;
    background: #fff;
    border-radius: 3px;
  }
  @media screen and (max-width: 767px) {
    padding: 48px 0 64px;
    h2 {
      margin-bottom: 24px;
      font-size: 2.4rem;
      letter-spacing: 1.2px;
      line-height: 1.5;
    }
    h2 + div {
      padding: 48px 5%;
    }
  }
}
.price_sec .more_btn {
  background: var(--main-color);
  color: #fff;
  max-width: 320px;
  margin: 0 auto;
}


.result_outer {
  padding: 80px 0 48px;
}
.result_sec--link {
  position: relative;
  width: 90%;
  max-width: 840px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  &::before {
    content: '';
    position: absolute;
    background: url(/security/training-services/img/result_note.svg)no-repeat center;
    background-size: contain;
    width: 390px;
    height: 40px;
    top: -50px;
    right: 0;
    left: 0;
    margin: auto;
  }
  div {
    background: #1651A7;
    padding: 20px;
    padding-top: 0;
  }
  @media screen and (max-width: 767px) {
    &::before {
      width: 100%;
    }
  }
}
.yellow_note {
  color: #F9FF40;
  font-size: 2.4rem;
  letter-spacing: 1.2px;
  text-align: center;
  font-weight: 700;
  span:first-child {
    font-size: 6.4rem;
  }
  span:last-child {
    font-size: 4.8rem;
    letter-spacing: 2.4px;
  }
  @media screen and (max-width: 767px) {
    font-size: 1.8rem;
    letter-spacing: 0.9px;
    span:first-child {
      font-size: 4rem;
    }
    span:last-child {
      font-size: 2.8rem;
      letter-spacing: 1.4px;
    }
  }
}
.yellow_note + p {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  color: #fff;
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 1px;
}
.result_sec--link .bold_txt {
  position: relative;
  background: #9BB7DE;
  color: #000;
  font-size: 1.6rem;
  font-weight: bold;
  padding: 4px 8px;
  text-align: center;
  &::after {
    content: url(/security/common/img/arrow_wht.svg);
    position: relative;
    top: 2px;
    right: -8px;
  }
}