:root {
  --blue-900:#111E42;--blue-800:#1B2D5E;--blue-700:#1E3570;--blue-600:#1565C0;--blue-500:#1976D2;--blue-300:#64B5F6;--blue-200:#BBDEFB;--blue-100:#E3F2FD;
  --green-700:#1B5E20;--green-600:#2E7D32;--green-500:#388E3C;--green-400:#66BB6A;--green-300:#A5D6A7;--green-200:#C8E6C9;--green-100:#E8F5E9;
  --gray-50:#F6F9FC;--gray-100:#EDF1F8;--gray-200:#D1DAE8;--gray-300:#B0BDD4;--gray-400:#8896AE;--gray-500:#6B7280;--gray-600:#4B5563;--gray-700:#374151;--gray-800:#1F2937;
  --purple-dark:#5B3F8A;--purple-light:#C0B5E0;--purple-pale:#EDE8F8;--purple-glow:rgba(123,85,176,.25);
  --bg-light:#F6F9FC;--font-display:'Libre Baskerville',Georgia,serif;--font-body:'Source Sans 3',system-ui,sans-serif;
  --navy:       #111E42;
  --navy-2:     #152550;
  --navy-3:     #1B2D5E;
  --blue:       #1565C0;
  --blue-h:     #0E4FA3;
  --blue-lt:    #EBF4FF;
  --blue-mid:   #D1E8FF;
  --teal:       #00838F;
  --teal-h:     #006974;
  --teal-mid:   #00ACC1;
  --teal-lt:    #D4EFF2;
  --slate:      #D1DAE8;
  --slate-lt:   #EDF1F8;
  --purple:     #7B55B0;
  --purple-lt:  #C0B5E0;
  --green:      #388E3C;
  --green-lt:   #EBF5EB;
  --green-mid:  #66BB6A;
  --white:      #FFFFFF;
  --off-white:  #F6F9FC;
  --border:     #D1DAE8;
  --border-2:   #B8C5D8;
  --text-h:     #111E42;
  --text-body:  #1F2937;
  --text-muted: #6B7280;
  --text-faint: #9CA3AF;
  --shadow-sm:  0 1px 4px rgba(17,30,66,.09), 0 2px 8px rgba(17,30,66,.05);
  --shadow-md:  0 4px 16px rgba(17,30,66,.12), 0 1px 4px rgba(17,30,66,.06);
  --shadow-lg:  0 12px 36px rgba(17,30,66,.15), 0 4px 10px rgba(17,30,66,.07);
  --shadow-xl:  0 24px 56px rgba(17,30,66,.18);
  --r:     8px;
  --r-lg:  12px;
  --r-xl:  16px;
  --r-2xl: 20px;
  --font-h: 'Libre Baskerville', Georgia, serif;
  --font-b: 'Source Sans 3', system-ui, sans-serif;
  --max-w: 1200px;
  --nav-h: 155px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--font-b);
  background:var(--white);
  color:var(--text-body);
  font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
html{overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:var(--font-b)}
::selection{background:var(--blue);color:#fff}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(5px,-9px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-7px,6px)}}
@keyframes float3{0%,100%{transform:translate(0,0)}50%{transform:translate(6px,7px)}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--white);
  border-bottom:2px solid var(--navy);
  transition:box-shadow .25s;
}
.nav.scrolled{box-shadow:0 2px 16px rgba(17,30,66,.14)}
.nav-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;height:var(--nav-h);
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-h);font-weight:700;font-size:19px;
  color:var(--navy);text-decoration:none;letter-spacing:-.3px;flex-shrink:0;
}
.nav-logo-icon{width:240px;height:132px;display:flex;align-items:center}
.nav-logo-icon img{width:100%;height:100%;object-fit:contain}

.nav-links{display:flex;gap:4px;align-items:center;flex-wrap:nowrap}
.nav-links>a{  color:var(--navy);font-size:14px;font-weight:600;
  padding:7px 12px;border-radius:var(--r);
  transition:color .18s,background .18s;white-space:nowrap;
font-family:var(--font-b);}
.nav-links>a.active{color:var(--teal);font-weight:700}

  content:'';display:inline-block;width:6px;height:6px;
  border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px);transition:transform .2s;
}
  display:none;position:absolute;top:calc(100% - 8px);left:0;
  background:var(--white);border:1px solid var(--border);
  border-top:3px solid var(--navy);
  border-radius:0 0 var(--r-lg) var(--r-lg);
  box-shadow:var(--shadow-lg);min-width:296px;padding:16px 8px 8px 8px;
  animation:slideDown .18s ease;z-index:200;
}
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-radius:var(--r);
  color:var(--text-body);font-size:14px;font-weight:500;
  transition:background .15s,color .15s;
}

.nav-cta,.nav-links>a.nav-cta{
  background:var(--navy)!important;color:var(--white)!important;
  padding:9px 20px!important;border-radius:var(--r)!important;
  font-weight:700!important;font-size:14px!important;
  transition:background .2s,transform .15s,box-shadow .2s!important;
  box-shadow:0 2px 8px rgba(17,30,66,.25)!important;white-space:nowrap;
}
.nav-cta:hover,.nav-links>a.nav-cta:hover{
  background:var(--blue)!important;
  transform:translateY(-1px)!important;
  box-shadow:0 4px 16px rgba(21,101,192,.35)!important;
}

.dd-tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;letter-spacing:.3px;margin-left:8px}

.lang-switcher{display:flex;gap:2px;margin-left:8px}
.lang-btn{
  background:none;border:1px solid var(--border);
  color:var(--text-muted);padding:5px 10px;border-radius:var(--r);
  font-size:12px;font-weight:700;cursor:pointer;
  transition:all .2s;letter-spacing:.5px;
}
.lang-btn.active,.lang-btn:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}

