.article-wrap { padding: calc(var(--header-h) + 2rem) 0 3.5rem; }
.article-wrap .container { max-width: 720px; }
.article-wrap h1 { font-family: var(--font-display); font-size: clamp(1.65rem, 3.5vw, 2.1rem); margin: 0 0 0.75rem; line-height: 1.2; }
.article-meta { font-size: 0.85rem; color: var(--muted); margin-bottom: 1.25rem; }
.article-prose h2 { font-size: 1.2rem; margin: 1.75rem 0 0.6rem; }
.article-prose h3 { font-size: 1.05rem; margin: 1.35rem 0 0.4rem; color: var(--text); }
.article-prose p, .article-prose li { color: var(--muted); margin: 0 0 1rem; line-height: 1.68; }
.article-prose ul, .article-prose ol { padding-left: 1.2rem; }
.article-prose strong { color: var(--text); }
.article-prose a { color: var(--accent); font-weight: 500; }
.back { display: inline-block; margin-bottom: 1.25rem; font-weight: 600; }
.key-facts {
  background: var(--accent-soft);
  border: 1px solid rgba(201, 169, 98, 0.28);
  border-radius: var(--radius-lg);
  padding: 1.15rem 1.35rem;
  margin: 1.25rem 0 1.75rem;
}
.key-facts h2 { margin: 0 0 0.65rem !important; font-size: 1rem !important; }
.key-facts ul { margin: 0; padding-left: 1.15rem; color: var(--muted); }
.article-figure { margin: 1.5rem 0; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); }
.article-figure img { width: 100%; height: auto; display: block; }
.article-figure figcaption { font-size: 0.85rem; color: var(--muted); padding: 0.65rem 0.85rem; background: var(--bg-elevated); line-height: 1.45; }
.article-faq { margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.article-faq h2 { margin-bottom: 1rem; }
.article-faq dl { margin: 0; }
.article-faq dt { font-weight: 600; color: var(--text); margin: 1.1rem 0 0.35rem; font-size: 1.02rem; }
.article-faq dd { margin: 0 0 0.85rem 0; color: var(--muted); padding-left: 0; }
.article-cta {
  margin-top: 2rem;
  padding: 1.35rem 1.5rem;
  background: var(--bg-elevated);
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-radius: var(--radius-lg);
  text-align: center;
}
.article-cta p { margin: 0 0 1rem; color: var(--muted); }
.article-cta .btn { margin: 0 0.35rem; }
.related-posts { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.related-posts h2 { font-size: 1.05rem; margin-bottom: 0.75rem; }
.related-posts ul { margin: 0; padding-left: 1.2rem; }
.related-posts li { margin-bottom: 0.45rem; color: var(--muted); }
.price-table-wrap { overflow-x: auto; margin: 1.25rem 0; border-radius: var(--radius); border: 1px solid var(--border); }
.price-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
.price-table th, .price-table td { padding: 0.65rem 0.85rem; text-align: left; border-bottom: 1px solid var(--border); color: var(--muted); }
.price-table th { background: var(--bg-elevated); color: var(--text); font-weight: 600; }
.price-table tbody tr:last-child td { border-bottom: none; }
.def-list { margin: 1rem 0 1.5rem; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.def-list div { padding: 0.85rem 1rem; border-bottom: 1px solid var(--border); }
.def-list div:last-child { border-bottom: none; }
.def-list dt { font-weight: 600; color: var(--text); font-size: 0.95rem; margin: 0 0 0.25rem; }
.def-list dd { margin: 0; color: var(--muted); font-size: 0.92rem; line-height: 1.55; }
.steps-ol { counter-reset: step; padding-left: 0; list-style: none; color: var(--muted); line-height: 1.68; }
.steps-ol li { position: relative; padding-left: 2.75rem; margin-bottom: 1rem; min-height: 1.75rem; }
.steps-ol li::before { counter-increment: step; content: counter(step); position: absolute; left: 0; top: 0; width: 1.85rem; height: 1.85rem; background: var(--accent-soft); color: var(--accent); font-weight: 700; font-size: 0.85rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; border: 1px solid rgba(201, 169, 98, 0.35); }
