:root{
  --blue:#00a8ff;
  --blue2:#3fc3ff;
  --green:#8cc63f;
  --green2:#b9ff35;
  --bg:#020712;
  --white:#f5fbff;
  --text:#d8e6f5;
  --muted:#9fb0c4;
  --border:rgba(165,225,255,.16);
  --panel:rgba(5,15,30,.72);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--white);
  background:
    linear-gradient(180deg, rgba(2,7,16,.08), rgba(2,7,16,.76)),
    url("hydrex-premium-background.png") center top / cover fixed no-repeat;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(circle at 15% 22%, rgba(0,168,255,.16), transparent 30%),
    radial-gradient(circle at 86% 23%, rgba(140,198,63,.14), transparent 26%),
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
  background-size:auto, auto, 100px 100px, 100px 100px;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font:inherit}
.background-flow{
  position:fixed;
  inset:-12%;
  pointer-events:none;
  z-index:-2;
  background:
    radial-gradient(circle at 10% 52%, rgba(0,168,255,.24), transparent 18%),
    radial-gradient(circle at 90% 36%, rgba(140,198,63,.20), transparent 18%),
    radial-gradient(circle at 65% 80%, rgba(0,168,255,.12), transparent 22%);
  filter:blur(70px);
}
.site-wrap,.nav-shell{
  width:min(1220px, calc(100% - 44px));
  margin-inline:auto;
}
.nav-shell{
  position:sticky;
  top:16px;
  z-index:50;
  margin-top:22px;
  min-height:74px;
  display:flex;
  align-items:center;
  gap:28px;
  padding:10px 16px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(5,15,30,.82), rgba(5,15,30,.50));
  border:1px solid var(--border);
  box-shadow:0 28px 90px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px) saturate(145%);
}
.nav-logo{width:170px;flex:0 0 170px}
.nav-logo img{filter:brightness(1.08) contrast(1.08) drop-shadow(0 7px 20px rgba(0,0,0,.25))}
.nav-links{
  margin-left:auto;
  display:flex;
  gap:36px;
  align-items:center;
}
.nav-links a{
  font-weight:800;
  font-size:13px;
  color:#eaf6ff;
  position:relative;
}
.nav-links a.active,.nav-links a:hover{color:var(--green2)}
.nav-links a.active::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-21px;
  height:2px;
  background:var(--green);
  box-shadow:0 0 14px rgba(140,198,63,.55);
}
.nav-cta,.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 25px;
  border-radius:12px;
  text-transform:uppercase;
  font-weight:900;
  font-size:13px;
  letter-spacing:.03em;
}
.nav-cta,.btn-primary{
  color:#06111f;
  background:linear-gradient(135deg,var(--green2),var(--green));
  box-shadow:0 0 34px rgba(140,198,63,.34), inset 0 1px 0 rgba(255,255,255,.45);
}
.btn-secondary{
  color:#fff;
  border:1px solid rgba(184,225,255,.18);
  background:linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
}
.panel{
  background:
    linear-gradient(180deg, rgba(6,18,34,.78), rgba(6,18,34,.48)),
    linear-gradient(135deg, rgba(0,168,255,.09), rgba(140,198,63,.045));
  border:1px solid var(--border);
  box-shadow:0 28px 90px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px) saturate(145%);
}
.hero{
  min-height:610px;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:44px;
  align-items:center;
  padding:52px 0 28px;
}
.hero-left h1{
  margin:0 0 22px;
  font-size:clamp(56px, 6.5vw, 98px);
  line-height:.98;
  letter-spacing:-.058em;
  text-transform:uppercase;
}
.hero-left h1 span{display:block}
.green{color:var(--green2)}
.hero-text{
  color:#f0f6ff;
  font-size:18px;
  line-height:1.65;
  max-width:560px;
  margin:0 0 24px;
}
.hero-text strong:first-child{color:var(--blue2)}
.hero-text strong:last-child{color:var(--green2)}
.hero-buttons{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  margin-bottom:28px;
}
.trust-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  max-width:640px;
}
.trust-item{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:var(--text);
}
.trust-icon{
  font-size:28px;
  line-height:1;
}
.trust-icon.blue{color:var(--blue2)}
.trust-icon.green{color:var(--green2)}
.trust-item b{display:block;font-size:12px;color:#fff}
.trust-item small{display:block;color:var(--muted);font-size:11px;line-height:1.35}
.photo-stack{
  position:relative;
  min-height:520px;
}
.main-photo{
  position:absolute;
  left:8%;
  top:4%;
  width:48%;
  height:420px;
  border-radius:22px;
  overflow:hidden;
}
.main-photo img{width:100%;height:100%;object-fit:cover}
.mini-card{
  position:absolute;
  border-radius:16px;
  padding:20px;
  width:220px;
}
.mini-card h3{margin:8px 0 6px;font-size:16px}
.mini-card p{margin:0;color:var(--text);font-size:13px;line-height:1.45}
.mini-icon{
  width:46px;height:46px;border-radius:14px;
  display:grid;place-items:center;
  font-size:24px;
}
.mini-icon.green{color:var(--green2);background:rgba(140,198,63,.12)}
.mini-icon.blue{color:var(--blue2);background:rgba(0,168,255,.12)}
.garden{
  top:4%;
  right:5%;
  box-shadow:0 0 28px rgba(140,198,63,.16), 0 28px 90px rgba(0,0,0,.42);
}
.logo-card{
  right:11%;
  top:40%;
  width:210px;
  padding:18px;
  border-radius:18px;
}
.logo-card img{filter:brightness(1.08) contrast(1.08)}
.cleaning{
  right:0;
  bottom:4%;
  width:250px;
  box-shadow:0 0 28px rgba(0,168,255,.16), 0 28px 90px rgba(0,0,0,.42);
}
.section{
  padding:34px 0 22px;
}
.section-kicker{
  text-align:center;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--green2);
  font-weight:900;
  font-size:13px;
  margin-bottom:8px;
}
.section h2{
  text-align:center;
  font-size:32px;
  line-height:1.1;
  margin:0 0 26px;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.service-card{
  border-radius:18px;
  overflow:hidden;
}
.service-image{
  height:155px;
  overflow:hidden;
}
.service-image img{width:100%;height:100%;object-fit:cover}
.service-body{
  padding:20px;
  position:relative;
}
.service-icon{
  position:absolute;
  top:-35px;
  left:18px;
  width:58px;height:58px;border-radius:18px;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(6,18,34,.8);
  font-size:28px;
}
.service-icon.blue{color:var(--blue2);box-shadow:0 0 20px rgba(0,168,255,.15)}
.service-icon.green{color:var(--green2);box-shadow:0 0 20px rgba(140,198,63,.15)}
.service-body h3{
  margin:24px 0 10px;
  color:var(--blue2);
  text-transform:uppercase;
  font-size:18px;
  letter-spacing:.04em;
}
.green-card h3{color:var(--green2)}
.service-body p{
  color:var(--text);
  font-size:13px;
  line-height:1.6;
  margin:0 0 16px;
}
.service-body a{
  width:34px;height:34px;
  display:grid;place-items:center;
  border-radius:50%;
  margin-left:auto;
  color:var(--blue2);
  border:1px solid rgba(0,168,255,.35);
}
.fusion-panel{
  margin:42px 0;
  border-radius:18px;
  padding:30px;
  display:grid;
  grid-template-columns:.8fr 1.3fr .8fr;
  gap:28px;
  align-items:center;
}
.fusion-left span{
  text-transform:uppercase;
  color:#fff;
  font-weight:900;
  letter-spacing:.12em;
}
.fusion-left h2{
  font-size:64px;
  margin:8px 0 0;
  line-height:.85;
  letter-spacing:-.08em;
}
.fusion-left strong{
  color:var(--green2);
  letter-spacing:.36em;
}
.fusion-copy h3{font-size:24px;margin:0 0 10px}
.fusion-copy p{
  color:var(--text);
  line-height:1.7;
  margin:0 0 22px;
}
.fusion-features{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.fusion-features b{display:block;color:#fff;font-size:13px}
.fusion-features small{color:var(--muted);font-size:11px;line-height:1.35}
.fusion-logo{
  display:flex;
  justify-content:center;
}
.fusion-logo img{
  width:220px;
  filter:drop-shadow(0 0 28px rgba(0,168,255,.14)) drop-shadow(0 0 18px rgba(140,198,63,.12));
}
.results{
  padding-top:18px;
}
.compare-box{
  border-radius:18px;
  padding:8px;
  position:relative;
}
.compare-nav{
  position:absolute;
  right:18px;
  top:18px;
  z-index:8;
  display:flex;
  gap:10px;
}
.compare-nav button{
  width:38px;height:38px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(6,18,34,.75);
  color:#fff;
  cursor:pointer;
}
.compare{
  height:370px;
  position:relative;
  overflow:hidden;
  border-radius:14px;
}
.compare-base,.compare-after img{
  width:100%;height:100%;object-fit:cover;
}
.compare-after{
  position:absolute;
  inset:0 auto 0 0;
  width:56%;
  overflow:hidden;
}
.compare input{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  opacity:0;
  z-index:5;
  cursor:ew-resize;
}
.compare-handle{
  position:absolute;
  top:0;bottom:0;left:56%;
  width:3px;
  background:linear-gradient(180deg,#fff,var(--green));
  z-index:4;
}
.compare-handle span{
  position:absolute;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:54px;height:54px;
  border-radius:50%;
  display:grid;place-items:center;
  background:#06101d;
  border:2px solid var(--green);
  box-shadow:0 0 20px rgba(140,198,63,.35);
}
.tag,.compare-count{
  position:absolute;
  z-index:4;
  padding:9px 14px;
  border-radius:8px;
  text-transform:uppercase;
  font-weight:900;
  font-size:12px;
  background:rgba(6,18,34,.75);
}
.tag.before{left:14px;top:14px}
.tag.after{right:14px;top:14px;color:#07111d;background:linear-gradient(135deg,var(--green2),var(--green))}
.compare-count{left:50%;bottom:14px;transform:translateX(-50%)}
.result-points{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  padding:18px 22px 14px;
  color:var(--text);
  font-size:13px;
}
.contact-panel{
  margin:42px 0 42px;
  border-radius:20px;
  padding:34px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:28px;
  align-items:center;
}
.phone-badge{
  width:92px;height:92px;
  border-radius:50%;
  display:grid;place-items:center;
  font-size:38px;
  color:var(--blue2);
  border:1px solid rgba(0,168,255,.35);
  box-shadow:0 0 28px rgba(0,168,255,.2);
}
.contact-panel h2{
  font-size:34px;
  margin:0 0 8px;
}
.contact-panel p{
  margin:0 0 16px;
  color:var(--text);
}
.mini-checks{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  color:var(--text);
  font-size:13px;
}
.contact-cta{
  display:grid;
  gap:14px;
}
.contact-details{
  display:flex;
  gap:20px;
  color:var(--text);
  font-size:14px;
}
@media(max-width:1060px){
  .hero{grid-template-columns:1fr}
  .photo-stack{min-height:500px}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .fusion-panel,.contact-panel{grid-template-columns:1fr}
  .fusion-features,.result-points{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  body{background-attachment:scroll}
  .site-wrap,.nav-shell{width:min(100% - 24px,1220px)}
  .nav-links{display:none}
  .nav-logo{width:142px;flex-basis:142px}
  .nav-cta{padding:0 16px;font-size:11px}
  .hero-left h1{font-size:42px}
  .trust-row,.service-grid,.fusion-features,.result-points{grid-template-columns:1fr}
  .main-photo{left:4%;right:4%;width:auto;height:300px}
  .garden{top:0;right:0;width:180px}
  .logo-card{right:6%;top:44%;width:170px}
  .cleaning{right:0;bottom:0;width:210px}
  .compare{height:280px}
  .contact-panel{padding:24px}
}



/* ===== v30 architectural premium background ===== */

body.v30-arch-bg{
  background:
    linear-gradient(90deg, rgba(2,7,16,.76) 0%, rgba(2,7,16,.48) 38%, rgba(2,7,16,.30) 62%, rgba(2,7,16,.62) 100%),
    linear-gradient(180deg, rgba(2,7,16,.10) 0%, rgba(2,7,16,.42) 54%, rgba(2,7,16,.82) 100%),
    url("hydrex-v30-background.png") center top / cover fixed no-repeat !important;
}

/* Make the new image feel like a real premium website background */
body.v30-arch-bg::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(circle at 16% 18%, rgba(0,168,255,.13), transparent 28%),
    radial-gradient(circle at 82% 24%, rgba(140,198,63,.13), transparent 26%),
    radial-gradient(circle at 54% 72%, rgba(0,168,255,.08), transparent 32%),
    linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:auto, auto, auto, 110px 110px, 110px 110px;
  opacity:1;
}

/* Reduce the old abstract glow so the architectural background is the star */
.background-flow{
  opacity:.44 !important;
  filter:blur(85px) !important;
  background:
    radial-gradient(circle at 11% 46%, rgba(0,168,255,.18), transparent 20%),
    radial-gradient(circle at 84% 35%, rgba(140,198,63,.16), transparent 18%),
    radial-gradient(circle at 70% 82%, rgba(0,168,255,.09), transparent 24%) !important;
}

/* Darker glass so text stays readable on the new photo background */
.panel,
.nav-shell{
  background:
    linear-gradient(180deg, rgba(4,12,24,.82), rgba(4,12,24,.56)),
    linear-gradient(135deg, rgba(0,168,255,.10), rgba(140,198,63,.045)) !important;
  border:1px solid rgba(190,232,255,.17) !important;
  box-shadow:
    0 30px 100px rgba(0,0,0,.48),
    inset 0 1px 0 rgba(255,255,255,.08),
    0 0 28px rgba(0,168,255,.035),
    0 0 24px rgba(140,198,63,.025) !important;
  backdrop-filter:blur(18px) saturate(145%) !important;
}

/* Hero: align with the new mockup feel */
.hero{
  padding-top:46px !important;
  min-height:620px !important;
}

.hero-left h1{
  text-shadow:0 12px 34px rgba(0,0,0,.32);
}

.hero-left h1 span:nth-child(2){
  color:#3c9fff;
}

.hero-left h1 span.green{
  color:var(--green2);
}

.hero-text{
  text-shadow:0 8px 24px rgba(0,0,0,.34);
}

/* Add subtle premium shine on topbar and cards */
.nav-shell,
.service-card,
.fusion-panel,
.compare-box,
.contact-panel{
  position:relative;
  overflow:hidden;
}

.nav-shell::after,
.service-card::after,
.fusion-panel::after,
.compare-box::after,
.contact-panel::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(255,255,255,.10), transparent 24%, transparent 74%, rgba(255,255,255,.035));
  opacity:.52;
}

/* Make services cards slightly more premium over the architecture background */
.service-card{
  transform:translateZ(0);
}
.service-card:hover{
  transform:translateY(-5px);
  box-shadow:
    0 36px 110px rgba(0,0,0,.52),
    0 0 30px rgba(0,168,255,.08),
    0 0 24px rgba(140,198,63,.07) !important;
}

/* Strong CTA pop */
.nav-cta,
.btn-primary{
  box-shadow:
    0 0 34px rgba(140,198,63,.32),
    0 12px 32px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.45) !important;
}

/* Keep background good on mobile */
@media(max-width:760px){
  body.v30-arch-bg{
    background:
      linear-gradient(180deg, rgba(2,7,16,.30), rgba(2,7,16,.82)),
      url("hydrex-v30-background.png") center top / cover no-repeat !important;
  }
}




/* ===== v31 motion background + hero cleanup ===== */

.bg-parallax{
  --bgx: 0px;
  --bgy: 0px;
  --bgscroll: 0px;
  position: fixed;
  inset: -5%;
  z-index: -4;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(2,7,16,.70) 0%, rgba(2,7,16,.44) 38%, rgba(2,7,16,.26) 62%, rgba(2,7,16,.58) 100%),
    linear-gradient(180deg, rgba(2,7,16,.06) 0%, rgba(2,7,16,.36) 54%, rgba(2,7,16,.74) 100%),
    url("hydrex-v30-background.png") center center / cover no-repeat;
  transform: translate3d(var(--bgx), calc(var(--bgy) + var(--bgscroll)), 0) scale(1.09);
  transform-origin: center;
  will-change: transform;
  animation: hydrexBgFloat 20s ease-in-out infinite alternate;
  filter: saturate(1.05) contrast(1.04);
}

/* Keep body itself darker/cleaner while the image moves underneath */
body.v30-arch-bg{
  background:
    linear-gradient(180deg, rgba(2,7,16,.12), rgba(2,7,16,.80)) !important;
}

@keyframes hydrexBgFloat{
  0%{
    transform: translate3d(var(--bgx), calc(var(--bgy) + var(--bgscroll)), 0) scale(1.09);
  }
  100%{
    transform: translate3d(calc(var(--bgx) + 10px), calc(var(--bgy) + var(--bgscroll) - 8px), 0) scale(1.12);
  }
}

/* Make the headline safer and fully visible */
.hero{
  grid-template-columns: minmax(0, 1.02fr) minmax(0, .98fr) !important;
  gap: 30px !important;
}
.hero-left{
  min-width: 0 !important;
}
.hero-left h1{
  font-size: clamp(48px, 5.6vw, 86px) !important;
  line-height: .94 !important;
  letter-spacing: -.05em !important;
  max-width: 760px !important;
  margin-bottom: 18px !important;
}
.hero-left h1 span{
  display: block !important;
  white-space: nowrap !important;
}
.hero-left h1 .hero-betrouwbaar{
  color: #ffffff !important;
  text-shadow:
    0 0 12px rgba(60,159,255,.18),
    0 10px 28px rgba(0,0,0,.30);
}

/* Clean the right side now that the clutter is gone */
.photo-stack{
  min-height: 500px !important;
}
.main-photo{
  left: 10% !important;
  top: 7% !important;
  width: 62% !important;
  height: 430px !important;
  border-radius: 24px !important;
}
.cleaning{
  right: 2% !important;
  bottom: 7% !important;
  width: 255px !important;
}

/* Slightly reduce old glows so it feels more professional */
.background-flow{
  opacity: .34 !important;
  filter: blur(75px) !important;
}

@media (max-width: 1100px){
  .hero{
    grid-template-columns: 1fr !important;
  }
  .hero-left h1{
    font-size: clamp(44px, 7.2vw, 74px) !important;
  }
  .hero-left h1 span{
    white-space: normal !important;
  }
  .photo-stack{
    min-height: 460px !important;
  }
  .main-photo{
    width: 68% !important;
    left: 8% !important;
  }
}

@media (max-width: 760px){
  .bg-parallax{
    animation-duration: 26s;
    inset: -8%;
    transform: translate3d(0, 0, 0) scale(1.08);
  }
  .hero-left h1{
    font-size: clamp(38px, 10vw, 58px) !important;
    line-height: .98 !important;
  }
  .main-photo{
    left: 4% !important;
    right: auto !important;
    width: calc(100% - 110px) !important;
    height: 290px !important;
  }
  .cleaning{
    width: 210px !important;
    right: 0 !important;
    bottom: 0 !important;
  }
}




/* ===== v32 REAL animated background ===== */

/* De achtergrond beweegt nu echt: langzaam pannen, zoomen en meebewegen */
.bg-parallax{
  animation:
    hydrexRealBgDrift 34s ease-in-out infinite alternate,
    hydrexRealBgPulse 12s ease-in-out infinite !important;
  transform-origin:center center !important;
}

/* Moving light ribbons over the image */
.bg-light-sweep{
  position:fixed;
  inset:-18%;
  z-index:-3;
  pointer-events:none;
  background:
    linear-gradient(115deg, transparent 0%, transparent 36%, rgba(0,168,255,.10) 42%, rgba(255,255,255,.06) 46%, rgba(140,198,63,.10) 50%, transparent 58%, transparent 100%),
    radial-gradient(circle at 72% 40%, rgba(140,198,63,.12), transparent 20%),
    radial-gradient(circle at 28% 66%, rgba(0,168,255,.10), transparent 24%);
  filter:blur(20px) saturate(135%);
  opacity:.72;
  mix-blend-mode:screen;
  animation: hydrexLightSweep 18s ease-in-out infinite alternate;
}

/* Subtle moving clean-water particles */
.bg-particles{
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:
    radial-gradient(circle, rgba(255,255,255,.22) 0 1px, transparent 2px),
    radial-gradient(circle, rgba(0,168,255,.20) 0 1px, transparent 2px),
    radial-gradient(circle, rgba(140,198,63,.18) 0 1px, transparent 2px);
  background-size: 180px 180px, 260px 260px, 340px 340px;
  background-position: 0 0, 80px 120px, 160px 60px;
  opacity:.16;
  filter:blur(.2px);
  animation: hydrexParticlesMove 28s linear infinite;
}

/* Stronger real movement than v31 */
@keyframes hydrexRealBgDrift{
  0%{
    transform:translate3d(calc(var(--bgx, 0px) - 26px), calc(var(--bgy, 0px) + var(--bgscroll, 0px) - 10px), 0) scale(1.11);
  }
  25%{
    transform:translate3d(calc(var(--bgx, 0px) + 12px), calc(var(--bgy, 0px) + var(--bgscroll, 0px) - 28px), 0) scale(1.14);
  }
  50%{
    transform:translate3d(calc(var(--bgx, 0px) + 30px), calc(var(--bgy, 0px) + var(--bgscroll, 0px) + 8px), 0) scale(1.16);
  }
  75%{
    transform:translate3d(calc(var(--bgx, 0px) - 6px), calc(var(--bgy, 0px) + var(--bgscroll, 0px) + 24px), 0) scale(1.13);
  }
  100%{
    transform:translate3d(calc(var(--bgx, 0px) - 30px), calc(var(--bgy, 0px) + var(--bgscroll, 0px) - 4px), 0) scale(1.15);
  }
}

@keyframes hydrexRealBgPulse{
  0%,100%{filter:saturate(1.04) contrast(1.04) brightness(.96)}
  50%{filter:saturate(1.14) contrast(1.08) brightness(1.02)}
}

@keyframes hydrexLightSweep{
  0%{
    transform:translate3d(-5%, 3%, 0) rotate(-2deg) scale(1.02);
    opacity:.45;
  }
  50%{
    transform:translate3d(4%, -4%, 0) rotate(2deg) scale(1.08);
    opacity:.82;
  }
  100%{
    transform:translate3d(8%, 2%, 0) rotate(-1deg) scale(1.05);
    opacity:.58;
  }
}

@keyframes hydrexParticlesMove{
  0%{background-position:0 0, 80px 120px, 160px 60px}
  100%{background-position:360px -260px, -220px 420px, 520px 300px}
}

/* Make foreground feel separated from moving background */
.nav-shell,
.panel{
  backdrop-filter:blur(20px) saturate(150%) !important;
}

/* Accessibility: reduce motion when the user/browser requests it */
@media (prefers-reduced-motion: reduce){
  .bg-parallax,
  .bg-light-sweep,
  .bg-particles{
    animation:none !important;
  }
}

@media(max-width:760px){
  .bg-parallax{
    animation: hydrexRealBgDriftMobile 32s ease-in-out infinite alternate !important;
  }
  .bg-light-sweep{
    opacity:.48;
    filter:blur(24px);
  }
  .bg-particles{
    opacity:.10;
  }
}

@keyframes hydrexRealBgDriftMobile{
  0%{transform:translate3d(-14px, -8px, 0) scale(1.10)}
  50%{transform:translate3d(18px, 10px, 0) scale(1.14)}
  100%{transform:translate3d(-8px, 18px, 0) scale(1.12)}
}




/* ===== v37 smaller navbar + hero slideshow ===== */

/* Smaller, cleaner navbar */
.nav-shell{
  min-height: 60px !important;
  margin-top: 16px !important;
  padding: 8px 14px !important;
  gap: 18px !important;
  border-radius: 18px !important;
}
.nav-logo{
  width: 148px !important;
  flex-basis: 148px !important;
}
.nav-links{
  gap: 26px !important;
}
.nav-links a{
  font-size: 12px !important;
}
.nav-links a.active::after{
  bottom: -16px !important;
}
.nav-cta{
  min-height: 42px !important;
  padding: 0 18px !important;
  font-size: 11px !important;
  border-radius: 11px !important;
}

/* Hero slideshow */
.hero{
  grid-template-columns: minmax(0, 1fr) minmax(0, .95fr) !important;
  align-items: center !important;
}

.hero-showcase{
  min-height: 510px !important;
  position: relative;
}

.hero-slideshow{
  position: absolute;
  inset: 24px 24px 68px 24px;
  border-radius: 24px;
  overflow: hidden;
  box-shadow:
    0 30px 100px rgba(0,0,0,.50),
    inset 0 1px 0 rgba(255,255,255,.08),
    0 0 20px rgba(0,168,255,.06);
}

.hero-slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateX(8%);
  transition: opacity .7s ease, transform .8s ease;
}
.hero-slide.active{
  opacity: 1;
  transform: translateX(0);
}
.hero-slide::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(4,10,18,.12), rgba(4,10,18,.36)),
    linear-gradient(90deg, rgba(4,10,18,.40) 0%, rgba(4,10,18,.10) 45%, rgba(4,10,18,.32) 100%);
}
.hero-slide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-slide-overlay{
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 24px;
  z-index: 3;
  max-width: 420px;
}
.hero-slide-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  text-transform: uppercase;
  font-size: 10px;
  letter-spacing: .12em;
  font-weight: 900;
  color:#fff;
  background: rgba(6,18,34,.54);
  border:1px solid rgba(255,255,255,.12);
  margin-bottom: 12px;
}
.hero-slide-kicker::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background: var(--blue2);
  box-shadow: 0 0 10px rgba(0,168,255,.7);
}
.hero-slideshow h3{
  margin:0 0 8px;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -.04em;
}
.hero-slideshow p{
  margin:0;
  color:#e5f0fb;
  font-size: 14px;
  line-height: 1.6;
  max-width: 360px;
}

