.is-lp-page{
    background: #fff;
    color: #222;
  }
  
  /* =========================
    utility
  ========================= */
  .pc-only{
    display: block;
  }
  
  .sp-only{
    display: none;
  }
  
  /* =========================
    LP header
  ========================= */
  .lp-header{
    position: sticky;
    top: 0;
    z-index: 9999;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid #ececec;
  }
  
  .lp-header__inner{
    width: min(100%, 1180px);
    margin: 0 auto;
    padding: 16px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
  }
  
  .lp-header__logo a{
    text-decoration: none;
    color: rgb(150, 0, 0);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: .04em;
  }
  
  .lp-header__nav{
    display: flex;
    align-items: center;
    gap: 24px;
  }
  
  .lp-header__nav a{
    text-decoration: none;
    color: #222;
    font-size: 14px;
    font-weight: 600;
    transition: opacity .3s ease;
  }
  
  .lp-header__cta{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 18px;
    background: rgb(150, 0, 0);
    color: #fff !important;
    border: 1px solid rgb(150, 0, 0);
  }
  
  .lp-header__sp{
    display: flex;
    gap: 10px;
  }
  
  .lp-header__mini-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 74px;
    padding: 10px 14px;
    border: 1px solid #222;
    text-decoration: none;
    color: #222;
    font-size: 13px;
    font-weight: 700;
  }
  
  .lp-header__mini-btn--accent{
    background: rgb(150, 0, 0);
    color: #fff;
  }
  
  /* =========================
    common layout
  ========================= */
  .template-sale-lp{
    background: #fff;
    color: #222;
  }
  
  .template-sale-lp .inner{
    width: min(100%, 1180px);
    margin: 0 auto;
    padding: 0 20px;
  }
  
  .template-sale-lp .inner.narrow{
    width: min(100%, 900px);
  }
  
  .sec-title,
  .template-fv__sub,
  .lp-footer__sub{
    margin: 0 0 16px;
    font-size: 13px;
    line-height: 1.4;
    letter-spacing: .18em;
    color: #777;
    font-weight: 700;
  }
  
  .section-heading{
    margin: 0 0 18px;
    font-size: clamp(28px, 4vw, 42px);
    line-height: 1.4;
    font-weight: 700;
    color: rgb(150, 0, 0);
  }
  
  .lead,
  .template-fv__text,
  .lp-footer__text{
    color: #666;
    line-height: 2;
    font-size: 15px;
  }
  
  .btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 220px;
    padding: 16px 22px;
    border: 1px solid #222;
    background: #fff;
    color: rgb(150, 0, 0);
    text-decoration: none;
    text-align: center;
    font-weight: 700;
    transition: opacity .3s ease, transform .3s ease, background-color .3s ease, color .3s ease;
  }
  
  .btn--fill{
    background: rgb(150, 0, 0);
    color: #fff;
  }
  
  .btn--line{
    background: #fff;
    color: rgb(150, 0, 0);
  }
  
  .btn:hover,
  .link-btn:hover,
  .lp-header__nav a:hover,
  .lp-footer__links a:hover{
    opacity: .75;
  }
  
  .btn:hover{
    transform: translateY(-1px);
  }
  
  /* =========================
    FV
  ========================= */
  .template-fv{
    padding: 110px 0 90px;
    text-align: center;
    border-bottom: 1px solid #eee;
  }
  
  .template-fv__title{
    margin: 0 0 24px;
    font-size: clamp(32px, 5vw, 58px);
    line-height: 1.32;
    font-weight: 700;
    color: rgb(150, 0, 0);
  }
  
  .template-fv__btns,
  .lp-footer__btns{
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 36px;
  }
  
  /* =========================
    section spacing
  ========================= */
  .template-trust,
  .template-intro,
  .template-list-sec,
  .how-to-buy,
  .template-faq,
  .template-contact-inline{
    padding: 90px 0;
  }
  
  /* =========================
    trust
  ========================= */
  .template-trust{
    background: #fafafa;
  }
  
  .template-trust__grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  
  .template-trust__item{
    background: #fff;
    border: 1px solid #e9e9e9;
    padding: 30px;
  }
  
  .template-trust__num{
    display: inline-block;
    margin-bottom: 18px;
    font-size: 12px;
    letter-spacing: .14em;
    color: #888;
    font-weight: 700;
  }
  
  .template-trust__item h2{
    margin: 0 0 14px;
    font-size: 24px;
    line-height: 1.5;
    font-weight: 700;
    color: rgb(150, 0, 0);
  }
  
  .template-trust__item p{
    margin: 0;
    color: #666;
    line-height: 2;
    font-size: 14px;
  }
  
  /* =========================
    template list
  ========================= */
  .template-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-top: 36px;
  }
  
  .template-card{
    border: 1px solid #e8e8e8;
    padding: 30px;
    background: #fff;
  }
  
  .template-card__meta{
    margin-bottom: 10px;
    font-size: 12px;
    letter-spacing: .14em;
    color: #888;
    font-weight: 700;
  }
  
  .template-card__title{
    margin: 0 0 14px;
    font-size: 24px;
    line-height: 1.5;
    color: rgb(150, 0, 0);
  }
  
  .template-card__text{
    margin: 0;
    color: #666;
    line-height: 2;
    font-size: 14px;
  }
  
  .template-card__btns{
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 24px;
  }
  
  .link-btn{
    display: inline-block;
    padding-bottom: 4px;
    border-bottom: 1px solid #222;
    text-decoration: none;
    color: #222;
    font-weight: 700;
    transition: opacity .3s ease;
  }
  
  .inline-cta{
    margin-top: 40px;
    padding: 30px;
    border: 1px solid #ececec;
    text-align: center;
    background: #fafafa;
  }
  
  .inline-cta p{
    margin: 0 0 20px;
    color: #666;
    line-height: 2;
  }
  
  /* =========================
    how to buy
  ========================= */
  .how-to-buy{
    background: #fafafa;
  }
  
  .flow-list{
    display: grid;
    gap: 20px;
    margin-top: 36px;
  }
  
  .flow-item{
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 24px;
    align-items: start;
    padding: 28px 30px;
    border: 1px solid #e9e9e9;
    background: #fff;
  }
  
  .flow-item__num{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 78px;
    height: 78px;
    border: 1px solid rgb(150, 0, 0);
    border-radius: 999px;
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
    color: rgb(150, 0, 0);
    background: #fff;
  }
  
  .flow-item__body h3{
    margin: 0 0 10px;
    font-size: 24px;
    line-height: 1.5;
    color: rgb(150, 0, 0);
  }
  
  .flow-item__body p{
    margin: 0;
    color: #666;
    line-height: 2;
    font-size: 14px;
  }
  
  .how-to-buy__cta{
    margin-top: 36px;
    padding: 30px;
    border: 1px solid #e9e9e9;
    background: #fff;
    text-align: center;
  }
  
  .how-to-buy__cta p{
    margin: 0 0 18px;
    font-size: 14px;
    line-height: 2;
    color: #666;
  }
  
  .btn-row{
    display: flex;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
  }
  
  /* =========================
    faq
  ========================= */
  .faq-list{
    margin-top: 36px;
    border-top: 1px solid #eee;
  }
  
  .faq-item{
    padding: 28px 0;
    border-bottom: 1px solid #eee;
  }
  
  .faq-item h3{
    margin: 0 0 12px;
    font-size: 24px;
    line-height: 1.5;
    color: rgb(150, 0, 0);
  }
  
  .faq-item__answer{
    color: #666;
    font-size: 14px;
    line-height: 2;
  }
  
  .faq-item__answer p{
    margin: 0;
  }
  
  /* =========================
    contact inline
  ========================= */
  .template-contact-inline{
    background: #fff;
  }
  
  .template-contact-inline__form{
    margin-top: 36px;
    padding: 34px 32px;
    border: 1px solid #e8e8e8;
    background: #fafafa;
  }
  
  .template-contact-inline__form .wpcf7{
    width: 100%;
  }
  
  .template-contact-inline__form .wpcf7 form{
    margin: 0;
  }
  
  .template-contact-inline__form .wpcf7 label{
    display: block;
    margin-bottom: 22px;
    font-size: 14px;
    line-height: 1.8;
    font-weight: 700;
    color: #222;
  }
  
  .template-contact-inline__form .wpcf7 input[type="text"],
  .template-contact-inline__form .wpcf7 input[type="email"],
  .template-contact-inline__form .wpcf7 input[type="tel"],
  .template-contact-inline__form .wpcf7 select,
  .template-contact-inline__form .wpcf7 textarea{
    width: 100%;
    margin-top: 8px;
    padding: 16px 18px;
    border: 1px solid #dcdcdc;
    background: #fff;
    box-sizing: border-box;
    font-size: 15px;
    line-height: 1.6;
    color: #222;
    appearance: none;
  }
  
  .template-contact-inline__form .wpcf7 textarea{
    min-height: 180px;
    resize: vertical;
  }
  
  .template-contact-inline__form .wpcf7 input[type="text"]:focus,
  .template-contact-inline__form .wpcf7 input[type="email"]:focus,
  .template-contact-inline__form .wpcf7 input[type="tel"]:focus,
  .template-contact-inline__form .wpcf7 select:focus,
  .template-contact-inline__form .wpcf7 textarea:focus{
    outline: none;
    border-color: rgb(150, 0, 0);
    box-shadow: 0 0 0 3px rgba(0,0,0,.06);
  }
  
  .template-contact-inline__form .wpcf7 input::placeholder,
  .template-contact-inline__form .wpcf7 textarea::placeholder{
    color: #999;
  }
  
  .template-contact-inline__form .wpcf7 .wpcf7-acceptance{
    display: block;
    margin: 10px 0 28px;
  }
  
  .template-contact-inline__form .wpcf7 .wpcf7-acceptance label{
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 0;
    font-size: 13px;
    line-height: 1.8;
    font-weight: 500;
    color: #555;
  }
  
  .template-contact-inline__form .wpcf7 .wpcf7-acceptance input{
    margin-top: 3px;
  }
  
  .template-contact-inline__form .wpcf7 input[type="submit"]{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 260px;
    padding: 16px 26px;
    border: 1px solid rgb(150, 0, 0);
    background: rgb(150, 0, 0);
    color: #fff;
    font-size: 15px;
    line-height: 1.4;
    font-weight: 700;
    cursor: pointer;
    transition: opacity .3s ease, transform .3s ease;
  }
  
  .template-contact-inline__form .wpcf7 input[type="submit"]:hover{
    opacity: .85;
    transform: translateY(-1px);
  }
  
  .template-contact-inline__form .wpcf7 .wpcf7-submit{
    display: block;
    margin: 0 auto;
  }
  
  .template-contact-inline__form .wpcf7 .wpcf7-not-valid-tip{
    margin-top: 6px;
    font-size: 12px;
    color: #d63638;
  }
  
  .template-contact-inline__form .wpcf7-response-output{
    margin: 20px 0 0;
    padding: 14px 16px;
    border: 1px solid #ddd;
    font-size: 13px;
    line-height: 1.8;
  }
  
  /* =========================
    LP footer
  ========================= */
  .lp-footer__cta{
    padding: 90px 20px;
    background: #f8f8f8;
    text-align: center;
  }
  
  .lp-footer__title{
    margin: 0 0 20px;
    font-size: clamp(28px, 4vw, 44px);
    line-height: 1.4;
    color: rgb(150, 0, 0);
  }
  
  .lp-footer__bottom{
    padding: 28px 20px;
    border-top: 1px solid #e8e8e8;
    background: #fff;
  }
  
  .lp-footer__bottom .inner{
    width: min(100%, 1180px);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
  }
  
  .lp-footer__name{
    margin: 0;
    font-weight: 700;
    color: rgb(150, 0, 0);
  }
  
  .lp-footer__links{
    display: flex;
    gap: 16px;
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
    flex-wrap: wrap;
  }
  
  .lp-footer__links a{
    text-decoration: none;
    color: #666;
    transition: opacity .3s ease;
  }
  
  .lp-footer__copy{
    margin: 0;
    color: #888;
    font-size: 13px;
  }
  
  /* =========================
    responsive
  ========================= */
  @media (max-width: 767px){
    .pc-only{
      display: none;
    }
  
    .sp-only{
      display: flex;
    }
  
    .template-fv{
      padding: 80px 0 64px;
    }
  
    .template-trust,
    .template-intro,
    .template-list-sec,
    .how-to-buy,
    .template-faq,
    .template-contact-inline{
      padding: 64px 0;
    }
  
    .template-trust__grid,
    .template-grid{
      grid-template-columns: 1fr;
    }
  
    .template-trust__item,
    .template-card,
    .inline-cta,
    .how-to-buy__cta,
    .template-contact-inline__form{
      padding: 22px 18px;
    }
  
    .flow-item{
      grid-template-columns: 1fr;
      gap: 16px;
      padding: 22px 18px;
    }
  
    .flow-item__num{
      width: 62px;
      height: 62px;
      font-size: 20px;
    }
  
    .flow-item__body h3,
    .template-card__title,
    .faq-item h3,
    .template-trust__item h2{
      font-size: 20px;
    }
  
    .btn{
      min-width: 100%;
    }
  
    .btn-row{
      flex-direction: column;
    }
  
    .lp-footer__bottom .inner{
      flex-direction: column;
      align-items: flex-start;
    }
  
    .template-contact-inline__form .wpcf7 input[type="text"],
    .template-contact-inline__form .wpcf7 input[type="email"],
    .template-contact-inline__form .wpcf7 input[type="tel"],
    .template-contact-inline__form .wpcf7 select,
    .template-contact-inline__form .wpcf7 textarea{
      padding: 14px 14px;
      font-size: 14px;
    }
  
    .template-contact-inline__form .wpcf7 input[type="submit"]{
      width: 100%;
      min-width: 100%;
    }
  }


  /* =========================================
   template-sale 下部ブログ一覧
========================================= */
.column03{
    padding: 90px 0;
    background: #fafafa;
  }
  
  .column03 h2{
    width: min(100%, 1180px);
    margin: 0 auto 36px;
    padding: 0 20px;
    font-size: clamp(28px, 4vw, 44px);
    line-height: 1.35;
    font-weight: 700;
    color: #111;
  }
  
  .column03 h2 span{
    display: block;
    margin-top: 8px;
    font-size: 14px;
    line-height: 1.6;
    letter-spacing: .14em;
    color: #777;
    font-weight: 700;
    text-transform: uppercase;
  }
  
  .column03 ul{
    width: min(100%, 1180px);
    margin: 0 auto;
    padding: 0 20px;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
  }
  
  .column03 li{
    margin: 0;
    padding: 0;
  }
  
  .column03 li a{
    display: block;
    height: 100%;
    background: #fff;
    border: 1px solid #e8e8e8;
    text-decoration: none;
    color: #111;
    overflow: hidden;
    transition: transform .3s ease, box-shadow .3s ease, opacity .3s ease;
  }
  
  .column03 li a:hover{
    transform: translateY(-4px);
    box-shadow: 0 14px 32px rgba(0,0,0,.06);
  }
  
  .column03 figure{
    margin: 0;
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    background: #f2f2f2;
  }
  
  .column03 figure img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .45s ease;
  }
  
  .column03 li a:hover figure img{
    transform: scale(1.05);
  }
  
  .column03 figure span{
    position: absolute;
    left: 16px;
    bottom: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 6px 12px;
    background: rgba(17,17,17,.78);
    color: #fff;
    font-size: 12px;
    line-height: 1.4;
    letter-spacing: .06em;
    font-weight: 700;
  }
  
  .column03 .title{
    margin: 22px 22px 10px;
    font-size: 22px;
    line-height: 1.55;
    font-weight: 700;
    color: #111;
  
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  
  .column03 .txt{
    margin: 0 22px 24px;
    font-size: 14px;
    line-height: 2;
    color: #666;
  
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  
  /* 少しLPになじませる余白調整 */
  .template-sale-lp + .column03,
  main + .column03{
    border-top: 1px solid #ececec;
  }
  
  /* 3件以上増えた時にも崩れにくく */
  .column03 ul:has(li:nth-child(3)){
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  
  /* Firefoxなど :has 未対応環境向けの保険 */
  @supports not selector(:has(*)){
    .column03 ul{
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  
  /* タブレット */
  @media (max-width: 1024px){
    .column03{
      padding: 72px 0;
    }
  
    .column03 ul,
    .column03 ul:has(li:nth-child(3)){
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 22px;
    }
  
    .column03 .title{
      font-size: 20px;
    }
  }
  
  /* SP */
  @media (max-width: 767px){
    .column03{
      padding: 56px 0;
    }
  
    .column03 h2{
      margin-bottom: 24px;
      padding: 0 16px;
    }
  
    .column03 ul,
    .column03 ul:has(li:nth-child(3)){
      padding: 0 16px;
      grid-template-columns: 1fr;
      gap: 18px;
    }
  
    .column03 figure span{
      left: 12px;
      bottom: 12px;
      min-height: 28px;
      padding: 5px 10px;
      font-size: 11px;
    }
  
    .column03 .title{
      margin: 18px 16px 8px;
      font-size: 18px;
    }
  
    .column03 .txt{
      margin: 0 16px 18px;
      font-size: 13px;
      line-height: 1.9;
    }
  }