/* === Shopware Versionen & Roadmap – Section-Design (Namespace .vh-) === */
.shopware-versions main.content.vh-page { max-width: none !important; padding: 0 !important; flex-grow: 1 !important; background: #f7fafd; }
.vh-container { max-width: 1100px; padding: 0 0 0 80px; margin: 0; box-sizing: border-box; }
@media (max-width: 768px) { .vh-container { padding: 0 20px; } }
.vh-page, .vh-page h1, .vh-page h2, .vh-page h3 { color: #1a2b3c; }
.vh-page p { line-height: 1.7; color: #334155; }

/* Hero */
.vh-hero { background: linear-gradient(135deg, #eef4fb 0%, #f7fbff 55%, #eaf3fb 100%); border-bottom: 1px solid #d4e4f4; padding: 30px 0 44px; }
.vh-hero-grid { display: grid; grid-template-columns: 1fr 280px; gap: 44px; align-items: center; }
.vh-hero h1 { font-size: 2.3rem; font-weight: 800; letter-spacing: -0.025em; line-height: 1.15; margin: 0 0 14px; color: #0d2137; }
.vh-hero h1 span { color: #0d5a93; }
.vh-hero-sub { font-size: 1.1rem; line-height: 1.6; color: #475569; max-width: 600px; margin: 0 0 24px; }
.vh-hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }
.vh-hero-visual { text-align: center; }
.vh-hero-visual img { width: 100%; max-width: 240px; height: auto; }

/* Buttons */
.vh-btn { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 1rem; padding: 13px 24px; border-radius: 9px; text-decoration: none; transition: transform .15s, box-shadow .2s, background .2s; }
.vh-btn svg { width: 16px; height: 16px; }
.vh-btn-primary { background: #0d5a93; color: #fff; box-shadow: 0 6px 16px rgba(13,90,147,0.25); }
.vh-btn-primary:hover { background: #094a7a; color: #fff; transform: translateY(-2px); text-decoration: none; }
.vh-btn-ghost { background: #fff; color: #0d5a93; border: 1px solid #c7ddf0; }
.vh-btn-ghost:hover { background: #eef5fb; color: #0d5a93; transform: translateY(-2px); text-decoration: none; }

/* Sections */
.vh-section { padding: 40px 0; }
.vh-section + .vh-section { padding-top: 0; }
.vh-section-head { max-width: 760px; margin: 0 0 22px; }
.vh-section-head h2 { font-size: 1.55rem; font-weight: 800; letter-spacing: -0.02em; margin: 0 0 8px; }
.vh-section-head p { color: #586878; font-size: 1.02rem; line-height: 1.6; margin: 0; }

/* Karten */
.vh-card { background: #fff; border: 1px solid #e6eef4; border-radius: 16px; padding: 26px 28px; box-shadow: 0 4px 18px rgba(13,33,55,0.06); margin-bottom: 18px; }
.vh-card h3 { font-size: 1.2rem; font-weight: 800; margin: 0 0 8px; color: #0d2137; }
.vh-card p:last-child { margin-bottom: 0; }
.vh-card a { color: #0d5a93; font-weight: 600; }

/* Schnell-Links Grid */
.vh-links { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.vh-link { display: flex; align-items: flex-start; gap: 12px; background: #fff; border: 1px solid #e6eef4; border-radius: 13px; padding: 18px; text-decoration: none; transition: transform .15s, box-shadow .2s, border-color .2s; }
.vh-link:hover { transform: translateY(-3px); box-shadow: 0 12px 26px rgba(13,90,147,0.1); border-color: #b9d6ef; text-decoration: none; }
.vh-link-ico { flex: 0 0 auto; width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; background: #eef5fb; color: #0d5a93; border-radius: 11px; }
.vh-link-ico svg { width: 21px; height: 21px; }
.vh-link-body { min-width: 0; }
.vh-link-title { font-weight: 700; color: #0d2137; font-size: 1rem; margin: 0 0 3px; }
.vh-link-text { font-size: 0.88rem; color: #64748b; line-height: 1.45; margin: 0; }

/* FAQ-Accordion */
.vh-page .accordion-item { border: 1px solid #e6eef4; border-radius: 12px !important; margin-bottom: 10px; overflow: hidden; box-shadow: 0 2px 8px rgba(13,33,55,0.04); background: #fff; }
.vh-page .accordion-button { font-weight: 700; color: #0d2137; }
.vh-page .accordion-button:not(.collapsed) { background: #eef5fb; color: #0d5a93; box-shadow: none; }
.vh-page .accordion-button:focus { box-shadow: 0 0 0 .2rem rgba(13,90,147,0.18); }
.vh-page .accordion-body { color: #334155; }
.vh-page .accordion-body a { color: #0d5a93; font-weight: 600; }

/* CTA-Band */
.vh-cta { background: linear-gradient(135deg, #0d5a93 0%, #0a4a7a 100%); color: #fff; border-radius: 18px; padding: 34px; text-align: center; }
.vh-cta h2 { color: #fff; font-size: 1.45rem; font-weight: 800; margin: 0 0 8px; }
.vh-cta p { color: #d6e6f3; margin: 0 auto 20px; max-width: 580px; }
.vh-cta .vh-btn-primary { background: #fff; color: #0d5a93; }
.vh-cta .vh-btn-primary:hover { background: #eef5fb; color: #0d5a93; }

@media (max-width: 860px) {
  .vh-hero-grid { grid-template-columns: 1fr; gap: 20px; }
  .vh-hero-visual { display: none; }
  .vh-hero h1 { font-size: 1.9rem; }
  .vh-links { grid-template-columns: 1fr; }
}
