/* ===================================================================
   SHODO FAM 申込ページ — TORAbit完全一致CSS v9
   TORAbit computed styles から正確にコピー
   =================================================================== */

/* ---------- Reset: Swell テーマ要素を全て非表示 ---------- */
#body_wrap.sf-checkout-page #header,
#body_wrap.sf-checkout-page header#header,
#body_wrap.sf-checkout-page .l-header,
#body_wrap.sf-checkout-page .l-fixHeader,
#body_wrap.sf-checkout-page [class*="l-header"],
#body_wrap.sf-checkout-page [class*="fixHeader"],
#body_wrap.sf-checkout-page .c-headBand,
#body_wrap.sf-checkout-page .p-breadcrumb,
#body_wrap.sf-checkout-page .c-pageTitle,
#body_wrap.sf-checkout-page .post_ttl,
#body_wrap.sf-checkout-page .l-sidebar,
#body_wrap.sf-checkout-page footer,
#body_wrap.sf-checkout-page .l-footer,
#body_wrap.sf-checkout-page #footer,
#body_wrap.sf-checkout-page .p-footer,
#body_wrap.sf-checkout-page .c-widget,
#body_wrap.sf-checkout-page .c-gnav,
#body_wrap.sf-checkout-page .p-spMenu,
#body_wrap.sf-checkout-page .c-overlay,
#body_wrap.sf-checkout-page #sp_menu,
#body_wrap.sf-checkout-page .c-scrollTop {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  position: static !important;
}
#body_wrap.sf-checkout-page .l-content,
#body_wrap.sf-checkout-page .l-content.l-container {
  padding: 0 !important;
  margin: 0 auto !important;
  max-width: 100% !important;
  width: 100% !important;
}
#body_wrap.sf-checkout-page .l-content__inner {
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}
#body_wrap.sf-checkout-page .l-mainContent,
#body_wrap.sf-checkout-page .l-mainContent.l-article {
  padding: 0 !important;
  margin: 0 auto !important;
  max-width: 100% !important;
  width: 100% !important;
}
#body_wrap.sf-checkout-page .l-mainContent__inner {
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}
#body_wrap.sf-checkout-page .l-mainContent__body {
  padding: 0 !important;
  margin: 0 !important;
}
#body_wrap.sf-checkout-page #body_wrap,
#body_wrap.sf-checkout-page .l-fixHeader + * {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
#body_wrap.sf-checkout-page .post_content {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}

/* ---------- Body = TORAbit: bg #f4f4f4, Noto Sans JP 15px, #555 ---------- */
#body_wrap.sf-checkout-page {
  background: #fff !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: 15px !important;
  color: #555 !important;
  line-height: 1.5 !important;
}

/* ---------- 全体ラッパー = TORAbit: 100%幅、bg #f4f4f4 ---------- */
.sf-subscribe {
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #fff !important;
}

/* ---------- サイトヘッダー = TORAbit: 白bg, height 88.8px ---------- */
.sf-subscribe__site-header {
  background: #fff !important;
  text-align: center !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #333 !important;
  border-bottom: none !important;
  min-height: 88.8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
}

/* ---------- メインコンテンツ = TORAbit: col-lg-8 (66.67%), padding 25.6px, margin auto ---------- */
.sf-subscribe__main {
  max-width: 800px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 15px !important;
  background: #fff !important;
  padding: 25.6px calc((100% - min(100%, 1300px) * 0.6667) / 2) !important;
  box-sizing: border-box !important;
}
/* Fallback: 実際のコンテンツ幅をTORAbitと一致させる */
@supports (width: min(100%, 800px)) {
  .sf-subscribe__main {
    max-width: min(100%, 800px) !important;
    width: 100% !important;
    padding: 15px !important;
    background: #fff !important;
  }
}

/* ---------- タイトル = TORAbit: text-align start, 22.5px, 700, #24292d ---------- */
.sf-subscribe__title {
  text-align: left !important;
  font-size: 22.5px !important;
  font-weight: 700 !important;
  color: #24292d !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  border: none !important;
  line-height: 1.25 !important;
}
.sf-subscribe__title::before,
.sf-subscribe__title::after {
  display: none !important;
}

/* ---------- 説明テキスト = TORAbit: start, 15px, #555, margin 0 0 16px ---------- */
.sf-subscribe__desc {
  text-align: left !important;
  font-size: 15px !important;
  color: #555 !important;
  margin: 0 0 16px !important;
}