.hero-slide-dots{
  position:absolute;
  top: 18px;
  right: 18px;
  z-index: 4;
  display:flex;
  gap:8px;
}
.hero-slide-dots button{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  padding: 0;
  border: 0;
  background: rgba(255,255,255,.32);
  cursor: pointer;
  transition: all .25s ease;
}
.hero-slide-dots button.active{
  width: 28px;
  background: linear-gradient(90deg, var(--blue2), var(--green2));
  box-shadow: 0 0 12px rgba(0,168,255,.28);
}

.hero-floating-badge{
  position: absolute;
  right: -2px;
  bottom: 8px;
  width: 250px;
  padding: 18px 18px 18px 16px;
  border-radius: 18px;
  display:flex;
  align-items:flex-start;
  gap:12px;
  z-index: 5;
  transition: transform .5s ease, box-shadow .4s ease, border-color .4s ease, background .4s ease;
}
.hero-floating-badge .badge-icon{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  flex: 0 0 42px;
  font-size: 22px;
  color: var(--blue2);
  background: rgba(0,168,255,.12);
  box-shadow: 0 0 14px rgba(0,168,255,.16);
  transition: all .4s ease;
}
.hero-floating-badge strong{
  display:block;
  font-size: 15px;
  margin-bottom: 4px;
}
.hero-floating-badge p{
  margin:0;
  color: var(--text);
  font-size: 12px;
  line-height: 1.5;
}
.hero-floating-badge.green{
  background:
    linear-gradient(180deg, rgba(7,22,20,.88), rgba(7,22,20,.60)),
    linear-gradient(135deg, rgba(140,198,63,.09), rgba(140,198,63,.03)) !important;
  border-color: rgba(190,255,175,.16) !important;
  box-shadow:
    0 24px 80px rgba(0,0,0,.48),
    inset 0 1px 0 rgba(255,255,255,.06),
    0 0 20px rgba(140,198,63,.08) !important;
}
.hero-floating-badge.green .badge-icon{
  color: var(--green2);
  background: rgba(140,198,63,.12);
  box-shadow: 0 0 14px rgba(140,198,63,.18);
}

.hero-slideshow.green-mode .hero-slide-kicker::before{
  background: var(--green2);
  box-shadow: 0 0 10px rgba(140,198,63,.7);
}
.hero-slideshow.green-mode .hero-slideshow h3,
.hero-slideshow.green-mode h3{
  color: var(--green2);
}

@media (max-width: 980px){
  .hero{
    grid-template-columns: 1fr !important;
  }
  .hero-showcase{
    min-height: 450px !important;
  }
  .hero-floating-badge{
    right: 8px;
    bottom: 6px;
  }
}
@media (max-width: 760px){
  .nav-shell{
    min-height: 54px !important;
    padding: 7px 11px !important;
  }
  .nav-logo{
    width: 132px !important;
    flex-basis: 132px !important;
  }
  .nav-cta{
    min-height: 38px !important;
    padding: 0 14px !important;
    font-size: 10px !important;
  }
  .hero-showcase{
    min-height: 395px !important;
  }
  .hero-slideshow{
    inset: 10px 0 60px 0;
    border-radius: 18px;
  }
  .hero-slide-overlay{
    left: 16px;
    right: 16px;
    bottom: 16px;
  }
  .hero-slideshow h3{
    font-size: 26px;
  }
  .hero-floating-badge{
    width: 210px;
    padding: 14px;
    border-radius: 16px;
  }
}




/* ===== v38 even smaller / cleaner navbar ===== */
.nav-shell{
  min-height: 54px !important;
  margin-top: 12px !important;
  padding: 6px 12px !important;
  gap: 14px !important;
  border-radius: 16px !important;
}

.nav-logo{
  width: 126px !important;
  flex-basis: 126px !important;
}

.nav-links{
  gap: 22px !important;
}

.nav-links a{
  font-size: 11px !important;
}

.nav-links a.active::after{
  bottom: -14px !important;
  height: 2px !important;
}

.nav-cta{
  min-height: 36px !important;
  padding: 0 15px !important;
  font-size: 10px !important;
  border-radius: 10px !important;
}

@media (max-width: 760px){
  .nav-shell{
    min-height: 48px !important;
    padding: 6px 10px !important;
    gap: 10px !important;
  }

  .nav-logo{
    width: 116px !important;
    flex-basis: 116px !important;
  }

  .nav-cta{
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 9px !important;
  }
}



/* ===== v39 no-rain cleanup ===== */
/* Regen-effecten bewust verwijderd. Alleen premium motion background blijft actief. */



/* ===== v40 commercial sections ===== */

.trust-bar{
  margin: -12px 0 28px;
  padding: 18px 22px;
  border-radius: 18px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.trust-bar div{
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.06);
}

.trust-bar strong{
  display:block;
  font-size:14px;
  color:#fff;
  margin-bottom:4px;
}

.trust-bar span{
  display:block;
  color:var(--muted);
  font-size:12px;
}

.why-grid,
.process-grid,
.review-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:18px;
}

.review-grid{
  grid-template-columns: repeat(3, 1fr);
}

.why-card,
.process-step,
.review-card{
  border-radius:18px;
  padding:24px;
  position:relative;
  overflow:hidden;
}

.why-icon{
  width:52px;
  height:52px;
  display:grid;
  place-items:center;
  border-radius:16px;
  margin-bottom:18px;
  font-size:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
}

.why-icon.blue{color:var(--blue2);box-shadow:0 0 18px rgba(0,168,255,.10)}
.why-icon.green{color:var(--green2);box-shadow:0 0 18px rgba(140,198,63,.10)}

.why-card h3,
.process-step h3{
  margin:0 0 10px;
  font-size:18px;
}

.why-card p,
.process-step p,
.review-card p{
  margin:0;
  color:var(--text);
  font-size:14px;
  line-height:1.65;
}

.process-step span{
  display:inline-flex;
  min-height:34px;
  padding:0 12px;
  align-items:center;
  border-radius:999px;
  margin-bottom:18px;
  color:#07111d;
  background:linear-gradient(135deg,var(--green2),var(--green));
  font-weight:900;
  font-size:12px;
}

.stars{
  color:var(--green2);
  letter-spacing:.08em;
  margin-bottom:14px;
  text-shadow:0 0 14px rgba(140,198,63,.25);
}

.review-card strong{
  display:block;
  margin-top:16px;
  color:#fff;
}

.faq-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:16px;
}

.faq-item{
  border-radius:16px;
  padding:0;
  overflow:hidden;
}

.faq-item summary{
  cursor:pointer;
  list-style:none;
  padding:20px 22px;
  color:#fff;
  font-weight:800;
}

.faq-item summary::-webkit-details-marker{display:none}

.faq-item summary::after{
  content:"+";
  float:right;
  color:var(--green2);
  font-size:20px;
}

.faq-item[open] summary::after{
  content:"–";
}

.faq-item p{
  margin:0;
  padding:0 22px 20px;
  color:var(--text);
  line-height:1.65;
  font-size:14px;
}

.quote-panel{
  border-radius:22px;
  padding:34px;
  display:grid;
  grid-template-columns: .85fr 1.15fr;
  gap:34px;
  align-items:start;
}

.section-kicker.left{
  display:block;
  text-align:left;
}

.quote-copy h2{
  text-align:left;
  margin:10px 0 14px;
  font-size:42px;
  line-height:1;
}

.quote-copy p{
  color:var(--text);
  line-height:1.7;
  margin:0 0 22px;
}

.quote-benefits{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.quote-benefits span{
  padding:10px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:var(--text);
  font-size:13px;
}

.quote-form{
  display:grid;
  gap:14px;
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.quote-form label{
  display:grid;
  gap:8px;
  color:#fff;
  font-size:13px;
  font-weight:800;
}

.quote-form input,
.quote-form select,
.quote-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(4,12,24,.64);
  color:#fff;
  border-radius:12px;
  min-height:46px;
  padding:12px 14px;
  font:inherit;
  outline:none;
}

.quote-form textarea{
  resize:vertical;
}

.quote-form input::placeholder,
.quote-form textarea::placeholder{
  color:rgba(220,235,255,.52);
}

.quote-form input:focus,
.quote-form select:focus,
.quote-form textarea:focus{
  border-color:rgba(140,198,63,.45);
  box-shadow:0 0 0 3px rgba(140,198,63,.08);
}

.quote-form button{
  border:none;
  cursor:pointer;
  justify-self:start;
}

@media(max-width:1060px){
  .trust-bar,
  .why-grid,
  .process-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .quote-panel{
    grid-template-columns:1fr;
  }
}

@media(max-width:760px){
  .trust-bar,
  .why-grid,
  .process-grid,
  .review-grid,
  .faq-grid,
  .form-row{
    grid-template-columns:1fr;
  }

  .trust-bar{
    margin-top:0;
    padding:14px;
  }

  .quote-panel{
    padding:22px;
  }

  .quote-copy h2{
    font-size:32px;
  }

  .quote-form button{
    width:100%;
  }
}




/* ===== v41 hover glow for cards / bars ===== */

.panel,
.service-card,
.why-card,
.process-step,
.review-card,
.faq-item,
.trust-bar div,
.contact-panel,
.quote-panel,
.hero-floating-badge,
.compare-box,
.fusion-panel,
.service-body a,
.nav-shell{
  transition:
    transform .28s ease,
    box-shadow .32s ease,
    border-color .28s ease,
    background .28s ease,
    filter .28s ease;
}

@media (hover: hover) {
  .service-card:hover,
  .why-card:hover,
  .process-step:hover,
  .review-card:hover,
  .faq-item:hover,
  .trust-bar div:hover,
  .contact-panel:hover,
  .quote-panel:hover,
  .compare-box:hover,
  .fusion-panel:hover,
  .hero-floating-badge:hover{
    transform: translateY(-4px);
    border-color: rgba(180, 240, 255, .22) !important;
    box-shadow:
      0 34px 110px rgba(0,0,0,.46),
      0 0 0 1px rgba(255,255,255,.04),
      0 0 22px rgba(0,168,255,.11),
      0 0 34px rgba(140,198,63,.10),
      inset 0 1px 0 rgba(255,255,255,.09) !important;
    filter: saturate(1.04);
  }

  .service-card:hover .service-icon.blue,
  .why-card:hover .why-icon.blue,
  .hero-floating-badge:hover .badge-icon{
    box-shadow:
      0 0 18px rgba(0,168,255,.24),
      0 0 30px rgba(0,168,255,.12) !important;
  }

  .green-card:hover .service-icon.green,
  .why-card:hover .why-icon.green,
  .hero-floating-badge.green:hover .badge-icon{
    box-shadow:
      0 0 18px rgba(140,198,63,.24),
      0 0 30px rgba(140,198,63,.12) !important;
  }

  .faq-item:hover summary,
  .review-card:hover strong,
  .why-card:hover h3,
  .process-step:hover h3{
    color: #ffffff;
    text-shadow: 0 0 12px rgba(0,168,255,.10);
  }

  .service-card:hover .service-body a{
    transform: translateX(2px);
    border-color: rgba(140,198,63,.45);
    box-shadow:
      0 0 14px rgba(140,198,63,.16),
      0 0 20px rgba(0,168,255,.10);
    color: var(--green2);
  }

  .trust-bar div:hover{
    background:
      linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)),
      linear-gradient(135deg, rgba(0,168,255,.06), rgba(140,198,63,.04));
  }

  .nav-shell:hover{
    box-shadow:
      0 28px 90px rgba(0,0,0,.42),
      0 0 18px rgba(0,168,255,.07),
      0 0 26px rgba(140,198,63,.05),
      inset 0 1px 0 rgba(255,255,255,.08) !important;
  }
}




