/* ============================================================
   Front Page Polish v3 (2026-04-27)
   v2 を起点に「メリハリ」「信頼感」を底上げするレイヤー
   既存トークン・構造は踏襲し、追加 / 上書きのみ行う
   ============================================================ */

/* ---------- 1. Derived tokens (派生色) ---------- */
body.home {
  --fp-paper-warm: #F4ECDC;
  --fp-paper-cool: #F6F1E5;
  --fp-section-deep: #E2D9C3;
  --fp-section-soft: #EAE3D2;
  --fp-brown-light: #8E6B4F;
  --fp-brown-mid: #6B4F3B;
  --fp-brown-dark: #4A3525;
  --fp-brown-grad-top: #7B5C45;
  --fp-brown-grad-bot: #5A4030;
  --fp-navy-glow: #2A3F60;
  --fp-navy-deep: #182338;
  --fp-ink-soft: #3D3833;
  --fp-vermilion: #B5563A;
}

/* ---------- 2. Body base — 紙テクスチャ追加 ---------- */
body.home {
  background-color: var(--fp-paper);
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='280' height='280'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='7'/><feColorMatrix values='0 0 0 0 0.42  0 0 0 0 0.31  0 0 0 0 0.22  0 0 0 0.04 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>"),
    linear-gradient(to right, rgba(200,191,177,0.16) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(200,191,177,0.16) 1px, transparent 1px);
  background-size: 280px 280px, 40px 40px, 40px 40px;
}

/* ---------- 3. HERO 強化 ---------- */
.fp-hero {
  padding: 160px 0 120px !important;
  background:
    radial-gradient(ellipse at 30% 0%, rgba(255,250,242,1) 0%, var(--fp-paper-warm) 70%) !important;
  border-bottom: 2px solid var(--fp-brown-mid) !important;
  position: relative;
  overflow: hidden;
}

/* 上端の影（古書の見開き感） */
.fp-hero::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 100px;
  background: linear-gradient(to bottom, rgba(74,53,37,0.10), transparent);
  pointer-events: none;
  z-index: 0;
}

/* 製図グリッドを薄く敷き直し */
.fp-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(107,79,59,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(107,79,59,0.06) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  z-index: 0;
}

/* 構造文字を削除したので単カラム化（中央寄せ） */
.fp-hero-inner {
  position: relative;
  z-index: 1;
  grid-template-columns: 1fr !important;
  max-width: 920px !important;
  margin: 0 auto !important;
  text-align: left;
}

.fp-hero-eyebrow {
  color: var(--fp-brown-dark) !important;
  font-weight: 700 !important;
  position: relative;
  display: inline-block;
  padding-left: 28px;
}
.fp-hero-eyebrow::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  width: 18px; height: 1px;
  background: var(--fp-brown-dark);
}

.fp-hero-title {
  font-weight: 800 !important;
  font-size: clamp(38px, 5.2vw, 64px) !important;
  line-height: 1.4 !important;
  color: var(--fp-ink) !important;
  letter-spacing: 0.05em !important;
}

.fp-hero-mark {
  background: linear-gradient(transparent 55%, rgba(196,156,100,0.55) 55%, rgba(196,156,100,0.55) 92%, transparent 92%) !important;
  padding: 0 6px !important;
}

.fp-hero-sub {
  color: var(--fp-ink-soft) !important;
  font-size: 1.08rem !important;
  font-weight: 500 !important;
}

/* ---------- 4. CTA Buttons — フラット ---------- */
.fp-btn {
  padding: 20px 40px;
  font-size: 1.05rem;
  font-weight: 600;
  border-radius: 0;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
}

