/* ═══════════════════════════════════════════════════════
   landing.css v2 — 吉娃 AI 落地頁設計系統（大破大立版）
   全部用 #page-home 開頭確保優先級
   關鍵排版用 !important 徹底覆蓋 inline style
   ═══════════════════════════════════════════════════════ */

/* ── 0. 本頁顏色變數 ── */
#page-home {
  --lp-bright: #eeeef2;
  --lp-body:   rgba(238,238,242,.88);
  --lp-muted:  rgba(238,238,242,.55);
  --lp-gold:   #e8c55a;
}

/* ── 1. 全頁段落：左對齊、最小 15px ── */
#page-home p {
  text-align: left !important;
  font-size: 15px !important;
  line-height: 1.9 !important;
  color: var(--lp-body);
}

/* ── 2. 但 funnel-copy（區塊說明短段落）維持置中 ── */
#page-home .funnel-copy {
  text-align: center !important;
  font-size: 15px !important;
  line-height: 1.9 !important;
  max-width: 760px;
  margin: 0 auto 22px;
  color: var(--lp-body);
}

/* ── 3. Kicker 置中小標籤 ── */
#page-home .funnel-kicker {
  font-size: 12px !important;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--lp-gold) !important;
  font-weight: 900;
  margin-bottom: 14px;
  display: block;
  text-align: center !important;
}

/* ── 4. 區塊大標題（H1 等級，全頁統一） ── */
#page-home .funnel-title,
#page-home .lp-h2,
#page-home .vsl-audience-title {
  font-size: clamp(26px,4vw,38px) !important;
  font-weight: 950 !important;
  line-height: 1.22 !important;
  margin: 0 0 16px !important;
  text-align: center !important;
}
#page-home .funnel-title,
#page-home .lp-h2.white { color: var(--lp-bright) !important; }
#page-home .funnel-title.gold,
#page-home .lp-h2.gold,
#page-home .vsl-audience-title { color: var(--lp-gold) !important; }

/* ── 5. 欄位主標（Solutions A/B） ── */
#page-home .column-title,
#page-home .column-title-stacked {
  font-size: clamp(20px,2.8vw,26px) !important;
  font-weight: 900 !important;
  color: var(--lp-bright) !important;
  margin-bottom: 8px !important;
  line-height: 1.3 !important;
  text-align: left !important;
}
#page-home .column-subtitle {
  font-size: 15px !important;
  color: var(--lp-muted) !important;
  margin-bottom: 28px !important;
  line-height: 1.8 !important;
  text-align: left !important;
}
#page-home .column-badge {
  font-size: 15px !important;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 16px;
}

/* ── 6. 子區塊標題（核心交付價值等） ── */
#page-home .sub-group-title {
  font-size: 22px !important;
  font-weight: 900 !important;
  color: var(--lp-gold) !important;
  margin: 32px 0 16px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid rgba(232,197,90,.2) !important;
  text-align: left !important;
}

/* ── 7. 卡片標題 ── */
#page-home .split-card-title {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--lp-bright) !important;
  margin-bottom: 6px !important;
  text-align: left !important;
}
#page-home .split-card-desc {
  font-size: 15px !important;
  color: var(--lp-muted) !important;
  line-height: 1.85 !important;
  text-align: left !important;
}

/* ── 8. 步驟標題 ── */
#page-home .timeline-step-title {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--lp-gold) !important;
  display: block !important;
  margin-bottom: 4px !important;
  text-align: left !important;
}
#page-home .timeline-step-desc {
  font-size: 14px !important;
  color: var(--lp-muted) !important;
  line-height: 1.75 !important;
  text-align: left !important;
}

/* ── 9. 影片示範小標 ── */
#page-home .lp-h3 {
  font-size: clamp(18px,2.5vw,22px) !important;
  font-weight: 800 !important;
  color: var(--lp-gold) !important;
  margin: 0 0 12px !important;
  line-height: 1.35 !important;
  text-align: center !important;
}
#page-home .lp-h3.white { color: var(--lp-bright) !important; }

/* ── 10. Copy Box（迷思、變現案例、課程試看） ── */
#page-home .vsl-feature-copy,
#page-home .vsl-monetization-copy,
#page-home .vsl-course-preview-copy {
  max-width: 820px;
  margin: 0 auto 36px;
  padding: 28px 32px;
  border: 1px solid rgba(232,197,90,.22);
  border-radius: 16px;
  background: rgba(13,15,24,.72);
  text-align: left !important;
  font-size: 15px !important;
  line-height: 1.9 !important;
  color: var(--lp-body) !important;
}
#page-home .vsl-feature-copy p,
#page-home .vsl-monetization-copy p,
#page-home .vsl-course-preview-copy p {
  text-align: left !important;
  font-size: 15px !important;
  line-height: 1.9 !important;
  color: var(--lp-body) !important;
  margin: 0 0 14px !important;
}
#page-home .vsl-feature-copy p:last-child,
#page-home .vsl-monetization-copy p:last-child,
#page-home .vsl-course-preview-copy p:last-child {
  margin-bottom: 0 !important;
  color: var(--lp-bright) !important;
  font-weight: 800 !important;
}
#page-home .vsl-feature-copy strong,
#page-home .vsl-course-preview-copy strong {
  display: block;
  color: var(--lp-gold) !important;
  font-size: 17px !important;
  margin-bottom: 14px !important;
  font-weight: 800 !important;
}

