: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;

  &::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;
  }
}

@keyframes glow-animation {
  0% {
    left: -100%;
  }
  25%,
  100% {
    left: 100%;
  }
}

/* ------------------------------ 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__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') !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%, 615px) !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 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;
      }
    }
  }

  .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') !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%, 615px) !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;
    }
  }
}
