
/* ==========================================================================
   ZENITH WEBSITE — DESIGN SYSTEEM
   
   KLEUREN AANPASSEN? Wijzig de variabelen hieronder.
   LETTERTYPEN? Wijzig --font-heading en --font-body.
   ========================================================================== */
:root {
  --blue: #008CAA;
  --blue-dark: #006E86;
  --blue-light: #B2EAF4;
  --blue-vlight: #00A3CB;
  --orange: #F28C38;
  --orange-medium: #FDB679;
  --grey-light: #DEDEDE;
  --pink-light: #F5D7BC;
  --white: #FFFFFF;
  --off-white: #F8FAFB;
  --text-dark: #1A2B3C;
  --text-medium: #4A5568;
  --text-light: #718096;
  --font-heading: 'Trebuchet MS', 'Lucida Grande', sans-serif;
  --font-body: Tahoma, Geneva, sans-serif;
  --nav-height: 72px;
  --max-width: 1180px;
  --radius: 16px;
  --radius-lg: 24px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
.visually-hidden { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--text-dark);
  background: var(--white);
  line-height: 1.7;
  font-size: 16px;
  overflow-x: hidden;
  -webkit-tap-highlight-color: transparent;
}
h1, h2, h3, h4, h5 { font-family: var(--font-heading); font-weight: 700; line-height: 1.2; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

.container { max-width: var(--max-width); margin: 0 auto; padding: 0 40px; position: relative; z-index: 2; }
.section-pad { padding: 100px 0; }

.section-label {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; font-weight: 700; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--blue); margin-bottom: 16px;
  position:relative;
}
.section-label::before { content: ''; width: 28px; height: 2px; background: var(--orange); border-radius: 2px; }
.section-label::after {
  content:''; width:22px; height:22px;
  background:url('/img/condor.png') no-repeat center/contain;
  opacity:.35; display:inline-block;
  animation:condorBob 4s ease-in-out infinite;
  filter:brightness(0.8);
}
@keyframes condorBob {
  0%,100%{ transform:translateY(0) rotate(-3deg); }
  50%{ transform:translateY(-4px) rotate(3deg); }
}
.section-title { font-size: 44px; color: var(--text-dark); margin-bottom: 20px; letter-spacing: -1px; }
.section-title .hl-blue { color: var(--blue); }
.section-title .hl-orange { color: var(--orange); }
.section-desc { font-size: 17px; color: var(--text-medium); max-width: 620px; line-height: 1.8; }
.text-center { text-align: center; }
.text-center .section-desc { margin: 0 auto; }

/* Shapes */
.shape { position: absolute; pointer-events: none; z-index: 0; }
.blob-1 { border-radius: 42% 58% 70% 30% / 45% 45% 55% 55%; }
.blob-2 { border-radius: 60% 40% 30% 70% / 50% 60% 40% 50%; }
.blob-3 { border-radius: 30% 70% 70% 30% / 30% 52% 48% 70%; }
.blob-4 { border-radius: 50% 50% 20% 80% / 40% 60% 40% 60%; }
.blob-5 { border-radius: 70% 30% 50% 50% / 60% 40% 60% 40%; }

/* Shape color presets */
.shape-blue { background: var(--blue-light); }
.shape-orange { background: var(--orange-medium); }
.shape-blue-dark { background: var(--blue); }
.shape-orange-light { background: var(--pink-light); }
.shape-outline-blue { border: 3px solid var(--blue-light); background: none; }
.shape-outline-orange { border: 3px solid var(--orange-medium); background: none; }
.shape-dot-blue { background: var(--blue); border-radius: 50%; }
.shape-dot-orange { background: var(--orange); border-radius: 50%; }

/* Sections need relative + overflow for shapes */
.has-shapes { position: relative; overflow: hidden; }

@keyframes float { 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-18px) rotate(2deg)} }
@keyframes floatSlow { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes pulse { 0%,100%{transform:scale(1);opacity:.6} 50%{transform:scale(1.05);opacity:.8} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

.reveal { opacity:0; transform:translateY(30px); transition:all .7s cubic-bezier(.25,.46,.45,.94); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-d1 { transition-delay:.1s; } .reveal-d2 { transition-delay:.2s; } .reveal-d3 { transition-delay:.3s; }

/* Buttons */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 30px; border-radius:10px; font-family:var(--font-body);
  font-size:15px; font-weight:700; cursor:pointer; border:none; transition:all .3s ease; white-space:nowrap;
}
.btn-primary { background:var(--blue); color:white; box-shadow:0 4px 16px rgba(0,140,170,.2); }
.btn-primary:hover { background:var(--blue-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,140,170,.3); }
.btn-orange { background:var(--orange); color:white; box-shadow:0 4px 16px rgba(242,140,56,.2); }
.btn-orange:hover { background:#E07B2A; transform:translateY(-2px); }
.btn-outline { background:transparent; color:var(--blue); border:2px solid var(--blue); padding:12px 28px; }
.btn-outline:hover { background:var(--blue); color:white; transform:translateY(-2px); }
.btn-ghost { background:rgba(255,255,255,.12); color:white; border:2px solid rgba(255,255,255,.25); padding:12px 28px; }
.btn-ghost:hover { background:rgba(255,255,255,.2); border-color:rgba(255,255,255,.4); }
.btn-sm { padding:10px 22px; font-size:14px; }
.btn-arrow::after { content:'→'; transition:transform .3s; }
.btn-arrow:hover::after { transform:translateX(4px); }

/* ==========================================================================
   NAVIGATIE
   ========================================================================== */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-height); display:flex; align-items:center;
  justify-content:space-between; padding:0 40px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px); border-bottom:1px solid rgba(0,140,170,.06);
  transition:all .3s;
}
.nav.scrolled { box-shadow:0 1px 20px rgba(0,140,170,.06); }
.nav-logo {
  font-family:var(--font-heading); font-size:26px; font-weight:700;
  color:var(--blue); letter-spacing:-.5px; display:flex; align-items:center; gap:4px; cursor:pointer;
}
.nav-logo-dot { width:8px; height:8px; background:var(--orange); border-radius:50%; margin-top:-8px; }
.nav-links { display:flex; gap:8px; align-items:center; }
.nav-link {
  padding:8px 16px; font-size:14px; font-weight:600;
  color:var(--text-medium); border-radius:8px; transition:all .2s; cursor:pointer;
}
.nav-link:hover, .nav-link.active { color:var(--blue); background:rgba(0,140,170,.05); }
.nav-cta {
  margin-left:8px; padding:10px 22px !important;
  background:var(--orange); color:white !important; border-radius:8px;
  font-size:14px; font-weight:700; box-shadow:0 2px 12px rgba(242,140,56,.2);
  transition:all .3s !important; cursor:pointer;
}
.nav-cta:hover { background:#E07B2A; transform:translateY(-1px); }
.lang-switch { display:flex; gap:2px; margin-left:16px; padding:4px; background:var(--off-white); border-radius:8px; }
.lang-btn {
  padding:4px 10px; font-size:12px; font-weight:700; color:var(--text-light);
  border-radius:6px; cursor:pointer; border:none; background:none; font-family:var(--font-body); transition:all .2s;
}
.lang-btn.active { background:white; color:var(--blue); box-shadow:0 1px 4px rgba(0,0,0,.06); }
.nav-dropdown { position:relative; }
.nav-dropdown-toggle { display:inline-flex; align-items:center; gap:4px; }
.nav-dropdown-arrow { transition:transform .2s; flex-shrink:0; }
.nav-dropdown:hover .nav-dropdown-arrow { transform:rotate(180deg); }
.nav-dropdown-menu {
  display:none; position:absolute; top:100%; left:0; min-width:200px;
  background:white; border-radius:12px; padding:8px;
  box-shadow:0 8px 32px rgba(0,0,0,.1); border:1px solid rgba(0,140,170,.08);
  z-index:1001;
}
.nav-dropdown:hover .nav-dropdown-menu { display:block; }
.nav-dropdown-item {
  display:block; padding:10px 16px; font-size:14px; font-weight:600;
  color:var(--text-medium); border-radius:8px; transition:all .2s; white-space:nowrap;
}
.nav-dropdown-item:hover, .nav-dropdown-item.active { color:var(--blue); background:rgba(0,140,170,.05); }

.nav-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; background:none; border:none; }
.nav-toggle span { width:22px; height:2px; background:var(--text-dark); border-radius:2px; transition:all .3s; }

/* ==========================================================================
   PAGINA: HOME — ✏️ PAS TEKSTEN HIERONDER AAN
   ========================================================================== */


/* Hero */
.hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  padding:calc(var(--nav-height) + 60px) 0 80px;
  background:linear-gradient(165deg, var(--white) 0%, #EFF9FC 35%, var(--white) 70%, #FFFBF7 100%);
  overflow-x:hidden; overflow-y:visible;
}
.hero::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:200px;
  background:url('/img/condor-skyline-1.jpg') no-repeat center bottom/cover;
  opacity:.03; pointer-events:none; z-index:0;
  mask-image:linear-gradient(to top, rgba(0,0,0,.6), transparent);
  -webkit-mask-image:linear-gradient(to top, rgba(0,0,0,.6), transparent);
}
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--blue-light); color:var(--blue); font-size:12px; font-weight:700;
  padding:6px 16px 6px 12px; border-radius:100px; letter-spacing:1.5px;
  text-transform:uppercase; margin-bottom:28px; animation:fadeUp .7s ease both;
}
.hero-tag-dot { width:6px; height:6px; background:var(--orange); border-radius:50%; }
.hero h1 { font-size:54px; letter-spacing:-1.5px; margin-bottom:8px; animation:fadeUp .7s ease .1s both; }
.hero-tagline {
  font-family:var(--font-heading); font-size:20px; color:var(--blue);
  font-weight:700; letter-spacing:3px; text-transform:uppercase;
  margin-bottom:24px; animation:fadeUp .7s ease .15s both;
}
.hero-desc { font-size:18px; color:var(--text-medium); line-height:1.8; margin-bottom:40px; max-width:500px; animation:fadeUp .7s ease .2s both; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; animation:fadeUp .7s ease .3s both; }

