
:root{
  --ink:#071525;
  --navy:#061d35;
  --deep:#04101d;
  --muted:#596477;
  --line:#dfe7ef;
  --bg:#f6f8fb;
  --white:#ffffff;
  --teal:#007164;
  --gold:#b88a35;
  --blue-soft:#eaf3fb;
  --teal-soft:#e6f2ef;
  --gold-soft:#f5efe3;
  --lavender-soft:#f0edf7;
  --sand:#fbf6ec;
  --shadow:0 28px 80px rgba(7,21,37,.11);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Inter,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.58;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(1220px,calc(100% - 48px));margin:0 auto}
.narrow{width:min(920px,calc(100% - 48px));margin:0 auto}
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(180%) blur(22px);
  border-bottom:1px solid rgba(223,231,239,.85);
}
.nav{
  min-height:104px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:28px;
}
.header-logo{height:88px;width:auto;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:28px;color:#26364a;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.07em}
.nav-links a{padding:8px 0;border-bottom:1px solid transparent}
.nav-links a:hover{color:var(--teal);border-bottom-color:var(--teal)}
.hero{
  min-height:780px;
  background:
    linear-gradient(125deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.88) 48%,rgba(229,238,249,.96) 48%,rgba(214,228,243,.78) 100%),
    radial-gradient(circle at 80% 10%,rgba(0,113,100,.14),transparent 30%);
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
}
.hero:after{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-150px;
  width:720px;
  height:520px;
  background:
    linear-gradient(135deg,rgba(7,21,37,.08),rgba(0,113,100,.05)),
    repeating-linear-gradient(110deg,rgba(7,21,37,.08) 0 1px,transparent 1px 14px);
  border-radius:48% 52% 0 0;
  transform:rotate(-10deg);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:72px;align-items:center;position:relative;z-index:2}
