/* SafeComments — marketing.css (platform, feature, compare pages) */

.mkt-page { padding-block: 48px 80px; }
.mkt-container { max-width: var(--maxw); margin-inline: auto; padding-inline: 24px; }
.mkt-breadcrumb { display: flex; flex-wrap: wrap; gap: 8px; font-size: 14px; color: var(--text-3); margin-bottom: 24px; }
.mkt-breadcrumb a { color: var(--text-2); }
.mkt-breadcrumb a:hover { color: var(--brand); }
.mkt-breadcrumb [aria-current="page"] { color: var(--text); font-weight: 500; }
.mkt-breadcrumb .sep { opacity: 0.5; }

.mkt-hero { max-width: 42rem; margin-bottom: 48px; }
.mkt-hero .eyebrow { font-family: var(--font-jetbrains-mono, 'JetBrains Mono', monospace); font-size: 13px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brand); margin-bottom: 14px; display: block; }
.mkt-hero h1 { font-size: clamp(32px, 4.5vw, 48px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.08; }
.mkt-hero .sub { margin-top: 18px; font-size: 18px; line-height: 1.55; color: var(--text-3); max-width: 36em; }

.mkt-callout { margin: 40px 0; padding: 24px 28px; border-radius: var(--r-lg); border: 1px solid color-mix(in srgb, var(--brand) 25%, var(--border)); background: var(--brand-light); font-size: 17px; line-height: 1.5; color: var(--text-2); }
[data-theme="dark"] .mkt-callout { background: color-mix(in srgb, var(--brand) 12%, var(--surface-2)); color: var(--text-2); }

.mkt-section { margin-bottom: 48px; }
.mkt-section h2 { font-size: clamp(24px, 3vw, 32px); font-weight: 700; letter-spacing: -0.02em; margin-bottom: 16px; }
.mkt-section h3 { font-size: 20px; font-weight: 600; margin: 24px 0 10px; }
.mkt-section p { font-size: 17px; line-height: 1.6; color: var(--text-2); margin-bottom: 14px; }
.mkt-section ul { margin: 0 0 16px; padding-inline-start: 1.35em; }
.mkt-section li { font-size: 17px; line-height: 1.55; color: var(--text-2); margin-bottom: 10px; }

.mkt-pick { display: grid; gap: 20px; margin: 32px 0; }
@media (min-width: 768px) { .mkt-pick { grid-template-columns: 1fr 1fr; } }
.mkt-pick-card { padding: 24px; border-radius: var(--r-lg); border: 1px solid var(--border); background: var(--surface-2); }
.mkt-pick-card h3 { margin: 0 0 10px; font-size: 18px; }
.mkt-pick-card p { margin: 0; font-size: 15px; }

.mkt-compare-wrap { overflow-x: auto; margin: 32px 0; -webkit-overflow-scrolling: touch; }
.mkt-compare { width: 100%; min-width: 520px; border-collapse: collapse; font-size: 15px; }
.mkt-compare th, .mkt-compare td { border: 1px solid var(--border); padding: 14px 16px; text-align: start; vertical-align: top; }
.mkt-compare thead th { background: var(--surface-2); font-weight: 600; }
.mkt-compare tbody th { background: var(--surface-3); font-weight: 500; width: 28%; }

.mkt-faq { margin-top: 48px; }
.mkt-faq h2 { font-size: 28px; font-weight: 700; margin-bottom: 20px; }
.mkt-faq details { border: 1px solid var(--border); border-radius: var(--r-md); margin-bottom: 10px; background: var(--surface); }
.mkt-faq summary { padding: 16px 18px; font-weight: 600; cursor: pointer; list-style: none; }
.mkt-faq summary::-webkit-details-marker { display: none; }
.mkt-faq details[open] summary { border-bottom: 1px solid var(--border); }
.mkt-faq .ans { padding: 14px 18px 18px; font-size: 15px; line-height: 1.55; color: var(--text-2); }

.mkt-related { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--border); }
.mkt-related h2 { font-size: 20px; margin-bottom: 14px; }
.mkt-related ul { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 10px 20px; }
.mkt-related a { font-size: 15px; font-weight: 500; color: var(--brand); text-decoration: underline; text-underline-offset: 3px; }

.mkt-cta { margin-top: 56px; padding: 40px; border-radius: var(--r-lg); background: var(--surface-2); border: 1px solid var(--border); text-align: center; }
.mkt-cta h2 { font-size: 24px; font-weight: 700; margin-bottom: 10px; }
.mkt-cta p { font-size: 16px; color: var(--text-3); margin-bottom: 20px; max-width: 32em; margin-inline: auto; }
.mkt-cta .btns { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