/* ===== v42 cleanup: no fusion/reviews + footer + quote glow ===== */

.site-footer{
  width:min(1220px, calc(100% - 44px));
  margin: 0 auto 34px;
  padding: 18px 22px;
  border-radius: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.footer-brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.footer-brand img{
  width:116px;
  height:auto;
  display:block;
  filter:brightness(1.08) contrast(1.08);
}

.footer-brand strong{
  display:block;
  color:#fff;
  font-size:15px;
  letter-spacing:.03em;
}

.footer-brand span{
  display:block;
  color:var(--muted);
  font-size:12px;
}

.footer-meta{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:18px;
  color:var(--text);
  font-size:13px;
}

.footer-meta a{
  color:inherit;
}

/* extra glow on quote request bars / fields */
.quote-benefits span,
.quote-form input,
.quote-form select,
.quote-form textarea,
.quote-form .btn-primary{
  transition:
    transform .24s ease,
    box-shadow .28s ease,
    border-color .24s ease,
    background .24s ease,
    filter .24s ease;
}

@media (hover: hover){
  .quote-benefits span:hover{
    transform: translateY(-2px);
    border-color: rgba(180,240,255,.18);
    box-shadow:
      0 0 18px rgba(0,168,255,.12),
      0 0 24px rgba(140,198,63,.10),
      inset 0 1px 0 rgba(255,255,255,.06);
    background:
      linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.03)),
      linear-gradient(135deg, rgba(0,168,255,.05), rgba(140,198,63,.04));
  }

  .quote-form input:hover,
  .quote-form select:hover,
  .quote-form textarea:hover{
    border-color: rgba(160,232,255,.20);
    box-shadow:
      0 0 16px rgba(0,168,255,.10),
      0 0 22px rgba(140,198,63,.08),
      inset 0 1px 0 rgba(255,255,255,.03);
  }

  .quote-form .btn-primary:hover{
    transform: translateY(-2px);
    box-shadow:
      0 0 26px rgba(140,198,63,.22),
      0 0 18px rgba(0,168,255,.10),
      0 14px 32px rgba(0,0,0,.22),
      inset 0 1px 0 rgba(255,255,255,.45) !important;
  }
}

@media(max-width:760px){
  .site-footer{
    width:min(100% - 24px, 1220px);
    padding:16px;
    flex-direction:column;
    align-items:flex-start;
  }

  .footer-brand img{
    width:100px;
  }

  .footer-meta{
    justify-content:flex-start;
    gap:10px 14px;
    font-size:12px;
  }
}




/* ===== v43 conversion addons: combos, promise, sticky actions ===== */

.combo-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.combo-card{
  border-radius:18px;
  padding:24px;
  position:relative;
  overflow:hidden;
}

.combo-tag{
  display:inline-flex;
  min-height:30px;
  align-items:center;
  padding:0 11px;
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:18px;
  border:1px solid rgba(255,255,255,.10);
}

.combo-tag.blue{
  color:var(--blue2);
  background:rgba(0,168,255,.09);
}

.combo-tag.green{
  color:var(--green2);
  background:rgba(140,198,63,.10);
}

.combo-card h3{
  margin:0 0 10px;
  font-size:20px;
  line-height:1.15;
}

.combo-card p{
  color:var(--text);
  margin:0 0 18px;
  font-size:14px;
  line-height:1.65;
}

.combo-card a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--green2);
  text-transform:uppercase;
  font-size:12px;
  font-weight:900;
  letter-spacing:.05em;
}

.promise-panel{
  border-radius:22px;
  padding:34px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
  align-items:center;
}

.promise-copy h2{
  text-align:left;
  margin:10px 0 14px;
  font-size:40px;
  line-height:1;
  letter-spacing:-.045em;
}

.promise-copy p{
  color:var(--text);
  line-height:1.75;
  margin:0;
  max-width:620px;
}

.promise-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.promise-list div{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px;
  border-radius:16px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}

.promise-list span{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  flex:0 0 34px;
  border-radius:50%;
  color:#07111d;
  background:linear-gradient(135deg,var(--green2),var(--green));
  font-weight:900;
}

.promise-list strong{
  font-size:14px;
}

.upload-field input{
  padding:12px;
}

.upload-field span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:500;
  margin-top:-2px;
}

.sticky-actions{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:90;
  display:grid;
  gap:10px;
}

.sticky-actions a{
  min-width:142px;
  padding:12px 16px;
  border-radius:16px;
  display:flex;
  flex-direction:column;
  gap:2px;
  border:1px solid rgba(255,255,255,.14);
  background:
    linear-gradient(180deg, rgba(4,12,24,.84), rgba(4,12,24,.60)),
    linear-gradient(135deg, rgba(0,168,255,.10), rgba(140,198,63,.045));
  box-shadow:
    0 18px 50px rgba(0,0,0,.36),
    0 0 16px rgba(0,168,255,.08),
    0 0 22px rgba(140,198,63,.06);
  backdrop-filter:blur(16px) saturate(140%);
  transition:transform .24s ease, box-shadow .28s ease, border-color .24s ease;
}

.sticky-actions span{
  color:var(--muted);
  font-size:11px;
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.08em;
}

.sticky-actions strong{
  color:#fff;
  font-size:14px;
}

.sticky-whatsapp strong{
  color:var(--green2);
}

.sticky-offerte strong{
  color:var(--blue2);
}

@media(hover:hover){
  .combo-card:hover,
  .promise-list div:hover{
    transform:translateY(-4px);
    border-color:rgba(180,240,255,.22) !important;
    box-shadow:
      0 34px 110px rgba(0,0,0,.46),
      0 0 22px rgba(0,168,255,.10),
      0 0 34px rgba(140,198,63,.09),
      inset 0 1px 0 rgba(255,255,255,.08) !important;
  }

  .sticky-actions a:hover{
    transform:translateY(-3px);
    border-color:rgba(180,240,255,.24);
    box-shadow:
      0 24px 70px rgba(0,0,0,.42),
      0 0 24px rgba(0,168,255,.13),
      0 0 32px rgba(140,198,63,.12);
  }
}

@media(max-width:1060px){
  .combo-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .promise-panel{
    grid-template-columns:1fr;
  }
}

@media(max-width:760px){
  .combo-grid,
  .promise-list{
    grid-template-columns:1fr;
  }

  .promise-panel{
    padding:22px;
  }

  .promise-copy h2{
    font-size:30px;
  }

  .sticky-actions{
    right:12px;
    bottom:12px;
  }

  .sticky-actions a{
    min-width:118px;
    padding:10px 12px;
    border-radius:14px;
  }

  .sticky-actions span{
    font-size:9px;
  }

  .sticky-actions strong{
    font-size:12px;
  }
}



/* ===== v44 slideshow cleanup ===== */
.process-section h2:empty,
.combos-section h2:empty{
  display:none;
}

.process-section .section-kicker,
.combos-section .section-kicker{
  margin-bottom: 20px;
}

.hero-slide-dots button{
  width: 9px;
  height: 9px;
}
.hero-slide-dots button.active{
  width: 26px;
}



/* ===== v45 language switcher + sticky cleanup ===== */

.lang-switcher{
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.lang-btn{
  min-width:38px;
  height:32px;
  padding:0 10px;
  border:none;
  border-radius:999px;
  background:transparent;
  color:var(--muted);
  font:inherit;
  font-size:11px;
  font-weight:900;
  letter-spacing:.06em;
  cursor:pointer;
  transition:
    color .22s ease,
    background .22s ease,
    box-shadow .22s ease,
    transform .22s ease;
}

.lang-btn:hover{
  color:#fff;
  background:rgba(255,255,255,.05);
}

.lang-btn.active{
  color:#fff;
  background:linear-gradient(135deg, rgba(0,168,255,.28), rgba(140,198,63,.22));
  box-shadow:
    0 0 14px rgba(0,168,255,.12),
    0 0 18px rgba(140,198,63,.08),
    inset 0 1px 0 rgba(255,255,255,.14);
}

.sticky-actions{
  grid-template-columns:1fr;
}

.sticky-actions a{
  min-width:154px;
}

@media(max-width:980px){
  .lang-switcher{
    order:3;
  }
}

@media(max-width:760px){
  .lang-switcher{
    gap:4px;
    padding:3px;
  }

  .lang-btn{
    min-width:32px;
    height:28px;
    font-size:10px;
    padding:0 8px;
  }

  .sticky-actions a{
    min-width:126px;
  }
}




/* ===== v46 cleanup: single sticky whatsapp + narrower FAQ ===== */

#faq.faq-section{
  width: min(920px, calc(100% - 44px));
  margin: 0 auto 36px;
}

#faq .faq-grid{
  grid-template-columns: 1fr !important;
  max-width: 840px;
  margin: 0 auto;
  gap: 14px;
}

#faq h2{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.sticky-actions{
  grid-template-columns: 1fr !important;
}

.sticky-actions .sticky-whatsapp{
  min-width: 150px;
}

@media(max-width:760px){
  #faq.faq-section{
    width: min(100% - 24px, 920px);
    margin-bottom: 22px;
  }

  #faq .faq-grid{
    max-width: 100%;
  }
}




/* ===== v47 Pashto language support ===== */

.lang-switcher{
  flex-wrap: nowrap;
}

.lang-btn[data-lang="ps"]{
  min-width: 36px;
}

html[dir="rtl"] body{
  direction: rtl;
}

html[dir="rtl"] .nav-shell,
html[dir="rtl"] .hero-buttons,
html[dir="rtl"] .trust-item,
html[dir="rtl"] .footer-brand,
html[dir="rtl"] .footer-meta,
html[dir="rtl"] .sticky-actions a{
  direction: rtl;
}

html[dir="rtl"] .nav-links{
  margin-left: 0;
  margin-right: auto;
}

html[dir="rtl"] .section-kicker.left,
html[dir="rtl"] .quote-copy h2,
html[dir="rtl"] .promise-copy h2{
  text-align: right;
}

html[dir="rtl"] .quote-form input,
html[dir="rtl"] .quote-form select,
html[dir="rtl"] .quote-form textarea{
  text-align: right;
}

html[dir="rtl"] .faq-item summary::after{
  float: left;
}

html[dir="rtl"] .hero-slide-overlay{
  text-align: right;
}

html[dir="rtl"] .hero-slide-kicker::before{
  order: 2;
}

html[dir="rtl"] .footer-meta{
  justify-content: flex-start;
}

@media(max-width:760px){
  .lang-btn[data-lang="ps"]{
    min-width: 30px;
  }
}




/* ===== v48 Pashto display fix ===== */
.lang-btn[data-lang="ps"]{
  min-width: 54px;
  font-size: 12px;
}

html[dir="rtl"] body{
  direction: rtl;
}

html[dir="rtl"] .nav-shell,
html[dir="rtl"] .hero-buttons,
html[dir="rtl"] .trust-item,
html[dir="rtl"] .footer-brand,
html[dir="rtl"] .footer-meta,
html[dir="rtl"] .sticky-actions a{
  direction: rtl;
}

html[dir="rtl"] .nav-links{
  margin-left: 0;
  margin-right: auto;
}

html[dir="rtl"] .hero-left,
html[dir="rtl"] .hero-slide-overlay,
html[dir="rtl"] .quote-copy,
html[dir="rtl"] .promise-copy,
html[dir="rtl"] .faq-section{
  text-align: right;
}

html[dir="rtl"] .section-kicker.left,
html[dir="rtl"] .quote-copy h2,
html[dir="rtl"] .promise-copy h2{
  text-align: right;
}

html[dir="rtl"] .quote-form input,
html[dir="rtl"] .quote-form select,
html[dir="rtl"] .quote-form textarea{
  text-align: right;
}

html[dir="rtl"] .faq-item summary::after{
  float: left;
}

@media(max-width:760px){
  .lang-btn[data-lang="ps"]{
    min-width: 42px;
    font-size: 11px;
  }
}




/* ===== v53 premium CTA + offerte progress polish ===== */

.nav-cta,
.btn-primary,
.service-link{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

.nav-cta::before,
.btn-primary::before,
.service-link::before{
  content:"";
  position:absolute;
  top:-120%;
  left:-35%;
  width:42%;
  height:320%;
  transform:rotate(24deg);
  background:linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.42), rgba(255,255,255,0));
  opacity:.0;
  transition:transform .9s cubic-bezier(.22,1,.36,1), opacity .45s ease;
  pointer-events:none;
  z-index:0;
}

.nav-cta:hover::before,
.btn-primary:hover::before,
.service-link:hover::before{
  opacity:1;
  transform:translateX(320%) rotate(24deg);
}

.nav-cta,
.btn-primary{
  box-shadow:
    0 0 0 1px rgba(255,255,255,.08) inset,
    0 16px 40px rgba(88, 184, 143, .22),
    0 0 34px rgba(140,198,63,.34),
    inset 0 1px 0 rgba(255,255,255,.45);
  transition:transform .25s ease, box-shadow .3s ease, filter .3s ease;
}

.nav-cta:hover,
.btn-primary:hover{
  transform:translateY(-2px);
  filter:saturate(1.08) brightness(1.03);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.12) inset,
    0 22px 56px rgba(35, 155, 255, .18),
    0 0 38px rgba(140,198,63,.42),
    inset 0 1px 0 rgba(255,255,255,.55);
}

.service-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:46px;
  padding:0 18px;
  margin-top:10px;
  border-radius:14px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:900;
  letter-spacing:.05em;
  color:#eaf8ff;
  border:1px solid rgba(184,225,255,.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.025)),
    linear-gradient(135deg, rgba(0,168,255,.14), rgba(140,198,63,.12));
  box-shadow:
    0 14px 32px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.12);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, color .25s ease;
}

.service-link span{
  display:inline-block;
  transition:transform .25s ease;
  position:relative;
  z-index:1;
}

.service-link:hover{
  transform:translateY(-2px);
  border-color:rgba(140,198,63,.34);
  color:#ffffff;
  box-shadow:
    0 18px 40px rgba(0,0,0,.28),
    0 0 26px rgba(0,168,255,.12),
    inset 0 1px 0 rgba(255,255,255,.16);
}

.service-link:hover span{
  transform:translateX(3px);
}

.service-link,
.nav-cta,
.btn-primary{
  text-decoration:none;
}

.panel-soft{
  margin:0 0 16px;
  padding:18px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.09);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025)),
    linear-gradient(135deg, rgba(0,168,255,.09), rgba(140,198,63,.08));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 18px 40px rgba(0,0,0,.14);
}

.quote-progress-wrap{
  margin-bottom:18px;
}

.quote-progress-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

.quote-progress-kicker{
  font-size:11px;
  font-weight:900;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:#9fdcff;
}

.quote-progress-label{
  font-size:13px;
  font-weight:800;
  color:#fff;
}

.quote-progress-bar{
  position:relative;
  height:10px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.quote-progress-fill{
  display:block;
  height:100%;
  width:25%;
  border-radius:inherit;
  background:linear-gradient(90deg, #00a8ff 0%, #4fc3ff 32%, #8cc63f 100%);
  box-shadow:0 0 24px rgba(0,168,255,.20), 0 0 28px rgba(140,198,63,.18);
  transition:width .35s ease;
}

.quote-progress-steps{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:10px;
  margin-top:14px;
}

.quote-progress-step{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.06);
  color:rgba(220,235,255,.7);
  transition:all .25s ease;
}

.quote-progress-step span{
  width:24px;
  height:24px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:900;
  color:#06111f;
  background:rgba(255,255,255,.18);
}

.quote-progress-step small{
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
}

.quote-progress-step.is-active,
.quote-progress-step.is-complete{
  color:#fff;
  border-color:rgba(140,198,63,.2);
  background:linear-gradient(135deg, rgba(0,168,255,.09), rgba(140,198,63,.11));
  box-shadow:0 10px 24px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.06);
}

.quote-progress-step.is-active span,
.quote-progress-step.is-complete span{
  background:linear-gradient(135deg, #8fe1ff, #8cc63f);
  box-shadow:0 0 16px rgba(140,198,63,.18);
}

.quote-progress-step.is-complete span::before{
  content:"✓";
}

.quote-progress-step.is-complete span{
  font-size:0;
}

.quote-form button.btn-primary{
  min-width:220px;
}

@media(max-width:760px){
  .quote-progress-top{
    flex-direction:column;
    align-items:flex-start;
  }
  .quote-progress-steps{
    grid-template-columns:1fr 1fr;
  }
  .service-link{
    width:100%;
  }
}



/* ===== v55 premium signals + better service buttons + luxe offerteprocess ===== */

/* Premium signals section */
.premium-signals-section{
  padding-top:8px;
}

.premium-signals-section h2{
  max-width:820px;
}

.premium-signals-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
  margin-top:24px;
}

.premium-signal-card{
  position:relative;
  overflow:hidden;
  min-height:148px;
  padding:24px 22px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at 0% 0%, rgba(0,168,255,.12), transparent 34%),
    radial-gradient(circle at 100% 100%, rgba(140,198,63,.10), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.028)),
    linear-gradient(135deg, rgba(7,19,33,.96), rgba(10,27,43,.84));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 20px 40px rgba(0,0,0,.16);
}

.premium-signal-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, rgba(0,168,255,.18), rgba(255,255,255,.03), rgba(140,198,63,.16));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
}

.premium-signal-card::after{
  content:"";
  position:absolute;
  width:120px;
  height:120px;
  top:-30px;
  right:-22px;
  background:radial-gradient(circle, rgba(0,168,255,.10), transparent 70%);
  pointer-events:none;
  filter:blur(2px);
}

.premium-signal-value{
  position:relative;
  z-index:1;
  display:block;
  margin-bottom:14px;
  font-size:clamp(28px, 4vw, 42px);
  line-height:1;
  font-weight:900;
  letter-spacing:-.04em;
  color:#ffffff;
  text-shadow:0 0 14px rgba(0,168,255,.10);
}

.premium-signal-card p{
  position:relative;
  z-index:1;
  margin:0;
  max-width:220px;
  color:rgba(230,243,255,.84);
  line-height:1.55;
  font-size:14px;
  font-weight:600;
}