/* ---------- ステップバー = TORAbit: block, bg #f6f6f6, border 0.8px #ddd ---------- */
.sf-step-bar {
  display: block !important;
  list-style: none !important;
  margin: 20px 0 !important;
  padding: 15px 0 !important;
  border: 1px solid #ddd !important;
  border-radius: 0 !important;
  overflow: visible !important;
  background: #f6f6f6 !important;
  text-align: center !important;
}
/* ステップバーLI = TORAbit: inline-block, width ~30%, padding 10px, margin 0 ---------- */
.sf-step-bar__item {
  display: inline-block !important;
  width: 29% !important;
  text-align: center !important;
  padding: 10px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  background: #eee !important;
  color: #444 !important;
  position: relative !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  vertical-align: middle !important;
}
/* 矢印 = TORAbit: ::after border triangle, right: -19.2px, top calculated */
.sf-step-bar__item::after {
  content: " " !important;
  position: absolute !important;
  left: 100% !important;
  top: 50% !important;
  margin-top: -10px !important;
  width: 0 !important;
  height: 0 !important;
  border-style: solid !important;
  border-width: 10px !important;
  border-color: transparent transparent transparent #eee !important;
  pointer-events: none !important;
}
.sf-step-bar__item:last-child::after {
  display: none !important;
}
/* アクティブ = TORAbit: bg #aaa, color #fff */
.sf-step-bar__item.--current {
  background: #aaa !important;
  color: #fff !important;
}
.sf-step-bar__item.--current::after {
  border-left-color: #aaa !important;
}
.sf-step-bar__item:nth-child(2) {
  margin-left: 8px !important;
  margin-right: 8px !important;
}

/* ---------- プランカード = TORAbit: border 0.8px #dde0e3, radius 3.2px, padding 16px ---------- */
.sf-plan-box {
  background: #fff !important;
  border: 0.8px solid #dde0e3 !important;
  border-radius: 3.2px !important;
  padding: 16px !important;
  margin: 0 0 16px !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  line-height: 22.5px !important;
  letter-spacing: 0.6px !important;
}
.sf-plan-box__inner {
  display: flex !important;
  gap: 16px !important;
  align-items: flex-start !important;
}
.sf-plan-box__image {
  flex: 0 0 172px !important;
  width: 172px !important;
}
/* 空P要素を非表示(余分なgap消費を防止) */
.sf-plan-box__inner > p {
  display: none !important;
}
.sf-plan-box__image img,
.sf-plan-box__image svg {
  width: 100% !important;
  height: auto !important;
  border-radius: 4px !important;
  display: block !important;
}
.sf-plan-box__info {
  flex: 1 !important;
}
.sf-plan-box__name {
  font-size: 26.25px !important;
  font-weight: 700 !important;
  color: #24292d !important;
  margin: 0 0 8px !important;
  line-height: 32.8125px !important;
}
/* 価格行（TORAbit: display block, 15px, line-height 22.5px） */
.sf-plan-box__price-row {
  font-weight: 400 !important;
  display: flex !important;
  align-items: center !important;
  
  margin: 0 !important;
  font-size: 15px !important;
  line-height: 22.5px !important;
}
.sf-plan-box__price-row br {
  display: none !important;
}
/* 税込価格スパン：インラインスタイル上書き */
#sf-price-tax {
  font-size: 15px !important;
  font-weight: 400 !important;
  color: rgb(85, 85, 85) !important;
}