.hero-visual { display:flex; align-items:center; gap:28px; animation:fadeUp .9s ease .3s both; }

/* Expertise cards */
.expertise-cards { display:flex; flex-direction:column; gap:24px; min-width:260px; }
.expertise-card {
  display:flex; align-items:center; gap:20px;
  background:var(--white); border-radius:var(--radius);
  padding:32px 36px; border-left:5px solid;
  box-shadow:0 8px 40px rgba(0,140,170,.08), 0 1px 3px rgba(0,0,0,.04);
  transition:transform .4s;
}
.expertise-card:hover { transform:translateY(-4px); }
.expertise-card--blue { border-left-color:var(--blue); animation:float 7s ease-in-out infinite; }
.expertise-card--orange { border-left-color:var(--orange); animation:float 8s ease-in-out 1s infinite; }
.expertise-card-icon { font-size:42px; line-height:1; flex-shrink:0; }
.expertise-card-text h4 { font-size:24px; font-weight:700; margin-bottom:4px; }
.expertise-card-text p { font-size:16px; color:var(--text-medium); line-height:1.5; font-style:italic; }

.hero .hs-1 { top:10%;right:5%;width:220px;height:220px;background:var(--blue-light);opacity:.25;animation:floatSlow 10s ease-in-out infinite; }
.hero .hs-2 { bottom:8%;left:3%;width:140px;height:140px;background:var(--orange-medium);opacity:.15;animation:floatSlow 8s ease-in-out 2s infinite; }
.hero .hs-3 { top:40%;left:42%;width:60px;height:60px;background:var(--pink-light);opacity:.35;animation:pulse 6s ease-in-out infinite; }
.hero .hs-4 { bottom:25%;right:25%;width:40px;height:40px;border:3px solid var(--blue-light);border-radius:8px;animation:spin 25s linear infinite; }
.hero .hs-5 { top:15%;left:15%;width:12px;height:12px;background:var(--orange);border-radius:50%;opacity:.4;animation:pulse 4s ease-in-out infinite; }

/* Hero stats bar */
.hero-stats {
  display:flex; gap:40px; margin-top:48px; padding-top:32px;
  border-top:1px solid rgba(0,140,170,.1); animation:fadeUp .7s ease .4s both;
}
.hero-stat { text-align:left; }
.hero-stat-num {
  font-family:var(--font-heading); font-size:36px; font-weight:700;
  color:var(--blue); line-height:1; margin-bottom:4px;
  display:flex; align-items:baseline; gap:2px;
}
.hero-stat-num .counter { display:inline; }
.hero-stat-num .suffix { font-size:24px; color:var(--orange); }
.hero-stat-label { font-size:13px; color:var(--text-light); font-weight:600; }

/* Hero portraits */
.hero-portraits {
  flex-shrink:0;
  display:flex; gap:24px; align-items:flex-start;
}
.hero-portrait {
  width:240px; height:300px; border-radius:42% 58% 70% 30% / 45% 45% 55% 55%;
  overflow:hidden; opacity:.8;
  animation:floatSlow 9s ease-in-out infinite;
  box-shadow:0 16px 48px rgba(0,140,170,.2);
}
.hero-portrait img {
  width:100%; height:100%; object-fit:cover; object-position:center top;
  filter:grayscale(10%) brightness(1.02);
}
.hero-portrait:nth-child(2) {
  border-radius:60% 40% 30% 70% / 50% 60% 40% 50%;
  animation-delay:2s; margin-top:40px;
}
.hero-portrait:nth-child(3) {
  border-radius:30% 70% 70% 30% / 30% 52% 48% 70%;
  animation-delay:4s; margin-top:-15px;
}


/* Clients — logo carousel */
.clients-section {
  padding:60px 0; background:var(--white);
  border-top:1px solid rgba(0,0,0,.04); border-bottom:1px solid rgba(0,0,0,.04);
}
.clients-header {
  text-align:center; margin-bottom:32px;
}
.clients-header p {
  font-size:13px; font-weight:700; text-transform:uppercase;
  letter-spacing:2.5px; color:var(--text-light);
}
.logo-carousel {
  overflow:hidden;
  -webkit-mask-image:linear-gradient(to right, transparent, black 8%, black 92%, transparent);
  mask-image:linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}
.logo-track {
  display:flex; align-items:center; gap:56px;
  width:max-content;
  animation:logoScroll 50s linear infinite;
}
.logo-track img {
  height:72px; width:auto; object-fit:contain;
  opacity:.8;
  transition:opacity .3s;
  flex-shrink:0;
}
.logo-track img:hover {
  opacity:1;
}
@keyframes logoScroll {
  0%   { transform:translateX(0) }
  100% { transform:translateX(-50%) }
}

/* Contact CTA (bottom homepage) */
.home-contact-cta {
  background:var(--off-white); position:relative; overflow:hidden;
}
.home-contact-cta::before {
  content:''; position:absolute; top:0; right:0; bottom:0; width:50%;
  background:url('/img/condor-skyline-2.jpg') no-repeat right center/cover;
  opacity:.03; pointer-events:none; z-index:0;
}
.home-contact-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.home-contact-visual {
  background:linear-gradient(135deg, var(--blue), var(--blue-vlight));
  border-radius:var(--radius-lg); padding:48px; color:white;
  position:relative; overflow:hidden;
}
.home-contact-visual::before {
  content:''; position:absolute; top:-40px;right:-40px;
  width:180px;height:180px; background:var(--orange); opacity:.12;
  border-radius:50%;
}
.home-contact-visual::after {
  content:''; position:absolute; bottom:-30px;left:-30px;
  width:120px;height:120px; background:var(--blue-light); opacity:.15;
  border-radius:60% 40% 30% 70%/50% 60% 40% 50%;
}
.home-contact-visual h3 { font-size:28px; margin-bottom:16px; position:relative;z-index:1; }
.home-contact-visual p { font-size:16px; opacity:.85; line-height:1.7; margin-bottom:24px; position:relative;z-index:1; }
.home-contact-visual .contact-stats {
  display:flex; gap:24px; margin-top:24px; position:relative;z-index:1;
}
.home-contact-visual .cs-item { text-align:center; }
.home-contact-visual .cs-num { font-family:var(--font-heading); font-size:28px; font-weight:700; }
.home-contact-visual .cs-label { font-size:12px; opacity:.7; }
.home-contact-form {
  background:white; border-radius:var(--radius-lg); padding:40px;
  box-shadow:0 4px 24px rgba(0,0,0,.04);
}