/* ── 11. VSL 影片前後說明文字 ── */
#page-home #vsl-main-container p,
#page-home #vsl-main-container div p {
  text-align: left !important;
  font-size: 15px !important;
  line-height: 1.9 !important;
}

/* ── 12. Funnel Panel ── */
#page-home .funnel-panel {
  border: 1px solid rgba(232,197,90,.24);
  border-radius: 20px;
  background: linear-gradient(180deg,rgba(18,20,32,.82),rgba(9,10,18,.88));
  box-shadow: 0 18px 48px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.04);
  padding: 40px;
}
#page-home .funnel-pill {
  padding: 20px;
  text-align: left !important;
}
#page-home .funnel-pill b {
  display: block;
  color: var(--lp-gold) !important;
  font-size: 16px !important;
  margin-bottom: 8px;
  font-weight: 700;
}
#page-home .funnel-pill span {
  display: block;
  color: var(--lp-body) !important;
  font-size: 14px !important;
  line-height: 1.75;
}

/* ── 13. Decision + Not-fit 卡片 ── */
#page-home .funnel-decision-card h3,
#page-home .funnel-decision-card .lp-h3 {
  font-size: 17px !important;
  font-weight: 800 !important;
  color: var(--lp-gold) !important;
  margin: 0 0 10px !important;
  text-align: left !important;
}
#page-home .funnel-decision-card p {
  font-size: 15px !important;
  color: var(--lp-body) !important;
  line-height: 1.85 !important;
  text-align: left !important;
}
#page-home .funnel-not-fit-card h3,
#page-home .funnel-not-fit-card .lp-h3 {
  font-size: 17px !important;
  font-weight: 800 !important;
  color: #ff9a9a !important;
  margin: 0 0 10px !important;
  text-align: left !important;
}
#page-home .funnel-not-fit-card p {
  font-size: 15px !important;
  color: var(--lp-body) !important;
  line-height: 1.85 !important;
  text-align: left !important;
}

/* ── 14. B 欄 inline div 的 16px 標題 ── */
#page-home .split-solution-right div[style*="font-size:16px"],
#page-home .split-solution-right div[style*="font-size: 16px"] {
  font-size: 17px !important;
  text-align: left !important;
}
#page-home .split-solution-right div[style*="font-size:14px"],
#page-home .split-solution-right div[style*="font-size: 14px"] {
  font-size: 15px !important;
  text-align: left !important;
}

/* ── 15. FAQ ── */
#page-home .faq-q {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--lp-bright) !important;
  line-height: 1.55 !important;
}
#page-home .faq-a {
  font-size: 15px !important;
  line-height: 1.85 !important;
  color: var(--lp-muted) !important;
  text-align: left !important;
}
#page-home .faq-a p {
  font-size: 15px !important;
  text-align: left !important;
}

/* ── 16. Final CTA ── */
#page-home .cta-title {
  font-size: clamp(26px,4vw,40px) !important;
  font-weight: 950 !important;
  margin-bottom: 14px !important;
  color: var(--lp-bright) !important;
  text-align: center !important;
}
#page-home .cta-sub {
  font-size: 16px !important;
  color: var(--lp-muted) !important;
  margin-bottom: 32px !important;
  line-height: 1.8 !important;
  text-align: center !important;
}

/* ── 17. 間距 ── */
#page-home .funnel-clarity-section,
#page-home .funnel-decision-section,
#page-home .funnel-not-fit-section {
  max-width: 1100px;
  margin: 0 auto 88px;
  padding: 0 24px;
}
#page-home .vsl-standalone-video-section {
  max-width: 1100px;
  margin: 0 auto 88px;
  padding: 0 24px;
}

/* ── 18. RWD ── */
@media(max-width:768px){
  #page-home p { font-size: 14px !important; }
  #page-home .funnel-copy { font-size: 14px !important; }
  #page-home .funnel-title,
  #page-home .lp-h2,
  #page-home .vsl-audience-title { font-size: clamp(22px,7vw,30px) !important; }
  #page-home .sub-group-title { font-size: 19px !important; }
  #page-home .lp-h3 { font-size: 17px !important; }
  #page-home .funnel-panel { padding: 28px 20px; }
  #page-home .vsl-feature-copy,
  #page-home .vsl-monetization-copy,
  #page-home .vsl-course-preview-copy { padding: 20px 18px; font-size: 14px !important; }
  #page-home .funnel-clarity-section,
  #page-home .funnel-decision-section,
  #page-home .funnel-not-fit-section,
  #page-home .vsl-standalone-video-section { margin-bottom: 60px; padding: 0 16px; }
  #page-home .funnel-pill-grid { grid-template-columns: 1fr; }
}