/* チェックマーク（TORAbit: Font Awesome 5 fa-check-circle完全一致） */
.sf-check-icon {
  display: inline-block !important;
  color: #0cbc87 !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  font-family: "Font Awesome 5 Free" !important;
  flex-shrink: 0 !important;
  line-height: 15px !important;
  margin-right: 8px !important;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  background: none !important;
  vertical-align: baseline !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

/* 灰色エリア統一ラッパー（TORAbit: 1つの連続ブロック） */
.sf-plan-box__gray-wrap {
  background: #f5f7f9 !important;
  border-radius: 5.2px !important;
  padding: 8px !important;
  margin: 8px 0 0 !important;
}
/* 割引ボックス（gray-wrap内、個別bg/radius不要） */
.sf-plan-box__discount {
  overflow: visible !important;
  margin: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
/* TORAbit準拠バッジ: 【7日間無料】と OFF! */
.sf-badge-free,
.sf-badge-off {
  font-size: 21.33px !important;
  font-weight: 700 !important;
  line-height: 32px !important;
}
.sf-plan-box__discount-label {
  line-height: 22.5px !important;
  font-size: 15px !important;
  font-weight: 700;
  color: rgb(85, 85, 85)!important;
  margin: 0 0 16px!important;
  text-align: left !important;
}
.sf-plan-box__discount-prices {
  line-height: 22.5px !important;
  text-align: left !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  display: block !important;
margin: 0 0 16px!important;
}
.sf-plan-box__discount-prices br {
  display: none !important;
}
.sf-plan-box__discount-prices span {
  display: inline !important;
}
.sf-plan-box__price-old {
  font-weight: 400 !important;
  font-size: 18px !important;
  color: #555 !important;
  text-decoration: line-through !important;
}
.sf-plan-box__price-new {
  font-size: 24px !important;
  font-weight: 700 !important;
  color: #555 !important;
}
.sf-plan-box__desc { font-size: 15px !important;
  color: #555 !important;
  margin: 0 0 16px!important;
  text-align: left !important;
}

/* チェックリスト（TORAbit: gray bg continuation） */

/* 税抜注記（TORAbit: 13.33px） */
.sf-plan-box__discount-prices small,
.sf-plan-box__discount-prices .sf-tax-note {
  font-size: 13.33px !important;
  font-weight: 400 !important;
  line-height: 20px !important;
}
.sf-plan-box__checks {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
}
.sf-plan-box__checks li {
  font-weight: 400 !important;
  font-size: 15px !important;
  color: #555 !important;
  padding: 3px 0 !important;
}

/* ---------- 無料体験リンク ---------- */
.sf-subscribe__free-link {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  text-align: left !important;
  margin: 0 0 16px !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  color: #555 !important;
  line-height: 22.5px !important;
}
.sf-subscribe__free-link a {
  color: rgb(6, 106, 201) !important;
  text-decoration: none !important;
  font-weight: 400 !important;
  font-size: 15px !important;
}

/* ---------- アコーディオン = TORAbit: border 0.8px #dde0e3, radius 3.2px ---------- */
.sf-accordion {
  background: #fff !important;
  border: 0.8px solid #dde0e3 !important;
  border-radius: 3.2px !important;
  margin: 0 0 16px !important;
  overflow: hidden !important;
}
/* ヘッダー = TORAbit: bg #f5f7f9, padding 16px, 15px, 700, color #000 */
.sf-accordion__header {
  background: #f5f7f9 !important;
  padding: 16px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #666 !important;
  cursor: pointer !important;
  display: block !important;
  border-bottom: 0.8px solid #dde0e3 !important;
  user-select: none !important;
  min-height: 55.3px !important;
  box-sizing: border-box !important;
  line-height: 22.5px !important;
}
.sf-accordion__header::before {
  content: "\f101" !important;
  font-family: "Font Awesome 5 Free" !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  margin-right: 4px !important;
  display: inline-block !important;
  color: #666 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}
.sf-accordion.--open .sf-accordion__header::before {
  content: "\f103" !important;
  margin-right: 8px !important;
}
.sf-accordion__header::after {
  content: none !important;
  display: none !important;
}
.sf-accordion__body {
  padding: 0 !important;
  max-height: 0 !important;
  overflow: hidden !important;
  transition: max-height 0.3s ease, padding 0.2s ease !important;
}
.sf-accordion.--open .sf-accordion__body {
  max-height: 2000px !important;
  transition: max-height 0.4s ease-in, padding 0.2s ease !important;
}
.sf-accordion.--open/* login accordion padding: moved to --open state only */

/* ---------- PMPro フォーム全体 ---------- */
.sf-subscribe #pmpro_form {
  margin: 0 !important;
  padding: 0 !important;
}
.sf-subscribe .pmpro_checkout {
  margin: 0 !important;
  padding: 0 !important;
  max-width: 100% !important;
}
.sf-subscribe .pmpro_card {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  border-radius: 0 !important;
}
.sf-subscribe .pmpro_card_content {
  padding: 0 !important;
}
.sf-subscribe .pmpro_card_title,
.sf-subscribe .pmpro_form_heading,
.sf-subscribe .pmpro_form_legend,
.sf-subscribe legend {
  display: none !important;
}

/* ---------- フォームフィールド = TORAbit: table layout ---------- */
/* PC: 横並び（ラベル左、入力右）— TORAbitのtable-cell再現 */
.sf-subscribe .sf-accordion__body .pmpro_form_field.pmpro_form_field-text,
.sf-subscribe .sf-accordion__body .pmpro_form_field.pmpro_form_field-email,
.sf-subscribe .sf-accordion__body .pmpro_form_field.pmpro_form_field-password,
.sf-subscribe .pmpro_form_field-CardType,
.sf-subscribe [class*="pmpro_form_field-card"],
.sf-subscribe [class*="pmpro_form_field-Card"] {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  border-bottom: 0.8px solid #ddd !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ラベル = TORAbit th: bg transparent, width 33%, padding 15px 8px, fontSize 15px, color #000 */
.sf-subscribe .sf-accordion__body .pmpro_form_field .pmpro_form_label,
.sf-subscribe .pmpro_form_field[class*="CardType"] label,
.sf-subscribe .pmpro_form_field label[for*="card"],
.sf-subscribe .pmpro_form_field label[for*="Card"] {
  display: flex !important;
  align-items: center !important;
  background: transparent !important;
  padding: 15px 8px !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  color: #666 !important;
  min-width: 200px !important;
  width: 33% !important;
  flex-shrink: 0 !important;
  border-right: none !important;
  margin: 0 !important;
  white-space: nowrap !important;
  line-height: 1.4 !important;
}

/* 入力 = TORAbit td: padding 12.8px 24px, border 0.8px #dde0e3, radius 2px */
.sf-subscribe .sf-accordion__body .pmpro_form_field .pmpro_form_input {
  flex: 1 !important;
  border: 0.8px solid #dde0e3 !important;
  border-radius: 2px !important;
  padding: 12.8px 24px !important;
  font-size: 15px !important;
  color: #404448 !important;
  background: #fff !important;
  width: 100% !important;
  box-sizing: border-box !important;
  outline: none !important;
  margin: 0 !important;
  height: 46px !important;
}
.sf-subscribe .sf-accordion__body .pmpro_form_field .pmpro_form_input:focus {
  border-color: #dde0e3 !important;
  box-shadow: none !important;
  outline: none !important;
}

/* ---------- 必須バッジ = TORAbit: bg #e73b6e, 10.5px, padding 1.6px 9.6px, radius 1.6px ---------- */
.sf-subscribe .pmpro_asterisk::before,
.sf-subscribe .pmpro_required::before {
  content: none !important;
  display: none !important;
}
.sf-subscribe .pmpro_form_label .pmpro_asterisk {
  background: #e73b6e !important;
  color: #fff !important;
  font-size: 0 !important;
  padding: 1.6px 9.6px !important;
  border-radius: 1.6px !important;
  margin-left: 6px !important;
  display: inline-block !important;
  line-height: 1.2 !important;
  vertical-align: middle !important;
}
.sf-subscribe .pmpro_form_label .pmpro_asterisk::after {
  content: "\5FC5\9808" !important;
  font-size: 10.5px !important;
  font-weight: 500 !important;
}

/* ---------- パスワード関連非表示 ---------- */
.sf-subscribe .pmpro_card_actions,
.sf-subscribe .pmpro_form_field-password-toggle,
#body_wrap.sf-checkout-page .pmpro_form_field-password {
  display: none !important;
}
/* メールをパスワードの前に表示（JSでのDOM移動を不要にする） */
/* flexbox order 削除: パスワード非表示はdisplay:noneで対応済み */
#body_wrap.sf-checkout-page .pmpro_form_field-bemail {
  /* order削除: 名前→メールの順番を維持 */
}

/* ---------- Stripe 支払い情報 ---------- */
.sf-subscribe #pmpro_payment_information_fields {
  margin-top: 0 !important;
  border: none !important;
}
.sf-subscribe #pmpro_payment_information_fields .pmpro_card {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
}
.sf-subscribe #pmpro_payment_information_fields .pmpro_form_fields,
.sf-subscribe #pmpro_payment_information_fields .pmpro_card_content {
  border-top: none !important;
}
.sf-subscribe .pmpro-stripe-element-holder,
.sf-subscribe #pmpro_stripe_payment_element {
  padding: 0 !important;
  border: none !important;
}