.mobile-menu-btn{
  display:none;background:none;border:1px solid var(--border);
  color:var(--navy);cursor:pointer;padding:8px;border-radius:var(--r);
}
.mobile-menu{
  display:none;position:fixed;inset:0;z-index:99;
  background:var(--navy);flex-direction:column;
  align-items:flex-start;justify-content:center;
  padding:60px 40px;gap:0;animation:fadeIn .25s ease;overflow-y:auto;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  color:rgba(255,255,255,.85);font-size:18px;font-weight:600;
  padding:13px 0;border-bottom:1px solid rgba(255,255,255,.08);width:100%;
  transition:color .2s;
}
.mobile-menu a:hover{color:var(--teal-mid)}
.mobile-menu a:first-of-type{border-top:1px solid rgba(255,255,255,.08)}
.mobile-close{
  position:absolute;top:20px;right:20px;
  background:rgba(255,255,255,.1);border:none;
  color:var(--white);cursor:pointer;padding:10px;border-radius:var(--r);
}
.nav-drop{position:relative}
.nav-drop>a,.nav-drop>button{display:inline-flex;align-items:center;gap:5px;cursor:pointer;color:var(--navy);font-size:14px;font-weight:600;padding:7px 12px;border-radius:var(--r);transition:color .15s,background .15s;white-space:nowrap;text-decoration:none;border:none;background:none;font-family:var(--font-b)}
.nav-drop>a:hover,.nav-drop>a[aria-expanded="true"],.nav-drop>button:hover,.nav-drop>button[aria-expanded="true"]{color:var(--navy);background:var(--slate-lt)}
.nav-drop>a .chev,.nav-drop>button .chev{width:.75em;height:.75em;flex-shrink:0;transition:transform .25s ease}
.nav-drop>a[aria-expanded="true"] .chev,.nav-drop>button[aria-expanded="true"] .chev{transform:rotate(180deg)}
.nav-drop-menu{position:absolute;top:calc(100% - 8px);left:0;background:var(--white);border:1px solid var(--border);border-top:3px solid var(--teal);border-radius:0 0 var(--r-lg) var(--r-lg);box-shadow:var(--shadow-lg);min-width:296px;padding:16px 8px 8px 8px;z-index:200;visibility:hidden;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .2s ease,transform .2s ease,visibility 0s linear .2s}
.nav-drop-menu.open{visibility:visible;opacity:1;transform:translateY(0);pointer-events:auto;transition:opacity .2s ease,transform .2s ease,visibility 0s linear 0s}
.nav-drop-inner{display:flex;flex-direction:column;gap:2px}
.nav-drop-inner a{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--r);font-size:14px;font-weight:500;color:var(--text-body);transition:background .15s,color .15s;text-decoration:none}
.nav-drop-inner a:hover{background:var(--teal-pale);color:var(--teal-h)}
@media(max-width:900px){
  .nav-links{display:none}
  .mobile-menu-btn{display:flex;align-items:center;justify-content:center}
  .nav{height:84px!important}.nav-inner{padding:0 12px!important;height:64px!important;min-height:unset!important;overflow:visible!important}
  .nav-logo-icon{width:180px!important;height:100px!important}
}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue);color:var(--white);
  padding:13px 28px;border-radius:var(--r);
  font-size:15px;font-weight:700;font-family:var(--font-b);
  text-decoration:none;border:none;cursor:pointer;
  transition:background .2s,transform .15s,box-shadow .2s;
  box-shadow:0 2px 10px rgba(21,101,192,.30);white-space:nowrap;
}
.btn-primary:hover{background:var(--blue-h);transform:translateY(-1px);box-shadow:0 6px 18px rgba(21,101,192,.40)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--white);
  padding:12px 26px;border-radius:var(--r);
  font-size:15px;font-weight:600;font-family:var(--font-b);
  text-decoration:none;border:2px solid rgba(255,255,255,.75);cursor:pointer;
  transition:border-color .2s,background .2s,color .2s;white-space:nowrap;
}
.btn-secondary:hover{border-color:var(--white);background:rgba(255,255,255,.1)}
.btn-secondary.dark{color:var(--navy);border-color:var(--border)}
.btn-secondary.dark:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-lt)}
.section{max-width:var(--max-w);margin:0 auto;padding:88px 32px}
.section-alt{background:var(--slate-lt)}
.section-navy{background:var(--navy)}
.section-blue{background:var(--blue)}
.section-teal{background:var(--teal)}

.section-label{
  display:flex;align-items:center;gap:10px;
  font-size:11px;font-weight:800;letter-spacing:1.8px;
  text-transform:uppercase;color:var(--teal);margin-bottom:16px;
}
.section-label-line{width:28px;height:2px;background:var(--teal);border-radius:1px;flex-shrink:0}
.section-navy .section-label,.section-blue .section-label,.section-teal .section-label{color:var(--teal-lt)}
.section-navy .section-label-line,.section-blue .section-label-line,.section-teal .section-label-line{background:var(--teal-mid)}

.section-title{
  font-family:var(--font-h);font-size:clamp(28px,3.5vw,40px);
  font-weight:700;color:var(--text-h);line-height:1.2;
  letter-spacing:-.5px;margin-bottom:16px;
}
.section-title em{font-style:italic;color:var(--blue)}
.section-navy .section-title,.section-blue .section-title,.section-teal .section-title{color:var(--white)}
.section-navy .section-title em{color:var(--teal-mid)}
.section-blue .section-title em,.section-teal .section-title em{color:var(--teal-lt)}

.section-desc{font-size:17px;line-height:1.75;color:var(--text-muted);max-width:620px}
.section-navy .section-desc,.section-blue .section-desc,.section-teal .section-desc{color:rgba(255,255,255,.72)}
.hero{
  background:var(--navy);
  margin-top:var(--nav-h);padding-top:72px;padding-bottom:88px;
  position:relative;overflow-x:hidden;min-height:620px;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 900px 600px at 72% 40%,rgba(0,172,193,.22) 0%,transparent 55%),
    radial-gradient(ellipse 600px 500px at 10% 90%,rgba(21,101,192,.20) 0%,transparent 50%),
    radial-gradient(ellipse 400px 300px at 90% 90%,rgba(123,85,176,.12) 0%,transparent 45%);
}

.hero::after{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--teal) 0%,var(--blue) 50%,var(--purple) 100%);
}
.hero-content{
  max-width:var(--max-w);margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:1fr 420px;gap:64px;align-items:center;
  position:relative;z-index:1;
}
@media(max-width:960px){.hero-content{grid-template-columns:1fr;text-align:center}}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,172,193,.15);border:1px solid rgba(0,172,193,.40);
  color:var(--teal-mid);font-size:12px;font-weight:700;
  padding:6px 14px;border-radius:20px;margin-bottom:24px;
  letter-spacing:.5px;text-transform:uppercase;
}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--teal-mid);animation:pulse 2.5s ease infinite}

.hero h1{
  font-family:var(--font-h);font-size:clamp(34px,4.5vw,54px);
  font-weight:700;color:var(--white);line-height:1.15;
  letter-spacing:-.8px;margin-bottom:20px;
}
.hero h1 em{font-style:italic;color:var(--teal-mid)}
.hero-sub{
  font-size:17px;line-height:1.75;color:var(--slate);
  max-width:560px;margin-bottom:36px;
}
@media(max-width:960px){.hero-sub{margin-left:auto;margin-right:auto}}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:960px){.hero-actions{justify-content:center}}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center}
@media(max-width:960px){.hero-visual{display:none}}
.network-visual{
  position:relative;width:340px;height:340px;
  background:radial-gradient(ellipse at center,rgba(0,172,193,.18) 0%,transparent 70%);
  border-radius:50%;
}
.network-center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:rgba(21,101,192,.25);border:2px solid rgba(21,101,192,.60);color:var(--white);border-radius:50%;
  width:90px;height:90px;display:flex;align-items:center;justify-content:center;
  text-align:center;font-size:12px;font-weight:700;line-height:1.3;
}
.network-node{
  position:absolute;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;text-align:center;line-height:1.2;
  color:var(--white);cursor:pointer;
}
.trust-bar{background:var(--navy-2);border-bottom:1px solid rgba(255,255,255,.08)}
.trust-bar-inner{
  max-width:var(--max-w);margin:0 auto;padding:18px 32px;
  display:flex;flex-wrap:wrap;gap:32px;align-items:center;justify-content:center;
}
.trust-item{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:var(--slate)}
.trust-icon{
  width:34px;height:34px;border-radius:var(--r);
  background:rgba(0,172,193,.2);color:var(--teal-mid);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.svc5-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:20px;margin-top:52px;
}