/* ── 19. Solutions refactor classes ── */
#page-home .title-workflow-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-top: 12px;
  padding: 8px 16px;
  border-radius: 999px;
  background: linear-gradient(135deg,#ff9f2f,#ffe678);
  color: #141006;
  font-size: 15px !important;
  font-weight: 900;
  line-height: 1.2;
}
#page-home .solutions-intro-copy {
  max-width: 760px;
  margin: 0 auto 32px !important;
  color: var(--lp-muted) !important;
  font-size: 14px !important;
  line-height: 1.85 !important;
  text-align: center !important;
}
#page-home .split-card-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 10px;
}
#page-home .course-step-num,
#page-home .course-workflow-num {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-family: 'Space Mono', monospace;
  font-weight: 900;
}
#page-home .course-workflow-spotlight {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 22px;
  border: 1px solid rgba(232,197,90,.36);
  border-radius: 16px;
  background: linear-gradient(135deg,rgba(232,197,90,.12),rgba(74,158,255,.06));
}
#page-home .course-workflow-num {
  color: #111;
  background: var(--lp-gold);
  border: 1px solid rgba(255,255,255,.22);
}
#page-home .workflow-spotlight-kicker {
  color: var(--lp-gold);
  font-size: 12px !important;
  font-weight: 900;
  letter-spacing: 2px;
  margin-bottom: 4px;
}
#page-home .workflow-spotlight-title {
  color: var(--lp-bright);
  font-size: 18px !important;
  font-weight: 900;
  margin-bottom: 8px;
}
#page-home .workflow-spotlight-desc {
  color: var(--lp-body);
  font-size: 15px !important;
  line-height: 1.85;
}
#page-home .workflow-spotlight-time {
  color: var(--lp-gold);
  font-weight: 900;
}
#page-home .course-appendix {
  margin-top: 22px;
  padding: 22px;
  border: 1px solid rgba(232,197,90,.18);
  border-radius: 16px;
  background: rgba(232,197,90,.04);
}
#page-home .course-appendix-title {
  color: var(--lp-gold);
  font-size: 15px !important;
  font-weight: 900;
  letter-spacing: 2px;
  margin-bottom: 16px;
}
#page-home .course-appendix-items {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
#page-home .course-appendix-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
#page-home .course-appendix-icon {
  flex-shrink: 0;
  line-height: 1.5;
}
#page-home .lp-price-block {
  margin: 24px 0 10px;
  text-align: center;
}
#page-home .lp-price-main {
  color: var(--lp-gold) !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1.5 !important;
  margin: 0 0 8px !important;
  text-align: center !important;
}
#page-home .lp-price-note {
  color: var(--lp-muted) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 1.7 !important;
  margin: 0 !important;
  text-align: center !important;
}

/* ── 20. Preserve verified visual fixes ── */
#page-home .funnel-kicker {
  font-size: 15px !important;
  letter-spacing: 1px !important;
  text-transform: none !important;
}
#page-home .column-title,
#page-home .column-title-stacked {
  font-size: clamp(24px,3.5vw,32px) !important;
  font-weight: 950 !important;
}
#page-home #vsl-main-container p,
#page-home #vsl-main-container div>p {
  text-align: left !important;
  font-size: 15px !important;
  line-height: 1.9 !important;
}

@media(max-width:768px){
  #page-home .course-workflow-spotlight,
  #page-home .course-appendix-item {
    flex-direction: column;
  }
  #page-home .title-workflow-chip {
    font-size: 13px !important;
  }
}

/* ── 21. Layout shell v4: clear section rhythm, function-safe ── */
#page-home {
  --chiwa-page: #08090f;
  --chiwa-band: #0d1018;
  --chiwa-band-2: #111420;
  --chiwa-panel: rgba(18, 21, 32, .92);
  --chiwa-panel-soft: rgba(255,255,255,.035);
  --chiwa-line: rgba(232,197,90,.22);
  --chiwa-line-soft: rgba(255,255,255,.1);
  --chiwa-text: #f0f1f6;
  --chiwa-muted: rgba(240,241,246,.68);
  --chiwa-gold: #e8c55a;
  background: var(--chiwa-page) !important;
  color: var(--chiwa-text);
  overflow-x: hidden;
}

#page-home .hero,
#page-home .audience-first-section,
#page-home .funnel-clarity-section,
#page-home .vsl-feature-section,
#page-home .vsl-standalone-video-section,
#page-home .split-solutions-container,
#page-home .funnel-decision-section,
#page-home .funnel-not-fit-section,
#page-home #faq,
#page-home .cta-section {
  width: min(1180px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  padding: 88px 0 !important;
  box-sizing: border-box;
}

#page-home .funnel-clarity-section,
#page-home .vsl-standalone-video-section,
#page-home .funnel-decision-section,
#page-home .funnel-not-fit-section {
  max-width: none !important;
}