/* ---------- ユーザーフィールド ---------- */
.sf-subscribe #pmpro_user_fields .pmpro_card {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}
.sf-subscribe #pmpro_user_fields .pmpro_card_content {
  padding: 0 !important;
}
.sf-subscribe #pmpro_user_fields .pmpro_form_fields {
  border-top: none !important;
}

/* ---------- 送信ボタン = TORAbit: bg #0cbc87, radius 8px, padding 12.8px 96px ---------- */
.sf-subscribe #pmpro_form .pmpro_submit,
.sf-subscribe #pmpro_form .pmpro_form_submit,
.sf-subscribe .pmpro_submit {
  text-align: center !important;
  padding: 24px 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
}
.sf-subscribe #pmpro_btn-submit {
  background: #0cbc87 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 12.8px 96px !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  min-width: 260px !important;
  min-height: 51px !important;
  letter-spacing: 0.5px !important;
  transition: opacity 0.2s !important;
}
.sf-subscribe #pmpro_btn-submit:hover {
  opacity: 0.85 !important;
}

/* ---------- ログインアコーディオン ---------- */
/* login accordion padding: moved to --open state only */

/* ---------- フッター ---------- */
.sf-subscribe__footer {
  text-align: center !important;
  font-size: 12px !important;
  color: #888 !important;
  padding: 30px 0 20px !important;
  margin-top: 20px !important;
}

