.bsh-vm *,
.bsh-vm *::before,
.bsh-vm *::after { box-sizing: border-box; margin: 0; padding: 0; }
.bsh-vm { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; color: var(--dark, #0f1720); line-height: 1.6; overflow: hidden; } .bsh-vm__container { position: relative; z-index: 1; max-width: 1600px; margin: 0 auto; padding: 0 32px; } .bsh-vm__kicker { font-size: .85rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--orange, #eb6a05); margin-bottom: 8px; }
.bsh-vm__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-vm__subtitle { font-size: clamp(1rem, 1.8vw, 1.2rem); font-weight: 400; line-height: 1.55; color: #3c4a59; margin-bottom: 24px; }
.bsh-vm__text   { font-size: 1.05rem; color: #3c4a59; max-width: 640px; margin-bottom: 16px; } .bsh-vm__kicker--light { color: rgba(255,255,255,.65); }
.bsh-vm__heading--light { color: #fff; } .bsh-vm__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-vm__btn:hover { background: #cf5c04; transform: translateY(-2px); } .bsh-vm__consent { display: flex; align-items: flex-start; gap: 8px; font-size: .82rem; color: #5a6a7a; margin-top: 10px; cursor: pointer; }
.bsh-vm__consent input[type="checkbox"] { margin-top: 3px; accent-color: var(--orange, #eb6a05); }
.bsh-vm__consent a { color: var(--blue, #4283c4); text-decoration: underline; } .bsh-vm-s1 { padding: 80px 0; background: #f4f7fb; position: relative; overflow: hidden; min-height: 50vh; }
.bsh-vm-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-vm-s1 .bsh-vm__container { position: relative; z-index: 2; }
.bsh-vm-s1__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.bsh-vm-s1__body { font-size: 1.05rem; color: #3c4a59; line-height: 1.7; }
.bsh-vm-s1__body p + p { margin-top: 12px; }
.bsh-vm-s1__image { border-top-left-radius: 50%; border-bottom-right-radius: 50%; overflow: hidden; height: 450px; }
.bsh-vm-s1__image img { width: 100%; height: 100%; object-fit: cover; display: block; } .bsh-vm-s2 { position: relative; padding: 80px 0; background: #1b3a61; overflow: hidden;}
.bsh-vm-s2 .bsh-vm__container { position: relative; z-index: 2; }
.bsh-vm-s2 .bsh-vm__heading { color: #fff; }
.bsh-vm-s2 .bsh-vm__subtitle { color: rgba(255,255,255,.85); }
.bsh-vm-s2 .bsh-vm__kicker { color: var(--orange, #eb6a05); }
.bsh-vm-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-vm-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-vm-s2__timeline { display: flex; flex-direction: column; gap: 0; margin-top: 32px; position: relative; padding-left: 48px; }
.bsh-vm-s2__timeline::before {
content: '';
position: absolute; left: 19px; top: 0; bottom: 0;
width: 2px; background: var(--blue, #4283c4); opacity: .25;
}
.bsh-vm-s2__step { display: flex; align-items: flex-start; gap: 20px; position: relative; padding-bottom: 36px; }
.bsh-vm-s2__step:last-child { padding-bottom: 0; }
.bsh-vm-s2__step-num {
position: absolute; left: -48px;
width: 40px; height: 40px;
border-radius: 50%;
background: var(--blue, #4283c4);
color: #fff; font-weight: 800; font-size: 1rem;
display: flex; align-items: center; justify-content: center;
flex-shrink: 0; z-index: 1;
}
.bsh-vm-s2__step-body { background: #fff; border-radius: 0; padding: 28px; box-shadow: 0 2px 12px rgba(0,0,0,.06); flex: 1; }
.bsh-vm-s2__step-title { font-size: 1.15rem; font-weight: 700; color: var(--blue-dark, #1b3a61); margin-bottom: 6px; }
.bsh-vm-s2__step-text  { font-size: .95rem; color: #5a6a7a; line-height: 1.55; } .bsh-vm-s3 { position: relative; padding: 80px 0; background: var(--blue-dark, #1b3a61); color: #fff; }
.bsh-vm-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-vm-s3__content { max-width: 680px; }
.bsh-vm-s3__body { font-size: 1.05rem; color: rgba(255,255,255,.8); line-height: 1.7; margin-bottom: 24px; }
.bsh-vm-s3__body p + p { margin-top: 10px; } .bsh-vm-s4 { position: relative; padding: 80px 0; background: var(--light-bg, #f4f7fb); }
.bsh-vm-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-vm-s4__wrap { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; background: #fff; padding: 48px; }
.bsh-vm-s4__form { display: flex; flex-direction: column; gap: 6px; }
.bsh-vm-s4__row  { display: flex; gap: 12px; }
.bsh-vm-s4__input { flex: 1; padding: 14px 18px; border: 1px solid #c3cdd8; border-radius: 0; font-size: 1rem; outline: none; }
.bsh-vm-s4__input:focus { border-color: var(--blue, #4283c4); }
.bsh-vm-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-vm-s4__btn:hover { background: #cf5c04; } @media (max-width: 900px) {
.bsh-vm-s1__grid,
.bsh-vm-s4__wrap { grid-template-columns: 1fr; }
.bsh-vm-s1__image { order: -1; }
.bsh-vm-s1, .bsh-vm-s2, .bsh-vm-s3, .bsh-vm-s4 { padding: 56px 0; }
}
@media (max-width: 600px) {
.bsh-vm-s4__row { flex-direction: column; }
.bsh-vm-s2__timeline { padding-left: 40px; }
.bsh-vm-s2__step-num { left: -40px; width: 32px; height: 32px; font-size: .85rem; }
.bsh-vm-s2__timeline::before { left: 15px; }
.bsh-vm-s1, .bsh-vm-s2, .bsh-vm-s3, .bsh-vm-s4 { padding: 40px 0; }
}
.bsh-vm-s2 .bsh-vm-s2__timeline::before { background: rgba(255,255,255,.2); }