:root {
  --cta-text-color: #000000;
  --cta-white-color: #ffffff;
  --cta-sub-color: #3d84da;
  --cta-main-color: #1058af;
  --cta-highlight-color: #f8ff4d;
  --cta-border-color: #1058af;
  --cta-letter-spacing: -0.03em;
  --cta-box-shadow: 0 4px 4px 0 #00000040;
  --cta-text-shadow: 1px 2px 0 #00000040;
}

/* WordPress CSS対策：CTAコンポーネント専用のリセット */
.cta1,
.cta2,
.cta3 {
  /* フォント継承を防ぐ */
  /* font-family: inherit !important; */
  font-family: "Noto Sans JP", sans-serif !important;
  font-weight: normal !important;
  letter-spacing: normal !important;
  line-height: 1.4 !important;
  text-decoration: none !important;

  /* レイアウトリセット */
  box-sizing: border-box !important;

  /* WordPressのグローバルスタイルを無効化 */
  * {
    box-sizing: border-box !important;
    font-weight: inherit !important;
    letter-spacing: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    text-decoration: none !important;
    transition: none !important;
  }

  /* リンクのスタイルリセット */
  a,
  a:link,
  a:visited,
  a:hover,
  a:active {
    text-decoration: none !important;
    color: inherit !important;
    transition: all 0.3s ease !important;
  }

  /* 画像のスタイルリセット */
  img {
    vertical-align: middle !important;
    border: none !important;
  }

  br {
    display: none !important; /* WordPressの自動挿入を防ぐ */
  }
  .cta1__box-text br {
    display: block !important; /* 必要な場所でのみ表示 */
  }
  .cta2__box-text br {
    display: block !important; /* 必要な場所でのみ表示 */
  }
  .cta2__box2-box br {
    display: block !important; /* 必要な場所でのみ表示 */
  }
}

/* ---------------------------- キラッと光るボタンのCSS --------------------------- */
.btn-glow {
  position: relative;
  overflow: hidden;
  padding: 5px;

  &::before {
    z-index: 10;
    position: absolute;
    content: "";
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(
      90deg,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.85) 45%,
      rgba(255, 255, 255, 0) 100%
    );
    transform: skewX(-45deg);
    animation: glow-animation 2.5s cubic-bezier(0.55, 0.085, 0.68, 0.53)
      infinite;
  }
}
@media (max-width: 767px) {
  .btn-glow {
    padding: 5px 0;
  }
}
@keyframes glow-animation {
  0% {
    left: -100%;
  }
  25%,
  100% {
    left: 100%;
  }
}

/* ------------------------------------------------------------------------------ */
.pc-none {
  display: none !important;
}

.sp-none {
  display: block !important;
}

@media (max-width: 767px) {
  .pc-none {
    display: block !important;
  }

  .sp-none {
    display: none !important;
  }
}

