/* Phase 11A — SEO marketing pages */
.seo-page { padding: 2rem 0 4rem; }
.seo-breadcrumb { font-size: 0.875rem; color: var(--lp-muted, #6b7280); margin-bottom: 1.5rem; }
.seo-breadcrumb a { color: inherit; text-decoration: none; }
.seo-breadcrumb a:hover { text-decoration: underline; }
.seo-hero { max-width: 48rem; margin-bottom: 2.5rem; }
.seo-hero__cta { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 1.5rem; }
.seo-section { margin: 3rem 0; }
.seo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem; }
.seo-card { padding: 1.25rem; border-radius: 12px; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.03); }
.seo-card h3 { font-size: 1rem; margin: 0 0 0.5rem; }
.seo-card p { font-size: 0.875rem; margin: 0; opacity: 0.85; }
.seo-feature-list { display: grid; gap: 0.5rem; padding-left: 1.25rem; }
.seo-ai-block { padding: 1.5rem; border-radius: 12px; background: linear-gradient(135deg, rgba(59,130,246,0.08), rgba(16,185,129,0.06)); border: 1px solid rgba(59,130,246,0.2); margin-bottom: 2rem; }
.seo-ai-block__title { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; opacity: 0.7; margin: 0 0 0.75rem; }
.seo-ai-block__summary { margin: 0 0 1rem; line-height: 1.6; }
.seo-ai-block__faq dt { font-weight: 600; margin-top: 0.75rem; }
.seo-ai-block__faq dd { margin: 0.25rem 0 0; opacity: 0.9; }
.seo-faq__item { border-bottom: 1px solid rgba(255,255,255,0.08); padding: 0.75rem 0; }
.seo-faq__item summary { cursor: pointer; font-weight: 500; }
.seo-reviews { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.seo-review { margin: 0; padding: 1.25rem; border-radius: 12px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06); }
.seo-review footer { font-size: 0.875rem; opacity: 0.75; margin-top: 0.75rem; }
.seo-table-wrap { overflow-x: auto; }
.seo-table { width: 100%; border-collapse: collapse; font-size: 0.9375rem; }
.seo-table th, .seo-table td { padding: 0.75rem 1rem; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.08); }
.seo-table th { font-weight: 600; }
.seo-migration { margin-top: 1rem; padding: 1rem; border-radius: 8px; background: rgba(16,185,129,0.08); }
.seo-related__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1rem; }
.seo-related__link { display: block; padding: 1rem; border-radius: 10px; text-decoration: none; color: inherit; border: 1px solid rgba(255,255,255,0.08); transition: border-color 0.15s; }
.seo-related__link:hover { border-color: rgba(59,130,246,0.5); }
.seo-related__link strong { display: block; margin-bottom: 0.35rem; }
.seo-related__link span { font-size: 0.875rem; opacity: 0.8; }
.seo-cta-band { text-align: center; padding: 3rem 1.5rem; border-radius: 16px; background: linear-gradient(180deg, rgba(59,130,246,0.12), transparent); margin-top: 3rem; }
.seo-footer__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 2rem; margin-bottom: 2rem; }
.seo-footer__grid ul { list-style: none; padding: 0; margin: 0.5rem 0 0; }
.seo-footer__grid a { color: inherit; opacity: 0.85; text-decoration: none; font-size: 0.875rem; }
.seo-footer__grid a:hover { opacity: 1; text-decoration: underline; }
.seo-footer__copy { font-size: 0.8125rem; opacity: 0.6; border-top: 1px solid rgba(255,255,255,0.08); padding-top: 1.5rem; }
.seo-blog-list { display: grid; gap: 1.5rem; }
.seo-blog-card { padding: 1.5rem; border-radius: 12px; border: 1px solid rgba(255,255,255,0.08); }
.seo-blog-card a { color: inherit; text-decoration: none; }
.seo-blog-card h2 { margin: 0 0 0.5rem; font-size: 1.25rem; }
.seo-blog-meta { font-size: 0.8125rem; opacity: 0.7; }
.seo-article-body { max-width: 42rem; line-height: 1.7; }
.seo-article-body p { margin: 0 0 1rem; }
@media (prefers-reduced-motion: no-preference) {
  .seo-card, .seo-related__link { transition: transform 0.15s ease; }
  .seo-related__link:hover { transform: translateY(-2px); }
}
