/**
 * JFHANY Web - Membership ページスタイル
 *
 * Figma デザイン準拠: Desktop (4:3) / Tablet (8:47) / Mobile (8:77)
 * すべての値はカスタムプロパティ (--jfhany-*) を参照する。
 *
 * @package jfhany-web
 */

/* ==========================================================================
   レイアウト（flex column, セクション間 gap 48px）
   ========================================================================== */

.membership-join__layout {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--jfhany-space-2xl);
  padding: var(--jfhany-space-2xl) 0;
}

/* ==========================================================================
   3プラン BOX
   ========================================================================== */

.membership-join__plans {
  width: 100%;
}

.membership-join__plan-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--jfhany-space-lg);
  padding: var(--jfhany-space-lg);
}

.membership-join__plan-card {
  background-color: var(--jfhany-color-accent);
  border-radius: var(--jfhany-border-radius-lg);
  padding: var(--jfhany-space-xl);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--jfhany-space-md);
  box-shadow: var(--jfhany-shadow-sm);
}

.membership-join__plan-name {
  font-family: var(--jfhany-font-heading);
  font-size: var(--jfhany-font-size-lg);
  font-weight: 700;
  line-height: 1;
  color: var(--jfhany-color-primary);
}

.membership-join__plan-price {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--jfhany-space-md);
}

.membership-join__plan-amount {
  font-family: var(--jfhany-font-heading);
  font-size: var(--jfhany-font-size-4xl);
  font-weight: 700;
  line-height: 1;
  color: var(--jfhany-color-primary);
}

.membership-join__small {
  font-size: var(--jfhany-font-size-md);
  vertical-align: 0.1em;
}

.membership-join__plan-note {
  font-size: var(--jfhany-font-size-sm);
  line-height: 1.1;
  color: var(--jfhany-color-text-muted);
}

/* ==========================================================================
   会員特典
   ========================================================================== */

.membership-join__benefits {
  background-color: var(--jfhany-color-surface-container-low);
  border-radius: var(--jfhany-border-radius-lg);
  padding: var(--jfhany-space-lg) var(--jfhany-space-2xl);
  text-align: center;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--jfhany-space-md);
  overflow: hidden;
}

.membership-join__benefits-title {
  font-family: var(--jfhany-font-heading);
  font-size: var(--jfhany-font-size-xl);
  font-weight: 700;
  line-height: 1;
  color: var(--jfhany-color-primary);
}

.membership-join__benefits-item {
  font-size: var(--jfhany-font-size-base);
  line-height: 1.7;
  color: var(--jfhany-color-primary);
  margin: 0;
}

/* ==========================================================================
   CTA（登録ボタン）
   ========================================================================== */

.membership-join__cta {
  text-align: center;
}

.membership-join__register-btn {
  font-size: var(--jfhany-font-size-md);
  padding: var(--jfhany-space-md) var(--jfhany-space-3xl);
}

/* ==========================================================================
   メンバーメッセージ（ログイン済み）
   ========================================================================== */

.membership-join__member-message {
  font-family: var(--jfhany-font-heading);
  font-size: var(--jfhany-font-size-lg);
  font-weight: 600;
  color: var(--jfhany-color-primary);
  margin: 0;
}

/* ==========================================================================
   ログインプロンプト（未ログイン時）
   ========================================================================== */

.membership-join__login-prompt {
  margin-top: var(--jfhany-space-sm);
  font-size: var(--jfhany-font-size-sm);
  color: var(--jfhany-color-text-muted);
}

.membership-join__login-prompt a {
  color: var(--jfhany-color-primary);
  text-decoration: underline;
  font-weight: 600;
}

.membership-join__login-prompt a:hover {
  text-decoration: none;
}

/* ==========================================================================
   レスポンシブ
   ========================================================================== */

@media (max-width: 768px) {
  .membership-join__plan-grid {
    grid-template-columns: 1fr;
  }

  .membership-join__benefits {
    padding: var(--jfhany-space-lg) var(--jfhany-space-lg);
  }
}
