@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,700;12..96,800&family=Instrument+Sans:wght@400;500;600&display=swap');

/* ============================================================
   VDV BENEFIT – Redesign Override  (nach site.css einbinden)
   ============================================================ */

:root{
  --vdv-red:#e30613; --vdv-red-dark:#b00510; --vdv-anthracite:#3d3e3e;
  --vdv-pink:#ffd7da; --vdv-paper:#fbf9f5; --vdv-ink:#1b1426;
  --vdv-mute:#6a6b6f; --vdv-line:rgba(43,44,44,.12);
  --acc-sky:#1fc4f0; --acc-sun:#ffc83d; --acc-mint:#19cf8f;
  --acc-mint-dark:#11b87e; --acc-plum:#241638;
  --r:24px; --shadow:0 20px 44px rgba(43,44,44,.10); --shadow-lg:0 30px 60px rgba(43,44,44,.16);
  --font-display:"Bricolage Grotesque",sans-serif;
  --font-body:"Instrument Sans",system-ui,sans-serif;
}

/* ---------- Schrift global ---------- */
body{background:var(--vdv-paper) !important;color:var(--vdv-ink);font-family:var(--font-body) !important}
.section,.section p,.section li,.section a,.section span,
.hero-split,.usp-block,.cta-grid{font-family:var(--font-body)}
h1,h2,h3,.section h1,.section h2,.section h3,
.hero-split h1,.usp-block h2,.cta-grid h3,.kicker{
  font-family:var(--font-display) !important;text-transform:none !important;letter-spacing:-.02em}

/* ---------- Accordion (aufklappbar) ---------- */
.section-accordion .acc-title{font-family:var(--font-display);font-weight:800;
  font-size:clamp(28px,3.4vw,40px);margin:0 0 28px}
.section-accordion .acc-list{display:flex;flex-direction:column;gap:16px}
.acc-item{background:#fff;border:1px solid var(--vdv-line);border-radius:20px;
  box-shadow:0 6px 20px rgba(43,44,44,.05);overflow:hidden}
.acc-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;
  justify-content:space-between;gap:18px;padding:22px 26px}
.acc-item summary::-webkit-details-marker{display:none}
.acc-sum-text{min-width:0}
.acc-sum-title{display:block;font-family:var(--font-display);font-weight:700;
  font-size:19px;color:var(--vdv-ink);line-height:1.25}
.acc-sum-sub{display:block;margin-top:3px;font-size:14px;color:var(--acc-plum);font-weight:600}
.acc-chevron{flex:0 0 auto;width:11px;height:11px;margin-right:2px;
  border-right:2.5px solid var(--vdv-red);border-bottom:2.5px solid var(--vdv-red);
  transform:translateY(-3px) rotate(45deg);transition:transform .25s}
.acc-item[open] .acc-chevron{transform:translateY(2px) rotate(-135deg)}
.acc-item[open] summary{border-bottom:1px solid var(--vdv-line)}
.acc-body{padding:8px 26px 26px}
.acc-body .acc-h{font-family:var(--font-display);font-weight:700;font-size:15px;
  color:var(--vdv-ink);margin:18px 0 8px}
.acc-body .acc-h:first-child{margin-top:6px}
.acc-body .acc-li{position:relative;padding-left:22px;margin:6px 0;line-height:1.55;
  color:var(--vdv-ink-soft,#444)}
.acc-body .acc-li::before{content:"";position:absolute;left:4px;top:9px;width:7px;height:7px;
  border-radius:50%;background:var(--vdv-red)}

/* ---------- Layout-Basis ---------- */
.section{padding:90px 0}
.section + .section{padding-top:0}
.container{max-width:1240px;padding-left:28px;padding-right:28px}

/* alle Sektionen cremefarben, nur das Logo-Band weiß */
#maincontent > section{background:var(--vdv-paper)}
.section-logo-marquee{background:#fff !important}

/* ---------- Kicker ---------- */
.kicker{display:inline-flex !important;align-items:center;gap:9px;font-size:13px !important;
  font-weight:600 !important;letter-spacing:.1em !important;text-transform:uppercase !important;
  color:var(--acc-plum) !important;margin-bottom:10px}
.kicker::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--vdv-red)}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:14px 26px;border-radius:999px;font-weight:600;font-size:15px;
  background:var(--vdv-red);color:#fff !important;border:none;text-transform:none !important;
  box-shadow:0 10px 22px rgba(227,6,19,.22);
  transition:transform .2s,background .2s,box-shadow .2s;text-decoration:none;font-family:var(--font-body)}