/* Value props */
.value-section { background:var(--off-white); }
.value-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:48px; }
.value-card {
  background:var(--white); border-radius:var(--radius-lg); padding:36px 32px;
  position:relative; overflow:hidden; transition:all .4s; border:1px solid rgba(0,140,170,.05);
}
.value-card::before { content:''; position:absolute; top:0;left:0;right:0; height:4px; border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
.value-card:nth-child(1)::before { background:var(--blue); }
.value-card:nth-child(2)::before { background:var(--orange); }
.value-card:nth-child(3)::before { background:var(--blue-vlight); }
.value-card:hover { transform:translateY(-6px); box-shadow:0 16px 48px rgba(0,140,170,.1); }
.value-icon { width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px; }
.value-card:nth-child(1) .value-icon { background:var(--blue-light); }
.value-card:nth-child(2) .value-icon { background:var(--pink-light); }
.value-card:nth-child(3) .value-icon { background:var(--blue-light); }
.value-card h3 { font-size:20px; margin-bottom:10px; }
.value-card p { font-size:15px; color:var(--text-medium); line-height:1.7; }
.value-link { display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-size:14px; font-weight:700; color:var(--blue); cursor:pointer; transition:gap .3s; }
.value-card:hover .value-link { gap:10px; }

/* Olympic Rings USP */
.rings-wrapper { display:flex; flex-direction:column; align-items:center; margin-top:56px; }
.rings-row { display:flex; justify-content:center; }
.rings-row-top { gap:20px; }
.rings-row-bottom { gap:20px; margin-top:-50px; }
.ring {
  width:200px; height:200px; border-radius:50%; position:relative;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:28px;
  border:5px solid transparent; background:var(--white);
  transition:transform .4s, box-shadow .4s;
  z-index:1;
}
.ring:hover { transform:scale(1.06); z-index:3; }
.ring-1 { border-color:var(--blue); box-shadow:0 4px 20px rgba(0,140,170,.15); }
.ring-2 { border-color:var(--orange); box-shadow:0 4px 20px rgba(242,140,56,.15); }
.ring-3 { border-color:var(--blue-dark); box-shadow:0 4px 20px rgba(0,110,134,.15); }
.ring-4 { border-color:var(--blue-vlight); box-shadow:0 4px 20px rgba(0,163,203,.15); }
.ring-5 { border-color:var(--orange-medium); box-shadow:0 4px 20px rgba(253,182,121,.15); }
.ring:hover.ring-1 { box-shadow:0 8px 32px rgba(0,140,170,.25); }
.ring:hover.ring-2 { box-shadow:0 8px 32px rgba(242,140,56,.25); }
.ring:hover.ring-3 { box-shadow:0 8px 32px rgba(0,110,134,.25); }
.ring:hover.ring-4 { box-shadow:0 8px 32px rgba(0,163,203,.25); }
.ring:hover.ring-5 { box-shadow:0 8px 32px rgba(253,182,121,.25); }
.ring-icon { font-size:28px; margin-bottom:6px; }
.ring h4 { font-size:14px; line-height:1.3; color:var(--text-dark); }
.ring p { font-size:12px; color:var(--text-medium); line-height:1.4; margin-top:4px; }

/* CTA band */
.cta-band {
  background:linear-gradient(135deg, var(--blue), var(--blue-dark)); position:relative; overflow:hidden;
}
.cta-band::after {
  content:''; position:absolute; top:0; right:0; bottom:0; left:0;
  background:url('/img/condor-skyline-3.jpg') no-repeat center/cover;
  opacity:.08; pointer-events:none; mix-blend-mode:overlay;
}
.cta-band-inner { display:grid; grid-template-columns:1.2fr 1fr; gap:60px; align-items:center; color:white; }
.cta-band h2 { font-size:36px; color:white; margin-bottom:16px; letter-spacing:-.5px; }
.cta-band > .container > .cta-band-inner > div > p { font-size:17px; opacity:.85; line-height:1.8; margin-bottom:32px; }
.cta-form { background:rgba(255,255,255,.08); border-radius:var(--radius-lg); padding:40px; border:1px solid rgba(255,255,255,.1); }
.cta-form h3 { font-size:22px; margin-bottom:8px; color:white; }
.cta-form > p { font-size:14px; opacity:.7; margin-bottom:24px; color:white; }
.cta-input {
  width:100%; padding:14px 20px; border:2px solid rgba(255,255,255,.15);
  border-radius:10px; background:rgba(255,255,255,.06); color:white;
  font-family:var(--font-body); font-size:15px; outline:none; transition:all .3s; margin-bottom:12px;
}
.cta-input::placeholder { color:rgba(255,255,255,.4); }
.cta-input:focus { border-color:var(--orange); background:rgba(255,255,255,.1); }
.cta-band .cs-1 { top:-60px;right:-60px;width:250px;height:250px;background:var(--orange);opacity:.08;animation:floatSlow 12s ease-in-out infinite; }
.cta-band .cs-2 { bottom:-50px;left:-50px;width:200px;height:200px;background:var(--blue-vlight);opacity:.1;animation:floatSlow 10s ease-in-out 3s infinite; }

/* Blog cards */
.blog-preview-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:40px; }
.blog-grid, .blog-preview-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card {
  background:white; border-radius:var(--radius); overflow:hidden;
  box-shadow:0 2px 16px rgba(0,0,0,.03); transition:all .4s; border:1px solid rgba(0,0,0,.04);
}
.blog-card:hover { transform:translateY(-6px); box-shadow:0 12px 40px rgba(0,140,170,.08); }
.blog-thumb { height:160px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.blog-thumb--has-img { background:var(--off-white) !important; }
.blog-thumb img { width:100%; height:100%; object-fit:cover; }
.blog-thumb-shape { position:absolute; bottom:-30px;right:-30px; width:120px;height:120px; background:rgba(255,255,255,.12); }
.blog-thumb-icon { font-size:40px; opacity:.3; position:relative; z-index:1; }
.blog-hero-image { max-width:800px; margin:0 auto 40px; border-radius:var(--radius); overflow:hidden; box-shadow:0 8px 40px rgba(0,0,0,.08); }
.blog-hero-image img { width:100%; height:auto; display:block; }
.blog-body { padding:24px 28px; }
.blog-tag { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--blue); margin-bottom:10px; }
.blog-card h3 { font-size:17px; margin-bottom:8px; line-height:1.4; }
.blog-card p { font-size:14px; color:var(--text-medium); line-height:1.6; margin-bottom:14px; }
.blog-link { font-size:14px; font-weight:700; color:var(--blue); display:inline-flex; align-items:center; gap:6px; cursor:pointer; transition:gap .3s; }
.blog-link:hover { gap:10px; }

/* ==========================================================================
   PAGINA: OVER ZENITH — ✏️ PAS TEKSTEN HIERONDER AAN
   ========================================================================== */
.page-hero {
  padding:calc(var(--nav-height) + 60px) 0 60px;
  background:linear-gradient(165deg, var(--white) 0%, #EFF9FC 50%, var(--white) 100%);
  position:relative; overflow:hidden;
}
.page-hero-inner { max-width:700px; }
.page-hero h1 { font-size:48px; letter-spacing:-1px; margin-bottom:20px; }
.page-hero p { font-size:18px; color:var(--text-medium); line-height:1.8; }

/* Page hero with visual (grid variant) */
.page-hero-grid { display:grid; grid-template-columns:1fr auto; gap:48px; align-items:center; }
.page-hero-portrait {
  width:280px; height:350px; flex-shrink:0;
  border-radius:42% 58% 70% 30% / 45% 45% 55% 55%;
  overflow:hidden; box-shadow:0 16px 48px rgba(0,140,170,.15);
  animation:floatSlow 12s ease-in-out infinite;
}
.page-hero-portrait.page-hero-fade { position:relative; }
.page-fade-img {
  position:absolute; top:0; left:0; width:100%; height:100%;
  opacity:0; animation:pageFade 60s infinite;
}
.page-fade-img img {
  width:100%; height:100%; object-fit:cover; object-position:center top;
  border-radius:42% 58% 70% 30% / 45% 45% 55% 55%;
  filter:grayscale(10%) brightness(1.02);
}
.page-fade-img:first-child { opacity:1; }
@keyframes pageFade {
  0%   { opacity:0 }
  1%   { opacity:1 }
  7%   { opacity:1 }
  8.33%  { opacity:0 }
  100% { opacity:0 }
}

.philo-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.philo-card {
  background:linear-gradient(135deg, var(--blue), var(--blue-vlight));
  border-radius:var(--radius-lg); padding:48px; color:white; position:relative; overflow:hidden;
}
.philo-card::before { content:'"'; position:absolute; top:-20px;left:20px; font-family:Georgia,serif; font-size:180px; opacity:.08; line-height:1; }
.philo-card blockquote { font-family:var(--font-heading); font-size:22px; line-height:1.5; position:relative;z-index:1; margin-bottom:16px; }
.philo-card cite { font-style:normal; font-size:14px; opacity:.7; }
.philo-points h3 { font-size:26px; margin-bottom:24px; }
.philo-point { display:flex; gap:14px; margin-bottom:18px; align-items:flex-start; }
.philo-dot { width:10px;height:10px;min-width:10px; border-radius:50%; background:var(--orange); margin-top:8px; }
.philo-point p { font-size:15px; color:var(--text-medium); line-height:1.7; }
.philo-point strong { color:var(--text-dark); }

.formula-card { background:white; border-radius:var(--radius-lg); padding:48px; box-shadow:0 4px 24px rgba(0,0,0,.04); text-align:center; }
.formula-card h3 { font-size:18px; color:var(--text-light); margin-bottom:20px; }
.formula-equation { display:flex; align-items:center; justify-content:center; gap:12px; flex-wrap:wrap; margin-bottom:12px; }
.formula-pill { padding:10px 20px; border-radius:100px; font-family:var(--font-heading); font-size:15px; font-weight:700; }
.formula-pill-blue { background:var(--blue-light); color:var(--blue); }
.formula-pill-orange { background:var(--pink-light); color:var(--orange); }
.formula-sign { font-family:var(--font-heading); font-size:20px; color:var(--text-light); }

.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:48px; }
.team-card {
  text-align:center; background:white; border-radius:var(--radius-lg); padding:40px 32px 36px;
  box-shadow:0 2px 12px rgba(0,0,0,.03); transition:all .4s; border:1px solid rgba(0,140,170,.04);
  display:flex; flex-direction:column; align-items:center;
}
.team-card:hover { transform:translateY(-6px); box-shadow:0 12px 40px rgba(0,140,170,.08); }
.team-avatar {
  width:440px;height:440px; max-width:100%; margin:0 auto 28px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-heading); font-size:64px; font-weight:700; color:white;
}
.team-photo {
  width:440px; height:440px; border-radius:50%; object-fit:cover; margin:0 auto 28px;
  border:4px solid var(--blue-light); transition:transform .3s; max-width:100%;
}
.team-card:hover .team-photo { transform:scale(1.05); }
.team-card:nth-child(1) .team-avatar { background:linear-gradient(135deg,var(--blue),var(--blue-vlight)); border-radius:42% 58% 70% 30%/45% 45% 55% 55%; }
.team-card:nth-child(2) .team-avatar { background:linear-gradient(135deg,var(--orange),var(--orange-medium)); border-radius:60% 40% 30% 70%/50% 60% 40% 50%; }
.team-card:nth-child(3) .team-avatar { background:linear-gradient(135deg,var(--blue-vlight),var(--blue-light)); border-radius:30% 70% 70% 30%/30% 52% 48% 70%; }
.team-card:nth-child(4) .team-avatar { background:linear-gradient(135deg,var(--blue-dark),var(--blue)); border-radius:50% 50% 42% 58%/58% 42% 58% 42%; }
.team-card:nth-child(5) .team-avatar { background:linear-gradient(135deg,var(--orange),var(--blue)); border-radius:42% 58% 55% 45%/55% 42% 58% 48%; }
.team-card:nth-child(6) .team-avatar { background:linear-gradient(135deg,var(--blue),var(--blue-light)); border-radius:58% 42% 45% 55%/42% 58% 42% 58%; }
.team-card:nth-child(7) .team-avatar { background:linear-gradient(135deg,var(--orange-medium),var(--orange)); border-radius:45% 55% 60% 40%/50% 45% 55% 50%; }
.team-card:nth-child(8) .team-avatar { background:linear-gradient(135deg,var(--blue-vlight),var(--blue-dark)); border-radius:55% 45% 40% 60%/45% 55% 45% 55%; }
.team-card:nth-child(9) .team-avatar { background:linear-gradient(135deg,var(--blue-dark),var(--orange-medium)); border-radius:40% 60% 55% 45%/60% 40% 55% 45%; }
.team-card:nth-child(10) .team-avatar { background:linear-gradient(135deg,var(--orange),var(--blue-vlight)); border-radius:50% 50% 45% 55%/55% 45% 50% 50%; }
.team-card:nth-child(11) .team-avatar { background:linear-gradient(135deg,var(--blue),var(--orange)); border-radius:45% 55% 50% 50%/50% 50% 45% 55%; }
.team-card:nth-child(12) .team-avatar { background:linear-gradient(135deg,var(--blue-light),var(--blue)); border-radius:55% 45% 42% 58%/48% 52% 50% 50%; }
.team-card h4 { font-size:20px; margin-bottom:6px; }
.team-role { font-size:14px; color:var(--blue); font-weight:600; margin-bottom:12px; }
.team-bio { font-size:15px; color:var(--text-light); line-height:1.6; margin-bottom:14px; }
.team-tags { display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin-bottom:14px; }
.team-tag {
  font-size:11px; font-weight:600; letter-spacing:.5px; padding:4px 10px;
  border-radius:20px; background:var(--off-white); color:var(--text-medium); border:1px solid var(--grey-light);
}
.team-tag-sales { background:rgba(0,140,170,.08); color:var(--blue); border-color:rgba(0,140,170,.15); }
.team-tag-neg { background:rgba(242,140,56,.08); color:var(--orange); border-color:rgba(242,140,56,.15); }
.team-linkedin {
  display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:600;
  color:var(--blue); transition:color .3s; margin-top:auto;
}
.team-linkedin:hover { color:var(--blue-dark); }
.team-linkedin svg { width:16px; height:16px; fill:currentColor; }