/* ------------------------------ CTA 1 法人向け(大) ----------------------------- */
.cta1 {
  .cta1__wrapper {
    width: min(100%, 740px) !important;
    margin-inline: auto !important;
    border: 3px solid var(--cta-border-color) !important;
    background-color: var(--cta-white-color) !important;
    padding: 28px 39px 16px 39px !important;
    color: var(--cta-text-color) !important;
    box-sizing: border-box !important;
  }
  .cta1__wrapper-red {
    border: 1px solid var(--cta-border-color) !important;
  }

  .cta1__box,
  .cta1__list {
    display: flex !important;
    align-items: center !important;
    flex-flow: row nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .cta1__box {
    justify-content: center !important;
    gap: 24px !important;
    margin-bottom: 15px !important;
  }

  .cta1__box-box {
    width: min(100%, 375px) !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .cta1__box-title {
    color: var(--cta-main-color) !important;
    font-size: 20px !important;
    font-weight: bold !important;
    letter-spacing: var(--cta-letter-spacing) !important;
    margin-bottom: 14px !important;
    margin-top: 0 !important;
    padding: 0 !important;
    line-height: 1.4 !important;
  }

  .cta1__box-text {
    color: var(--cta-text-color) !important;
    font-size: 13px !important;
    font-weight: normal !important;
    letter-spacing: 0 !important;
    margin-bottom: 7px !important;
    margin-top: 0 !important;
    padding: 0 !important;
    line-height: 1.4 !important;
  }

  .cta1__list {
    justify-content: flex-start !important;
    gap: 20px !important;
    list-style: none !important;
  }

  .cta1__item {
    color: var(--cta-main-color) !important;
    font-size: 15px !important;
    font-weight: bold !important;
    letter-spacing: var(--cta-letter-spacing) !important;
    position: relative !important;
    padding-left: 18px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
    list-style: none !important;

    &::before {
      content: "" !important;
      position: absolute !important;
      inset: 0 auto 0 0 !important;
      margin-block: auto !important;
      width: 15px !important;
      height: 15px !important;
      background: no-repeat center / contain
        url("../images/cmn_cta/cta1_deco1.png") !important;
    }

    span {
      /* background-color: var(--cta-highlight-color) !important; */
      color: inherit !important;
      font-weight: inherit !important;
      padding: 0 !important;
      margin: 0 !important;
    }
  }

  .cta1__button,
  .cta1__tel {
    margin: 0 !important;
    padding: 0 !important;

    a {
      display: block !important;
      display: flex !important;
      justify-content: center !important;
      align-items: center !important;
      flex-flow: row nowrap !important;
      text-decoration: none !important;
      color: inherit !important;
    }
  }

  .cta1__button {
    padding-top: 18px !important;

    a {
      width: min(100%, 654px) !important;
      border-radius: 37px !important;
      padding: 11px 10px 15px !important;
      color: var(--cta-white-color) !important;
      margin-inline: auto !important;
      gap: 10px !important;
      position: relative !important;
      box-shadow: var(--cta-box-shadow) !important;
      margin-bottom: 5px !important;
      background: linear-gradient(
        to bottom,
        var(--cta-sub-color) 0%,
        var(--cta-main-color) 76%
      ) !important;
      border: none !important;
      box-sizing: border-box !important;

      &::before,
      &::after {
        content: "" !important;
        position: absolute !important;
        background: no-repeat center / contain !important;
      }

      &::before {
        inset: 0 0 auto 0 !important;
        margin-inline: auto !important;
        width: 213px !important;
        height: 30px !important;
        background-image: url("../images/cmn_cta/cta1_deco3.png?202507172") !important;
        transform: translateY(-17px) !important;
      }

      &::after {
        inset: 0 0 0 auto !important;
        margin-block: auto !important;
        width: 20px !important;
        height: 20px !important;
        background-image: url("../images/cmn_cta/cta1_deco2.png") !important;
        transform: translateX(-35px) !important;
      }

      span,
      strong {
        color: inherit !important;
        font-weight: inherit !important;
        margin: 0 !important;
        padding: 0 !important;
        text-decoration: none !important;
      }

      span {
        font-size: 17px !important;
        font-weight: normal !important;
      }

      strong {
        font-size: 25px !important;
        font-weight: bold !important;
      }
    }
  }


  .cta1__tel {
    a {
      width: fit-content !important;
      margin-inline: auto 0 !important;
      gap: 6px !important;

      strong {
        font-size: 30px !important;
        font-weight: bold !important;
        letter-spacing: 0.05em !important;
        position: relative !important;
        padding-left: 43px !important;
        text-shadow: var(--cta-text-shadow) !important;
        color: var(--cta-text-color) !important;
        margin: 0 !important;

        &::before {
          content: "" !important;
          position: absolute !important;
          inset: 0 auto 0 0 !important;
          margin-block: auto !important;
          width: 35px !important;
          height: 35px !important;
          background: no-repeat center / contain
            url("../images/cmn_cta/cta_tel.png") !important;
        }
      }
    }
  }
}

/* ------------------------------ CTA 2 個人向け(大) ----------------------------- */
.cta2 {
  .cta2__wrapper {
    width: min(100%, 654px) !important;
    margin-inline: auto !important;
    color: var(--cta-text-color) !important;
    box-sizing: border-box !important;
    padding: 0 !important;
  }

  .cta2__box {
    width: fit-content !important;
    margin: 0 auto 9px auto !important;
    position: relative !important;
    padding: 0 40px 5px 40px !important;

    &::before,
    &::after {
      content: "" !important;
      position: absolute !important;
      width: 30px !important;
      height: 33px !important;
      background: no-repeat center / contain !important;
    }

    &::before {
      inset: auto auto 0 0 !important;
      background-image: url("../images/cmn_cta/cta2_deco1.png") !important;
    }

    &::after {
      inset: auto 0 0 auto !important;
      background-image: url("../images/cmn_cta/cta2_deco2.png") !important;
    }

    p {
      color: var(--cta-main-color) !important;
      text-align: center !important;
      font-size: 20px !important;
      font-weight: 500 !important;
      margin: 0 !important;
      padding: 0 !important;
      line-height: 1.4 !important;

      em {
        font-size: 16px !important;
        font-weight: bold !important;
        font-style: normal !important;
        color: inherit !important;
        margin: 0 !important;
        padding: 0 !important;
      }

      small {
        /* font-size: 16px !important; */
        font-size: inherit !important;
        color: inherit !important;
        margin: 0 !important;
        padding: 0 !important;
      }

      span {
        /* background-color: var(--cta-highlight-color) !important; */
        color: inherit !important;
        margin: 0 !important;
        padding: 0 !important;
      }
    }
  }

  .cta2__button {
    padding-top: 20px !important;
    margin-bottom: 10px !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;

    a {
      display: block !important;
      position: relative !important;
      text-decoration: none !important;
      color: inherit !important;
      margin: 0 !important;
      padding: 0 !important;

      &::before {
        content: "" !important;
        position: absolute !important;
        inset: 0 0 auto 0 !important;
        margin-inline: auto !important;
        width: 213px !important;
        height: 30px !important;
        background: no-repeat center / contain
          url("../images/cmn_cta/cta1_deco3.png?20250718") !important;
        transform: translateY(-20px) !important;
      }

      img {
        width: 100% !important;
        height: auto !important;
        display: block !important;
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
      }
    }
  }

  .cta2__box2,
  .cta2__box2-box {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-flow: row nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .cta2__box2 {
    gap: 12px !important;
    align-items: flex-end !important;
  }

  .cta2__box2-box {
    width: fit-content !important;
    gap: 8px !important;

    p {
      color: var(--cta-main-color) !important;
      font-size: 14px !important;
      font-weight: normal !important;
      letter-spacing: var(--cta-letter-spacing) !important;
      margin: 0 !important;
      padding: 0 !important;
      line-height: 1.4 !important;
    }
  }

  .cta2__tel {
    width: fit-content !important;
    margin: 0 !important;
    padding: 0 !important;

    a {
      display: flex !important;
      justify-content: center !important;
      align-items: flex-start !important;
      flex-flow: column nowrap !important;
      text-decoration: none !important;
      color: inherit !important;
      margin: 0 !important;
      padding: 0 !important;

      span {
        position: relative !important;
        padding-left: 43px !important;
        margin: 0 !important;
        color: inherit !important;

        &::before {
          content: "" !important;
          position: absolute !important;
          inset: 0 auto 0 0 !important;
          margin-block: auto !important;
          width: 35px !important;
          height: 35px !important;
          background: no-repeat center / contain
            url("../images/cmn_cta/cta_tel.png") !important;
        }
      }

      strong {
        font-size: 30px !important;
        font-weight: bold !important;
        letter-spacing: 0.05em !important;
        text-shadow: var(--cta-text-shadow) !important;
        color: var(--cta-text-color) !important;
        margin: 0 !important;
        padding: 0 !important;
      }
    }
  }
}

/* ---------------------------------- CTA 3 小 ---------------------------------- */
.cta3 {
  .cta3__wrapper {
    width: min(100%, 654px) !important;
    margin-inline: auto !important;
    color: var(--cta-text-color) !important;
    box-sizing: border-box !important;
    padding: 0 !important;
  }

  .cta3__box {
    width: fit-content !important;
    margin: 0 auto 9px auto !important;
    position: relative !important;
    padding: 0 40px 10px 40px !important;

    &::before,
    &::after {
      content: "" !important;
      position: absolute !important;
      width: 30px !important;
      height: 33px !important;
      background: no-repeat center / contain !important;
    }

    &::before {
      inset: auto auto 0 0 !important;
      background-image: url("../images/cmn_cta/cta2_deco1.png") !important;
    }

    &::after {
      inset: auto 0 0 auto !important;
      background-image: url("../images/cmn_cta/cta2_deco2.png") !important;
    }

    p {
      color: var(--cta-main-color) !important;
      text-align: center !important;
      font-size: 20px !important;
      font-weight: 500 !important;
      margin: 0 !important;
      padding: 0 !important;
      line-height: 1.4 !important;

      em {
        font-size: 16px !important;
        font-weight: bold !important;
        font-style: normal !important;
        color: inherit !important;
        margin: 0 !important;
        padding: 0 !important;
      }

      small {
        font-size: 16px !important;
        color: inherit !important;
        margin: 0 !important;
        padding: 0 !important;
      }

      span {
        /* background-color: var(--cta-highlight-color) !important; */
        color: inherit !important;
        margin: 0 !important;
        padding: 0 !important;
      }
    }
  }

  .cta3__button {
    margin: 0 !important;
    padding: 0 !important;

    a {
      display: block !important;
      text-decoration: none !important;
      color: inherit !important;
      margin: 0 !important;
      padding: 0 !important;

      img {
        width: 100% !important;
        height: auto !important;
        display: block !important;
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
      }
    }
  }
}

/* スマートフォン対応の調整 */
@media (max-width: 767px) {
  .cta1,
  .cta2,
  .cta3 {
    /* より強力な上書き */
    * {
      font-weight: inherit !important;
      letter-spacing: inherit !important;
    }
  }

  .cta1 {
    .cta1__wrapper {
      padding: 20px 15px 16px 15px !important;
    }

    .cta1__box {
      flex-direction: column !important;
      gap: 15px !important;
    }

    .cta1__box-title {
      font-size: 18px !important;
    }

    .cta1__list {
      flex-direction: column !important;
      gap: 10px !important;
      align-items: flex-start !important;
    }

    .cta1__button a {
      padding: 8px 10px 12px !important;

      span {
        font-size: 15px !important;
      }

      strong {
        font-size: 22px !important;
      }
    }

    .cta1__tel a strong {
      font-size: 26px !important;
    }
  }

  .cta2,
  .cta3 {
    .cta2__wrapper,
    .cta3__wrapper {
      padding: 0 15px !important;
    }

    .cta2__box,
    .cta3__box {
      padding: 0 30px 10px 30px !important;

      p {
        font-size: 18px !important;
      }
    }

    .cta2__tel a strong {
      font-size: 26px !important;
    }
  }
}

/* -------------------------------------------------------------------------- */
/*                                     SP                                     */
/* -------------------------------------------------------------------------- */
.cta-sp {
  .cta-sp__wrapper {
    padding-inline: calc((15 / 390) * 100vw) !important;
  }

  .cta-sp__text {
    text-align: center !important;
    font-size: calc((16 / 390) * 100vw) !important;
    font-weight: bold !important;
    color: var(--cta-main-color) !important;
    letter-spacing: 0.08em !important;
    margin: 0 auto calc((10 / 390) * 100vw) auto !important;
    padding: 0;
  }

  .cta-sp__list {
    width: fit-content !important;
    display: flex !important;
    justify-content: center !important;
    align-items: start !important;
    flex-flow: column nowrap !important;
    position: relative !important;
    padding: 0 calc((40 / 390) * 100vw) !important;
    margin: 0 auto calc((13 / 390) * 100vw) auto !important;

    &::before,
    &::after {
      content: "" !important;
      position: absolute !important;
      width: calc((30 / 390) * 100vw) !important;
      height: calc((33 / 390) * 100vw) !important;
      background: no-repeat center / contain !important;
    }

    &::before {
      /* inset: auto auto 0 0 !important; */
      background-image: url("../images/cmn_cta/cta-sp_deco1.png?20250717") !important;
      left: 0;
      top: calc(50% - ((33 / 390) * 100vw) / 2) !important;
    }

    &::after {
      /* inset: auto 0 0 auto !important; */
      background-image: url("../images/cmn_cta/cta-sp_deco2.png?20250717") !important;
      right: 0;
      top: calc(50% - ((33 / 390) * 100vw) / 2) !important;
    }
  }

  .cta-sp__item {
    /* width: calc((250 / 390) * 100vw) !important; */
    width: fit-content !important;
    margin-inline: auto !important;
    color: var(--cta-main-color) !important;
    font-size: calc((20 / 390) * 100vw) !important;
    font-weight: bold !important;
    letter-spacing: 0.05em !important;
    position: relative;
    /* padding-left: calc((25 / 390) * 100vw) !important; */
    padding-left: 0 !important;
    margin-bottom: 0 !important;

    &::before {
      content: none !important;
      /* content: "" !important;
      position: absolute !important;
      inset: 0 auto 0 0 !important;
      margin-block: auto !important;
      width: calc((15 / 390) * 100vw) !important;
      height: calc((15 / 390) * 100vw) !important;
      background: no-repeat center / contain
        url("../images/cmn_cta/cta1_deco1.png") !important; */
    }

    span {
      font-size: calc((20 / 390) * 100vw) !important;
      /* font-weight: bold !important;
      background: linear-gradient(
        to bottom,
        transparent 80%,
        var(--cta-highlight-color) 80%
      ) !important; */
    }
    span.kerning-min {
      letter-spacing: 0.03em !important;
    }

    small {
      /* font-size: calc((16 / 390) * 100vw) !important; */
      font-size: inherit;
    }
  }

  .cta-sp__box2 {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-flow: column nowrap !important;
    gap: calc((7 / 390) * 100vw) !important;

    &:has(+ .cta-sp__box3) {
      margin-bottom: calc((15 / 390) * 100vw) !important;
    }
    p {
      display: none;
    }
  }

  .cta-sp__button {
    width: 100% !important;
    a {
      /* width: calc((295 / 390) * 100vw) !important; */
      width: 100% !important;
      height: calc((58 / 390) * 100vw) !important;
      margin-inline: auto !important;
      border-radius: calc((37 / 390) * 100vw) !important;
      display: flex !important;
      justify-content: center !important;
      align-items: center !important;
      background: var(--cta-white-color) !important;
      box-shadow: var(--cta-box-shadow) !important;
      text-decoration: none !important;
      span {
        font-weight: bold !important;
        font-size: calc((20 / 390) * 100vw) !important;
        letter-spacing: 0 !important;
        position: relative !important;
        color: #e8354c !important;

        &::before,
        &::after {
          content: "" !important;
          position: absolute !important;
          margin-block: auto !important;
          background: no-repeat center / contain !important;
        }

        &::before {
          inset: 0 auto 0 0 !important;
        }

        &::after {
          inset: 0 0 0 auto !important;
          width: calc((21 / 390) * 100vw) !important;
          height: calc((16 / 390) * 100vw) !important;
        }
      }
    }
  }

  .cta-sp__button--des1 {
    a {
      background: linear-gradient(
        to bottom,
        #f68b99 3%,
        #df3719 84%
      ) !important;

      span {
        color: var(--cta-white-color) !important;
        padding-inline: calc((45 / 390) * 100vw) calc((35 / 390) * 100vw) !important;

        &::before {
          width: calc((39 / 390) * 100vw) !important;
          height: calc((39 / 390) * 100vw) !important;
          background-image: url("../images/cmn_cta/cta-sp_deco6.png") !important;
        }

        &::after {
          background-image: url("../images/cmn_cta/cta-sp_deco5.png") !important;
        }
      }
    }
  }

  .cta-sp__button--des2 {
    a {
      border: 1px solid #e8354c !important;

      span {
        font-size: calc((18 / 390) * 100vw) !important;
        padding-inline: calc((40 / 390) * 100vw) calc((35 / 390) * 100vw) !important;

        &::before {
          width: calc((31 / 390) * 100vw) !important;
          height: calc((31 / 390) * 100vw) !important;
          background-image: url("../images/cmn_cta/cta-sp_deco4.png") !important;
        }

        &::after {
          background-image: url("../images/cmn_cta/cta-sp_deco3.png") !important;
        }
      }
    }
  }

  .cta-sp__box3 {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-flow: row nowrap !important;
    gap: calc((3 / 390) * 100vw) !important;

    img {
      width: calc((43 / 390) * 100vw) !important;
      height: calc((52 / 390) * 100vw) !important;
    }
    p {
      display: none;
    }
    p.cta-sp__box-txt {
      display: block;
      font-size: calc((14 / 390) * 100vw) !important;
      font-weight: bold !important;
      color: var(--cta-main-color) !important;
      letter-spacing: -0.03em !important;
      line-height: 1.4 !important;
    }
  }
}