.btn:hover{transform:translateY(-3px);background:var(--vdv-red-dark) !important;color:#fff !important;
  box-shadow:0 16px 30px rgba(227,6,19,.30) !important}
.btn--ghost{background:transparent !important;color:var(--vdv-ink) !important;
  border:1.5px solid var(--vdv-ink) !important;box-shadow:none !important}
.btn--ghost:hover{background:var(--vdv-ink) !important;color:#fff !important}

/* ---------- Überschriften dunkel ---------- */
.section h2{font-size:clamp(30px,4vw,48px);line-height:1.02;margin:0 0 18px;color:var(--vdv-ink)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:100;
  background:rgba(251,249,245,.82) !important;
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:none}
.site-header .header-top{background:transparent !important;border:none !important;padding:4px 0 0}
.site-header.scrolled{box-shadow:0 2px 16px rgba(27,20,38,.08)}
.header-main .container{display:flex;align-items:center;gap:26px;flex-wrap:nowrap}
.main-nav{display:flex;align-items:center;gap:30px;margin-left:auto}
.main-nav a{text-transform:none !important;font-family:var(--font-body) !important;
  font-weight:600 !important;font-size:15px;letter-spacing:0;position:relative}
.main-nav a:not(.nav-home)::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2.5px;
  background:var(--vdv-red);border-radius:2px;transition:width .25s}
.main-nav a:not(.nav-home):hover::after,.main-nav a:not(.nav-home).active::after{width:100%}
.main-nav a.nav-home{display:none !important}
.site-header .header-top .container{display:flex;justify-content:flex-end}
.lang-switcher{display:flex;align-items:center;gap:8px}
.lang-switcher a{line-height:0;border:none !important}
.lang-switcher a img{height:15px;width:auto;border-radius:2px;opacity:.7;transition:opacity .2s}
.lang-switcher a:hover img,.lang-switcher a.active img{opacity:1}
/* grüner Händler-Button */
.nav-cta{display:inline-flex !important;align-items:center;background:var(--acc-mint) !important;
  color:#06231a !important;padding:11px 22px;border-radius:999px;font-weight:600;font-size:14px;
  font-family:var(--font-body) !important;white-space:nowrap;text-decoration:none;flex:0 0 auto;
  transition:transform .2s,background .2s}
.nav-cta::after{display:none !important}
.nav-cta:hover{background:var(--acc-mint-dark) !important;transform:translateY(-2px);color:#06231a !important}

/* ============================================================
   FOOTER (mehrspaltig, dunkel)
   ============================================================ */
.site-footer{background:#161616 !important;color:rgba(255,255,255,.66);text-align:left;
  border-top:none !important;border-bottom:4px solid var(--vdv-red);
  padding:64px 0 34px;margin-top:0}
.site-footer .container{display:block;max-width:1240px}
.site-footer a{color:rgba(255,255,255,.78) !important;text-decoration:none !important;
  border:none !important;box-shadow:none !important}
.site-footer a:hover{color:#fff !important}
.site-footer .footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:48px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12);text-align:left}
.site-footer .footer-col{text-align:left}
.site-footer .footer-logo{height:54px;width:auto;background:#fff;padding:12px 16px;
  border-radius:12px;display:inline-block}