/* ==========================================================================
   PAGINA: AANPAK — ✏️ PAS TEKSTEN HIERONDER AAN
   ========================================================================== */
.phases-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; position:relative; margin-top:48px; }
.phases-grid::before { content:''; position:absolute; top:56px; left:12%;right:12%; height:3px; background:linear-gradient(90deg,var(--blue),var(--orange),var(--blue-vlight)); border-radius:3px; z-index:0; }
.phase-card {
  background:white; border-radius:var(--radius-lg); padding:40px 32px; text-align:center;
  position:relative; z-index:1; box-shadow:0 4px 24px rgba(0,0,0,.03); transition:all .4s; border:1px solid rgba(0,140,170,.05);
}
.phase-card:hover { transform:translateY(-8px); box-shadow:0 16px 48px rgba(0,140,170,.1); }
.phase-num {
  width:56px;height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-heading); font-size:22px; font-weight:700; color:white; margin:0 auto 24px;
}
.phase-card:nth-child(1) .phase-num { background:var(--blue); }
.phase-card:nth-child(2) .phase-num { background:var(--orange); }
.phase-card:nth-child(3) .phase-num { background:var(--blue-vlight); }
.phase-card h3 { font-size:22px; margin-bottom:12px; }
.phase-card p { font-size:15px; color:var(--text-medium); line-height:1.7; }
.phase-card:nth-child(4) .phase-num { background:var(--blue-dark); }

/* Partner page */
.partner-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.partner-card {
  background:white; border-radius:var(--radius-lg); padding:36px 28px;
  box-shadow:0 4px 24px rgba(0,0,0,.04); transition:transform .3s, box-shadow .3s;
  border:1px solid rgba(0,140,170,.05);
}
.partner-card:hover { transform:translateY(-8px); box-shadow:0 16px 48px rgba(0,140,170,.1); }
.partner-icon { width:48px;height:48px; margin-bottom:20px; color:var(--blue); }
.partner-card h4 { font-size:18px; margin-bottom:8px; }
.partner-card p { font-size:15px; color:var(--text-medium); line-height:1.7; }
.partner-quote {
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
}
.partner-quote-photo { border-radius:var(--radius-lg); overflow:hidden; }
.partner-quote-photo img { width:100%; height:auto; display:block; }
.phases-grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; margin-top:48px; }
.phases-grid-4::before { content:''; position:absolute; top:56px; left:8%;right:8%; height:3px; background:linear-gradient(90deg,var(--blue),var(--orange),var(--blue-vlight),var(--blue)); border-radius:3px; z-index:0; }

.phases-impact {
  margin-top:40px; display:flex; align-items:center; gap:24px;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark)); border-radius:var(--radius-lg);
  padding:32px 40px; color:white; position:relative; overflow:hidden;
}
.phases-impact::before { content:''; position:absolute; top:-40px;right:-40px; width:160px;height:160px; background:var(--orange); opacity:.12; border-radius:50%; }
.phases-impact-title { font-family:var(--font-heading); font-size:40px; color:var(--orange); z-index:1; flex-shrink:0; margin:0; }
.phases-impact-eq { font-family:var(--font-heading); font-size:48px; color:var(--orange); font-weight:700; z-index:1; flex-shrink:0; }
.phases-impact-desc { font-size:15px; opacity:.85; line-height:1.6; max-width:520px; z-index:1; margin:0; }

/* Knob grid (5 knoppen competentiemodel) */
.knob-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:20px; margin-top:36px; }
.knob-card { background:var(--off-white); border-radius:var(--radius); padding:24px 20px; text-align:center; }
.knob-card h4 { font-size:16px; margin-bottom:8px; }
.knob-card p { font-size:14px; color:var(--text-medium); line-height:1.6; }
.knob-num { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-size:18px; font-weight:700; color:white; margin:0 auto 12px; }
.knob-blue { background:var(--blue); }
.knob-orange { background:var(--orange); }

/* Competentie domain headers */
.comp-domain { font-size:18px; margin-bottom:20px; display:flex; align-items:center; gap:10px; }
.comp-domain-dot { width:12px; height:12px; border-radius:50%; display:inline-block; flex-shrink:0; }
.comp-card p { font-size:13px; color:var(--text-medium); line-height:1.5; margin-top:6px; }

.comp-tabs { display:flex; justify-content:center; gap:8px; margin-bottom:36px; }
.comp-tab {
  padding:10px 28px; border-radius:100px; font-family:var(--font-body); font-size:14px;
  font-weight:700; cursor:pointer; border:2px solid var(--grey-light); background:white; color:var(--text-medium); transition:all .3s;
}
.comp-tab.active, .comp-tab:hover { border-color:var(--blue); background:var(--blue); color:white; }
.comp-tab[data-cat="neg"].active, .comp-tab[data-cat="neg"]:hover { border-color:var(--orange); background:var(--orange); color:white; }
.comp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.comp-card {
  background:white; border-radius:var(--radius); padding:24px;
  box-shadow:0 2px 12px rgba(0,0,0,.03); border-left:4px solid var(--blue); transition:all .3s;
}
.comp-card:hover { transform:translateY(-3px); box-shadow:0 8px 28px rgba(0,140,170,.08); }
.comp-num { font-family:var(--font-heading); font-size:32px; font-weight:700; color:var(--blue-light); margin-bottom:6px; }
.comp-card h4 { font-size:15px; }
.neg .comp-card { border-left-color:var(--orange); }
.neg .comp-num { color:var(--orange-medium); }

/* USP detail cards */
.usp-detail { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:40px; }
.usp-card {
  display:flex; gap:20px; padding:28px; background:white; border-radius:var(--radius);
  box-shadow:0 2px 12px rgba(0,0,0,.03); transition:all .3s; border:1px solid rgba(0,140,170,.04); align-items:flex-start;
}
.usp-card:hover { box-shadow:0 8px 32px rgba(0,140,170,.08); transform:translateY(-3px); }
.usp-icon { width:52px;height:52px;min-width:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:24px; }
.usp-card:nth-child(odd) .usp-icon { background:var(--blue-light); }
.usp-card:nth-child(even) .usp-icon { background:var(--pink-light); }
.usp-card h4 { font-size:17px; margin-bottom:6px; }
.usp-card p { font-size:14px; color:var(--text-medium); line-height:1.6; }
.usp-full { grid-column:span 2; }

/* ==========================================================================
   PAGINA: CONTACT — ✏️ PAS CONTACTGEGEVENS HIERONDER AAN
   ========================================================================== */
