@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");

:root {
  --content-width: 1156px;
  --content-width-wide: 1264px;
}

body {
  font-family: "Noto Sans JP", sans-serif;
}

.contents-wrapper {
  max-width: var(--content-width);
  padding: 80px 0 120px;
  height: 100%;
  margin: 0 auto;
}

.contents-title {
  text-align: center;
  font-weight: 400;

  h2 {
    font-size: 44px;
  }

  .desc {
    margin-top: 32px;
    font-size: 30px;
    font-weight: 400;
  }
}

.accent {
  color: #164ca0;
}

.pc-none {
  display: none;
}

.sp-none {
  display: block;
}

@media screen and (max-width: 767px) {
  .contents-wrapper {
    padding: 60px 24px;
  }

  .contents-title {
    text-align: center;
    font-weight: 400;

    h2 {
      font-size: 22px;
    }

    .headline-bar {
      margin-top: 24px;
    }

    .desc {
      margin-top: 24px;
      font-size: 18px;
      font-weight: 300;
    }
  }

  .pc-none {
    display: block;
  }

  .sp-none {
    display: none;
  }
}

.header-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100px;
  z-index: 999;
  padding: 64px;

  .header-wrapper {
    display: flex;
    justify-content: space-between;

    .logo {
      height: 56px;
      filter: drop-shadow(0px 2px 7px rgba(57, 57, 57, 0.3));
    }

    .btn-contact {
      display: inline-block;
      background-color: #fff;
      color: #164ca0;
      border: 1px solid #164ca0;
      padding: 0 28px;
      font-size: 24px;
      font-weight: 600;
      height: 64px;
      line-height: 64px;
      vertical-align: middle;
      border-radius: 10px;
    }

    .btn-contact:hover {
      background-color: #235bb4;
    }
  }
}

@media screen and (max-width: 767px) {
  .header-container {
    padding: 12px 10px 0 14px;
    height: 50px;

    .header-wrapper {
      align-items: center;
      .logo {
        height: 30px;
      }

      .btn-contact {
        border-radius: 6px;
        font-size: 14px;
        padding: 0 12px;
        height: 32px;
        line-height: 32px;
        border: 1px soild #164ca0;
      }
    }
  }
}