/* Service cards: full-width elegant button bar */
.service-body{
  display:flex;
  flex-direction:column;
}

.service-link{
  position:relative;
  display:flex !important;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  width:100%;
  min-height:50px;
  margin-top:auto;
  padding:0 18px;
  border-radius:16px;
  border:1px solid rgba(170,220,255,.16);
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025)),
    linear-gradient(135deg, rgba(7,20,35,.95), rgba(10,28,42,.82));
  color:#eef9ff !important;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 14px 30px rgba(0,0,0,.18);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease;
}

.service-link::before{
  content:"";
  position:absolute;
  top:-120%;
  left:-18%;
  width:26%;
  height:320%;
  transform:rotate(22deg);
  background:linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.28), rgba(255,255,255,0));
  opacity:0;
  pointer-events:none;
  transition:transform .95s cubic-bezier(.22,1,.36,1), opacity .4s ease;
}

.service-link:hover::before{
  opacity:1;
  transform:translateX(420%) rotate(22deg);
}

.service-link span{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(0,168,255,.95), rgba(140,198,63,.92));
  color:#06111f;
  font-size:14px;
  font-weight:900;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.14) inset,
    0 8px 18px rgba(0,168,255,.16),
    0 0 14px rgba(140,198,63,.12);
  transition:transform .22s ease, box-shadow .22s ease;
}

.service-link:hover{
  transform:translateY(-2px);
  border-color:rgba(140,198,63,.26);
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.03)),
    linear-gradient(135deg, rgba(9,25,42,.96), rgba(12,34,50,.86));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.10),
    0 18px 36px rgba(0,0,0,.22),
    0 0 20px rgba(0,168,255,.06);
}

.service-link:hover span{
  transform:translateX(2px);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.16) inset,
    0 10px 22px rgba(0,168,255,.18),
    0 0 16px rgba(140,198,63,.14);
}

/* Much more premium quote progress bar */
.quote-progress-wrap{
  position:relative;
  overflow:hidden;
  margin-bottom:18px;
  padding:20px 20px 18px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.09);
  background:
    radial-gradient(circle at 0% 0%, rgba(0,168,255,.16), transparent 34%),
    radial-gradient(circle at 100% 0%, rgba(93,216,220,.08), transparent 26%),
    radial-gradient(circle at 100% 100%, rgba(140,198,63,.14), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)),
    linear-gradient(135deg, rgba(6,18,32,.97), rgba(9,24,40,.90));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 24px 46px rgba(0,0,0,.18);
}

.quote-progress-wrap::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, rgba(0,168,255,.24), rgba(255,255,255,.03), rgba(140,198,63,.22));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
}

.quote-progress-wrap::after{
  content:"";
  position:absolute;
  width:220px;
  height:220px;
  right:-50px;
  top:-80px;
  background:radial-gradient(circle, rgba(0,168,255,.12), transparent 68%);
  filter:blur(8px);
  pointer-events:none;
}

.quote-progress-top{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin-bottom:14px;
}

.quote-progress-kicker{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.07);
  color:#b2ebff;
  font-size:10px;
  font-weight:900;
  letter-spacing:.11em;
  text-transform:uppercase;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.quote-progress-label{
  color:#ffffff;
  font-size:15px;
  font-weight:900;
  letter-spacing:-.01em;
}

.quote-progress-bar{
  position:relative;
  height:16px;
  border-radius:999px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    inset 0 -8px 16px rgba(0,0,0,.10);
}

.quote-progress-fill{
  position:relative;
  display:block;
  height:100%;
  width:25%;
  border-radius:inherit;
  background:
    linear-gradient(90deg, #00a8ff 0%, #36b9ff 20%, #67ddff 42%, #59d9c1 65%, #8cc63f 100%);
  background-size:260% 100%;
  animation:v55HydrexFlow 7s linear infinite;
  box-shadow:
    0 0 22px rgba(0,168,255,.24),
    0 0 30px rgba(140,198,63,.18);
  transition:width .35s ease;
}

.quote-progress-fill::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.36), rgba(255,255,255,0));
  opacity:.78;
  mix-blend-mode:screen;
}

.quote-progress-fill::after{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:34px;
  height:100%;
  background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.26));
  filter:blur(4px);
}

.quote-progress-steps{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:12px;
  margin-top:16px;
}

.quote-progress-step{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.06);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
  color:rgba(225,239,255,.72);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  transition:all .26s ease;
}

.quote-progress-step span{
  display:grid;
  place-items:center;
  flex:0 0 auto;
  width:28px;
  height:28px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
  color:#e9fbff;
  font-size:12px;
  font-weight:900;
}

.quote-progress-step small{
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
  color:inherit;
}

.quote-progress-step.is-active{
  color:#fff;
  border-color:rgba(0,168,255,.24);
  background:
    linear-gradient(135deg, rgba(0,168,255,.13), rgba(87,211,255,.08)),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 12px 28px rgba(0,168,255,.10);
}

.quote-progress-step.is-active span{
  color:#06111f;
  background:linear-gradient(135deg, #93e5ff, #43c7ff);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.14) inset,
    0 0 16px rgba(0,168,255,.18);
}

.quote-progress-step.is-complete{
  color:#fff;
  border-color:rgba(140,198,63,.24);
  background:
    linear-gradient(135deg, rgba(87,174,112,.10), rgba(140,198,63,.15)),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 12px 24px rgba(140,198,63,.08);
}

.quote-progress-step.is-complete span{
  color:#06111f;
  background:linear-gradient(135deg, #d9ff80, #8cc63f);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.14) inset,
    0 0 14px rgba(140,198,63,.16);
  font-size:0;
}

.quote-progress-step.is-complete span::before{
  content:"✓";
  font-size:12px;
  font-weight:900;
}

@keyframes v55HydrexFlow{
  0%{ background-position:0% 50%; }
  100%{ background-position:260% 50%; }
}

@media(max-width:1060px){
  .premium-signals-grid{
    grid-template-columns:repeat(2, 1fr);
  }
}

@media(max-width:760px){
  .premium-signals-grid{
    grid-template-columns:1fr;
  }
  .quote-progress-top{
    flex-direction:column;
    align-items:flex-start;
  }
  .quote-progress-steps{
    grid-template-columns:1fr 1fr;
  }
}



/* ===== v56 ONLY: premium signal count-up + hover glow ===== */
.premium-signal-card{
  transition:
    transform .28s ease,
    box-shadow .32s ease,
    border-color .28s ease,
    background .28s ease,
    filter .28s ease;
}

@media (hover:hover){
  .premium-signal-card:hover{
    transform: translateY(-5px);
    border-color: rgba(170, 230, 255, .24);
    box-shadow:
      0 28px 90px rgba(0,0,0,.42),
      0 0 0 1px rgba(255,255,255,.04) inset,
      0 0 26px rgba(0,168,255,.14),
      0 0 34px rgba(140,198,63,.11);
    filter: saturate(1.04);
  }

  .premium-signal-card:hover .premium-signal-value{
    text-shadow:
      0 0 16px rgba(0,168,255,.20),
      0 0 22px rgba(140,198,63,.13);
  }
}


/* ===== v57 only: dienstenkaarten verfijnd + offerteprocess weg ===== */
.service-card{
  display:flex;
  flex-direction:column;
  height:100%;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 54px rgba(0,0,0,.28), 0 0 0 1px rgba(255,255,255,.04) inset, 0 0 22px rgba(0,168,255,.09);
}
.service-image{
  height:170px;
}
.service-body{
  display:flex;
  flex-direction:column;
  min-height:260px;
  padding:22px 20px 20px;
}
.service-body h3{
  line-height:1.12;
}
.service-body p{
  flex:1;
  margin:0 0 18px;
}
.service-link,
.service-body a.service-link{
  align-self:flex-start;
  margin-left:0;
  min-width:126px;
  min-height:44px;
  padding:10px 16px;
  border-radius:14px;
  white-space:nowrap;
}
.service-link span{display:inline-block; transform:translateY(-1px);}
.quote-progress-wrap{display:none !important;}

@media (max-width: 1100px){
  .service-body{min-height:280px;}
}
@media (max-width: 860px){
  .service-body{min-height:0;}
}


/* ===== v58: service buttons fully fixed + real form ready ===== */
.service-card{
  min-width:0;
}

.service-body{
  min-height:285px;
}

.service-link,
.service-body a.service-link{
  width:100% !important;
  max-width:100%;
  align-self:stretch !important;
  display:flex !important;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 18px !important;
  margin-top:auto !important;
  margin-left:0 !important;
  border-radius:16px !important;
  white-space:nowrap;
  overflow:visible;
  text-align:center;
  line-height:1;
}

.service-link span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  transform:none;
}

.service-body h3{
  word-break:normal;
  overflow-wrap:normal;
}

.quote-form{
  position:relative;
}

.quote-form::after{
  content:"";
  display:block;
  margin-top:12px;
  color:var(--muted);
  font-size:12px;
  line-height:1.5;
}

@media(max-width:1100px){
  .service-body{
    min-height:300px;
  }
}

@media(max-width:860px){
  .service-body{
    min-height:0;
  }

  .service-link,
  .service-body a.service-link{
    width:auto !important;
    align-self:flex-start !important;
    min-width:148px;
  }
}


/* ===== v60: grotere navbar + extra pagina's in dropdown ===== */
.nav-shell{
  gap:18px;
}

.nav-links{
  align-items:center;
  gap:12px;
  overflow:visible;
}

.nav-links > a,
.nav-dropbtn{
  font-size:14px !important;
  font-weight:850;
  letter-spacing:.035em;
  white-space:nowrap;
}

.nav-links > a{
  padding:11px 12px;
  border-radius:999px;
}

.nav-links > a:hover{
  background:rgba(255,255,255,.055);
  color:#fff;
}

.nav-dropdown{
  position:relative;
  display:flex;
  align-items:center;
}

.nav-dropbtn{
  appearance:none;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
  color:var(--muted);
  min-height:38px;
  padding:0 13px;
  border-radius:999px;
  cursor:pointer;
  font-family:inherit;
  text-transform:none;
  transition:color .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.nav-dropbtn span{
  font-size:11px;
  margin-left:4px;
}

.nav-dropdown-menu{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  width:260px;
  padding:10px;
  border-radius:18px;
  border:1px solid rgba(180,230,255,.14);
  background:
    linear-gradient(180deg, rgba(8,18,34,.96), rgba(6,14,26,.92));
  box-shadow:
    0 26px 70px rgba(0,0,0,.44),
    0 0 24px rgba(0,168,255,.08),
    inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  opacity:0;
  transform:translateY(8px);
  pointer-events:none;
  z-index:120;
  transition:opacity .22s ease, transform .22s ease;
}

.nav-dropdown-menu a{
  display:flex;
  align-items:center;
  min-height:40px;
  padding:0 12px;
  border-radius:12px;
  color:rgba(234,246,255,.80);
  font-size:13px;
  font-weight:750;
  letter-spacing:.015em;
  text-transform:none;
  transition:background .2s ease, color .2s ease, transform .2s ease;
}

.nav-dropdown-menu a:hover{
  background:rgba(255,255,255,.06);
  color:#fff;
  transform:translateX(2px);
}

.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

.nav-dropdown:hover .nav-dropbtn,
.nav-dropdown:focus-within .nav-dropbtn{
  color:#fff;
  border-color:rgba(140,198,63,.24);
  background:rgba(255,255,255,.06);
  box-shadow:0 0 18px rgba(0,168,255,.08), 0 0 18px rgba(140,198,63,.08);
}

.nav-cta{
  white-space:nowrap;
}

@media(max-width:1120px){
  .nav-shell{
    gap:12px;
  }

  .nav-links{
    gap:8px;
  }

  .nav-links > a,
  .nav-dropbtn{
    font-size:12px !important;
  }

  .nav-links > a{
    padding:9px 9px;
  }

  .nav-dropbtn{
    min-height:34px;
    padding:0 10px;
  }
}

@media(max-width:820px){
  .nav-shell{
    align-items:flex-start;
  }

  .nav-links{
    order:3;
    width:100%;
    justify-content:flex-start;
    flex-wrap:wrap;
  }

  .nav-dropdown{
    position:static;
  }

  .nav-dropdown-menu{
    left:0;
    right:auto;
    top:auto;
    width:min(100%, 310px);
    margin-top:44px;
  }
}


/* ===== v61 clean structure polish ===== */
.nav-dropdown-menu{
  width:230px;
}

.footer-legal{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.08);
}

.footer-legal a{
  color:var(--muted);
  font-size:13px;
}

.footer-legal a:hover{
  color:#fff;
}


/* ===== v62 fixes: dropdown + footer + service icons ===== */

/* NAV DROPDOWN FIX */
.nav-shell{
  overflow:visible !important;
}

.nav-links{
  overflow:visible !important;
}

.nav-dropdown{
  position:relative;
  z-index:250;
}

.nav-dropdown-menu{
  top:calc(100% + 14px) !important;
  right:0;
  left:auto;
  width:280px !important;
  display:block;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(12px) scale(.98);
  transform-origin:top right;
  z-index:500;
  border:1px solid rgba(170,230,255,.16);
  background:linear-gradient(180deg, rgba(8,18,34,.98), rgba(7,15,28,.96));
  box-shadow:
    0 30px 80px rgba(0,0,0,.48),
    0 0 24px rgba(0,168,255,.08),
    inset 0 1px 0 rgba(255,255,255,.06);
}

.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0) scale(1);
}

.nav-dropdown-menu a{
  min-height:44px;
  font-size:13px;
  font-weight:780;
  border-radius:12px;
}

.nav-dropbtn{
  min-height:40px !important;
}

/* SERVICE ICONS */
.service-icon{
  width:58px;
  height:58px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.08), transparent 48%),
    linear-gradient(145deg, rgba(0,168,255,.14), rgba(140,198,63,.10));
  border:1px solid rgba(255,255,255,.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 16px 30px rgba(0,0,0,.18);
}

.service-svg{
  width:28px;
  height:28px;
  fill:#e8f7ff;
  opacity:.95;
}

.service-card:hover .service-icon{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 20px 36px rgba(0,0,0,.22),
    0 0 20px rgba(0,168,255,.12),
    0 0 18px rgba(140,198,63,.10);
}

/* FOOTER PROFESSIONAL */
.site-footer{
  padding:34px 32px 22px !important;
}

.footer-top{
  display:grid;
  grid-template-columns:1.4fr .8fr .8fr .9fr;
  gap:28px;
  align-items:start;
}

.footer-links-col,
.footer-contact-col,
.footer-brand-col{
  min-width:0;
}

.footer-links-col h4,
.footer-contact-col h4{
  margin:0 0 14px;
  font-size:14px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
}

.footer-links-col a,
.footer-contact-col a,
.footer-contact-col span{
  display:block;
  margin:0 0 10px;
  color:var(--muted);
  font-size:14px;
}

.footer-links-col a:hover,
.footer-contact-col a:hover{
  color:#fff;
}

.footer-meta{
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  flex-wrap:wrap;
  gap:14px 20px;
  align-items:center;
  justify-content:space-between;
}

.footer-legal{
  margin-top:14px !important;
  padding-top:14px !important;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex !important;
  gap:16px;
  flex-wrap:wrap;
  align-items:center;
}

.footer-legal a{
  margin:0 !important;
  padding:0;
  font-size:13px;
  color:var(--muted);
}

.footer-legal a:hover{
  color:#fff;
}

@media(max-width:1020px){
  .footer-top{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:760px){
  .footer-top{
    grid-template-columns:1fr;
  }

  .footer-meta{
    justify-content:flex-start;
  }

  .nav-dropdown-menu{
    width:min(92vw, 320px) !important;
    right:0;
  }
}


/* ===== v63: dropdown bridge + creative service icons + footer legal alignment ===== */

/* Keep dropdown open while moving mouse from button to menu */
.nav-dropdown{
  position:relative;
}

.nav-dropdown::after{
  content:"";
  position:absolute;
  left:-12px;
  right:-12px;
  top:100%;
  height:18px;
  z-index:499;
}

.nav-dropdown-menu{
  top:calc(100% + 8px) !important;
  transition:
    opacity .22s ease,
    transform .22s ease,
    visibility .22s ease;
}

.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu,
.nav-dropdown-menu:hover{
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:translateY(0) scale(1) !important;
}

/* Make service icons definitely override old diamond symbol */
.service-icon{
  font-size:0 !important;
  color:transparent !important;
  overflow:hidden;
}

.service-icon::before,
.service-icon::after{
  display:none !important;
  content:none !important;
}

.service-svg{
  width:30px !important;
  height:30px !important;
  fill:url(#none);
  fill:#eaf8ff !important;
  stroke:none;
  filter:
    drop-shadow(0 0 10px rgba(0,168,255,.18))
    drop-shadow(0 0 8px rgba(140,198,63,.10));
}

.service-card:nth-child(1) .service-icon{
  background:
    radial-gradient(circle at 25% 20%, rgba(255,255,255,.12), transparent 38%),
    linear-gradient(145deg, rgba(0,168,255,.20), rgba(0,168,255,.06));
}

.service-card:nth-child(2) .service-icon{
  background:
    radial-gradient(circle at 25% 20%, rgba(255,255,255,.12), transparent 38%),
    linear-gradient(145deg, rgba(0,168,255,.16), rgba(140,198,63,.08));
}

.service-card:nth-child(3) .service-icon{
  background:
    radial-gradient(circle at 25% 20%, rgba(255,255,255,.12), transparent 38%),
    linear-gradient(145deg, rgba(90,200,255,.14), rgba(255,255,255,.04));
}

.service-card:nth-child(4) .service-icon{
  background:
    radial-gradient(circle at 25% 20%, rgba(255,255,255,.12), transparent 38%),
    linear-gradient(145deg, rgba(140,198,63,.22), rgba(0,168,255,.06));
}

/* Footer legal should sit aligned in the same bottom bar instead of floating higher */
.footer-meta{
  align-items:center !important;
  margin-bottom:0 !important;
}

.footer-legal{
  width:100%;
  margin-top:14px !important;
  padding-top:14px !important;
  border-top:1px solid rgba(255,255,255,.06) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:18px !important;
  line-height:1 !important;
}

.footer-legal a{
  display:inline-flex !important;
  align-items:center !important;
  height:22px !important;
  line-height:1 !important;
  margin:0 !important;
  padding:0 !important;
}

@media(max-width:760px){
  .footer-legal{
    justify-content:flex-start !important;
  }
}


/* ===== v64: stronger service icons + footer alignment cleanup ===== */

/* SERVICE ICONS: make them clearly visible and no longer overlap the photo */
.service-body{
  position:relative;
  padding-top:22px !important;
}

.service-icon{
  position:relative !important;
  top:0 !important;
  left:0 !important;
  margin:0 0 16px 0 !important;
  width:64px !important;
  height:64px !important;
  border-radius:20px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.18), transparent 34%),
    linear-gradient(145deg, rgba(7,18,32,.96), rgba(10,25,42,.94)) !important;
  border:1px solid rgba(180,230,255,.18) !important;
  box-shadow:
    0 18px 38px rgba(0,0,0,.26),
    0 0 0 1px rgba(255,255,255,.04) inset,
    0 0 18px rgba(0,168,255,.12) !important;
  z-index:2;
  overflow:hidden;
}

