.bsh-vs *,
.bsh-vs *::before,
.bsh-vs *::after { box-sizing: border-box; margin: 0; padding: 0; }
.bsh-vs { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; color: var(--dark, #0f1720); line-height: 1.6; overflow: hidden; } .bsh-vs__container { position: relative; z-index: 1; max-width: 1600px; margin: 0 auto; padding: 0 32px; } .bsh-vs__kicker { font-size: .85rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--orange, #eb6a05); margin-bottom: 8px; }
.bsh-vs__heading { font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 800; line-height: 1.2; color: var(--blue-dark, #1b3a61); margin-bottom: 8px; }
.bsh-vs__subtitle { font-size: clamp(1rem, 1.8vw, 1.2rem); font-weight: 400; line-height: 1.55; color: #3c4a59; margin-bottom: 24px; }
.bsh-vs__text   { font-size: 1.05rem; color: #3c4a59; max-width: 640px; margin-bottom: 16px; } .bsh-vs__kicker--light { color: rgba(255,255,255,.65); }
.bsh-vs__heading--light { color: #fff; } .bsh-vs__btn { display: inline-block; padding: 14px 32px; border-radius: 50px 0 50px 0; background: var(--orange, #eb6a05); color: #fff; font-weight: 700; font-size: 1rem; text-decoration: none; transition: background .3s, transform .3s; }
.bsh-vs__btn:hover { background: #cf5c04; transform: translateY(-2px); } .bsh-vs__consent { display: flex; align-items: flex-start; gap: 8px; font-size: .82rem; color: #5a6a7a; margin-top: 10px; cursor: pointer; }
.bsh-vs__consent input[type="checkbox"] { margin-top: 3px; accent-color: var(--orange, #eb6a05); }
.bsh-vs__consent a { color: var(--blue, #4283c4); text-decoration: underline; } .bsh-vs-s1 { padding: 80px 0; background: #f4f7fb; position: relative; overflow: hidden; min-height: 50vh; }
.bsh-vs-s1__bg { position: absolute; inset: 0; z-index: 0; background-size: 20%; background-repeat: no-repeat; background-position: right -60px bottom -60px; opacity: .04; pointer-events: none; }
.bsh-vs-s1 .bsh-vs__container { position: relative; z-index: 2; }
.bsh-vs-s1__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.bsh-vs-s1__body { font-size: 1.05rem; color: #3c4a59; line-height: 1.7; }
.bsh-vs-s1__body p + p { margin-top: 12px; }
.bsh-vs-s1__image { border-top-left-radius: 50%; border-bottom-right-radius: 50%; overflow: hidden; height: 450px; }
.bsh-vs-s1__image img { width: 100%; height: 100%; object-fit: cover; display: block; } .bsh-vs-s2 { position: relative; padding: 80px 0; background: #1b3a61; overflow: hidden;}
.bsh-vs-s2 .bsh-vs__container { position: relative; z-index: 2; }
.bsh-vs-s2 .bsh-vs__heading { color: #fff; }
.bsh-vs-s2 .bsh-vs__subtitle { color: rgba(255,255,255,.85); }
.bsh-vs-s2 .bsh-vs__kicker { color: var(--orange, #eb6a05); }
.bsh-vs-s2__tree {
position: absolute; right: -40px; bottom: -40px;
width: 320px; height: 320px;
background-size: contain; background-repeat: no-repeat; background-position: center;
filter: brightness(0) invert(1); opacity: .1;
pointer-events: none; z-index: 0;
}
.bsh-vs-s2__dots { position: absolute; inset: 0; background: radial-gradient(rgb(66 131 196 / 71%) 1px, transparent 1px); background-size: 9px 9px; opacity: .45; pointer-events: none; }
.bsh-vs-s2__layout { display: grid; grid-template-columns: 1fr 360px; gap: 40px; margin-top: 32px; align-items: start; } .bsh-vs-s2__termine { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; }
.bsh-vs-s2__termin {
background: #fff; border-radius: 0; padding: 28px;
box-shadow: 0 2px 12px rgba(0,0,0,.06);
display: flex; flex-direction: column; gap: 8px;
border-left: 4px solid var(--orange, #eb6a05);
}
.bsh-vs-s2__termin-badge { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--blue, #4283c4); background: #fff; padding: 3px 10px; border-radius: 0; align-self: flex-start; }
.bsh-vs-s2__termin-date { font-size: 1.15rem; font-weight: 700; color: var(--blue-dark, #1b3a61); }
.bsh-vs-s2__termin-time { font-size: .95rem; color: #5a6a7a; } .bsh-vs-s2__sidebar { display: flex; flex-direction: column; gap: 28px; }
.bsh-vs-s2__sidebar-block { background: #fff; border-radius: 0; padding: 28px; box-shadow: 0 2px 12px rgba(0,0,0,.06); }
.bsh-vs-s2__sidebar-heading { font-size: 1rem; font-weight: 700; color: var(--blue-dark, #1b3a61); margin-bottom: 8px; }
.bsh-vs-s2__sidebar-text { font-size: .95rem; color: #5a6a7a; line-height: 1.55; margin-bottom: 14px; }
.bsh-vs-s2__sidebar-block .bsh-vs__btn { font-size: .9rem; padding: 12px 24px; } .bsh-vs-s3 { position: relative; padding: 80px 0; background: var(--blue-dark, #1b3a61); color: #fff; }
.bsh-vs-s3__bg { position: absolute; inset: 0; background-repeat: no-repeat; background-position: right -60px bottom -60px; background-size: 420px; opacity: .04; pointer-events: none; }
.bsh-vs-s3__content { max-width: 680px; }
.bsh-vs-s3__body { font-size: 1.05rem; color: rgba(255,255,255,.8); line-height: 1.7; margin-bottom: 24px; }
.bsh-vs-s3__body p + p { margin-top: 10px; } .bsh-vs-s4 { position: relative; padding: 80px 0; background: var(--light-bg, #f4f7fb); }
.bsh-vs-s4__bg { position: absolute; inset: 0; z-index: 0; background-repeat: no-repeat; background-position: right -60px bottom -60px; background-size: 380px; opacity: .04; pointer-events: none; }
.bsh-vs-s4__wrap { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; background: #fff; padding: 48px; }
.bsh-vs-s4__form { display: flex; flex-direction: column; gap: 6px; }
.bsh-vs-s4__row  { display: flex; gap: 12px; }
.bsh-vs-s4__input { flex: 1; padding: 14px 18px; border: 1px solid #c3cdd8; border-radius: 0; font-size: 1rem; outline: none; }
.bsh-vs-s4__input:focus { border-color: var(--blue, #4283c4); }
.bsh-vs-s4__btn { padding: 14px 28px; border: none; border-radius: 50px 0 50px 0; background: var(--orange, #eb6a05); color: #fff; font-weight: 700; font-size: 1rem; cursor: pointer; transition: background .3s; }
.bsh-vs-s4__btn:hover { background: #cf5c04; } @media (max-width: 900px) {
.bsh-vs-s1__grid,
.bsh-vs-s2__layout,
.bsh-vs-s4__wrap { grid-template-columns: 1fr; }
.bsh-vs-s1__image { order: -1; }
.bsh-vs-s1, .bsh-vs-s2, .bsh-vs-s3, .bsh-vs-s4 { padding: 56px 0; }
}
@media (max-width: 600px) {
.bsh-vs-s4__row { flex-direction: column; }
.bsh-vs-s2__termine { grid-template-columns: 1fr; }
.bsh-vs-s1, .bsh-vs-s2, .bsh-vs-s3, .bsh-vs-s4 { padding: 40px 0; }
}