/* PMPro非表示要素 */
.sf-subscribe #pmpro_levels_table,
.sf-subscribe .pmpro_checkout-fields-level,
.sf-subscribe #pmpro_level_cost,
.sf-subscribe .pmpro_level_cost_text,
.sf-subscribe #pmpro_pricing_fields,
.sf-subscribe .pmpro_checkout-fields .pmpro_checkout-field-level,
.sf-subscribe .pmpro_checkout_intro,
.sf-subscribe .pmpro_checkout-field-level_cost,
.sf-subscribe .pmpro_checkout-fields-checkout_boxes,
.sf-subscribe .pmpro_checkout_box_description,
.sf-subscribe #pmpro_account_fields > .pmpro_card > .pmpro_card_content > p,
.sf-subscribe .pmpro_checkout-fields .pmpro_checkout-field:first-child,
.sf-subscribe #pmpro_form > div:first-child > p,
.sf-subscribe #pmpro_form > p,
.sf-subscribe #pmpro_form > .pmpro_card > .pmpro_card_content > p {
  display: none !important;
}

/* PMPro fieldset余白 */
.sf-subscribe fieldset {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

/* ---------- 利用規約リンク ---------- */
.sf-terms-link {
  padding: 12px 0 8px !important;
  font-size: 15px !important;
  color: #555 !important;
  border-bottom: none !important;
}
.sf-terms-link a {
  color: #066ac9 !important;
  text-decoration: none !important;
}

/* ---------- 同意・支払い方法・カードロゴ行 ---------- */
.sf-agree-row,
.sf-paymethod-row,
.sf-cardlogo-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  border-bottom: 0.8px solid #ddd !important;
  margin: 0 !important;
  padding: 0 !important;
}
.sf-agree-row__label,
.sf-paymethod-row__label,
.sf-cardlogo-row__label {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background: transparent !important;
  padding: 15px 8px !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  color: #666 !important;
  min-width: 200px !important;
  width: 33% !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
  white-space: normal !important;
  line-height: 1.4 !important;
}
.sf-agree-row__value,
.sf-paymethod-row__value,
.sf-cardlogo-row__value {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  padding: 15px 8px !important;
  font-size: 15px !important;
  color: #555 !important;
  gap: 8px !important;
}
.sf-required-badge {
  margin-left: auto !important;
  background: #e73b6e !important;
  color: #fff !important;
  font-size: 10.5px !important;
  font-weight: 500 !important;
  padding: 1.6px 9.6px !important;
  border-radius: 1.6px !important;
  display: inline-block !important;
  line-height: 1.2 !important;
  vertical-align: middle !important;
  white-space: nowrap !important;
}
.sf-agree-checkbox {
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  cursor: pointer !important;
  accent-color: #0cbc87 !important;
}
.sf-card-logos {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}
.sf-card-logos svg,
.sf-card-logos img {
  height: 32px !important;
  width: auto !important;
  flex-shrink: 0 !important;
}

/* PC: アコーディオンヘッダーとフォームの間の隙間 + 左右余白（TORAbit: card-body padding 16px 20px） */
.sf-subscribe #pmpro_form {
  padding: 16px 20px 0 20px !important;
}

/* ==========================================================================
   SP レスポンシブ = TORAbit SP layout
   TORAbit SP: th display:block (縦並び), container padding 0 15px
   ========================================================================== */
