﻿body { min-height: 100vh; display: flex; flex-direction: column; }
  .pricing-page { max-width: 960px; margin: 0 auto; padding: 48px 20px 64px; flex: 1; }
  .pricing-page-header { text-align: center; margin-bottom: 48px; }
  .pricing-page-header .logo-link { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; margin-bottom: 24px; }
  .pricing-page-header .logo-link img { width: 36px; height: 36px; }
  .pricing-page-header .logo-link span { font-size: 1.2rem; font-weight: 700; color: var(--gold); }
  .pricing-page-header h1 { font-size: 2.2rem; color: var(--text); margin: 0 0 12px; }
  .pricing-page-header p { color: var(--text-dim); font-size: 1.05rem; max-width: 540px; margin: 0 auto; }

  .pricing-section { margin-bottom: 56px; }
  .pricing-section-title { text-align: center; font-size: 0.85rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); margin-bottom: 24px; }

  .pricing-page .pricing-grid--2col { grid-template-columns: repeat(2, 1fr); gap: 24px; display: grid; }
  @media (max-width: 600px) { .pricing-page .pricing-grid--2col { grid-template-columns: 1fr; } }

  .pricing-page .pricing-card { background: var(--bg3); border: 2px solid var(--border); border-radius: 12px; padding: 32px 28px; display: flex; flex-direction: column; position: relative; transition: border-color 0.2s, transform 0.2s; }
  .pricing-page .pricing-card:hover { border-color: var(--gold-dim); transform: translateY(-2px); }
  .pricing-page .pricing-card.featured { border-color: var(--gold); background: linear-gradient(135deg, rgba(201,168,76,0.08) 0%, var(--bg3) 100%); }
  .pricing-page .pricing-card.featured-pro { border-color: var(--accent); background: linear-gradient(135deg, rgba(74,130,240,0.08) 0%, var(--bg3) 100%); }
  .pricing-page .tier-badge-label { position: absolute; top: -1px; right: 16px; background: var(--gold); color: #0a0a0f; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 3px 10px; border-radius: 0 0 6px 6px; }
  .pricing-page .tier-badge-label.pro { background: var(--accent); }
  .pricing-page .tier-name { font-size: 1.3rem; font-weight: 700; color: var(--gold); margin-bottom: 8px; margin-top: 8px; }
  .pricing-page .tier-name.pro { color: var(--accent); }
  .pricing-page .tier-price { font-size: 2.4rem; font-weight: 700; color: var(--text); margin-bottom: 4px; }
  .pricing-page .tier-price .currency { font-size: 1.2rem; font-weight: 400; color: var(--text-dim); }
  .pricing-page .tier-billing { font-size: 0.8rem; color: var(--text-dim); margin-bottom: 20px; }
  .pricing-page .tier-features { flex: 1; list-style: none; margin: 0 0 24px; padding: 0; }
  .pricing-page .tier-features li { padding: 7px 0; font-size: 0.9rem; color: var(--text); display: flex; align-items: flex-start; gap: 8px; }
  .pricing-page .tier-features li::before { content: '✓'; color: var(--accent2); font-weight: 700; flex-shrink: 0; }
  .pricing-page .tier-features li.disabled { color: var(--text-dim); opacity: 0.5; }
  .pricing-page .tier-features li.disabled::before { content: '–'; color: var(--text-dim); }
  .pricing-page .tier-cta { width: 100%; padding: 12px; font-size: 0.95rem; border-radius: 8px; border: none; cursor: pointer; font-weight: 700; transition: opacity 0.15s; }
  .pricing-page .tier-cta:hover { opacity: 0.9; }
  .pricing-page .tier-cta.primary { background: var(--gold); color: #0a0a0f; }
  .pricing-page .tier-cta.secondary { background: transparent; border: 2px solid var(--border); color: var(--text-dim); }
  .pricing-page .tier-cta.accent { background: var(--color-blue-700, #2a5fc8); color: #fff; }  /* #2a5fc8 on #fff = 5.87:1 (WCAG AA) — --accent #5b8af0 only gave 3.31:1 */

  .addon-section { text-align: center; margin: 48px 0; }
  .addon-section h3 { color: var(--text); font-size: 1.2rem; margin-bottom: 8px; }
  .addon-section p { color: var(--text-dim); font-size: 0.9rem; margin-bottom: 24px; }
  .addon-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
  @media (max-width: 700px) { .addon-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 400px) { .addon-grid { grid-template-columns: 1fr; } }
  .addon-card { background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; padding: 20px 16px; text-align: center; }
  .addon-card .addon-name { font-weight: 700; color: var(--text); font-size: 0.9rem; margin-bottom: 4px; }
  .addon-card .addon-desc { font-size: 0.78rem; color: var(--text-dim); margin-bottom: 12px; }
  .addon-card .addon-price { font-size: 1.3rem; font-weight: 700; color: var(--gold); }

  .faq-section { max-width: 640px; margin: 0 auto 48px; }
  .faq-section h3 { text-align: center; font-size: 1.2rem; color: var(--text); margin-bottom: 24px; }
  .faq-item { border-bottom: 1px solid var(--border); padding: 16px 0; }
  .faq-item summary { cursor: pointer; font-weight: 600; font-size: 0.95rem; color: var(--text); list-style: none; display: flex; align-items: center; gap: 8px; }
  .faq-item summary::before { content: '+'; color: var(--gold); font-weight: 700; font-size: 1.1rem; }
  .faq-item[open] summary::before { content: '−'; }
  .faq-item p { color: var(--text-dim); font-size: 0.9rem; line-height: 1.6; margin: 8px 0 0; padding-left: 20px; }

  .pricing-footer { text-align: center; padding: 32px 20px; border-top: 1px solid var(--border); }
  .pricing-footer a { color: var(--gold); text-decoration: none; }
  .pricing-footer a:hover { text-decoration: underline; }
  .pricing-footer p { color: var(--text-dim); font-size: 0.8rem; margin: 8px 0 0; }

  /* GTM-BL-14: Social proof strip */
  .social-proof-strip { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 12px 24px; padding: 14px 20px; background: rgba(201,168,76,0.06); border: 1px solid rgba(201,168,76,0.18); border-radius: 10px; margin-bottom: 40px; font-size: 0.875rem; color: var(--text-dim); }
  .social-proof-strip-item { display: flex; align-items: center; gap: 6px; }
  .proof-icon { font-size: 1rem; }
  .proof-divider { color: var(--border); display: none; }
  @media (min-width: 640px) { .proof-divider { display: inline; } }

  /* Phase B — Tier Arc Subtitles */
  .tier-arc-sub { font-size: 0.78rem; font-style: italic; color: var(--text-muted, #b3aec8); margin: 2px 0 10px; letter-spacing: 0.02em; }

  /* Phase B — Journey Arc */
  .journey-arc { display: flex; align-items: flex-start; justify-content: center; gap: 0; padding: 28px 20px 40px; }
  .arc-node { display: flex; flex-direction: column; align-items: center; gap: 8px; flex: 0 0 auto; width: 140px; text-align: center; }
  .arc-dot { width: 14px; height: 14px; border-radius: 50%; background: var(--gold); opacity: 0.44; flex-shrink: 0; }
  .arc-dot.gift-dot { opacity: 0.72; }
  .arc-dot.transcendent-dot { opacity: 1; box-shadow: 0 0 8px rgba(201,168,76,0.5); }
  .arc-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--gold); }
  .arc-desc { font-size: 0.8rem; color: var(--text-dim, #d8d5e8); line-height: 1.4; }
  .arc-line { flex: 1; height: 1px; background: var(--border, rgba(255,255,255,0.1)); margin-top: 7px; min-width: 20px; }

  /* Phase B — Deferral CTA */
  .deferral-cta { margin: 0 0 48px; padding: 28px 32px; background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: 14px; text-align: center; }
  .deferral-cta p { color: var(--text-dim); font-size: 0.95rem; line-height: 1.7; margin: 0 0 14px; max-width: 540px; margin-left: auto; margin-right: auto; }
  .deferral-cta a { color: var(--gold); text-decoration: none; font-weight: 600; }
  .deferral-cta a:hover { text-decoration: underline; }