.contact-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:60px; margin-top:48px; }
.contact-info h3 { font-size:26px; margin-bottom:16px; }
.contact-info > p { font-size:16px; color:var(--text-medium); margin-bottom:28px; line-height:1.7; }
.contact-item { display:flex; gap:16px; margin-bottom:20px; align-items:center; }
.contact-icon { width:48px;height:48px;min-width:48px; border-radius:14px; background:var(--blue-light); display:flex; align-items:center; justify-content:center; font-size:20px; }
.contact-item strong { display:block; font-size:13px; margin-bottom:2px; }
.contact-item p { font-size:15px; color:var(--text-medium); }
.leadrr-badge { margin-top:32px; padding:20px 24px; background:var(--blue-light); border-radius:14px; }
.leadrr-badge strong { font-size:14px; color:var(--blue); display:block; margin-bottom:4px; }
.leadrr-badge p { font-size:13px; color:var(--text-medium); line-height:1.6; }
.contact-form-card { background:white; border-radius:var(--radius-lg); padding:40px; box-shadow:0 4px 24px rgba(0,0,0,.04); }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:13px; font-weight:700; margin-bottom:6px; }
.form-control {
  width:100%; padding:13px 18px; border:2px solid #E8ECF0; border-radius:10px;
  font-family:var(--font-body); font-size:15px; color:var(--text-dark); outline:none;
  transition:border-color .3s; background:var(--off-white);
}
.form-control:focus { border-color:var(--blue); background:white; }
textarea.form-control { min-height:110px; resize:vertical; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* Programs — Framework funnel */
.funnel { max-width:520px; margin:0 auto; }
.funnel-phase { margin-bottom:4px; }
.funnel-phase-label {
  font-family:var(--font-heading); font-weight:700; font-size:22px;
  text-transform:uppercase; letter-spacing:1px; margin-bottom:14px;
  display:flex; align-items:baseline; gap:10px; flex-wrap:wrap;
}
.funnel-phase-label span { font-size:15px; font-weight:500; text-transform:none; letter-spacing:0; opacity:.75; }
.funnel-phase--sell .funnel-phase-label { color:var(--blue); }
.funnel-phase--nego .funnel-phase-label { color:var(--orange); }

.funnel-steps { display:flex; flex-direction:column; gap:3px; }
.funnel-step {
  display:flex; align-items:center; gap:14px; padding:12px 20px;
  border-radius:10px; font-size:15px; color:var(--white); font-weight:600;
  transition:transform .2s;
}
.funnel-step:hover { transform:translateX(4px); }
.funnel-step-num {
  font-size:12px; opacity:.7; min-width:18px; font-weight:700;
}
.funnel-phase--sell .funnel-step { background:var(--blue); }

.funnel-divider {
  text-align:center; padding:14px 0; font-size:13px; font-weight:700;
  color:var(--text-light); text-transform:uppercase; letter-spacing:2px;
  position:relative;
}
.funnel-divider::before,
.funnel-divider::after {
  content:''; position:absolute; top:50%; height:1px;
  width:calc(50% - 80px); background:var(--grey-light);
}
.funnel-divider::before { left:0; }
.funnel-divider::after { right:0; }

.funnel-phase--nego .funnel-step { background:var(--orange); }

.funnel-caption {
  text-align:center; margin-top:24px; font-size:14px; color:var(--text-light); line-height:1.6;
}

/* Programs — Services grid */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.services-col {
  background:var(--white); border-radius:var(--radius-lg); padding:0;
  box-shadow:0 2px 16px rgba(0,0,0,.04); overflow:hidden;
  display:flex; flex-direction:column;
}
.services-col-header {
  padding:28px 28px 20px; position:relative;
}
.services-col-header::before {
  content:''; position:absolute; top:0;left:0;right:0; height:4px;
}
.services-col:nth-child(1) .services-col-header::before { background:var(--blue); }
.services-col:nth-child(2) .services-col-header::before { background:var(--orange); }
.services-col:nth-child(3) .services-col-header::before { background:var(--blue-vlight); }
.services-col-icon {
  width:48px; height:48px; border-radius:12px; display:flex;
  align-items:center; justify-content:center; font-size:22px; margin-bottom:14px;
}
.services-col:nth-child(1) .services-col-icon { background:var(--blue-light); }
.services-col:nth-child(2) .services-col-icon { background:var(--pink-light); }
.services-col:nth-child(3) .services-col-icon { background:var(--blue-light); }
.services-col-header h3 { font-size:22px; margin-bottom:6px; }
.services-col-header p { font-size:14px; color:var(--text-medium); line-height:1.6; }

.services-col-body {
  padding:0 28px 28px; flex:1;
}
.services-list {
  list-style:none; padding:0; margin:0;
  border-top:1px solid rgba(0,0,0,.06); padding-top:16px;
}
.services-list li {
  display:flex; align-items:flex-start; gap:10px; padding:5px 0;
  font-size:14px; color:var(--text-medium); line-height:1.6;
}
.services-list li::before {
  content:''; width:6px; height:6px; min-width:6px; border-radius:50%;
  background:var(--blue); margin-top:8px;
}
.services-col:nth-child(2) .services-list li::before { background:var(--orange); }
.services-col:nth-child(3) .services-list li::before { background:var(--blue-vlight); }

.services-sub { font-weight:700; font-size:13px; color:var(--text-dark); margin:14px 0 4px; }
.services-sub:first-child { margin-top:0; }

.services-badge {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; font-weight:600; color:var(--blue-vlight);
  background:rgba(0,163,203,.08); padding:4px 10px; border-radius:20px;
  margin-top:10px;
}
.services-badge::before { content:'🔬'; font-size:13px; }

/* Open training cards */
.open-training-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.open-training-card {
  background:var(--white); border-radius:var(--radius-lg); padding:36px 32px;
  position:relative; overflow:hidden; border:1px solid rgba(0,140,170,.05);
  display:flex; flex-direction:column;
}
.open-training-card::before { content:''; position:absolute; top:0;left:0;right:0; height:4px; border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
.open-training-card--blue::before { background:var(--blue); }
.open-training-card--orange::before { background:var(--orange); }
.open-training-card h3 { font-size:22px; margin-bottom:12px; }
.open-training-card > p { font-size:15px; color:var(--text-medium); line-height:1.7; margin-bottom:20px; }
.open-training-details { list-style:none; margin-bottom:28px; display:flex; flex-direction:column; gap:8px; flex-grow:1; }
.open-training-details li { font-size:14px; color:var(--text-medium); line-height:1.6; padding-left:0; }
.open-training-details li strong { color:var(--text-dark); }
.open-training-actions { display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.open-training-actions .btn-outline { font-size:13px; color:var(--text-medium); border-color:var(--grey-light); }
.open-training-actions .btn-outline:hover { color:var(--blue); border-color:var(--blue); }

/* Audience grid */
.audience-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.audience-card {
  background:var(--white); border-radius:var(--radius-lg); padding:32px 28px;
  border:1px solid rgba(0,140,170,.05); text-align:center;
}
.audience-icon { font-size:32px; margin-bottom:16px; }
.audience-card h4 { font-size:18px; margin-bottom:10px; }
.audience-card p { font-size:15px; color:var(--text-medium); line-height:1.7; }
.audience-note { text-align:center; margin-top:28px; font-size:15px; color:var(--text-medium); font-style:italic; }

/* Callout light — off-white variant of cta-band */
.callout-light {
  background:var(--white); border:1px solid rgba(0,140,170,.08);
  border-radius:var(--radius-lg); padding:48px 40px; text-align:center;
}
.callout-light h3 { font-size:24px; margin-bottom:12px; }
.callout-light p { font-size:16px; color:var(--text-medium); line-height:1.7; max-width:620px; margin:0 auto 24px; }

/* Programs — CTA band */
.programs-cta {
  background:linear-gradient(135deg, var(--blue), var(--blue-dark));
  color:white; text-align:center; padding:48px 40px; border-radius:var(--radius-lg);
  position:relative; overflow:hidden;
}
.programs-cta::before {
  content:''; position:absolute; top:-50px;right:-50px;
  width:200px;height:200px; background:var(--orange); opacity:.08;
  border-radius:42% 58% 70% 30% / 45% 45% 55% 55%;
}
.programs-cta::after {
  content:''; position:absolute; bottom:-40px;left:-40px;
  width:160px;height:160px; background:var(--blue-vlight); opacity:.1;
  border-radius:60% 40% 30% 70%/50% 60% 40% 50%;
}
.programs-cta h3 { font-size:28px; margin-bottom:12px; position:relative;z-index:1; }
.programs-cta p { font-size:16px; opacity:.85; line-height:1.7; max-width:620px; margin:0 auto 28px; position:relative;z-index:1; }
.programs-cta .btn { position:relative; z-index:1; }

/* ==========================================================================
   FOOTER — ✏️ PAS FOOTERTEKSTEN AAN
   ========================================================================== */
.footer { background:var(--text-dark); color:rgba(255,255,255,.65); padding:60px 0 28px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px; margin-bottom:40px; }
.footer-brand p { font-size:14px; line-height:1.7; margin-top:12px; max-width:260px; }
.footer-social { display:inline-flex; margin-top:14px; color:rgba(255,255,255,.45); transition:color .2s; }
.footer-social:hover { color:var(--orange); }
.footer h5 { color:white; font-size:14px; margin-bottom:16px; }
.footer ul li { margin-bottom:10px; }
.footer ul a { font-size:14px; color:rgba(255,255,255,.55); transition:color .2s; cursor:pointer; }
.footer ul a:hover { color:var(--orange); }
.footer-address { font-size:14px; color:rgba(255,255,255,.55); }
.footer-nl-form { display:flex; gap:8px; margin-top:12px; }
.footer-nl-form input { flex:1; padding:10px 14px; border:1px solid rgba(255,255,255,.12); border-radius:8px; background:rgba(255,255,255,.05); color:white; font-family:var(--font-body); font-size:14px; outline:none; }
.footer-nl-form input::placeholder { color:rgba(255,255,255,.3); }
.footer-nl-form button { padding:10px 16px; border:none; border-radius:8px; background:var(--orange); color:white; font-weight:700; cursor:pointer; }
.footer-bar { border-top:1px solid rgba(255,255,255,.06); padding-top:24px; display:flex; justify-content:space-between; align-items:center; font-size:13px; }
.footer-leadrr { font-size:12px; color:rgba(255,255,255,.35); }
.footer-leadrr span { color:rgba(255,255,255,.6); font-weight:600; }

/* Legal pages */
.legal-article { max-width:800px; margin:0 auto; }
.legal-article h2 { font-size:22px; margin-top:48px; margin-bottom:16px; padding-bottom:8px; border-bottom:2px solid var(--blue-light); }
.legal-article h3 { font-size:18px; margin-top:32px; margin-bottom:12px; }
.legal-article p, .legal-article li { font-size:15px; line-height:1.7; color:var(--text-medium); }
.legal-article ol, .legal-article ul { margin-bottom:20px; padding-left:24px; }
.legal-article li { margin-bottom:8px; }
.legal-article a { color:var(--blue); font-weight:600; }
.legal-meta { background:var(--white); border-radius:var(--radius); padding:24px 28px; margin-bottom:40px; box-shadow:0 2px 12px rgba(0,0,0,.04); }
.legal-meta table { width:100%; }
.legal-meta td { padding:6px 12px 6px 0; font-size:14px; color:var(--text-medium); vertical-align:top; }
.legal-meta td:first-child { white-space:nowrap; width:140px; }
.footer-legal { display:flex; gap:16px; }
.footer-legal a { color:rgba(255,255,255,.4); font-size:12px; transition:color .3s; }
.footer-legal a:hover { color:rgba(255,255,255,.7); }

/* AI Avatar section */
.ai-avatar-section { background:var(--white); }
.ai-avatar-grid {
  display:grid; grid-template-columns:1fr 1.4fr; gap:60px; align-items:center;
}
.ai-avatar-visual { display:flex; justify-content:center; }
.ai-avatar-placeholder {
  position:relative; width:320px; height:360px;
  background:linear-gradient(145deg, #EFF9FC 0%, #E8F4F8 50%, #FFFBF7 100%);
  border-radius:var(--radius-lg); display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  border:2px solid rgba(0,140,170,.08);
  box-shadow:0 16px 48px rgba(0,140,170,.08);
  animation:float 8s ease-in-out infinite;
}
.ai-avatar-icon { width:180px; height:180px; }
.ai-avatar-icon svg { width:100%; height:100%; }
.ai-avatar-badge {
  position:absolute; bottom:20px;
  background:var(--orange); color:white;
  font-size:13px; font-weight:700; letter-spacing:.5px;
  padding:8px 20px; border-radius:100px;
}
.ai-avatar-intro {
  font-size:18px; color:var(--text-medium); line-height:1.8;
  margin-bottom:32px; max-width:520px;
}
.ai-avatar-features { display:flex; flex-direction:column; gap:20px; margin-bottom:36px; }
.ai-avatar-feature {
  display:flex; gap:16px; align-items:flex-start;
}
.ai-avatar-feature-icon { font-size:28px; line-height:1; flex-shrink:0; margin-top:2px; }
.ai-avatar-feature strong {
  font-family:var(--font-heading); font-size:16px; display:block; margin-bottom:4px;
}
.ai-avatar-feature p { font-size:15px; color:var(--text-medium); line-height:1.6; }
.ai-avatar-cta { display:flex; flex-wrap:wrap; align-items:center; gap:16px; }
.ai-avatar-cta-note { font-size:13px; color:var(--text-light); }

/* ==========================================================================
   FLYING CONDOR — scroll parallax
   ========================================================================== */
.flying-condor {
  position:fixed; top:0; left:0; z-index:1;
  pointer-events:none; will-change:transform,opacity;
  transform:translate(-5vw, 75vh) rotate(10deg) scale(0.6);
  opacity:0.10; transition:opacity .3s;
}
.flying-condor img {
  width:clamp(140px, 16vw, 260px); height:auto;
}
@media(max-width:768px){
  .flying-condor img { width:100px; }
}

/* ==========================================================================
   HOMEPAGE — CHALLENGE SECTION (pijn-blokken)
   ========================================================================== */
.challenge-section {
  background:var(--off-white); position:relative; overflow:hidden;
}
.challenge-section::before {
  content:''; position:absolute; top:0; right:0; bottom:0; left:0;
  background:url('/img/condor-skyline-1.jpg') no-repeat right center/50% auto;
  opacity:.06; pointer-events:none; z-index:0;
}
.challenge-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
  margin-top:48px;
}
.challenge-card {
  background:var(--white); border-radius:var(--radius-lg); padding:40px 32px;
  border:1px solid rgba(0,0,0,.04); position:relative; overflow:hidden;
  transition:all .4s;
}
.challenge-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg, var(--blue), var(--orange));
}
.challenge-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,140,170,.1); }
.challenge-stat {
  font-family:var(--font-heading); font-size:56px; font-weight:700;
  color:var(--blue); line-height:1; margin-bottom:16px;
  background:linear-gradient(135deg, var(--blue), var(--orange));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.challenge-card h3 { font-size:20px; margin-bottom:12px; color:var(--text-dark); }
.challenge-card p { font-size:15px; color:var(--text-medium); line-height:1.7; }
.stat-source { display:block; margin-top:8px; font-size:12px; color:var(--text-light,#999); font-style:italic; }
.challenge-quote {
  margin-top:48px; text-align:center; max-width:740px; margin-left:auto; margin-right:auto;
}
.challenge-quote blockquote {
  font-family:var(--font-heading); font-size:22px; line-height:1.5;
  color:var(--text-dark); font-style:italic; position:relative; padding:0 32px;
}
.challenge-quote blockquote::before,
.challenge-quote blockquote::after {
  font-style:normal; font-size:48px; color:var(--orange); opacity:.5;
  font-family:Georgia,serif; line-height:1; position:absolute;
}
.challenge-quote blockquote::before { content:'\201C'; left:0; top:-8px; }
.challenge-quote blockquote::after  { content:'\201D'; right:0; bottom:-24px; }

/* ==========================================================================
   PROGRAMMA'S — DIB CYCLUS DIAGRAM
   ========================================================================== */
.dib-cycle { text-align:center; }
.dib-cycle-svg { max-width:520px; width:100%; height:auto; margin:0 auto; display:block; }

/* ==========================================================================
   PAGE HERO — CONDOR & WIREFRAME DECORATIE
   ========================================================================== */
.page-hero::after {
  content:''; position:absolute; top:50%; right:20px;
  width:280px; height:280px; transform:translateY(-60%);
  background:url('/img/condor.png') no-repeat center/contain;
  opacity:.1; pointer-events:none; z-index:0;
  animation:floatSlow 8s ease-in-out infinite;
}
.page-hero::before {
  content:''; position:absolute; top:0; left:0; right:0; bottom:0;
  background:
    url('/img/condor-skyline-2.jpg') no-repeat right center/60% auto,
    repeating-linear-gradient(
      135deg,
      transparent,
      transparent 60px,
      rgba(0,140,170,.02) 60px,
      rgba(0,140,170,.02) 61px
    );
  opacity:.035; pointer-events:none; z-index:0;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{flex-direction:column;gap:20px}
  .hero-portraits{justify-content:center}
  .hero-portrait{width:120px;height:150px}
  .philo-grid,.contact-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .page-hero-grid{grid-template-columns:1fr}
  .page-hero-portrait{width:220px;height:275px;margin:0 auto}
  .open-training-grid{grid-template-columns:1fr}
  .audience-grid{grid-template-columns:1fr}
  .partner-grid{grid-template-columns:repeat(2,1fr)}
  .partner-quote{grid-template-columns:1fr}
  .phases-grid-4{grid-template-columns:repeat(2,1fr)}
  .cta-band-inner{grid-template-columns:1fr}
  .usp-detail{grid-template-columns:1fr} .usp-full{grid-column:span 1}
  .ring{width:170px;height:170px;padding:22px}
  .rings-row-bottom{margin-top:-40px}
  .challenge-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav{padding:0 16px;height:64px}
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:white;padding:20px;box-shadow:0 8px 32px rgba(0,0,0,.06);gap:4px;z-index:999}
  .nav-link{padding:12px 16px;font-size:16px;min-height:44px;display:flex;align-items:center}
  .nav-dropdown{position:static}
  .nav-dropdown-menu{display:none;position:static;box-shadow:none;border:none;padding:0 0 0 16px;min-width:0;background:transparent}
  .nav-dropdown.open .nav-dropdown-menu{display:block}
  .nav-dropdown-item{padding:10px 16px;font-size:15px;min-height:40px;display:flex;align-items:center}
  .nav-dropdown:hover .nav-dropdown-menu{display:none}
  .nav-dropdown.open .nav-dropdown-menu{display:block}
  .nav-cta{margin:8px 0 0;text-align:center;display:block;padding:14px 22px !important;min-height:44px}
  .lang-switch{margin-left:0;margin-top:12px;justify-content:center}
  .lang-btn{padding:8px 16px;font-size:14px;min-height:36px}

  .container{padding:0 20px}
  .section-pad{padding:64px 0}
  .section-title{font-size:30px;letter-spacing:-.5px}
  .section-desc{font-size:16px}
  .section-label{font-size:11px}

  /* Hero mobile */
  .hero{padding:calc(64px + 32px) 0 48px;min-height:auto}
  .hero h1{font-size:34px;letter-spacing:-1px}
  .hero-tagline{font-size:16px;letter-spacing:2px}
  .hero-desc{font-size:16px;margin-bottom:28px}
  .hero-tag{font-size:11px;margin-bottom:20px}
  .hero-actions{flex-direction:column;gap:12px}
  .hero-actions .btn{width:100%;justify-content:center;min-height:48px;font-size:16px}

  /* Hero visual — stack on mobile */
  .hero-visual{flex-direction:column;gap:16px;margin-top:32px}
  .hero-portraits{justify-content:center;gap:0;margin:0 auto}
  .hero-portrait{width:100px;height:120px}
  .expertise-cards{width:100%}
  .expertise-card{animation:none !important}

  /* Hero stats */
  .hero-stats{flex-wrap:wrap;gap:0;margin-top:32px;padding-top:24px;justify-content:space-between}
  .hero-stat{flex:1;min-width:33%;text-align:center}
  .hero-stat-num{font-size:26px;justify-content:center}
  .hero-stat-num .suffix{font-size:18px}
  .hero-stat-label{font-size:12px}

  /* Clients */
  .clients-section{padding:40px 0}
  .clients-header{margin-bottom:20px}
  .logo-track{gap:40px}
  .logo-track img{height:52px}

  /* Value cards */
  .value-grid{grid-template-columns:1fr;gap:16px;margin-top:32px}
  .value-card{padding:28px 24px}
  .value-card h3{font-size:18px}

  /* Rings mobile */
  .rings-wrapper{margin-top:36px}
  .rings-row-top,.rings-row-bottom{flex-wrap:wrap;gap:12px}
  .rings-row-bottom{margin-top:-30px}
  .ring{width:150px;height:150px;padding:18px;border-width:4px}
  .ring-icon{font-size:22px;margin-bottom:4px}
  .ring h4{font-size:12px}
  .ring p{font-size:11px}

  /* Challenge mobile */
  .challenge-grid{grid-template-columns:1fr;gap:16px;margin-top:32px}
  .challenge-card{padding:28px 24px}
  .challenge-stat{font-size:44px}
  .challenge-card h3{font-size:18px}
  .challenge-quote blockquote{font-size:18px;padding:0 20px}

  /* Page hero condor mobile */
  .page-hero::after{width:140px;height:140px;right:-10px;opacity:.05}

  /* CTA band */
  .cta-band .container{padding:0 20px}
  .cta-form{padding:28px 24px}
  .cta-form h3{font-size:20px}

  /* Blog */
  .blog-preview-grid,.blog-grid{grid-template-columns:1fr;gap:16px}
  .blog-preview-header{flex-direction:column;align-items:flex-start;gap:12px}
  .blog-thumb{height:140px}
  .blog-body{padding:20px 24px}

  /* Phases */
  .phases-grid{grid-template-columns:1fr;gap:16px;margin-top:32px}
  .phases-grid::before{display:none}
  .phases-grid-4{grid-template-columns:1fr;gap:16px;margin-top:32px}
  .phases-grid-4::before{display:none}
  .phase-card{padding:32px 24px}
  .partner-grid{grid-template-columns:1fr}
  .partner-card{padding:28px 20px}

  /* Phases impact */
  .phases-impact{padding:24px 20px;gap:14px;flex-wrap:wrap}
  .phases-impact-title{font-size:28px}
  .phases-impact-eq{font-size:32px}
  .phases-impact-desc{font-size:14px}

  /* Knob grid */
  .knob-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .knob-card:last-child{grid-column:span 2;max-width:50%;margin:0 auto}

  /* Competencies */
  .comp-grid{grid-template-columns:1fr;gap:12px}
  .comp-tabs{gap:6px}
  .comp-tab{padding:10px 20px;font-size:14px;min-height:44px}
  .comp-domain{font-size:16px}

  /* Team */
  .team-grid{grid-template-columns:1fr;gap:20px;max-width:400px;margin-left:auto;margin-right:auto}
  .team-card{padding:32px 24px}
  .team-photo{width:180px;height:180px}
  .team-avatar{width:180px;height:180px;font-size:40px}

  /* Philosophy */
  .philo-card{padding:32px 24px}
  .philo-card blockquote{font-size:19px}
  .philo-grid{gap:32px}

  /* Formula */
  .formula-card{padding:32px 20px}
  .formula-pill{padding:8px 14px;font-size:13px}
  .formula-sign{font-size:16px}

  /* USP detail */
  .usp-detail{grid-template-columns:1fr;gap:12px}
  .usp-card{padding:24px 20px}

  /* Programs — Funnel */
  .funnel{max-width:100%}
  .funnel-step{font-size:13px;padding:10px 16px;gap:10px}
  .funnel-phase--sell .funnel-step:nth-child(2),
  .funnel-phase--sell .funnel-step:nth-child(3),
  .funnel-phase--sell .funnel-step:nth-child(4),
  .funnel-phase--sell .funnel-step:nth-child(5),
  .funnel-phase--sell .funnel-step:nth-child(6){margin-left:0;margin-right:0}
  .funnel-phase--nego .funnel-step:nth-child(1),
  .funnel-phase--nego .funnel-step:nth-child(2),
  .funnel-phase--nego .funnel-step:nth-child(3),
  .funnel-phase--nego .funnel-step:nth-child(4),
  .funnel-phase--nego .funnel-step:nth-child(5){margin-left:0;margin-right:0}
  .funnel-divider::before,.funnel-divider::after{width:calc(50% - 60px)}

  /* Programs — Services */
  .services-grid{grid-template-columns:1fr;gap:16px}
  .services-col-header{padding:24px 24px 16px}
  .services-col-header h3{font-size:20px}
  .services-col-body{padding:0 24px 24px}

  /* Open training */
  .open-training-grid{grid-template-columns:1fr;gap:16px}
  .open-training-card{padding:28px 24px}
  .open-training-card h3{font-size:20px}
  .audience-grid{grid-template-columns:1fr;gap:16px;max-width:400px;margin-left:auto;margin-right:auto}
  .audience-card{padding:28px 24px}
  .callout-light{padding:32px 24px}
  .callout-light h3{font-size:20px}

  /* Programs — CTA */
  .programs-cta{padding:32px 24px}
  .programs-cta h3{font-size:22px}

  /* AI Avatar */
  .ai-avatar-grid{grid-template-columns:1fr;gap:32px}
  .ai-avatar-placeholder{width:260px;height:290px}
  .ai-avatar-icon{width:140px;height:140px}
  .ai-avatar-intro{font-size:16px}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .contact-form-card{padding:28px 24px}
  .form-row{grid-template-columns:1fr}
  .form-control{min-height:48px;font-size:16px}
  textarea.form-control{min-height:100px}
  .form-group label{font-size:14px}
  .contact-form-card .btn,.home-contact-form .btn{min-height:48px;font-size:16px}

  /* Home contact CTA */
  .home-contact-grid{grid-template-columns:1fr;gap:24px}
  .home-contact-visual{padding:32px 24px}
  .home-contact-visual h3{font-size:24px}
  .home-contact-visual .contact-stats{gap:16px;flex-wrap:wrap}
  .home-contact-form{padding:28px 24px}

  /* Page hero */
  .page-hero{padding:calc(64px + 32px) 0 40px}
  .page-hero h1{font-size:32px}
  .page-hero p{font-size:16px}
  .page-hero-grid{grid-template-columns:1fr;gap:24px}
  .page-hero-portrait{width:200px;height:250px;margin:0 auto}

  /* Footer */
  .footer{padding:48px 0 24px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bar{flex-direction:column;gap:10px;text-align:center}
  .footer-nl-form input{min-height:44px}
  .footer-nl-form button{min-height:44px;padding:10px 20px}

  /* All buttons min touch target */
  .btn{min-height:44px}
}

/* Extra small screens */
@media(max-width:400px){
  .hero h1{font-size:28px}
  .hero-tagline{font-size:14px;letter-spacing:1.5px}
  .section-title{font-size:26px}
  .hero-stat-num{font-size:22px}
  .logo-track{gap:32px}
  .logo-track img{height:44px}
  .container{padding:0 16px}
  .formula-equation{gap:8px}
  .formula-pill{padding:6px 10px;font-size:12px}
  .rings-row-top,.rings-row-bottom{gap:8px}
  .rings-row-bottom{margin-top:-24px}
  .ring{width:120px;height:120px;padding:14px;border-width:3px}
  .ring-icon{font-size:18px;margin-bottom:2px}
  .ring h4{font-size:11px}
  .ring p{display:none}
}

/* FAQ (GEO) */
.faq-grid { max-width:800px; margin:0 auto; }
.faq-item { background:white; border-radius:var(--radius); padding:0; margin-bottom:12px; border:1px solid rgba(0,140,170,.06); overflow:hidden; transition:all .3s; }
.faq-item:hover { border-color:var(--blue-light); }
.faq-item summary { padding:20px 28px; font-family:var(--font-heading); font-size:17px; font-weight:700; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item[open] summary::after { transform:rotate(45deg); }
.faq-item p { padding:0 28px 20px; font-size:15px; color:var(--text-medium); line-height:1.7; }
.blog-article { max-width:720px; margin:0 auto; font-size:17px; line-height:1.8; }
.blog-article h2 { font-size:28px; margin:40px 0 16px; }
.blog-article h3 { font-size:22px; margin:32px 0 12px; }
.blog-article p { margin-bottom:20px; color:var(--text-medium); }
.blog-article strong { color:var(--text-dark); }
.blog-meta { font-size:14px; color:var(--text-light); font-weight:600; }
.blog-meta-bar { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.blog-reading-time { display:inline-flex; align-items:center; gap:4px; }

/* Blog author box */
.blog-author-box {
  display:flex; gap:20px; align-items:center; padding:28px;
  background:white; border-radius:var(--radius-lg); border:1px solid rgba(0,140,170,.08);
  box-shadow:0 2px 12px rgba(0,0,0,.03); max-width:720px; margin:48px auto 0;
}
.blog-author-photo { width:72px; height:72px; border-radius:50%; object-fit:cover; border:2px solid var(--blue-light); flex-shrink:0; }
.blog-author-avatar {
  width:72px; height:72px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--blue),var(--blue-vlight));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-heading); font-size:22px; font-weight:700; color:white;
}
.blog-author-info h4 { font-size:16px; margin-bottom:2px; }
.blog-author-info p { font-size:13px; color:var(--text-medium); line-height:1.5; margin-bottom:6px; }
.blog-author-linkedin {
  display:inline-flex; align-items:center; gap:5px;
  font-size:12px; font-weight:700; color:var(--blue); transition:color .3s;
}
.blog-author-linkedin:hover { color:var(--blue-dark); }
.blog-author-linkedin svg { width:14px; height:14px; fill:currentColor; }

/* Related articles */
.blog-related { max-width:720px; margin:48px auto 0; }
.blog-related h3 { font-size:20px; margin-bottom:20px; }
.blog-related-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.blog-related-card {
  background:white; border-radius:var(--radius); padding:24px;
  box-shadow:0 2px 12px rgba(0,0,0,.03); border:1px solid rgba(0,140,170,.04);
  transition:all .3s;
}
.blog-related-card:hover { transform:translateY(-3px); box-shadow:0 8px 28px rgba(0,140,170,.08); }
.blog-related-card .blog-tag { margin-bottom:8px; }
.blog-related-card h4 { font-size:15px; margin-bottom:8px; line-height:1.4; }
.blog-related-card p { font-size:13px; color:var(--text-medium); line-height:1.5; }

/* Blog CTA band */
.blog-cta {
  max-width:720px; margin:48px auto 0; padding:36px; text-align:center;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark)); border-radius:var(--radius-lg);
  color:white; position:relative; overflow:hidden;
}
.blog-cta::before { content:''; position:absolute; top:-30px;right:-30px; width:120px;height:120px; background:var(--orange); opacity:.12; border-radius:50%; }
.blog-cta h3 { font-size:22px; margin-bottom:8px; position:relative; z-index:1; }
.blog-cta p { font-size:15px; opacity:.85; margin-bottom:20px; position:relative; z-index:1; }
.blog-cta .btn { position:relative; z-index:1; }