.service-card.green-card .service-icon{
  border-color: rgba(140,198,63,.26) !important;
  box-shadow:
    0 18px 38px rgba(0,0,0,.26),
    0 0 0 1px rgba(255,255,255,.04) inset,
    0 0 16px rgba(140,198,63,.12) !important;
}

.service-card:nth-child(1) .service-icon{
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.18), transparent 34%),
    linear-gradient(145deg, rgba(4,28,48,.98), rgba(10,22,38,.94)) !important;
}
.service-card:nth-child(2) .service-icon{
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.18), transparent 34%),
    linear-gradient(145deg, rgba(6,24,42,.98), rgba(14,33,48,.94)) !important;
}
.service-card:nth-child(3) .service-icon{
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.18), transparent 34%),
    linear-gradient(145deg, rgba(8,30,46,.98), rgba(12,23,36,.94)) !important;
}
.service-card:nth-child(4) .service-icon{
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.18), transparent 34%),
    linear-gradient(145deg, rgba(12,34,28,.98), rgba(10,24,34,.94)) !important;
}

.service-svg{
  width:32px !important;
  height:32px !important;
  fill:#ffffff !important;
  opacity:1 !important;
  filter:
    drop-shadow(0 0 14px rgba(255,255,255,.12))
    drop-shadow(0 0 12px rgba(0,168,255,.14));
}

.service-card.green-card .service-svg{
  filter:
    drop-shadow(0 0 14px rgba(255,255,255,.12))
    drop-shadow(0 0 12px rgba(140,198,63,.14));
}

.service-body h3{
  margin-top:0 !important;
}

/* FOOTER: clean, aligned and more premium */
.site-footer{
  display:grid !important;
  grid-template-columns:minmax(280px,1fr) auto !important;
  gap:18px 24px !important;
  align-items:center !important;
  padding:28px 30px 20px !important;
}

.footer-brand{
  grid-column:1 / 2;
  align-self:center;
}

.footer-meta{
  grid-column:2 / 3;
  align-self:center;
  justify-content:flex-end !important;
  margin:0 !important;
  padding:0 !important;
  border-top:none !important;
}

.footer-legal{
  grid-column:1 / -1;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:18px !important;
  margin:0 !important;
  padding-top:16px !important;
  border-top:1px solid rgba(255,255,255,.08) !important;
  min-height:24px;
}

.footer-legal a{
  display:inline-flex !important;
  align-items:center !important;
  line-height:1 !important;
  margin:0 !important;
  height:auto !important;
}

@media(max-width:860px){
  .site-footer{
    grid-template-columns:1fr !important;
  }

  .footer-brand,
  .footer-meta,
  .footer-legal{
    grid-column:1 / -1 !important;
  }

  .footer-meta,
  .footer-legal{
    justify-content:flex-start !important;
  }
}


/* ===== v65: sticky topbar + compact footer alignment + service pages ===== */

/* Sticky top navigation */
.nav-shell{
  position:sticky !important;
  top:14px !important;
  z-index:1000 !important;
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
}

/* Keep dropdown above everything while sticky */
.nav-dropdown,
.nav-dropdown-menu{
  z-index:1200 !important;
}

/* Compact footer: everything aligned, no extra height */
.site-footer{
  display:grid !important;
  grid-template-columns:auto 1fr auto !important;
  align-items:center !important;
  gap:16px 22px !important;
  padding:18px 22px !important;
  min-height:0 !important;
}

.footer-brand{
  grid-column:1 / 2 !important;
  align-items:center !important;
  margin:0 !important;
}

.footer-brand img{
  width:102px !important;
}

.footer-meta{
  grid-column:2 / 3 !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap:12px 18px !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  line-height:1 !important;
}

.footer-meta span,
.footer-meta a{
  display:inline-flex !important;
  align-items:center !important;
  line-height:1 !important;
  margin:0 !important;
}

.footer-legal{
  grid-column:3 / 4 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:14px !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  min-height:0 !important;
  line-height:1 !important;
}

.footer-legal a{
  display:inline-flex !important;
  align-items:center !important;
  height:auto !important;
  line-height:1 !important;
  margin:0 !important;
  padding:0 !important;
}

/* Service detail pages */
.service-detail-section h2,
.service-benefits-section h2{
  margin:0 0 24px;
}

.service-benefit-list{
  display:grid;
  gap:10px;
  margin:18px 0 0;
  padding:0;
  list-style:none;
}

.service-benefit-list li{
  color:var(--text);
  line-height:1.6;
  padding-left:26px;
  position:relative;
}

.service-benefit-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--green2);
  font-weight:900;
}

.service-quote-section{
  padding-top:20px;
}

.service-quote-section .quote-panel{
  grid-template-columns:.85fr 1.15fr;
}

@media(max-width:980px){
  .site-footer{
    grid-template-columns:1fr !important;
    align-items:flex-start !important;
  }

  .footer-brand,
  .footer-meta,
  .footer-legal{
    grid-column:1 / -1 !important;
    justify-content:flex-start !important;
  }

  .footer-meta{
    flex-wrap:wrap !important;
  }

  .service-quote-section .quote-panel{
    grid-template-columns:1fr;
  }
}

@media(max-width:760px){
  .nav-shell{
    top:8px !important;
  }

  .site-footer{
    padding:16px !important;
  }
}


/* ===== v66: cleaner service pages + slideshow badge icons ===== */

/* Slideshow badge icon */
.hero-floating-badge .badge-icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(circle at 28% 24%, rgba(255,255,255,.16), transparent 38%),
    linear-gradient(145deg, rgba(5,20,38,.94), rgba(8,24,42,.94));
  border:1px solid rgba(180,230,255,.18);
  box-shadow:
    0 14px 30px rgba(0,0,0,.22),
    0 0 16px rgba(0,168,255,.10);
  font-size:0;
  color:transparent;
  overflow:hidden;
}

.hero-floating-badge.green .badge-icon{
  border-color: rgba(140,198,63,.24);
  box-shadow:
    0 14px 30px rgba(0,0,0,.22),
    0 0 16px rgba(140,198,63,.10);
}

.hero-floating-badge .badge-icon svg{
  width:22px;
  height:22px;
  fill:#fff;
  opacity:.96;
}

/* Cleaner service pages */
.compact-list{
  margin:18px 0 0;
}

.compact-list li{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  padding:12px 14px 12px 36px;
}

.service-page-copy{
  max-width:650px;
}

.service-intro-text{
  max-width:860px;
  margin:0 0 24px;
  color:var(--muted);
  line-height:1.75;
}

.service-detail-grid{
  align-items:stretch;
}

.service-detail-card{
  min-height:0;
}

.service-detail-card h3{
  margin:0 0 10px;
}

.service-detail-card p{
  margin:0;
  line-height:1.7;
}

.service-quote-section{
  padding-top:8px;
}

.service-quote-section .quote-panel{
  grid-template-columns:.88fr 1.12fr;
}

@media(max-width:980px){
  .service-quote-section .quote-panel{
    grid-template-columns:1fr;
  }
}


/* ===== v67: premium service pages + unified professional footer ===== */

.service-page-shell{
  position:relative;
  z-index:2;
}

/* Premium service pages */
.service-explainer-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.service-explainer-card{
  padding:28px;
  min-height:100%;
}

.service-explainer-card h2{
  margin:0 0 14px;
}

.service-explainer-card p{
  margin:0;
  color:var(--muted);
  line-height:1.8;
}

.service-process-section h2{
  margin:0 0 24px;
}

.service-process-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

.service-step-card{
  padding:26px;
  position:relative;
  overflow:hidden;
}

.service-step-index{
  width:42px;
  height:42px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  background:
    radial-gradient(circle at 30% 22%, rgba(255,255,255,.14), transparent 38%),
    linear-gradient(145deg, rgba(0,168,255,.18), rgba(140,198,63,.10));
  border:1px solid rgba(180,230,255,.16);
  color:#fff;
  font-weight:800;
  box-shadow:
    0 12px 28px rgba(0,0,0,.18),
    0 0 14px rgba(0,168,255,.08);
}

.service-step-card h3{
  margin:0 0 12px;
}

.service-step-card p{
  margin:0;
  color:var(--muted);
  line-height:1.75;
}

.compact-list li{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.service-quote-section .quote-panel{
  grid-template-columns:.88fr 1.12fr;
}

/* Professional footer */
.premium-footer{
  margin-top:42px;
  padding:28px 28px 18px !important;
}

.premium-footer .footer-main{
  display:grid;
  grid-template-columns:1.4fr .75fr .8fr .9fr;
  gap:26px;
  align-items:start;
}

.premium-footer .footer-brand-block{
  min-width:0;
}

.premium-footer .footer-brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.premium-footer .footer-brand img{
  width:112px;
  max-width:100%;
  height:auto;
  object-fit:contain;
}

.premium-footer .footer-brand strong{
  display:block;
  color:#fff;
  font-size:18px;
  letter-spacing:.04em;
}

.premium-footer .footer-brand span{
  display:block;
  color:var(--muted);
  margin-top:4px;
  font-size:13px;
}

.premium-footer .footer-intro{
  margin:16px 0 0;
  color:var(--muted);
  line-height:1.75;
  max-width:440px;
}

.premium-footer .footer-col h4{
  margin:0 0 14px;
  color:#fff;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.09em;
}

.premium-footer .footer-col a,
.premium-footer .footer-col span{
  display:block;
  margin:0 0 10px;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}

.premium-footer .footer-col a:hover{
  color:#fff;
}

.premium-footer .footer-bottom{
  margin-top:22px;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}

.premium-footer .footer-bottom > span{
  color:var(--muted);
  font-size:13px;
}

.premium-footer .footer-legal{
  display:flex !important;
  align-items:center;
  justify-content:flex-end;
  gap:16px;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
}

.premium-footer .footer-legal a{
  color:var(--muted);
  font-size:13px;
  line-height:1;
  display:inline-flex !important;
  align-items:center;
}

.premium-footer .footer-legal a:hover{
  color:#fff;
}

@media(max-width:1080px){
  .premium-footer .footer-main{
    grid-template-columns:1.2fr 1fr 1fr;
  }
  .premium-footer .footer-brand-block{
    grid-column:1 / -1;
  }
}

@media(max-width:980px){
  .service-explainer-grid,
  .service-process-grid,
  .service-quote-section .quote-panel{
    grid-template-columns:1fr;
  }
}

@media(max-width:760px){
  .premium-footer{
    padding:22px 18px 16px !important;
  }

  .premium-footer .footer-main{
    grid-template-columns:1fr;
    gap:20px;
  }

  .premium-footer .footer-bottom{
    align-items:flex-start;
    justify-content:flex-start;
  }

  .premium-footer .footer-legal{
    justify-content:flex-start;
    flex-wrap:wrap;
  }
}


/* ===== v68: footer intro removed + legal bottom aligned ===== */
.premium-footer .footer-intro,
.site-footer .footer-intro{
  display:none !important;
}

.premium-footer .footer-bottom,
.site-footer .footer-bottom{
  margin-top:20px !important;
  padding-top:15px !important;
  border-top:1px solid rgba(255,255,255,.08) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:16px !important;
  flex-wrap:wrap !important;
}

.premium-footer .footer-copyright,
.site-footer .footer-copyright{
  color:var(--muted) !important;
  font-size:13px !important;
  line-height:1 !important;
  display:inline-flex !important;
  align-items:center !important;
  margin:0 !important;
}

.premium-footer .footer-legal,
.site-footer .footer-legal{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:18px !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  min-height:0 !important;
  line-height:1 !important;
}

.premium-footer .footer-legal a,
.site-footer .footer-legal a{
  color:var(--muted) !important;
  font-size:13px !important;
  line-height:1 !important;
  display:inline-flex !important;
  align-items:center !important;
  margin:0 !important;
  padding:0 !important;
  height:auto !important;
}

.premium-footer .footer-legal a:hover,
.site-footer .footer-legal a:hover{
  color:#fff !important;
}

@media(max-width:760px){
  .premium-footer .footer-bottom,
  .site-footer .footer-bottom{
    align-items:flex-start !important;
    justify-content:flex-start !important;
    flex-direction:column !important;
  }

  .premium-footer .footer-legal,
  .site-footer .footer-legal{
    justify-content:flex-start !important;
    flex-wrap:wrap !important;
  }
}


/* ===== v91: build further from v68 - clean mobile hamburger menu ===== */
/* Goal: keep the original v68 background and desktop layout untouched,
   but make the phone version genuinely usable. */

.nav-toggle,
.nav-mobile-lang{
  display:none;
}

@media(max-width:760px){

  body{
    overflow-x:hidden !important;
  }

  .site-wrap,
  .nav-shell{
    width:min(100% - 24px,1220px) !important;
  }

  .nav-shell.nav-mobile-ready{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:10px !important;
    min-height:72px !important;
    padding:10px 12px !important;
    overflow:visible !important;
  }

  .nav-logo{
    width:122px !important;
    flex-basis:122px !important;
    grid-column:1 / 2 !important;
  }

  .nav-logo img{
    width:100% !important;
    height:auto !important;
    display:block !important;
  }

  .nav-toggle{
    display:flex !important;
    grid-column:3 / 4 !important;
    justify-self:end !important;
    width:44px !important;
    height:40px !important;
    border-radius:14px !important;
    border:1px solid rgba(255,255,255,.12) !important;
    background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)) !important;
    align-items:center !important;
    justify-content:center !important;
    flex-direction:column !important;
    gap:5px !important;
    cursor:pointer !important;
    box-shadow:
      0 12px 28px rgba(0,0,0,.22),
      inset 0 1px 0 rgba(255,255,255,.08) !important;
  }

  .nav-toggle span{
    display:block !important;
    width:19px !important;
    height:2px !important;
    border-radius:999px !important;
    background:#ffffff !important;
    transition:transform .22s ease, opacity .22s ease !important;
  }

  .nav-shell.menu-open .nav-toggle span:nth-child(1){
    transform:translateY(7px) rotate(45deg) !important;
  }

  .nav-shell.menu-open .nav-toggle span:nth-child(2){
    opacity:0 !important;
  }

  .nav-shell.menu-open .nav-toggle span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg) !important;
  }

  /* Phone menu */
  .nav-links{
    display:none !important;
    grid-column:1 / -1 !important;
    width:100% !important;
    margin:10px 0 0 !important;
    padding:10px !important;
    border-radius:18px !important;
    background:
      linear-gradient(180deg, rgba(4,12,24,.90), rgba(4,12,24,.74)),
      linear-gradient(135deg, rgba(0,168,255,.08), rgba(140,198,63,.05)) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    box-shadow:
      0 22px 52px rgba(0,0,0,.34),
      inset 0 1px 0 rgba(255,255,255,.05) !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
    overflow:visible !important;
  }

  .nav-shell.menu-open .nav-links{
    display:flex !important;
  }

  .nav-links > a,
  .nav-dropbtn{
    width:100% !important;
    min-height:44px !important;
    padding:0 14px !important;
    border-radius:14px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    text-align:left !important;
    background:rgba(255,255,255,.035) !important;
    border:1px solid rgba(255,255,255,.06) !important;
    color:#eef8ff !important;
    font-size:14px !important;
    font-weight:800 !important;
    letter-spacing:.02em !important;
  }

  .nav-dropdown{
    width:100% !important;
    position:relative !important;
  }

  .nav-dropbtn{
    justify-content:space-between !important;
  }

  .nav-dropdown-menu{
    position:static !important;
    display:none !important;
    width:100% !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:none !important;
    margin-top:8px !important;
    padding:8px !important;
    border-radius:16px !important;
    background:rgba(0,0,0,.22) !important;
    box-shadow:none !important;
  }

  .nav-dropdown.open .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu{
    display:block !important;
  }

  .nav-dropdown-menu a{
    min-height:40px !important;
    padding:0 12px !important;
    border-radius:12px !important;
  }

  /* Put language neatly inside the menu */
  .lang-switcher{
    display:none !important;
  }

  .nav-mobile-lang{
    display:none !important;
  }

  .nav-shell.menu-open .nav-mobile-lang{
    display:block !important;
    margin-top:2px !important;
  }

  .nav-mobile-lang-buttons{
    display:grid !important;
    grid-template-columns:repeat(3,1fr) !important;
    gap:8px !important;
  }

  .nav-mobile-lang .lang-btn{
    min-height:40px !important;
    border-radius:999px !important;
    border:1px solid rgba(255,255,255,.10) !important;
    background:rgba(255,255,255,.045) !important;
    color:var(--muted) !important;
    font-size:12px !important;
    font-weight:900 !important;
    letter-spacing:.04em !important;
  }

  .nav-mobile-lang .lang-btn.active{
    color:#ffffff !important;
    border-color:rgba(140,198,63,.34) !important;
    background:rgba(140,198,63,.12) !important;
    box-shadow:0 0 18px rgba(140,198,63,.12) !important;
  }

  .nav-cta{
    display:none !important;
  }

  /* Keep sections clean on mobile */
  .hero-left h1{
    font-size:42px !important;
  }

  .hero-buttons{
    flex-direction:column !important;
    align-items:stretch !important;
  }

  .hero-buttons .btn{
    width:100% !important;
    justify-content:center !important;
  }

  .photo-stack{
    min-height:430px !important;
  }

  .main-photo{
    left:4% !important;
    right:4% !important;
    width:auto !important;
    height:300px !important;
  }

  .logo-card{
    right:4% !important;
    top:44% !important;
    width:160px !important;
  }

  .cleaning{
    right:0 !important;
    bottom:0 !important;
    width:198px !important;
  }
}


/* ===== v92: responsive nav breakpoint + cleaner mobile/tablet hamburger ===== */
/* Mobile/tablet: everything goes inside hamburger. Desktop: normal navbar. */

