/* === Vergleich (Comparison Pages) === */
/* Reuses lp-* tokens from Landing/style.css (loaded via _EmptyLayout) */

.vs-page { background:#fff; color:#0F172A; min-height:100vh; }
.vs-container { max-width:1080px; margin:0 auto; padding:0 24px; }

/* === Hero === */
.vs-hero { padding:120px 0 60px; text-align:center; position:relative; }
.vs-eyebrow {
    display:inline-block; padding:6px 14px; border-radius:999px;
    background:linear-gradient(135deg,#7C3AED11,#DB277711);
    color:#7C3AED; font-size:13px; font-weight:600; letter-spacing:0.04em;
    text-transform:uppercase; margin-bottom:18px;
}
.vs-h1 { font-size:clamp(32px,5.5vw,54px); font-weight:800; line-height:1.1; letter-spacing:-0.02em; margin:0 0 18px 0; }
.vs-h1 em { font-style:normal; background:linear-gradient(135deg,#7C3AED,#DB2777); -webkit-background-clip:text; background-clip:text; color:transparent; }
.vs-sub { font-size:clamp(16px,2.2vw,19px); color:#475569; max-width:780px; margin:0 auto 28px; line-height:1.55; }
.vs-cta-row { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.vs-cta-primary { display:inline-flex; align-items:center; gap:8px; background:linear-gradient(135deg,#7C3AED,#DB2777); color:#fff; padding:14px 24px; border-radius:12px; font-weight:600; text-decoration:none; box-shadow:0 8px 24px -8px rgba(124,58,237,0.5); transition:transform 0.2s; }
.vs-cta-primary:hover { transform:translateY(-2px); }
.vs-cta-ghost { display:inline-flex; align-items:center; gap:8px; padding:14px 24px; border-radius:12px; border:1px solid #E2E8F0; color:#0F172A; text-decoration:none; font-weight:600; }
.vs-cta-ghost:hover { background:#F8FAFC; }

/* === TL;DR Box === */
.vs-tldr { margin:48px auto; max-width:760px; padding:24px 28px; background:linear-gradient(135deg,#FAF5FF,#FDF2F8); border:1px solid #F3E8FF; border-radius:16px; }
.vs-tldr-head { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:#7C3AED; letter-spacing:0.05em; text-transform:uppercase; margin-bottom:12px; }
.vs-tldr ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.vs-tldr li { padding-left:24px; position:relative; line-height:1.55; color:#1E293B; font-size:15px; }
.vs-tldr li::before { content:"→"; position:absolute; left:0; color:#7C3AED; font-weight:700; }

/* === Section === */
.vs-section { padding:60px 0; }
.vs-section h2 { font-size:clamp(24px,3.5vw,36px); font-weight:800; letter-spacing:-0.02em; margin:0 0 12px 0; line-height:1.2; }
.vs-section h2 em { font-style:normal; background:linear-gradient(135deg,#7C3AED,#DB2777); -webkit-background-clip:text; background-clip:text; color:transparent; }
.vs-section h3 { font-size:21px; font-weight:700; margin:28px 0 10px 0; color:#0F172A; }
.vs-section p { color:#475569; line-height:1.7; margin:0 0 14px 0; }
.vs-section-lede { font-size:17px; color:#475569; line-height:1.6; margin-bottom:28px; max-width:720px; }

/* === Compare Table === */
.vs-table-wrap { border:1px solid #E2E8F0; border-radius:16px; overflow:hidden; background:#fff; box-shadow:0 4px 24px -8px rgba(15,23,42,0.06); }
.vs-table { width:100%; border-collapse:collapse; }
.vs-table thead th {
    background:linear-gradient(135deg,#FAFAFC,#F1F5F9);
    padding:18px 20px; text-align:left; font-size:13px; font-weight:700;
    color:#0F172A; border-bottom:1px solid #E2E8F0; letter-spacing:0.02em;
}
.vs-table thead th.vs-th-us { background:linear-gradient(135deg,#7C3AED,#DB2777); color:#fff; }
.vs-table tbody td { padding:14px 20px; border-bottom:1px solid #F1F5F9; font-size:14.5px; color:#1E293B; vertical-align:top; }
.vs-table tbody tr:last-child td { border-bottom:0; }
.vs-table tbody td:first-child { font-weight:600; color:#0F172A; }
.vs-table .vs-cat-row td { background:#F8FAFC; font-size:11px; font-weight:700; color:#7C3AED; text-transform:uppercase; letter-spacing:0.06em; padding:10px 20px; }
.vs-yes { color:#16A34A; font-weight:700; }
.vs-no  { color:#DC2626; font-weight:700; }
.vs-meh { color:#CA8A04; font-weight:700; }

/* === Price Compare === */
.vs-price-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:32px 0; }
@@media (max-width:680px) { .vs-price-grid { grid-template-columns:1fr; } }
.vs-price-card { padding:28px; border-radius:16px; border:1px solid #E2E8F0; background:#fff; }
.vs-price-card.us { background:linear-gradient(135deg,#FAF5FF,#FDF2F8); border-color:#E9D5FF; }
.vs-price-name { font-size:13px; font-weight:700; color:#7C3AED; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:8px; }
.vs-price-card.them .vs-price-name { color:#64748B; }
.vs-price-num { font-size:42px; font-weight:800; letter-spacing:-0.02em; }
.vs-price-per { color:#64748B; font-size:14px; margin-top:4px; }
.vs-price-line { height:1px; background:#E2E8F0; margin:16px 0; }
.vs-price-feats { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.vs-price-feats li { font-size:14px; color:#1E293B; padding-left:22px; position:relative; line-height:1.5; }
.vs-price-feats li::before { content:"✓"; position:absolute; left:0; color:#16A34A; font-weight:700; }
.vs-price-feats li.no::before { content:"✗"; color:#DC2626; }
.vs-savings-banner { margin:20px 0 0; padding:16px 20px; background:linear-gradient(135deg,#7C3AED,#DB2777); color:#fff; border-radius:12px; text-align:center; font-weight:600; }
.vs-savings-banner b { font-size:1.15em; }

/* === Two-Column "Wann passt was" === */
.vs-when-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:24px 0; }
@@media (max-width:680px) { .vs-when-grid { grid-template-columns:1fr; } }
.vs-when-card { padding:24px; border-radius:14px; border:1px solid #E2E8F0; background:#fff; }
.vs-when-card.us { border-color:#E9D5FF; background:linear-gradient(135deg,#FAF5FF,#FDF2F8); }
.vs-when-card h4 { margin:0 0 14px 0; font-size:17px; font-weight:700; }
.vs-when-card.us h4 { color:#7C3AED; }
.vs-when-card ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.vs-when-card li { padding-left:22px; position:relative; line-height:1.5; font-size:14.5px; color:#1E293B; }
.vs-when-card li::before { content:""; position:absolute; left:0; top:7px; width:8px; height:8px; border-radius:999px; background:#94A3B8; }
.vs-when-card.us li::before { background:linear-gradient(135deg,#7C3AED,#DB2777); }

/* === FAQ === */
.vs-faq { display:flex; flex-direction:column; gap:10px; max-width:820px; margin:0 auto; }
.vs-faq-item { border:1px solid #E2E8F0; border-radius:12px; background:#fff; overflow:hidden; }
.vs-faq-q { width:100%; text-align:left; padding:18px 20px; background:transparent; border:0; cursor:pointer; font-weight:600; font-size:15px; color:#0F172A; display:flex; justify-content:space-between; align-items:center; gap:12px; }
.vs-faq-q-icon { flex-shrink:0; transition:transform 0.2s; }
.vs-faq-item.open .vs-faq-q-icon { transform:rotate(45deg); }
.vs-faq-a { max-height:0; overflow:hidden; transition:max-height 0.3s ease; }
.vs-faq-item.open .vs-faq-a { max-height:600px; }
.vs-faq-a-inner { padding:0 20px 18px 20px; color:#475569; line-height:1.65; font-size:14.5px; }

/* === Final CTA === */
.vs-cta-final { margin:48px 0 0; padding:48px 32px; border-radius:24px; background:linear-gradient(135deg,#0F0B1F,#3B0F4F); color:#fff; text-align:center; position:relative; overflow:hidden; }
.vs-cta-final::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 20% 30%, rgba(124,58,237,0.4), transparent 60%), radial-gradient(circle at 80% 70%, rgba(219,39,119,0.4), transparent 60%); }
.vs-cta-final > * { position:relative; }
.vs-cta-final h2 { color:#fff; margin:0 0 12px 0; font-size:clamp(24px,3.5vw,34px); }
.vs-cta-final p { color:rgba(255,255,255,0.75); max-width:520px; margin:0 auto 24px; font-size:16px; }
.vs-cta-final-btn { display:inline-flex; align-items:center; gap:8px; background:#fff; color:#0F172A; padding:14px 28px; border-radius:12px; font-weight:700; text-decoration:none; box-shadow:0 12px 32px -8px rgba(0,0,0,0.4); transition:transform 0.2s; }
.vs-cta-final-btn:hover { transform:translateY(-2px); }
.vs-cta-final-sub { display:block; margin-top:16px; color:rgba(255,255,255,0.6); font-size:13px; }

/* === Internal Links === */
.vs-related { padding:48px 0 80px; border-top:1px solid #E2E8F0; }
.vs-related h3 { text-align:center; font-size:22px; font-weight:700; margin:0 0 24px 0; }
.vs-related-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; }
.vs-related-card { padding:18px 20px; border:1px solid #E2E8F0; border-radius:12px; background:#fff; text-decoration:none; color:#0F172A; transition:all 0.2s; }
.vs-related-card:hover { border-color:#7C3AED; transform:translateY(-2px); box-shadow:0 8px 24px -8px rgba(124,58,237,0.2); }
.vs-related-card-label { font-size:12px; color:#64748B; margin-bottom:4px; }
.vs-related-card-name { font-weight:700; font-size:16px; }

/* === Breadcrumbs === */
.vs-breadcrumb { font-size:13px; color:#64748B; padding:24px 0 0; }
.vs-breadcrumb a { color:#64748B; text-decoration:none; }
.vs-breadcrumb a:hover { color:#7C3AED; }
.vs-breadcrumb-sep { margin:0 8px; opacity:0.5; }

/* === Hub === */
.vs-hub { padding:120px 0 80px; }
.vs-hub-cat { margin-top:40px; }
.vs-hub-cat-title { font-size:13px; font-weight:700; color:#7C3AED; text-transform:uppercase; letter-spacing:0.06em; margin:0 0 14px 0; }
.vs-hub-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.vs-hub-card { padding:22px; border:1px solid #E2E8F0; border-radius:14px; background:#fff; text-decoration:none; color:#0F172A; transition:all 0.2s; display:block; }
.vs-hub-card:hover { border-color:#7C3AED; transform:translateY(-3px); box-shadow:0 12px 32px -10px rgba(124,58,237,0.25); }
.vs-hub-card-name { font-size:18px; font-weight:700; margin-bottom:6px; }
.vs-hub-card-desc { font-size:13.5px; color:#64748B; line-height:1.5; }
.vs-hub-card-arrow { display:inline-block; margin-top:12px; color:#7C3AED; font-weight:600; font-size:13px; }
