/* =====================================================================
   ポイ活プレミアム - Pop Skin (style.css の上に重ねる reskin layer)
   v2 (コミックエッセイ／ママ系インスタ漫画) の雰囲気を本番LPに適用
   - 既存 class 名は変えず、トークンと装飾だけを上書き
   - style.css の後に link すること
   ===================================================================== */

/* ---------- Token overrides ---------- */
:root {
  /* Pink-pop palette */
  --c-primary: #e8285f;
  --c-primary-light: #ff5e8e;
  --c-primary-rgb: 232, 40, 95;
  --c-gold: #ff5e8e;            /* gold → pink (CTAやアクセント色全般) */
  --c-gold-light: #ffc8d8;
  --c-gold-dark: #c4004a;
  --c-gold-rgb: 255, 94, 142;
  --c-accent: #ff5e8e;           /* accent もピンク統一（黄色は yellow-marker でだけ使う） */
  --c-accent-light: #ffaec0;
  --c-accent-rgb: 255, 94, 142;
  --c-yellow-marker: #fff044;    /* 黄色マーカー専用 */
  --c-success: #4fc88a;
  --c-bg: #fffaf3;
  --c-bg-alt: #ffeef2;
  --c-bg-dark: #2a1820;
  --c-text: #3d2817;
  --c-text-light: #6b5645;
  --c-text-inverse: #fff;
  --c-border: #f4d4dc;

  /* Pop fonts (v2 と同じ手描き・丸ゴ系) */
  --ff-heading: 'Zen Maru Gothic', 'Noto Sans JP', sans-serif;
  --ff-body: 'Zen Maru Gothic', 'Noto Sans JP', sans-serif;
  --ff-accent: 'Yusei Magic', 'Klee One', cursive;
  --ff-display: 'Yusei Magic', 'Zen Maru Gothic', cursive;
  --ff-en: 'Yusei Magic', 'Klee One', cursive;

  /* Shadow を pink tone に */
  --shadow-sm: 0 2px 6px rgba(255, 94, 142, 0.10);
  --shadow-md: 0 4px 16px rgba(255, 94, 142, 0.14);
  --shadow-lg: 0 8px 28px rgba(255, 94, 142, 0.18);
  --shadow-xl: 0 16px 40px rgba(255, 94, 142, 0.22);
  --shadow-gold: 0 4px 18px rgba(255, 94, 142, 0.28);
}

body {
  font-weight: 500;
  letter-spacing: 0.02em;
  background: var(--c-bg);
}

/* ---------- 全体に水色水玉装飾（カード裏・section背景前） ----------
   z-index 0 で default static要素の前。 各カード(白枠)は position:relative + z-index:1 で
   水玉を上から覆う。 background-attachment: scroll で スマホ描画コストを下げる */
body::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 12% 6%, rgba(80, 200, 255, 0.28) 10px, transparent 11px),
    radial-gradient(circle at 88% 12%, rgba(80, 200, 255, 0.22) 14px, transparent 15px),
    radial-gradient(circle at 6% 22%, rgba(80, 200, 255, 0.24) 8px, transparent 9px),
    radial-gradient(circle at 92% 28%, rgba(80, 200, 255, 0.22) 12px, transparent 13px),
    radial-gradient(circle at 18% 38%, rgba(80, 200, 255, 0.20) 11px, transparent 12px),
    radial-gradient(circle at 78% 46%, rgba(80, 200, 255, 0.26) 9px, transparent 10px),
    radial-gradient(circle at 8% 58%, rgba(80, 200, 255, 0.22) 13px, transparent 14px),
    radial-gradient(circle at 88% 68%, rgba(80, 200, 255, 0.24) 8px, transparent 9px),
    radial-gradient(circle at 22% 78%, rgba(80, 200, 255, 0.20) 11px, transparent 12px),
    radial-gradient(circle at 92% 88%, rgba(80, 200, 255, 0.26) 10px, transparent 11px);
  background-size: 100vw 200vh;
  background-repeat: repeat-y;
}

body { position: relative; }

/* 全カード/枠を 水玉より前面に出して カバー（.header は除外: 上で 1000 に固定） */
.hero__card,
.pain__card,
.solution__step,
.compare__col,
.results__card,
.result-detail,
.results__detail-item,
.trust__operator,
.trust__meta,
.testimonial,
.pricing__card,
.faq__item,
.v2-manga__panel,
.cta-section,
.footer,
.marquee,
.v2-shock-text,
.v2-amazing,
.v2-narration,
.hero__inner {
  position: relative;
  z-index: 2;
}

/* ---------- Header ---------- */
.header {
  background: rgba(255, 250, 243, 0.92) !important;
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 2px solid var(--c-border);
  z-index: 1000 !important; /* nav-overlay (1050) との関係維持 */
}

/* ハンバーガーが nav-overlay より上に出るようにする */
.hamburger { z-index: 1100 !important; position: relative; }
.nav-overlay { z-index: 1050 !important; }

