:root {
--bg: #1c1c1c;
--panel: #171a1c;
--muted: #9aa3aa;
--text: #e9eef2;
--accent: #ff8c00; /* oranje */
--accent-2: #ffd9a1;
--radius: 1.25rem;
}
html, body {
    background: var(--bg);
    color: var(--text);
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}
 h1, h2, h3, h4, h5, h6 {
font-family: transducer-extended, sans-serif;
}
h1{
font-size: 80px;
line-height: 80px;
}
h2{
font-size: 44px;
line-height: 44px;
}
h3{
font-size: 28px;
line-height: 28px;
}
h4{
font-size: 18px;
line-height: 24px;
}
h5{
font-size: 18px;
line-height: 24px;
}
	/* Tablet ≤ 992px */
@media (max-width: 991.98px){
  h1{ font-size:64px !important; line-height:64px !important; }
  h2{ font-size:36px !important; line-height:40px !important; }
  h3{ font-size:24px !important; line-height:28px !important; }
  h4{ font-size:16px !important; line-height:22px !important; }
  h5{ font-size:16px !important; line-height:22px !important; }
}

/* Mobile ≤ 576px */
@media (max-width: 575.98px){
  h1{ font-size:40px !important; line-height:44px !important; }
  h2{ font-size:28px !important; line-height:32px !important; }
  h3{ font-size:20px !important; line-height:26px !important; }
  h4{ font-size:16px !important; line-height:22px !important; }
  h5{ font-size:16px !important; line-height:22px !important; }
}
.heading {
 
    text-transform: uppercase;
}

@media (min-width: 1400px) {
.container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
    max-width: 1170px;
}
}
/* NAV */
.navbar {
    background: transparent;
    border-bottom: 0;
--bs-navbar-padding-y: 2rem;
	 --bs-navbar-nav-link-padding-x: 1rem;
}
 
.navbar.navbar-dark .navbar-toggler {
    border: 0;
}
.navbar .nav-link {
     color: #ffffff;
    font-weight: 400;
    padding: .9rem 1rem;
    font-family: "Space Grotesk", sans-serif;
    text-transform: uppercase;
    font-size: 14px;
}
.navbar .nav-link:hover, .navbar .nav-link:focus {
    color: var(--text);
}
.navbar .dropdown-toggle .bi {
    transition: transform .2s ease;
}
.navbar .dropdown.show .bi {
    transform: rotate(180deg);
}
.dropdown-menu {
    background: #0f1214;
    border: 1px solid #242a2f;
    border-radius: .75rem;
    padding: .25rem;
    min-width: 16rem;
}
.dropdown-item {
    color: var(--text);
    border-radius: .5rem;
      font-family: "Space Grotesk", sans-serif;
}
.dropdown-item:hover {
    background: #161a1d;
    color: var(--text);
}
.logo-rvm {
    font-family: Oswald;
    font-size: 1.9rem;
    letter-spacing: .15em;
}
.logo-sub {
    font-size: .55rem;
    letter-spacing: .18em;
    color: #cfd6dc;
    opacity: .9;
}
.btn-accent {
      background: #ff8c00;
    color: #1c1c1c;
    border: none;
    font-weight: 500;
    font-family: "Space Grotesk", sans-serif;
    text-transform: uppercase;
    line-height: 24px;
    font-size: 14px;
    padding: 12px 20px;
}
.btn-accent:hover {
    background: #ffa833;
    color: #111;
}
.btn-outline-accent {
  background: transparent;
    color: #ffffff;
    border: none;
    font-weight: 500;
    font-family: "Space Grotesk", sans-serif;
    text-transform: uppercase;
    line-height: 24px;
    font-size: 14px;
    padding: 12px 20px;
	    border: 1px solid #fff;
}
.btn-outline-accent:hover {
    background: var(--accent);
    color: #1c1c1c;
		    border: 1px solid  var(--accent);
}
.navbar .dropdown-toggle::after {
    display: NONE;
}

/* Hover open on desktop */
@media (min-width: 992px) {
.navbar .dropdown:hover > .dropdown-menu {
    display: block;
}
}
/* HERO fullscreen + media + contact */
.hero {
    position: relative;
    min-height: 100svh;
    display: flex;
    align-items: center;
    padding-top: 5rem;
    border-bottom: 13px solid #1c1c1c;
    overflow: hidden
}
.hero.hero-2 {
    position: relative;
    min-height: 100svh;
    display: flex;
    align-items: end;
    padding-bottom: 15rem;
    border-bottom: 13px solid #1c1c1c;
    overflow: hidden;
}
.hero-bg {
    position: absolute;
    inset: 0;
    background-position: center;
    background-size: cover;
    filter: saturate(.9) contrast(1.05)
}
.hero-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: none
}
.hero.has-video .hero-video {
    display: block
}
.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(13,15,16,.55) 0%, rgba(13,15,16,.55) 60%, rgba(13,15,16,.75) 100%)
}
.hero .kicker {
    color: var(--muted);
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase
}
.hero h1 {
    line-height: 1;
    font-size: 80px;
	font-family: transducer-extended, sans-serif;
    margin-bottom: 20px;
}
	