.hero-container {
  position: relative;
  background-image: url(../images/lp/bg_hero.jpg);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center top;
  height: 800px;

  .hero-wrapper {
    position: relative;
    top: 468px;
    left: 0;

    .hero-contents {
      position: relative;
      text-wrap: nowrap;
      text-align: center;

      .title {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        display: block;
        font-weight: bold;
        color: #fff;
        text-shadow: 0 1px 8px rgba(0, 0, 0, 0.5);
      }

      .title-top {
        font-size: 44px;
      }

      .title-bottom {
        font-size: 56px;
      }

      .sub-title {
        padding: 0;
        font-size: 32px;
        color: #fff;
        font-weight: 400;
        text-align: center;
      }

      .sub-title-top {
        position: absolute;
        top: 189px;
        left: 50%;
        transform: translateX(-50%);
        display: block;
        padding: 1px 10px;
        background-color: rgba(0, 0, 0, 0.5);
      }

      .sub-title-bottom {
        position: absolute;
        top: 260px;
        display: inline-block;
        padding: 1px 10px;
        background-color: rgba(0, 0, 0, 0.5);
      }

      br {
        line-height: 0;
        height: 0;
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .hero-container {
    width: 100%;
    height: 500px;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: url(../images/lp/bg_hero.jpg);

    .hero-wrapper {
      top: 259px;
      left: 50%;
      transform: translateX(-50%);

      .hero-contents {
        text-align: center;
        .title {
          padding: 0;
        }

        .title-top {
          display: block;
          font-size: 20px;
        }

        .title-bottom {
          display: block;
          font-size: 32px;
        }

        .sub-title-top {
          top: 70px;
          margin-top: 21px;
          font-size: 18px;
          display: inline-block;
        }

        .sub-title-bottom {
          top: 116px;
          margin-top: 10px;
          font-size: 18px;
        }
      }
    }
  }

  .hero-container .hero-wrapper {
    position: relative;
    display: block;
  }

  .hero-contents {
    position: absolute;
  }

  .hero-contents .title {
    font-size: var(--font-size-40);
    padding: 0 16px;
    line-height: 1.3em;
  }

  .hero-contents .title-02 {
    margin-top: 8px;
  }

  .hero-contents .sub-title {
    font-size: var(--font-size-28);
    padding: 0 16px;
  }

  .hero-contents .desc {
    font-size: 17px;
    padding: 0 16px;
    margin-top: 16px;
    line-height: 1.5em;
  }
}

.needs-contents {
  background-image: url(../images/lp/problem_bg.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: right bottom;

  .contents-title {
    font-size: 44px;
  }

  .contents-content {
    display: flex;
    justify-content: center;
    padding: 0 12px;
    margin-top: 32px;

    img {
      margin-top: 82px;
      width: 1040px;
    }
  }
}

@media screen and (max-width: 767px) {
  .needs-contents {
    .contents-content {
      flex-direction: column-reverse;
      margin-top: 24px;
      padding: 0;

      img {
        margin-top: 32px;
      }

      .problem-image {
        margin: 0 auto;
        text-align: center;
      }

      .problem-list li {
        font-size: 16px;
        column-gap: 6px;
        margin-bottom: 18px;
        align-items: flex-start;
      }
    }
  }

  .needs-contents .problem-list li img {
    width: 24px;
  }

  .needs-contents .problem-image {
    margin-top: 64px;
  }
}

.recommend-wrapper {
  padding-top: 0;
}

.recommend-contents {
  .arrow-down {
    display: block;
    text-align: center;
    margin: 0 auto 65px;
  }
  .usecase-list {
    display: flex;
    flex-wrap: wrap;
    gap: 56px 38px;
    margin-top: 65px;

    li {
      width: calc(calc(100% - 76px) / 3);
      text-align: center;

      span {
        display: block;
        font-size: 28px;
        margin-top: 24px;
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .recommend-contents {
    .arrow-down {
      height: 30px;
    }
    .usecase-list {
      flex-wrap: wrap;
      gap: 30px 22px;
      margin-top: 44px;

      li {
        width: calc(calc(100% - 22px) / 2);

        span {
          display: block;
          font-size: 14px;
          margin-top: 12px;
        }
      }
    }
  }
}

.message-container {
  height: 500px;
  background-image: url(../images/lp/bg_message.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: right;

  .massage-wrapper {
    padding: 122px 0 124px;
  }

  .message {
    position: relative;

    .title {
      font-size: 44px;

      .title-top,
      .title-bottom {
        display: inline-block;
        width: 100%;
        text-align: center;
      }
    }

    .desc {
      text-align: center;
      margin-top: 39px;
      font-size: 30px;
      padding-left: 34px;
      font-weight: 300;
    }
  }
}

@media screen and (max-width: 767px) {
  .message-container {
    height: 312px;
    background-image: url(../images/lp/bg_message.png);
    background-position: center right -50px;
    background-size: cover;
    padding: 0 24px;

    .massage-wrapper {
      padding-top: 64px;
      padding-left: 0;
    }

    .message {
      position: relative;
      width: 100%;
      padding: 24px 0 8px;
      text-align: center;

      .title {
        padding-top: 0;
        padding-right: 0;
        font-size: 22px;

        .title-top,
        .title-bottom {
          font-size: 22px;
          font-weight: 600;
          display: contents;
          width: 100%;
          text-align: left;
        }
      }

      .desc {
        width: 100%;
        margin-top: 24px;
        padding: 0;
        padding-bottom: 8px;
        font-size: 18px;
        font-weight: 400;
      }
    }
  }
}

.curriculum-container {
  .contents-wrapper {
    max-width: var(--content-width-wide);
  }

  .curriculum-wrapper {
    .curriculum-list {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(600px, 1fr));
      gap: 88px 56px;

      .card {
        display: grid;
        grid-template-rows: subgrid;
        grid-row: span 3;
        gap: 0;

        font-size: 28px;
        font-weight: 300;

        .card-header {
          display: flex;
          align-items: center;
          column-gap: 28px;
          font-size: 40px;
        }

        .card-content {
          margin-top: 32px;
        }

        .check-list {
          margin-top: 16px;

          li::before {
            content: "→";
            color: #164ca0;
            margin-right: 8px;
          }
        }
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .curriculum-container {
    .contents-wrapper {
      max-width: 100%;
    }

    .curriculum-wrapper {
      .curriculum-list {
        display: grid;
        grid-template-columns: 1fr;
        row-gap: 76px;

        .card {
          font-size: 16px;

          .card-header {
            column-gap: 9px;
            font-size: 22px;
            font-weight: 600;
          }

          .card-content {
            margin-top: 16px;
          }
        }
      }
    }
  }
}

.comment-container {
  background-image: url(../images/lp/bg_comment.png);
  background-repeat: no-repeat;
  background-size: cover;

  .comment-wrapper {
    padding: 100px 0;
  }

  .comment-area {
    background-color: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(16px);
    padding: 50px 80px;
    border-radius: 10px;
  }

  .title {
    position: relative;
    font-size: 44px;
    text-align: center;
    margin: 0 auto;
  }

  h3 {
    margin-top: 28px;
    font-size: 30px;
    text-align: center;
  }

  p {
    font-size: 24px;
    font-weight: 300;
    margin: 32px auto 0;
    padding: 0 38px;
  }

  a {
    display: block;
    font-size: 28px;
    width: 716px;
    height: 76px;
    line-height: 76px;
    color: #fff;
    background-color: #164ca0;
    text-align: center;
    margin: 64px auto 0;
  }
}

@media screen and (max-width: 767px) {
  .comment-container {
    background-image: url(../images/lp/bg_comment.png);
    background-size: cover;
    background-position: top 0 right -180px;
    .comment-wrapper {
      padding: 72px 24px;
    }

    .comment-area {
      padding: 20px;
    }

    .title {
      font-size: 22px;
    }

    h3 {
      margin-top: 28px;
      font-size: 16px;
      text-align: center;
      text-wrap: balance;
    }

    p {
      font-size: 16px;
      font-weight: 300;
      width: 100%;
      margin: 40px auto 0;
      padding: 0;
    }

    a {
      font-size: 18px;
      width: 100%;
      height: 56px;
      line-height: 56px;
      margin: 40px auto 0;
    }
  }
}

.merit-container {
  .accent {
    font-weight: 600;
  }
  .merit-contents {
    .title-top {
      display: block;
      font-size: 44px;
    }

    .title-bottom {
      display: block;
      font-size: 48px;
    }

    .desc {
      display: inline-block;
      font-size: 30px;
      font-weight: 300;
      text-align: right;

      .desc-span {
        font-size: 24px;
        font-weight: 100;
      }
    }

    .merit-image {
      display: block;
      margin: 64px auto 0;
    }

    .support {
      background-color: #164ca0;
      color: #fff;
      padding: 56px 0;
      margin-top: 64px;

      .title {
        position: relative;
        font-size: 44px;
        text-align: center;
        margin: 0 auto;
      }

      p {
        font-size: 30px;
        font-weight: 300;
        max-width: 727px;
        text-align: center;
        margin: 42px auto 0;
      }

      span {
        display: block;
        margin: 12px auto 0;
        font-size: 28px;
        font-weight: 300;
        text-align: center;
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .merit-container {
    .merit-contents {
      .title-top {
        font-size: 22px;
      }

      .title-bottom {
        font-size: 32px;
      }

      .desc {
        font-size: 18px;
        text-align: center;

        .desc-span {
          font-size: 14px;
          font-weight: 100;
        }
      }

      .merit-image {
        display: block;
        margin: 64px auto 0;
      }

      .support {
        background-color: #164ca0;
        color: #fff;
        padding: 56px 24px;
        margin-top: 64px;

        .title {
          position: relative;
          font-size: 22px;
          text-align: center;
          margin: 0 auto;
          display: flex;
          align-items: baseline;
          justify-content: center;
          text-wrap: nowrap;
        }

        p {
          font-size: 16px;
          font-weight: 300;
          max-width: 727px;
          text-align: left;
          margin: 42px auto 0;
        }

        span {
          display: block;
          margin: 12px auto 0;
          font-size: 16px;
          font-weight: 300;
          text-align: left;
        }
      }
    }
  }
}

.contact-container {
  background-color: #abc1d6;
  height: 520px;
  .contact-wrapper {
    .contents-title {
      color: #fff;

      .title {
        font-size: 48px;
        text-align: center;
        font-weight: 900;
      }

      .sub-title {
        font-size: 36px;
        margin-top: 10px;
      }

      p {
        font-size: 28px;
        margin-top: 24px;
        font-weight: 300;
      }
    }

    .contents-content {
      display: flex;
      justify-content: space-between;
      margin-top: 44px;
      gap: 57px;
      a {
        display: flex;
        flex-direction: column;
        padding: 28px 0 24px;
        width: 100%;
        background-color: #fff;
        color: #164ca0;
        .contact-tel-title,
        .contact-mail-title {
          display: block;
          font-size: 24px;
          text-align: center;
        }

        .contact-tel-value,
        .contact-mail-value {
          display: block;
          font-size: 32px;
          text-align: center;
          font-weight: 500;
        }
      }

      a:hover {
        color: #353535;
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .contact-container {
    height: 462px;
    .contact-wrapper {
      .contents-title {
        .title {
          font-size: 28px;
        }

        .sub-title {
          font-size: 22px;
          margin-top: 8px;
        }

        p {
          font-size: 16px;
          margin-top: 20px;
        }
      }

      .contents-content {
        flex-direction: column;
        margin-top: 36px;
        row-gap: 24px;

        a {
          padding: 15px 0;

          .contact-tel-title,
          .contact-mail-title {
            font-size: 16px;
          }

          .contact-tel-value,
          .contact-mail-value {
            font-size: 22px;
          }
        }
      }
    }
  }
}

.footer-container {
  background-color: #0c2347;
  color: #fff;

  .footer-wrapper {
    padding: 120px 160px 128px;

    .footer-contents {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;

      .company-info {
        font-weight: 300;
        h3 {
          font-size: 34px;
          font-weight: 600;
        }

        .address {
          font-size: 28px;
          margin-top: 15px;
        }

        .info-list {
          margin-top: 15px;

          li {
            .list-head {
              min-width: 154px;
            }

            font-size: 28px;
            display: flex;
            align-items: flex-start;
            text-align: left;
            padding: 4px 0;
          }
        }
      }

      .company-logo img {
        height: 56px;
        text-align: right;
      }
    }
  }
}

@media screen and (max-width: 787px) {
  .footer-container {
    .footer-wrapper {
      padding: 40px 24px 60px;

      .footer-contents {
        display: flex;
        flex-direction: column;
        row-gap: 60px;
        align-items: flex-start;

        .company-info {
          h3 {
            font-size: 22px;
          }

          .address {
            font-size: 16px;
            margin-top: 15px;
          }

          .info-list {
            margin-top: 16px;

            li {
              .list-head {
                min-width: 56px;
              }

              font-size: 16px;
              display: flex;
              align-items: flex-start;
              text-align: left;
              padding: 4px 0;
            }
          }
        }

        .company-logo img {
          height: 32px;
          text-align: right;
        }
      }
    }
  }
}

/* P20250603 */
.comment {
    position: relative;
    margin: 2rem auto;
    display: flex;
    align-items: center;
    gap: 2rem;
    background-color: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(16px);
    padding: 2rem;
    border-radius: 10px;
}
.comment-container .comment-area {
    width: 60%;
    background: none;
    backdrop-filter: none;
    padding: 0;
    border-radius: 0px;
}
.comment .comment-area h2 {
    font-weight: bold;
}
.comment .comment-area h3 {
    text-align: center;
    font-size: 30px;
    margin-top: 1rem;
}
.comment .comment-area ul {
    font-size: 18px;
    margin-top: 1rem;
    border: 1px solid #000;
    padding: 1rem 1rem 1rem 3rem;
}
.comment .comment-area ul li{
    text-indent: -1.25em;
    margin-bottom: 0.25em;
    text-decoration: underline #fff 1px;
}
.comment .comment-area ul li::before{
    content: '';
    display: inline-block;
    width: 0.5em;
    height: 0.5em;
    background-color: #164ca0;
    margin-right: 0.75em;
    border-radius: 50%;
}
.comment-img-area {
    width: 40%;
}
.comment-img-area .comment-img-3{
    display: none;
}
.document-link{
    margin-bottom: 5rem;
}
.document-link div{
    width: 98%;
    max-width: 1000px;
    margin: 1rem auto;
    padding: 2rem;
    text-align: center;
    /* border: 1px solid #164ca0; */
    background-color: rgba(0, 0, 0, 0.3);
}
.document-link h2{
    padding: 0.5rem 2rem;
    font-size: 1.25rem;
    color: #fff;
}
.document-link p{
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0.5rem 1rem;
    gap: 1rem;
    margin-top: 0.5rem;
}
.document-link p a{
    padding: 1rem 1rem 1rem 1.5rem;
    font-size: 1.1rem;
    background: rgb(255 255 255 / 90%);
    color: #164ca0;
    font-weight: 500;
    width: calc((100% - 2rem) / 3);
    margin: 0;
    line-height: 1;
    height: auto;
}
.document-link p a:hover{
    opacity: .8;
    color: #000;
}

.documents-container{
    margin: 0 auto 8rem;
    background: #c5cad1;
    font-size: 16px;
    padding: 2rem 1rem 1rem;
    width: 90%;
    max-width: 1000px;
}
.documents-container h3{
    text-align: center;
    font-size: 18px;
}
.documents-container .documents-item{
    display: flex;
    gap: 2rem;
    justify-content: center;
    padding: 1rem 0;
}
.documents-container a{
    padding: 0.5rem 2rem;
    background: #fff;
    color: #164ca0;
}
.documents-container a:hover{
    color: #000;
}
@media screen and (max-width: 1280px) {
    .comment{
        align-items: start;
        padding: 3rem 3rem 10vw;
        margin-bottom: 4rem;
    }
    .comment-area{
        width: 60%;
    }
    .comment-img-area{
        width: 40%;
    }
    .comment .comment-area h2{
        margin: 0;
    }
    .comment .comment-area ul{
        background: rgb(255 255 255 / 90%);
        width: calc(100% - 2rem);
        font-size: 20px;
    }
}
@media screen and (max-width: 979px) {
    .comment{
        flex-wrap: wrap;
    }
    .comment .comment-area {
        width: 100%;
        padding: 1rem 0;
    }
    .comment .comment-area h3 {
        font-size: 24px;
    }
    .comment .comment-area ul {
        font-size: 18px;
        padding: 1rem 1rem 1rem 2.5rem;
        width: 100%;
        margin-top: 1rem;
    }
    .comment-img-area{
        width: 100%;
        right: 1rem;
        bottom: 0.5rem;
        z-index: 0;
    }
    .documents-container{
        padding: 3rem 1rem 2rem;
    }
    .documents-container .documents-item{
        gap: 1rem;
    }
    .documents-container a{
        text-align: center;
    }
}
@media screen and (max-width: 767px) {
    .comment {
        margin: 0 0 2.5rem;
        padding: 2rem 1rem 0;
        flex-direction: column;
        gap: 0;
    }
    .comment .comment-area h2 {
        font-size: 26px;
    }
    .comment .comment-area h3 {
        font-size: 18px;
        margin-top: 0.5rem;
    }
    .comment .comment-area ul {
        font-size: 16px;
    }
    .comment-image {
        position: absolute;
        top: unset;
        left: 50%;
        bottom: -100px;
        max-width: 180px;
        transform: translateX(-50%);
    }
    .comment-img-area{
        width: 100%;
        right: 1rem;
        bottom: 0.5rem;
        z-index: 0;
    }
    .comment-img-area .comment-img-1 , .comment-img-area .comment-img-2{
        display: none;
    }
    .comment-img-area .comment-img-3{
        display: block;
    }
    .document-link{
        margin-bottom: 0;
    }
    .document-link div{
        width: 90%;
    }
    .document-link h2{
        padding: 0;
        font-size: 1rem;
        margin-bottom: 1rem;
    }
    .document-link p{
        padding: 0;
        flex-direction: column;
    }
    .document-link p a{
        font-size: 1rem;
        width: 100%;
        padding: 0.65rem;
    }
    .documents-container{
        margin: 0;
        padding: 2rem 1rem;
        width: 100%;
    }
    .documents-container h3{
        font-size: 16px;
    }
    .documents-container .documents-item{
        gap: 1rem;
    }
    .documents-container .documents-item{
        padding: 1rem 0;
        gap: 1rem;
        flex-direction: column;
    }
    .documents-container a{
        margin: 0 auto;
        font-size: 1rem;
        padding: 0.65rem;
        line-height: 1;
        width: 80%;
        max-width: 30em;
    }
}