.header__logo,
.logo {
  font-family: var(--ff-display) !important;
  color: var(--c-primary) !important;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.header__logo-aya {
  width: auto !important;
  height: 44px !important;
  display: block;
  /* manga-hero (1024x768=4:3) はキャラ周囲に余白あり。
     CSSで右側余白をクロップして顔メインに見せる */
  object-fit: cover;
  object-position: center;
}

@media (max-width: 640px) {
  .header__logo-aya { height: 36px !important; }
}

/* ---------- Hero (radial-gradient×2 を linear に置換、描画負荷軽減) ---------- */
.hero {
  background: linear-gradient(180deg, #fff5f8 0%, #fffaf3 100%);
}

/* ---------- Marquee 動作保証 + 幅広く + 速度遅く ---------- */
.marquee {
  padding: 18px 0 !important;
  font-size: var(--fs-md) !important;
}

.marquee__track {
  animation: marquee-scroll 60s linear infinite !important;
  animation-play-state: running !important;
  will-change: transform;
  backface-visibility: hidden;
}

.marquee__item {
  padding: 0 var(--sp-2xl) !important;
  font-weight: 700;
}

/* ---------- v2-shock-text を少し左に傾けて手書き感UP ---------- */
.v2-shock-text {
  transform: rotate(-2.5deg);
  transform-origin: center;
}

/* ---------- compare demo-head: SP では縦並びで tag/title/date が
   横にぎゅっと詰まって読みにくい問題を解消 ---------- */
@media (max-width: 640px) {
  .compare__demo-head {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }
  .compare__demo-tag,
  .compare__demo-title,
  .compare__demo-date {
    width: 100% !important;
  }
  .compare__demo-tag {
    background: var(--c-bg-alt) !important;
    color: var(--c-primary) !important;
    border-color: var(--c-primary) !important;
  }
}

/* compare__demo-tag を pop tone に上書き (元 gold から pink) */
.compare__demo-tag {
  background: var(--c-bg-alt) !important;
  color: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
  font-family: var(--ff-display) !important;
}

.compare__demo-title {
  font-family: var(--ff-display) !important;
  color: var(--c-primary) !important;
}

/* ---------- PC hero: あや背景を右上に小さく寄せて タイトル との重なり回避 ---------- */
@media (min-width: 1025px) {
  .hero::before {
    background-size: 38% auto !important;
    background-position: 96% 12% !important;
    opacity: 0.50 !important;
  }
}

/* ===========================================================
   PC 専用レイアウト最適化 (≥1025px)
   =========================================================== */
@media (min-width: 1025px) {
  /* solution 見出しを中央寄せ（LP の他セクションと統一） */
  .solution .section-label,
  .solution .section-title,
  .solution .section-desc {
    text-align: center;
  }
  .solution .section-title { font-size: clamp(2rem, 1.5rem + 1.5vw, 2.8rem); }

  /* solution__step PC では aya 画像を 小さく → 文字スペース確保 */
  .solution__step { padding-right: 130px !important; flex: 0 0 340px !important; }
  .solution__step-aya { width: 140px; }
  .solution__step-aya--square { width: 122px; }

  /* pricing カードの幅を拡張 (元 max-width が狭すぎ) */
  .pricing__card {
    max-width: 720px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* v2-manga / v2-chapter PC では中央 720px のままだと両側余白が空き過ぎ
     → 少し広げて装飾感UP（max-width 880px） */
  .v2-chapter,
  .v2-manga {
    max-width: 880px !important;
    padding: 80px 32px !important;
  }

  /* v2-manga__panel PC では 横幅活用＋中央寄せでカードが大きく見える */
  .v2-manga__panels { max-width: 720px; margin-left: auto; margin-right: auto; }

  /* divider PC: 中央テキストをもう少し大きく */
  .v2-divider__text { font-size: clamp(28px, 2vw, 36px) !important; }
  .v2-divider__arrow { font-size: 64px !important; }
}

/* タブレット (768〜1024) 個別調整 */
@media (min-width: 768px) and (max-width: 1024px) {
  .solution__step-aya { width: 130px; }
  .solution__step-aya--square { width: 110px; }
}

.hero::before {
  /* 元: 写真(手＋スマホ)背景 → manga-hero(あや) に差し替え */
  background-image: url("../images/manga-hero.webp") !important;
  background-size: contain !important;
  background-position: right 5% !important;
  background-repeat: no-repeat !important;
  opacity: 0.55 !important;
  filter: none !important;
}

@media (max-width: 1024px) {
  .hero::before {
    background-position: center 8% !important;
    opacity: 0.70 !important;
  }
}

.hero::after {
  background: linear-gradient(
    105deg,
    rgba(255, 250, 243, 0.78) 0%,
    rgba(255, 250, 243, 0.50) 45%,
    rgba(255, 250, 243, 0.10) 100%
  ) !important;
}

@media (max-width: 1024px) {
  .hero::after {
    background: linear-gradient(
      180deg,
      rgba(255, 250, 243, 0.55) 0%,
      rgba(255, 250, 243, 0.40) 50%,
      rgba(255, 250, 243, 0.65) 100%
    ) !important;
  }
}

.hero__badge {
  background: #fff !important;
  color: var(--c-primary) !important;
  border: 2px solid var(--c-primary) !important;
  border-radius: 100px !important;
  font-family: var(--ff-display) !important;
  font-weight: 700;
  box-shadow: var(--shadow-sm);
}

.hero__title {
  font-family: var(--ff-display) !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em !important;
}

.hero__title-accent {
  color: var(--c-text) !important;
  background: linear-gradient(180deg, transparent 60%, var(--c-yellow-marker) 60%);
  -webkit-text-fill-color: initial !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  padding: 0 4px;
}

.hero__title-accent::after {
  display: none !important;
}

.hero__subtitle {
  font-family: var(--ff-body) !important;
  font-weight: 500;
}

.hero__subtitle .highlight,
.highlight {
  background: linear-gradient(180deg, transparent 55%, var(--c-yellow-marker) 55%) !important;
  color: var(--c-text) !important;
  font-weight: 700;
  padding: 0 2px;
}

.hero__stat-number {
  font-family: var(--ff-accent) !important;
  color: var(--c-primary) !important;
}

.hero__stat-label {
  font-family: var(--ff-body) !important;
  color: var(--c-text-light);
}

/* hero の visual カード（モック画面） */
.hero__card {
  background: #fff !important;
  border: 2px solid var(--c-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-md) !important;
}

.hero__card--main {
  border-color: var(--c-primary) !important;
}

.hero__card-title {
  font-family: var(--ff-display) !important;
  color: var(--c-primary) !important;
}

.hero__card-amount {
  font-family: var(--ff-accent) !important;
  color: var(--c-text) !important;
  background: none !important;
  -webkit-background-clip: initial !important;
  -webkit-text-fill-color: initial !important;
  background-clip: initial !important;
}

.hero__card-amount--gold {
  color: var(--c-primary) !important;
  background: none !important;
  -webkit-background-clip: initial !important;
  -webkit-text-fill-color: initial !important;
}

.hero__card--tertiary .hero__card-amount {
  color: var(--c-primary) !important;
  font-weight: 900;
}

/* ---------- Buttons ---------- */
.btn {
  font-family: var(--ff-display) !important;
  letter-spacing: 0.04em;
}

.btn--primary {
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 14px rgba(255, 94, 142, 0.4), 0 0 0 3px rgba(255, 255, 255, 0.6) inset !important;
  border-radius: 100px !important;
}

.btn--primary:hover {
  background: linear-gradient(135deg, #ff7ba2 0%, #ff3b78 100%) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(255, 94, 142, 0.5), 0 0 0 3px rgba(255, 255, 255, 0.6) inset !important;
}

.btn--secondary {
  background: #fff !important;
  color: var(--c-primary) !important;
  border: 2px solid var(--c-primary) !important;
  border-radius: 100px !important;
}

.btn--secondary:hover {
  background: var(--c-bg-alt) !important;
}

/* ---------- Section common ---------- */
.section__eyebrow,
.eyebrow {
  font-family: var(--ff-display) !important;
  color: var(--c-primary) !important;
}

/* 見出しはフォントだけ強制。色は既存ルールを尊重（ピンク背景の上の白文字を壊さない） */
h1, h2, h3, h4,
.section__title,
.title,
.heading,
.h2, .h3 {
  font-family: var(--ff-display) !important;
}

/* マーカー風 highlight */
strong, b {
  color: var(--c-primary);
}

/* ---------- Skip-link を主張させない ---------- */
.skip-link {
  background: #2a1820 !important;
  color: #fff !important;
}

/* ---------- Pricing card ピンク背景上のバッジを白に戻す ---------- */
.pricing__card-header {
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%) !important;
  color: #fff !important;
}

.pricing__card-header h2,
.pricing__card-header h3,
.pricing__card-header .pricing__card-title {
  color: #fff !important;
}

.pricing__card-badge {
  background: #fff !important;
  color: var(--c-primary) !important;
  border: 2px solid #fff !important;
}

.pricing__card-note {
  color: rgba(255, 255, 255, 0.92) !important;
  opacity: 1 !important;
}

.pricing__card-price {
  font-family: 'Zen Maru Gothic', 'Noto Sans JP', sans-serif !important;
  font-weight: 900 !important;
  color: #fff !important;
  letter-spacing: 0.05em !important;
  text-shadow: 0 2px 6px rgba(196, 0, 74, 0.35);
}

/* ---------- Sticky CTA (右下フローティング) ---------- */
.sticky-cta {
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%) !important;
  color: #fff !important;
  border: 3px solid #fff !important;
  box-shadow: 0 6px 22px rgba(232, 40, 95, 0.45) !important;
  font-family: var(--ff-display) !important;
}

.sticky-cta:hover {
  background: linear-gradient(135deg, #ff7ba2 0%, #ff3b78 100%) !important;
}

/* ---------- 全 .btn フォールバック（accent等の取りこぼし防止） ---------- */
.btn--accent,
.cta-button,
button[class*="cta"] {
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%) !important;
  color: #fff !important;
  border: none !important;
  font-family: var(--ff-display) !important;
}

/* ---------- Pain section ---------- */
.pain {
  background: linear-gradient(180deg, #fffaf3 0%, #ffeef2 100%) !important;
}

.pain__item,
.pain-item,
[class*="pain__"] li {
  background: #fff !important;
  border: 2px solid var(--c-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ---------- Cards / generic ---------- */
.card,
.compare__col,
.results__card,
.testimonial,
.faq__item,
.story__step,
.trust__item,
.solution__card,
.pricing__card {
  background: #fff !important;
  border: 2px solid var(--c-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ---------- CTA section / Pricing ---------- */
.pricing__card {
  border-color: var(--c-primary) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* ---------- Solution（元: 紺背景＋ゴールド → 明るいピンクトーンへ） ---------- */
.solution {
  background: linear-gradient(180deg, #fff5f8 0%, #ffeef2 100%) !important;
  color: var(--c-text) !important;
}

.solution::before {
  background: var(--c-bg) !important;
}

.solution .section-label,
.solution .section-title {
  color: var(--c-text) !important;
}

.solution__badge {
  background: #fff !important;
  border: 2px solid var(--c-border) !important;
  color: var(--c-text) !important;
  backdrop-filter: none !important;
  box-shadow: var(--shadow-sm) !important;
}

.solution__badge-icon {
  color: var(--c-primary) !important;
}

.solution__badge-title {
  color: var(--c-text) !important;
}

.solution__badge-sub {
  color: var(--c-text-light) !important;
}

/* solution__flow を 横スクロール (snap) に変更:
   元 grid 1.2fr 1fr 0.8fr で STEP3 だけ狭かった問題を解決
   PC: マウス horizontal scroll / SP: タッチ swipe */
.solution__flow {
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: visible !important;
  scroll-snap-type: x mandatory;
  gap: 20px !important;
  padding: 20px 4px 28px !important;
  margin-left: -4px;
  margin-right: -4px;
  -webkit-overflow-scrolling: touch;
  /* スクロールバーを ピンク細く */
  scrollbar-width: thin;
  scrollbar-color: var(--c-primary) transparent;
}

.solution__flow::-webkit-scrollbar {
  height: 6px;
}
.solution__flow::-webkit-scrollbar-track {
  background: transparent;
}
.solution__flow::-webkit-scrollbar-thumb {
  background: var(--c-primary);
  border-radius: 100px;
}

.solution__step {
  background: #fff !important;
  border: 2px solid var(--c-border) !important;
  box-shadow: var(--shadow-sm) !important;
  flex: 0 0 84% !important;       /* SP: 1枚見せ + 隣カードちょっと覗く */
  scroll-snap-align: start;
  max-width: 360px;
}

@media (min-width: 768px) {
  .solution__step { flex: 0 0 320px !important; max-width: 360px; }
}

@media (min-width: 1025px) {
  .solution__step { flex: 0 0 340px !important; }
}

/* 元 nth-child(2) が translateY していた装飾は横スクロール化で削除 */
.solution__step:nth-child(2) {
  transform: none !important;
}

.solution__step:hover {
  background: #fff !important;
  border-color: var(--c-primary) !important;
}

.solution__step-title {
  color: var(--c-text) !important;
}

.solution__step-desc {
  color: var(--c-text-light) !important;
}

.solution__step-num {
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%) !important;
  color: #fff !important;
}

.solution__step-arrow {
  color: var(--c-primary) !important;
  opacity: 0.7 !important;
}

/* 各 STEP カードの右下に あや の透過イラストを配置 */
.solution__step {
  position: relative;
  overflow: hidden;
  padding-right: 150px !important;
  min-height: 180px;
}

.solution__step-aya {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 170px;
  height: auto;
  pointer-events: none;
  user-select: none;
}

.solution__step-aya--square {
  width: 150px;
}

@media (max-width: 480px) {
  .solution__step {
    padding-right: 130px !important;
  }
  .solution__step-aya {
    width: 140px;
  }
  .solution__step-aya--square {
    width: 122px;
  }
}

/* ---------- FAQ summary（元: --c-primary 紺で見やすかったが今ピンクで弱い） ---------- */
.faq__question {
  color: var(--c-text) !important;
  font-family: var(--ff-display) !important;
}

.faq__question-icon {
  background: var(--c-bg-alt) !important;
  color: var(--c-primary) !important;
  border: 1px solid var(--c-border) !important;
}

.faq__item.is-open .faq__question-icon {
  background: var(--c-primary) !important;
  color: #fff !important;
}

.faq__answer-inner {
  color: var(--c-text) !important;
}

/* ---------- Trust card 強化（白カード上の文字をクッキリ） ---------- */
.trust__meta {
  border: 2px solid var(--c-border) !important;
  border-top: 4px solid var(--c-primary) !important;
}

.trust__meta h3 {
  color: var(--c-text) !important;
  font-family: var(--ff-display) !important;
}

.trust__stats li {
  color: var(--c-text) !important;
}

.trust__stats-val {
  color: var(--c-primary) !important;
  font-family: var(--ff-accent) !important;
}

.trust__updated {
  background: var(--c-bg-alt) !important;
  color: var(--c-text) !important;
}

.trust__updated strong {
  color: var(--c-primary) !important;
}

/* ---------- CTA Section（公園散歩イラストを背景に + うすめのピンクオーバーレイ） ---------- */
.cta-section {
  background:
    linear-gradient(
      135deg,
      rgba(232, 40, 95, 0.30) 0%,
      rgba(196, 0, 74, 0.45) 100%
    ),
    url('../images/manga-final.webp') center/cover no-repeat !important;
}

/* オーバーレイ薄くした分、文字側に強めの影と背景パッドで読みやすく */
.cta-section__title,
.cta-section__desc {
  color: #fff !important;
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.65), 0 0 18px rgba(196, 0, 74, 0.55);
}

/* CTA section の中の .btn--primary は白背景＋ピンク文字に反転（同化回避） */
.cta-section .btn--primary {
  background: #fff !important;
  color: var(--c-primary) !important;
  border: 3px solid #fff !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18) !important;
}

.cta-section .btn--primary:hover {
  background: var(--c-bg-alt) !important;
  color: var(--c-primary) !important;
}

/* ---------- Animation 堅牢化 + 軽量化（スマホで重い blur/clip 排除） ----------
   - 元 .reveal は opacity:0 で隠れて IO で .is-visible 付与
   - JS失敗・遅延でも消えないよう初期 opacity 0.5 に
   - blur/clip-path は重いので不採用（opacity + transform だけに統一）
   - duration も 0.7s → 0.45s に短縮 */
.reveal {
  transition: opacity 0.45s var(--ease-out), transform 0.45s var(--ease-out) !important;
}

.reveal:not(.is-visible) {
  opacity: 0.5 !important;
  transform: translateY(10px) !important;
  filter: none !important;
  clip-path: none !important;
}

.reveal--blur:not(.is-visible) {
  opacity: 0.5 !important;
  filter: none !important;
}

.reveal--clip:not(.is-visible) {
  clip-path: none !important;
  opacity: 0.5 !important;
}

/* prefers-reduced-motion はそのまま既存の rules で安全（reveal が opacity:1 強制） */

/* ---------- Footer ---------- */
.footer {
  background:
    linear-gradient(180deg, rgba(232, 40, 95, 0.85) 0%, rgba(196, 0, 74, 0.92) 100%),
    var(--c-bg-dark) !important;
  color: #fff !important;
}

.footer a {
  color: rgba(255, 255, 255, 0.92) !important;
}

/* footer ロゴ 改行防止 */
.footer__brand {
  white-space: nowrap !important;
  font-family: var(--ff-display) !important;
}

/* ---------- Member layout (会員エリアにも影響しないよう class 衝突避ける) ---------- */
/* 何も書かない（member/* は触らない方針） */

/* =========================================================
   v2 漫画パート移植 (story セクション置換用)
   v2 専用クラス (v2-) なので本番既存クラスとは衝突しない
   v2 専用 tokens もここで定義
   ========================================================= */

:root {
  --paper: #ffffff;
  --paper-cream: #fff5e6;
  --paper-pink: #ffeef2;
  --paper-pink-deep: #ffe0e8;
  --pink: #ff5e8e;
  --pink-soft: #ffaec0;
  --pink-deep: #e8285f;
  --magenta: #ff0d6e;
  --magenta-deep: #c4004a;
  --yellow-pop: #ffe600;
  --yellow-marker: #fff044;
  --yellow-marker-soft: #fff8b0;
  --pink-marker: #ffc8d8;
  --pink-burst: #ff3787;
  --border-strong: #f4a8b8;
  --shadow: 0 4px 20px rgba(255, 107, 157, 0.12);
  --shadow-deep: 0 8px 32px rgba(255, 107, 157, 0.18);
  --radius: 16px;
  --font-handwritten: 'Yusei Magic', 'Klee One', cursive;
  --font-heading: 'Zen Maru Gothic', 'Noto Sans JP', sans-serif;
}

@keyframes v2-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(6px); }
}

/* 「↓ 私が見つけた方法 ↓」を 左右ぷるぷる揺れに */
@keyframes v2-shake {
  0%, 100% { transform: rotate(-2deg) translateX(0); }
  20% { transform: rotate(-5deg) translateX(-3px); }
  40% { transform: rotate(1deg) translateX(2px); }
  60% { transform: rotate(-4deg) translateX(-2px); }
  80% { transform: rotate(0deg) translateX(2px); }
}

.v2-manga__cta-block .v2-handwritten {
  animation: v2-shake 1.4s ease-in-out infinite !important;
  display: inline-block;
  transform-origin: center;
}

/* divider が viewport に入った時の にゅいん 登場 */
@keyframes v2-divider-nyuin {
  0% { transform: translateY(80px) scaleY(1.15) scaleX(0.92); opacity: 0; }
  55% { transform: translateY(-14px) scaleY(0.94) scaleX(1.05); opacity: 1; }
  78% { transform: translateY(4px) scaleY(1.02) scaleX(0.99); }
  100% { transform: translateY(0) scaleY(1) scaleX(1); opacity: 1; }
}

.v2-divider__inner {
  transform-origin: center bottom;
}

.v2-divider.is-visible .v2-divider__inner {
  animation: v2-divider-nyuin 1.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

/* solution 全体に animation を掛けると section が消える事故が起きるので外す */

@keyframes v2-amazing-glow {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}

/* 漫画→具体策 の仕切り（普通のセクションに戻す。sticky は後続レイアウト崩しの原因だった） */
.v2-divider {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #fffaf3 0%, #fff5f8 100%);
  text-align: center;
  padding: 48px 20px;
}

.v2-divider__inner {
  max-width: 480px;
}

.v2-divider__text {
  font-family: var(--ff-display);
  font-size: clamp(20px, 5.5vw, 32px);
  color: var(--c-text);
  line-height: 1.85;
  margin-bottom: 36px;
  font-weight: 700;
}

.v2-divider__text strong {
  color: var(--c-primary);
  background: linear-gradient(180deg, transparent 60%, var(--c-yellow-marker) 60%);
  padding: 0 6px;
  font-weight: 900;
}

.v2-divider__arrow {
  display: inline-block;
  font-size: 56px;
  color: var(--c-primary);
  animation: v2-bob 1.2s ease-in-out infinite;
  text-shadow: 0 4px 12px rgba(232, 40, 95, 0.25);
}

/* v2-chapter / v2-manga セクションを v2 preview と同じレイアウトに */
.v2-chapter,
.v2-manga {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  padding: 64px 20px;
}

@media (max-width: 640px) {
  .v2-chapter,
  .v2-manga {
    padding: 48px 16px;
  }
}
.v2-handwritten {
  font-family: var(--font-handwritten);
  color: var(--pink-deep);
  font-size: 16px;
  line-height: 1.6;
  display: inline-block;
  transform: rotate(-2deg);
}

.v2-manga {
  background: var(--paper-cream);
  padding-bottom: 72px !important;
}

.v2-manga__panels {
  display: flex;
  flex-direction: column;
  gap: 56px;
  margin-top: 16px;
}

.v2-manga__panel {
  position: relative;
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 48px 20px 24px;
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
}

.v2-manga__panel--highlight {
  background: linear-gradient(180deg, #fff8e0 0%, #fff 100%);
  border: 2px solid var(--yellow-marker);
  box-shadow: 0 8px 32px rgba(255, 200, 0, 0.18);
}

.v2-manga__panel--final {
  background: linear-gradient(180deg, #fff0f5 0%, #fff 100%);
  border: 2px solid var(--pink-soft);
  box-shadow: 0 8px 32px rgba(255, 107, 157, 0.18);
}

.v2-manga__panel-no {
  position: absolute;
  top: -16px;
  left: 50%;
  transform: translateX(-50%);
  width: 56px;
  height: 56px;
  background: var(--pink);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: 24px;
  box-shadow: var(--shadow);
  z-index: 2;
}

.v2-manga__panel--highlight .v2-manga__panel-no {
  background: #f5b800;
}

.v2-manga__panel--final .v2-manga__panel-no {
  background: var(--pink-deep);
}

.v2-manga__cta-block {
  text-align: center;
  margin-top: 56px;
}

.v2-manga__cta-block .v2-handwritten {
  font-size: 18px;
  animation: v2-bob 1.6s ease-in-out infinite;
}

.v2-magenta {
  color: var(--magenta);
  font-weight: 900;
}

.v2-chapter {
  text-align: center;
  padding: 32px 16px !important;
  margin: 0 auto !important;
  max-width: none !important;
  position: relative;
  width: 100%;
}

.v2-chapter--1 {
  background:
    radial-gradient(circle at 10% 50%, var(--yellow-dot) 4px, transparent 5px) 0 0/40px 40px,
    radial-gradient(circle at 90% 50%, var(--yellow-dot) 4px, transparent 5px) 20px 20px/40px 40px,
    linear-gradient(180deg, var(--bg), var(--yellow-bg));
}

.v2-chapter--2 {
  background:
    repeating-linear-gradient(
      -45deg,
      #1a1530 0,
      #1a1530 20px,
      #251f3a 20px,
      #251f3a 40px
    );
  color: #fff;
  position: relative;
}

.v2-chapter--2::before,
.v2-chapter--2::after {
  content: '';
  position: absolute;
  width: 60px;
  height: 60px;
  background: var(--magenta);
  border-radius: 50%;
  filter: blur(40px);
  opacity: 0.6;
}

.v2-chapter--2::before { top: 20%; left: 20%; }
.v2-chapter--2::after { bottom: 20%; right: 20%; background: var(--yellow-pop); }

.v2-chapter--2 .v2-chapter__title,
.v2-chapter--2 .v2-chapter__num {
  color: #fff;
  position: relative;
  z-index: 2;
}

.v2-chapter--3 {
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 230, 0, 0.18), transparent 70%),
    linear-gradient(180deg, var(--yellow-bg), #fff5fa);
}

.v2-chapter__head {
  display: inline-block;
  position: relative;
}

.v2-chapter__num {
  display: inline-block;
  font-family: 'RocknRoll One', var(--font-heading), sans-serif;
  font-size: 14px;
  letter-spacing: 0.15em;
  color: #fff;
  background: var(--magenta);
  padding: 6px 22px;
  border-radius: 100px;
  border: 3px solid var(--text);
  margin-bottom: 14px;
  box-shadow: 3px 3px 0 var(--text);
  transform: rotate(-2deg);
}

.v2-chapter--2 .v2-chapter__num {
  background: var(--yellow-pop);
  color: var(--text);
  border-color: #fff;
  box-shadow: 3px 3px 0 #fff;
}

.v2-chapter__title {
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: clamp(20px, 5.2vw, 26px);
  color: var(--text);
  line-height: 1.4;
}

.v2-narration-banner {
  margin: 0 auto;
  max-width: 100%;
  padding: 20px 16px;
  background:
    repeating-linear-gradient(
      45deg,
      var(--yellow-marker-soft) 0,
      var(--yellow-marker-soft) 8px,
      #fff 8px,
      #fff 16px
    );
  text-align: center;
  border-radius: 0;
  border-top: 2px dashed var(--magenta);
  border-bottom: 2px dashed var(--magenta);
}

.v2-narration-banner__text {
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: clamp(15px, 4vw, 18px);
  color: var(--text);
  line-height: 1.7;
  background: rgba(255, 255, 255, 0.92);
  padding: 8px 12px;
  display: inline-block;
  border-radius: 4px;
}

.v2-narration-banner--bright {
  background:
    repeating-linear-gradient(
      45deg,
      #fff5cc 0,
      #fff5cc 8px,
      #fffaeb 8px,
      #fffaeb 16px
    );
  border-color: var(--magenta);
}

.v2-shock-text {
  text-align: center;
  padding: 32px 20px;
  background: #fff;
  margin: 0 auto;
  max-width: 100%;
  position: relative;
}

.v2-shock-text__main,
.v2-shock-text__big {
  font-family: var(--font-heading);
  font-weight: 900;
  color: var(--text);
  line-height: 1.4;
  margin-bottom: 16px;
}

.v2-shock-text__main {
  font-size: clamp(28px, 7vw, 36px);
  letter-spacing: 0.04em;
}

.v2-shock-text__big {
  font-size: clamp(22px, 5.5vw, 28px);
}

.v2-shock-text__sub {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(15px, 4vw, 17px);
  line-height: 1.85;
  color: var(--text);
}

.v2-shock-text--dark {
  background: #1a1530;
  color: #fff;
}

.v2-shock-text--dark .v2-shock-text__big,
.v2-shock-text--dark .v2-shock-text__sub {
  color: #fff;
}

.v2-amazing {
  text-align: center;
  padding: 32px 20px;
  background:
    radial-gradient(circle at 50% 50%, #fffce0 0%, #fff5d0 60%, var(--bg) 100%);
  position: relative;
}

.v2-amazing::before,
.v2-amazing::after {
  content: '★';
  position: absolute;
  font-size: 32px;
  color: var(--yellow-pop);
  text-shadow: 0 0 8px rgba(255, 230, 0, 0.6), 0 0 2px rgba(255, 200, 0, 0.9);
  font-family: var(--ff-display) !important;
  pointer-events: none;
}

/* SP: タイトルが折り返さないよう padding/font 詰める + 星も外側に */
@media (max-width: 480px) {
  .v2-amazing { padding-left: 18px !important; padding-right: 18px !important; }
  .v2-amazing__title { font-size: 22px !important; white-space: nowrap; letter-spacing: -0.01em; }
  .v2-amazing::before,
  .v2-amazing::after { font-size: 22px; }
  .v2-amazing::before { top: -10px !important; left: 0 !important; }
  .v2-amazing::after { bottom: -10px !important; right: 0 !important; }
}

.v2-amazing::before {
  top: 12px;
  left: 16px;
  transform: rotate(-15deg);
}

.v2-amazing::after {
  bottom: 12px;
  right: 16px;
  transform: rotate(20deg);
}

.v2-amazing__title {
  font-family: 'RocknRoll One', var(--font-heading), sans-serif;
  font-weight: 900;
  font-size: clamp(28px, 7vw, 36px);
  color: var(--magenta);
  text-shadow: 3px 3px 0 #fff, 5px 5px 0 var(--yellow-marker);
  letter-spacing: 0.02em;
  line-height: 1.2;
  margin-bottom: 12px;
}

.v2-amazing__sub {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(15px, 4vw, 18px);
  color: var(--text);
  line-height: 1.8;
}

.v2-manga__panel--shock {
  border: 3px solid var(--magenta);
  box-shadow: 0 0 0 4px #fff, 0 0 0 6px var(--magenta);
  position: relative;
}

.v2-manga__panel--shock::before {
  content: '!?';
  position: absolute;
  top: -20px;
  right: -8px;
  background: var(--magenta);
  color: #fff;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'RocknRoll One', var(--font-heading), sans-serif;
  font-size: 22px;
  font-weight: 900;
  border: 3px solid #fff;
  z-index: 3;
  transform: rotate(15deg);
}

.v2-manga__panel--bright {
  background: linear-gradient(180deg, #fffce0 0%, #fff 100%);
  border: 2px solid var(--yellow-marker);
}

.v2-manga__image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius);
  border: 3px solid var(--text);
  box-shadow: 5px 5px 0 var(--text);
  background: #fff;
}

.v2-manga__panel:has(.v2-manga__image) {
  padding-bottom: 16px;
}

.v2-narration {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(14px, 4vw, 17px);
  line-height: 1.85;
  text-align: center;
  padding: 14px 16px;
  margin: 0 auto;
  color: var(--text);
  background: #fffbe9;
  border: 2px solid var(--text);
  border-radius: 12px;
  box-shadow: 3px 3px 0 var(--text);
  max-width: 96%;
  position: relative;
}

.v2-narration--top {
  margin-bottom: 16px;
  background: linear-gradient(180deg, #fff8d0 0%, #fffbe9 100%);
}

.v2-narration--top::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%) rotate(-5deg);
  width: 18px;
  height: 18px;
  background: #fffbe9;
  border-right: 2px solid var(--text);
  border-bottom: 2px solid var(--text);
  clip-path: polygon(0 0, 100% 0, 100% 100%);
}

.v2-narration--bottom {
  margin-top: 16px;
  background: #fff;
}

.v2-narration--bottom::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%) rotate(135deg);
  width: 18px;
  height: 18px;
  background: #fff;
  border-right: 2px solid var(--text);
  border-bottom: 2px solid var(--text);
  clip-path: polygon(0 0, 100% 0, 100% 100%);
}

.v2-narration--final {
  background: linear-gradient(135deg, #fff5fa 0%, #fff8d0 100%);
  border-color: var(--magenta);
  box-shadow: 4px 4px 0 var(--magenta);
  font-size: clamp(15px, 4.2vw, 18px);
  font-weight: 900;
}

.v2-narration--final::before {
  background: linear-gradient(135deg, #fff5fa 0%, #fff8d0 100%);
  border-color: var(--magenta);
}

.v2-narration strong {
  font-weight: 900;
}

.v2-magenta {
  color: var(--magenta);
  font-weight: 900;
}

/* ----- HOOK 強化（さらにポップ） ----- */
.v2-shock-text {
  text-align: center;
  padding: 32px 20px;
  background: #fff;
  margin: 0 auto;
  max-width: 100%;
  position: relative;
}

.v2-shock-text__main,
.v2-shock-text__big {
  font-family: var(--font-heading);
  font-weight: 900;
  color: var(--text);
  line-height: 1.4;
  margin-bottom: 16px;
}

.v2-shock-text__main {
  font-size: clamp(28px, 7vw, 36px);
  letter-spacing: 0.04em;
}

.v2-shock-text__big {
  font-size: clamp(22px, 5.5vw, 28px);
}

.v2-shock-text__sub {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(15px, 4vw, 17px);
  line-height: 1.85;
  color: var(--text);
}

.v2-shock-text--dark {
  background: #1a1530;
  color: #fff;
}

.v2-shock-text--dark .v2-shock-text__big,
.v2-shock-text--dark .v2-shock-text__sub {
  color: #fff;
}

/* ----- 「アメイジング！」ブロック ----- */
.v2-amazing {
  text-align: center;
  padding: 32px 20px;
  background:
    radial-gradient(circle at 50% 50%, #fffce0 0%, #fff5d0 60%, var(--bg) 100%);
  position: relative;
}

.v2-amazing::before,
.v2-amazing::after {
  content: '★';
  position: absolute;
  font-size: 32px;
  color: var(--yellow-pop);
  text-shadow: 0 0 8px rgba(255, 230, 0, 0.6), 0 0 2px rgba(255, 200, 0, 0.9);
  font-family: var(--ff-display) !important;
  pointer-events: none;
}

/* SP: タイトルが折り返さないよう padding/font 詰める + 星も外側に */
@media (max-width: 480px) {
  .v2-amazing { padding-left: 18px !important; padding-right: 18px !important; }
  .v2-amazing__title { font-size: 22px !important; white-space: nowrap; letter-spacing: -0.01em; }
  .v2-amazing::before,
  .v2-amazing::after { font-size: 22px; }
  .v2-amazing::before { top: -10px !important; left: 0 !important; }
  .v2-amazing::after { bottom: -10px !important; right: 0 !important; }
}

.v2-amazing::before {
  top: 12px;
  left: 16px;
  transform: rotate(-15deg);
}

.v2-amazing::after {
  bottom: 12px;
  right: 16px;
  transform: rotate(20deg);
}

.v2-amazing__title {
  font-family: 'RocknRoll One', var(--font-heading), sans-serif;
  font-weight: 900;
  font-size: clamp(28px, 7vw, 36px);
  color: var(--magenta);
  text-shadow: 3px 3px 0 #fff, 5px 5px 0 var(--yellow-marker);
  letter-spacing: 0.02em;
  line-height: 1.2;
  margin-bottom: 12px;
}

.v2-amazing__sub {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(15px, 4vw, 18px);
  color: var(--text);
  line-height: 1.8;
}

/* ----- pre-panel-text ----- */
.v2-pre-panel-text {
  text-align: center;
}

.v2-chapter {
  text-align: center;
  padding: 32px 16px !important;
  margin: 0 auto !important;
  max-width: none !important;
  position: relative;
  width: 100%;
}

.v2-chapter--1 {
  background:
    radial-gradient(circle at 10% 50%, var(--yellow-dot) 4px, transparent 5px) 0 0/40px 40px,
    radial-gradient(circle at 90% 50%, var(--yellow-dot) 4px, transparent 5px) 20px 20px/40px 40px,
    linear-gradient(180deg, var(--bg), var(--yellow-bg));
}

.v2-chapter--2 {
  background:
    repeating-linear-gradient(
      -45deg,
      #1a1530 0,
      #1a1530 20px,
      #251f3a 20px,
      #251f3a 40px
    );
  color: #fff;
  position: relative;
}

.v2-chapter--2::before,
.v2-chapter--2::after {
  content: '';
  position: absolute;
  width: 60px;
  height: 60px;
  background: var(--magenta);
  border-radius: 50%;
  filter: blur(40px);
  opacity: 0.6;
}
.v2-chapter--2::before { top: 20%; left: 20%; }
.v2-chapter--2::after { bottom: 20%; right: 20%; background: var(--yellow-pop); }

.v2-chapter--2 .v2-chapter__title,
.v2-chapter--2 .v2-chapter__num {
  color: #fff;
  position: relative;
  z-index: 2;
}

.v2-chapter--3 {
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 230, 0, 0.18), transparent 70%),
    linear-gradient(180deg, var(--yellow-bg), #fff5fa);
}

.v2-chapter__head {
  display: inline-block;
  position: relative;
}

.v2-chapter__num {
  display: inline-block;
  font-family: 'RocknRoll One', var(--font-heading), sans-serif;
  font-size: 14px;
  letter-spacing: 0.15em;
  color: #fff;
  background: var(--magenta);
  padding: 6px 22px;
  border-radius: 100px;
  border: 3px solid var(--text);
  margin-bottom: 14px;
  box-shadow: 3px 3px 0 var(--text);
  transform: rotate(-2deg);
}

.v2-chapter--2 .v2-chapter__num {
  background: var(--yellow-pop);
  color: var(--text);
  border-color: #fff;
  box-shadow: 3px 3px 0 #fff;
}

.v2-chapter__title {
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: clamp(20px, 5.2vw, 26px);
  color: var(--text);
  line-height: 1.4;
}

/* ----- ナレーションバナー（コマ間の煽り） ----- */
.v2-narration-banner {
  margin: 0 auto;
  max-width: 100%;
}

/* ----- Pricing 総額ウィジェット ----- */
.pricing__total {
  margin: 36px auto 0;
  max-width: 720px;
  padding: 28px 24px 24px;
  background: linear-gradient(135deg, #ffffff 0%, #fff5f8 100%);
  border: 2px solid #ffd6e4;
  border-radius: 24px;
  text-align: center;
  box-shadow: 0 8px 28px rgba(232, 40, 95, 0.10);
  position: relative;
  overflow: hidden;
}

.pricing__total::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -20%;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(255, 240, 68, 0.35) 0%, transparent 70%);
  pointer-events: none;
}

.pricing__total-eyebrow {
  font-family: var(--ff-display, 'Yusei Magic', sans-serif);
  font-size: 12px;
  letter-spacing: 0.22em;
  color: var(--c-primary, #e8285f);
  margin-bottom: 8px;
  position: relative;
}

.pricing__total-label {
  font-family: var(--ff-display, 'Yusei Magic', sans-serif);
  font-size: clamp(15px, 4vw, 18px);
  color: var(--c-text, #3d2817);
  margin: 0 0 14px;
  line-height: 1.6;
  position: relative;
}

.pricing__total-amount {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 10px;
  position: relative;
}

.pricing__total-number {
  font-family: var(--ff-display, 'Yusei Magic', sans-serif);
  font-weight: 900;
  font-size: clamp(40px, 11vw, 64px);
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.01em;
  line-height: 1;
  text-shadow: 0 4px 12px rgba(232, 40, 95, 0.18);
}

.pricing__total-unit {
  font-family: var(--ff-display, 'Yusei Magic', sans-serif);
  font-weight: 700;
  font-size: clamp(16px, 4.5vw, 22px);
  color: var(--c-primary, #e8285f);
}

.pricing__total-note {
  font-size: clamp(11px, 3vw, 13px);
  color: var(--c-text-light, #6b5645);
  line-height: 1.7;
  position: relative;
}

.pricing__total-update {
  display: inline-block;
  margin-top: 4px;
  font-size: 11px;
  opacity: 0.8;
}

/* ----- 実践者の声 LINEトーク画像 ----- */
.testimonial__talk {
  position: relative;
  margin: 0 0 var(--sp-m, 18px);
  padding: 6px 0 6px 18px;
  text-align: left;
}

.testimonial__talk::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 6px;
  background: linear-gradient(180deg, #ff8a3d 0%, #ffd166 100%);
  border-radius: 3px;
  box-shadow: 0 1px 4px rgba(255, 138, 61, 0.35);
}

.testimonial:nth-child(2) .testimonial__talk::before {
  background: linear-gradient(180deg, #e8285f 0%, #ff8ab0 100%);
  box-shadow: 0 1px 4px rgba(232, 40, 95, 0.30);
}

.testimonial:nth-child(3) .testimonial__talk::before {
  background: linear-gradient(180deg, #1ea672 0%, #6be0a5 100%);
  box-shadow: 0 1px 4px rgba(30, 166, 114, 0.30);
}

.testimonial:nth-child(4) .testimonial__talk::before {
  background: linear-gradient(180deg, #4a7bdb 0%, #87b7ff 100%);
  box-shadow: 0 1px 4px rgba(74, 123, 219, 0.30);
}

.testimonial__talk img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 360px;
  margin: 0;
}

@media (min-width: 1025px) {
  .testimonial__talk img {
    max-width: 100%;
  }
}

/* ----- LINEトーク 風スクショ（一撃報酬の実例 導入） ----- */
.line-talk {
  margin: var(--sp-l) auto var(--sp-m);
  max-width: 560px;
  width: 92%;
  padding: 0;
}

.line-talk img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 18px;
  box-shadow:
    0 10px 28px rgba(196, 0, 74, 0.15),
    0 2px 6px rgba(196, 0, 74, 0.10);
  border: 3px solid #fff;
  background: #fff;
}

.line-talk__caption {
  margin-top: 10px;
  text-align: center;
  font-family: var(--ff-display, 'Yusei Magic', 'Zen Maru Gothic', cursive);
  font-size: clamp(13px, 3.4vw, 15px);
  color: var(--c-primary, #e8285f);
  letter-spacing: 0.02em;
  line-height: 1.5;
}

@media (min-width: 1025px) {
  .line-talk {
    max-width: 640px;
  }
}

/* ============================================================
   A-5: HERO直後・合計理論値ブロック（前出しカウントアップ）
   ============================================================ */
.hero-total {
  position: relative;
  padding: clamp(48px, 9vw, 96px) 0;
  background:
    radial-gradient(circle at 18% 22%, rgba(255, 220, 0, 0.18) 0%, transparent 55%),
    radial-gradient(circle at 82% 78%, rgba(232, 40, 95, 0.12) 0%, transparent 55%),
    linear-gradient(180deg, #fff7fa 0%, #ffe9f1 100%);
  overflow: hidden;
}
.hero-total::before,
.hero-total::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(173, 216, 230, 0.55);
  pointer-events: none;
}
.hero-total::before { top: 14%; left: 8%; }
.hero-total::after  { bottom: 18%; right: 10%; width: 22px; height: 22px; }

.hero-total__inner {
  text-align: center;
  position: relative;
  z-index: 1;
}

.hero-total__eyebrow {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(11px, 2.6vw, 13px);
  letter-spacing: 0.22em;
  color: var(--c-primary, #e8285f);
  margin-bottom: 12px;
}

.hero-total__heading {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-weight: 700;
  font-size: clamp(18px, 4.2vw, 28px);
  line-height: 1.55;
  color: #4a2530;
  margin: 0 0 clamp(20px, 4vw, 32px);
}
.hero-total__heading-em {
  display: inline-block;
  background: linear-gradient(transparent 60%, #ffe066 60%);
  padding: 0 0.15em;
  color: #4a2530;
}

.hero-total__amount {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 4px;
  padding: clamp(18px, 4vw, 32px) clamp(24px, 6vw, 56px);
  background: #fff;
  border: 4px solid var(--c-primary, #e8285f);
  border-radius: 28px;
  box-shadow:
    0 14px 36px rgba(232, 40, 95, 0.20),
    0 2px 8px rgba(0, 0, 0, 0.04);
  margin-bottom: clamp(14px, 3vw, 22px);
  max-width: 100%;
}
.hero-total__yen {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(28px, 6vw, 44px);
  color: var(--c-primary, #e8285f);
  font-weight: 700;
}
.hero-total__number {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(40px, 11vw, 84px);
  font-weight: 800;
  color: var(--c-primary, #e8285f);
  letter-spacing: -0.01em;
  line-height: 1;
  text-shadow: 0 3px 0 rgba(196, 0, 74, 0.18);
}
.hero-total__unit {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-size: clamp(15px, 3.4vw, 22px);
  color: #4a2530;
  font-weight: 700;
  margin-left: 6px;
}

.hero-total__meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(12px, 3vw, 14px);
  color: #6b4554;
  margin-bottom: clamp(14px, 3vw, 20px);
}
.hero-total__sep {
  color: rgba(232, 40, 95, 0.55);
}

.hero-total__note {
  max-width: 640px;
  margin: 0 auto;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(11px, 2.8vw, 13px);
  line-height: 1.7;
  color: #6b4554;
}

@media (max-width: 480px) {
  .hero-total__amount {
    padding: 18px 20px;
    border-width: 3px;
    border-radius: 22px;
  }
}

/* ============================================================
   A-1: 価格表示（¥59,800・1期生残り10名・段階値上げ）
   ============================================================ */
.pricing__card {
  position: relative;
  overflow: visible !important;
}

/* 「3ヶ月返金保証」円形スタンプ（右上） */
.pricing__refund-stamp {
  position: absolute;
  top: -18px;
  right: -10px;
  z-index: 5;
  width: 96px;
  height: 96px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 50%;
  background: #fff;
  border: 4px dashed var(--c-primary, #e8285f);
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  font-size: 14px;
  line-height: 1.25;
  box-shadow: 0 6px 18px rgba(232, 40, 95, 0.20);
  transform: rotate(-12deg);
}
@media (max-width: 480px) {
  .pricing__refund-stamp {
    width: 76px;
    height: 76px;
    font-size: 12px;
    top: -12px;
    right: -4px;
    border-width: 3px;
  }
}

/* 1期生バッジ */
.pricing__cohort-badge {
  display: inline-block;
  margin: 14px auto 0;
  padding: 7px 18px;
  background: linear-gradient(135deg, #ffd84a 0%, #ffae00 100%);
  color: #5a3300;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  font-size: clamp(13px, 3vw, 15px);
  border-radius: 999px;
  box-shadow: 0 4px 12px rgba(255, 174, 0, 0.35);
  letter-spacing: 0.03em;
}

/* 価格ブロック */
.pricing__price-block {
  text-align: center;
  margin-top: 20px;
}
.pricing__price-old {
  font-family: var(--ff-body, system-ui);
  font-size: clamp(13px, 3vw, 15px);
  color: rgba(74, 37, 48, 0.65);
}
.pricing__price-old s {
  text-decoration-color: rgba(232, 40, 95, 0.7);
  text-decoration-thickness: 2px;
}
.pricing__price-arrow {
  font-size: clamp(18px, 4vw, 22px);
  color: var(--c-primary, #e8285f);
  margin: 2px 0;
  font-weight: 700;
}
.pricing__price-main {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 800;
  line-height: 1;
  text-shadow: 0 3px 0 rgba(196, 0, 74, 0.18);
}
.pricing__price-yen {
  font-size: clamp(28px, 6vw, 40px);
}
.pricing__price-num {
  font-size: clamp(48px, 12vw, 86px);
  letter-spacing: -0.02em;
}
.pricing__price-tax {
  font-family: var(--ff-body, system-ui);
  font-size: clamp(12px, 2.8vw, 14px);
  color: #6b4554;
  margin-top: 6px;
  font-weight: 600;
}

/* 価格メリットリスト */
.pricing__price-perks {
  list-style: none;
  padding: 0;
  margin: 18px auto 14px;
  max-width: 360px;
  display: grid;
  gap: 8px;
  text-align: left;
}
.pricing__price-perks li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(13px, 3vw, 14px);
  color: #4a2530;
  font-weight: 600;
}
.pricing__price-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  background: var(--c-primary, #e8285f);
  color: #fff;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
}

/* 段階値上げ予告メモ */
.pricing__cohort-note {
  font-family: var(--ff-body, system-ui);
  font-size: clamp(11px, 2.6vw, 12px);
  color: rgba(74, 37, 48, 0.7);
  line-height: 1.7;
  text-align: center;
  margin: 8px auto 0;
  max-width: 480px;
}

/* ★中核オファー特典 */
.pricing__feature--star {
  background: linear-gradient(180deg, #fff 0%, #fff7fa 100%);
  border: 2px solid rgba(232, 40, 95, 0.20);
  border-radius: 14px;
  padding: 14px 14px !important;
  align-items: flex-start !important;
}
.pricing__feature-icon--star {
  background: linear-gradient(135deg, #ffd84a 0%, #ffae00 100%) !important;
  color: #5a3300 !important;
  font-size: 16px !important;
  font-weight: 800;
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0;
}
.pricing__feature--star strong {
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(14px, 3.4vw, 16px);
  line-height: 1.5;
}
.pricing__feature-sub {
  display: block;
  margin-top: 4px;
  font-size: clamp(12px, 2.8vw, 13px);
  color: #6b4554;
  font-weight: 500;
  line-height: 1.6;
}

/* 返金保証独立ブロック */
.pricing__refund {
  max-width: 720px;
  margin: clamp(24px, 5vw, 40px) auto 0;
  padding: clamp(24px, 5vw, 40px) clamp(20px, 4vw, 36px);
  background: #fff;
  border: 3px solid var(--c-primary, #e8285f);
  border-radius: 24px;
  box-shadow: 0 12px 32px rgba(232, 40, 95, 0.12);
  text-align: center;
}
.pricing__refund-head {
  margin-bottom: 18px;
}
.pricing__refund-eyebrow {
  display: inline-block;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(11px, 2.6vw, 13px);
  letter-spacing: 0.18em;
  color: var(--c-primary, #e8285f);
  margin-bottom: 8px;
}
.pricing__refund-title {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-size: clamp(20px, 4.6vw, 28px);
  color: #4a2530;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}
.pricing__refund-lead {
  font-family: var(--ff-body, system-ui);
  font-size: clamp(14px, 3.4vw, 16px);
  line-height: 1.85;
  color: #4a2530;
  margin: 0 0 18px;
}
.pricing__refund-lead strong {
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 800;
}
.pricing__refund-conditions {
  text-align: left;
  background: #fff7fa;
  border-radius: 16px;
  padding: 18px 20px;
  margin: 0 auto;
  max-width: 580px;
}
.pricing__refund-conditions-title {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  color: var(--c-primary, #e8285f);
  margin-bottom: 8px;
  font-size: clamp(14px, 3.4vw, 16px);
}
.pricing__refund-conditions ul {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  display: grid;
  gap: 6px;
}
.pricing__refund-conditions li {
  position: relative;
  padding-left: 16px;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(12px, 3vw, 14px);
  line-height: 1.7;
  color: #4a2530;
}
.pricing__refund-conditions li::before {
  content: "・";
  position: absolute;
  left: 0;
  color: var(--c-primary, #e8285f);
}
.pricing__refund-link-note {
  font-size: clamp(12px, 2.8vw, 13px);
  color: #6b4554;
  margin: 8px 0 0;
}
.pricing__refund-link-note a {
  color: var(--c-primary, #e8285f);
  text-decoration: underline;
}
.pricing__refund-foot {
  font-size: clamp(11px, 2.6vw, 12px);
  color: rgba(74, 37, 48, 0.7);
  line-height: 1.7;
  margin: 10px 0 0;
}
.pricing__refund-tagline {
  margin: 18px 0 0;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(15px, 3.8vw, 20px);
  color: var(--c-primary, #e8285f);
  font-weight: 700;
  letter-spacing: 0.03em;
}

/* ============================================================
   A-2-2: 申し込みサポート独立ブロック
   ============================================================ */
.support-block {
  position: relative;
  padding: clamp(56px, 10vw, 96px) 0;
  background:
    radial-gradient(circle at 80% 20%, rgba(255, 220, 0, 0.16) 0%, transparent 50%),
    linear-gradient(180deg, #fff 0%, #fff7fa 100%);
  overflow: hidden;
}
.support-block__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto clamp(28px, 5vw, 44px);
}
.support-block__eyebrow {
  display: inline-block;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(11px, 2.6vw, 13px);
  letter-spacing: 0.22em;
  color: var(--c-primary, #e8285f);
  margin-bottom: 12px;
}
.support-block__title {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-weight: 700;
  font-size: clamp(20px, 4.6vw, 30px);
  line-height: 1.55;
  color: #4a2530;
  margin: 0 0 18px;
}
.support-block__title-sub {
  display: inline-block;
  font-size: 0.7em;
  color: rgba(74, 37, 48, 0.7);
  margin-top: 4px;
}
.support-block__lead {
  font-family: var(--ff-body, system-ui);
  font-size: clamp(13px, 3.2vw, 15px);
  line-height: 1.85;
  color: #4a2530;
  margin: 0;
}

.support-block__steps {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 1080px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(14px, 2.5vw, 20px);
}
@media (max-width: 768px) {
  .support-block__steps {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 480px) {
  .support-block__steps {
    grid-template-columns: 1fr;
    max-width: 420px;
  }
}

.support-block__step {
  position: relative;
  background: #fff;
  border: 2px solid rgba(232, 40, 95, 0.20);
  border-radius: 18px;
  padding: clamp(20px, 4vw, 26px) clamp(16px, 3vw, 22px);
  box-shadow: 0 8px 22px rgba(232, 40, 95, 0.08);
  text-align: left;
  transition: transform 0.3s var(--ease-out, ease), box-shadow 0.3s ease;
}
.support-block__step:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 32px rgba(232, 40, 95, 0.16);
}
.support-block__step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%);
  color: #fff;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 800;
  font-size: 18px;
  border-radius: 50%;
  box-shadow: 0 4px 10px rgba(232, 40, 95, 0.30);
  margin-bottom: 12px;
}
.support-block__step-title {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-weight: 700;
  font-size: clamp(15px, 3.6vw, 17px);
  color: #4a2530;
  margin: 0 0 8px;
  line-height: 1.5;
}
.support-block__step-desc {
  font-family: var(--ff-body, system-ui);
  font-size: clamp(12px, 3vw, 14px);
  line-height: 1.7;
  color: #6b4554;
  margin: 0;
}

.support-block__tagline {
  text-align: center;
  margin: clamp(28px, 5vw, 44px) 0 0;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(17px, 4.2vw, 24px);
  color: var(--c-primary, #e8285f);
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 0.02em;
}

/* ============================================================
   B-6: コミュニティブロック
   ============================================================ */
.community-block {
  position: relative;
  padding: clamp(56px, 10vw, 96px) 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(232, 40, 95, 0.08) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(255, 220, 0, 0.14) 0%, transparent 50%),
    linear-gradient(180deg, #ffe9f1 0%, #fff7fa 100%);
  overflow: hidden;
}
.community-block__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto clamp(28px, 5vw, 44px);
}
.community-block__eyebrow {
  display: inline-block;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(11px, 2.6vw, 13px);
  letter-spacing: 0.22em;
  color: var(--c-primary, #e8285f);
  margin-bottom: 12px;
}
.community-block__title {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-weight: 700;
  font-size: clamp(22px, 5vw, 32px);
  color: #4a2530;
  margin: 0 0 18px;
  line-height: 1.55;
}
.community-block__lead {
  font-family: var(--ff-body, system-ui);
  font-size: clamp(13px, 3.2vw, 15px);
  line-height: 1.85;
  color: #4a2530;
  margin: 0;
}
.community-block__lead strong {
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 800;
  font-size: 1.12em;
}

.community-block__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(16px, 3vw, 24px);
  max-width: 1080px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .community-block__grid {
    grid-template-columns: 1fr;
  }
}

.community-block__panel {
  background: #fff;
  border: 2px solid rgba(232, 40, 95, 0.20);
  border-radius: 22px;
  padding: clamp(22px, 4vw, 32px) clamp(20px, 3.5vw, 28px);
  box-shadow: 0 10px 28px rgba(232, 40, 95, 0.10);
}
.community-block__panel--target {
  background: linear-gradient(180deg, #fff 0%, #fff7fa 100%);
}

.community-block__panel-title {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 18px;
  padding: 0 0 14px;
  border-bottom: 2px dashed rgba(232, 40, 95, 0.25);
}
.community-block__panel-title--target {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  color: var(--c-primary, #e8285f);
  font-size: clamp(15px, 3.6vw, 18px);
  border-bottom-style: solid;
  display: block;
}

.community-block__tag {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 999px;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  font-size: clamp(12px, 2.8vw, 14px);
  letter-spacing: 0.04em;
}
.community-block__tag--exclusive {
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%);
  color: #fff;
  box-shadow: 0 4px 10px rgba(232, 40, 95, 0.30);
}
.community-block__tag--trend {
  background: linear-gradient(135deg, #ffd84a 0%, #ffae00 100%);
  color: #5a3300;
  box-shadow: 0 4px 10px rgba(255, 174, 0, 0.30);
}

.community-block__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 14px;
}
.community-block__list > li {
  position: relative;
  padding-left: 22px;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(13px, 3.2vw, 15px);
  line-height: 1.8;
  color: #4a2530;
}
.community-block__list > li::before {
  content: "▶";
  position: absolute;
  left: 0;
  top: 2px;
  color: var(--c-primary, #e8285f);
  font-size: 11px;
}
.community-block__list strong {
  color: #4a2530;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
}
.community-block__sublist {
  list-style: none;
  padding: 8px 0 0 0;
  margin: 4px 0 0;
  display: grid;
  gap: 4px;
}
.community-block__sublist li {
  position: relative;
  padding-left: 14px;
  font-size: clamp(12px, 2.8vw, 13px);
  color: #6b4554;
  line-height: 1.6;
  font-weight: 500;
}
.community-block__sublist li::before {
  content: "・";
  position: absolute;
  left: 0;
  color: rgba(232, 40, 95, 0.6);
}

.community-block__target-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
}
.community-block__target-list li {
  position: relative;
  padding-left: 22px;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(13px, 3.2vw, 14px);
  line-height: 1.7;
  color: #4a2530;
}
.community-block__target-list li::before {
  content: "♥";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--c-primary, #e8285f);
  font-size: 14px;
}
.community-block__target-list strong {
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
}

.community-block__disclaimer {
  text-align: center;
  margin: clamp(20px, 4vw, 32px) auto 0;
  max-width: 720px;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(11px, 2.6vw, 12px);
  line-height: 1.7;
  color: rgba(74, 37, 48, 0.7);
}

/* ============================================================
   A-3: 口コミ仮枠（画像差し込み待ち）
   ============================================================ */
.testimonial__talk--placeholder {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 200px;
  padding: clamp(20px, 4vw, 28px) clamp(18px, 3.5vw, 26px);
  background: linear-gradient(180deg, #fff7fa 0%, #ffe9f1 100%) !important;
  border: 2px dashed rgba(232, 40, 95, 0.40) !important;
  border-radius: 18px !important;
  box-shadow: none !important;
}
.testimonial__placeholder-note {
  position: absolute;
  top: 8px;
  right: 12px;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: rgba(232, 40, 95, 0.7);
  background: rgba(255, 255, 255, 0.85);
  padding: 3px 10px;
  border-radius: 999px;
}
.testimonial__placeholder-text {
  margin: 18px 0 0;
  padding: 0;
  font-family: var(--ff-body, system-ui);
  font-size: clamp(13px, 3.2vw, 14.5px);
  line-height: 1.85;
  color: #4a2530;
  font-style: normal;
  border: none;
  font-weight: 500;
}
.testimonial__pending {
  font-size: 0.85em;
  color: rgba(232, 40, 95, 0.75);
  font-style: italic;
}

/* ============================================================
   B-2: 比較表（他のポイ活サロンとの違い）
   ============================================================ */
.vs-table {
  position: relative;
  padding: clamp(56px, 10vw, 96px) 0;
  background:
    radial-gradient(circle at 70% 30%, rgba(255, 220, 0, 0.14) 0%, transparent 50%),
    linear-gradient(180deg, #fff 0%, #fff7fa 100%);
}
.vs-table__head {
  text-align: center;
  margin-bottom: clamp(28px, 5vw, 40px);
}
.vs-table__eyebrow {
  display: inline-block;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(11px, 2.6vw, 13px);
  letter-spacing: 0.22em;
  color: var(--c-primary, #e8285f);
  margin-bottom: 10px;
}
.vs-table__title {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-weight: 700;
  font-size: clamp(22px, 5vw, 32px);
  color: #4a2530;
  margin: 0;
  line-height: 1.55;
}

.vs-table__wrap {
  max-width: 880px;
  margin: 0 auto;
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 14px 40px rgba(232, 40, 95, 0.14);
  overflow: hidden;
  border: 2px solid rgba(232, 40, 95, 0.18);
}
.vs-table__table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--ff-body, system-ui);
}
.vs-table__th {
  padding: clamp(14px, 3vw, 22px) clamp(8px, 2vw, 18px);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  font-size: clamp(13px, 3vw, 16px);
  text-align: center;
  vertical-align: middle;
  border-bottom: 2px solid rgba(232, 40, 95, 0.12);
}
.vs-table__th--label {
  background: #fff7fa;
  color: #6b4554;
  width: 22%;
  font-size: clamp(12px, 2.8vw, 14px);
}
.vs-table__th--other {
  background: #f5f5f7;
  color: #6b4554;
  width: 38%;
}
.vs-table__th--us {
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%);
  color: #fff;
  width: 40%;
  position: relative;
  font-size: clamp(13px, 3.2vw, 17px);
  text-shadow: 0 2px 4px rgba(196, 0, 74, 0.3);
}
.vs-table__th-crown {
  display: inline-block;
  font-size: 1.2em;
  margin-right: 4px;
  vertical-align: -0.1em;
}
.vs-table__row-label {
  padding: clamp(12px, 2.5vw, 18px) clamp(8px, 2vw, 16px);
  background: #fff7fa;
  color: #4a2530;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  font-size: clamp(13px, 3vw, 15px);
  text-align: center;
  vertical-align: middle;
  border-bottom: 1px solid rgba(232, 40, 95, 0.08);
}
.vs-table__cell {
  padding: clamp(14px, 3vw, 22px) clamp(10px, 2vw, 18px);
  font-size: clamp(12px, 2.8vw, 14.5px);
  line-height: 1.65;
  color: #4a2530;
  text-align: center;
  vertical-align: middle;
  border-bottom: 1px solid rgba(232, 40, 95, 0.08);
}
.vs-table__cell small {
  display: inline-block;
  margin-top: 2px;
  font-size: 0.82em;
  color: rgba(74, 37, 48, 0.65);
}
.vs-table__cell--other {
  background: #fafafb;
  color: rgba(74, 37, 48, 0.75);
}
.vs-table__cell--us {
  background: rgba(255, 218, 230, 0.55);
  color: #4a2530;
  font-weight: 600;
  position: relative;
}
.vs-table__cell--us strong {
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: 1.08em;
  font-weight: 800;
}
.vs-table__cell--us small {
  color: rgba(196, 0, 74, 0.7);
}
.vs-table__table tr:last-child .vs-table__cell,
.vs-table__table tr:last-child .vs-table__row-label {
  border-bottom: none;
}

@media (max-width: 480px) {
  .vs-table__wrap {
    border-radius: 16px;
  }
  .vs-table__th,
  .vs-table__cell,
  .vs-table__row-label {
    padding: 12px 6px;
    font-size: 12px;
  }
  .vs-table__th { font-size: 11.5px; }
  .vs-table__cell--us strong { font-size: 1em; }
}

/* ============================================================
   B-1: 監修者プロフィール（完全非属人AIキャラ・仮枠）
   ============================================================ */
.brand-host {
  position: relative;
  padding: clamp(56px, 10vw, 96px) 0;
  background:
    radial-gradient(circle at 30% 80%, rgba(232, 40, 95, 0.08) 0%, transparent 50%),
    linear-gradient(180deg, #fff7fa 0%, #fff 100%);
}
.brand-host__head {
  text-align: center;
  margin-bottom: clamp(28px, 5vw, 40px);
}
.brand-host__eyebrow {
  display: inline-block;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(11px, 2.6vw, 13px);
  letter-spacing: 0.22em;
  color: var(--c-primary, #e8285f);
  margin-bottom: 10px;
}
.brand-host__title {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  font-weight: 700;
  font-size: clamp(22px, 5vw, 32px);
  color: #4a2530;
  margin: 0;
  line-height: 1.55;
}

.brand-host__card {
  display: grid;
  grid-template-columns: minmax(200px, 280px) 1fr;
  gap: clamp(20px, 4vw, 40px);
  align-items: center;
  max-width: 880px;
  margin: 0 auto;
  background: #fff;
  border: 2px solid rgba(232, 40, 95, 0.18);
  border-radius: 24px;
  padding: clamp(24px, 5vw, 40px);
  box-shadow: 0 14px 36px rgba(232, 40, 95, 0.12);
}
@media (max-width: 640px) {
  .brand-host__card {
    grid-template-columns: 1fr;
    text-align: center;
  }
}

.brand-host__avatar {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: linear-gradient(135deg, #ffe066 0%, #ffd54a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 24px rgba(255, 174, 0, 0.30);
  border: 4px solid #fff;
  position: relative;
  overflow: hidden;
}
.brand-host__avatar-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  color: #5a3300;
  text-align: center;
}
.brand-host__avatar-icon {
  font-size: clamp(48px, 12vw, 72px);
  line-height: 1;
}
.brand-host__avatar-note {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(11px, 2.6vw, 13px);
  line-height: 1.4;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.brand-host__avatar[data-pending-image="true"]::after {
  content: "PLACEHOLDER";
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: rgba(90, 51, 0, 0.6);
  background: rgba(255, 255, 255, 0.7);
  padding: 2px 8px;
  border-radius: 999px;
}

.brand-host__body {
  font-family: var(--ff-body, system-ui);
}
.brand-host__name-row,
.brand-host__title-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 6px;
  font-size: clamp(13px, 3vw, 15px);
}
@media (max-width: 640px) {
  .brand-host__name-row,
  .brand-host__title-row {
    justify-content: center;
  }
}
.brand-host__name-label,
.brand-host__title-label {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: rgba(232, 40, 95, 0.7);
  flex-shrink: 0;
  width: 56px;
}
.brand-host__name {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(17px, 4vw, 22px);
  font-weight: 800;
  color: var(--c-primary, #e8285f);
  letter-spacing: 0.05em;
}
.brand-host__name small {
  font-size: 0.6em;
  font-weight: 600;
  color: rgba(232, 40, 95, 0.6);
  margin-left: 4px;
}
.brand-host__title-text {
  font-family: var(--ff-heading, 'Zen Maru Gothic', sans-serif);
  color: #4a2530;
  font-weight: 700;
  font-size: clamp(13px, 3vw, 15px);
}

.brand-host__bio {
  margin: clamp(16px, 3vw, 22px) 0;
  font-size: clamp(13px, 3.2vw, 15px);
  line-height: 1.95;
  color: #4a2530;
}
.brand-host__bio strong {
  color: var(--c-primary, #e8285f);
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 800;
}

.brand-host__facts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px 16px;
  margin: 0;
  padding: 16px 18px;
  background: #fff7fa;
  border-radius: 14px;
  border-left: 4px solid var(--c-primary, #e8285f);
}
.brand-host__fact {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin: 0;
  font-size: clamp(12px, 2.8vw, 14px);
}
.brand-host__fact dt {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  color: rgba(232, 40, 95, 0.85);
  flex-shrink: 0;
  font-size: 0.92em;
}
.brand-host__fact dd {
  margin: 0;
  color: #4a2530;
  font-weight: 600;
}
.brand-host__fact dd small {
  font-size: 0.78em;
  font-weight: 500;
  color: rgba(74, 37, 48, 0.65);
  margin-left: 3px;
}

/* ============================================================
   返金保証 条件3点版（更新コピー）
   ============================================================ */
.pricing__refund-title-sub {
  display: inline-block;
  margin-top: 4px;
  font-size: 0.7em;
  color: rgba(74, 37, 48, 0.75);
  font-weight: 700;
}
.pricing__refund-conditions-title small {
  margin-left: 8px;
  font-size: 0.78em;
  font-weight: 600;
  color: rgba(74, 37, 48, 0.7);
  font-family: var(--ff-body, system-ui);
}

.pricing__refund-clauses {
  list-style: none;
  padding: 0;
  margin: 0 0 14px;
  display: grid;
  gap: 12px;
}
.pricing__refund-clause {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 12px;
  padding: 14px 14px;
  background: #fff;
  border: 2px solid rgba(232, 40, 95, 0.18);
  border-radius: 14px;
  align-items: flex-start;
}
.pricing__refund-clause-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: linear-gradient(135deg, #ff5e8e 0%, #e8285f 100%);
  color: #fff;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 800;
  font-size: 18px;
  border-radius: 50%;
  box-shadow: 0 3px 8px rgba(232, 40, 95, 0.25);
  flex-shrink: 0;
}
.pricing__refund-clause-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: var(--ff-body, system-ui);
}
.pricing__refund-clause-body strong {
  color: #4a2530;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(13px, 3.2vw, 15px);
  line-height: 1.55;
  font-weight: 800;
}
.pricing__refund-clause-reason {
  display: inline-block;
  padding: 6px 10px;
  background: rgba(255, 218, 0, 0.18);
  border-radius: 8px;
  font-size: clamp(11px, 2.8vw, 13px);
  line-height: 1.6;
  color: #6b4554;
  border-left: 3px solid #ffae00;
}

.pricing__refund-extras {
  margin: 14px 0 0;
  padding: 12px 14px;
  background: #fff7fa;
  border-radius: 10px;
  border-left: 3px solid var(--c-primary, #e8285f);
}
.pricing__refund-extras-title {
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-weight: 700;
  color: var(--c-primary, #e8285f);
  margin-bottom: 6px;
  font-size: clamp(12px, 3vw, 14px);
}
.pricing__refund-extras ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 4px;
}
.pricing__refund-extras li {
  position: relative;
  padding-left: 14px;
  font-size: clamp(11px, 2.8vw, 13px);
  line-height: 1.7;
  color: #4a2530;
}
.pricing__refund-extras li::before {
  content: "・";
  position: absolute;
  left: 0;
  color: var(--c-primary, #e8285f);
}

@media (max-width: 480px) {
  .pricing__refund-clause {
    grid-template-columns: 28px 1fr;
    gap: 10px;
    padding: 12px 12px;
  }
  .pricing__refund-clause-num {
    width: 28px;
    height: 28px;
    font-size: 15px;
  }
}

/* ============================================================
   A-4-1: COMPARE 会員エリア実画面プレビュー
   ============================================================ */
.compare__preview {
  margin: clamp(28px, 5vw, 44px) auto 0;
  max-width: 760px;
  padding: clamp(14px, 3vw, 22px);
  background: #fff;
  border: 3px dashed rgba(232, 40, 95, 0.30);
  border-radius: 22px;
  box-shadow: 0 14px 36px rgba(232, 40, 95, 0.10);
  text-align: center;
}
.compare__preview img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 14px;
  border: 2px solid rgba(232, 40, 95, 0.10);
  background: #fff;
  margin: 0 auto;
  max-width: 560px;
}
@media (max-width: 640px) {
  .compare__preview img {
    max-width: 320px;
  }
}
.compare__preview-caption {
  margin: clamp(14px, 3vw, 18px) 0 0;
  font-family: var(--ff-display, 'Yusei Magic', cursive);
  font-size: clamp(12px, 3vw, 14.5px);
  line-height: 1.85;
  color: #4a2530;
  letter-spacing: 0.02em;
}
.compare__preview-caption strong {
  color: var(--c-primary, #e8285f);
  background: linear-gradient(transparent 60%, rgba(255, 218, 0, 0.5) 60%);
  padding: 0 0.1em;
  font-weight: 700;
}
.compare__preview-arrow {
  display: inline-block;
  font-size: 1.1em;
  color: var(--c-primary, #e8285f);
  font-weight: 700;
  margin-right: 4px;
}

/* ============================================================
   A-6: HERO下統計 横長クリエ画像
   ============================================================ */
.hero__stats--image {
  display: block !important;
  margin-top: clamp(16px, 3.5vw, 28px) !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  text-align: center;
}
.hero__stats--image img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 720px;
  margin: 0 auto;
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(232, 40, 95, 0.14);
}
@media (max-width: 480px) {
  .hero__stats--image img {
    max-width: 100%;
    border-radius: 12px;
  }
}