.site-footer .footer-blurb{margin:18px 0 0;font-size:14.5px;line-height:1.6;
  color:rgba(255,255,255,.58);max-width:42ch}
.site-footer .footer-col h4{color:#fff;font-family:var(--font-display);font-size:13px;
  text-transform:uppercase;letter-spacing:.12em;margin:0 0 16px}
.site-footer .footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:11px;font-size:15px}
.site-footer .footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding-top:22px;font-size:13.5px;color:rgba(255,255,255,.5)}
.site-footer .footer-langs a{margin:0 3px}

/* ============================================================
   BESTANDS-SEKTIONEN
   ============================================================ */
.hero-overlay{background:linear-gradient(180deg,rgba(36,22,56,.15),rgba(36,22,56,.55))}
.hero-overlay h1{font-size:clamp(40px,6vw,76px);line-height:.98;text-shadow:0 4px 24px rgba(0,0,0,.45)}
.hero-overlay p{font-size:clamp(16px,2vw,22px);max-width:32ch;text-shadow:0 2px 14px rgba(0,0,0,.45)}

.text-with-image{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.text-with-image .image-col img{border-radius:var(--r);width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow)}
.text-with-image .text-col p{color:var(--vdv-mute);font-size:16.5px;max-width:52ch}
.text-with-image.image-left .text-col{order:2}
.text-with-image .text-col .btn{margin-top:22px}
.text-with-image .twi-seals{display:flex;flex-wrap:wrap;gap:14px;margin-top:18px}
.text-with-image .twi-seals img{height:74px;width:auto;background:#fff;border:1px solid var(--vdv-line);
  border-radius:16px;padding:12px 18px;box-shadow:0 6px 18px rgba(43,44,44,.06);object-fit:contain}

.logo-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:48px;padding:8px 0}
.logo-row img{height:60px;width:auto;object-fit:contain;transition:transform .25s}
.logo-row img:hover{transform:scale(1.08)}
.section-logo-grid .logo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
  gap:36px;align-items:center;justify-items:center}
.section-logo-grid .logo-grid img{max-height:64px;width:auto;object-fit:contain}

.section-cta .cta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.section-cta .cta-grid > *{background:#fff;border:1px solid var(--vdv-line);border-radius:var(--r);
  overflow:hidden;transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.section-cta .cta-grid > *:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.section-cta .cta-grid img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .4s}
.section-cta .cta-grid > *:hover img{transform:scale(1.05)}
.section-cta .cta-grid h3{font-size:21px;color:var(--vdv-red) !important;margin:20px 24px 0}
.section-cta .cta-grid p{color:var(--vdv-mute);font-size:14.5px;margin:8px 24px 18px;flex:1}
.section-cta .cta-grid .btn{margin:0 24px 24px;align-self:center}

.event-card{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);background:#fff}
.event-info{padding:22px 26px}
.event-info h3{color:var(--vdv-red) !important;margin:0 0 4px}

/* ============================================================
   NEUE SEKTIONEN
   ============================================================ */