/* Blog FAQ section */
.blog-faq { max-width:720px; margin:48px auto 0; }
.blog-faq h3 { font-size:20px; margin-bottom:20px; }

/* Logo images */
.nav-logo-img {
  height: 44px;
  width: 44px;
  object-fit: contain;
  border-radius: 6px;
  display: block;
}
.nav.scrolled .nav-logo-img {
  height: 38px;
  width: 38px;
}
.footer-logo-img {
  height: 56px;
  width: 56px;
  object-fit: contain;
  border-radius: 6px;
  margin-bottom: 12px;
}

/* Hero trainer fade carousel */
.hero-portrait.hero-fade {
  position: relative;
  width: 240px;
  height: 300px;
}
.hero-fade-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 16px;
  opacity: 0;
  animation: heroFade 36s infinite;
}
.hero-fade-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
}
.hero-fade-img:first-child {
  opacity: 1;
}
@keyframes heroFade {
  0%      { opacity: 0 }
  1.5%    { opacity: 1 }
  7%      { opacity: 1 }
  8.33%   { opacity: 0 }
  100%    { opacity: 0 }
}

/* ==========================================================================
   OPEN TRAINING BANNER (homepage)
   ========================================================================== */
.open-training-banner {
  background: linear-gradient(135deg, #FFF5EC 0%, #FFF0E0 50%, #FFEAD1 100%);
  position: relative;
  overflow: hidden;
  border-top: 3px solid var(--orange);
}
.open-training-banner .section-label::before { background: var(--orange); }
.open-training-banner-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.open-training-banner-text h2 {
  font-size: 36px;
  color: var(--text-dark);
  margin-bottom: 12px;
  letter-spacing: -0.5px;
}
.open-training-banner-text p {
  font-size: 17px;
  color: var(--text-medium);
  line-height: 1.8;
  margin-bottom: 8px;
}
.open-training-banner-text .b2b-note {
  font-size: 14px;
  color: var(--text-light);
  font-style: italic;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(242,140,56,.2);
}
.open-training-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.open-training-card {
  background: white;
  border-radius: var(--radius);
  padding: 24px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  box-shadow: 0 2px 16px rgba(242,140,56,.1);
  border: 1px solid rgba(242,140,56,.15);
  transition: all .3s;
}
.open-training-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(242,140,56,.18);
}
.open-training-card-info h4 {
  font-size: 18px;
  color: var(--text-dark);
  margin-bottom: 4px;
}
.open-training-card-info p {
  font-size: 14px;
  color: var(--text-medium);
  margin: 0;
}
.open-training-card .btn {
  white-space: nowrap;
  flex-shrink: 0;
}
@media(max-width:768px) {
  .open-training-banner-inner { grid-template-columns: 1fr; gap: 32px; }
  .open-training-banner-text h2 { font-size: 28px; }
  .open-training-card { flex-direction: column; align-items: flex-start; gap: 12px; }
  .open-training-card .btn { width: 100%; justify-content: center; }
}