#page-home .funnel-clarity-section > *,
#page-home .vsl-standalone-video-section > *,
#page-home .funnel-decision-section > *,
#page-home .funnel-not-fit-section > * {
  width: min(1060px, 100%);
  margin-left: auto !important;
  margin-right: auto !important;
}

#page-home .hero {
  min-height: 76vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  border-bottom: 1px solid rgba(232,197,90,.16);
}

#page-home .audience-first-section {
  padding-top: 72px !important;
  padding-bottom: 84px !important;
  border-bottom: 1px solid rgba(232,197,90,.16);
}

#page-home .audience-first-section .vsl-audience-title {
  margin-bottom: 24px !important;
}

#page-home .audience-first-section .vsl-audience-image-wrap {
  max-width: 1100px !important;
  margin-bottom: 0 !important;
}

#page-home .hero-badge {
  font-size: 23px !important;
  letter-spacing: 2px !important;
  padding: 9px 18px !important;
  border-radius: 999px !important;
  background: rgba(232,197,90,.08) !important;
  border-color: rgba(232,197,90,.32) !important;
}

#page-home .hero-title {
  max-width: 960px;
  font-size: 48px !important;
  line-height: 1.18 !important;
  letter-spacing: 0 !important;
  margin: 0 0 22px !important;
}

#page-home .hero-sub {
  max-width: 720px !important;
  font-size: 17px !important;
  line-height: 1.9 !important;
  color: var(--chiwa-muted) !important;
  margin-bottom: 32px !important;
}

#page-home .hero-btns {
  gap: 14px !important;
  margin-top: 6px;
}

#page-home .section-cta-block {
  width: min(1180px, calc(100% - 48px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  box-sizing: border-box;
}

#page-home .section-cta-block .btn-gold {
  max-width: 100% !important;
  justify-content: center !important;
  text-align: center !important;
  white-space: normal !important;
  line-height: 1.45 !important;
}

#page-home .btn-gold,
#page-home .funnel-secondary-btn,
#page-home .btn-line {
  min-height: 44px;
  border-radius: 999px !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

#page-home .funnel-kicker {
  font-size: 14px !important;
  letter-spacing: 1px !important;
  color: var(--chiwa-gold) !important;
  margin-bottom: 14px !important;
}

#page-home .funnel-title,
#page-home .lp-h2,
#page-home .vsl-audience-title {
  font-size: 36px !important;
  line-height: 1.24 !important;
  letter-spacing: 0 !important;
  margin-bottom: 16px !important;
}

#page-home .funnel-copy,
#page-home .solutions-intro-copy,
#page-home .section-p,
#page-home .section-copy {
  max-width: 780px !important;
  font-size: 16px !important;
  line-height: 1.95 !important;
  color: var(--chiwa-muted) !important;
}

#page-home .funnel-panel,
#page-home .vsl-feature-copy,
#page-home .vsl-monetization-copy,
#page-home .vsl-course-preview-copy,
#page-home .split-solution-left,
#page-home .split-solution-right,
#page-home .faq-column,
#page-home .brandish-card {
  border-radius: 8px !important;
  border: 1px solid var(--chiwa-line-soft) !important;
  background: var(--chiwa-panel) !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.24) !important;
}

#page-home .funnel-panel {
  padding: 44px !important;
}

#page-home .funnel-pill-grid,
#page-home .split-cards-grid,
#page-home .tech-badges-grid,
#page-home .funnel-decision-grid,
#page-home .funnel-not-fit-grid {
  gap: 18px !important;
}

#page-home .funnel-pill,
#page-home .split-card-item,
#page-home .tech-badge-card,
#page-home .funnel-decision-card,
#page-home .funnel-not-fit-card,
#page-home .faq-item,
#page-home .course-appendix {
  border-radius: 8px !important;
  border: 1px solid var(--chiwa-line-soft) !important;
  background: var(--chiwa-panel-soft) !important;
}

#page-home .funnel-pill,
#page-home .split-card-item,
#page-home .tech-badge-card {
  padding: 22px !important;
}

#page-home .split-card-title,
#page-home .timeline-step-title,
#page-home .faq-q {
  font-size: 16px !important;
  line-height: 1.45 !important;
  color: var(--chiwa-text) !important;
}

#page-home .split-card-desc,
#page-home .timeline-step-desc,
#page-home .faq-a,
#page-home .course-appendix .split-card-desc {
  font-size: 15px !important;
  line-height: 1.85 !important;
  color: var(--chiwa-muted) !important;
}

#page-home .vsl-feature-section {
  width: min(1260px, calc(100% - 48px)) !important;
}

#page-home .vsl-feature-copy,
#page-home .vsl-monetization-copy,
#page-home .vsl-course-preview-copy {
  max-width: 860px !important;
  padding: 30px 34px !important;
  margin-bottom: 34px !important;
}

#page-home .vsl-feature-category-grid {
  max-width: 1120px !important;
  gap: 28px !important;
}

#page-home .vsl-feature-category {
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  padding: 28px 18px 30px;
}