@media(max-width:980px){

  .site-wrap,
  .nav-shell{
    width:min(100% - 24px,1220px) !important;
  }

  .nav-shell.nav-mobile-ready{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:10px !important;
    min-height:72px !important;
    padding:10px 12px !important;
    overflow:visible !important;
  }

  .nav-logo{
    width:132px !important;
    flex-basis:132px !important;
    grid-column:1 / 2 !important;
  }

  .nav-logo img{
    width:100% !important;
    height:auto !important;
    display:block !important;
  }

  /* Hide desktop items that caused overflow */
  .nav-shell > .lang-switcher,
  .nav-shell > .nav-cta{
    display:none !important;
  }

  /* Show hamburger on phone/tablet */
  .nav-toggle{
    display:flex !important;
    grid-column:3 / 4 !important;
    justify-self:end !important;
    width:44px !important;
    height:40px !important;
    border-radius:14px !important;
    border:1px solid rgba(255,255,255,.12) !important;
    background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)) !important;
    align-items:center !important;
    justify-content:center !important;
    flex-direction:column !important;
    gap:5px !important;
    cursor:pointer !important;
    box-shadow:
      0 12px 28px rgba(0,0,0,.22),
      inset 0 1px 0 rgba(255,255,255,.08) !important;
  }

  .nav-toggle span{
    display:block !important;
    width:19px !important;
    height:2px !important;
    border-radius:999px !important;
    background:#ffffff !important;
    transition:transform .22s ease, opacity .22s ease !important;
  }

  .nav-shell.menu-open .nav-toggle span:nth-child(1){
    transform:translateY(7px) rotate(45deg) !important;
  }

  .nav-shell.menu-open .nav-toggle span:nth-child(2){
    opacity:0 !important;
  }

  .nav-shell.menu-open .nav-toggle span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg) !important;
  }

  /* Clean full mobile/tablet menu */
  .nav-links{
    display:none !important;
    grid-column:1 / -1 !important;
    width:100% !important;
    margin:10px 0 0 !important;
    padding:10px !important;
    border-radius:20px !important;
    background:
      linear-gradient(180deg, rgba(4,12,24,.94), rgba(4,12,24,.76)),
      linear-gradient(135deg, rgba(0,168,255,.08), rgba(140,198,63,.05)) !important;
    border:1px solid rgba(255,255,255,.11) !important;
    box-shadow:
      0 22px 52px rgba(0,0,0,.36),
      inset 0 1px 0 rgba(255,255,255,.055) !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
    overflow:visible !important;
  }

  .nav-shell.menu-open .nav-links{
    display:flex !important;
  }

  .nav-links > a,
  .nav-dropbtn{
    width:100% !important;
    min-height:44px !important;
    padding:0 14px !important;
    border-radius:14px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    text-align:left !important;
    background:rgba(255,255,255,.035) !important;
    border:1px solid rgba(255,255,255,.065) !important;
    color:#eef8ff !important;
    font-size:14px !important;
    font-weight:850 !important;
    letter-spacing:.02em !important;
  }

  .nav-links > a:hover,
  .nav-dropbtn:hover{
    background:rgba(255,255,255,.06) !important;
  }

  /* Fix bad-looking Diensten block */
  .nav-dropdown{
    width:100% !important;
    position:relative !important;
    display:block !important;
  }

  .nav-dropbtn{
    justify-content:space-between !important;
  }

  .nav-dropbtn span{
    margin-left:auto !important;
    font-size:12px !important;
    opacity:.8 !important;
  }

  .nav-dropdown-menu{
    position:static !important;
    display:none !important;
    width:100% !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:none !important;
    margin:8px 0 0 !important;
    padding:8px !important;
    border-radius:16px !important;
    background:
      linear-gradient(180deg, rgba(0,0,0,.24), rgba(255,255,255,.025)) !important;
    border:1px solid rgba(255,255,255,.07) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.035) !important;
  }

  .nav-dropdown.open .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu{
    display:grid !important;
    gap:6px !important;
  }

  .nav-dropdown-menu a{
    min-height:40px !important;
    padding:0 12px 0 16px !important;
    border-radius:12px !important;
    display:flex !important;
    align-items:center !important;
    color:rgba(234,246,255,.82) !important;
    background:rgba(255,255,255,.025) !important;
    border:1px solid rgba(255,255,255,.045) !important;
    font-size:13px !important;
    font-weight:750 !important;
  }

  .nav-dropdown-menu a:hover{
    color:#fff !important;
    background:rgba(255,255,255,.055) !important;
  }

  /* Language inside hamburger only */
  .nav-mobile-lang{
    display:none !important;
  }

  .nav-shell.menu-open .nav-mobile-lang{
    display:block !important;
    margin-top:2px !important;
    padding-top:4px !important;
  }

  .nav-mobile-lang-buttons{
    display:grid !important;
    grid-template-columns:repeat(3,1fr) !important;
    gap:8px !important;
  }

  .nav-mobile-lang .lang-btn{
    width:100% !important;
    min-height:40px !important;
    border-radius:999px !important;
    border:1px solid rgba(255,255,255,.10) !important;
    background:rgba(255,255,255,.045) !important;
    color:var(--muted) !important;
    font-size:12px !important;
    font-weight:900 !important;
    letter-spacing:.04em !important;
  }

  .nav-mobile-lang .lang-btn.active{
    color:#ffffff !important;
    border-color:rgba(140,198,63,.34) !important;
    background:rgba(140,198,63,.12) !important;
    box-shadow:0 0 18px rgba(140,198,63,.12) !important;
  }
}

/* Desktop: no hamburger, normal nav */
@media(min-width:981px){
  .nav-toggle,
  .nav-mobile-lang{
    display:none !important;
  }

  .nav-links{
    display:flex !important;
  }

  .nav-shell > .lang-switcher{
    display:flex !important;
  }

  .nav-shell > .nav-cta{
    display:inline-flex !important;
  }
}


/* ===== v95: EXTERIX transparent logo inserted ===== */
.nav-shell{
  min-height: 92px !important;
}

.nav-logo{
  width: 168px !important;
  flex: 0 0 168px !important;
}

.nav-logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-height: 74px !important;
  object-fit: contain !important;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.28)) !important;
}

.footer-brand img{
  width: 132px !important;
  height:auto !important;
  object-fit: contain !important;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.20)) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height: 84px !important;
  }

  .nav-logo{
    width: 126px !important;
    flex-basis: 126px !important;
  }

  .nav-logo img{
    max-height: 64px !important;
  }
}


/* ===== v97: use the NEW EXTERIX logo and let it fit properly ===== */
.nav-shell{
  min-height: 122px !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.nav-logo{
  width: 188px !important;
  flex: 0 0 188px !important;
}

.nav-logo img{
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-height: 98px !important;
  object-fit: contain !important;
  filter: drop-shadow(0 10px 26px rgba(0,0,0,.30)) !important;
}

.footer-brand img{
  width: 144px !important;
  height: auto !important;
  object-fit: contain !important;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.22)) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height: 94px !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  .nav-logo{
    width: 126px !important;
    flex-basis: 126px !important;
  }

  .nav-logo img{
    max-height: 72px !important;
  }

  .footer-brand img{
    width: 122px !important;
  }
}


/* ===== v98: smaller logo so it fits and loads fully ===== */
.nav-shell{
  min-height: 106px !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}

.nav-logo{
  width: 154px !important;
  flex: 0 0 154px !important;
}

.nav-logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-height:80px !important;
  object-fit:contain !important;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,.26)) !important;
}

.footer-brand img{
  width:118px !important;
  height:auto !important;
  object-fit:contain !important;
}

@media (max-width:980px){
  .nav-shell{
    min-height: 88px !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }

  .nav-logo{
    width: 112px !important;
    flex-basis: 112px !important;
  }

  .nav-logo img{
    max-height:64px !important;
  }

  .footer-brand img{
    width:104px !important;
  }
}


/* ===== v99: premium horizontal EXTERIX logo integration ===== */
.nav-shell{
  min-height: 116px !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.nav-logo{
  width: 250px !important;
  flex: 0 0 250px !important;
}

.nav-logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-height:86px !important;
  object-fit:contain !important;
  object-position:left center !important;
  filter: drop-shadow(0 10px 26px rgba(0,0,0,.28)) !important;
}

.footer-brand img{
  width: 178px !important;
  height:auto !important;
  object-fit:contain !important;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.22)) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height: 90px !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  .nav-logo{
    width: 150px !important;
    flex: 0 0 150px !important;
  }

  .nav-logo img{
    max-height: 54px !important;
  }

  .footer-brand img{
    width: 134px !important;
  }
}


/* ===== v100: premium readable EXTERIX logo ===== */
.nav-shell{
  min-height: 110px !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}

.nav-logo{
  width: 238px !important;
  flex: 0 0 238px !important;
}

.nav-logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-height:78px !important;
  object-fit:contain !important;
  object-position:left center !important;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.24)) !important;
}

.footer-brand img{
  width: 168px !important;
  height:auto !important;
  object-fit:contain !important;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.18)) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height: 88px !important;
    padding-top: 9px !important;
    padding-bottom: 9px !important;
  }

  .nav-logo{
    width: 148px !important;
    flex: 0 0 148px !important;
  }

  .nav-logo img{
    max-height: 52px !important;
  }

  .footer-brand img{
    width: 128px !important;
  }
}


/* ===== v102: cleaner premium logo fit ===== */
.nav-shell{
  min-height: 104px !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.nav-inner,
.nav-content{
  align-items: center !important;
}

.nav-logo{
  width: 228px !important;
  flex: 0 0 228px !important;
  display: flex !important;
  align-items: center !important;
}

.nav-logo img{
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-height: 70px !important;
  object-fit: contain !important;
  object-position: left center !important;
  image-rendering: auto !important;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.22)) brightness(1.03) saturate(1.06) !important;
}

.footer-brand img{
  width: 162px !important;
  height: auto !important;
  object-fit: contain !important;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.18)) brightness(1.02) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height: 86px !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }

  .nav-logo{
    width: 146px !important;
    flex: 0 0 146px !important;
  }

  .nav-logo img{
    max-height: 48px !important;
  }

  .footer-brand img{
    width: 126px !important;
  }
}


/* ===== v103: best EXTERIX metallic logo inserted ===== */
.nav-shell{
  min-height: 108px !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.nav-inner,
.nav-content{
  align-items:center !important;
}

.nav-logo{
  width: 250px !important;
  flex: 0 0 250px !important;
  display:flex !important;
  align-items:center !important;
}

.nav-logo img{
  width: 100% !important;
  height: auto !important;
  max-height: 74px !important;
  object-fit: contain !important;
  object-position: left center !important;
  display:block !important;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.24)) !important;
}

.footer-brand img{
  width: 170px !important;
  height:auto !important;
  object-fit:contain !important;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.18)) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height: 88px !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }

  .nav-logo{
    width: 155px !important;
    flex: 0 0 155px !important;
  }

  .nav-logo img{
    max-height: 50px !important;
  }

  .footer-brand img{
    width: 128px !important;
  }
}


/* ===== v104: regenerated clean logo integration ===== */
.nav-shell{
  min-height: 108px !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.nav-logo{
  width: 244px !important;
  flex: 0 0 244px !important;
  display:flex !important;
  align-items:center !important;
}

.nav-logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-height:72px !important;
  object-fit:contain !important;
  object-position:left center !important;
  image-rendering:auto !important;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.20)) !important;
}

.footer-brand img{
  width:166px !important;
  height:auto !important;
  object-fit:contain !important;
  image-rendering:auto !important;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.16)) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height: 88px !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }

  .nav-logo{
    width: 152px !important;
    flex: 0 0 152px !important;
  }

  .nav-logo img{
    max-height: 50px !important;
  }

  .footer-brand img{
    width:128px !important;
  }
}


/* ===== v105: new EXTERIX logo inserted into the new version ===== */
.nav-shell{
  min-height: 108px !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.nav-logo{
  width: 248px !important;
  flex: 0 0 248px !important;
  display:flex !important;
  align-items:center !important;
}

.nav-logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-height:74px !important;
  object-fit:contain !important;
  object-position:left center !important;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,.22)) !important;
}

.footer-brand img{
  width:168px !important;
  height:auto !important;
  object-fit:contain !important;
  filter:drop-shadow(0 6px 14px rgba(0,0,0,.18)) !important;
}

@media (max-width: 980px){
  .nav-shell{
    min-height:88px !important;
    padding-top:8px !important;
    padding-bottom:8px !important;
  }
  .nav-logo{
    width:156px !important;
    flex:0 0 156px !important;
  }
  .nav-logo img{
    max-height:50px !important;
  }
  .footer-brand img{
    width:128px !important;
  }
}


/* ===== v108: hamburger click fix + footer symmetry + nav Contact label ===== */

/* Make sure hamburger is always physically clickable in mobile/tablet mode */
@media (max-width: 980px){
  .nav-shell,
  header.nav-shell{
    overflow: visible !important;
  }

  .nav-toggle{
    display:flex !important;
    position:relative !important;
    z-index:2147483647 !important;
    pointer-events:auto !important;
    cursor:pointer !important;
    touch-action:manipulation !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  .nav-toggle span{
    pointer-events:none !important;
  }

  .nav-links{
    position:relative !important;
    z-index:2147483600 !important;
  }

  .nav-shell.menu-open .nav-links{
    display:flex !important;
  }

  .nav-dropdown-menu{
    z-index:2147483601 !important;
  }
}

/* Footer: cleaner, more symmetrical alignment */
.site-footer,
.premium-footer{
  overflow:hidden;
}

.site-footer .footer-main,
.premium-footer .footer-main,
footer .footer-main{
  align-items:start !important;
}

.footer-brand{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
  gap:12px !important;
}

.footer-brand img{
  display:block !important;
  margin:0 !important;
}

.footer-brand h2,
.footer-brand h3,
.footer-brand strong,
.footer-brand .brand-title,
.footer-brand .footer-brand-title{
  display:none !important;
}

.footer-bottom,
.premium-footer .footer-bottom,
.site-footer .footer-bottom,
footer .footer-bottom{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:18px !important;
  flex-wrap:wrap !important;
  padding-top:18px !important;
  margin-top:18px !important;
  border-top:1px solid rgba(255,255,255,.12) !important;
}

.footer-legal,
.premium-footer .footer-legal,
.site-footer .footer-legal,
footer .footer-legal{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:18px !important;
  flex-wrap:wrap !important;
  margin-left:auto !important;
  text-align:right !important;
}

.footer-legal a,
footer .footer-legal a{
  display:inline-flex !important;
  align-items:center !important;
  min-height:28px !important;
  line-height:1.2 !important;
}

@media(max-width:760px){
  .footer-main,
  .site-footer .footer-main,
  .premium-footer .footer-main,
  footer .footer-main{
    grid-template-columns:1fr !important;
    gap:24px !important;
    text-align:left !important;
  }

  .footer-brand{
    align-items:center !important;
    text-align:center !important;
  }

  .footer-bottom,
  .premium-footer .footer-bottom,
  .site-footer .footer-bottom,
  footer .footer-bottom{
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    gap:12px !important;
  }

  .footer-legal,
  .premium-footer .footer-legal,
  .site-footer .footer-legal,
  footer .footer-legal{
    margin-left:0 !important;
    justify-content:center !important;
    text-align:center !important;
    gap:14px !important;
  }
}


/* ===== v109: desktop footer symmetry polish ===== */
/* Desktop: put copyright and legal links cleanly underneath the footer columns,
   centered and symmetrical. Mobile keeps the already-good stacked layout. */

@media (min-width: 761px){
  .site-footer.premium-footer,
  .premium-footer,
  .site-footer,
  footer{
    text-align:left !important;
  }

  .site-footer.premium-footer .footer-main,
  .premium-footer .footer-main,
  .site-footer .footer-main,
  footer .footer-main{
    align-items:start !important;
    gap:32px !important;
    padding-bottom:18px !important;
  }

  .site-footer.premium-footer .footer-bottom,
  .premium-footer .footer-bottom,
  .site-footer .footer-bottom,
  footer .footer-bottom{
    display:grid !important;
    grid-template-columns:1fr !important;
    justify-items:center !important;
    align-items:center !important;
    gap:10px !important;
    width:100% !important;
    margin-top:20px !important;
    padding-top:18px !important;
    border-top:1px solid rgba(255,255,255,.12) !important;
    text-align:center !important;
  }

  .footer-copyright,
  .site-footer .footer-copyright,
  .premium-footer .footer-copyright{
    display:block !important;
    width:100% !important;
    text-align:center !important;
    margin:0 !important;
    color:rgba(235,245,255,.72) !important;
    line-height:1.45 !important;
  }

  .footer-legal,
  .site-footer .footer-legal,
  .premium-footer .footer-legal,
  footer .footer-legal{
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
    gap:22px !important;
    margin:0 !important;
    width:100% !important;
    text-align:center !important;
  }

  .footer-legal a,
  footer .footer-legal a{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:28px !important;
    line-height:1.2 !important;
    color:rgba(235,245,255,.78) !important;
  }

  .footer-legal a:hover,
  footer .footer-legal a:hover{
    color:#ffffff !important;
  }
}

/* Keep mobile centered and clean */
@media (max-width:760px){
  .site-footer.premium-footer .footer-bottom,
  .premium-footer .footer-bottom,
  .site-footer .footer-bottom,
  footer .footer-bottom{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
  }

  .footer-legal,
  .site-footer .footer-legal,
  .premium-footer .footer-legal,
  footer .footer-legal{
    justify-content:center !important;
    margin-left:0 !important;
  }
}


/* ===== v111: cleaner desktop footer ===== */
footer,
.site-footer,
.premium-footer {
  position: relative;
}

footer .footer-main,
.site-footer .footer-main,
.premium-footer .footer-main {
  width: 100%;
}

@media (min-width: 900px) {
  /* Main footer columns */
  footer .footer-main,
  .site-footer .footer-main,
  .premium-footer .footer-main {
    display: grid !important;
    grid-template-columns: minmax(180px, 220px) minmax(150px, 1fr) minmax(170px, 1fr) minmax(170px, 1fr) !important;
    align-items: start !important;
    gap: 32px !important;
    padding-bottom: 22px !important;
  }

  /* Brand column smaller and cleaner */
  footer .footer-brand,
  .site-footer .footer-brand,
  .premium-footer .footer-brand {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    min-width: 0 !important;
  }

  footer .footer-brand img,
  .site-footer .footer-brand img,
  .premium-footer .footer-brand img {
    width: 150px !important;
    max-width: 150px !important;
    height: auto !important;
    object-fit: contain !important;
    margin: 0 !important;
  }

  footer .footer-brand h1,
  footer .footer-brand h2,
  footer .footer-brand h3,
  footer .footer-brand h4,
  footer .footer-brand p,
  footer .footer-brand span:not(.footer-badge),
  .site-footer .footer-brand h1,
  .site-footer .footer-brand h2,
  .site-footer .footer-brand h3,
  .site-footer .footer-brand h4,
  .site-footer .footer-brand p,
  .site-footer .footer-brand span:not(.footer-badge),
  .premium-footer .footer-brand h1,
  .premium-footer .footer-brand h2,
  .premium-footer .footer-brand h3,
  .premium-footer .footer-brand h4,
  .premium-footer .footer-brand p,
  .premium-footer .footer-brand span:not(.footer-badge) {
    display: none !important;
  }

  /* All column blocks align equally */
  footer .footer-col,
  footer .footer-column,
  footer .footer-nav,
  footer .footer-links,
  .site-footer .footer-col,
  .site-footer .footer-column,
  .site-footer .footer-nav,
  .site-footer .footer-links,
  .premium-footer .footer-col,
  .premium-footer .footer-column,
  .premium-footer .footer-nav,
  .premium-footer .footer-links {
    min-width: 0 !important;
  }

  footer .footer-main h4,
  footer .footer-main .footer-title,
  .site-footer .footer-main h4,
  .site-footer .footer-main .footer-title,
  .premium-footer .footer-main h4,
  .premium-footer .footer-main .footer-title {
    margin: 0 0 12px 0 !important;
    line-height: 1.2 !important;
  }

  footer .footer-main a,
  footer .footer-main li,
  footer .footer-main p,
  .site-footer .footer-main a,
  .site-footer .footer-main li,
  .site-footer .footer-main p,
  .premium-footer .footer-main a,
  .premium-footer .footer-main li,
  .premium-footer .footer-main p {
    line-height: 1.55 !important;
  }

  /* Bottom legal row separated underneath, centered */
  footer .footer-bottom,
  .site-footer .footer-bottom,
  .premium-footer .footer-bottom {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    text-align: center !important;
    border-top: 1px solid rgba(255,255,255,.12) !important;
    margin-top: 18px !important;
    padding-top: 18px !important;
  }

  footer .footer-copyright,
  .site-footer .footer-copyright,
  .premium-footer .footer-copyright {
    margin: 0 !important;
    width: 100% !important;
    text-align: center !important;
    line-height: 1.4 !important;
  }

  footer .footer-legal,
  .site-footer .footer-legal,
  .premium-footer .footer-legal {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 24px !important;
    margin: 0 !important;
    width: 100% !important;
    text-align: center !important;
  }

  footer .footer-legal a,
  .site-footer .footer-legal a,
  .premium-footer .footer-legal a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    white-space: nowrap !important;
  }
}