/* ==========================================================================
   LEARNING JOURNEY TIMELINE
   ========================================================================== */
.journey-section {
  background: var(--white);
}
.journey-timeline {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  max-width: 900px;
  margin: 48px auto 0;
  padding-top: 40px;
}
.journey-line {
  position: absolute;
  top: 80px;
  left: 40px;
  right: 40px;
  height: 3px;
  background: var(--orange);
  z-index: 0;
}
.journey-step {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1;
  max-width: 200px;
}
.journey-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  border: 3px solid var(--blue);
  background: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  transition: background .3s;
}
.journey-step:hover .journey-icon {
  background: var(--blue-light);
}
.journey-label {
  font-family: var(--font-heading);
  font-size: 17px;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 8px;
}
.journey-desc {
  font-size: 14px;
  color: var(--text-medium);
  line-height: 1.6;
  max-width: 180px;
}
.journey-footnote {
  font-size: 13px;
  color: var(--text-medium);
  text-align: center;
  max-width: 720px;
  margin: 32px auto 0;
  line-height: 1.6;
  opacity: .7;
}
.journey-cycle {
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  height: 48px;
}
.journey-cycle-arrow {
  position: absolute;
  top: 0;
  left: 40px;
  right: 40px;
  height: 40px;
  border: 2px dashed var(--orange);
  border-top: none;
  border-radius: 0 0 20px 20px;
  opacity: .5;
}
.journey-cycle-arrow::after {
  content: '';
  position: absolute;
  left: -2px;
  top: -6px;
  width: 0;
  height: 0;
  border-right: 8px solid var(--orange);
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  opacity: 1;
}
.journey-cycle-label {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 12px;
  font-weight: 600;
  color: var(--orange);
  text-transform: uppercase;
  letter-spacing: 2px;
  background: var(--white);
  padding: 0 16px;
  white-space: nowrap;
}