#page-home .vsl-feature-subtitle {
  display: block !important;
  max-width: 860px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
  font-size: 17px !important;
  line-height: 1.65 !important;
}

#page-home .vsl-video-styles-title {
  display: block !important;
  max-width: 900px !important;
  margin: 34px auto 24px !important;
  text-align: center !important;
  color: var(--chiwa-gold, var(--lp-gold)) !important;
  font-size: clamp(26px, 3vw, 34px) !important;
  line-height: 1.28 !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
}

#page-home .vsl-course-preview-subtitle {
  display: block !important;
  max-width: 860px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
}

#page-home .vsl-wrap {
  margin-bottom: 0 !important;
}

#page-home #vsl-main-container {
  width: min(920px, calc(100% - 48px)) !important;
  max-width: 920px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#page-home #vsl-main-container .vsl-intro-framing {
  width: min(860px, 100%) !important;
  max-width: 860px !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
  box-sizing: border-box;
}

#page-home #vsl-main-container .vsl-main-subtitle {
  display: block !important;
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
  font-size: 25px !important;
  line-height: 1.45 !important;
  font-weight: 800 !important;
  color: var(--chiwa-muted, var(--lp-muted)) !important;
}

#page-home .vsl-box,
#page-home .vimeo-video-wrapper {
  border-radius: 8px !important;
  border: 1px solid rgba(232,197,90,.22) !important;
  overflow: hidden;
}

#page-home .split-solutions-container {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 28px !important;
  align-items: start;
  border-top: 1px solid rgba(232,197,90,.14);
  border-bottom: 1px solid rgba(232,197,90,.14);
}

#page-home .split-solutions-container > .funnel-kicker,
#page-home .split-solutions-container > .funnel-title,
#page-home .split-solutions-container > .solutions-intro-copy {
  grid-column: 1 / -1;
}

#page-home .solutions-section-title {
  grid-column: 1 / -1;
  display: block !important;
  max-width: 960px !important;
  margin: 0 auto 18px !important;
  text-align: center !important;
  color: var(--chiwa-gold, var(--lp-gold)) !important;
  font-size: clamp(40px, 5vw, 58px) !important;
  line-height: 1.16 !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
}

#page-home .split-solution-left,
#page-home .split-solution-right {
  padding: 34px !important;
}

#page-home .column-badge {
  width: fit-content;
  border-radius: 999px !important;
  margin-bottom: 20px !important;
}

#page-home .column-title,
#page-home .column-title-stacked {
  font-size: 28px !important;
  line-height: 1.25 !important;
  margin-bottom: 14px !important;
}

#page-home .column-subtitle {
  font-size: 16px !important;
  line-height: 1.85 !important;
  margin-bottom: 28px !important;
}

#page-home .lp-price-block {
  padding: 18px 20px;
  border-radius: 8px;
  border: 1px solid rgba(232,197,90,.22);
  background: rgba(232,197,90,.045);
}

#page-home .course-workflow-spotlight {
  border-radius: 8px !important;
}

#page-home #faq {
  max-width: 1180px !important;
}

#page-home .faq-split-container {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px !important;
}

#page-home .faq-column {
  padding: 28px !important;
}

#page-home .faq-column-title,
#page-home .faq-sub-title {
  color: var(--chiwa-gold) !important;
}

#page-home .cta-section {
  width: 100% !important;
  max-width: none !important;
  padding: 86px 24px !important;
  border-top: 1px solid rgba(232,197,90,.16);
  background: #0b0d14 !important;
}

#page-home .cta-title {
  font-size: 38px !important;
}

#page-home .cta-sub {
  max-width: 720px;
  margin-left: auto !important;
  margin-right: auto !important;
}

@media(max-width:900px){
  #page-home .hero,
  #page-home .audience-first-section,
  #page-home .funnel-clarity-section,
  #page-home .vsl-feature-section,
  #page-home .vsl-standalone-video-section,
  #page-home .split-solutions-container,
  #page-home .funnel-decision-section,
  #page-home .funnel-not-fit-section,
  #page-home #faq {
    width: min(100% - 32px, 720px) !important;
    padding: 64px 0 !important;
  }
  #page-home #vsl-main-container {
    width: calc(100% - 16px) !important;
  }
  #page-home #vsl-main-container .vsl-intro-framing {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  #page-home .hero {
    min-height: auto;
    padding-top: 84px !important;
  }
  #page-home .audience-first-section {
    padding-top: 52px !important;
    padding-bottom: 56px !important;
  }
  #page-home .hero-title {
    font-size: 34px !important;
  }
  #page-home .hero-sub {
    font-size: 15px !important;
  }
  #page-home .funnel-title,
  #page-home .lp-h2,
  #page-home .vsl-audience-title,
  #page-home .cta-title {
    font-size: 28px !important;
  }
  #page-home .funnel-panel,
  #page-home .split-solution-left,
  #page-home .split-solution-right,
  #page-home .faq-column {
    padding: 24px !important;
  }
  #page-home .split-solutions-container,
  #page-home .faq-split-container,
  #page-home .funnel-decision-grid,
  #page-home .funnel-not-fit-grid {
    grid-template-columns: 1fr !important;
  }
  #page-home .vsl-feature-category-grid {
    grid-template-columns: 1fr !important;
    max-width: 420px !important;
  }
  #page-home .vsl-feature-category {
    padding: 22px 14px 24px;
  }
  #page-home .hero-btns,
  #page-home .funnel-cta-row {
    flex-direction: column;
    align-items: stretch;
  }
  #page-home .hero-btns > *,
  #page-home .funnel-cta-row > * {
    width: 100% !important;
    justify-content: center !important;
  }
}