.hero.hero-2 h1{
	line-height: 1;
    font-size: 48px;
}
.hero.hero-2 p {
    max-width: 66ch;
    color: #ffffff;
	font-size: 18px;
	margin-bottom: 30px;
}
.hero p {
    max-width: 56ch;
    color: #ffffff;
	font-size: 18px;
	margin-bottom: 30px;
      font-family: "Space Grotesk", sans-serif;
}
.contact-card {
    position: absolute;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 35px;
    background: transparent;
    min-width: 350px
}
.contact-card .avatar {
    width: 70px;
    height: 70px;
    border-radius: 8px;
    object-fit: cover
}
.contact-card .role {
    color: var(--muted);
    font-size: .75rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    font-weight: 700
}
.icon-btn {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #292825 ;
    color: #ffffff;
    border: 1px solid #292825
}
.icon-btn:hover {
    background: var(--accent);
    color: #111;
    border-color: var(--accent)
}

@media (max-width:575.98px) {
.contact-card {
    min-width: 0;
    padding: .6rem .7rem;
    gap: .6rem
}
}
#branches {
    padding: 150px 0px;
    background: #1C1C1C;
}
.branch-card {
    position: relative;
    display: block;
    border: 1px solid #22282d;
    border-radius: var(--radius);
    overflow: hidden;
    background: #000;
    text-decoration: none
}
.branch-card .card-img {
    height: 460px;
    object-fit: cover;
    transition: transform .6s ease
}
.branch-card .card-img-overlay {
    background: transparent linear-gradient(180deg, #0000004D 0%, #000000CC 100%) 0% 0% no-repeat padding-box;
    opacity: 0.8;
    padding: 40px;
}
.branch-card .heading {
    color: #fff;
    text-transform: uppercase;
 
    margin: 0 0 .25rem
}
.branch-card p {
    color: #ffffff;
    margin: 0 0 14px;
		    font-family: "Space Grotesk", sans-serif;
}
.branch-card .discover {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: .8rem;
    color: #fff;
    text-decoration: none;
	font-family: "Space Grotesk", sans-serif;
}
.branch-card .discover .bi {
    transition: transform .2s ease
}
.branch-card:hover .card-img {
    transform: scale(1.05)
}
.branch-card:hover .discover {
    color: #ffa833
}             /* orange hover */
.branch-card:hover .discover .bi {
    transform: translateX(2px)
}

@media (max-width: 767.98px) {
.branch-card .card-img {
    height: 400px
}
}
/* SECTION WRAPPERS */
section {
    padding-top: 4.5rem;
	padding-bottom: 4.5rem;
	padding-left: 30px !important;
	padding-right: 30px !important;
}
.section-dark {
    background: var(--bg);
}
.section-panel {
 
        overflow: hidden;
 
    border-radius: 8px;
}
/* CARDS */
.card-dark {
    background: #141719;
    border: 1px solid #22282d;
    border-radius: var(--radius);
    overflow: hidden;
    height: 100%;
}
.card-dark .card-img-top {
    height: 180px;
    object-fit: cover;
    filter: grayscale(.1) contrast(1.05);
}
.card-dark .card-body {
    padding: 1.2rem 1.2rem 1.4rem;
}
.card-dark .card-title {
    font-family: Oswald;
    letter-spacing: .03em;
}
.eyebrow {
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .16em;
    font-weight: 700;
    font-size: .8rem;
}
/* SPLIT CTA */
.cta-slab {
    background: linear-gradient(180deg, rgba(255,159,28,.12), rgba(255,159,28,.04));
    border: 1px solid #2a2f33;
    border-radius: var(--radius);
    overflow: hidden;
}
/* PROCESS */
.step {
    background: #292825;
    border-radius: 8px;
    padding: 50px;
    height: 100%;
    min-height: 370px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-decoration: none !important;
    color: inherit;
}
.step:hover {
    background: #615d4c;
}
.step i {
    font-size: 45px;
    color: var(--accent);
}
/* FOOTER */
footer {
 
}
.brand-mark {
    font-family: Oswald;
    font-size: 2.25rem;
    letter-spacing: .15em;
}
/* WIDE CTA media background (image -> video toggle) */
.cta-media {
    position: relative;
    overflow: hidden;
}
.cta-media .cta-bg, .cta-media .cta-video, .cta-media .cta-overlay {
    position: absolute;
    inset: 0;
}
.cta-media .cta-bg {
    background-position: center;
    background-size: cover;
    filter: brightness(.7) contrast(1.05);
}
.cta-media .cta-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: none;
}
.cta-media.has-video .cta-video {
    display: block;
}
.cta-media .cta-overlay {
    background: linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.65) 60%, rgba(0,0,0,.75) 100%);
}
/* Top-left toggle icon (you can swap the icon) */
.media-toggle {
    position: absolute;
    top: 1rem;
    left: 1rem;
    z-index: 3;
    width: 40px;
    height: 40px;
    border-radius: .6rem;
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0px;
}
.media-toggle:hover {
    opacity: 0.5;
}
/* make the media wrapper span the full viewport width (no horizontal scroll) */
.cta-bleed {
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
}
/* WIDE CTA: min-height 720px + content verticaal centreren */
#ctaWide{
    min-height: 720px;
    display: flex;
    align-items: center;   /* centreert de .container-xxl verticaal */
}
#cta2Wide {
    min-height: 920px;
    display: flex;
    align-items: center;   /* centreert de .container-xxl verticaal */
	    align-items: end;
    padding: 150px;
}
#ctaWide > .container-xxl, #cta2Wide > .container-xxl{
    width: 100%;
} 
 #ctaWide .content p  {
    --bs-text-opacity: 1;
    color: #fff !important;
    font-size: 18px;
    line-height: 24px;
    font-family: "Space Grotesk", sans-serif;
    margin-top: 20px;
    margin-bottom: 30px;
}
/* optional: full-bleed usually has no rounded outer corners */
.cta-media {
    border-radius: 0;
    border-left: 0;
    border-right: 0;
}
/* UTIL */
.chip {
    display: inline-block;
    border-radius: 999px;
    background: #111417;
    border: 1px solid #242a2f;
    padding: .4rem .75rem;
    font-weight: 700;
    letter-spacing: .12em;
    font-size: .75rem;
    text-transform: uppercase;
    color: var(--muted);
}
.trusted-partners {
    padding: 150px 0px 150px 0px;
    background: #1C1C1C;
}
.trusted-partners.hero-3 h1 {
	color: #EFEEED;
	font-size: 44px;
	line-height: 1;
	max-width: 674px;
	margin-bottom: 200px;
}
.trusted-partners.hero-3 {
    padding: 100px 0px 250px 0px;
    background: #1C1C1C;
	position: relative;
}
.trusted-partners.hero-3 .left-sep-image{
    position: absolute;
    bottom: -5px;
    left: 0px;
}
.trusted-partners.hero-3 .center-sep-image{
  position: absolute;
  inset: 0;     
	margin: auto;      
}