.section-hero-split{padding:112px 0 90px;overflow:hidden}
.hero-split{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.section-hero-split h1{position:relative;z-index:0;font-weight:800;font-size:clamp(46px,6.2vw,82px);line-height:.92;margin:18px 0 22px}
.hero-split h1 .hl{position:relative;white-space:nowrap;font-family:var(--font-display) !important;font-weight:inherit}
.hero-split h1 .hl::after{content:"";position:absolute;left:-.06em;right:-.06em;bottom:.04em;
  height:.30em;background:var(--acc-sun);border-radius:.55em .5em .45em .6em;
  transform:rotate(-1.4deg);z-index:-1}
.hero-split__lead{font-size:18px;max-width:46ch;color:#4a4b4f;margin:0}
.hero-split__actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-split__stats{display:flex;gap:34px;margin-top:42px;flex-wrap:wrap}
.hero-split__stats .stat__n{font-family:var(--font-display);font-weight:800;font-size:32px;line-height:1;color:var(--vdv-red)}
.hero-split__stats .stat__l{font-size:13.5px;color:var(--vdv-mute);margin-top:4px;max-width:17ch}
.hero-split__media img{border-radius:var(--r);width:100%;aspect-ratio:5/5.4;object-fit:cover;box-shadow:var(--shadow-lg)}
.hero-split__ph{border-radius:var(--r);aspect-ratio:5/5.4;background:#eee;display:flex;align-items:center;justify-content:center;color:#aaa}

.section-logo-marquee{padding:64px 0 44px;border-top:1px solid var(--vdv-line);border-bottom:1px solid var(--vdv-line);background:#fff}
.section-logo-marquee .kicker{display:flex !important;justify-content:center;margin-bottom:26px}
.logo-marquee{overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.logo-marquee__track{display:flex;align-items:center;gap:52px;width:max-content;animation:vdv-scroll 40s linear infinite}
.logo-marquee__track img{height:58px;width:auto;object-fit:contain}
.logo-marquee:hover .logo-marquee__track{animation-play-state:paused}
@keyframes vdv-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.section-usp{padding-top:0}
.usp-block{background:var(--acc-plum);color:var(--vdv-paper);border-radius:30px;padding:60px;
  position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;
  background-image:radial-gradient(rgba(255,255,255,.05) 1.5px,transparent 1.5px);background-size:26px 26px}
.usp-block .kicker{color:#fff !important}
.usp-block .kicker::before{background:var(--acc-sun)}
.usp-block .usp-confetti{position:absolute;inset:0;z-index:1;pointer-events:none}
.usp-block .usp-confetti span{position:absolute;width:13px;height:13px;border-radius:3px;opacity:.9}
.usp-block__text,.usp-block__media{position:relative;z-index:2}
.usp-block__big{font-family:var(--font-display);font-weight:800;font-size:clamp(80px,11vw,150px);
  line-height:.82;letter-spacing:-.04em;color:var(--acc-sun);margin:14px 0 8px}
.usp-block__big small{display:block;font-size:.17em;letter-spacing:.08em;color:#fff;margin-top:10px}
.usp-block h2{color:#fff !important;margin:8px 0 14px}
.usp-block p{color:rgba(251,249,245,.78);font-size:17px;max-width:46ch}
.usp-block__seal{display:inline-block;margin-top:22px;font-weight:600;font-size:14px;
  border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:10px 18px}
.usp-block__media img{border-radius:18px;width:100%;aspect-ratio:4/3;object-fit:cover}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:880px){
  .section{padding:60px 0}
  .header-main .container{flex-wrap:wrap;gap:14px}
  .main-nav{gap:18px}
  .text-with-image{grid-template-columns:1fr;gap:28px}
  .text-with-image.image-left .text-col{order:0}
  .section-cta .cta-grid{grid-template-columns:1fr}
  .logo-row{gap:30px}.logo-row img{height:46px}
  .hero-split{grid-template-columns:1fr;gap:30px}
  .hero-split__media{order:-1}
  .usp-block{grid-template-columns:1fr;gap:26px;padding:34px}
  .site-footer .footer-grid{grid-template-columns:1fr;gap:28px}
}

.lang-switcher img{height:16px;width:auto;display:block;border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.12)}
.lang-switcher a{opacity:.5;transition:opacity .2s}
.lang-switcher a.active,.lang-switcher a:hover{opacity:1}

.site-header .site-logo img{transition:transform .25s;transform-origin:left center}
.site-header.scrolled .site-logo img{transform:scale(.85)}

html{ overflow-anchor: none; }

.site-header .header-top{ padding-top:10px !important; padding-bottom:0 !important; }
.site-header .header-main{ padding-top:4px !important; }