/* ── 22. IA pass: section hierarchy and reading rhythm ── */
#page-home .audience-first-section,
#page-home .hero,
#page-home .funnel-clarity-section,
#page-home #vsl-main-container,
#page-home .vsl-feature-section,
#page-home .vsl-standalone-video-section,
#page-home .split-solutions-container,
#page-home .funnel-decision-section,
#page-home .funnel-not-fit-section,
#page-home #faq,
#page-home .cta-section {
  scroll-margin-top: 92px;
}

#page-home .section-header {
  width: min(960px, 100%) !important;
  margin: 0 auto 36px !important;
  text-align: center !important;
}

#page-home .section-header > * {
  margin-left: auto !important;
  margin-right: auto !important;
}

#page-home .section-header .funnel-kicker,
#page-home .section-header .section-tag,
#page-home .audience-first-section::before {
  display: block !important;
  text-align: center !important;
  color: var(--chiwa-gold, var(--lp-gold)) !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  font-weight: 950 !important;
  letter-spacing: 2px !important;
  margin: 0 auto 14px !important;
}

#page-home .section-header .funnel-title,
#page-home .section-header .lp-h2,
#page-home .section-header .solutions-section-title,
#page-home .audience-first-section > .vsl-audience-title,
#page-home .cta-title {
  display: block !important;
  max-width: 980px !important;
  margin: 0 auto 18px !important;
  text-align: center !important;
  font-size: clamp(38px, 5vw, 58px) !important;
  line-height: 1.16 !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
}

#page-home .section-header .funnel-title,
#page-home .section-header .lp-h2.gold,
#page-home .section-header .solutions-section-title,
#page-home .audience-first-section > .vsl-audience-title {
  color: var(--chiwa-gold, var(--lp-gold)) !important;
}

#page-home .section-header .funnel-copy,
#page-home .section-header .section-subtitle,
#page-home .section-header .vsl-feature-subtitle,
#page-home .section-header .vsl-course-preview-subtitle,
#page-home .section-header .solutions-intro-copy,
#page-home .cta-sub {
  display: block !important;
  max-width: 820px !important;
  margin: 0 auto !important;
  text-align: center !important;
  color: var(--chiwa-muted, var(--lp-muted)) !important;
  font-size: 18px !important;
  line-height: 1.9 !important;
  font-weight: 600 !important;
}

#page-home .section-header .funnel-copy + .funnel-copy,
#page-home .section-header .section-subtitle + .section-subtitle {
  margin-top: 12px !important;
}

#page-home .hero > p,
#page-home .hero-sub {
  text-align: center !important;
}

#page-home #vsl-main-container .vsl-main-header {
  margin-bottom: 24px !important;
}

#page-home #vsl-main-container .vsl-main-subtitle {
  max-width: 900px !important;
  text-align: center !important;
  font-size: 25px !important;
  line-height: 1.45 !important;
  font-weight: 850 !important;
  color: #8BD3FF !important;
}

#page-home #vsl-main-container .vsl-intro-framing {
  max-width: 920px !important;
  margin-bottom: 28px !important;
}

#page-home #vsl-main-container .vsl-intro-framing p {
  text-align: center !important;
  font-size: 16px !important;
  line-height: 1.9 !important;
}

#page-home .vsl-feature-copy,
#page-home .vsl-monetization-copy,
#page-home .vsl-course-preview-copy {
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: left !important;
}

#page-home .vsl-video-styles-title {
  max-width: 980px !important;
  margin: 44px auto 28px !important;
  text-align: center !important;
  font-size: clamp(30px, 3.8vw, 44px) !important;
  line-height: 1.2 !important;
  font-weight: 950 !important;
  color: var(--chiwa-gold, var(--lp-gold)) !important;
}

#page-home .vsl-feature-category > .lp-h3,
#page-home .funnel-decision-card .lp-h3,
#page-home .funnel-not-fit-card .lp-h3 {
  text-align: left !important;
  font-size: 22px !important;
  line-height: 1.35 !important;
  margin-bottom: 12px !important;
}

#page-home .vsl-feature-category > .lp-h3 {
  text-align: center !important;
}

#page-home .split-solutions-container > .section-header {
  grid-column: 1 / -1;
  margin-bottom: 22px !important;
}

#page-home .split-solution-left,
#page-home .split-solution-right {
  display: flex !important;
  flex-direction: column !important;
}