/* Tablet/mobile keep it compact and centered */
@media (max-width: 899px) {
  footer .footer-main,
  .site-footer .footer-main,
  .premium-footer .footer-main {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  footer .footer-brand,
  .site-footer .footer-brand,
  .premium-footer .footer-brand {
    align-items: center !important;
    text-align: center !important;
  }

  footer .footer-brand img,
  .site-footer .footer-brand img,
  .premium-footer .footer-brand img {
    width: 135px !important;
    height: auto !important;
  }

  footer .footer-bottom,
  .site-footer .footer-bottom,
  .premium-footer .footer-bottom {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    text-align: center !important;
  }

  footer .footer-legal,
  .site-footer .footer-legal,
  .premium-footer .footer-legal {
    justify-content: center !important;
    gap: 14px !important;
    margin: 0 !important;
  }
}


/* ===== v112: footer legal group + thank/error background polish ===== */

/* Bedankt/error pages get the same visual depth as the homepage */
.service-page-body .bg-parallax,
.service-page-body .bg-light-sweep,
.service-page-body .bg-particles,
.service-page-body .background-flow{
  display:block !important;
}

/* Desktop footer: legal links together, copyright underneath */
@media (min-width: 900px){
  footer .footer-bottom,
  .site-footer .footer-bottom,
  .premium-footer .footer-bottom{
    display:flex !important;
    flex-direction:column-reverse !important;
    align-items:center !important;
    justify-content:center !important;
    gap:10px !important;
    width:100% !important;
    text-align:center !important;
    border-top:1px solid rgba(255,255,255,.12) !important;
    margin-top:20px !important;
    padding-top:18px !important;
  }

  footer .footer-legal,
  .site-footer .footer-legal,
  .premium-footer .footer-legal{
    order:1 !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:26px !important;
    width:auto !important;
    margin:0 !important;
    padding:0 !important;
    text-align:center !important;
  }

  footer .footer-copyright,
  .site-footer .footer-copyright,
  .premium-footer .footer-copyright{
    order:2 !important;
    display:block !important;
    width:100% !important;
    margin:0 !important;
    text-align:center !important;
    color:rgba(235,245,255,.70) !important;
    line-height:1.4 !important;
  }

  footer .footer-legal a,
  .site-footer .footer-legal a,
  .premium-footer .footer-legal a{
    white-space:nowrap !important;
    min-height:28px !important;
    display:inline-flex !important;
    align-items:center !important;
  }

  /* Keep columns balanced without making the logo dominate */
  footer .footer-main,
  .site-footer .footer-main,
  .premium-footer .footer-main{
    grid-template-columns:minmax(150px, 190px) repeat(3, minmax(160px, 1fr)) !important;
    gap:34px !important;
  }

  footer .footer-brand img,
  .site-footer .footer-brand img,
  .premium-footer .footer-brand img{
    width:138px !important;
    max-width:138px !important;
  }
}

/* Mobile stays stacked cleanly: links together, rights below */
@media (max-width:899px){
  footer .footer-bottom,
  .site-footer .footer-bottom,
  .premium-footer .footer-bottom{
    display:flex !important;
    flex-direction:column-reverse !important;
    align-items:center !important;
    gap:10px !important;
  }

  footer .footer-legal,
  .site-footer .footer-legal,
  .premium-footer .footer-legal{
    display:flex !important;
    justify-content:center !important;
    gap:16px !important;
    flex-wrap:wrap !important;
  }

  footer .footer-copyright,
  .site-footer .footer-copyright,
  .premium-footer .footer-copyright{
    text-align:center !important;
  }
}


/* ===== v113: styled form error page ===== */
.form-error-page{
  min-height:100vh !important;
  background:#06111f !important;
}

.form-error-page .bg-parallax,
.form-error-page .bg-light-sweep,
.form-error-page .bg-particles,
.form-error-page .background-flow{
  display:block !important;
}

.form-message-wrap{
  min-height:100vh !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding-top:80px !important;
  padding-bottom:80px !important;
}

.form-message-card{
  width:min(820px, 100%) !important;
  margin:0 auto !important;
  padding:42px !important;
  border-radius:28px !important;
  background:
    linear-gradient(180deg, rgba(8,20,37,.88), rgba(6,16,30,.78)),
    linear-gradient(135deg, rgba(0,168,255,.10), rgba(140,198,63,.08)) !important;
  border:1px solid rgba(255,255,255,.13) !important;
  box-shadow:
    0 28px 90px rgba(0,0,0,.38),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter: blur(18px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(140%) !important;
  text-align:left !important;
}

.form-message-card h1{
  margin-top:10px !important;
  margin-bottom:14px !important;
}

.form-message-info{
  display:flex !important;
  flex-direction:column !important;
  gap:6px !important;
  margin:24px 0 26px !important;
  padding:18px 20px !important;
  border-radius:18px !important;
  background:rgba(255,255,255,.055) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  color:rgba(235,247,255,.82) !important;
}

.form-message-info strong{
  color:#ffffff !important;
  font-weight:900 !important;
}

.form-message-info span{
  color:rgba(235,247,255,.72) !important;
  line-height:1.55 !important;
}

@media(max-width:760px){
  .form-message-wrap{
    padding-top:46px !important;
    padding-bottom:46px !important;
  }

  .form-message-card{
    padding:28px 22px !important;
    border-radius:22px !important;
  }

  .form-message-card .hero-buttons{
    flex-direction:column !important;
    align-items:stretch !important;
  }

  .form-message-card .btn{
    width:100% !important;
    justify-content:center !important;
  }
}


/* ===== v114: complete footer rebuild ===== */
/* This footer ignores older footer rules and uses a clean fixed structure. */

footer.ex-footer.site-footer.premium-footer{
  width:min(100% - 48px, 1220px) !important;
  margin:70px auto 34px !important;
  padding:30px 34px 22px !important;
  border-radius:26px !important;
  background:
    linear-gradient(180deg, rgba(8,22,39,.86), rgba(5,15,29,.76)),
    linear-gradient(135deg, rgba(0,168,255,.08), rgba(140,198,63,.055)) !important;
  border:1px solid rgba(255,255,255,.13) !important;
  box-shadow:
    0 24px 70px rgba(0,0,0,.30),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter:blur(18px) saturate(135%) !important;
  -webkit-backdrop-filter:blur(18px) saturate(135%) !important;
  box-sizing:border-box !important;
}

.ex-footer-main{
  display:grid !important;
  grid-template-columns:180px 1fr 1fr 1.15fr !important;
  gap:38px !important;
  align-items:start !important;
  width:100% !important;
}

.ex-footer-brand{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
  min-width:0 !important;
}

.ex-footer-brand img{
  width:145px !important;
  max-width:145px !important;
  height:auto !important;
  display:block !important;
  object-fit:contain !important;
  margin:0 !important;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,.22)) !important;
}

.ex-footer-col{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  gap:8px !important;
  min-width:0 !important;
  text-align:left !important;
}

.ex-footer-col h4{
  margin:0 0 6px !important;
  color:#ffffff !important;
  font-size:13px !important;
  line-height:1.2 !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
  letter-spacing:.04em !important;
}

.ex-footer-col a,
.ex-footer-col span{
  color:rgba(235,247,255,.78) !important;
  text-decoration:none !important;
  font-size:14px !important;
  font-weight:700 !important;
  line-height:1.35 !important;
}

.ex-footer-col a:hover{
  color:#ffffff !important;
}

.ex-footer-bottom{
  margin-top:24px !important;
  padding-top:18px !important;
  border-top:1px solid rgba(255,255,255,.12) !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  text-align:center !important;
  width:100% !important;
}

.ex-footer-legal{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:12px !important;
  flex-wrap:wrap !important;
  width:100% !important;
  margin:0 !important;
  padding:0 !important;
}

.ex-footer-legal a,
.ex-footer-legal span{
  color:rgba(235,247,255,.82) !important;
  text-decoration:none !important;
  font-size:14px !important;
  font-weight:800 !important;
  line-height:1.2 !important;
}

.ex-footer-legal a:hover{
  color:#ffffff !important;
}

.ex-footer-copy{
  color:rgba(235,247,255,.62) !important;
  font-size:13px !important;
  font-weight:700 !important;
  line-height:1.35 !important;
  margin:0 !important;
}

@media(max-width:980px){
  footer.ex-footer.site-footer.premium-footer{
    width:min(100% - 28px, 720px) !important;
    margin:54px auto 24px !important;
    padding:28px 22px 22px !important;
  }

  .ex-footer-main{
    grid-template-columns:1fr 1fr !important;
    gap:26px 24px !important;
  }

  .ex-footer-brand{
    grid-column:1 / -1 !important;
    justify-content:center !important;
  }

  .ex-footer-brand img{
    width:138px !important;
    max-width:138px !important;
  }
}

@media(max-width:620px){
  footer.ex-footer.site-footer.premium-footer{
    width:min(100% - 24px, 520px) !important;
    padding:26px 20px 22px !important;
    border-radius:22px !important;
  }

  .ex-footer-main{
    grid-template-columns:1fr !important;
    gap:22px !important;
    text-align:center !important;
  }

  .ex-footer-brand,
  .ex-footer-col{
    align-items:center !important;
    text-align:center !important;
  }

  .ex-footer-brand img{
    width:128px !important;
    max-width:128px !important;
  }

  .ex-footer-bottom{
    margin-top:20px !important;
  }

  .ex-footer-legal{
    gap:10px !important;
  }
}


/* ===== v115: compact language dropdown ===== */
.lang-menu-switcher{
  position:relative !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  min-width:74px !important;
  z-index:2147483000 !important;
}

.lang-current{
  min-width:74px !important;
  height:38px !important;
  padding:0 12px !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.12) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.085), rgba(255,255,255,.035)) !important;
  color:#ffffff !important;
  font-weight:900 !important;
  font-size:12px !important;
  letter-spacing:.04em !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:7px !important;
  cursor:pointer !important;
  box-shadow:
    0 12px 26px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.lang-current-arrow{
  font-size:11px !important;
  opacity:.75 !important;
  transform:translateY(-1px);
}

.lang-menu{
  position:absolute !important;
  top:calc(100% + 8px) !important;
  right:0 !important;
  min-width:86px !important;
  padding:7px !important;
  border-radius:16px !important;
  background:
    linear-gradient(180deg, rgba(8,22,39,.96), rgba(5,15,29,.90)) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  box-shadow:
    0 22px 50px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.07) !important;
  backdrop-filter:blur(16px) saturate(140%) !important;
  -webkit-backdrop-filter:blur(16px) saturate(140%) !important;
  display:none !important;
  flex-direction:column !important;
  gap:5px !important;
}

.lang-menu-switcher.open .lang-menu,
.lang-menu-switcher:hover .lang-menu,
.lang-menu-switcher:focus-within .lang-menu{
  display:flex !important;
}

.lang-menu .lang-btn{
  width:100% !important;
  min-height:32px !important;
  border-radius:11px !important;
  border:1px solid rgba(255,255,255,.075) !important;
  background:rgba(255,255,255,.035) !important;
  color:rgba(235,247,255,.72) !important;
  font-size:12px !important;
  font-weight:900 !important;
  letter-spacing:.04em !important;
  cursor:pointer !important;
}

.lang-menu .lang-btn:hover,
.lang-menu .lang-btn.active{
  color:#ffffff !important;
  border-color:rgba(140,198,63,.34) !important;
  background:rgba(140,198,63,.13) !important;
  box-shadow:0 0 16px rgba(140,198,63,.12) !important;
}

/* On tablet/mobile, language remains inside the hamburger menu. */
@media(max-width:980px){
  header.nav-shell > .lang-menu-switcher{
    display:none !important;
  }
}


/* ===== v116: hamburger breakpoint increased to 1100px ===== */
/* Between 981px and 1100px the navbar was too tight, so tablet/small laptop uses hamburger. */

@media (max-width:1100px){
  .nav-shell.nav-mobile-ready{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:10px !important;
    min-height:90px !important;
    padding:10px 12px !important;
    overflow:visible !important;
  }

  .nav-logo{
    width:165px !important;
    flex:0 0 165px !important;
  }

  .nav-logo img{
    max-height:52px !important;
  }

  header.nav-shell > .lang-menu-switcher,
  header.nav-shell > .lang-switcher,
  .nav-shell > .nav-cta{
    display:none !important;
  }

  .nav-toggle{
    display:flex !important;
    position:relative !important;
    z-index:2147483647 !important;
    pointer-events:auto !important;
    cursor:pointer !important;
    touch-action:manipulation !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  .nav-toggle span{
    pointer-events:none !important;
  }

  .nav-links{
    display:none !important;
    grid-column:1 / -1 !important;
    width:100% !important;
    margin:10px 0 0 !important;
    padding:10px !important;
    border-radius:20px !important;
    background:
      linear-gradient(180deg, rgba(4,12,24,.94), rgba(4,12,24,.76)),
      linear-gradient(135deg, rgba(0,168,255,.08), rgba(140,198,63,.05)) !important;
    border:1px solid rgba(255,255,255,.11) !important;
    box-shadow:
      0 22px 52px rgba(0,0,0,.36),
      inset 0 1px 0 rgba(255,255,255,.055) !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
    overflow:visible !important;
    position:relative !important;
    z-index:2147483600 !important;
  }

  .nav-shell.menu-open .nav-links{
    display:flex !important;
  }

  .nav-links > a,
  .nav-dropbtn{
    width:100% !important;
    min-height:44px !important;
    padding:0 14px !important;
    border-radius:14px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    text-align:left !important;
    background:rgba(255,255,255,.035) !important;
    border:1px solid rgba(255,255,255,.065) !important;
    color:#eef8ff !important;
    font-size:14px !important;
    font-weight:850 !important;
    letter-spacing:.02em !important;
  }

  .nav-dropdown{
    width:100% !important;
    position:relative !important;
    display:block !important;
  }

  .nav-dropbtn{
    justify-content:space-between !important;
  }

  .nav-dropdown-menu{
    position:static !important;
    display:none !important;
    width:100% !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:none !important;
    margin:8px 0 0 !important;
    padding:8px !important;
    border-radius:16px !important;
    background:linear-gradient(180deg, rgba(0,0,0,.24), rgba(255,255,255,.025)) !important;
    border:1px solid rgba(255,255,255,.07) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.035) !important;
    z-index:2147483601 !important;
  }

  .nav-dropdown.open .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu{
    display:grid !important;
    gap:6px !important;
  }

  .nav-mobile-lang{
    display:none !important;
  }

  .nav-shell.menu-open .nav-mobile-lang{
    display:block !important;
    margin-top:2px !important;
    padding-top:4px !important;
  }

  .nav-mobile-lang-buttons{
    display:grid !important;
    grid-template-columns:repeat(3,1fr) !important;
    gap:8px !important;
  }

  .nav-mobile-lang .lang-btn{
    width:100% !important;
    min-height:40px !important;
    border-radius:999px !important;
    border:1px solid rgba(255,255,255,.10) !important;
    background:rgba(255,255,255,.045) !important;
    color:var(--muted) !important;
    font-size:12px !important;
    font-weight:900 !important;
    letter-spacing:.04em !important;
  }

  .nav-mobile-lang .lang-btn.active{
    color:#ffffff !important;
    border-color:rgba(140,198,63,.34) !important;
    background:rgba(140,198,63,.12) !important;
    box-shadow:0 0 18px rgba(140,198,63,.12) !important;
  }
}

@media (min-width:1101px){
  .nav-toggle,
  .nav-mobile-lang{
    display:none !important;
  }

  .nav-links{
    display:flex !important;
  }

  header.nav-shell > .lang-menu-switcher{
    display:flex !important;
  }

  .nav-shell > .nav-cta{
    display:inline-flex !important;
  }
}


/* ===== v117: fix white/bugged nav bar between 981px and 1100px ===== */
/* Force the tablet/small-laptop nav to use the same dark glass hamburger styling. */

