@charset "utf-8";

/* override */
.serviceLogoHeadline {
  .image {
    @media (width < 768px) {
      width: 150px;
    }
  }
}
.underContentTxt:first-child {
  width: 100%;
  margin-inline: 0;
}
.underContentCaution {
  color: #DE0012;
}

.p-miyaburu {
  /* CSS カスタムプロパティ */
  --color-primary: #1897E1;
  --color-guide-sub-ttl: #D90001;
  --color-caution: #FF4E4E;
  --color-case-sub-ttl: #000;
  --bg-primary: #F2F9FD;
  --bg-gray: #F7F7F7;
  --bg-white: #fff;
  --border-primary: #EDEDED;
  --border-ttl: #35318f;
  --border-width-case: 4px;
  --border-width-evaluation: 4px;

  margin: 0 auto;

  /* reset */
  figure {
    margin: 0;
  }
  img {
    width: 100%;
    height: auto;
  }
  
  p {
    text-align: left;
  }

  .c-page__main-ttl {
    margin-bottom: 45px;
    padding: 0.64em 0.5em;
    border-radius: 15px;
    background-color: #1897E1;
    color: #fff;
    font-size: 26px;
    line-height: 1.4em;
    text-align: center;
    @media (width < 768px) {
      font-size: 5.3vw;
      border-radius: 3.2vw;
    }
  }
  .c-page__sub-ttl {
    margin-top: 30px;
    padding: 0.4em 0 0.4em 0.5em;
    border-left: solid 0.25em #1897E1;
    font-size: 24px;
    text-align: left;
    @media (width < 768px) {
      margin-top: 6vw;
      font-size: 4.8vw;
    }
  }
  
  /* common */
  .pcVer {
    display: block;
    @media (width < 768px) {
      display: none;
    }
  }
  .spVer {
    display: none;
    @media (width < 768px) {
      display: block;
    }
  }

  /* guide */
  .p-guide {
    width: 1040px;
    margin-inline: auto;
    box-sizing: border-box;
    @media (width < 768px) {
      width: 100%;
      padding-inline: 4vw;
    }
  }
  .p-guide__inner {
    border-radius: 10px;
    border: 3px solid var(--color-primary);
    background: #FFF;
  }
  .p-guide__ttl {
    padding: 25px 20px;
    color: #fff;
    background: var(--color-primary);
    font-size: 28px;
    text-align: center;
    @media (width < 768px) {
      padding: 10px 20px;
      font-size: 15px;
    }
  }
  .p-guide__img {
    width: 100%;
    max-width: 635.75px;
    height: auto;
    margin: 40px auto 0;
    @media (width < 768px) {
      width: calc(100% - 20px);
      max-width: 287px;
      margin: 40px auto 0;
    }
  }
  .p-guide__txt {
    width: calc(100% - 40px);
    margin: 40px auto 0;
    font-size: 16px;
    line-height: 1.5;
    @media (width < 768px) {
      width: calc(100% - 20px);
      margin: 40px auto 0;
      font-size: 14px;
      line-height: 2;
    }
  }
  .p-guide__note {
    display: flex;
    justify-content: center;
    width: calc(100% - 40px);
    margin: 16px auto 0;
    color: var(--color-caution);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
    @media (width < 768px) {
      width: calc(100% - 20px);
      margin: 14px auto 0;
      font-size: 14px;
      line-height: 2;
    }
    span {
      display: inline-block;
      text-indent: -1em;
      padding-left: 1em;
    }
  }
  .p-guide__box {
    width: calc(100% - 40px);
    margin: 20px 20px 40px;
    padding: 20px 10px;
    border-radius: 10px;
    background-color: var(--bg-primary);
    box-sizing: border-box;
    @media (width < 768px) {
      width: calc(100% - 20px);
      margin: 20px 10px;
      padding: 20px 10px;
    }
  }
  .p-guide__box-ttl {
    color: var(--color-guide-sub-ttl);
    font-size: 20px;
    text-align: center;
    @media (width < 768px) {
      font-size: 16px; 
      line-height: 1.5;
    }
  }
  .p-guide__box-txt {
    margin-top: 25px;
    font-size: 16px;
    line-height: 1.5;
    @media (width < 768px) {
      margin-top: 16px;
      font-size: 14px;
      line-height: 2;
    }
  }

  /* service */
  .p-service {
    width: 1040px;
    margin-top: 60px;
    margin-inline: auto;
    box-sizing: border-box;
    @media (width < 768px) {
      width: 100%;
      margin-top: 50px;
      padding-inline: 4vw;
    }
  }
  .p-service__main-img {
    width: 100%;
    max-width: 774px;
    height: auto;
    margin: 24px auto 0;
    @media (width < 768px) {
      margin: 20px auto 0;
    }
  }
  .p-service__sub-ttl {
    padding: 20px;
    background: var(--bg-gray);
    font-size: 30px;
    font-weight: 900;
    line-height: 1.5;
    letter-spacing: 0.005em;
    text-align: center;
    @media (width < 768px) {
      font-size: 16px;
    }
  }
  .p-service__txt {
    margin-top: 30px;
    font-size: 16px;
    line-height: 2;
    @media (width < 768px) {
      margin-top: 42px;
      font-size: 14px;
    }
    .u-caution {
      color: var(--color-caution);
    }
  }
  .p-service__sub-img {
    width: 100%;
    height: auto;
    margin-top: 70px;
    margin-inline: auto;
    @media (width < 768px) {
      margin-top: 40px;
    }
    img {
      width: 100%;
    }
  }

   /* case */
   .p-case {
    width: 100%;
    margin-top: 80px;
    margin-inline: auto;
    padding-block: 80px;
    background-color: #F2F9FD;
    box-sizing: border-box;
    @media (width < 768px) {
      margin-top: 50px;
      padding: 50px 4vw;
    }
   }
   .p-case__inner {
    width: 1040px;
    margin-inline: auto;
    box-sizing: border-box;
    @media (width < 768px) {
      width: 100%;
    }
  }
  .p-case__container {
    display: grid;
    gap: 20px;
    margin-top: 24px;
    list-style: none;
    @media (width < 768px) {
      gap: 40px;
      margin-top: 20px;
    }
  }
  .p-case__item {
    display: grid;
    grid-template-columns: 200fr 692fr;
    gap: 50px;
    align-items: center;
    justify-content: space-between;
    padding: 25px 20px;
    border: var(--border-width-case) solid var(--border-primary);
    border-radius: 15px;
    background-color: var(--bg-white);
    @media (width < 768px) {
      grid-template-columns: 1fr;
      gap: 15px;
      padding: 25px 20px 15px;
    }
  }
  .p-case__item-img {
    @media (width < 768px) {
      width: 100%;
      max-width: 200px;
      margin-inline: auto;
    }
  }
  .p-case__item-ttl {
    padding: 10px;
    background: #EDEDED;
    color: var(--color-case-sub-ttl);
    font-size: 18px;
    font-weight: 700;
    @media (width < 768px) {
      font-size: 15px;
    }
  }
  .p-case__item-txt {
    margin-top: 4px;
    font-size: 16px;
    line-height: 2;
    @media (width < 768px) {
      margin-top: 8;
    }
  }

  /* engine */
  .p-engine {
    width: 1040px;
    margin-top: 80px;
    margin-inline: auto;
    box-sizing: border-box;
    @media (width < 768px) {
      width: 100%;
      margin-top: 50px;
      padding-inline: 4vw;
    }
  }
  .p-engine__img {
    width: 100%;
    max-width: 810px;
    height: auto;
    margin: 24px auto 0;
  }
  .p-engine__sub-ttl {
    margin-top: 20px;
    padding: 20px;
    background: var(--bg-gray);
    font-size: 30px;
    line-height: 1.5;
    letter-spacing: 0.005em;
    text-align: center;
    @media (width < 768px) {
      padding: 20px 4px;
      font-size: 18px;
    }
    sub {
      font-size: 16px;
      vertical-align: 4px ;
      @media (width < 768px) {
        font-size: 12px;
      }
    }
  }
  .p-engine__txt {
    margin-top: 45px;
    font-size: 16px;
    line-height: 2;
    @media (width < 768px) {
      margin-top: 24px;
      font-size: 14px;
    }
  }
  .p-engine__note {
    margin-top: 6px;
    font-size: 16px;
    line-height: 2;
    @media (width < 768px) {
      margin-top: 12px;
      font-size: 14px;
    }
  }

  /* evaluation */
  .p-evaluation {
    width: 1040px;
    margin-inline: auto;
    margin-bottom: 80px;
    box-sizing: border-box;
    @media (width < 768px) {
      width: 100%;
      margin-block: 50px;
      padding-inline: 4vw;
    }
  }
  .p-evaluation__container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 35px;
    justify-content: space-between;
    margin-top: 24px;
    list-style: none;
    @media (width < 768px) {
      grid-template-columns: 1fr;
      gap: 40px;
    }
  }
  .p-evaluation__item {
    width: 100%;
    padding: 30px 20px;
    border: var(--border-width-evaluation) solid var(--border-primary);
    border-radius: 15px;
    box-sizing: border-box;
    @media (width < 768px) {
      max-width: auto;
      padding: 15px;
    }
  }
  .p-evaluation__sub-ttl {
    padding: 7.5px 10px;
    background-color: #FFD800;
    color: var(--color-case-sub-ttl);
    font-size: 22px;
    font-weight: 700;
    text-align: center;
    @media (width < 768px) {
      font-size: 15px;
    }
  }
  .p-evaluation__img {
    width: 100%;
    max-width: 180px;
    height: auto;
    margin: 20px auto 0;
    @media (width < 768px) {
      margin: 15px auto 0;
    }
  }
  .p-evaluation__txt {
    margin: 20px auto 0;
    font-size: 16px;
    line-height: 2;
    @media (width < 768px) {
      margin: 15px auto 0;
      font-size: 14px;
    }
  }
}