#page-home .column-title,
#page-home .column-title-stacked {
  font-size: clamp(28px, 3.2vw, 36px) !important;
  line-height: 1.22 !important;
  font-weight: 950 !important;
}

#page-home .sub-group-title {
  font-size: 24px !important;
  line-height: 1.35 !important;
  margin-top: 34px !important;
}

#page-home .funnel-panel > .section-header {
  margin-bottom: 30px !important;
}

#page-home #faq .faq-section-header {
  margin-bottom: 18px !important;
}

#page-home #faq .divider {
  margin: 0 auto 34px !important;
}

#page-home .cta-section {
  padding-top: 92px !important;
  padding-bottom: 92px !important;
}

@media(max-width:900px){
  #page-home .section-header {
    margin-bottom: 28px !important;
  }

  #page-home .section-header .funnel-kicker,
  #page-home .section-header .section-tag {
    font-size: 12px !important;
    letter-spacing: 1.4px !important;
  }

  #page-home .section-header .funnel-title,
  #page-home .section-header .lp-h2,
  #page-home .section-header .solutions-section-title,
  #page-home .audience-first-section > .vsl-audience-title,
  #page-home .cta-title {
    font-size: clamp(30px, 8vw, 38px) !important;
    line-height: 1.18 !important;
  }

  #page-home .section-header .funnel-copy,
  #page-home .section-header .section-subtitle,
  #page-home .section-header .vsl-feature-subtitle,
  #page-home .section-header .vsl-course-preview-subtitle,
  #page-home .section-header .solutions-intro-copy,
  #page-home .cta-sub {
    font-size: 15px !important;
    line-height: 1.85 !important;
  }

  #page-home #vsl-main-container .vsl-main-subtitle {
    font-size: 20px !important;
  }

  #page-home #vsl-main-container .vsl-intro-framing p {
    font-size: 15px !important;
    text-align: left !important;
  }

  #page-home .vsl-video-styles-title {
    font-size: clamp(25px, 7vw, 32px) !important;
  }

  #page-home .vsl-feature-category > .lp-h3,
  #page-home .funnel-decision-card .lp-h3,
  #page-home .funnel-not-fit-card .lp-h3 {
    font-size: 20px !important;
  }

  #page-home .column-title,
  #page-home .column-title-stacked {
    font-size: 27px !important;
  }

  #page-home .sub-group-title {
    font-size: 21px !important;
  }
}

/* Section number labels */
#page-home .audience-first-section > .section-number-label,
#page-home .section-number-label {
  width: min(1080px, 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 14px !important;
  margin: 0 auto 28px !important;
  color: var(--chiwa-gold, var(--lp-gold)) !important;
  font-size: clamp(24px, 2.8vw, 34px) !important;
  line-height: 1.2 !important;
  font-weight: 950 !important;
  letter-spacing: 1px !important;
  text-align: center !important;
}

#page-home .audience-first-section > .section-number-label::before,
#page-home .audience-first-section > .section-number-label::after,
#page-home .section-number-label::before,
#page-home .section-number-label::after {
  content: "" !important;
  display: block !important;
  flex: 1 1 90px !important;
  max-width: 360px !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(232,197,90,.42)) !important;
}

#page-home .audience-first-section > .section-number-label::after,
#page-home .section-number-label::after {
  background: linear-gradient(90deg, rgba(232,197,90,.42), transparent) !important;
}

#page-home .section-label-num {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 48px !important;
  height: 36px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(232,197,90,.48) !important;
  background: rgba(232,197,90,.08) !important;
  color: var(--chiwa-gold, var(--lp-gold)) !important;
  font-size: .72em !important;
  font-weight: 950 !important;
  letter-spacing: .5px !important;
}

#page-home .section-label-text {
  display: inline-block !important;
  white-space: nowrap !important;
}

#page-home .audience-first-section > .section-number-label {
  max-width: 1120px !important;
  margin-bottom: 22px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 14px !important;
  font-size: clamp(24px, 2.8vw, 34px) !important;
  line-height: 1.2 !important;
  font-weight: 950 !important;
  letter-spacing: 1px !important;
}

#page-home .section-header > .section-number-label {
  margin-bottom: 22px !important;
}

#page-home #vsl-monetization-case-container > .section-header {
  margin-bottom: 18px !important;
}

#page-home #vsl-monetization-case-container .section-header .lp-h2 {
  margin-bottom: 0 !important;
}

#page-home #vsl-course-preview-container .section-header .lp-h2 {
  max-width: 100% !important;
  font-size: clamp(32px, 3.8vw, 46px) !important;
  white-space: nowrap !important;
}

@media(max-width:900px){
  #page-home .section-number-label {
    gap: 10px !important;
    font-size: clamp(22px, 7vw, 30px) !important;
    margin-bottom: 22px !important;
  }

  #page-home .section-number-label::before,
  #page-home .section-number-label::after {
    flex-basis: 34px !important;
    max-width: 90px !important;
  }

  #page-home .section-label-num {
    min-width: 42px !important;
    height: 32px !important;
    padding: 0 10px !important;
  }

  #page-home #vsl-course-preview-container .section-header .lp-h2 {
    font-size: clamp(26px, 7vw, 32px) !important;
    white-space: normal !important;
  }
}