/* Journey timeline — vertical on mobile */
@media(max-width:768px) {
  .journey-timeline {
    flex-direction: column;
    align-items: flex-start;
    padding-top: 0;
    padding-left: 40px;
    gap: 40px;
  }
  .journey-line {
    top: 0;
    bottom: 0;
    left: 40px;
    right: auto;
    width: 3px;
    height: auto;
  }
  .journey-step {
    flex-direction: row;
    text-align: left;
    max-width: 100%;
    gap: 20px;
  }
  .journey-icon {
    flex-shrink: 0;
    margin-bottom: 0;
  }
  .journey-label {
    margin-bottom: 4px;
  }
  .journey-desc {
    max-width: 100%;
  }
  .journey-cycle {
    display: none;
  }
  .journey-cycle-mobile {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 24px;
    padding: 12px 20px;
    border: 2px dashed var(--orange);
    border-radius: 12px;
    opacity: .6;
  }
  .journey-cycle-mobile .journey-cycle-label {
    position: static;
    transform: none;
    padding: 0;
    background: none;
  }
}
@media(min-width:769px) {
  .journey-cycle-mobile { display: none; }
}

/* ==========================================================================
   ROI CALCULATOR
   ========================================================================== */
.roi-section {
  background: linear-gradient(170deg, #0A2E3A 0%, var(--blue-dark) 100%);
  position: relative;
  overflow: hidden;
}
.roi-section .section-title { color: var(--white); }

.roi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* Sliders column */
.roi-sliders {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.roi-slider-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.roi-slider-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.roi-slider-label {
  color: rgba(255,255,255,0.85);
  font-size: 15px;
  font-weight: 500;
}
.roi-slider-value {
  color: var(--orange);
  font-weight: 700;
  font-size: 15px;
  font-family: var(--font-heading);
  min-width: 90px;
  text-align: right;
}

/* Custom range slider */
.roi-slider-group input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 3px;
  outline: none;
  cursor: pointer;
  background: linear-gradient(to right, var(--orange) 0%, var(--orange) var(--fill, 50%), rgba(255,255,255,0.2) var(--fill, 50%), rgba(255,255,255,0.2) 100%);
  transition: background 0.1s;
}
.roi-slider-group input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--orange);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  cursor: pointer;
  transition: transform 0.15s;
}
.roi-slider-group input[type="range"]::-webkit-slider-thumb:hover {
  transform: scale(1.15);
}
.roi-slider-group input[type="range"]::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--orange);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  cursor: pointer;
  transition: transform 0.15s;
}
.roi-slider-group input[type="range"]::-moz-range-thumb:hover {
  transform: scale(1.15);
}
.roi-slider-group input[type="range"]::-moz-range-track {
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.2);
}
.roi-slider-group input[type="range"]::-moz-range-progress {
  height: 6px;
  border-radius: 3px;
  background: var(--orange);
}

/* Output column */
.roi-output {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: 120px;
}
.roi-result-card {
  background: rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 28px 32px;
  text-align: center;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,0.08);
}
.roi-result-label {
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
  margin-bottom: 8px;
}
.roi-result-number {
  font-size: 48px;
  font-weight: 700;
  color: var(--orange);
  font-family: var(--font-heading);
  line-height: 1.1;
  transition: transform 0.2s, opacity 0.2s;
}
.roi-result-number.roi-animate {
  animation: roiPop 0.35s ease;
}
.roi-result-big {
  font-size: 64px;
}
.roi-result-highlight {
  background: rgba(242,140,56,0.15);
  border: 1px solid rgba(242,140,56,0.3);
}

@keyframes roiPop {
  0% { transform: scale(0.92); opacity: 0.6; }
  60% { transform: scale(1.04); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

.roi-disclaimer {
  text-align: center;
  font-size: 13px;
  color: rgba(255,255,255,0.5);
  margin-top: 32px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* ROI Calculator responsive */
@media (max-width: 768px) {
  .roi-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .roi-output {
    position: static;
  }
  .roi-result-number {
    font-size: 36px;
  }
  .roi-result-big {
    font-size: 48px;
  }
  .roi-result-card {
    padding: 20px 24px;
  }
}