.kicker{margin:0 0 16px;color:#0c4f8b;text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:900}
h1,h2,h3{margin:0;color:var(--ink);letter-spacing:-.045em;line-height:1.04}
h1{font-size:clamp(52px,7vw,90px);font-weight:740}
h2{font-size:clamp(34px,4.6vw,58px);font-weight:720}
h3{font-size:24px;font-weight:740}
.lead{font-size:21px;color:#455064;max-width:760px;margin:28px 0 34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 24px;border-radius:4px;font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.btn.dark{background:var(--navy);color:white;box-shadow:0 12px 30px rgba(7,21,37,.16)}
.btn.light{background:rgba(255,255,255,.66);border:1px solid #8aa0b8;color:var(--navy)}
.hero-visual{
  min-height:520px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.logo-frame{
  width:min(560px,100%);
  min-height:360px;
  border:1px solid rgba(7,21,37,.18);
  background:rgba(255,255,255,.58);
  box-shadow:0 28px 70px rgba(7,21,37,.10);
  backdrop-filter:blur(14px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:44px;
  position:relative;
}
.logo-frame:before{
  content:"";
  position:absolute;
  inset:16px;
  border:1px solid rgba(0,113,100,.18);
}
.logo-frame img{width:100%;max-width:460px;position:relative;z-index:1}
.hero-note{
  position:absolute;
  left:0;
  bottom:10px;
  width:min(460px,85%);
  background:var(--navy);
  color:white;
  padding:28px 30px;
  box-shadow:var(--shadow);
}
.hero-note strong{display:block;font-size:22px;letter-spacing:-.02em;margin-bottom:8px}
.hero-note p{margin:0;color:rgba(255,255,255,.74)}
.section{padding:96px 0}
.white{background:white}
.soft-blue{background:linear-gradient(180deg,#edf6fd,#f8fbfd)}
.soft-sand{background:linear-gradient(180deg,#fbf7ef,#ffffff)}
.dark{background:var(--navy);color:white}
.dark h2,.dark h3{color:white}.dark p{color:rgba(255,255,255,.72)}
.section-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:70px;
  align-items:end;
  margin-bottom:44px;
}
.section-head p{font-size:17px;color:var(--muted);margin:0}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service-card{
  min-height:370px;
  padding:34px 30px;
  border:1px solid rgba(7,21,37,.08);
  box-shadow:0 12px 34px rgba(7,21,37,.04);
  transition:.25s ease;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.service-card:hover{transform:translateY(-5px);box-shadow:0 24px 54px rgba(7,21,37,.09)}
.service-card:nth-child(1){background:linear-gradient(160deg,#e8f3fb,#ffffff)}
.service-card:nth-child(2){background:linear-gradient(160deg,#e7f2ef,#ffffff)}
.service-card:nth-child(3){background:linear-gradient(160deg,#f8f1e5,#ffffff)}
.service-card:nth-child(4){background:linear-gradient(160deg,#f0edf7,#ffffff)}
.service-card:nth-child(5){background:linear-gradient(160deg,#eaf4fb,#ffffff)}
.service-card:nth-child(6){background:linear-gradient(160deg,#f8ede8,#ffffff)}
.icon{
  width:48px;height:48px;border:1px solid rgba(7,21,37,.22);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--navy);font-weight:900;margin-bottom:24px;
}
.service-card p{color:#4e5a6d;font-size:15.5px}
.card-link{display:inline-flex;color:#0c4f8b;font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:12px;margin-top:18px}
.approach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.approach-item{padding:30px;border-left:1px solid rgba(255,255,255,.22)}
.approach-item span{display:block;color:#e5bd66;font-size:13px;font-weight:900;letter-spacing:.14em;margin-bottom:16px}
.insight-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.insight-card{
  background:white;
  border:1px solid var(--line);
  min-height:360px;
  display:flex;
  flex-direction:column;
}
.insight-card .image-band{
  height:115px;
  background:
    linear-gradient(135deg,rgba(7,21,37,.12),rgba(0,113,100,.10)),
    repeating-linear-gradient(115deg,rgba(7,21,37,.16) 0 1px,transparent 1px 13px);
}
.insight-card:nth-child(2) .image-band{background:linear-gradient(135deg,#dfeef7,#ffffff),radial-gradient(circle,#8ba8c5,transparent)}
.insight-card:nth-child(3) .image-band{background:linear-gradient(135deg,#f4ead8,#ffffff)}
.insight-card:nth-child(4) .image-band{background:linear-gradient(135deg,#e7f2ef,#ffffff)}
.insight-card:nth-child(5) .image-band{background:linear-gradient(135deg,#edeaf7,#ffffff)}
.insight-body{padding:24px;display:flex;flex-direction:column;flex:1}
.article-meta{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:#0c4f8b;font-weight:900;margin:0 0 12px}
.insight-body h3{font-size:20px}
.insight-body p{color:var(--muted);font-size:14.5px}
.leader-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.leader-card{
  background:linear-gradient(180deg,#ffffff,#f3f7fa);
  border:1px solid var(--line);
  padding:38px;
  box-shadow:var(--shadow);
}
.leader-card img{width:280px;margin-bottom:28px}
.leader-copy p{color:var(--muted);font-size:18px}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:34px}
.proof{padding:24px;border-top:1px solid var(--line)}
.proof strong{display:block;margin-bottom:8px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px}
.contact-card{background:white;border:1px solid var(--line);box-shadow:var(--shadow);padding:38px}
.footer{background:#06101d;color:rgba(255,255,255,.74);padding:56px 0}
.footer-grid{display:grid;grid-template-columns:1.15fr .85fr .85fr;gap:42px}
.footer img{height:76px;width:auto;margin-bottom:20px;filter:brightness(1.05)}
.footer a{display:block;color:rgba(255,255,255,.84);margin:7px 0}
.page-hero{padding:96px 0 72px;background:linear-gradient(180deg,#fff,#edf6fd)}
.page-hero h1{font-size:clamp(46px,6.2vw,78px)}
.page-hero p{max-width:860px;color:var(--muted);font-size:21px}
.content-grid{display:grid;grid-template-columns:.68fr 1.32fr;gap:52px}
.sidebox{position:sticky;top:125px;background:white;border:1px solid var(--line);padding:30px;box-shadow:0 14px 38px rgba(7,21,37,.06)}
.sidebox a{display:block;padding:13px 0;border-bottom:1px solid var(--line);font-weight:760;color:#26364a}
.sidebox a:last-child{border-bottom:0}
.rich p,.rich li{font-size:18px;color:var(--muted)}
.rich h2{font-size:42px;margin:8px 0 24px}
.rich h3{margin-top:40px;margin-bottom:12px}
.rich blockquote{margin:34px 0;padding:28px;border-left:4px solid var(--teal);background:#f4f7fa;color:#26364a;font-size:20px}
.pill-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}
.pill{padding:10px 15px;border-radius:999px;background:white;border:1px solid var(--line);color:#27364a;font-weight:760}
@media(max-width:1050px){
  .nav{display:grid;grid-template-columns:1fr;gap:12px;padding:18px 0}.header-logo{height:70px}.nav-links{flex-wrap:wrap;gap:14px}
  .hero{min-height:auto;padding:72px 0}.hero-grid,.section-head,.leader-grid,.contact-grid,.footer-grid,.content-grid{grid-template-columns:1fr}
  .service-grid,.approach-grid{grid-template-columns:1fr 1fr}.insight-grid{grid-template-columns:1fr 1fr}.proof-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .service-grid,.approach-grid,.insight-grid,.proof-grid{grid-template-columns:1fr}
  h1{font-size:44px}.section{padding:72px 0}.hero-note{position:relative;width:100%;margin-top:20px}.logo-frame{min-height:260px}
}


.service-icon{
  width:54px;
  height:54px;
  margin-bottom:24px;
  color:#061d35;
}
.service-icon svg{
  width:54px;
  height:54px;
  stroke:currentColor;
  fill:none;
  stroke-width:1.7;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.service-card .icon{display:none}

.insight-card .image-band{
  position:relative;
  overflow:hidden;
}
.insight-card .image-band svg{
  width:100%;
  height:100%;
  display:block;
}
.insight-card:nth-child(1) .image-band{background:linear-gradient(135deg,#dfeef7,#ffffff)}
.insight-card:nth-child(2) .image-band{background:linear-gradient(135deg,#dfe8f2,#f8fbfd)}
.insight-card:nth-child(3) .image-band{background:linear-gradient(135deg,#f3ead9,#ffffff)}
.insight-card:nth-child(4) .image-band{background:linear-gradient(135deg,#e4f1ee,#ffffff)}
.insight-card:nth-child(5) .image-band{background:linear-gradient(135deg,#eeebf8,#ffffff)}

.leader-card.profile-photo-card{
  padding:0;
  overflow:hidden;
  background:#fff;
}
.raoul-photo{
  width:100%;
  height:560px;
  object-fit:cover;
  object-position:center top;
}
.leader-card-caption{
  padding:30px 34px 36px;
}
.leader-card-caption .kicker{margin-bottom:10px}
@media(max-width:1050px){
  .raoul-photo{height:480px}
}


/* Refinements: logo not covered, visual approach cards, non-stretched profile photo */
.hero-visual{
  display:grid;
  grid-template-rows:auto auto;
  gap:26px;
  align-content:center;
  justify-items:center;
}
.logo-frame{
  width:min(700px,100%);
  min-height:440px;
  padding:30px;
}
.logo-frame img{
  max-width:630px;
}
.hero-note{
  position:relative;
  left:auto;
  bottom:auto;
  width:min(630px,100%);
  background:rgba(7,21,37,.94);
  margin-top:0;
}

.approach-grid{
  grid-template-columns:repeat(4,1fr);
}
.approach-item{
  border-left:0;
  padding:0;
  background:rgba(255,255,255,.075);
  border:1px solid rgba(255,255,255,.13);
  min-height:320px;
  display:flex;
  flex-direction:column;
}
.approach-visual{
  height:126px;
  background:rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.approach-visual svg{
  width:100%;
  height:100%;
  display:block;
}
.approach-copy{
  padding:28px;
}
.approach-item span{
  display:none;
}

.insight-card .image-band{
  height:145px;
}
.insight-card .image-band svg{
  height:145px;
}

.leader-card.profile-photo-card{
  max-width:390px;
  justify-self:start;
  border-radius:6px;
  padding:0;
  overflow:hidden;
  background:#fff;
}
.raoul-photo{
  width:100%;
  height:auto;
  max-height:520px;
  object-fit:contain;
  object-position:center;
  background:#eef3f7;
}
.leader-card-caption{
  padding:26px 28px 30px;
}
@media(max-width:1050px){
  .approach-grid{grid-template-columns:1fr 1fr}
  .leader-card.profile-photo-card{max-width:380px}
}
@media(max-width:680px){
  .approach-grid{grid-template-columns:1fr}
  .logo-frame{min-height:300px}
}


/* McKinsey-style refinements: photographic abstract panels, smaller profile portrait */
.approach-item{
  background:#ffffff;
  color:#071525;
  border:1px solid rgba(7,21,37,.08);
  box-shadow:0 18px 46px rgba(7,21,37,.06);
}
.approach-item h3{color:#071525}
.approach-item p{color:#596477}
.approach-visual{
  height:150px;
  background-size:cover;
  background-position:center;
  border-bottom:1px solid rgba(7,21,37,.08);
}
.approach-visual svg{display:none}
.approach-item:nth-child(1) .approach-visual{background-image:url('assets/abstract-6.jpg')}
.approach-item:nth-child(2) .approach-visual{background-image:url('assets/abstract-7.jpg')}
.approach-item:nth-child(3) .approach-visual{background-image:url('assets/abstract-8.jpg')}
.approach-item:nth-child(4) .approach-visual{background-image:url('assets/abstract-9.jpg')}
.dark .approach-item p{color:#596477}

.insight-card .image-band{
  height:150px;
  background-size:cover!important;
  background-position:center!important;
}
.insight-card .image-band svg{display:none}
.insight-card:nth-child(1) .image-band{background-image:url('assets/abstract-1.jpg')!important}
.insight-card:nth-child(2) .image-band{background-image:url('assets/abstract-2.jpg')!important}
.insight-card:nth-child(3) .image-band{background-image:url('assets/abstract-3.jpg')!important}
.insight-card:nth-child(4) .image-band{background-image:url('assets/abstract-4.jpg')!important}
.insight-card:nth-child(5) .image-band{background-image:url('assets/abstract-5.jpg')!important}

.leader-card.profile-photo-card{
  max-width:300px;
  justify-self:start;
  box-shadow:0 18px 48px rgba(7,21,37,.08);
}
.raoul-photo{
  width:100%;
  height:auto;
  max-height:380px;
  object-fit:contain;
  background:#eef3f7;
}
.leader-card-caption{
  padding:20px 22px 24px;
}
.leader-card-caption h2{
  font-size:28px;
}
.leader-grid{
  grid-template-columns:0.42fr 1.58fr;
}
@media(max-width:1050px){
  .leader-grid{grid-template-columns:1fr}
  .leader-card.profile-photo-card{max-width:280px}
}


/* V9 final editorial imagery */
.approach-item:nth-child(1) .approach-visual{background-image:url('assets/how-senior-led.jpg')!important}
.approach-item:nth-child(2) .approach-visual{background-image:url('assets/how-faster-decisions.jpg')!important}
.approach-item:nth-child(3) .approach-visual{background-image:url('assets/how-execution-focus.jpg')!important}
.approach-item:nth-child(4) .approach-visual{background-image:url('assets/how-results.jpg')!important}

.insight-card:nth-child(1) .image-band{background-image:url('assets/insight-savings.jpg')!important}
.insight-card:nth-child(2) .image-band{background-image:url('assets/insight-cloud.jpg')!important}
.insight-card:nth-child(3) .image-band{background-image:url('assets/insight-infrastructure.jpg')!important}
.insight-card:nth-child(4) .image-band{background-image:url('assets/insight-open-banking.jpg')!important}
.insight-card:nth-child(5) .image-band{background-image:url('assets/insight-resilience.jpg')!important}

.nav-links a[href*="#raoul"]{display:none!important}

.leader-grid{
  grid-template-columns:.34fr 1.66fr!important;
}
.leader-card.profile-photo-card{
  max-width:260px!important;
}
.raoul-photo{
  max-height:340px!important;
}
.leader-card-caption h2{
  font-size:24px!important;
}
.leader-copy p{
  font-size:17px!important;
}

/* V10 final: swapped logos and real contextual imagery */
.header-logo{height:82px!important;width:auto;}
.logo-frame.wide-logo-frame{width:min(760px,100%)!important;min-height:430px!important;padding:42px!important;}
.logo-frame.wide-logo-frame img{max-width:680px!important;width:100%!important;}
.hero-note{position:relative!important;margin-top:28px!important;}
.approach-item:nth-child(1) .approach-visual{background-image:linear-gradient(rgba(7,21,37,.18),rgba(7,21,37,.18)),url('https://images.unsplash.com/photo-1552664730-d307ca884978?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.approach-item:nth-child(2) .approach-visual{background-image:linear-gradient(rgba(7,21,37,.16),rgba(7,21,37,.16)),url('https://images.unsplash.com/photo-1517245386807-bb43f82c33c4?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.approach-item:nth-child(3) .approach-visual{background-image:linear-gradient(rgba(7,21,37,.14),rgba(7,21,37,.14)),url('https://images.unsplash.com/photo-1454165804606-c3d57bc86b40?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.approach-item:nth-child(4) .approach-visual{background-image:linear-gradient(rgba(7,21,37,.18),rgba(7,21,37,.18)),url('https://images.unsplash.com/photo-1551288049-bebda4e38f71?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.insight-card:nth-child(1) .image-band{background-image:linear-gradient(rgba(7,21,37,.10),rgba(7,21,37,.10)),url('https://images.unsplash.com/photo-1554224155-6726b3ff858f?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.insight-card:nth-child(2) .image-band{background-image:linear-gradient(rgba(7,21,37,.12),rgba(7,21,37,.12)),url('https://images.unsplash.com/photo-1516321318423-f06f85e504b3?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.insight-card:nth-child(3) .image-band{background-image:linear-gradient(rgba(7,21,37,.12),rgba(7,21,37,.12)),url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.insight-card:nth-child(4) .image-band{background-image:linear-gradient(rgba(7,21,37,.10),rgba(7,21,37,.10)),url('https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
.insight-card:nth-child(5) .image-band{background-image:linear-gradient(rgba(7,21,37,.15),rgba(7,21,37,.15)),url('https://images.unsplash.com/photo-1550751827-4bd374c3f58b?auto=format&fit=crop&w=1200&q=80')!important;background-size:cover!important;background-position:center!important;}
@media(max-width:1050px){.header-logo{height:68px!important;}.logo-frame.wide-logo-frame{min-height:300px!important;}}






}

}


/* V22: Subpage visuals reuse the exact homepage visual language */
.subpage-home-visual{
  width:min(1220px, calc(100% - 48px));
  margin:0 auto 58px;
  display:grid;
  grid-template-columns:.42fr 1.58fr;
  gap:34px;
  align-items:stretch;
}
.subpage-home-visual-card{
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 20px 58px rgba(7,21,37,.08);
  min-height:210px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:34px;
}
.subpage-home-visual-card .service-icon{
  width:96px;
  height:96px;
  margin:0;
}
.subpage-home-visual-card .service-icon svg{
  width:96px;
  height:96px;
}
.subpage-home-visual-card .icon{
  width:96px;
  height:96px;
  margin:0;
  font-size:30px;
}
.subpage-home-visual-card .image-band{
  width:100%;
  height:100%;
  min-height:230px;
}
.subpage-home-visual-card .image-band svg{
  width:100%;
  height:100%;
  min-height:230px;
}
.subpage-home-visual-copy{
  background:linear-gradient(180deg,#ffffff,#f6f8fb);
  border:1px solid var(--line);
  padding:34px 38px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.subpage-home-visual-copy .kicker{
  margin-bottom:12px;
}
.subpage-home-visual-copy h2{
  font-size:34px;
  max-width:760px;
}
.subpage-home-visual-copy p{
  color:var(--muted);
  font-size:17px;
  max-width:820px;
}
@media(max-width:800px){
  .subpage-home-visual{grid-template-columns:1fr;margin-bottom:42px}
  .subpage-home-visual-card{min-height:160px}
}


/* V24 rebuilt subpage design */
.detail-hero{
  padding:92px 0 42px;
  background:linear-gradient(180deg,#ffffff,#edf6fd);
}
.detail-hero .eyebrow{
  color:#0c4f8b;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:12px;
  font-weight:900;
  margin:0 0 18px;
}
.detail-hero h1{
  max-width:980px;
}
.detail-hero p{
  max-width:900px;
  color:var(--muted);
  font-size:21px;
  margin-top:24px;
}
.detail-visual{
  width:min(1220px, calc(100% - 48px));
  margin:0 auto 72px;
  height:380px;
  overflow:hidden;
  box-shadow:0 28px 70px rgba(7,21,37,.12);
  background:#eef3f7;
}
.detail-visual img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(.92) contrast(1.04) brightness(.96);
}
.detail-layout{
  width:min(1120px, calc(100% - 48px));
  margin:0 auto 100px;
  display:grid;
  grid-template-columns:.7fr 1.3fr;
  gap:56px;
}
.detail-side{
  border-top:1px solid var(--line);
  padding-top:26px;
}
.detail-side .side-title{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:900;
  color:#0c4f8b;
  margin-bottom:20px;
}
.detail-side p{
  color:var(--muted);
  font-size:17px;
}
.detail-body{
  background:#fff;
  border:1px solid var(--line);
  padding:46px 52px;
  box-shadow:0 18px 54px rgba(7,21,37,.06);
}
.detail-body h2{
  font-size:38px;
  margin-bottom:22px;
}
.detail-body h3{
  margin-top:36px;
  margin-bottom:10px;
}
.detail-body p, .detail-body li{
  color:var(--muted);
  font-size:18px;
}
.detail-body ul{
  padding-left:22px;
}
.detail-callout{
  margin-top:36px;
  padding:28px 30px;
  background:linear-gradient(135deg,#071525,#0b3458);
  color:#fff;
}
.detail-callout strong{
  display:block;
  font-size:22px;
  margin-bottom:8px;
}
.detail-callout p{
  color:rgba(255,255,255,.78);
  margin:0;
}
@media(max-width:880px){
  .detail-layout{grid-template-columns:1fr}
  .detail-visual{height:260px}
  .detail-body{padding:34px 28px}
}

.detail-body p {margin-bottom:16px;}
.detail-body h3 {margin-top:30px;}


/* V28 homepage and subpage corrections */
.hero-grid{
  align-items:center;
}
.hero-visual{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:24px!important;
  min-height:auto!important;
  position:relative!important;
}
.hero-visual > img.hero-logo-main{
  width:min(680px,100%)!important;
  height:auto!important;
  display:block!important;
  margin:0 auto!important;
}
.hero-message{
  width:min(680px,100%);
  background:#ffffff;
  border:1px solid var(--line);
  box-shadow:0 18px 48px rgba(7,21,37,.08);
  padding:24px 28px;
  text-align:left;
}
.hero-message strong{
  display:block;
  color:var(--ink);
  font-size:22px;
  line-height:1.15;
  letter-spacing:-.02em;
  margin-bottom:8px;
}
.hero-message p{
  color:var(--muted);
  margin:0;
  font-size:16px;
}
.hero-note{display:none!important;}
.logo-frame{display:none!important;}

.service-card p,
.insight-body p{
  line-height:1.48;
}

.detail-hero{
  padding:96px 0 46px!important;
}
.detail-visual{
  width:min(1220px, calc(100% - 48px))!important;
  margin:0 auto 70px!important;
  height:360px!important;
  overflow:hidden!important;
  box-shadow:0 28px 70px rgba(7,21,37,.12)!important;
  background:#eef3f7!important;
}
.detail-visual img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
  filter:saturate(.92) contrast(1.04) brightness(.96)!important;
}
.detail-layout{
  align-items:start;
}
.detail-body p{
  margin-bottom:17px!important;
}
.detail-body h3{
  margin-top:34px!important;
}
.detail-body ul{
  margin-top:8px;
  margin-bottom:18px;
}
.detail-context{
  background:#f6f8fb;
  border-left:4px solid var(--teal);
  padding:22px 24px;
  margin:8px 0 28px;
}
.detail-context p{
  margin:0!important;
  color:#4b586c;
}
@media(max-width:900px){
  .hero-message{text-align:left}
  .detail-visual{height:250px!important}
}

.hero-message{
  background:#071525 !important;
  color:#fff !important;
}
.hero-message p{
  color:rgba(255,255,255,0.75) !important;
}


/* V30 final visual polish — premium consulting finish */
:root{
  --rsv-ink:#071525;
  --rsv-navy:#061d35;
  --rsv-teal:#007164;
  --rsv-gold:#b88a35;
  --rsv-muted:#586477;
  --rsv-line:#dfe7ef;
  --rsv-soft:#f6f8fb;
}

/* Header refinement */
.header{
  box-shadow:0 8px 28px rgba(7,21,37,.035);
}
.header-logo{
  filter:drop-shadow(0 8px 18px rgba(7,21,37,.06));
}
.nav-links a{
  transition:color .22s ease, border-color .22s ease, opacity .22s ease;
}

/* Hero refinement */
.hero{
  background:
    radial-gradient(circle at 82% 12%, rgba(0,113,100,.10), transparent 30%),
    radial-gradient(circle at 18% 92%, rgba(184,138,53,.08), transparent 30%),
    linear-gradient(180deg,#ffffff 0%,#f4f8fb 100%) !important;
}
.hero h1{
  letter-spacing:-.055em;
}
.hero-visual{
  padding:10px 0;
}
.hero-visual > img.hero-logo-main{
  width:min(720px,100%)!important;
  filter:drop-shadow(0 20px 44px rgba(7,21,37,.10));
}
.hero-message{
  background:linear-gradient(135deg,#071525 0%,#09223d 62%,#0b3554 100%) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.12) !important;
  box-shadow:0 26px 70px rgba(7,21,37,.22), inset 0 1px 0 rgba(255,255,255,.08) !important;
  position:relative;
  overflow:hidden;
}
.hero-message:after{
  content:"";
  position:absolute;
  right:-72px;
  top:-76px;
  width:210px;
  height:210px;
  background:radial-gradient(circle, rgba(0,113,100,.34), transparent 68%);
}
.hero-message strong{
  color:#ffffff!important;
  position:relative;
  z-index:1;
}
.hero-message p{
  color:rgba(255,255,255,.78)!important;
  position:relative;
  z-index:1;
}

/* Buttons */
.btn{
  transition:transform .22s ease, box-shadow .22s ease, background .22s ease;
}
.btn:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 42px rgba(7,21,37,.14);
}

/* Section rhythm */
.section{
  padding-top:104px!important;
  padding-bottom:104px!important;
}
.section-head{
  margin-bottom:52px!important;
}
.section-head h2{
  max-width:760px;
}
.section-head p{
  line-height:1.62;
}

/* Services */
.service-card{
  border:1px solid rgba(7,21,37,.075)!important;
  box-shadow:0 14px 38px rgba(7,21,37,.055)!important;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease!important;
}
.service-card:hover{
  transform:translateY(-6px)!important;
  border-color:rgba(0,113,100,.22)!important;
  box-shadow:0 28px 68px rgba(7,21,37,.11)!important;
}
.service-card h3{
  margin-bottom:14px!important;
}
.service-card p{
  color:#4f5b6e!important;
}
.service-icon svg{
  stroke:#061d35!important;
}

/* How we work */
.approach-item{
  border:1px solid rgba(255,255,255,.14)!important;
  box-shadow:0 18px 50px rgba(0,0,0,.13);
}
.approach-item h3{
  letter-spacing:-.03em;
}
.approach-copy p{
  line-height:1.56;
}

/* Insight cards */
.insight-card{
  border:1px solid rgba(7,21,37,.08)!important;
  box-shadow:0 14px 38px rgba(7,21,37,.055)!important;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease!important;
}
.insight-card:hover{
  transform:translateY(-5px);
  box-shadow:0 28px 68px rgba(7,21,37,.11)!important;
  border-color:rgba(12,79,139,.18)!important;
}
.insight-body h3{
  letter-spacing:-.035em;
  line-height:1.08;
}
.insight-body p{
  line-height:1.52;
}

/* Raoul section */
.leader-card.profile-photo-card{
  box-shadow:0 24px 60px rgba(7,21,37,.11)!important;
}
.raoul-photo{
  filter:saturate(.96) contrast(1.03);
}
.proof{
  border-top-color:rgba(7,21,37,.13)!important;
}

/* Contact */
.contact-card{
  border:1px solid rgba(7,21,37,.08)!important;
}
.contact-card a{
  color:#0c4f8b;
  font-weight:750;
}

/* Detail pages */
.detail-hero{
  background:
    radial-gradient(circle at 82% 20%, rgba(0,113,100,.10), transparent 30%),
    linear-gradient(180deg,#ffffff,#edf6fd)!important;
}
.detail-hero h1{
  letter-spacing:-.052em;
}
.detail-visual{
  border:1px solid rgba(255,255,255,.9);
}
.detail-body{
  border:1px solid rgba(7,21,37,.08)!important;
  box-shadow:0 22px 62px rgba(7,21,37,.075)!important;
}
.detail-body h2{
  letter-spacing:-.045em;
}
.detail-body h3{
  color:#071525;
}
.detail-context{
  background:linear-gradient(180deg,#f6f8fb,#ffffff)!important;
  border-left:4px solid var(--rsv-teal)!important;
  box-shadow:0 12px 34px rgba(7,21,37,.04);
}
.detail-callout{
  background:linear-gradient(135deg,#071525,#0b3458)!important;
  box-shadow:0 20px 50px rgba(7,21,37,.14);
}

/* Footer */
.footer{
  background:linear-gradient(135deg,#06101d,#071525)!important;
}
.footer img{
  filter:brightness(1.08) drop-shadow(0 14px 26px rgba(0,0,0,.18))!important;
}

/* Accessibility / responsive spacing */
@media(max-width:900px){
  .section{padding-top:76px!important;padding-bottom:76px!important;}
  .hero-message{padding:22px 22px!important;}
  .hero-visual > img.hero-logo-main{width:min(560px,100%)!important;}
}

/* ── Subpage enhancements: perspectives grid, metrics, pullquote ─────────── */
.perspectives-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  margin:36px 0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
.perspective{
  padding:26px 24px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:#fafcfe;
}
.perspective .pers-tag{
  font-size:10px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#0c4f8b;
  margin-bottom:8px;
}
.perspective h4{
  font-size:16px;
  font-weight:700;
  margin:0 0 10px;
  color:var(--ink);
}
.perspective p{
  font-size:15px;
  color:var(--muted);
  line-height:1.6;
  margin:0;
}
.metric-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  margin:36px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:#f4f8fc;
}
.metric{
  padding:22px 20px;
  border-right:1px solid var(--line);
}
.metric:last-child{border-right:none;}
.metric-num{
  font-size:34px;
  font-weight:800;
  line-height:1;
  color:#0c4f8b;
  margin-bottom:6px;
  letter-spacing:-.02em;
}
.metric-label{
  font-size:13px;
  color:var(--muted);
  line-height:1.45;
}
.detail-pullquote{
  margin:36px 0;
  padding:0 0 0 24px;
  border-left:2px solid #b89b5e;
}
.detail-pullquote p{
  font-size:22px!important;
  font-style:italic;
  color:var(--ink)!important;
  line-height:1.4;
  margin:0;
}
.detail-pullquote .attr{
  margin-top:12px;
  font-size:12px!important;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted)!important;
  font-style:normal;
}
.detail-inline-img{
  margin:36px 0;
}
.detail-inline-img img{
  width:100%;
  height:260px;
  object-fit:cover;
  display:block;
  filter:saturate(.92) contrast(1.04) brightness(.96);
}
.detail-inline-img .caption{
  font-size:13px;
  color:var(--muted);
  margin-top:8px;
  font-style:italic;
}
@media(max-width:780px){
  .perspectives-grid{grid-template-columns:1fr;}
  .metric-strip{grid-template-columns:1fr;}
  .metric{border-right:none;border-bottom:1px solid var(--line);}
  .metric:last-child{border-bottom:none;}
}

/* ═══════════════════════════════════════════════════════════════════════════
   RSV CONSULT — McKINSEY POLISH LAYER
   Applied on top of all previous layers.
   Changes: typography, palette restraint, card clarity, subpage coherence.
   Structure, images and layout grids are untouched.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Google Fonts: Inter + source for editorial feel ─────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── Design tokens override ──────────────────────────────────────────────── */
:root{
  --ink:     #0D1B2A;   /* Deeper, richer navy */
  --navy:    #071525;
  --teal:    #006B5E;
  --gold:    #A8813A;
  --muted:   #4E5E72;
  --line:    #E0E6EE;
  --bg:      #F7F8FA;   /* Almost white, not blue-tinted */
  --blue-accent: #0A3F72;
}

/* ── Base typography ─────────────────────────────────────────────────────── */
body{
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  color: var(--ink) !important;
  background: #FFFFFF !important;
}

/* Headings: less aggressive letter-spacing, more editorial */
h1{ font-weight: 700 !important; letter-spacing: -0.03em !important; line-height: 1.06 !important; }
h2{ font-weight: 700 !important; letter-spacing: -0.025em !important; line-height: 1.08 !important; }
h3{ font-weight: 600 !important; letter-spacing: -0.015em !important; line-height: 1.2 !important; }
h4{ font-weight: 600 !important; letter-spacing: -0.01em !important; }

/* Kicker / eyebrow labels */
.kicker, .eyebrow{
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--blue-accent) !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.kicker::before, .eyebrow::before{
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--blue-accent);
  flex-shrink: 0;
}

/* ── Header — cleaner, sharper ───────────────────────────────────────────── */
.header{
  background: rgba(255,255,255,0.96) !important;
  backdrop-filter: blur(20px) !important;
  border-bottom: 1px solid var(--line) !important;
  box-shadow: none !important;
}
.nav{ min-height: 88px !important; }
.nav-links{
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: #2A3A4E !important;
  gap: 32px !important;
}
.nav-links a{
  border-bottom: 1px solid transparent !important;
  padding-bottom: 3px !important;
  transition: color 0.2s, border-color 0.2s !important;
}
.nav-links a:hover{
  color: var(--blue-accent) !important;
  border-bottom-color: var(--blue-accent) !important;
}

/* ── Hero — cleaner background, less gradient noise ─────────────────────── */
.hero{
  background: #FFFFFF !important;
  border-bottom: 1px solid var(--line) !important;
}
.hero:after{ display: none !important; }
.hero h1{ color: var(--ink) !important; }
.hero .lead{ color: var(--muted) !important; font-size: 19px !important; font-weight: 400 !important; }

/* Hero message box */
.hero-message{
  background: var(--navy) !important;
  border: none !important;
  border-left: 3px solid var(--gold) !important;
  border-radius: 0 !important;
  padding: 22px 26px !important;
}
.hero-message strong{ font-size: 18px !important; font-weight: 600 !important; letter-spacing: -0.01em !important; }

/* ── Buttons — sharp, flat McKinsey style ───────────────────────────────── */
.btn{
  border-radius: 0 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  min-height: 48px !important;
  padding: 0 28px !important;
  transition: background 0.2s, color 0.2s, border-color 0.2s !important;
}
.btn.dark{
  background: var(--navy) !important;
  box-shadow: none !important;
}
.btn.dark:hover{ background: var(--blue-accent) !important; }
.btn.light{
  background: transparent !important;
  border: 1px solid #7A90A8 !important;
  color: var(--navy) !important;
}
.btn.light:hover{
  background: var(--navy) !important;
  color: white !important;
  border-color: var(--navy) !important;
}

/* ── Sections — neutral backgrounds instead of colored gradients ─────────── */
.section{ padding: 96px 0 !important; }
.soft-blue{ background: #F7F8FA !important; }
.soft-sand{ background: #F7F8FA !important; }
.white{ background: #FFFFFF !important; }
.dark{ background: var(--navy) !important; }

/* Section heads: thin rule above kicker */
.section-head{
  margin-bottom: 56px !important;
  padding-bottom: 36px !important;
  border-bottom: 1px solid var(--line) !important;
}

/* ── Service cards — white, flat, left-accent-bar, no color gradients ────── */
.service-card{
  background: #FFFFFF !important;
  border: 1px solid var(--line) !important;
  border-radius: 0 !important;
  border-left: 3px solid transparent !important;
  box-shadow: 0 2px 12px rgba(13,27,42,0.04) !important;
  padding: 32px 28px !important;
  transition: border-left-color 0.2s, box-shadow 0.2s, transform 0.2s !important;
}
.service-card:hover{
  border-left-color: var(--blue-accent) !important;
  box-shadow: 0 12px 40px rgba(13,27,42,0.08) !important;
  transform: translateY(-3px) !important;
}
/* Each service card gets a distinct accent color on hover via nth-child */
.service-card:nth-child(1){ background: #FFFFFF !important; }
.service-card:nth-child(2){ background: #FFFFFF !important; }
.service-card:nth-child(3){ background: #FFFFFF !important; }
.service-card:nth-child(4){ background: #FFFFFF !important; }
.service-card:nth-child(5){ background: #FFFFFF !important; }
.service-card:nth-child(6){ background: #FFFFFF !important; }
.service-card h3{ font-size: 20px !important; margin-bottom: 10px !important; }
.service-card p{ font-size: 15px !important; color: var(--muted) !important; line-height: 1.55 !important; }
.card-link{
  color: var(--blue-accent) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid transparent !important;
  transition: border-color 0.2s !important;
}
.card-link:hover{ border-bottom-color: var(--blue-accent) !important; }

/* Service icons: restrained, monochrome */
.service-icon{ color: var(--blue-accent) !important; }
.service-icon svg{ stroke-width: 1.5 !important; }

/* ── Approach section (dark) ─────────────────────────────────────────────── */
.approach-item{
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.approach-item h3{ font-size: 20px !important; font-weight: 600 !important; }
.approach-item p{ color: rgba(255,255,255,0.65) !important; font-size: 15px !important; }
.approach-visual{ border-bottom: 1px solid rgba(255,255,255,0.08) !important; }
.approach-copy{ padding: 24px 26px !important; }

/* ── Insight cards — clean editorial ─────────────────────────────────────── */
.insight-card{
  border-radius: 0 !important;
  border: 1px solid var(--line) !important;
  box-shadow: 0 2px 10px rgba(13,27,42,0.04) !important;
  transition: box-shadow 0.2s, transform 0.2s !important;
}
.insight-card:hover{
  box-shadow: 0 14px 40px rgba(13,27,42,0.09) !important;
  transform: translateY(-2px) !important;
}
.insight-body h3{ font-size: 17px !important; font-weight: 600 !important; line-height: 1.3 !important; }
.insight-body p{ font-size: 14px !important; line-height: 1.55 !important; color: var(--muted) !important; }
.article-meta{ font-size: 10px !important; letter-spacing: 0.14em !important; color: var(--blue-accent) !important; }

/* ── Leader / Raoul section ──────────────────────────────────────────────── */
.leader-card{
  border-radius: 0 !important;
  border: 1px solid var(--line) !important;
  box-shadow: 0 4px 24px rgba(13,27,42,0.06) !important;
}
.leader-copy p{ font-size: 16px !important; line-height: 1.65 !important; color: #3A4A5E !important; }
.proof{
  border-top: 1px solid var(--line) !important;
  padding: 20px 0 !important;
}
.proof strong{
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  margin-bottom: 4px !important;
}
.proof span{ font-size: 13px !important; color: var(--muted) !important; }

/* ── Contact section ─────────────────────────────────────────────────────── */
.contact-card{
  border-radius: 0 !important;
  border: 1px solid var(--line) !important;
  border-top: 3px solid var(--blue-accent) !important;
  box-shadow: none !important;
  padding: 36px !important;
}
.contact-card h3{ font-size: 22px !important; margin-bottom: 16px !important; }
.contact-card p{ font-size: 15px !important; color: var(--muted) !important; }
.contact-card a{ color: var(--blue-accent) !important; }

/* Why RSV link — polished CTA */
.why-rsv-cta{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--blue-accent);
  border-bottom: 1px solid var(--blue-accent);
  padding-bottom: 3px;
  transition: color 0.2s, border-color 0.2s;
}
.why-rsv-cta:hover{ color: var(--navy); border-color: var(--navy); }
.why-rsv-cta::after{ content: '↗'; font-size: 13px; }

/* ── Footer — refined ────────────────────────────────────────────────────── */
.footer{
  background: var(--navy) !important;
  padding: 64px 0 32px !important;
  border-top: 3px solid var(--blue-accent) !important;
}
.footer strong{ font-weight: 600 !important; font-size: 11px !important; letter-spacing: 0.12em !important; text-transform: uppercase !important; color: rgba(255,255,255,0.4) !important; margin-bottom: 16px !important; display: block !important; }
.footer a{ font-size: 14px !important; color: rgba(255,255,255,0.72) !important; margin: 8px 0 !important; }
.footer a:hover{ color: #FFFFFF !important; }
.footer p{ font-size: 14px !important; color: rgba(255,255,255,0.5) !important; }

/* ── Detail pages — subpage coherence ───────────────────────────────────── */
.detail-hero{
  background: #FFFFFF !important;
  padding: 80px 0 40px !important;
  border-bottom: 1px solid var(--line) !important;
}
.detail-hero .eyebrow{
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.14em !important;
  color: var(--blue-accent) !important;
  text-transform: uppercase !important;
  margin-bottom: 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.detail-hero .eyebrow::before{
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--blue-accent);
}
.detail-hero h1{
  font-size: clamp(36px, 5vw, 62px) !important;
  letter-spacing: -0.03em !important;
  line-height: 1.06 !important;
  font-weight: 700 !important;
  max-width: 900px !important;
}
.detail-hero p{
  font-size: 19px !important;
  color: var(--muted) !important;
  font-weight: 400 !important;
  line-height: 1.55 !important;
  max-width: 780px !important;
  margin-top: 20px !important;
}
.detail-visual{
  border-radius: 0 !important;
  box-shadow: 0 8px 40px rgba(13,27,42,0.10) !important;
}
.detail-side .side-title{
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  color: var(--blue-accent) !important;
  text-transform: uppercase !important;
}
.detail-side p{ font-size: 15px !important; line-height: 1.6 !important; }
.detail-body{
  border-radius: 0 !important;
  border: 1px solid var(--line) !important;
  border-top: 3px solid var(--blue-accent) !important;
  box-shadow: 0 4px 24px rgba(13,27,42,0.05) !important;
  padding: 44px 48px !important;
}
.detail-body h2{
  font-size: 32px !important;
  letter-spacing: -0.02em !important;
  font-weight: 700 !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid var(--line) !important;
  margin-bottom: 28px !important;
}
.detail-body h3{
  font-size: 18px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--ink) !important;
  margin-top: 36px !important;
  margin-bottom: 12px !important;
  padding-top: 4px !important;
}
.detail-body p, .detail-body li{
  font-size: 16px !important;
  line-height: 1.7 !important;
  color: #3A4A5E !important;
}
.detail-body ul{ margin: 8px 0 20px !important; }
.detail-body ul li{ margin-bottom: 8px !important; }
.detail-callout{
  border-radius: 0 !important;
  background: var(--navy) !important;
  border-left: 3px solid var(--gold) !important;
  padding: 28px 32px !important;
  margin-top: 40px !important;
}
.detail-callout strong{
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin-bottom: 10px !important;
}
.detail-callout p{
  font-size: 18px !important;
  color: rgba(255,255,255,0.88) !important;
  font-weight: 400 !important;
  font-style: italic !important;
  line-height: 1.5 !important;
}

/* Perspectives grid — polish */
.perspectives-grid{ border-color: var(--line) !important; margin: 40px 0 !important; }
.perspective{ background: #F7F8FA !important; border-color: var(--line) !important; padding: 28px 24px !important; }
.perspective .pers-tag{
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  color: var(--blue-accent) !important;
  text-transform: uppercase !important;
  margin-bottom: 10px !important;
}
.perspective h4{ font-size: 15px !important; font-weight: 600 !important; color: var(--ink) !important; margin-bottom: 8px !important; }
.perspective p{ font-size: 14px !important; line-height: 1.58 !important; color: var(--muted) !important; }

/* Metric strip — polish */
.metric-strip{ background: #F7F8FA !important; border-color: var(--line) !important; margin: 40px 0 !important; }
.metric{ padding: 24px 22px !important; border-color: var(--line) !important; }
.metric-num{ font-size: 32px !important; font-weight: 700 !important; color: var(--blue-accent) !important; letter-spacing: -0.02em !important; }
.metric-label{ font-size: 13px !important; color: var(--muted) !important; line-height: 1.45 !important; }

/* Pull-quote — gold border */
.detail-pullquote{ border-left: 2px solid var(--gold) !important; padding: 4px 0 4px 24px !important; margin: 40px 0 !important; }
.detail-pullquote p{ font-size: 20px !important; color: var(--ink) !important; font-weight: 400 !important; line-height: 1.4 !important; }
.detail-pullquote .attr{ font-size: 11px !important; color: var(--muted) !important; letter-spacing: 0.12em !important; margin-top: 10px !important; }

/* Inline image in detail body */
.detail-inline-img{ margin: 36px 0 !important; }
.detail-inline-img img{ height: 240px !important; box-shadow: 0 4px 24px rgba(13,27,42,0.08) !important; }
.detail-inline-img .caption{ font-size: 13px !important; color: var(--muted) !important; font-style: italic !important; margin-top: 10px !important; }

/* Insights index page */
.page-hero{ background: var(--navy) !important; color: white !important; padding: 100px 0 64px !important; }
.page-hero .kicker{ color: rgba(255,255,255,0.5) !important; }
.page-hero .kicker::before{ background: rgba(255,255,255,0.4) !important; }
.page-hero h1{ color: white !important; }
.page-hero p{ color: rgba(255,255,255,0.7) !important; }

/* ── Responsive tweaks ───────────────────────────────────────────────────── */
@media(max-width:880px){
  .detail-body{ padding: 28px 24px !important; }
  .detail-hero h1{ font-size: 32px !important; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   RSV CONSULT v36 — BRAND IDENTITY LAYER
   Exact colors from new logo: navy #011e3e · teal #04635c
   Top-tier consulting palette + Inter typeface system
   ═══════════════════════════════════════════════════════════════════════════ */

/* Brand tokens */
:root{
  --brand-navy:   #011e3e;   /* RSV letters navy */
  --brand-teal:   #04635c;   /* CONSULT teal */
  --brand-teal-l: #e6f2f1;   /* teal 8% for backgrounds */
  --brand-navy-l: #e8edf3;   /* navy 8% */
  --brand-gold:   #B8922E;
  --brand-white:  #ffffff;
  --brand-off:    #F5F7F9;   /* off-white, barely blue */
  --brand-line:   #D6DCE6;
  --brand-muted:  #4A5A6E;
  --brand-text:   #0D1F35;

  /* Override old tokens */
  --ink:   #011e3e !important;
  --navy:  #011e3e !important;
  --teal:  #04635c !important;
  --gold:  #B8922E !important;
  --muted: #4A5A6E !important;
  --line:  #D6DCE6 !important;
  --bg:    #F5F7F9 !important;
  --blue-accent: #04635c !important;   /* teal as main accent */
  --blue:  #04635c !important;
}

/* ── Typeface: Inter variable ───────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;1,14..32,400&display=swap');

body{
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  color: var(--brand-text) !important;
  background: #ffffff !important;
  font-feature-settings: "cv02","cv03","cv04","cv11" !important;
}

/* ── Headings: controlled, not over-compressed ──────────────────────────── */
h1{ font-size: clamp(46px,6.5vw,82px) !important; font-weight: 700 !important; letter-spacing: -0.032em !important; line-height: 1.05 !important; color: var(--brand-navy) !important; }
h2{ font-size: clamp(30px,3.8vw,50px) !important; font-weight: 700 !important; letter-spacing: -0.028em !important; line-height: 1.09 !important; color: var(--brand-navy) !important; }
h3{ font-size: clamp(18px,2vw,24px) !important; font-weight: 600 !important; letter-spacing: -0.015em !important; color: var(--brand-navy) !important; }

/* ── Kicker: teal rule + teal text ─────────────────────────────────────── */
.kicker, .eyebrow{
  color: var(--brand-teal) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.13em !important;
}
.kicker::before, .eyebrow::before{
  background: var(--brand-teal) !important;
  width: 24px !important;
  height: 1px !important;
}

/* ── Header ─────────────────────────────────────────────────────────────── */
.header{
  background: rgba(255,255,255,0.97) !important;
  border-bottom: 1px solid var(--brand-line) !important;
  box-shadow: 0 1px 0 var(--brand-line) !important;
}
.nav{ min-height: 80px !important; }
.nav-links{
  color: var(--brand-navy) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.07em !important;
  gap: 36px !important;
}
.nav-links a:hover{ color: var(--brand-teal) !important; border-bottom-color: var(--brand-teal) !important; }

/* ── Hero ────────────────────────────────────────────────────────────────── */
.hero{
  background: #ffffff !important;
  border-bottom: 1px solid var(--brand-line) !important;
}
.hero h1{ color: var(--brand-navy) !important; }
.hero .lead{ color: var(--brand-muted) !important; font-size: 18px !important; line-height: 1.65 !important; font-weight: 400 !important; }
.hero-message{
  background: var(--brand-navy) !important;
  border-left: 3px solid var(--brand-teal) !important;
  border-radius: 0 !important;
}
.btn.dark{
  background: var(--brand-navy) !important;
  border-color: var(--brand-navy) !important;
  border-radius: 0 !important;
}
.btn.dark:hover{ background: var(--brand-teal) !important; border-color: var(--brand-teal) !important; }
.btn.light{
  border-color: var(--brand-navy) !important;
  color: var(--brand-navy) !important;
  border-radius: 0 !important;
}
.btn.light:hover{ background: var(--brand-navy) !important; color: #fff !important; }

/* ── Section backgrounds ─────────────────────────────────────────────────── */
.soft-blue{ background: var(--brand-off) !important; }
.soft-sand{ background: var(--brand-off) !important; }
.white{ background: #ffffff !important; }
.dark{
  background: var(--brand-navy) !important;
}
.section-head{
  border-bottom: 1px solid var(--brand-line) !important;
}

/* ── Service cards: photo version (images injected by JS) ───────────────── */
.service-card{
  background: #ffffff !important;
  border: 1px solid var(--brand-line) !important;
  border-radius: 0 !important;
  border-left: 3px solid transparent !important;
  box-shadow: 0 1px 4px rgba(1,30,62,.04) !important;
  padding: 0 !important;           /* reset for image layout */
  display: flex !important;
  flex-direction: column !important;
  transition: border-left-color .22s, box-shadow .22s, transform .22s !important;
  overflow: hidden !important;
  min-height: 340px !important;
}
.service-card:hover{
  border-left-color: var(--brand-teal) !important;
  box-shadow: 0 10px 36px rgba(1,30,62,.10) !important;
  transform: translateY(-3px) !important;
}
.service-card .service-icon{ display: none !important; }  /* hide SVG icons */
.svc-img{
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
  filter: saturate(0.85) contrast(1.05);
  transition: filter .3s;
}
.service-card:hover .svc-img{ filter: saturate(1) contrast(1.05); }
.svc-body{ padding: 22px 24px 20px; flex: 1; display: flex; flex-direction: column; }
.svc-body h3{ font-size: 17px !important; margin-bottom: 10px !important; }
.svc-body p{ font-size: 14.5px !important; color: var(--brand-muted) !important; line-height: 1.55 !important; flex:1; margin: 0 0 14px !important; }
.card-link{ color: var(--brand-teal) !important; font-size: 11px !important; font-weight: 700 !important; letter-spacing: .09em !important; }
.card-link:hover{ border-bottom-color: var(--brand-teal) !important; }

/* ── Approach cards (dark section) ──────────────────────────────────────── */
.approach-item{
  background: rgba(255,255,255,.055) !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.approach-copy h3{ color: #fff !important; font-size: 18px !important; }
.approach-copy p{ color: rgba(255,255,255,.65) !important; font-size: 14.5px !important; }

/* ── Insight cards ───────────────────────────────────────────────────────── */
.insight-card{
  border: 1px solid var(--brand-line) !important;
  border-radius: 0 !important;
  box-shadow: 0 1px 4px rgba(1,30,62,.04) !important;
}
.insight-card:hover{
  box-shadow: 0 10px 32px rgba(1,30,62,.09) !important;
  transform: translateY(-2px) !important;
}
.article-meta{ color: var(--brand-teal) !important; }
.insight-body h3{ color: var(--brand-navy) !important; font-size: 16px !important; }
.insight-body p{ color: var(--brand-muted) !important; }

/* ── Detail pages ────────────────────────────────────────────────────────── */
.detail-hero .eyebrow{ color: var(--brand-teal) !important; }
.detail-hero .eyebrow::before{ background: var(--brand-teal) !important; }
.detail-side .side-title{ color: var(--brand-teal) !important; }
.detail-body{ border-top: 3px solid var(--brand-teal) !important; }
.detail-callout{ border-left: 3px solid var(--brand-teal) !important; background: var(--brand-navy) !important; }
.detail-callout strong{ color: var(--brand-teal) !important; }
.detail-pullquote{ border-left-color: var(--brand-teal) !important; }
.metric-num{ color: var(--brand-teal) !important; }
.perspective .pers-tag{ color: var(--brand-teal) !important; }

/* ── Contact card ────────────────────────────────────────────────────────── */
.contact-card{ border-top: 3px solid var(--brand-teal) !important; }
.contact-card a{ color: var(--brand-teal) !important; }
.why-rsv-cta{ color: var(--brand-teal) !important; border-color: var(--brand-teal) !important; }

/* ── Footer ──────────────────────────────────────────────────────────────── */
.footer{ background: var(--brand-navy) !important; border-top: 3px solid var(--brand-teal) !important; }
.footer a:hover{ color: var(--brand-teal) !important; }

/* ── Page hero (insights index) ─────────────────────────────────────────── */
.page-hero{ background: var(--brand-navy) !important; }
.page-hero h1{ color: #fff !important; }

/* ── Coverage section (new) ─────────────────────────────────────────────── */
.coverage-section{
  background: var(--brand-navy);
  color: white;
  padding: 72px 0;
  border-bottom: 3px solid var(--brand-teal);
}
.coverage-grid{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.12);
  border-left: 1px solid rgba(255,255,255,.12);
  margin-top: 40px;
}
.coverage-cell{
  border-right: 1px solid rgba(255,255,255,.12);
  border-bottom: 1px solid rgba(255,255,255,.12);
  padding: 28px 26px 30px;
}
.coverage-cell .region{
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--brand-teal);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.coverage-cell .region::before{
  content: '';
  display: inline-block;
  width: 18px; height: 1px;
  background: var(--brand-teal);
}
.coverage-cell h4{ font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 8px; letter-spacing: -.01em; }
.coverage-cell p{ font-size: 13.5px; color: rgba(255,255,255,.58); line-height: 1.55; margin: 0; }

/* ── Proof grid (Raoul section) ─────────────────────────────────────────── */
.proof strong{ color: var(--brand-navy) !important; }
.proof{ border-top-color: var(--brand-line) !important; }

@media(max-width:1050px){
  .coverage-grid{ grid-template-columns: 1fr 1fr; }
}
@media(max-width:680px){
  .coverage-grid{ grid-template-columns: 1fr; }
  .svc-img{ height: 130px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE FIX — Leader / Raoul section photo overflow + responsive cleanup
   ═══════════════════════════════════════════════════════════════════════════ */

/* Desktop: force correct grid ratio */
.leader-grid{
  display: grid !important;
  grid-template-columns: 0.38fr 1.62fr !important;
  gap: 56px !important;
  align-items: start !important;
}

/* Tablet */
@media (max-width: 1050px){
  .leader-grid{
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
  .leader-card.profile-photo-card{
    display: grid !important;
    grid-template-columns: 200px 1fr !important;
    gap: 0 !important;
    max-width: 100% !important;
    align-items: center !important;
  }
  .raoul-photo{
    width: 200px !important;
    height: 200px !important;
    max-height: 200px !important;
    object-fit: cover !important;
    object-position: center top !important;
    display: block !important;
    flex-shrink: 0 !important;
  }
  .leader-card-caption{
    padding: 20px 24px !important;
  }
  .leader-card-caption h2{
    font-size: 20px !important;
  }
  .leader-copy{
    margin-top: 24px !important;
  }
  .proof-grid{
    grid-template-columns: 1fr 1fr !important;
  }
}

/* Mobile */
@media (max-width: 680px){
  .leader-grid{
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
  .leader-card.profile-photo-card{
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    max-width: 100% !important;
    padding: 0 !important;
    gap: 0 !important;
  }
  .raoul-photo{
    width: 120px !important;
    min-width: 120px !important;
    height: 120px !important;
    max-height: 120px !important;
    object-fit: cover !important;
    object-position: center top !important;
    display: block !important;
    flex-shrink: 0 !important;
  }
  .leader-card-caption{
    padding: 16px 18px !important;
  }
  .leader-card-caption h2{
    font-size: 17px !important;
    letter-spacing: -0.01em !important;
    line-height: 1.2 !important;
  }
  .leader-copy{
    padding: 0 !important;
    margin-top: 20px !important;
  }
  .leader-copy p{
    font-size: 15px !important;
  }
  .proof-grid{
    grid-template-columns: 1fr 1fr !important;
    gap: 0 !important;
  }
  .proof{
    padding: 14px 4px !important;
  }
  /* Service grid: 1 col on mobile */
  .service-grid{
    grid-template-columns: 1fr !important;
  }
  /* Approach: 1 col on mobile */
  .approach-grid{
    grid-template-columns: 1fr 1fr !important;
  }
  /* Coverage: 1 col on mobile */
  .coverage-grid{
    grid-template-columns: 1fr !important;
  }
  /* Contact: stack */
  .contact-grid{
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  /* Section head */
  .section-head{
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  /* Nav spacing */
  .nav{
    min-height: 64px !important;
    padding: 0 !important;
  }
  .header-logo{
    height: 40px !important;
  }
  /* Hero */
  .hero-grid{
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  /* Footer */
  .footer-grid{
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }
  /* Insight grid mobile: 1 col */
  .insight-grid{
    grid-template-columns: 1fr !important;
  }
  h1{ font-size: 38px !important; }
  h2{ font-size: 28px !important; }
  .section{ padding: 56px 0 !important; }
  .coverage-section{ padding: 56px 0 !important; }
  /* Detail pages mobile */
  .detail-layout{
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .detail-body{
    padding: 24px 20px !important;
  }
  .perspectives-grid{
    grid-template-columns: 1fr !important;
  }
  .metric-strip{
    grid-template-columns: 1fr !important;
  }
}