.svc5-card:nth-child(-n+3){grid-column:span 2}

.svc5-card:nth-child(4),.svc5-card:nth-child(5){grid-column:span 3}
@media(max-width:960px){.svc5-grid{grid-template-columns:repeat(2,1fr)}
.svc5-card:nth-child(-n+3),.svc5-card:nth-child(4),.svc5-card:nth-child(5){grid-column:span 1}}
@media(max-width:600px){.svc5-grid{grid-template-columns:1fr}}
.svc5-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:32px;
  text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:12px;
  transition:border-color .25s,box-shadow .25s,transform .25s;
  position:relative;overflow:hidden;
}
.svc5-card:hover{border-color:var(--blue);box-shadow:var(--shadow-lg);transform:translateY(-3px)}

.svc5-card[data-color="blue"]  { border-top:4px solid var(--blue) }
.svc5-card[data-color="teal"]  { border-top:4px solid var(--teal) }
.svc5-card[data-color="purple"]{ border-top:4px solid var(--purple) }
.svc5-card[data-color="green"] { border-top:4px solid var(--green) }
.svc5-card[data-color="navy"]  { border-top:4px solid var(--navy) }
.svc5-icon{width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc5-num{font-size:11px;font-weight:800;letter-spacing:1.5px;color:var(--text-faint);text-transform:uppercase;margin-bottom:2px}
.svc5-card h3{font-family:var(--font-h);font-size:18px;font-weight:700;color:var(--text-h);line-height:1.3;margin:0}
.svc5-card p{font-size:14px;line-height:1.7;color:var(--text-muted);margin:0;flex:1}
.svc5-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.svc5-tags span{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--slate-lt);color:var(--text-body);letter-spacing:.3px}
.svc5-link{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--blue);margin-top:6px;transition:gap .2s}
.svc5-card:hover .svc5-link{gap:10px}
.grc-teaser{
  margin-top:56px;
  background:linear-gradient(135deg,var(--teal) 0%,var(--teal-h) 100%);
  border-radius:var(--r-xl);padding:32px 40px;
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;
}
.grc-teaser-icon{
  width:52px;height:52px;border-radius:var(--r-lg);
  background:rgba(255,255,255,.15);color:var(--white);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.grc-teaser>div:nth-child(2){flex:1;min-width:200px}
.grc-teaser-label{font-size:11px;font-weight:800;color:rgba(255,255,255,.7);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}
.grc-teaser-text{font-size:15px;color:var(--white);line-height:1.6;font-weight:500}
.grc-teaser-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);color:var(--teal);
  padding:11px 24px;border-radius:var(--r);font-size:14px;font-weight:700;
  text-decoration:none;transition:background .2s,transform .15s;white-space:nowrap;
}
.grc-teaser-btn:hover{background:var(--teal-lt);transform:translateY(-1px)}
.stats-bar{
  background:linear-gradient(135deg,var(--blue) 0%,var(--navy-3) 100%);
  padding:64px 0;
}
.stats-bar-inner{
  max-width:var(--max-w);margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
}
@media(max-width:600px){.stats-bar-inner{grid-template-columns:repeat(2,1fr)}}
.stat-item{text-align:center}
.stat-number{
  font-family:var(--font-h);font-size:clamp(36px,5vw,54px);
  font-weight:700;color:var(--white);line-height:1;margin-bottom:8px;letter-spacing:-1px;
}
.stat-label{font-size:13px;font-weight:700;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.8px}
.eu-s{padding:0;overflow:hidden}
.eu-s-inner{
  display:grid;grid-template-columns:1fr 1fr;min-height:480px;
}
@media(max-width:860px){.eu-s-inner{grid-template-columns:1fr}}
.eu-s-left{
  background:var(--white);padding:80px 60px;
  display:flex;flex-direction:column;justify-content:center;
}
.eu-s-right{
  background:var(--navy);padding:80px 60px;
  display:flex;flex-direction:column;justify-content:center;
}
@media(max-width:860px){.eu-s-left,.eu-s-right{padding:56px 32px}}
.eu-logo-strip{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.eu-logo-strip img{height:36px;width:auto}
.eu-badge{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--teal-lt);color:var(--teal);
  font-size:11px;font-weight:800;padding:4px 10px;
  border-radius:20px;letter-spacing:.8px;text-transform:uppercase;
}
.eu-eyebrow{font-size:11px;font-weight:800;color:var(--teal);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:12px}
.eu-h2{
  font-family:var(--font-h);font-size:clamp(24px,2.8vw,34px);
  font-weight:700;color:var(--text-h);line-height:1.2;
  margin-bottom:16px;letter-spacing:-.4px;
}
.eu-h2 .hl,.hl{color:var(--blue);font-style:italic}
.eu-lead{font-size:16px;line-height:1.75;color:var(--text-muted);margin-bottom:32px;max-width:460px}
.eu-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue);color:var(--white);
  padding:12px 24px;border-radius:var(--r);font-size:14px;font-weight:700;
  text-decoration:none;transition:background .2s,transform .15s;margin-right:12px;
}
.eu-cta:hover{background:var(--blue-h);transform:translateY(-1px)}
.eu-cta-ghost{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--blue);font-size:14px;font-weight:700;
  text-decoration:none;padding:12px 0;transition:color .2s;
}
.eu-cta-ghost:hover{color:var(--blue-h)}
.eu-pillars{display:flex;flex-direction:column;gap:24px}
.eu-pillar{display:flex;align-items:flex-start;gap:16px}
.eu-pi{
  width:44px;height:44px;border-radius:var(--r-lg);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.eu-pi-g{background:rgba(0,172,193,.2);color:var(--teal-mid)}
.eu-pi-t{background:rgba(21,101,192,.25);color:#7BBDF5}
.eu-pi-n{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8)}
.eu-pt{font-size:15px;font-weight:700;color:var(--white);margin-bottom:4px}
.eu-pd{font-size:14px;color:rgba(255,255,255,.6);line-height:1.6}
.cta-section{background:linear-gradient(135deg,var(--teal) 0%,var(--blue) 100%);padding:88px 0}
.cta-section-inner{
  max-width:var(--max-w);margin:0 auto;padding:0 32px;
  text-align:center;
}
.cta-section h2{
  font-family:var(--font-h);font-size:clamp(26px,3.5vw,40px);
  font-weight:700;color:var(--white);margin-bottom:16px;
  letter-spacing:-.4px;
}
.cta-section h2 em{font-style:italic;color:var(--teal-lt)}
.cta-section p{font-size:17px;color:rgba(255,255,255,.80);max-width:560px;margin:0 auto 36px;line-height:1.75}
.cta-section .btn-primary{background:var(--white);color:var(--blue);font-size:16px;padding:15px 36px;box-shadow:0 4px 20px rgba(0,0,0,.2)}
.cta-section .btn-primary:hover{background:var(--teal-lt);color:var(--teal-h);transform:translateY(-2px)}
.cta-banner{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 60%,#1E3A7A 100%);
  border-radius:var(--r-xl);padding:64px 56px;text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 600px 400px at 80% 50%,rgba(0,131,143,.20) 0%,transparent 60%);
}
.cta-banner h2{font-family:var(--font-h);font-size:clamp(26px,3.5vw,38px);font-weight:700;color:var(--white);margin-bottom:16px;position:relative;letter-spacing:-.4px}
.cta-banner h2 em{font-style:italic;color:var(--teal-mid)}
.cta-banner p{font-size:16px;color:rgba(255,255,255,.75);max-width:560px;margin:0 auto 36px;position:relative;line-height:1.75}
.cta-banner .btn-primary{position:relative;font-size:16px;padding:15px 36px}
@media(max-width:640px){.cta-banner{padding:44px 28px}}
.footer{background:var(--navy);padding:64px 0 40px;border-top:3px solid var(--teal)}
.footer-inner{
  max-width:var(--max-w);margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:200px 1fr auto;gap:48px;align-items:start;
}
@media(max-width:860px){.footer-inner{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-inner{grid-template-columns:1fr;gap:32px}}
.footer-text{font-size:13px;color:rgba(255,255,255,.75);margin-top:10px;line-height:1.6}
.footer-links{display:grid;grid-template-columns:repeat(2,1fr);gap:4px 24px}
.footer-links a{color:rgba(255,255,255,.65);font-size:14px;font-weight:500;padding:5px 0;text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--teal-mid)}
.footer-badges{display:flex;flex-direction:column;gap:8px}
.footer-badge{
  display:inline-flex;align-items:center;
  background:rgba(0,172,193,.15);border:1px solid rgba(0,172,193,.30);
  color:var(--teal-mid);font-size:12px;font-weight:700;
  padding:6px 14px;border-radius:20px;letter-spacing:.5px;white-space:nowrap;
}
.page-hero{
  background:var(--navy);
  margin-top:var(--nav-h);padding-top:56px;padding-bottom:72px;
  position:relative;overflow-x:hidden;
  border-bottom:3px solid var(--teal);
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 700px 400px at 90% 60%,rgba(0,131,143,.18) 0%,transparent 55%),
    radial-gradient(ellipse 400px 300px at 0% 100%,rgba(21,101,192,.15) 0%,transparent 50%);
}
.page-hero::after{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--teal) 0%,var(--blue) 100%);
}
.page-hero-inner{
  max-width:860px;margin:0 auto;padding:0 32px;
  position:relative;z-index:1;
}
.breadcrumb{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:500;color:rgba(255,255,255,.50);margin-bottom:20px;
}
.breadcrumb a{color:rgba(255,255,255,.50);transition:color .2s}
.breadcrumb a:hover{color:var(--teal-mid)}
.breadcrumb svg{opacity:.5;flex-shrink:0}
.breadcrumb span{color:var(--teal-mid)}
.page-hero h1{
  font-family:var(--font-h);font-size:clamp(30px,4vw,48px);
  font-weight:700;color:var(--white);line-height:1.15;
  letter-spacing:-.5px;margin-bottom:18px;
}
.page-hero h1 em{font-style:italic;color:var(--teal-mid)}
.page-hero-desc{font-size:17px;color:var(--slate);line-height:1.75;max-width:680px}
.page-content{padding:0}
.content-grid{
  max-width:var(--max-w);margin:0 auto;padding:64px 32px;
  display:grid;grid-template-columns:1fr 300px;gap:64px;align-items:start;
}
@media(max-width:920px){.content-grid{grid-template-columns:1fr;gap:48px}}
.content-main{min-width:0}
.content-main h2{
  font-family:var(--font-h);font-size:24px;font-weight:700;
  color:var(--text-h);margin:40px 0 14px;letter-spacing:-.3px;
  padding-bottom:10px;border-bottom:2px solid var(--teal-lt);
}
.content-main h2:first-child{margin-top:0}
.content-main h3{font-family:var(--font-h);font-size:19px;font-weight:700;color:var(--text-h);margin:28px 0 10px}
.content-main p{font-size:16px;line-height:1.8;color:var(--text-body);margin-bottom:16px}
.content-main ul,.content-main ol{padding-left:24px;margin-bottom:16px}
.content-main li{font-size:16px;line-height:1.75;color:var(--text-body);margin-bottom:6px}
.content-main strong{color:var(--text-h);font-weight:700}
.content-main a{color:var(--blue);font-weight:600}
.content-main a:hover{text-decoration:underline}
.content-main table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
.content-main th{background:var(--navy);color:var(--white);padding:10px 14px;text-align:left;font-weight:700}
.content-main td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-body)}
.content-main tr:nth-child(even) td{background:var(--off-white)}
.content-aside{position:sticky;top:calc(var(--nav-h) + 24px)}
.aside-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:28px;margin-bottom:20px;
  box-shadow:var(--shadow-sm);border-top:3px solid var(--teal);
}
.aside-card h4{font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:16px}
.aside-card ul{list-style:none;padding:0}
.aside-card ul li{margin-bottom:6px}
.aside-card ul li a{color:var(--blue);font-size:14px;font-weight:600;transition:color .2s}
.aside-card ul li a:hover{color:var(--blue-h)}
.aside-cta{background:var(--navy);border-radius:var(--r-xl);padding:28px;border-top:3px solid var(--teal)}
.aside-cta h4{font-size:15px;font-weight:700;color:var(--white);margin-bottom:10px}
.aside-cta p{font-size:14px;color:rgba(255,255,255,.70);margin-bottom:20px;line-height:1.6}
.photo-ph{
  background:var(--slate-lt);border:2px dashed var(--border);
  border-radius:var(--r-lg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;color:var(--text-faint);text-align:center;padding:32px;
}
.photo-ph-lbl{font-size:14px;font-weight:700;color:var(--text-muted)}
.photo-ph-hint{font-size:13px;color:var(--text-faint);max-width:300px}
.photo-ph-sz{font-size:11px;font-weight:700;letter-spacing:.8px;color:var(--text-faint)}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px;
}
@media(max-width:860px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr}}
.service-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:28px;
  transition:border-color .25s,box-shadow .25s,transform .25s;position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--blue),var(--teal));
  opacity:0;transition:opacity .25s;
}
.service-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.service-card:hover::before{opacity:1}
.service-icon{width:44px;height:44px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.service-card h3{font-family:var(--font-h);font-size:17px;font-weight:700;color:var(--text-h);margin-bottom:8px}
.service-card p{font-size:14px;line-height:1.7;color:var(--text-muted)}
.service-tag{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--blue-lt);color:var(--blue);margin-top:12px;letter-spacing:.3px}
.testimonials-section{
  background:var(--navy-2);padding:64px 0;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);
}
.testimonials-track{display:flex;gap:24px;animation:marquee 40s linear infinite;width:max-content}
.testimonials-track:hover{animation-play-state:paused}
.testimonial-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);
  border-radius:var(--r-xl);padding:28px;min-width:320px;max-width:360px;
}
.testimonial-quote{font-size:15px;line-height:1.75;color:var(--slate);margin-bottom:16px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--teal);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:700;flex-shrink:0;
}
.testimonial-name{font-size:14px;font-weight:700;color:var(--white)}
.testimonial-company{font-size:12px;color:rgba(255,255,255,.75)}
.contact-section{
  max-width:var(--max-w);margin:0 auto;padding:0 32px 80px;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
}
@media(max-width:760px){.contact-section{grid-template-columns:1fr;gap:40px}}
.contact-heading{font-family:var(--font-h);font-size:24px;font-weight:700;color:var(--text-h);margin-bottom:28px;letter-spacing:-.3px}
.contact-form{display:flex;flex-direction:column;gap:14px}
.form-input{
  width:100%;padding:12px 16px;
  background:var(--white);border:1.5px solid var(--border);
  border-radius:var(--r);font-family:var(--font-b);font-size:15px;
  color:var(--text-body);transition:border-color .2s,box-shadow .2s;outline:none;appearance:none;
}
.form-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,131,143,.12)}
.form-input::placeholder{color:var(--text-faint)}
textarea.form-input{resize:vertical;min-height:140px}
select.form-input{cursor:pointer}
.contact-info-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:20px;border-radius:var(--r-lg);margin-bottom:12px;
  background:var(--slate-lt);border:1px solid var(--border);
}
.contact-info-item svg{color:var(--teal);flex-shrink:0;margin-top:2px}
.contact-info-label{font-size:12px;font-weight:700;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px}
.contact-info-val{font-size:15px;color:var(--text-body);font-weight:500}
.contact-info-val a{color:var(--blue)}
.jobs-list{margin-top:48px;display:flex;flex-direction:column;gap:20px}
.job-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  transition:border-color .25s,box-shadow .25s;
  border-left:4px solid var(--navy);
}
.job-card:hover{border-left-color:var(--teal);box-shadow:var(--shadow-md)}
.job-card-header{padding:28px 32px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:20px}
.job-card-left{display:flex;align-items:flex-start;flex-direction:column;gap:8px}
.job-level{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--navy);color:var(--white);
  font-size:11px;font-weight:800;padding:4px 12px;
  border-radius:20px;letter-spacing:.8px;text-transform:uppercase;
}
.job-title{font-family:var(--font-h);font-size:22px;font-weight:700;color:var(--text-h);line-height:1.2}
.job-meta{display:flex;flex-wrap:wrap;gap:12px}
.job-meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);font-weight:500}
.job-body{padding:0 32px 32px;border-top:1px solid var(--border);display:none}
.job-body.open{display:block}
.job-body h4{font-size:14px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);margin:24px 0 12px}
.job-body ul{list-style:none;padding:0}
.job-body li{padding:6px 0 6px 22px;font-size:15px;color:var(--text-body);position:relative;line-height:1.6}
.job-body li::before{content:'→';position:absolute;left:0;color:var(--teal);font-weight:700}
.job-apply{display:inline-flex;align-items:center;gap:8px;margin-top:24px}
.faq-list{margin-top:40px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-toggle{
  display:flex;justify-content:space-between;align-items:center;
  width:100%;background:none;border:none;padding:20px 0;
  cursor:pointer;text-align:left;
  font-size:16px;font-weight:700;color:var(--text-h);
  font-family:var(--font-b);transition:color .2s;gap:16px;
}
.faq-toggle:hover{color:var(--blue)}
.faq-toggle svg{flex-shrink:0;color:var(--text-muted);transition:transform .3s}
.faq-toggle.open svg{transform:rotate(180deg)}
.faq-answer{padding:0 0 20px;color:var(--text-muted);line-height:1.75;display:none}
.partners-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;
}
@media(max-width:860px){.partners-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.partners-grid{grid-template-columns:1fr}}
.partner-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:32px;text-align:center;
  transition:border-color .25s,box-shadow .25s,transform .25s;
  border-top:4px solid var(--teal);
}
.partner-card:hover{border-top-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.partner-photo{width:96px;height:96px;border-radius:50%;overflow:hidden;margin:0 auto 20px;border:3px solid var(--teal-lt);background:var(--slate-lt)}
.partner-photo img{width:100%;height:100%;object-fit:cover}
.partner-name{font-family:var(--font-h);font-size:19px;font-weight:700;color:var(--text-h);margin-bottom:4px}
.partner-role{font-size:13px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}
.partner-certs{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:14px}
.partner-cert{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--blue-lt);color:var(--blue)}
.partner-bio{font-size:14px;line-height:1.7;color:var(--text-muted)}
.grc-features-strip{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.grc-feature-pill{
  display:flex;align-items:center;gap:7px;
  background:var(--teal-lt);border:1px solid rgba(0,131,143,.25);
  padding:8px 16px;border-radius:20px;
  font-size:13px;font-weight:700;color:var(--teal);
}
.grc-feature-pill svg{flex-shrink:0}
.modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
@media(max-width:860px){.modules-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.modules-grid{grid-template-columns:1fr}}
.module-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:24px;
  transition:border-color .25s,box-shadow .25s;border-top:3px solid var(--teal);
}
.module-card:hover{border-top-color:var(--blue);box-shadow:var(--shadow-md)}
.module-icon{
  width:44px;height:44px;border-radius:var(--r-lg);
  background:var(--teal-lt);color:var(--teal);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.module-card h3{font-size:16px;font-weight:700;color:var(--text-h);margin-bottom:6px}
.module-card p{font-size:13px;color:var(--text-muted);line-height:1.6}
.integration-hub{background:var(--navy);border-radius:var(--r-xl);padding:40px;color:var(--white)}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:48px;position:relative;
}
@media(max-width:760px){.process-steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.process-steps{grid-template-columns:1fr}}
.process-step{text-align:center;padding:28px 20px;position:relative}
.process-step:not(:last-child)::after{
  content:'';position:absolute;top:44px;right:0;left:60%;
  height:2px;background:linear-gradient(90deg,var(--blue),var(--teal));
}
@media(max-width:760px){.process-step::after{display:none!important}}
.step-num{
  width:48px;height:48px;border-radius:50%;
  background:var(--blue);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-size:18px;font-weight:700;
  margin:0 auto 16px;position:relative;z-index:1;
}
.process-step h4{font-size:15px;font-weight:700;color:var(--text-h);margin-bottom:6px}
.process-step p{font-size:13px;color:var(--text-muted);line-height:1.6}
.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:40px}
@media(max-width:600px){.benefits-grid{grid-template-columns:1fr}}
.benefit-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:20px;background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);border-left:3px solid var(--teal);
}
.benefit-icon{
  width:36px;height:36px;border-radius:var(--r);
  background:var(--teal-lt);color:var(--teal);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.benefit-item h4{font-size:15px;font-weight:700;color:var(--text-h);margin-bottom:4px}
.benefit-item p{font-size:14px;color:var(--text-muted);line-height:1.6}
.diensten-hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.diensten-hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(0,172,193,.15);border:1px solid rgba(0,172,193,.35);
  color:var(--teal-mid);font-size:12px;font-weight:700;
  padding:6px 14px;border-radius:20px;letter-spacing:.3px;
}
.diensten-cards-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;
}
@media(max-width:860px){.diensten-cards-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.diensten-cards-grid{grid-template-columns:1fr}}
.diensten-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:28px;text-decoration:none;color:inherit;
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.diensten-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.diensten-card-icon{width:44px;height:44px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center}
.diensten-card h3{font-family:var(--font-h);font-size:17px;font-weight:700;color:var(--text-h)}
.diensten-card p{font-size:14px;color:var(--text-muted);line-height:1.65;flex:1}
.diensten-card-link{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--blue)}
.highlight{background:var(--teal-lt);color:var(--teal);padding:1px 6px;border-radius:3px;font-weight:700}
.norm-pill{display:inline-flex;align-items:center;gap:6px;background:var(--blue-lt);color:var(--blue);font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;margin:3px}
.tag{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.3px}
.tag-blue{background:var(--blue-lt);color:var(--blue)}
.tag-teal{background:var(--teal-lt);color:var(--teal)}
.tag-navy{background:var(--navy);color:var(--white)}
.tag-new{background:#FFF0F0;color:#C62828}
.tag-green{background:var(--green-lt);color:var(--green)}
.tag-purple{background:rgba(123,85,176,.12);color:var(--purple)}
hr.section-divider{border:none;border-top:1px solid var(--border);margin:48px 0}
@media(max-width:640px){
  .section{padding:60px 20px}
  .section-title{font-size:26px}
  .svc5-grid,.services-grid{grid-template-columns:1fr}
  .hero-content,.page-hero-inner,.content-grid{padding-left:20px;padding-right:20px}
  .contact-section,.trust-bar-inner,.footer-inner,.stats-bar-inner{padding-left:20px;padding-right:20px}
}
@media print{
  .nav,.footer,.mobile-menu{display:none!important}
  body{padding-top:0!important}
  .hero,.page-hero{padding-top:24px!important}
}
.eu-s-inner>div:first-child{background:var(--white)!important;padding:80px 60px;display:flex;flex-direction:column;justify-content:center;}
.eu-s-inner>div:last-child{background:var(--navy)!important;padding:80px 60px;display:flex;flex-direction:column;justify-content:center;}
.eu-s-inner>div:last-child .eu-pt{color:var(--white)!important;}
.eu-s-inner>div:last-child .eu-pd{color:rgba(255,255,255,.65)!important;}
.eu-s-inner>div:last-child .eu-pi{background:rgba(0,172,193,.2)!important;color:var(--teal-mid)!important;}
.eu-logo-strip{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important;margin-bottom:20px!important;}
.eu-logo-strip img{height:36px!important;}.eu-eyebrow{color:var(--teal)!important;}
.eu-h2{color:var(--text-h)!important;font-family:var(--font-h)!important;}
.eu-h2 .hl{color:var(--blue)!important;font-style:italic!important;}
.eu-lead{color:var(--text-muted)!important;}
.eu-cta{background:var(--blue)!important;color:var(--white)!important;padding:12px 24px!important;border-radius:var(--r)!important;display:inline-flex!important;align-items:center!important;gap:8px!important;font-size:14px!important;font-weight:700!important;text-decoration:none!important;}
.eu-note{padding:13px 20px!important;margin:24px 20px 0!important;font-size:13px!important;color:var(--text-muted)!important;overflow-wrap:break-word!important;word-break:break-word!important;}
*{box-sizing:border-box;}p,h1,h2,h3,li,span,a,td,th{overflow-wrap:break-word;word-break:break-word;}
@media(max-width:640px){
  .section{padding:48px 20px!important;}.hero{padding-top:64px!important;padding-bottom:56px!important;}
  .hero-content{padding:0 20px!important;}.hero h1{font-size:28px!important;}.hero-sub{font-size:15px!important;}
  .hero-actions{flex-direction:column!important;align-items:stretch!important;gap:10px!important;}
  .hero-actions .btn-primary,.hero-actions .btn-secondary{width:100%!important;justify-content:center!important;}
  .page-hero{padding-top:32px!important;padding-bottom:40px!important;}
  .page-hero-inner{padding:0 20px!important;}.page-hero h1{font-size:26px!important;}.page-hero-desc{font-size:15px!important;}
  .nav-inner{padding:0 12px!important;height:64px!important;overflow:visible!important;}
  .nav-logo-icon{width:160px!important;height:88px!important}
  .mobile-menu-btn{display:flex!important;align-items:center!important;justify-content:center!important;}
  .trust-bar-inner{padding:14px 20px!important;gap:14px!important;flex-direction:column!important;align-items:flex-start!important;}
  .svc5-grid{grid-template-columns:1fr!important;}.svc5-card{grid-column:span 1!important;padding:20px!important;}
  .grc-teaser{padding:20px!important;flex-direction:column!important;gap:16px!important;}.grc-teaser-btn{width:100%!important;justify-content:center!important;}
  .eu-s-inner{grid-template-columns:1fr!important;}
  .eu-s-inner>div:first-child{padding:40px 20px!important;}.eu-s-inner>div:last-child{padding:40px 20px!important;}
  .eu-h2{font-size:22px!important;}.eu-note{margin:16px 16px 0!important;padding:12px 16px!important;}
  .cta-banner{padding:36px 20px!important;}.cta-banner h2{font-size:22px!important;}
  .cta-section{padding:52px 0!important;}.cta-section-inner{padding:0 20px!important;}.cta-section h2{font-size:24px!important;}
  .cta-section .btn-primary{width:100%!important;max-width:300px!important;justify-content:center!important;}
  .footer-inner{padding:0 20px!important;grid-template-columns:1fr!important;gap:28px!important;}
  .footer-links{grid-template-columns:1fr 1fr!important;}.content-grid{padding:36px 20px!important;}
  .contact-section{padding:0 20px 44px!important;grid-template-columns:1fr!important;}
  .section-title{font-size:24px!important;}.section-desc{font-size:15px!important;}
  .partners-grid,.modules-grid,.services-grid,.benefits-grid,.process-steps{grid-template-columns:1fr!important;}
  .process-step::after{display:none!important;}
}
@media print{.nav,.footer,.mobile-menu{display:none!important;}body{padding-top:0!important;}.hero,.page-hero{padding-top:24px!important;}}

[data-lang]{display:none}
[data-lang].lang-active{display:inline}
span[data-lang].lang-active{display:inline}
p[data-lang].lang-active{display:block}
li[data-lang].lang-active{display:list-item}
h2[data-lang].lang-active,h3[data-lang].lang-active,h4[data-lang].lang-active{display:block}
</style>
<style>
#cookieBanner{
  position:fixed;bottom:0;left:0;right:0;z-index:99999;
  background:#111E42;border-top:3px solid #00838F;
  padding:20px 32px;display:flex;align-items:center;
  justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-family:'Source Sans 3',system-ui,sans-serif;
  box-shadow:0 -4px 24px rgba(0,0,0,.25);
}
#cookieBanner p{
  font-size:14px;color:rgba(255,255,255,.85);
  line-height:1.6;margin:0;flex:1;min-width:260px;
}
#cookieBanner a{color:#00ACC1;text-decoration:underline}
#cookieBanner a:hover{color:#4DD0E1}
.cookie-btns{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
.cookie-btn{
  padding:9px 20px;border-radius:8px;font-size:13px;
  font-weight:700;cursor:pointer;border:none;
  font-family:inherit;transition:all .2s;white-space:nowrap;
}
.cookie-btn-accept{background:#00838F;color:#fff}
.cookie-btn-accept:hover{background:#006974}
.cookie-btn-decline{
  background:transparent;color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.3);
}
.cookie-btn-decline:hover{background:rgba(255,255,255,.08);color:#fff}
@media(max-width:600px){
  #cookieBanner{padding:16px 20px;flex-direction:column}
  .cookie-btns{width:100%}
  .cookie-btn{flex:1;text-align:center}
}

/* === CONTRAST FIX v5 — targeted, no more wildcard descendants === */

/* Dark sections: set color on the section itself.
   Children inherit unless they define their own color. */
.ov-hero, .page-hero, .kb-hero, .hero,
.article-hero, section.hero,
.ov-cta-box, .aside-cta, .cta-band, .cta-banner, .cta-box,
.apply-box, .culture-strip, .grc-strip, .trust, .trust-bar,
.integration-hub, .svc-featured, .platform-visual,
.section-navy, .section-teal, .section-blue,
.footer, .cta-section, .grc-teaser,
.testimonials-section, .eu-s-right, .eu-right,
.marquee-wrap, .ow {
  color: #FFFFFF !important;
}

/* Headings + paragraphs + spans directly inside dark sections */
.ov-hero h1, .ov-hero h2, .ov-hero h3, .ov-hero p, .ov-hero li,
.ov-hero .section, .ov-hero .breadcrumb, .ov-hero .breadcrumb span,
.page-hero h1, .page-hero h2, .page-hero h3, .page-hero p, .page-hero li,
.page-hero .section, .page-hero .breadcrumb,
.kb-hero h1, .kb-hero h2, .kb-hero p, .kb-hero li, .kb-hero .section,
.hero h1, .hero h2, .hero p, .hero li,
.article-hero h1, .article-hero h2, .article-hero p, .article-hero li,
section.hero h1, section.hero h2, section.hero p, section.hero li,
.ov-cta-box h2, .ov-cta-box h3, .ov-cta-box p, .ov-cta-box span,
.aside-cta h2, .aside-cta p, .aside-cta span,
.cta-band h2, .cta-band p, .cta-band span,
.cta-banner h2, .cta-banner p, .cta-banner span,
.section-navy h1, .section-navy h2, .section-navy h3, .section-navy p, .section-navy li,
.section-teal h1, .section-teal h2, .section-teal h3, .section-teal p, .section-teal li,
.section-teal .section-desc, .section-teal .section-label, .section-teal .section-title em,
.section-blue h1, .section-blue h2, .section-blue h3, .section-blue p, .section-blue li,
.cta-section h2, .cta-section h2 em, .cta-section p,
.grc-teaser h2, .grc-teaser p,
.trust h2, .trust p, .trust span,
.trust-bar p, .trust-bar span,
.integration-hub h2, .integration-hub p,
.footer h3, .footer h4, .footer p, .footer li, .footer span {
  color: #FFFFFF !important;
}

/* Ghost buttons inside hero (transparent bg): keep text white */
.ov-hero .btn-ghost, .page-hero .btn-ghost, .hero .btn-ghost,
.ov-hero a.btn-ghost, .page-hero a.btn-ghost, .hero a.btn-ghost {
  color: #FFFFFF !important;
  border-color: rgba(255,255,255,.4) !important;
  background: transparent !important;
}

/* Breadcrumbs on dark */
.breadcrumb { color: rgba(255,255,255,.85) !important; }
.breadcrumb a { color: rgba(255,255,255,.85) !important; }
.breadcrumb a:hover { color: #80DEEA !important; }
.breadcrumb span { color: rgba(255,255,255,.85) !important; }

/* Stat labels */
.stat-label, .stat-num { color: #FFFFFF !important; }
.stats-bar .stat-label, .stats-bar .stat-num { color: #FFFFFF !important; }

/* --- CARDS / STEPS INSIDE HERO KEEP THEIR OWN LIGHT BG COLORS --- */
/* These elements have white/light background - ensure text is dark */
.step-card, .step-card h3, .step-card .step-title, .step-card .step-desc,
.service-card:not(.dark), .pricing-card:not(.dark),
.ov-card, .ov-card h2, .ov-card p, .ov-card .ov-card-num,
.svc-card, .svc-card h3, .svc-card p,
.pc, .pc h2, .pc p, .pc .pcta, .pc.pop .pcta {
  color: inherit;
}
.step-card { color: #1F2937 !important; }
.step-card .step-title, .step-title { color: #111E42 !important; }
.step-card .step-desc, .step-desc { color: #374151 !important; }
.step-card .step-time, .step-time { color: #00525B !important; font-weight: 700; }
.step-num, .step-n, .step-card .step-num { color: #FFFFFF !important; }

/* Card decorative numbers (01, 02 etc): darker for readability */
.ov-card-num, .svc-num, .service-num, .card-num {
  color: #6B7280 !important;
}

/* --- DARK SECTIONS: ensure their text children are readable --- */
.svc-featured h2, .svc-featured h3, .svc-featured p, .svc-featured li {
  color: #FFFFFF !important;
}
.svc-featured .svc-num {
  color: rgba(255,255,255,.60) !important;
}

/* --- COMPLI CHATBOT DISCLAIMER (dark navy bg) --- */
.compli-disclaimer {
  color: rgba(255,255,255,.85) !important;
  font-size: 11px;
}
.compli-header, .compli-header * {
  color: #FFFFFF !important;
}

/* --- SECTION LABELS (teal on very light) --- */
.section-label span, .sec-label span,
p[style*="color:#00838F"], p[style*="color: #00838F"] {
  color: #00525B !important;
}

/* --- PILL BADGES on light bg --- */
.tag-teal, .pill, .chip, .badge,
.benefit-icon, .module-icon, .highlight,
.eu-badge, .grc-feature-pill, .offer-icon,
.cert-item-tag, .phil-icon, .ov-card-cta {
  color: #00525B !important;
}
.tag-green { color: #1B5E20 !important; }
.tag-navy, .tag-blue { color: #FFFFFF !important; }

/* CTA button in dark sections */
.ov-cta-box a, .aside-cta a, .cta-band a, .cta-banner a,
.cta-section .btn-primary, .cta-section a.btn-primary {
  color: #FFFFFF !important;
  background: #00525B !important;
}
.ov-cta-box a:hover, .aside-cta a:hover, .cta-band a:hover,
.cta-section .btn-primary:hover {
  background: #003942 !important;
}

/* Buttons: standard fg white on bg */
.btn, a.btn { color: #FFFFFF !important; }
.btn-outline, a.btn-outline { color: #00525B !important; background: transparent !important; }
.btn-outline:hover, a.btn-outline:hover { color: #FFFFFF !important; background: #00525B !important; }

/* Pricing popup card (was white-on-white regression) */
.pc.pop { color: #111E42 !important; background: #FFFFFF !important; }
.pc.pop h2, .pc.pop h3, .pc.pop p, .pc.pop li { color: #111E42 !important; }
.pc.pop .pcta { color: #00525B !important; }

/* Form placeholders */
input::placeholder, textarea::placeholder, select::placeholder,
.form-input::placeholder {
  color: #6B7280 !important; opacity: 1 !important;
}

/* Muted / secondary text on light bg */
.muted, p.muted, span.muted, .text-muted { color: #4B5563 !important; }
.photo-ph { color: #4B5563 !important; }

/* Share buttons - brand-correct dark versions */
.share-btn-fb { background: #0B5FCA !important; color: #FFFFFF !important; font-weight: 700; }
.share-btn-tw { background: #0C7BCB !important; color: #FFFFFF !important; font-weight: 700; }
.share-btn-li { background: #084A80 !important; color: #FFFFFF !important; font-weight: 700; }

/* KB filter active/hover */
.kb-filter-btn.active, .kb-filter-btn:hover {
  color: #FFFFFF !important; background: #00525B !important;
}

/* Process step numbers */
.process-step .step-num { color: #FFFFFF !important; font-weight: 700; }

/* Footer logo mark: ensure contrast */
.footer-logo-mark, .footer-logo-mark span { color: #FFFFFF !important; }

/* Tag-pill muted */
.tag-pill { color: #374151 !important; }
.share-box h4 { color: #374151 !important; }

/* === CONTRAST FIX v6b === */
.trust .btn-ghost, .trust a.btn-ghost, .trust-bar .btn-ghost,
.pricing .btn-ghost, .faq .btn-ghost, .kb-grid .btn-ghost,
.container > .btn-ghost {
  color: #00525B !important; border-color: #00525B !important;
  background: transparent !important;
}
.trust .btn-ghost:hover { color: #FFFFFF !important; background: #00525B !important; }
.pv-fw-unit, .pv-fw-unit *, .pv-fw-label, .pv-fw-num {
  color: #FFFFFF !important; opacity: 1 !important;
}
.price-period, .pc .price-period { color: #4B5563 !important; }
.step-title, div.step-title { color: #111E42 !important; }
.step-desc, div.step-desc { color: #374151 !important; }
.step-time, span.step-time { color: #00525B !important; font-weight: 700; }
.svc-num, div.svc-num, .service-num, .ov-card-num, .card-num { color: #6B7280 !important; }
div.compli-disclaimer, .compli-disclaimer, .compli-disclaimer * {
  color: rgba(255,255,255,.85) !important;
}
.cta-muted, .form-note, .footnote { color: #4B5563 !important; }

/* === CONTRAST FIX v7 === final targeted fixes */

/* trust btn-ghost: child span inheriting white -> force teal on all children */
.trust .btn-ghost, .trust .btn-ghost *,
.trust a.btn-ghost, .trust a.btn-ghost span {
  color: #00525B !important;
  background: transparent !important;
}
.trust .btn-ghost:hover, .trust .btn-ghost:hover * {
  color: #FFFFFF !important;
  background: #00525B !important;
}

/* Generic teal links on very light backgrounds - darken to pass 4.5 */
a[href] { /* no-op placeholder - will be overridden */ }

/* Section label teal (#00838F) on light bg - darken */
.section-label span, .section-label, p.section-label,
.diensten-related-title, .dr-title, .dr-label,
span.section-label, p.related-label {
  color: #005F6A !important;
}
/* Also any raw span.teal on near-white bg via utility */
.text-teal, span.text-teal { color: #005F6A !important; }

/* Dark "section" breadcrumb-like text rendered dark on navy hero */
.ov-hero .section, .page-hero .section, .hero .section,
.article-hero .section, .kb-hero .section,
section.hero .section, section.ov-hero .section,
.section-navy .section, .section-teal .section,
.section-blue .section,
.breadcrumb, .breadcrumb *, .ov-hero .breadcrumb,
.page-hero .breadcrumb, .hero .breadcrumb {
  color: #FFFFFF !important;
}

/* Compli disclaimer - cover every possible nested class */
.compli-disclaimer, .compli-disclaimer *, div.compli-disclaimer,
.compli-disclaimer small, .compli-disclaimer span, .compli-disclaimer p {
  color: rgba(255,255,255,.88) !important;
}

/* ov-card-num: force grey-600 over any gray-400 */
.ov-card-num, div.ov-card-num, span.ov-card-num,
.ov-card .ov-card-num, section .ov-card-num {
  color: #6B7280 !important;
}

/* tag-blue on light backgrounds - dark text (was white which fails on pale blue) */
.tag.tag-blue, span.tag-blue, .tag-blue {
  color: #0B3D91 !important;
  background: #DBEAFE !important;
}

/* kb-cat: too-bright red - darken */
.kb-cat, span.kb-cat { color: #B91C1C !important; }

/* btn-secondary on dark navy backgrounds - keep text light */
.ov-hero .btn-secondary, .page-hero .btn-secondary, .hero .btn-secondary,
.section-navy .btn-secondary, .cta-section .btn-secondary,
.platform-visual .btn-secondary, .svc-featured .btn-secondary {
  color: #FFFFFF !important;
  background: #1565C0 !important;
  border-color: #1565C0 !important;
}

/* Blue links on dark navy backgrounds - make them light */
.ov-hero a, .page-hero a, .hero a, .article-hero a,
section.hero a, section.ov-hero a,
.section-navy a, .section-blue a, .cta-section a,
.svc-featured a, .platform-visual a {
  color: #80DEEA !important;
}
.ov-hero a.btn, .page-hero a.btn, .hero a.btn,
.section-navy a.btn, .cta-section a.btn { /* buttons keep their own styling */ }
.ov-hero a.btn-primary, .hero a.btn-primary, .cta-section a.btn-primary,
.section-navy a.btn-primary { color: #FFFFFF !important; }

/* Any remaining teal link on near-white background (over-ons) */
body a:not(.btn) {
  /* default teal link - ensure 4.5 ratio via darker shade */
}
a[style*="color: #00838F"], a[style*="color:#00838F"] { color: #005F6A !important; }

/* === LANG SWITCHER DUAL === */
.lang-dual{display:inline-flex;gap:0;margin-left:10px;border-radius:6px;overflow:hidden;border:1px solid var(--navy,#1B2D5E)}
.lang-dual a,.lang-dual span{padding:5px 10px;font-size:13px;font-weight:700;text-decoration:none;line-height:1;display:inline-block;transition:background .2s,color .2s}
.lang-dual .lang-active{background:#00838F;color:#fff;cursor:default}
.lang-dual .lang-inactive{background:#fff;color:var(--navy,#1B2D5E)}
.lang-dual .lang-inactive:hover{background:#E0F7FA;color:#00525B}