.trusted-partners.hero-3  .image-sep {
    position: absolute;
    right: auto;
    bottom: 0px;
    left: 0px;
    transform: rotateY(180deg);
}
.trusted-partners.hero-3 .content-box {
    max-width: 460px;
    margin: 0;
}
.trusted-partners .module-image {
    border-radius: 8px;
--bs-card-bg: transparent;
}
.trusted-partners .image-sep {
    position: absolute;
    right: 0px;
    bottom: 0px;
}
.trusted-partners .content-box {
    max-width: 460px;
    margin: 0 auto;
}
.trusted-partners .content p {
    --bs-text-opacity: 1;
    color: #fff !important;
    font-size: 18px;
    line-height: 24px;
    font-family: "Space Grotesk", sans-serif;
    margin-top: 20px;
    margin-bottom: 30px;
}
#proces {
    padding: 0px 0px 150px 0px;
    background: #1C1C1C;
}
#proces .header-text {
    margin-bottom: 80px;
}
	/* ORANGE STRIP CTA */
.cta-slab{
  background:#ff8c00;                   /* oranje */
  border:0;
  border-radius: 8px;
  padding: 100px;
}

/* donkere copy bovenop oranje */
.cta-slab .heading{ color:#141414; }
.cta-slab .text-secondary{ color:#1b1b1b; opacity:.9; }

/* knoppen op oranje achtergrond */
.cta-slab .btn-accent{                  /* primaire = donker blokje */
  background:#14181b; color:#fff; border:1px solid #14181b;
  font-weight:700;
}
.cta-slab .btn-accent:hover{ background:#0f1214; border-color:#0f1214; }

.cta-slab .btn-outline-accent{          /* secundaire = donkere outline */
  border:1px solid #1f252a; color:#1b1b1b; background:transparent;
  font-weight:700;
}
.cta-slab .btn-outline-accent:hover{
  background:#14181b; color:#fff; border-color:#14181b;
}
/* ===== FOOTER (full-bleed) ===== */
.footer-x{
  position: relative;
  background: #1c1c1c;  
  padding: 100px 0 0px 0;
}

/* Top layout: groot logo links, 3 kolommen rechts */
.footer-top{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 5vw, 140px);
  align-items: start;
  min-height: 180px;
}
.footer-logo{
 
  line-height: .9;
  color: #fff;
  letter-spacing: .06em;
}
.footer-nav{
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: clamp(24px, 6vw, 120px);
  align-content: start;
  padding-top: clamp(8px, 1vw, 16px);
}
.footer-nav .col{ list-style: none; margin: 0; padding: 0; }
.footer-nav a{
     display: block;
    text-decoration: none;
    color: #efeeed;
    text-transform: uppercase;
    letter-spacing: 0;
    font-weight: 400;
    font-size: 14px;
    margin: .35rem 0;
    font-family: "Space Grotesk", sans-serif;
    line-height: 24px;
}
.footer-nav a:hover{ color: #ffffff; }

/* Bottom row: legal links links-onder */
.footer-bottom{ position: relative; padding-top: 32px; background: url(https://143726354.fs1.hubspotusercontent-eu1.net/hubfs/143726354/RVM/images/footer-bg-image.svg);padding-bottom: 32px; background-repeat: no-repeat; background-position: right bottom;}
.legal{
  
}
.legal ul{
  list-style:none; display:flex; gap: 32px; margin:0; padding:0;
}
.legal a{  color: #efeeed; text-decoration:none;  font-family: "Space Grotesk", sans-serif;  font-size: 12px; text-transform: uppercase;}
.legal a:hover{ color:#fff; }

/* Partner tab rechts-onder met notch-vorm */
.footer-partners{

}
.footer-partners::before{
 
}
.footer-partners ul{
  list-style:none; display:flex; gap: 32px; margin:0; padding:0;
}
.footer-partners a{  color: #efeeed; text-decoration:none;  font-family: "Space Grotesk", sans-serif;  font-size: 12px; text-transform: uppercase;}
.footer-partners a:hover{ color:#ffffff; }
	.footer-content-box{
	display: flex;
	justify-content: space-between;
		    padding: 0 40px;
	}
/* Responsive */
@media (max-width: 991.98px){

}
@media (max-width: 575.98px){

}
p.text-secondary {
    --bs-text-opacity: 1;
    color: #fff !important;
	font-size: 18px;
	line-height: 24px;
	 font-family: "Space Grotesk", sans-serif;
	margin-top: 20px;
	margin-bottom: 30px;
}
.cta-slab .content p{
    font-size: 18px;
    line-height: 24px;
    color: #1c1c1c;
	font-family: "Space Grotesk", sans-serif;
}
	
	.navbar.nav-ghost{
  background: transparent;
  transition: background-color .25s ease, border-color .25s ease;
}

/* after scroll (or when menu is open) */
.navbar.nav-ghost.is-scrolled{
  background: rgb(0 0 0 / 70%);
  /* optional: a subtle bottom border */
  /* border-bottom: 1px solid rgba(255,255,255,.06); */
}
	
	/* layout desktop */
.footer-nav{
  display:grid;
  grid-template-columns: repeat(3, minmax(160px,1fr));
  gap: clamp(16px, 4vw, 80px);
}

/* links */
.footer-list{ list-style:none; margin:0; padding:0; }
.footer-list a{
  display:block; padding:.25rem 0;
  color:#cfd6dc; text-decoration:none;
  text-transform:uppercase; letter-spacing:.12em; font-weight:700; font-size:.78rem;
}
.footer-list a:hover{ color:#ff9f1c; } /* oranje hover */

/* mobile accordion toggle (verborgen op ≥ md) */
.footer-toggle{
  width:100%; text-align:left; background:transparent; border:0; color:#e9eef2;
  padding:.85rem 0; margin:0; display:none; /* hidden by default, shown on mobile */
  text-transform:uppercase; letter-spacing:.12em; font-weight:400;
  border-bottom:1px solid #2a2f33;
	font-family: "Space Grotesk", sans-serif;
}
.footer-toggle .bi{ transition: transform .2s ease; }

/* MOBILE ≤ md: toon toggles, collapse standaard gesloten */
@media (max-width: 991.98px){
  .footer-nav{ grid-template-columns: 1fr; gap:0; }
  .footer-toggle{ display:flex; align-items:center; justify-content:space-between; }
  .footer-list{ padding:.25rem 0 .75rem; border-bottom:1px solid #2a2f33; }
  .footer-list.collapse.show + .footer-list{ border-top:0; }
  /* draai caret wanneer open — Bootstrap zet .show op de UL; we targetten via aria-expanded op de button */
  .footer-toggle[aria-expanded="true"] .bi{ transform: rotate(180deg); }
}

/* DESKTOP ≥ md: forceer lijsten open, verberg toggles */
@media (min-width: 992px){
  .footer-toggle{ display:none; }
  .footer-list.collapse{ display:block !important; height:auto !important; visibility:visible !important; }
}
@media (max-width: 575.98px){
.footer-top {
     flex-direction: column;
    display: flex;
}
	
.cta-slab {
    padding: 40px;
}
#cta2Wide {
    min-height: 600px;
    padding: 50px;
}
	#cta2Wide > .container-xxl {
        width: 100%;
    }
 .trusted-partners {
    padding: 50px 0px 50px 0px;
    background: #1C1C1C;
}
	#ctaWide > .container-xxl  {
    width: 80%;
}
	#branches {
    padding: 50px 0px;
    background: #1C1C1C;
}
	.branch-card {
    position: relative;
    display: block;
    border: 1px solid #22282d;
    border-radius: 8px;
    overflow: hidden;
    background: #000;
    text-decoration: none;
}
}
#hero .bottom-container{
    background: url(https://143726354.fs1.hubspotusercontent-eu1.net/hubfs/143726354/RVM/images/hero-bottom-bg.svg);
    position: absolute;
    bottom: 0px;
    right: 0px;
    width: 100%;
    height: 120px;
    background-repeat: no-repeat;
    background-position: right bottom;
}
	
.contact-card .name{
    font-family: "Space Grotesk", sans-serif;
letter-spacing: 0;
color: #ffffff;
text-align: left;
font: normal normal normal 18px/24px Space Grotesk;
letter-spacing: 0px;
color: #FFFFFF;
 
	}
.contact-card .role{
 font-family: "Space Grotesk", sans-serif;
letter-spacing: 0;
color: #ff8c00;
text-align: left;
font: normal normal normal 14px/24px Space Grotesk;
letter-spacing: 0px;
color: #FF8C00;
text-transform: uppercase;
	}
	
.features-section {
  background-color: #1C1C1C; /* dark background */
}
.features-section .features-section-item{
	margin-bottom: 30px;
}
.features-section .iconbox {
min-width: 100px;
 min-height: 100px;
    background: #292825;
    border-radius: 4px;
    margin-right: 30px;
	display: flex;
    justify-content: center;
    align-items: center;
}
.features-section .iconbox i{
	    color: #ff8c00;
    font-size: 40px;
}
.features-section h6 {
  text-transform: uppercase;
  font-size: 18px;
   line-height: 24px;
	max-width: 400px;
}

.icon-box {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #222;
  border-radius: 4px;

}

.icon-box i {
  font-size: 1.4rem;
  color: #ff7a00; /* orange */
}



/* ----- Base / colors ----- */
.rvm-vert-tabs{
  background:#1c1c1c; /* donker vlak zoals in je design */
	
}
.rvm-vert-tabs .container{ position: relative; }
.rvm-vert-tabs .nav-link{
  text-align:left;
  padding: 47px 70px; /* ruimte voor de lijn links */
  background: transparent;
  border: 0;
  border-left: 3px solid transparent; /* wordt oranje bij active */
  border-radius: 0;
  color: #cfd5db;
}
.rvm-vert-tabs .nav-link:hover{ color:#ffffff; }
.rvm-vert-tabs .nav-link.active{
    border-left-color: #ff8a00;
    color: #ffffff;
    background: transparent;
    z-index: 9;
    display: block;
    position: relative;
}

/* Titel + copy zoals in voorbeeld */
.rvm-tab-title{
  display:block;
  text-transform:uppercase;
  font-size: 18px;
  margin-bottom: 5px;
	font-family: transducer-extended, sans-serif;
	line-height: 24px;
}
.rvm-tab-copy{
  display:block;
  color:#ffffff;
font-size: 18px;
    line-height: 24px;
    font-family: "Space Grotesk", sans-serif;
	max-width: 440px;
}
.rvm-vert-tabs .nav-link:not(.active) .rvm-tab-copy{
  color:#ffffff; /* grijs voor inactief */
	opacity: 0.5;
}
.rvm-vert-tabs .nav-link:not(.active) .rvm-tab-title{
	  color:#ffffff; /* grijs voor inactief */
	opacity: 0.5;
}
/* Linker “timeline”-lijn */
.rvm-tabs-stack{ padding-left: 0; }
.rvm-timeline{
position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: #5a5f65;
    border-radius: 0;
    content: "";
    z-index: 0;
}
.rvm-vert-tabs .nav-link.active::before{
  
}

/* Rechter beeldvlak */
.rvm-media{

}
.rvm-media img{
    display: block;
    width: 100%;
    height: auto;
    border-radius: .5rem;
    min-height: 580px;
    object-fit: cover;
}
}

/* Spacing tweaks */
@media (min-width: 992px){
  .rvm-vert-tabs .nav-link{ padding-right:2rem; }
}
.image-banner-section h2{
	font-size: 28px;
	line-height: 1;
}

 


/* Full-width section wrapper */
.rvm-bleed-cta{
  position: relative;
  background: #ff8a00;
  border-radius: 1rem;
  overflow: hidden;      
min-height: 350px;
  display: flex;
  align-items: center;
}

/* Left (orange) card inside the container */
.rvm-bleed-card{
 
  color:#141414;
 
}
.rvm-heading{
 
  text-transform: uppercase;
  font-size: 28px;
  line-height: 1;
  margin: 0;
}

/* Form controls */
.rvm-select{
  max-width: 240px;
  border:1px solid #1C1C1C;
  background-color:#ff8a00;
  color:#141414;
  box-shadow:none;
	border-radius: 4px;
}
.rvm-select:focus{
  border-color:#1C1C1C;
  box-shadow:0 0 0 .2rem rgba(0,0,0,.08);
}
.rvm-btn{
    background: #14181b;
    color: #fff;
    border: 1px solid #14181b;
   
}

/* The image "outside" the container */
.rvm-bleed-media{
  /* mobile: show below content */
  position: relative;
  height: 240px;
  margin-top: 1rem;
}
.rvm-bleed-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

/* Desktop: pin the image to the right, bleeding past the container */
@media (min-width: 992px){
  .rvm-bleed-cta{ padding-block: 3rem; }
  .rvm-bleed-media{
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;            /* match section height */
    height: auto;
    width: min(46vw, 780px);   /* bleed width */
    margin-top: 0;
  }
 
  .rvm-bleed-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
@media (max-width: 992px) {
  .rvm-bleed-card {
    color: #141414;
    padding: 40px;
}
	
	.rvm-bleed-cta {
  display: block;
}	
}
@media (max-width: 575.98px) {
  .rvm-bleed-card {
    color: #141414;
    padding: 40px;
	 
}
.rvm-bleed-cta {
  display: block;
}	
 
}



/* full-width dark backdrop */
.rvm-info{
  background:#1b1b1b;
}

/* the light card */
.rvm-panel{
  background:#cac9c4;                 /* light grey like the comp */
  color:#1C1C1C;
  padding: 100px;
  position: relative;
  overflow: hidden;
	
border-radius: 8px;
}

/* optional subtle noise/grain */
.rvm-panel::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    radial-gradient(rgba(0,0,0,.04) 1px, transparent 1px);
  background-size: 3px 3px;
  pointer-events:none;
  mix-blend-mode:multiply;
  opacity:.35;
}

/* headings & text */
.rvm-title{
  text-transform: uppercase;
  font-size: 28px;
  line-height:1 ;
  font-size: clamp(1.4rem, 2vw + 1rem, 2rem);
  margin-bottom: 20px;
}
.rvm-lead{
  
}
.rvm-panel p {
	    font-size: 18px;
    line-height: 24px;
    color: #1c1c1c;
    font-family: "Space Grotesk", sans-serif;
}
/* button */
.btn-rvm{
   
}
.btn-rvm:hover{
  background:#e67c00;
  color:#141414;
}



/* light panel look (optional) */
.rvm-compare{
  background:#cccbc6;
  padding: 120px 0px;
}
.rvm-title{
  text-transform: uppercase;
  font-size: 28px;
  line-height: 1;
  color: #1c1c1c;
  margin-bottom: 30px;
}
.rvm-compare p {
	    font-size: 18px;
    line-height: 24px;
    color: #1c1c1c;
    font-family: "Space Grotesk", sans-serif;
}

/* orange CTA */
.btn-rvm{
 
}
.btn-rvm:hover{   }

/* TABLE (desktop) */
.rvm-compare-table{
  border-collapse: separate; border-spacing:0;
}
.rvm-compare-table thead th{
  background:#b8b7af; color:#1c1c1c; font-weight:700;
  padding: .9rem .75rem;
}
.rvm-compare-table thead {
  border-color:#b8b7af;  
}
.rvm-compare-table tbody td{
  padding:.85rem .75rem; vertical-align:middle; color:#1c1c1c;
  border-bottom:1px solid #b8b7af;
 background-color: transparent;
}
.rvm-compare-table tr:last-child td{ }

/* CARDS (mobile) */
.rvm-card{
  background:#cccbc6;
  padding:1rem 1rem 0.5rem;
  border:1px solid #b8b7af;
}
.rvm-card-title{
  margin:0 0 .5rem 0;
  text-transform:uppercase;  
	color:#1c1c1c; 
}
.rvm-spec-list{ margin:0; }
.rvm-spec-list > div{
  display:flex; justify-content:space-between; gap:.75rem;
  padding:.55rem 0; border-bottom:1px dashed rgba(0,0,0,.12);
}
.rvm-spec-list > div:last-child{ border-bottom:0; }
.rvm-spec-list dt{
  flex: 0 0 52%;
  margin:0; color:#555; font-weight:600;
}
.rvm-spec-list dd{
  flex: 1; margin:0; color:#222; text-align:right;
}

/* Desktop: hide cards, show table */
@media (min-width: 992px){
  .rvm-compare{ background: #cccbc6; }
}


/* Section look */
.rvm-faq { background:#1c1c1c; }
.rvm-faq .container{
    max-width: 770px;
}
.rvm-faq-title{
 letter-spacing: 0px;
color: #FFFFFF;
text-transform: uppercase;
font-size: 28px;
line-height: 1;
margin-bottom: 30px;
}

/* Accordion container */
.rvm-accordion .accordion-item{
  background:transparent;
  border:none;
  margin-bottom:.6rem;
  border-radius:.6rem;
  overflow:hidden;
}

/* Heading button */
.rvm-accordion .accordion-button{
  background:#292825 ;
  color:#cfd3d7;
  padding: 24px 70px; /* space for badge */
     font-family: "Space Grotesk", sans-serif;
  border-radius:4px;
  box-shadow:none;
  position:relative;
	line-height: 1;
 
}
.rvm-accordion .accordion-button.collapsed{ color:#b6bbc1; }
.rvm-accordion .accordion-button:focus{ box-shadow:none; }

/* Remove default chevron */
.rvm-accordion .accordion-button::after{ display:none; }

/* Left square +/− badge */
.faq-badge{
  position:absolute; left: .9rem; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius: 4px;
  background:#121212;
   
}
.faq-badge::before, .faq-badge::after{
  content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  background:#ffffff; border-radius:2px;
}
.faq-badge::before{ width:11px; height:2px; }     /* horizontal bar */
.faq-badge::after { width:2px; height:11px; }     /* vertical bar = plus */

/* Active state: orange badge + minus */
.rvm-accordion .accordion-button[aria-expanded="true"]{
  background:#3b3a34; /* warm/darker highlight like comp */
  color:#ffffff;
  border-color: rgba(255,255,255,.12);
}
.rvm-accordion .accordion-button[aria-expanded="true"] .faq-badge{
  background:#ff8a00; border-color:#ff8a00;
}
.rvm-accordion .accordion-button[aria-expanded="true"] .faq-badge::after{
  opacity:0; /* hide vertical bar -> minus */
}

/* Body */
.rvm-accordion .accordion-body{
  background:#3b3a34;
  color:#e7e7e7;
  border-top: none;
  margin-top:-.5rem;                 /* tuck under header border */
  border-radius:0 0 4px 4px;
 padding: 10px 70px 24px 70px;/* align with title */
}


/* wrapper */
.rvm-hero{
  position: relative;
  width: 100%;
  min-height: clamp(280px, 42vw, 520px);
  overflow: hidden;   

}

/* background image */
.rvm-hero-img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
	
}

 
 /* overlay above image, below content */
.rvm-hero::after{
  content:"";
  position:absolute; inset:0;
  background:  rgba(0,0,0,.30) ;
  pointer-events:none;
  z-index:1;               /* ↑ */
}

/* bottom-right rounded tab (the beige “ticket” shape) */
.rvm-hero-tab{
  position: absolute;
  right: 0;
  bottom: -4px;                       /* hangs below image like the comp */
 z-index: 10;
}

/* small-screen tweak: shrink/hide the tab if needed */
@media (max-width: 575.98px){
  .rvm-hero-tab{ width: 58vw; height: 16vw; }
}


/* band behind the breadcrumb */
.rvm-breadcrumb{
  background:#CFCEC8;
  padding: 40px 0px;
  position:relative;
	font-family: "Space Grotesk", sans-serif;
}
.rvm-breadcrumb .container{
    max-width: 750px;
}
.rvm-breadcrumb::after{
  /* subtle noise / grain */
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(0,0,0,.05) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity:.35; pointer-events:none;
}
 .breadcrumb-item+  .breadcrumb-item {
    padding-left:0;
}
/* breadcrumb look */
.rvm-bc{
  text-transform:uppercase;
  font-size:14px;
  color:#1C1C1C;
}

/* links */
.rvm-bc a{ color:#1C1C1C; text-decoration:none; }
.rvm-bc a:hover{ text-decoration:underline; }

/* chevron between items */
.rvm-bc .breadcrumb-item + .breadcrumb-item::before{
  content:"\f285";         /* slim chevron */
  color: #1C1C1C;
  padding:0 .75rem;     
	    display: inline-block;
    font-family: bootstrap-icons !important;
    font-style: normal;
    font-weight: normal !important;
    font-variant: normal;
    text-transform: none;
     font-size: 12px;
    line-height: 21px;
    vertical-align: -.125em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* orange home icon */
.rvm-bc-home{
  display:inline-flex; align-items:center; justify-content:center;
  color:#ff8c00;  
}
.rvm-bc-home i{
	color: #ff8c00;
}
/* trim default spacing for first crumb so icon sits tight */
.rvm-bc .breadcrumb-item:first-child::before{ content:none; }

/* active item */
.rvm-bc .breadcrumb-item.active{ color:#6a6f74; }


/* Section background with subtle grain */
.rvm-case-details{
  background:#CFCEC8;
  position:relative;
}
.rvm-case-details .container{
    max-width: 750px;
	font-family: "Space Grotesk", sans-serif;
}
.rvm-case-details::after{
 
}
.rvm-case-details p {
    font-size: 18px;
    line-height: 1.5;
    color: #1c1c1c;
    font-family: "Space Grotesk", sans-serif;
}
/* Typography */
.rvm-title{
text-transform: uppercase;
    font-size: 28px;
    line-height: 1;
    color: #1c1c1c;
    margin-bottom: 30px;
}
.rvm-subtitle{
text-transform: uppercase;
    font-size: 18px;
    line-height: 24px;
    color: #1c1c1c;
    margin-bottom: 30px;
}
.rvm-body{ color:#3a3a3a; line-height:1.6; }

/* Bullet list with orange check */
.rvm-li-ico{
  width:24px; height:24px;
  border-radius:50%;
  background:#ff8a00;
  display:grid; place-items:center;
  margin-right:20px; margin-top:-1px;
  flex:0 0 24px;
}
.rvm-check{
  width:16px; height:16px;
  fill:none; stroke:#141414; stroke-width:3;
  stroke-linecap:round; stroke-linejoin:round;
}

/* CTA heading + button */
.rvm-cta-heading{
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.4px;
  color:#1a1a1a;
}
 

/* light textured background like your comps */
.rvm-slider{
  background:#CFCEC8; position:relative;
}
.rvm-slider .container {
    max-width: 750px;
    font-family: "Space Grotesk", sans-serif;
}
 
/* carousel look */
.rvm-carousel{ position:relative; }
.rvm-carousel .carousel-inner{ border-radius: 8px; }

/* inside-image circular controls */
.rvm-ctrl{
  width:32px; height:32px; border-radius:999px;
  background-color:#ffffff; opacity:.9; border:0;
  top:50%; transform:translateY(-50%);
}
.rvm-ctrl .carousel-control-prev-icon,
.rvm-ctrl .carousel-control-next-icon{
     color: #1c1c1c;
	 display: flex;
    width: 32px;
    height: 32px;
    background-repeat: no-repeat;
    background-position: 50%;
    background-size: 100% 100%;
    font-size: 18px;
    justify-content: center;
    align-items: center;
}
.rvm-ctrl.carousel-control-prev{ left:18px; }
.rvm-ctrl.carousel-control-next{ right:18px; }
.rvm-ctrl:hover{ opacity:1; }

/* footer note */
.rvm-slide-note{
  font-size:14px; 
   line-height: 24px;
  color:#1c1c1c; 
	margin-left:0;
	margin-top: 20px;
}
 


/* light textured page background (optional, like your comps) */
.rvm-quote{
  background:#CFCEC8; position:relative;
}
.rvm-quote .container {
    max-width: 750px;
     
}
/* orange card */
.rvm-quote-card{
  background:#ff8a00;
   padding: 80px 100px 100px 100px;
  color:#101010;
  min-height: 300px;
	position: relative;
	border-radius: 8px;
	overflow: hidden;
}

/* white quote icon at top-left */
.rvm-qmark{
  position:absolute; left:1.25rem; top:1.25rem;
  opacity:.9;
}

/* text and author */
.rvm-quote-text{
     margin-top: 26px;
    letter-spacing: .04em;
    line-height: 1;
    color: #1C1C1C;
    font-size: 28px;
    font-family: transducer-extended, sans-serif;
}
.rvm-quote-author{
    font-size: 14px;
    color: #1C1C1C;
    line-height: 24px;
	 font-family: "Space Grotesk", sans-serif;
}

/* bottom patterned strip */
.rvm-quote-pattern{
  position:absolute; left:0; right:0; bottom:0;
 
}

/* page band like your comps */
.rvm-more{
  background:#CFCEC8; 
	position:relative;
  padding-bottom: 120px;
}
.rvm-more .container {
    max-width: 750px;
     
}

/* heading */
.rvm-title{
  margin-bottom: 32px;
}

/* card media + hover */
.rvm-media img{ transition: transform .45s ease; }
.rvm-media:hover img{ transform: scale(1.03); }

/* text */
.rvm-kicker{
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.04em;
  font-size:1.05rem;
  color:#111;
}
.rvm-desc{ color: #1C1C1C;    
	font-size: 18px;
    line-height: 24px;
margin-bottom: 25px;
}

/* link */
.rvm-link{
 display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: .8rem;
    color: #1c1c1c;
    text-decoration: none;
    font-family: "Space Grotesk", sans-serif;
}
.rvm-link:hover{ text-decoration:underline; }

/* helpers */
.object-fit-cover{ object-fit:cover; }


/* --- Peek carousel --- */
.rvm-peek-wrap{ --peek-pad: clamp(12px, 4vw, 48px); --ctrl-offset: clamp(10px, 2vw, 20px); }
.rvm-track{
  display:flex; 
	gap: 0;
  overflow-x:auto; overflow-y:visible;
  scroll-snap-type: x mandatory;
  scroll-behavior:smooth;
 padding: 0 var(--peek-pad);             /* space so neighbors peek */
}
.rvm-track::-webkit-scrollbar{ display:none; }

/* Each slide < 100% so left/right items are visible */
.rvm-slide{ flex: 0 0 78%; scroll-snap-align: center; transition: filter .3s; filter:brightness(.92); }
.rvm-slide.is-center{ filter:none; }
@media (max-width: 992px){ .rvm-slide{ flex-basis: 88%; } }
.rvm-slide img{
 border-radius: 8px;
}
.rvm-slide:is(:hover, .is-center){ filter: none; }

/* mobile: show more of neighbors; desktop: a bit less */
@media (max-width: 991.98px){ .rvm-slide{ flex-basis: 88%; } }

.rvm-ctrl{
  position:absolute; top:50%; transform:translateY(-50%);
  width:48px; height:48px; border-radius: 4px; border:0; z-index:2;
  background:#EFEEED; color:#1c1c1c; display:grid; place-items:center;
  box-shadow:0 2px 10px rgba(0,0,0,.25);
}
.rvm-prev{ left: var(--ctrl-offset); }
.rvm-next{ right: var(--ctrl-offset); }
.rvm-ctrl span{ font-size:24px; line-height:1; }
.rvm-ctrl i{
    font-size: 20px;
}
 

/* Overlay on slide images */
.rvm-slide .ratio{ position: relative; }

/* base overlay */
.rvm-slide .ratio::after{
  content:"";
  position:absolute; inset:0;
  /* choose one: solid or gradient */
  /* Solid: */
  /* background: rgba(0,0,0,.35); */

  /* Gradient (nice vignette): */
  background:
    linear-gradient(to bottom, rgba(0,0,0,.40), rgba(0,0,0,.08) 45%),
    linear-gradient(to right,  rgba(0,0,0,.35), rgba(0,0,0,0) 25%, rgba(0,0,0,0) 75%, rgba(0,0,0,.35));
  pointer-events:none;
  opacity:.9;                      /* overall strength */
  transition: opacity .3s ease;
}

/* emphasize the focused slide */
.rvm-slide.is-center .ratio::after{ opacity:.55; }  /* brighter center */
/* (or set to .35 for even less overlay on the focused slide) */



/* section background (light, with grain) */
.rvm-catalog{ 
  background:#CFCEC8; 
	position:relative;
	  padding-top: 120px;
  padding-bottom: 120px;
}
 
.rvm-catalog  .rvm-title.text-center{
	max-width: 640px;
	margin: 0 auto;
}

/* orange button */
.rvm-catalog .button-cotnainer{
 margin-top: 60px;
}
.rvm-catalog .rvm-card{
	background: transparent;
	padding: 0px;
	border:0px;
}

.rvm-peek-carousel{
	padding-top: 100px !important; 
	padding-bottom: 100px !important; 
}

 

.rvm-hero4{ position:relative; background:#1c1c1c; color:#fff; min-height:100svh; overflow:hidden; }

/* left side visuals (optioneel) */
.rvm-hero4-left{ position:relative; z-index:2; } /* boven image */
.rvm-hero4-title{ line-height:1; font-size: 44px; }
.rvm-hero4-lead{ color:#d8d8d8; max-width:70ch; }

/* RIGHT: full-height image that sticks to viewport right */
.rvm-hero4-media{
  position:absolute;
  top:0; right:0; bottom:0;
  left: var(--split-left, 60%);   /* wordt door JS gezet = rechterrand van .container */
  z-index:1;
}
.rvm-hero4-media img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.rvm-hero4-imgOverlay{  position: absolute;
    inset: 0;
    pointer-events: none;
    background: rgb(0 0 0 / 40%);
    z-index: 7; }
.rvm-hero4 .hero4-sep-background{
    position: absolute;
    bottom: 0px;
}
/* Mobile: stack (image boven/onder), geen absolute bleed nodig */
@media (max-width: 991.98px){
  .rvm-hero4{ min-height:auto; }
  .rvm-hero4-media{ position:relative; left:auto; height:60svh; }
}