#page-home .cta-section .cta-sub {
  color: var(--chiwa-gold, var(--lp-gold)) !important;
  font-size: 19.8px !important;
  font-weight: 750 !important;
}

@media(max-width:900px){
  #page-home .cta-section .cta-sub {
    font-size: 16.5px !important;
  }
}

#page-home #funnel-decision .section-header .funnel-title {
  max-width: 100% !important;
  font-size: clamp(36px, 4.6vw, 54px) !important;
}

@media(max-width:900px){
  #page-home #funnel-decision .section-header .funnel-title {
    font-size: clamp(28px, 7vw, 36px) !important;
  }
}

#page-home #vsl-box-element.vsl-main-white-cover {
  background-color: #fffaf0 !important;
  background-size: cover !important;
  background-position: center !important;
  border: 2px solid rgba(232,197,90,.7) !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.28), 0 0 0 1px rgba(255,255,255,.15) !important;
}

#page-home #vsl-box-element.vsl-main-white-cover::before,
#page-home #vsl-box-element.vsl-main-white-cover.has-cover::before {
  opacity: 0 !important;
  background: none !important;
}

#page-home #vsl-box-element.vsl-main-white-cover .vsl-play {
  position: absolute !important;
  left: 50% !important;
  top: 58% !important;
  transform: translate(-50%, -50%) !important;
  color: #111111 !important;
  background: rgba(255,255,255,.86) !important;
  border: 2px solid #d6a93f !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.18) !important;
}

#page-home #vsl-box-element.vsl-main-white-cover:hover .vsl-play {
  transform: translate(-50%, -50%) scale(1.06) !important;
  background: #ffffff !important;
}

#page-home #vsl-box-element.vsl-main-white-cover .vsl-label {
  display: none !important;
}

#page-home .vsl-feature-white-cover {
  background-color: #fffaf0 !important;
  background-size: cover !important;
  background-position: center !important;
  border: 2px solid rgba(232,197,90,.68) !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.26), 0 0 0 1px rgba(255,255,255,.14) !important;
}

#page-home .vsl-feature-white-cover::before,
#page-home .vsl-feature-white-cover.has-cover::before {
  opacity: 0 !important;
  background: none !important;
}

#page-home .vsl-feature-white-cover .vsl-play {
  position: absolute !important;
  left: 50% !important;
  top: 58% !important;
  transform: translate(-50%, -50%) !important;
  color: #111111 !important;
  background: rgba(255,255,255,.86) !important;
  border: 2px solid #d6a93f !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.18) !important;
}

#page-home .vsl-feature-white-cover:hover .vsl-play {
  transform: translate(-50%, -50%) scale(1.06) !important;
  background: #ffffff !important;
}

#page-home .vsl-feature-white-cover .vsl-label {
  display: none !important;
}

#page-home .audience-first-section > .section-number-label,
#page-home .section-number-label {
  color: #ffffff !important;
  font-size: clamp(32px, 3.6vw, 46px) !important;
  gap: 18px !important;
  margin-bottom: 28px !important;
  text-shadow: 0 0 18px rgba(255,255,255,.12) !important;
}

#page-home .audience-first-section > .section-number-label::before,
#page-home .audience-first-section > .section-number-label::after,
#page-home .section-number-label::before,
#page-home .section-number-label::after {
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.58)) !important;
  box-shadow: 0 0 14px rgba(255,255,255,.16) !important;
}

#page-home .audience-first-section > .section-number-label::after,
#page-home .section-number-label::after {
  background: linear-gradient(90deg, rgba(255,255,255,.58), transparent) !important;
}

#page-home .audience-first-section > .section-number-label .section-label-num,
#page-home .section-number-label .section-label-num {
  min-width: 58px !important;
  height: 42px !important;
  padding: 0 14px !important;
  border-color: rgba(255,255,255,.62) !important;
  background: rgba(255,255,255,.075) !important;
  color: #ffffff !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06), 0 0 18px rgba(255,255,255,.1) !important;
}

#page-home .audience-first-section > .section-number-label .section-label-text,
#page-home .section-number-label .section-label-text {
  color: #ffffff !important;
}

@media(max-width:900px){
  #page-home .audience-first-section > .section-number-label,
  #page-home .section-number-label {
    font-size: clamp(27px, 8.5vw, 36px) !important;
    gap: 12px !important;
  }

  #page-home .audience-first-section > .section-number-label .section-label-num,
  #page-home .section-number-label .section-label-num {
    min-width: 50px !important;
    height: 36px !important;
    padding: 0 12px !important;
  }
}

#page-home #vsl-feature-container .section-header .vsl-feature-subtitle {
  color: #ffffff !important;
  font-size: 22px !important;
}

@media(max-width:900px){
  #page-home #vsl-feature-container .section-header .vsl-feature-subtitle {
    font-size: 18px !important;
  }
}