.fp-btn--primary {
  padding: 20px 44px !important;
  font-size: 1.05rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  background: var(--fp-brown-dark) !important;
  border: 1px solid var(--fp-brown-dark) !important;
  color: var(--fp-paper) !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
.fp-btn--primary:hover {
  background: var(--fp-ink) !important;
  border-color: var(--fp-ink) !important;
  color: var(--fp-paper) !important;
  transform: none !important;
  box-shadow: none !important;
}

.fp-btn--ghost {
  border: none !important;
  border-bottom: 1px solid var(--fp-brown-mid) !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  color: var(--fp-brown-dark) !important;
  padding: 18px 6px !important;
  background: transparent !important;
  box-shadow: none !important;
}
.fp-btn--ghost:hover {
  border-bottom-color: var(--fp-ink) !important;
  color: var(--fp-ink) !important;
  background: transparent !important;
  transform: none !important;
}

.fp-btn--lg {
  padding: 22px 56px !important;
  font-size: 1.12rem !important;
  letter-spacing: 0.1em !important;
}

.fp-btn--reverse {
  background: var(--fp-paper) !important;
  color: var(--fp-brown-dark) !important;
  border: 1px solid var(--fp-paper) !important;
  font-weight: 600 !important;
  padding: 22px 52px !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
.fp-btn--reverse:hover {
  background: var(--fp-gold) !important;
  color: var(--fp-navy-deep) !important;
  border-color: var(--fp-gold) !important;
  transform: none !important;
  box-shadow: none !important;
}

/* ---------- 5. Section background alternation ---------- */
.fp-proof {
  background: var(--fp-section-deep);
  padding: 100px 0 !important;
  position: relative;
}
.fp-proof::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: var(--fp-brown-mid);
  opacity: 0.4;
}
.fp-proof-grid {
  background: var(--fp-paper);
  border: 1.5px solid var(--fp-brown-mid) !important;
  box-shadow: 0 8px 24px rgba(74,53,37,0.10);
}
.fp-proof-num {
  color: var(--fp-brown-dark) !important;
  font-weight: 900 !important;
  text-shadow: 0 2px 0 rgba(74,53,37,0.06);
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: baseline;
  justify-content: center;
}
.fp-proof-num--small {
  color: var(--fp-ink) !important;
  white-space: nowrap !important;
  display: block !important;
}
.fp-proof-unit {
  color: var(--fp-brown-mid) !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
  display: inline-block !important;
}
.fp-proof-item {
  padding: 56px 16px !important;
}
.fp-proof-label {
  font-weight: 700 !important;
  color: var(--fp-brown-dark) !important;
}

/* services */
.fp-services {
  background: var(--fp-paper-cool);
  padding: 120px 0 !important;
  border-top: 1px solid var(--fp-soft-beige);
  border-bottom: 1px solid var(--fp-soft-beige);
}
.fp-blueprint {
  background: var(--fp-paper) !important;
  border: 1.5px solid var(--fp-brown-mid) !important;
  padding: 56px 40px !important;
  box-shadow:
    0 8px 24px rgba(74,53,37,0.08),
    inset 0 0 0 1px rgba(107,79,59,0.06);
}
.fp-flow-node {
  background: var(--fp-paper-warm) !important;
  border: 1.5px solid var(--fp-brown-mid) !important;
  box-shadow: 0 4px 12px rgba(74,53,37,0.14) !important;
  font-weight: 700 !important;
  width: 88px !important;
  height: 88px !important;
}
.fp-flow-arrow {
  background: var(--fp-paper) !important;
  color: var(--fp-brown-mid) !important;
  font-weight: 700;
}

/* phase items */
.fp-phase-num {
  font-weight: 700 !important;
  color: var(--fp-brown-dark) !important;
}
.fp-phase-title {
  color: var(--fp-ink) !important;
  font-size: 1.5rem !important;
}

/* before/after */
.fp-ba {
  background: var(--fp-section-soft);
  padding: 120px 0 !important;
}
.fp-ba-table th {
  background: var(--fp-brown-dark) !important;
  color: var(--fp-paper) !important;
  border-color: var(--fp-brown-dark) !important;
  font-size: 1.08rem !important;
}
.fp-ba-table td {
  background: var(--fp-paper) !important;
  border-color: var(--fp-soft-beige) !important;
}

.fp-mark {
  background: linear-gradient(transparent 55%, rgba(196,156,100,0.5) 55%, rgba(196,156,100,0.5) 92%, transparent 92%) !important;
  padding: 0 4px !important;
  font-weight: 700 !important;
  color: var(--fp-brown-dark) !important;
}

/* advisor */
.fp-advisor {
  background: var(--fp-paper-cool);
  padding: 120px 0 !important;
}
.fp-spec-list {
  border-top: 2px solid var(--fp-brown-dark) !important;
}
.fp-spec-num {
  font-family: var(--fp-mincho) !important;
  font-size: 1.6rem !important;
  font-weight: 900 !important;
  color: var(--fp-brown-dark) !important;
  letter-spacing: 0.04em !important;
  min-width: 56px !important;
}
.fp-spec-body h3 {
  color: var(--fp-ink) !important;
  font-size: 1.25rem !important;
}

/* about */
.fp-about {
  background: var(--fp-paper);
  padding: 120px 0 !important;
}
.fp-about-grid {
  background: var(--fp-paper-warm);
  padding: 56px !important;
  border: 1px solid var(--fp-soft-beige);
  box-shadow: 0 8px 32px rgba(74,53,37,0.08);
}
.fp-about-name {
  color: var(--fp-ink) !important;
  font-weight: 800 !important;
}

/* news — 提案書common風（縦線・番号レス・罫線最小） */
.fp-news {
  background: var(--fp-paper);
  padding: 120px 0 !important;
  position: relative;
}
.fp-news::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(107,79,59,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(107,79,59,0.05) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.fp-news .fp-container { position: relative; z-index: 1; }

.fp-news-list {
  background: transparent !important;
  border: none !important;
  list-style: none;
  padding: 0;
  margin: 0;
}
.fp-news-list li {
  border: none !important;
  border-bottom: 1px solid rgba(107,79,59,0.16) !important;
  padding: 0 !important;
  margin: 0;
}
.fp-news-list li:first-child {
  border-top: 1px solid rgba(107,79,59,0.16) !important;
}
.fp-news-list li:last-child {
  border-bottom: 1px solid rgba(107,79,59,0.16) !important;
}

.fp-news-item {
  display: grid !important;
  grid-template-columns: 130px 110px 1fr !important;
  gap: 32px !important;
  align-items: center !important;
  padding: 28px 16px 28px 28px !important;
  border-left: 2px solid var(--fp-brown-mid) !important;
  text-decoration: none !important;
  background: transparent !important;
  position: relative;
  transition: border-left-color 0.25s ease, padding-left 0.25s ease, background 0.25s ease !important;
}
a.fp-news-item:hover {
  background: rgba(107,79,59,0.04) !important;
  border-left-color: var(--fp-brown-dark) !important;
  border-left-width: 4px !important;
  padding-left: 26px !important;
}
.fp-news-date {
  font-family: var(--fp-mono) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.12em !important;
  color: var(--fp-brown-dark) !important;
  font-weight: 600 !important;
}
.fp-news-cat {
  font-family: var(--fp-mono) !important;
  font-size: 0.65rem !important;
  letter-spacing: 0.3em !important;
  color: var(--fp-brown-mid) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  border: 1px solid var(--fp-brown-mid);
  padding: 4px 10px;
  display: inline-block;
  text-align: center;
  width: fit-content;
}
.fp-news-title {
  font-family: var(--fp-mincho) !important;
  font-size: 1.05rem !important;
  font-weight: 600 !important;
  color: var(--fp-ink) !important;
  letter-spacing: 0.04em !important;
  line-height: 1.6 !important;
}

/* methods */
.fp-methods {
  background: var(--fp-paper-cool);
  padding: 120px 0 !important;
}
.fp-method-card {
  background: var(--fp-paper) !important;
  border: 1px solid var(--fp-brown-mid) !important;
  box-shadow: 0 4px 16px rgba(74,53,37,0.08);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-top 0.3s ease !important;
  overflow: hidden;
}
.fp-method-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(74,53,37,0.18) !important;
  border-top: 4px solid var(--fp-brown-dark) !important;
}
/* メソッドカードのアイキャッチを統一サイズに（全画像が見えるよう contain） */
.fp-method-thumb {
  aspect-ratio: 16 / 9 !important;
  width: 100% !important;
  overflow: hidden !important;
  background: var(--fp-paper, #F8F4ED) !important;
  display: block !important;
}
.fp-method-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
}

/* ---------- 6. DIAGNOSTIC — navy 反転（最大のメリハリポイント） ---------- */
.fp-diagnostic {
  background: var(--fp-navy) !important;
  color: #F4EFE6 !important;
  padding: 140px 0 !important;
  position: relative;
  overflow: hidden;
}
.fp-diagnostic::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(244,239,230,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(244,239,230,0.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.fp-diagnostic .fp-container { position: relative; z-index: 1; }
.fp-diagnostic .fp-section-label {
  color: var(--fp-gold) !important;
}
.fp-diagnostic .fp-section-title {
  color: #F4EFE6 !important;
}
.fp-diagnostic .fp-section-sub {
  color: rgba(244,239,230,0.78) !important;
}
.fp-diagnostic .fp-mark {
  background: linear-gradient(transparent 55%, rgba(196,156,100,0.6) 55%, rgba(196,156,100,0.6) 92%, transparent 92%) !important;
  color: var(--fp-gold) !important;
}
.fp-diag-steps li {
  border-top: 1px solid rgba(244,239,230,0.18) !important;
}
.fp-diag-steps li:last-child {
  border-bottom: 1px solid rgba(244,239,230,0.18) !important;
}
.fp-diag-step-num {
  color: var(--fp-gold) !important;
  font-weight: 700 !important;
}
.fp-diag-steps h4 {
  color: #F4EFE6 !important;
  font-weight: 700 !important;
}
.fp-diag-steps p {
  color: rgba(244,239,230,0.74) !important;
}

.fp-diagnostic-right {
  background: var(--fp-paper) !important;
  border: 1.5px solid var(--fp-paper) !important;
  box-shadow: 0 16px 48px rgba(0,0,0,0.40) !important;
  position: relative;
}
.fp-diagnostic-right::before {
  content: "";
  position: absolute;
  top: -6px; left: -6px; right: -6px; bottom: -6px;
  border: 1px solid rgba(196,156,100,0.4);
  pointer-events: none;
}
.fp-diag-sample-label {
  color: var(--fp-brown-dark) !important;
  font-weight: 700 !important;
}
.fp-diag-score-num {
  color: var(--fp-brown-dark) !important;
  font-weight: 900 !important;
}
.fp-diag-bar-fill {
  background: linear-gradient(90deg, var(--fp-brown-mid) 0%, var(--fp-brown-dark) 100%) !important;
}
.fp-diagnostic-actions {
  margin-top: 72px !important;
}
.fp-diagnostic-actions .fp-btn--primary {
  background: var(--fp-gold) !important;
  border: 1px solid var(--fp-gold) !important;
  color: var(--fp-navy-deep) !important;
  font-weight: 600 !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
.fp-diagnostic-actions .fp-btn--primary:hover {
  background: var(--fp-paper) !important;
  border-color: var(--fp-paper) !important;
  color: var(--fp-navy-deep) !important;
  transform: none !important;
  box-shadow: none !important;
}
.fp-diagnostic .fp-cta-note {
  color: rgba(244,239,230,0.6) !important;
}

/* ---------- 7. Mission polish (navy already, add depth) ---------- */
.fp-mission {
  background: linear-gradient(180deg, var(--fp-navy) 0%, var(--fp-navy-deep) 100%) !important;
  padding: 130px 0 !important;
  position: relative;
  overflow: hidden;
}
.fp-mission::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(244,239,230,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(244,239,230,0.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.fp-mission .fp-container { position: relative; z-index: 1; }
.fp-mission-statement {
  font-weight: 800 !important;
}
.fp-mission-mark {
  border-bottom: 3px solid var(--fp-gold) !important;
  padding-bottom: 6px !important;
}

/* ---------- 8. Final CTA polish ---------- */
.fp-cta-final {
  background: var(--fp-navy-deep) !important;
  padding: 140px 0 !important;
  position: relative;
  overflow: hidden;
}
.fp-cta-final::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, var(--fp-navy) 0%, var(--fp-navy-deep) 90%);
  pointer-events: none;
}
.fp-cta-final::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(244,239,230,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(244,239,230,0.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.fp-cta-final .fp-container { position: relative; z-index: 1; }
.fp-cta-title {
  font-weight: 800 !important;
}

/* ---------- 9. Section title polish ---------- */
.fp-section-title {
  font-weight: 800 !important;
}
.fp-section-label {
  font-weight: 700 !important;
  color: var(--fp-brown-dark) !important;
}

/* ---------- 10. Divider polish ---------- */
.fp-divider {
  margin: 0 auto !important;
}
.fp-divider-line {
  opacity: 0.55;
}

/* ---------- 11. 提案書common風 黒金引用ボックス（ユーティリティ） ---------- */
.fp-callout-dark {
  background: var(--fp-navy-deep);
  color: rgba(244,239,230,0.92);
  padding: 32px 40px;
  border-left: 3px solid var(--fp-gold);
  margin: 32px 0;
  font-family: var(--fp-mincho);
  line-height: 1.95;
}
.fp-callout-dark h4,
.fp-callout-dark .fp-callout-title {
  color: var(--fp-gold);
  font-family: var(--fp-mincho);
  font-weight: 700;
  letter-spacing: 0.1em;
  margin: 0 0 16px;
  font-size: 1.05rem;
}
.fp-callout-dark .fp-callout-flag {
  display: inline-block;
  margin-right: 8px;
}

/* ---------- 12. Section header — 提案書common風 ---------- */
.fp-section-num {
  font-family: var(--fp-mono);
  font-size: 0.78rem;
  letter-spacing: 0.3em;
  color: var(--fp-brown-mid);
  text-transform: uppercase;
  display: inline-block;
  border-left: 2px solid var(--fp-brown-mid);
  padding: 4px 0 4px 14px;
  margin-bottom: 16px;
  writing-mode: horizontal-tb;
}

/* ---------- 13. Mobile responsive adjustments ---------- */
@media (max-width: 900px) {
  .fp-hero { padding: 96px 0 64px !important; }
  .fp-hero-title {
    font-size: clamp(28px, 7vw, 40px) !important;
    line-height: 1.45 !important;
  }
  .fp-hero-sub {
    font-size: 0.95rem !important;
    line-height: 1.85 !important;
  }
  .fp-hero-eyebrow {
    font-size: 0.7rem !important;
  }
  .fp-btn--primary {
    padding: 16px 24px !important;
    font-size: 0.95rem !important;
    min-height: 48px;
  }
  .fp-about-grid { padding: 32px !important; }
  .fp-diagnostic { padding: 88px 0 !important; }
  .fp-cta-final { padding: 88px 0 !important; }
  .fp-news-item {
    grid-template-columns: 110px 1fr !important;
    gap: 16px !important;
    padding: 18px 12px 18px 16px !important;
  }
  .fp-news-cat { display: none !important; }
  .fp-section-title {
    font-size: clamp(22px, 5vw, 30px) !important;
    line-height: 1.4 !important;
  }
}

@media (max-width: 640px) {
  /* Hero */
  .fp-hero { padding: 80px 0 56px !important; }
  .fp-hero-inner { padding: 0 20px; }
  .fp-hero-title {
    font-size: 26px !important;
    line-height: 1.5 !important;
    letter-spacing: 0.02em !important;
  }
  .fp-hero-sub {
    font-size: 0.92rem !important;
    line-height: 1.85 !important;
    margin-top: 16px !important;
  }
  .fp-hero-actions {
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;
  }
  .fp-btn--primary,
  .fp-btn--ghost {
    width: 100% !important;
    justify-content: center !important;
    min-height: 48px;
    padding: 14px 20px !important;
  }

  /* Container padding */
  .fp-container {
    padding: 0 20px !important;
  }

  /* Sections common */
  .fp-services,
  .fp-methods,
  .fp-news,
  .fp-proof {
    padding: 64px 0 !important;
  }
  .fp-section-head {
    margin-bottom: 32px !important;
  }
  .fp-section-label {
    font-size: 0.7rem !important;
    margin-bottom: 12px !important;
  }
  .fp-section-title {
    font-size: 22px !important;
    line-height: 1.5 !important;
    letter-spacing: 0.02em !important;
  }
  .fp-section-sub {
    font-size: 0.92rem !important;
    line-height: 1.85 !important;
    margin-top: 12px !important;
  }

  /* Proof */
  .fp-proof-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
  }
  .fp-proof-item {
    padding: 16px !important;
  }
  .fp-proof-num {
    font-size: clamp(28px, 7vw, 36px) !important;
  }
  .fp-proof-num--small {
    font-size: clamp(20px, 5vw, 24px) !important;
  }
  .fp-proof-unit {
    font-size: 0.85rem !important;
  }
  .fp-proof-label {
    font-size: 0.7rem !important;
  }

  /* Blueprint */
  .fp-blueprint { padding: 28px 20px !important; }

  /* Method cards */
  .fp-method-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  .fp-method-card .fp-method-body {
    padding: 18px 20px !important;
  }
  .fp-method-card h3 {
    font-size: 1rem !important;
    line-height: 1.55 !important;
  }
  .fp-method-card p {
    font-size: 0.88rem !important;
    line-height: 1.8 !important;
  }

  /* Diagnostic */
  .fp-diagnostic { padding: 64px 0 !important; }
  .fp-diag-steps li {
    padding: 16px 0 !important;
    font-size: 0.92rem !important;
  }

  /* About Founder */
  .fp-about-grid {
    padding: 24px !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .fp-about-name {
    font-size: 1.4rem !important;
  }
  .fp-about-position {
    font-size: 0.85rem !important;
  }
  .fp-about-quote {
    max-width: 100% !important;
    padding: 14px 20px !important;
  }
  .fp-about-quote span {
    height: 240px !important;
    font-size: 0.95rem !important;
  }

  /* News list */
  .fp-news-list .fp-news-item {
    grid-template-columns: 95px 1fr !important;
    gap: 14px !important;
    padding: 16px 8px !important;
  }
  .fp-news-date {
    font-size: 0.78rem !important;
  }
  .fp-news-title {
    font-size: 0.92rem !important;
    line-height: 1.6 !important;
  }

  /* Final CTA */
  .fp-cta-final { padding: 64px 0 !important; }
  .fp-cta-final h2 {
    font-size: 22px !important;
    line-height: 1.5 !important;
  }
  .fp-cta-final p {
    font-size: 0.92rem !important;
    line-height: 1.85 !important;
  }
}

@media (max-width: 380px) {
  .fp-hero-title {
    font-size: 24px !important;
  }
  .fp-section-title {
    font-size: 20px !important;
  }
  .fp-proof-grid {
    grid-template-columns: 1fr !important;
  }
}