@media (min-width:981px) and (max-width:1100px){
  header.nav-shell,
  .nav-shell,
  body > header.nav-shell{
    position:sticky !important;
    top:14px !important;
    z-index:2147483647 !important;
    width:min(100% - 32px, 1220px) !important;
    margin:14px auto 0 !important;
    min-height:90px !important;
    padding:10px 14px !important;
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:12px !important;
    overflow:visible !important;
    border-radius:24px !important;
    background:
      linear-gradient(180deg, rgba(6,18,34,.88), rgba(5,15,29,.72)),
      linear-gradient(135deg, rgba(0,168,255,.08), rgba(140,198,63,.055)) !important;
    border:1px solid rgba(255,255,255,.13) !important;
    box-shadow:
      0 18px 55px rgba(0,0,0,.32),
      inset 0 1px 0 rgba(255,255,255,.08) !important;
    backdrop-filter:blur(18px) saturate(140%) !important;
    -webkit-backdrop-filter:blur(18px) saturate(140%) !important;
  }

  .nav-logo{
    grid-column:1 / 2 !important;
    width:165px !important;
    flex:0 0 165px !important;
    min-width:0 !important;
  }

  .nav-logo img{
    max-height:52px !important;
    width:100% !important;
    object-fit:contain !important;
    display:block !important;
  }

  header.nav-shell > .lang-menu-switcher,
  header.nav-shell > .lang-switcher,
  header.nav-shell > .nav-cta,
  .nav-shell > .nav-cta{
    display:none !important;
  }

  .nav-toggle{
    grid-column:3 / 4 !important;
    justify-self:end !important;
    display:flex !important;
    position:relative !important;
    width:44px !important;
    height:40px !important;
    border-radius:14px !important;
    border:1px solid rgba(255,255,255,.12) !important;
    background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)) !important;
    align-items:center !important;
    justify-content:center !important;
    flex-direction:column !important;
    gap:5px !important;
    z-index:2147483647 !important;
    pointer-events:auto !important;
    cursor:pointer !important;
    touch-action:manipulation !important;
    box-shadow:0 12px 28px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.08) !important;
  }

  .nav-toggle span{
    display:block !important;
    width:19px !important;
    height:2px !important;
    border-radius:999px !important;
    background:#ffffff !important;
    pointer-events:none !important;
  }

  .nav-links{
    grid-column:1 / -1 !important;
    display:none !important;
    width:100% !important;
    margin:10px 0 0 !important;
    padding:10px !important;
    border-radius:20px !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
    overflow:visible !important;
    position:relative !important;
    z-index:2147483600 !important;
    background:
      linear-gradient(180deg, rgba(4,12,24,.94), rgba(4,12,24,.78)),
      linear-gradient(135deg, rgba(0,168,255,.08), rgba(140,198,63,.055)) !important;
    border:1px solid rgba(255,255,255,.11) !important;
    box-shadow:0 22px 52px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.055) !important;
  }

  .nav-shell.menu-open .nav-links{
    display:flex !important;
  }

  .nav-links > a,
  .nav-dropbtn{
    width:100% !important;
    min-height:44px !important;
    padding:0 14px !important;
    border-radius:14px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    text-align:left !important;
    color:#eef8ff !important;
    background:rgba(255,255,255,.035) !important;
    border:1px solid rgba(255,255,255,.065) !important;
    font-size:14px !important;
    font-weight:850 !important;
    letter-spacing:.02em !important;
  }

  .nav-dropdown{
    width:100% !important;
    position:relative !important;
    display:block !important;
  }

  .nav-dropbtn{
    justify-content:space-between !important;
  }

  .nav-dropdown-menu{
    position:static !important;
    display:none !important;
    width:100% !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:none !important;
    margin:8px 0 0 !important;
    padding:8px !important;
    border-radius:16px !important;
    background:linear-gradient(180deg, rgba(0,0,0,.24), rgba(255,255,255,.025)) !important;
    border:1px solid rgba(255,255,255,.07) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.035) !important;
  }

  .nav-dropdown.open .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu{
    display:grid !important;
    gap:6px !important;
  }

  .nav-mobile-lang{
    display:none !important;
  }

  .nav-shell.menu-open .nav-mobile-lang{
    display:block !important;
  }
}

/* Safety: from 1101px back to true desktop nav */
@media (min-width:1101px){
  header.nav-shell,
  .nav-shell{
    display:flex !important;
  }

  .nav-toggle,
  .nav-mobile-lang{
    display:none !important;
  }

  .nav-links{
    display:flex !important;
  }

  header.nav-shell > .lang-menu-switcher{
    display:flex !important;
  }

  header.nav-shell > .nav-cta,
  .nav-shell > .nav-cta{
    display:inline-flex !important;
  }
}


/* ===== v118: mobile hamburger tap fix ===== */
@media (max-width:1100px){
  header.nav-shell,
  .nav-shell{
    overflow:visible !important;
  }

  .nav-toggle{
    display:flex !important;
    position:relative !important;
    z-index:2147483647 !important;
    pointer-events:auto !important;
    cursor:pointer !important;
    touch-action:manipulation !important;
    -webkit-tap-highlight-color:transparent !important;
    user-select:none !important;
  }

  .nav-toggle span{
    pointer-events:none !important;
  }

  .nav-shell.menu-open .nav-links{
    display:flex !important;
    pointer-events:auto !important;
  }
}


/* ===== v121: performance speed boost ===== */
/* Main lag sources on desktop were heavy fixed layers, blur filters and many animated effects. 
   This keeps the look, but makes the GPU/paint work much lighter. */

.bg-parallax{
  animation-duration:34s !important;
  transform:translate3d(var(--bgx,0px), calc(var(--bgy,0px) + var(--bgscroll,0px)), 0) scale(1.04) !important;
  filter:saturate(1.02) contrast(1.02) brightness(.98) !important;
  will-change:transform !important;
}

.background-flow{
  opacity:.28 !important;
  filter:blur(28px) !important;
  animation-duration:30s !important;
  will-change:transform !important;
}

.bg-light-sweep{
  opacity:.30 !important;
  animation-duration:24s !important;
}

.bg-particles{
  opacity:.07 !important;
  animation-duration:42s !important;
}

/* Backdrop blur is visually nice but expensive. Keep glass look with lighter blur. */
.nav-shell,
.panel,
.ex-footer,
.form-message-card,
.service-card,
.result-card,
.card,
.premium-card{
  backdrop-filter:blur(6px) saturate(112%) !important;
  -webkit-backdrop-filter:blur(6px) saturate(112%) !important;
}

/* Offscreen rendering optimization */
section,
.panel,
.ex-footer,
.service-page,
.results,
.services-grid,
.compare-box{
  content-visibility:auto;
  contain-intrinsic-size:1px 700px;
}

/* Reduce hover shine costs */
.service-card::before,
.result-card::before,
.card::before{
  transition-duration:.22s !important;
}

/* Mobile/tablet: keep even lighter */
@media(max-width:1100px){
  .background-flow{
    opacity:.22 !important;
    filter:blur(22px) !important;
  }

  .bg-particles{
    display:none !important;
  }

  .nav-shell,
  .panel,
  .ex-footer,
  .form-message-card{
    backdrop-filter:blur(4px) saturate(108%) !important;
    -webkit-backdrop-filter:blur(4px) saturate(108%) !important;
  }
}

/* Users/devices that prefer less motion get almost static effects */
@media (prefers-reduced-motion: reduce){
  .bg-parallax,
  .background-flow,
  .bg-light-sweep,
  .bg-particles{
    animation:none !important;
  }
}


/* ===== v122: performance mode — motion mostly only in hero ===== */
/* Goal: keep premium look, but stop expensive full-page fixed animations while scrolling. */

/* Global background stays visible but becomes mostly static */
.bg-parallax{
  animation:none !important;
  transform:translate3d(0,0,0) scale(1.035) !important;
  will-change:auto !important;
}

.background-flow{
  animation:none !important;
  opacity:.18 !important;
  filter:blur(20px) !important;
  will-change:auto !important;
}

.bg-light-sweep{
  animation:none !important;
  opacity:.22 !important;
}

.bg-particles{
  display:none !important;
}

/* Hero gets the premium moving effect instead of the whole page */
.hero{
  position:relative !important;
  overflow:hidden !important;
  isolation:isolate !important;
}

.hero::before{
  content:"" !important;
  position:absolute !important;
  inset:-18% !important;
  z-index:0 !important;
  pointer-events:none !important;
  background:
    radial-gradient(circle at 18% 18%, rgba(0,168,255,.18), transparent 24%),
    radial-gradient(circle at 82% 16%, rgba(140,198,63,.16), transparent 22%),
    radial-gradient(circle at 72% 84%, rgba(0,168,255,.10), transparent 26%) !important;
  filter:blur(36px) !important;
  opacity:.78 !important;
  animation:exHeroGlowMove 18s ease-in-out infinite alternate !important;
}

.hero::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:0 !important;
  pointer-events:none !important;
  background:
    linear-gradient(115deg, transparent 0%, rgba(255,255,255,.045) 44%, transparent 62%) !important;
  opacity:.52 !important;
  animation:exHeroSweep 12s ease-in-out infinite alternate !important;
}

.hero > *{
  position:relative !important;
  z-index:1 !important;
}

@keyframes exHeroGlowMove{
  0%{ transform:translate3d(-1.5%, -1%, 0) scale(1); }
  100%{ transform:translate3d(1.5%, 1.2%, 0) scale(1.04); }
}

@keyframes exHeroSweep{
  0%{ transform:translateX(-4%); opacity:.36; }
  100%{ transform:translateX(4%); opacity:.58; }
}

/* Less costly glass below the hero */
section:not(.hero),
.panel:not(.hero),
.ex-footer,
.service-card,
.result-card,
.form-message-card{
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}

/* Keep only nav glass premium */
.nav-shell{
  backdrop-filter:blur(6px) saturate(112%) !important;
  -webkit-backdrop-filter:blur(6px) saturate(112%) !important;
}

/* Reduce repaint-heavy shadows slightly */
.service-card,
.result-card,
.panel,
.ex-footer{
  box-shadow:0 16px 44px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.06) !important;
}

/* Extra safety on smaller devices */
@media(max-width:1100px){
  .hero::before{
    filter:blur(24px) !important;
    opacity:.55 !important;
    animation-duration:22s !important;
  }

  .hero::after{
    display:none !important;
  }
}


/* ===== v123: Services dropdown and scroll polish ===== */
.nav-dropbtn{
  white-space:nowrap !important;
}

#home,
#diensten,
#resultaten,
#offerte{
  scroll-margin-top:120px;
}


/* ===== v124: scroll target alignment ===== */
#home,
#diensten,
#resultaten,
#offerte{
  scroll-margin-top:82px !important;
}


/* ===== repair: professional legal page styling ===== */
.legal-page-main{
  padding-top:76px !important;
  padding-bottom:82px !important;
}

.legal-page-hero{
  position:relative !important;
  overflow:hidden !important;
  padding:58px 52px !important;
  margin-bottom:28px !important;
  border-radius:32px !important;
  background:
    linear-gradient(180deg, rgba(8,22,39,.90), rgba(5,15,29,.80)),
    radial-gradient(circle at 82% 18%, rgba(140,198,63,.14), transparent 28%),
    radial-gradient(circle at 12% 22%, rgba(0,168,255,.13), transparent 30%) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:
    0 26px 80px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.legal-page-hero::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  pointer-events:none !important;
  background:linear-gradient(115deg, transparent 0%, rgba(255,255,255,.045) 44%, transparent 62%) !important;
  opacity:.6 !important;
}

.legal-page-hero > *{
  position:relative !important;
  z-index:1 !important;
}

.legal-page-hero h1{
  max-width:900px !important;
  margin:10px 0 16px !important;
  letter-spacing:-.045em !important;
}

.legal-page-hero .legal-intro{
  max-width:850px !important;
  color:rgba(235,247,255,.78) !important;
  font-size:17px !important;
  line-height:1.7 !important;
}

.legal-updated{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  margin-top:16px !important;
  padding:8px 12px !important;
  border-radius:999px !important;
  color:rgba(235,247,255,.70) !important;
  background:rgba(255,255,255,.055) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  font-weight:850 !important;
  font-size:13px !important;
}

.legal-content-grid{
  display:block !important;
}

.legal-toc{
  display:none !important;
}

.legal-content{
  max-width:980px !important;
  margin:0 auto !important;
  padding:34px 36px !important;
  border-radius:28px !important;
  background:
    linear-gradient(180deg, rgba(8,22,39,.68), rgba(5,15,29,.54)) !important;
  border:1px solid rgba(255,255,255,.105) !important;
  box-shadow:0 18px 56px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.055) !important;
}

.legal-content section{
  margin:0 0 34px !important;
  padding:0 0 30px !important;
  border-bottom:1px solid rgba(255,255,255,.085) !important;
}

.legal-content section:last-of-type{
  margin-bottom:0 !important;
  padding-bottom:0 !important;
  border-bottom:0 !important;
}

.legal-content h2{
  color:#fff !important;
  font-size:25px !important;
  line-height:1.18 !important;
  margin:0 0 14px !important;
  letter-spacing:-.025em !important;
}

.legal-content p,
.legal-content li{
  color:rgba(235,247,255,.77) !important;
  line-height:1.78 !important;
  font-size:15.5px !important;
}

.legal-content p{
  margin:0 0 12px !important;
}

.legal-content p:last-child{
  margin-bottom:0 !important;
}

.legal-content ul{
  margin:12px 0 0 0 !important;
  padding:0 !important;
  list-style:none !important;
}

.legal-content li{
  position:relative !important;
  padding-left:22px !important;
  margin:8px 0 !important;
}

.legal-content li::before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  top:.72em !important;
  width:7px !important;
  height:7px !important;
  border-radius:999px !important;
  background:linear-gradient(135deg, #8cc63f, #00a8ff) !important;
  box-shadow:0 0 12px rgba(140,198,63,.25) !important;
}

.legal-content a{
  color:#8cc63f !important;
  text-decoration:none !important;
  font-weight:850 !important;
}

.legal-content a:hover{
  color:#ffffff !important;
}

.legal-note{
  margin-top:30px !important;
  padding:20px 22px !important;
  border-radius:20px !important;
  background:
    linear-gradient(135deg, rgba(0,168,255,.08), rgba(140,198,63,.10)) !important;
  border:1px solid rgba(140,198,63,.22) !important;
  color:rgba(235,247,255,.80) !important;
  line-height:1.7 !important;
}

.legal-note strong{
  color:#fff !important;
}

@media(max-width:900px){
  .legal-page-hero,
  .legal-content{
    padding:30px 22px !important;
    border-radius:24px !important;
  }
}


/* ===== repair: slideshow NA-label positie fix ===== */
.compare-after-label,
.after-label,
.result-after-label,
.slideshow-after-label,
.compare-label.after,
.compare-badge.after,
.before-after-after,
[data-label="NA"],
[data-label="Na"],
[data-label="na"]{
  top:auto !important;
  left:auto !important;
  right:18px !important;
  bottom:18px !important;
  transform:none !important;
  z-index:8 !important;
}

.compare-box .label-after,
.compare-box .after,
.results-slider .label-after,
.results-slider .after,
.before-after .label-after,
.before-after .after{
  top:auto !important;
  left:auto !important;
  right:18px !important;
  bottom:18px !important;
  transform:none !important;
}

@media(max-width:760px){
  .compare-after-label,
  .after-label,
  .result-after-label,
  .slideshow-after-label,
  .compare-label.after,
  .compare-badge.after,
  .before-after-after,
  [data-label="NA"],
  [data-label="Na"],
  [data-label="na"],
  .compare-box .label-after,
  .compare-box .after,
  .results-slider .label-after,
  .results-slider .after,
  .before-after .label-after,
  .before-after .after{
    right:12px !important;
    bottom:12px !important;
  }
}


/* ===== legal pages hardfix: hamburger always works on privacy/voorwaarden ===== */
@media(max-width:1100px){
  body.legal-hamburger-hardfix header.nav-shell{
    overflow:visible !important;
  }

  body.legal-hamburger-hardfix .nav-toggle{
    display:flex !important;
    position:relative !important;
    z-index:2147483647 !important;
    pointer-events:auto !important;
    cursor:pointer !important;
    touch-action:manipulation !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  body.legal-hamburger-hardfix .nav-toggle span{
    pointer-events:none !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-links{
    display:none !important;
  }

  body.legal-hamburger-hardfix header.nav-shell.menu-open .nav-links,
  body.legal-hamburger-hardfix header.nav-shell.legal-menu-open .nav-links{
    display:flex !important;
    pointer-events:auto !important;
  }

  body.legal-hamburger-hardfix .nav-dropdown-menu{
    display:none !important;
  }

  body.legal-hamburger-hardfix .nav-dropdown.open .nav-dropdown-menu{
    display:grid !important;
  }
}


/* ===== legal hamburger position fix ===== */
/* Op privacy/voorwaarden moet de hamburger helemaal rechts staan, niet naast het logo. */
@media(max-width:1100px){
  body.legal-hamburger-hardfix header.nav-shell{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:12px !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-logo{
    grid-column:1 / 2 !important;
    justify-self:start !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-toggle{
    grid-column:3 / 4 !important;
    justify-self:end !important;
    margin-left:auto !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-links{
    grid-column:1 / -1 !important;
    width:100% !important;
  }
}


/* ===== final legal hamburger working + right position fix ===== */
@media(max-width:1100px){
  body.legal-hamburger-hardfix header.nav-shell{
    display:grid !important;
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
    gap:12px !important;
    overflow:visible !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-logo{
    grid-column:1 / 2 !important;
    justify-self:start !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-toggle{
    grid-column:3 / 4 !important;
    justify-self:end !important;
    margin-left:auto !important;
    display:flex !important;
    position:relative !important;
    z-index:2147483647 !important;
    pointer-events:auto !important;
    cursor:pointer !important;
    touch-action:manipulation !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-toggle span{
    pointer-events:none !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-links{
    grid-column:1 / -1 !important;
    width:100% !important;
    display:none !important;
    pointer-events:auto !important;
  }

  body.legal-hamburger-hardfix header.nav-shell.menu-open .nav-links,
  body.legal-hamburger-hardfix header.nav-shell.legal-menu-open .nav-links{
    display:flex !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-dropdown-menu{
    display:none !important;
  }

  body.legal-hamburger-hardfix header.nav-shell .nav-dropdown.open .nav-dropdown-menu{
    display:grid !important;
  }
}