@media (max-width: 768px) {
  /* プランカード基本 */
  .sf-plan-box {
    font-size: 15px !important;
    font-weight: 400 !important;
    line-height: 22.5px !important;
  }
  .sf-plan-box__price-row {
    margin: 0 !important;
  }
  /* フォームフィールド間隔調整（TORAbit SP: gap 15px → section間 15.8px） */
  .sf-subscribe .pmpro_form_fields {
    gap: 15px !important;
  }

  /* SP: フォーム左右余白（入力欄が壁に当たらないように） */
  .sf-subscribe #pmpro_form {
    padding: 0 15px 0 15px !important;
  }

  /* メインコンテンツ = TORAbit SP: container padding 0 15px, full width */
  .sf-subscribe__main {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 15px !important;
  }

  .sf-subscribe__title {
    font-size: 22.5px !important;
  }

  /* ステップバー — SPでもPC同様（TORAbit準拠） */

  /* プランカード縦並び（SP） */
  .sf-plan-box__inner {
    flex-direction: column !important;
  }
  .sf-plan-box__image {
    flex: none !important;
    width: 75% !important;
    margin: 0 !important;
  }
  .sf-plan-box__name {
    font-size: 22px !important;
    line-height: 27.5px !important;
  }

  /* ========== フォーム = TORAbit SP: 縦並び（ラベル上、入力下）========== */
  /* TORAbit SP: th { display: block; width: 100%; font-size: 12px; padding: 5px 10px 4px } */
  .sf-subscribe .sf-accordion__body .pmpro_form_field.pmpro_form_field-text,
  .sf-subscribe .sf-accordion__body .pmpro_form_field.pmpro_form_field-email,
  .sf-subscribe .sf-accordion__body .pmpro_form_field.pmpro_form_field-password {
    flex-direction: column !important;
    border-bottom: none !important;
  }
  .sf-subscribe .sf-accordion__body .pmpro_form_field .pmpro_form_label {
    width: calc(100% + 30px) !important;
    min-width: unset !important;
    border-right: none !important;
    border-top: 0.8px solid #ddd !important;
    border-bottom: 0.8px solid #ddd !important;
    padding: 5px 10px 4px !important;
    font-size: 12px !important;
    white-space: normal !important;
    background: #f9f9f9 !important;
    margin-left: -15px !important;
    margin-right: -15px !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .sf-subscribe .sf-accordion__body .pmpro_form_field .pmpro_form_input {
    margin: 0 !important;
    padding: 12.8px 24px !important;
    font-size: 15px !important;
  }
  /* 同意・支払い行もSPで縦並び */
  .sf-agree-row,
  .sf-paymethod-row,
  .sf-cardlogo-row {
    flex-direction: column !important;
    border-bottom: none !important;
  }
  .sf-agree-row__label,
  .sf-paymethod-row__label,
  .sf-cardlogo-row__label {
    width: calc(100% + 30px) !important;
    min-width: unset !important;
    padding: 5px 10px 4px !important;
    font-size: 12px !important;
    background: #f9f9f9 !important;
    border-top: 0.8px solid #ddd !important;
    border-bottom: 0.8px solid #ddd !important;
    margin-left: -15px !important;
    margin-right: -15px !important;
  }
  .sf-agree-row__value,
  .sf-paymethod-row__value,
  .sf-cardlogo-row__value {
    padding: 15px 8px !important;
    font-size: 15px !important;
  }
  .sf-card-logos svg,
  .sf-card-logos img {
    height: 27px !important;
    width: auto !important;
  }


  /* SP: 価格表示の崩れ修正 */
  .sf-plan-box__discount-prices {
  line-height: 22.5px !important;
    display: block !important;
    text-align: left !important;
    font-size: 15px !important;
    font-weight: 400 !important;
  }
  .sf-plan-box__discount-prices br {
    display: none !important;
  }
  .sf-plan-box__price-new {
    font-size: 24px !important;
  }

  /* カード情報セクション SP */
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_card_content {
    display: block !important;
  }
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_heading {
    display: block !important;
    width: calc(100% + 30px) !important;
    margin-left: -15px !important;
    margin-right: -15px !important;
    padding: 5px 15px 4px !important;
    font-size: 12px !important;
    border: none !important;
    background: #f9f9f9 !important;
    border-top: 0.8px solid #ddd !important;
    border-bottom: 0.8px solid #ddd !important;
    border-bottom: none !important;
  }
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_fields {
    display: block !important;
    width: 100% !important;
    padding: 0 0 10px !important;
    border-bottom: 0.8px solid #ddd !important;
  }
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_cols-2 .pmpro_form_label {
    font-size: 14px !important;
  }

  /* カード情報内部のサブラベルはグレー背景なし */
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_label {
    background: transparent !important;
    border-top: none !important;
    border-bottom: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: auto !important;
  }

  /* 最初のラベルはアコーディオンヘッダーのborder-bottomと重複するのでborder-top除去 */
  .sf-subscribe .sf-accordion__body .pmpro_form_field-username + .pmpro_form_field .pmpro_form_label {
    border-top: none !important;
  }


  /* SP: バリデーションヒント幅修正（入力欄と同じ幅に） */
  .sf-validation-hint {
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .sf-validation-hint__content {
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* ボタンサイズ調整 */
  .sf-subscribe #pmpro_btn-submit {
    min-width: 200px !important;
    padding: 12px 40px !important;
    width: 90% !important;
  }


  /* SP: TORAbit準拠 margin/font-size修正 */
  .sf-plan-box__discount-label {
  line-height: 22.5px !important;
    margin-bottom: 16px !important;
  }
  .sf-plan-box__discount-prices {
  line-height: 22.5px !important;
    margin-bottom: 16px !important;
  }
  .sf-plan-box__desc {
    font-size: 15px !important;
    margin-bottom: 16px !important;
  }
}
/* カード情報セクション（TORAbit準拠テーブルレイアウト） */
#body_wrap.sf-checkout-page #pmpro_payment_information_fields {
  margin-top: 0 !important;
  border: none !important;
  padding: 0 !important;
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_card {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_card_content {
  width: 100% !important;
  padding: 0 !important;
  border-bottom: 0.8px solid #ddd !important;
}
@media (min-width: 769px) {
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_card_content {
    display: flex !important;
    align-items: flex-start !important;
  }
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_legend {
  display: block !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
@media (min-width: 769px) {
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_legend {
    width: 33.33% !important;
    flex-shrink: 0 !important;
  }
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_heading {
  padding: 30px 8px 15px !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  color: #666 !important;
  vertical-align: top !important;
  border: none !important;
  border-bottom: none !important;
  text-align: left !important;
  background: transparent !important;
}
@media (min-width: 769px) {
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_heading {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
  }
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_heading .sf-required-badge {
  margin-left: auto !important;
}
@media (max-width: 768px) {
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_heading {
    background: #f9f9f9 !important;
    padding: 5px 10px 4px !important;
    font-size: 12px !important;
    border-top: 0.8px solid #ddd !important;
    border-bottom: 0.8px solid #ddd !important;
    width: calc(100% + 30px) !important;
    margin-left: -15px !important;
    margin-right: -15px !important;
    display: flex !important;
    align-items: center !important;
  }
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_fields {
  padding: 15px 0 !important;
  vertical-align: top !important;
  border-bottom: none !important;
  gap: 0 !important;
  flex-direction: column !important;
}
@media (min-width: 769px) {
  #body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_fields {
    flex: 1 !important;
  }
}
/* カード番号ラベルを非表示（見出しに統合済み） */
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_label {
  display: none !important;
}
/* Stripe Element のスタイル */
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .StripeElement {
  border: 0.8px solid #dde0e3 !important;
  border-radius: 2px !important;
  padding: 12.8px 16px !important;
  font-size: 15px !important;
  background: #fff !important;
  margin-bottom: 10px !important;
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_field {
  margin-bottom: 10px !important;
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_cols-2 {
  display: flex !important;
  gap: 0 !important;
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_cols-2 > div {
  flex: 1 !important;
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_cols-2 .pmpro_form_label {
  display: block !important;
  font-size: 14px !important;
  color: #333 !important;
  margin-bottom: 4px !important;

}


/* ユーザー名フィールド非表示（本番準拠） */
.sf-subscribe .pmpro_form_field.pmpro_form_field-text.pmpro_form_field-username {
  display: none !important;
}
/* 送信ボタン中央配置 */
.sf-subscribe .pmpro_form_submit {
  display: block !important;
  text-align: center !important;
}
.sf-subscribe #pmpro_submit_span {
  display: inline-block !important;
}
.sf-subscribe #pmpro_processing_message {
  display: none !important;
}
/* カード情報を三段（縦並び）に */
.sf-subscribe .pmpro_cols-2 {
  flex-direction: column !important;
}
.sf-subscribe .pmpro_cols-2 > .pmpro_form_field {
  width: 100% !important;
  max-width: 100% !important;
}
/* カード情報ラベルフォント統一 */
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_label {
  font-size: 14px !important;
  font-weight: 400 !important;
  color: #333 !important;
  display: block !important;
}
/* カード情報フィールド間隔詰め */
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_field {
  margin-bottom: 0 !important;
  padding: 0 !important;
}
#body_wrap.sf-checkout-page #pmpro_payment_information_fields .pmpro_form_label {
  padding: 0 !important;
  margin: 4px 0 2px 0 !important;
}

/* SP入力欄修正 */
@media (max-width: 600px) {
  .sf-subscribe input[type="text"],
  .sf-subscribe input[type="email"],
  .sf-subscribe input[type="password"] {
    padding-left: 10px !important;
    padding-right: 10px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
}

/* ===== お名前・ふりがなフィールド ===== */
.sf-name-row {
  display: flex !important;
  gap: 8px !important;
  width: 100% !important;
}
@media (max-width: 768px) {
  .sf-name-row {
    flex-direction: column !important;
    gap: 0px !important;
  }
  /* お名前・ふりがなの姓/せいの下に4px余白（TORAbit準拠） */
  .pmpro_form_field-sf-name .sf-name-row__field:first-child,
  .pmpro_form_field-sf-kana .sf-name-row__field:first-child {
    padding-bottom: 4px !important;
  }
}
.sf-name-row__field {
  flex: 1 !important;
}
.sf-name-row__field input {
  width: 100% !important;
  box-sizing: border-box !important;
}
/* お名前ラベル */
.pmpro_form_field-sf-name .pmpro_form_label,
.pmpro_form_field-sf-kana .pmpro_form_label {
  display: block !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color: #333 !important;
  padding: 0 !important;
  margin: 4px 0 2px 0 !important;
}


/* 必須バッジ右寄せ（TORAbit準拠: float-end） */
.sf-subscribe .pmpro_form_label .pmpro_asterisk {
  margin-left: auto !important;
}

/* ===== フィールド余白調整（TORAbit準拠: td padding 15px 8px）===== */
/* ラベルと入力欄の間隔: 15px（TORAbitのtd上パディング相当） */
.sf-subscribe .sf-accordion__body .pmpro_form_field .pmpro_form_label {
  margin-bottom: 8px !important;
}
/* 名前・ふりがなフィールドのラベル */
.pmpro_form_field-sf-name .pmpro_form_label,
.pmpro_form_field-sf-kana .pmpro_form_label {
  margin-bottom: 8px !important;
}
/* 各入力フィールドの下余白（フィールド間スペース） */
.sf-subscribe .sf-accordion__body .pmpro_form_field {
  padding: 8px 0 !important;
}
/* 名前フィールドも同様 */
.pmpro_form_field-sf-name,
.pmpro_form_field-sf-kana {
  padding: 8px 0 !important;
}

/* === バリデーションヒント（TORAbit準拠） === */
.sf-validation-hint {
  display: block !important;
  width: 100% !important;
  margin-top: 0 !important;
  box-sizing: border-box !important;
}
.sf-validation-hint__content {
  display: block !important;
  background: #ffbf00 !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  padding: 6px 25px 6px 10px !important;
  border-radius: 3px !important;
  line-height: 1.5 !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
/* === フォーカススタイル（TORAbit準拠） === */
.sf-checkout-page #pmpro_form input[type="text"]:focus,
.sf-checkout-page #pmpro_form input[type="email"]:focus,
.sf-checkout-page #pmpro_form input[type="password"]:focus,
.sf-checkout-page #pmpro_form select:focus {
  border-color: rgb(6, 106, 201) !important;
  outline: none !important;
  box-shadow: none !important;
}
/* === バリデーションヒント wrapper === */
.sf-input-hint-wrapper {
  flex: 1 !important;
  min-width: 0 !important;
  display: block !important;
}
.sf-input-hint-wrapper input {
  width: 100% !important;
  box-sizing: border-box !important;
}
/* 同意チェックボックス ヒント配置 */
.sf-agree-row__value {
  flex-wrap: wrap !important;
}
.sf-agree-row__value .sf-validation-hint {
  flex-basis: 100% !important;
  margin-top: 4px !important;
}

/* ---------- パスワード補足テキスト ---------- */
.sf-password-note {
  font-size: 0.85em !important;
  color: #666 !important;
  line-height: 1.3 !important;
  margin-top: 2px !important;
}

/* ---------- 継続利用向け表示 ---------- */
.sf-notrial-warning-text {
  color: red !important;
}
.sf-notrial-notice {
  margin: 0 0 16px !important;
  font-size: 15px !important;
  color: #555 !important;
  line-height: 22.5px !important;
}
.sf-notrial-guide-text {
  font-size: 15px !important;
  color: #555 !important;
  line-height: 22.5px !important;
  margin: 0 0 16px !important;
  letter-spacing: 0.6px !important;
}


/* === 送信ボタン ローディング === */
#pmpro_processing_message {
  display: none !important;
}
button#pmpro_btn-submit {
  -webkit-appearance: none;
  appearance: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
#pmpro_btn-submit.sf-btn-loading {
  pointer-events: none;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  white-space: nowrap !important;
  padding: 12.8px 40px !important;
}
.sf-submit-spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 3px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: sf-spin 0.7s linear infinite;
  flex-shrink: 0;
}
@keyframes sf-spin {
  to { transform: rotate(360deg); }
}
