*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0b1d33;
  --navy-light:#122a47;
  --blue-900:#0f2a4a;
  --blue-800:#163d6b;
  --blue-700:#1e508c;
  --blue-600:#2968ad;
  --blue-500:#3580cc;
  --blue-400:#5199dd;
  --blue-300:#7eb8ec;
  --blue-200:#aed4f5;
  --blue-100:#d6eafa;
  --blue-50:#edf5fc;
  --white:#ffffff;
  --gray-50:#f7f9fb;
  --gray-100:#eef2f6;
  --gray-200:#dce3eb;
  --gray-300:#b8c5d3;
  --gray-400:#8a9aab;
  --gray-500:#60717f;
  --gray-600:#455565;
  --gray-700:#2e3e4e;
  --gray-900:#1a2530;
  --r-sm:10px;--r-md:16px;--r-lg:24px;--r-xl:32px;--r-full:9999px;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'DM Sans',sans-serif;color:var(--gray-600);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Outfit',sans-serif;color:var(--navy);line-height:1.15}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
ul{list-style:none}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:var(--r-full);font-family:'DM Sans',sans-serif;font-weight:600;font-size:.92rem;border:none;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);letter-spacing:.2px}
.btn-fill{background:var(--blue-500);color:#fff}
.btn-fill:hover{background:var(--blue-400);transform:translateY(-2px);box-shadow:0 10px 30px rgba(53,128,204,.35)}
.btn-ghost{background:rgba(255,255,255,.04);color:rgba(255,255,255,.92);border:1.5px solid rgba(255,255,255,.15)}
.btn-ghost:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.28);transform:translateY(-1px)}
.btn-outline-dark{background:transparent;color:var(--blue-600);border:1.5px solid var(--blue-200)}
.btn-outline-dark:hover{background:var(--blue-50);border-color:var(--blue-400)}
.btn svg{width:18px;height:18px;flex-shrink:0}

/* ── Section Labels ── */
.section-label{display:inline-flex;align-items:center;gap:10px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--blue-500);margin-bottom:14px}
.section-label::before{content:'';width:24px;height:2px;background:var(--blue-400);border-radius:2px}
.section-title{font-size:clamp(2rem,4.2vw,2.8rem);font-weight:700;margin-bottom:14px}
.section-desc{font-size:1.05rem;color:var(--gray-400);line-height:1.7;max-width:540px}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes bubbleRise{
   0%{transform:translate3d(0,0,0) scale(.85);opacity:0}
   8%{opacity:var(--alpha,.3)}
   70%{opacity:var(--alpha,.24)}
   88%{transform:translate3d(calc(var(--drift,16px) * .82),-98vh,0) scale(1.12);opacity:calc(var(--alpha,.24) * .8)}
   93%{transform:translate3d(calc(var(--drift,16px) * .92),-104vh,0) scale(1.28);opacity:.14}
   96%{transform:translate3d(var(--drift,16px),-108vh,0) scale(.18);opacity:0}
   100%{transform:translate3d(var(--drift,16px),-108vh,0) scale(0);opacity:0}
}
@keyframes soapShift{0%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(8px,-7px,0) scale(1.05)}100%{transform:translate3d(0,0,0) scale(1)}}
@keyframes heroBreath{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes gradientMove{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes twinkle{
   0%,33%,49%,80%,100%{opacity:0;transform:translate(-50%,-50%) scale(.6) rotate(0deg)}
   37%{opacity:.78;transform:translate(-50%,-50%) scale(.92) rotate(10deg)}
   43%{opacity:.22;transform:translate(-50%,-50%) scale(.72) rotate(16deg)}
   84%{opacity:.96;transform:translate(-50%,-50%) scale(1) rotate(14deg)}
   89%{opacity:.36;transform:translate(-50%,-50%) scale(.72) rotate(20deg)}
}
@keyframes twinkleSoft{
   0%,31%,47%,79%,100%{opacity:0;transform:translate(-50%,-50%) scale(.65)}
   35%{opacity:.58;transform:translate(-50%,-50%) scale(.92)}
   41%{opacity:.16;transform:translate(-50%,-50%) scale(.74)}
   85%{opacity:.9;transform:translate(-50%,-50%) scale(1.08)}
   92%{opacity:.24;transform:translate(-50%,-50%) scale(.76)}
}
@keyframes foamDrift{
   0%{transform:translate3d(0,0,0) scale(.9);opacity:0}
   15%{opacity:.42}
   55%{opacity:.3}
   100%{transform:translate3d(14px,-42px,0) scale(1.2);opacity:0}
}

/* ══════════════════════════════
   SITE HEADER / NAV
   ══════════════════════════════ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:80px;display:flex;align-items:center;overflow:visible;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:rgba(11,29,51,.07);box-shadow:0 1px 24px rgba(11,29,51,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:16px;min-width:0}
/* Logo */
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-img{height:52px;width:auto;object-fit:contain;transition:filter .3s}
.site-header:not(.scrolled) .logo-img{filter:brightness(0) invert(1)}
.site-header.scrolled .logo-img{filter:none}
/* Desktop nav */
#siteNav{display:flex;align-items:center;min-width:0;flex-shrink:1}
ul.nav-links{display:flex;align-items:center;gap:0;list-style:none;margin:0;padding:0;flex-wrap:nowrap;min-width:0}
ul.nav-links>li{display:flex;align-items:center;position:relative}
ul.nav-links>li>a:not(.btn-book-nav),.dropdown-toggle{font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:500;color:rgba(255,255,255,.8);text-decoration:none;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;padding:8px 14px;position:relative;background:none;border:none;cursor:pointer;transition:color .25s}
ul.nav-links>li>a:not(.btn-book-nav)::after,.dropdown-toggle::after{content:'';position:absolute;bottom:2px;left:14px;width:0;height:1px;background:rgba(255,255,255,.6);transition:width .3s ease}
ul.nav-links>li>a:not(.btn-book-nav):hover::after,.dropdown-toggle:hover::after{width:calc(100% - 28px)}
ul.nav-links>li>a:not(.btn-book-nav):hover,.dropdown-toggle:hover{color:#fff}
@media(min-width:769px){
  .site-header.scrolled ul.nav-links>li>a:not(.btn-book-nav),.site-header.scrolled .dropdown-toggle{color:var(--gray-600)}
  .site-header.scrolled ul.nav-links>li>a:not(.btn-book-nav)::after,.site-header.scrolled .dropdown-toggle::after{background:var(--blue-500)}
  .site-header.scrolled ul.nav-links>li>a:not(.btn-book-nav):hover,.site-header.scrolled .dropdown-toggle:hover{color:var(--blue-600)}
}
/* Dropdown */
.has-dropdown{position:relative}
.dropdown-toggle{display:inline-flex;align-items:center;gap:5px}
.dropdown-chevron{flex-shrink:0;transition:transform .25s ease}
.has-dropdown:hover .dropdown-chevron,.has-mega:hover .dropdown-chevron{transform:rotate(180deg)}
/* Call Us */
.btn-call-nav{display:inline-flex;align-items:center;gap:6px;background:transparent!important;color:#fff!important;font-family:'DM Sans',sans-serif!important;font-size:.875rem!important;font-weight:600!important;padding:9px 20px!important;border-radius:var(--r-full)!important;border:1.5px solid rgba(255,255,255,.45)!important;text-decoration:none!important;white-space:nowrap;transition:background .3s,border-color .3s,transform .2s,box-shadow .3s;margin-left:14px;flex-shrink:0}
.btn-call-nav::after{display:none!important}
.btn-call-nav svg{flex-shrink:0}
.btn-call-nav:hover{background:rgba(255,255,255,.1)!important;border-color:#fff!important;transform:translateY(-1px)}
.site-header.scrolled .btn-call-nav{color:var(--blue-500)!important;border-color:var(--blue-500)!important}
.site-header.scrolled .btn-call-nav:hover{background:rgba(53,128,204,.08)!important;border-color:var(--blue-400)!important;color:var(--blue-400)!important}
/* Book Now */
.btn-book-nav{display:inline-flex;align-items:center;background:var(--blue-500)!important;color:#fff!important;font-family:'DM Sans',sans-serif!important;font-size:.875rem!important;font-weight:600!important;padding:10px 22px!important;border-radius:var(--r-full)!important;text-decoration:none!important;white-space:nowrap;transition:background .3s,transform .2s,box-shadow .3s;margin-left:14px;flex-shrink:0}
.btn-book-nav::after{display:none!important}
.btn-book-nav:hover{background:var(--blue-400)!important;transform:translateY(-1px);box-shadow:0 6px 20px rgba(53,128,204,.3)}
/* ── Mega dropdown (desktop) ── */
.mega-dropdown{
  display:none;position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);
  background:#fff;
  border:1px solid rgba(11,29,51,.08);
  border-radius:22px;
  box-shadow:0 4px 6px rgba(11,29,51,.04),0 12px 32px rgba(11,29,51,.1),0 40px 80px rgba(11,29,51,.08);
  z-index:1100;flex-direction:row;gap:0;min-width:320px;overflow:hidden}
/* hover bridge on the li — not clipped by dropdown's overflow:hidden */
.has-mega::before{content:'';position:absolute;top:100%;left:-20px;right:-20px;height:12px;z-index:1099}
/* top inner highlight */
.mega-dropdown::after{display:none}
.has-mega:hover .mega-dropdown{display:flex;animation:megaDrop .22s cubic-bezier(.16,1,.3,1)}
@keyframes megaDrop{from{opacity:0;transform:translateX(-50%) translateY(-10px) scale(.98)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}
/* Col */
.mega-col{padding:24px 20px 24px 24px;flex-shrink:0;flex:1}
.mega-col p.mega-col-label{
  font-family:'DM Sans',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue-500);margin:0 0 16px 4px;opacity:.7}
.mega-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3px}
/* Service link rows */
.mega-link{
  display:flex;align-items:center;gap:13px;
  padding:10px 12px;border-radius:12px;
  text-decoration:none;
  transition:background .18s;
  position:relative}
.mega-link::after{display:none!important}
.mega-link:hover{background:rgba(53,128,204,.06)}
/* Icon box */
.mega-link-icon{
  width:36px;height:36px;flex-shrink:0;
  border-radius:9px;
  background:rgba(53,128,204,.08);
  border:1px solid rgba(53,128,204,.15);
  display:flex;align-items:center;justify-content:center;
  color:var(--blue-500);
  transition:background .18s,border-color .18s,color .18s}
.mega-link:hover .mega-link-icon{background:var(--blue-500);border-color:var(--blue-500);color:#fff}
/* Link text */
.mega-link-text{display:flex;flex-direction:column;gap:2px}
.mega-link-name{font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:600;color:var(--navy);transition:color .18s;white-space:nowrap}
.mega-link-desc{font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:400;color:var(--gray-400);white-space:nowrap;transition:color .18s}
.mega-link:hover .mega-link-name{color:var(--blue-600)}
.mega-link:hover .mega-link-desc{color:var(--gray-600)}
/* Stagger animation on items */
.mega-col ul li:nth-child(1) .mega-link{animation-delay:.03s}
.mega-col ul li:nth-child(2) .mega-link{animation-delay:.07s}
.mega-col ul li:nth-child(3) .mega-link{animation-delay:.11s}
.mega-col ul li:nth-child(4) .mega-link{animation-delay:.15s}
.has-mega:hover .mega-link{animation:megaItemIn .3s cubic-bezier(.16,1,.3,1) both}
@keyframes megaItemIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
/* All services link */
.mega-all-link{
  display:inline-flex;align-items:center;gap:6px;
  margin:10px 12px 6px;padding:9px 12px;
  font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;
  color:var(--blue-500);
  border-top:1px solid rgba(11,29,51,.07);
  text-decoration:none;
  transition:color .2s,gap .2s}
.mega-all-link::after{display:none!important}
.mega-all-link:hover{color:var(--blue-400);gap:10px}
/* Nav toggle (hamburger) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:4px;flex-shrink:0;position:relative;z-index:1001;-webkit-tap-highlight-color:transparent}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transform:translateZ(0);will-change:transform;transition:transform .3s ease,opacity .3s ease,background .3s}
.site-header.scrolled .nav-toggle span{background:var(--gray-600)}
.nav-toggle.open span{background:#fff!important}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ══════════════════════════════
   HERO
   ══════════════════════════════ */
.hero{min-height:100vh;display:flex;align-items:center;padding:120px 0 80px;position:relative;overflow:hidden;
  background-color:var(--navy);
  background-image:url('../images/table.webp');
  background-size:cover;
  background-position:center;
}
.hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 70% 50% at 65% 40%,rgba(53,128,204,.16),transparent),
  radial-gradient(ellipse 50% 60% at 20% 80%,rgba(41,104,173,.1),transparent),
  radial-gradient(ellipse 40% 40% at 80% 10%,rgba(81,153,221,.07),transparent),
  linear-gradient(rgba(11,29,51,.82),rgba(11,29,51,.82));
}
.hero::after{content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:64px 64px;
   animation:soapShift 18s ease-in-out infinite;
}
.hero-bubbles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1;transform:translate3d(0,var(--bubble-parallax,0px),0);will-change:transform;filter:saturate(1.22) contrast(1.08)}
.hero-bubbles::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 52% 58% at 34% 52%,rgba(11,29,51,.5),rgba(11,29,51,.28) 42%,transparent 72%)}
.bubble{
   position:absolute;
   left:var(--left,50%);
   bottom:-64px;
   width:var(--size,14px);
   height:var(--size,14px);
   border-radius:50%;
   background:
      radial-gradient(circle at 28% 24%,rgba(255,255,255,.92),rgba(255,255,255,.35) 18%,transparent 36%),
      radial-gradient(circle at 72% 78%,rgba(81,153,221,.26),transparent 48%),
      conic-gradient(from 120deg,rgba(214,234,250,.5),rgba(126,184,236,.22),rgba(81,153,221,.26),rgba(214,234,250,.52));
   border:1px solid rgba(214,234,250,.45);
   box-shadow:
      inset -5px -8px 12px rgba(11,29,51,.14),
      inset 3px 3px 8px rgba(255,255,255,.2),
      0 0 30px rgba(81,153,221,.26);
   filter:saturate(1.1) hue-rotate(-5deg);
   opacity:0;
   animation:bubbleRise var(--dur,18s) linear infinite;
   animation-delay:var(--delay,0s);
}
.bubble-spark::before,
.bubble-spark::after{
   content:'';
   position:absolute;
   left:50%;
   top:50%;
   pointer-events:none;
   opacity:0;
}
.bubble-spark::before{
   width:16px;
   height:16px;
   background:
      linear-gradient(transparent 46%,rgba(255,255,255,.96) 50%,transparent 54%),
      linear-gradient(90deg,transparent 46%,rgba(255,255,255,.96) 50%,transparent 54%);
   filter:drop-shadow(0 0 8px rgba(255,255,255,.7));
   animation:twinkle 5.4s linear infinite;
   animation-delay:calc(var(--delay,0s) - 1.1s);
}
.bubble-spark::after{
   width:10px;
   height:10px;
   border-radius:50%;
   background:radial-gradient(circle,rgba(255,255,255,.92) 0%,rgba(255,255,255,.15) 62%,transparent 72%);
   filter:blur(.2px) drop-shadow(0 0 8px rgba(214,234,250,.65));
   animation:twinkleSoft 5.4s linear infinite;
   animation-delay:calc(var(--delay,0s) - .8s);
}
.hero-foam{position:absolute;left:0;right:0;bottom:0;height:70px;overflow:hidden;pointer-events:none;z-index:1;transform:translate3d(0,var(--foam-parallax,0px),0);will-change:transform;filter:saturate(1.04)}
.hero-foam::before{
   content:'';
   position:absolute;
   inset:auto 0 0;
   height:36px;
   background:linear-gradient(180deg,rgba(214,234,250,0),rgba(214,234,250,.12) 56%,rgba(214,234,250,.18));
}
.foam-particle{
   position:absolute;
   left:var(--left,50%);
   bottom:6px;
   width:var(--size,8px);
   height:var(--size,8px);
   border-radius:50%;
   background:radial-gradient(circle at 30% 28%,rgba(255,255,255,.95),rgba(214,234,250,.42) 58%,rgba(214,234,250,.08) 76%);
   border:1px solid rgba(214,234,250,.44);
   box-shadow:inset -2px -3px 4px rgba(11,29,51,.08),0 0 10px rgba(214,234,250,.2);
   opacity:0;
   animation:foamDrift var(--dur,6.8s) ease-in-out infinite;
   animation-delay:var(--delay,0s);
}
.hero-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:82px;align-items:center;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(53,128,204,.1);border:1px solid rgba(53,128,204,.18);padding:7px 16px;border-radius:var(--r-full);margin-bottom:24px}
.hero-badge-dot{width:6px;height:6px;background:var(--blue-400);border-radius:50%;animation:pulse 2s infinite}
.hero-badge span{font-size:.76rem;color:var(--blue-300);font-weight:500;letter-spacing:.6px}
.hero h1{font-size:clamp(2.8rem,6.5vw,4.5rem);line-height:1.06;color:#fff;margin-bottom:22px;font-weight:800;max-width:12ch}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--blue-300),var(--blue-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{font-size:1.28rem;color:rgba(255,255,255,.72);line-height:1.68;margin-bottom:34px;max-width:540px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.hero-btns .btn-fill{box-shadow:0 10px 30px rgba(53,128,204,.24)}
.hero-btns .btn-fill:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(53,128,204,.34)}
.hero-btns .btn-ghost{background:rgba(255,255,255,.03);color:rgba(255,255,255,.88);border-color:rgba(255,255,255,.2)}
.hero-visual{display:flex;justify-content:center}
.spin{animation:spin 1.6s linear infinite;display:block}

/* ── Hero entrance animation (dashboard + marquee only) ── */
@keyframes heroIn{from{opacity:0}to{opacity:1}}

@media (prefers-reduced-motion: reduce){
   .bubble{animation:none;opacity:.22}
   .bubble-spark::before,.bubble-spark::after{animation:none;opacity:0}
   .foam-particle{animation:none;opacity:.16}
   .hero::after{animation:none}
   .marquee-track{animation:none;opacity:1;transform:none}
   .hero-dashboard{animation:heroBreath 7s ease-in-out infinite}
}

@media(max-width:768px){
   .bubble{filter:saturate(1.05);box-shadow:inset -4px -6px 10px rgba(11,29,51,.12),inset 2px 2px 6px rgba(255,255,255,.16),0 0 16px rgba(81,153,221,.16)}
}

/* ══════════════════════════════
   SERVICES
   ══════════════════════════════ */
.services{padding:120px 0;background:var(--gray-50)}
.services-header{text-align:center;margin-bottom:60px}
.services-header .section-desc{margin:0 auto}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.services-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:32px}
.svc{background:var(--white);border-radius:var(--r-xl);padding:36px 30px;border:1px solid var(--gray-200);transition:all .4s;position:relative;overflow:hidden}
.svc::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-400),var(--blue-600));border-radius:3px 3px 0 0;transform:scaleX(0);transition:transform .4s;transform-origin:left}
.svc:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(11,29,51,.07);border-color:var(--blue-100)}
.svc:hover::after{transform:scaleX(1)}
.svc-icon{width:60px;height:60px;background:var(--blue-50);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:all .4s}
.svc:hover .svc-icon{background:var(--blue-500)}
.svc-icon svg{width:26px;height:26px;color:var(--blue-500);transition:color .4s}
.svc:hover .svc-icon svg{color:#fff}
.svc h3{font-size:1.12rem;margin-bottom:10px;font-weight:600}
.svc p{font-size:.88rem;color:var(--gray-400);line-height:1.68}
.svc-more{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:.84rem;font-weight:600;color:var(--blue-600)}
.svc-more::after{content:'\2192';transition:transform .25s ease}
.svc:hover .svc-more{color:var(--blue-500)}
.svc:hover .svc-more::after{transform:translateX(3px)}

/* ══════════════════════════════
   PROCESS
   ══════════════════════════════ */
.process{padding:120px 0;background:var(--white)}
.process-header{text-align:center;margin-bottom:72px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--gray-100);border-radius:var(--r-xl);overflow:hidden}
.step{padding:48px 40px;background:#fff;position:relative;transition:background .35s}
.step+.step{border-left:1px solid var(--gray-100)}
.step::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-400),var(--blue-300));transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.16,1,.3,1);border-radius:0}
.step:hover{background:#f7f9fc}
.step:hover::after{transform:scaleX(1)}
.step-num{display:block;font-family:'Outfit',sans-serif;font-size:3rem;font-weight:800;color:var(--blue-100);line-height:1;margin-bottom:22px;transition:color .35s}
.step:hover .step-num{color:var(--blue-300)}
.step-rule{width:36px;height:2px;background:var(--blue-200);border-radius:2px;margin-bottom:20px;transition:width .4s,background .35s}
.step:hover .step-rule{width:64px;background:var(--blue-400)}
.step h3{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.step p{font-size:.875rem;color:var(--gray-500);line-height:1.7}

/* ══════════════════════════════
   WHY US
   ══════════════════════════════ */
.why{padding:120px 0;background:var(--navy);position:relative;overflow:hidden}
.why::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 60% 50% at 80% 50%,rgba(53,128,204,.1),transparent),
  radial-gradient(ellipse 50% 50% at 10% 30%,rgba(41,104,173,.06),transparent);
}
.section-bubbles,.why-bubbles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}
.section-bubbles .bubble,.why-bubbles .bubble{filter:saturate(1.2) contrast(1.1);box-shadow:inset -4px -7px 12px rgba(11,29,51,.18),inset 2px 2px 8px rgba(255,255,255,.32),0 0 28px rgba(81,153,221,.38),0 0 8px rgba(255,255,255,.12)}
.why-bubbles::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 58% 62% at 50% 52%,rgba(11,29,51,.52),transparent 72%)}
.why-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.5fr;gap:96px;align-items:start}
.stats-section>*:not(.section-bubbles),.cta>*:not(.section-bubbles){position:relative;z-index:2}
.why .section-label{color:var(--blue-300)}
.why .section-label::before{background:var(--blue-400)}
.why-heading{font-size:clamp(2.2rem,3.8vw,3.2rem);font-weight:800;color:#fff;line-height:1.1;margin:16px 0 20px}
.why-intro{font-size:.95rem;color:rgba(255,255,255,.42);line-height:1.74}

/* Feature list */
.why-features{display:flex;flex-direction:column}
.why-feat{border-top:1px solid rgba(255,255,255,.07);padding:28px 0;cursor:default;transition:padding .3s}
.why-features .why-feat:last-child{border-bottom:1px solid rgba(255,255,255,.07)}
.why-feat-head{display:flex;align-items:center;gap:18px;margin-bottom:10px}
.why-feat-num{font-family:'Outfit',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:2.5px;color:var(--blue-400);flex-shrink:0;width:24px}
.why-feat h3{font-size:1rem;font-weight:600;color:#fff;flex:1;margin:0;transition:color .3s}
.why-feat:hover h3{color:var(--blue-200)}
.why-feat p{font-size:.875rem;color:rgba(255,255,255,.58);line-height:1.7;padding-left:42px;margin:0;transition:color .3s}
.why-feat:hover p{color:rgba(255,255,255,.8)}

/* ══════════════════════════════
   WORK AREA
   ══════════════════════════════ */
.werk{background:#f7f9fc;padding:100px 0;position:relative;overflow:hidden}
.werk::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 55% 70% at 5% 50%,rgba(53,128,204,.06),transparent),
  radial-gradient(ellipse 50% 60% at 95% 30%,rgba(53,128,204,.04),transparent)}

/* Split layout: text left, image right */
.werk-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}

/* Text panel */
.werk-text{display:flex;flex-direction:column}
.werk .section-label{color:var(--blue-500)}
.werk .section-label::before{background:var(--blue-500)}
.werk-title{font-size:clamp(2.2rem,4vw,3.2rem);font-weight:800;color:var(--navy);line-height:1.1;margin-bottom:18px}
.werk-desc{font-size:.97rem;color:var(--gray-600);line-height:1.74;margin-bottom:28px}

/* City tags */
.werk-cities{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.werk-city{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;
  background:#fff;
  border:1px solid rgba(11,29,51,.1);
  border-radius:var(--r-full);
  font-size:.8rem;font-weight:500;
  color:var(--gray-600);
  white-space:nowrap;transition:all .28s;
}
.werk-city:hover{
  background:rgba(53,128,204,.08);
  border-color:rgba(53,128,204,.3);
  color:var(--blue-600);
  transform:translateY(-2px);
}
.werk-city svg{color:var(--blue-500);flex-shrink:0;transition:color .28s}
.werk-city:hover svg{color:var(--blue-500)}

/* Bottom CTA link */
.werk-cta{
  display:inline-flex;flex-direction:column;gap:4px;
  font-size:.78rem;color:var(--gray-400);
  text-decoration:none;transition:color .3s;
  border-top:1px solid rgba(11,29,51,.08);
  padding-top:22px;
}
.werk-cta span{display:flex;align-items:center;gap:7px;font-size:.86rem;font-weight:600;color:var(--blue-500);transition:gap .3s,color .3s}
.werk-cta:hover span{gap:11px;color:var(--blue-400)}

/* Single image */
.werk-img-wrap{position:relative}
.werk-img{
  position:relative;
  border-radius:var(--r-xl);
  overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:0 40px 80px rgba(0,0,0,.45),0 0 0 1px rgba(53,128,204,.08);
  background:linear-gradient(145deg,var(--blue-900),var(--blue-800));
}
.werk-img img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform .8s cubic-bezier(.16,1,.3,1);
}
.werk-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 40%,rgba(11,29,51,.5));
  transition:opacity .4s;pointer-events:none;
}
.werk-img-wrap:hover .werk-img img{transform:scale(1.04)}
.werk-img-wrap:hover .werk-img-overlay{opacity:.7}

/* Floating badge on image */
.werk-img-badge{
  position:absolute;
  bottom:20px;left:20px;
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;
  background:rgba(11,29,51,.72);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-full);
  font-size:.78rem;font-weight:600;
  color:rgba(255,255,255,.85);
  letter-spacing:.3px;
  pointer-events:none;
}
.werk-img-badge svg{color:var(--blue-400);flex-shrink:0}

/* ══════════════════════════════
   CTA
   ══════════════════════════════ */
.cta{padding:120px 0;background:#060e1c;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 70% 55% at 60% 30%,rgba(53,128,204,.18),transparent),
  radial-gradient(ellipse 50% 60% at 15% 80%,rgba(41,104,173,.12),transparent),
  radial-gradient(ellipse 40% 40% at 90% 60%,rgba(81,153,221,.08),transparent)}
.cta-box{max-width:860px;margin:0 auto;padding:24px 0;text-align:center;position:relative}
.cta-box::before,.cta-box::after{display:none}
.cta-box>*{position:relative;z-index:1}
.cta .section-label{color:var(--blue-300)}
.cta .section-label::before{background:var(--blue-400)}
.cta-box h2{font-size:clamp(1.8rem,3.5vw,2.5rem);margin-bottom:14px;color:#fff}
.cta-box p{font-size:1.05rem;color:rgba(255,255,255,.62);line-height:1.7;max-width:640px;margin:0 auto 36px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .btn-fill{background:var(--blue-500);color:#fff}
.cta .btn-fill:hover{background:var(--blue-400)}
.cta .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.22)}
.cta .btn-ghost:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.45)}

/* ══════════════════════════════
   FOOTER
   ══════════════════════════════ */
footer{background:var(--navy);padding:72px 0 0;color:rgba(255,255,255,.45)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-brand p{margin-top:16px;font-size:.87rem;line-height:1.65;max-width:260px}
.footer-logo{display:inline-block;margin-bottom:4px}
.footer-logo img{height:100px;width:auto;display:block}
.footer-col h3{color:#fff;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:1.8px;margin-bottom:18px}
.footer-subheading{color:rgba(255,255,255,.4);font-family:'DM Sans',sans-serif;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;margin:22px 0 12px}
.footer-col a{font-size:.87rem;display:block;padding:5px 0;transition:color .3s}
.footer-col a:hover{color:var(--blue-300)}
.footer-col {font-size:.87rem;display:block;padding:5px 0;transition:color .3s}
.footer-col li{font-size:.87rem;padding:5px 0;margin-bottom:2px;color:rgba(255,255,255,.4)}
.footer-bottom{padding:24px 0;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:rgba(255,255,255,.25)}

/* ══════════════════════════════
   RESPONSIVE
   ══════════════════════════════ */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:48px}
  .hero-desc{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
   .hero-trust{text-align:center}
  .hero-visual{order:-1}
   .hero h1{max-width:none}
   .hero-card{max-width:450px;margin:0 auto;padding:34px}
  .services-grid{grid-template-columns:1fr 1fr}
  .why-content{grid-template-columns:1fr;gap:48px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
/* Mobile nav overlay — sits left of the drawer */
.nav-overlay{position:fixed;inset:0;background:rgba(11,29,51,.5);z-index:998;opacity:0;visibility:hidden;transition:opacity .3s,visibility 0s linear .3s}
.nav-overlay.open{opacity:1;visibility:visible;transition:opacity .3s}
.nav-footer,.nav-dropdown--mobile,.nav-mobile-logo{display:none}

@media(max-width:768px){
  .nav-toggle{display:flex}
  body.menu-open{overflow:hidden}

  /* Header becomes the drawer's top bar — same navy background */
  .site-header.menu-active{background:var(--navy)!important;border-bottom-color:rgba(255,255,255,.08)!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  .site-header.menu-active .logo-img{filter:brightness(0) invert(1)!important}
  .site-header.menu-active .logo{opacity:0;pointer-events:none;transition:opacity .2s}
  .site-header.menu-active .nav-toggle span{background:#fff!important}

  /* Drawer — starts at top:0, padding-top pushes content below the header */
  #siteNav{position:fixed;top:0;right:0;bottom:0;width:min(380px,90vw);background:var(--navy);border-left:1px solid rgba(255,255,255,.06);z-index:999;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;visibility:hidden;pointer-events:none;transform:translateX(110%);transition:transform .4s cubic-bezier(.16,1,.3,1),visibility 0s linear .4s;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:80px}
  #siteNav.open{transform:translateX(0);pointer-events:auto;visibility:visible;transition:transform .4s cubic-bezier(.16,1,.3,1),visibility 0s}

  /* Nav list vertical */
  ul.nav-links{display:flex;flex-direction:column;width:100%;padding:8px 0 0;margin:0;gap:0;list-style:none}
  ul.nav-links>li{width:100%;border-bottom:1px solid rgba(255,255,255,.055);display:block}
  ul.nav-links>li.has-mega{display:flex;flex-direction:column;align-items:stretch}
  ul.nav-links>li>a:not(.btn-book-nav),.dropdown-toggle{display:flex;align-items:center;justify-content:space-between;font-size:.92rem;font-weight:500;letter-spacing:.04em;text-transform:none;color:rgba(255,255,255,.7);padding:17px 24px;transition:color .2s,background .2s;width:100%}
  ul.nav-links>li>a:not(.btn-book-nav)::after,.dropdown-toggle::after{display:none!important}
  ul.nav-links>li>a:not(.btn-book-nav):hover,.dropdown-toggle:hover{color:#fff;background:rgba(255,255,255,.04)}
  .dropdown-chevron{width:10px;height:auto;flex-shrink:0}
  .has-mega.active .dropdown-chevron{transform:rotate(180deg)}
  .has-mega:hover .dropdown-chevron{transform:none}

  /* Hide desktop mega, show mobile list */
  .mega-dropdown{display:none!important}
  .nav-dropdown--mobile{list-style:none;padding:6px 0 10px;margin:0;background:rgba(255,255,255,.03);border-top:1px solid rgba(255,255,255,.055);display:none;flex-direction:column}
  .has-mega.active .nav-dropdown--mobile{display:flex;animation:mobileDropDown .22s ease}
  .nav-dropdown-label{display:block;font-size:.58rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.25);padding:10px 24px 4px}
  .nav-dropdown--mobile>li{display:block;width:100%}
  .nav-dropdown--mobile>li>a{display:flex;align-items:center;width:100%;font-size:.88rem;font-weight:400;color:rgba(255,255,255,.55);padding:11px 24px 11px 36px;transition:color .2s,background .2s}
  .nav-dropdown--mobile>li>a:active{color:rgba(255,255,255,.9);background:rgba(255,255,255,.04)}
  .nav-dropdown-viewall a{color:var(--blue-300)!important;font-weight:600}
  @keyframes mobileDropDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

  /* Call Us in drawer */
  .btn-call-nav{display:flex!important;justify-content:center!important;margin:16px 24px 0!important;margin-left:24px!important;width:calc(100% - 48px)!important;padding:14px 20px!important;border-radius:14px!important;font-size:.92rem!important;letter-spacing:.04em!important;border-color:rgba(255,255,255,.35)!important}
  /* Book Now in drawer */
  .btn-book-nav{display:flex!important;justify-content:center!important;margin:10px 24px 8px!important;margin-left:24px!important;width:calc(100% - 48px)!important;padding:15px 20px!important;border-radius:14px!important;font-size:.92rem!important;letter-spacing:.04em!important}

  /* Nav footer */
  .nav-mobile-logo{display:flex;align-items:center;position:absolute;top:0;left:0;height:80px;padding:0 24px;pointer-events:none}
  .nav-mobile-logo img{height:50px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}
  .nav-footer{display:flex;flex-direction:column;padding:16px 24px 28px;border-top:1px solid rgba(255,255,255,.07);margin-top:auto;flex-shrink:0}
  .nav-quick-actions{display:flex;flex-direction:row;gap:10px}
  .nav-quick-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;font-size:.75rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.45);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-full);padding:11px 12px;transition:all .2s;-webkit-tap-highlight-color:transparent}
  .nav-quick-btn:hover{color:#fff;border-color:rgba(255,255,255,.35)}

  .hero{min-height:auto;padding:140px 0 72px}
   .section-title{font-size:2rem}
   .hero h1{font-size:clamp(2.3rem,9.5vw,3.25rem);max-width:none}
   .hero-desc{font-size:1.08rem;max-width:560px}
   .hero-trust{font-size:.78rem;margin-top:14px}
   .hero-card{max-width:392px;padding:30px}
  .services-grid{grid-template-columns:1fr}
   .services-actions{margin-top:24px}
  .steps{grid-template-columns:1fr}
  .step+.step{border-left:none;border-top:1px solid var(--gray-100)}
  .why-heading{font-size:clamp(1.9rem,5vw,2.4rem)}
   .werk-inner{grid-template-columns:1fr;gap:48px}
   .cta-box{padding:16px 0}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center}
}

/* ══════════════════════════════
   HERO — REDESIGN ADDITIONS
   ══════════════════════════════ */


/* Glow orbs */
.hero-glow{position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.hero-glow-1{width:600px;height:600px;top:-10%;right:-8%;background:radial-gradient(circle,rgba(53,128,204,.12),transparent 65%);animation:float 10s ease-in-out infinite}
.hero-glow-2{width:400px;height:400px;bottom:5%;left:-5%;background:radial-gradient(circle,rgba(81,153,221,.07),transparent 65%);animation:float 14s ease-in-out infinite;animation-delay:-5s}

/* Hero text area */
.hero-text{position:relative;z-index:2}

/* Trust strip below buttons */
.hero-trust-strip{display:flex;align-items:center;gap:14px;margin-top:28px;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:7px;font-size:.78rem;color:rgba(214,234,250,.6);font-weight:500;letter-spacing:.2px}
.hero-trust-item svg{color:var(--blue-400);flex-shrink:0}
.hero-trust-sep{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.15)}

/* Scroll hint */
.hero-scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:6px}
.scroll-hint-label{font-size:.65rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.45)}
.scroll-hint-chevrons{display:flex;flex-direction:column;align-items:center;gap:0}
.scroll-hint-chevrons svg{width:22px;height:22px;color:rgba(255,255,255,.7);display:block}
.scroll-hint-chevrons svg:nth-child(1){animation:scrollChevron 1.6s ease-in-out infinite}
.scroll-hint-chevrons svg:nth-child(2){animation:scrollChevron 1.6s ease-in-out .22s infinite;margin-top:-10px}
@keyframes scrollChevron{
  0%,100%{opacity:.25;transform:translateY(-4px)}
  50%{opacity:1;transform:translateY(4px)}
}

/* ══════════════════════════════
   HERO DASHBOARD CARD
   ══════════════════════════════ */
.hero-dashboard{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(28px);
  -webkit-backdrop-filter:blur(28px);
  border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-xl);
  padding:32px;
  width:100%;
  max-width:500px;
  position:relative;
  z-index:2;
  animation:heroIn .65s ease .22s both, heroBreath 7s ease-in-out 1s infinite;
}
.hero-dashboard::before{content:'';position:absolute;top:-1px;left:48px;right:48px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent)}
.hero-dashboard::after{content:'';position:absolute;inset:0;border-radius:var(--r-xl);background:linear-gradient(145deg,rgba(53,128,204,.06),transparent 60%);pointer-events:none}

.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.dashboard-hotel-info{display:flex;align-items:center;gap:12px}
.dashboard-hotel-icon{width:38px;height:38px;background:rgba(53,128,204,.14);border:1px solid rgba(53,128,204,.22);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dashboard-hotel-icon svg{width:18px;height:18px;color:var(--blue-300)}
.dashboard-hotel-name{font-family:'Outfit',sans-serif;font-size:.88rem;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:3px}
.dashboard-live{display:flex;align-items:center;gap:6px;font-size:.68rem;color:rgba(255,255,255,.38);letter-spacing:.3px}
.live-dot{width:5px;height:5px;border-radius:50%;background:#4ade80;animation:pulse 2s infinite;flex-shrink:0}
.dashboard-date{font-size:.72rem;color:rgba(255,255,255,.28);font-weight:500;letter-spacing:.4px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);padding:5px 10px;border-radius:var(--r-full)}

.dashboard-overall{margin-bottom:18px;padding:14px 16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-md)}
.dashboard-overall-labels{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.dashboard-overall-labels>span:first-child{font-size:.72rem;color:rgba(255,255,255,.38);letter-spacing:.3px;text-transform:uppercase;font-weight:600}
.dashboard-overall-count{font-family:'Outfit',sans-serif;font-size:1.05rem;font-weight:700;color:var(--blue-300)}
.dashboard-overall-count em{font-style:normal;font-size:.72rem;color:rgba(255,255,255,.3);font-weight:400}
.dashboard-overall-bar{height:5px;background:rgba(255,255,255,.07);border-radius:99px;overflow:hidden}
.dashboard-overall-fill{width:75%;height:100%;background:linear-gradient(90deg,var(--blue-700),var(--blue-400),var(--blue-300));background-size:200% 100%;animation:gradientMove 4s linear infinite;border-radius:99px}

.dashboard-floors{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.floor-row{display:grid;grid-template-columns:90px 1fr 36px;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);border:1px solid transparent;transition:background .3s}
.floor-done{background:rgba(74,222,128,.04);border-color:rgba(74,222,128,.1)}
.floor-active{background:rgba(53,128,204,.09);border-color:rgba(53,128,204,.2)}
.floor-pending{background:rgba(255,255,255,.02);border-color:rgba(255,255,255,.05)}
.floor-label{font-size:.73rem;color:rgba(255,255,255,.5);font-weight:500}
.floor-active .floor-label{color:rgba(255,255,255,.85)}
.floor-track{height:4px;background:rgba(255,255,255,.07);border-radius:99px;overflow:hidden}
.floor-fill{height:100%;background:rgba(74,222,128,.5);border-radius:99px}
.floor-active .floor-fill,.active-fill{background:linear-gradient(90deg,var(--blue-600),var(--blue-300));background-size:200% 100%;animation:gradientMove 3s linear infinite;width:58%}
.floor-count{font-size:.68rem;font-weight:600;text-align:right;font-variant-numeric:tabular-nums}
.done-count{color:rgba(74,222,128,.7)}
.active-count{color:var(--blue-300)}
.pending-count{color:rgba(255,255,255,.2)}

.dashboard-feed{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;padding:12px;background:rgba(0,0,0,.15);border-radius:var(--r-md);border:1px solid rgba(255,255,255,.05)}
.feed-row{display:flex;align-items:center;gap:9px}
.feed-icon{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feed-done .feed-icon{background:rgba(74,222,128,.18)}
.feed-done .feed-icon svg{width:10px;height:10px;stroke:#4ade80}
.feed-active .feed-icon{background:rgba(53,128,204,.25)}
.feed-active .feed-icon svg{width:10px;height:10px;stroke:var(--blue-300)}
.feed-pending .feed-icon{border:1.5px solid rgba(255,255,255,.1)}
.feed-text{flex:1;font-size:.76rem;color:rgba(255,255,255,.45)}
.feed-done .feed-text{color:rgba(255,255,255,.72)}
.feed-active .feed-text{color:rgba(255,255,255,.9);font-weight:500}
.feed-time{font-size:.67rem;color:rgba(255,255,255,.22);font-variant-numeric:tabular-nums;white-space:nowrap}
.feed-active .feed-time{color:var(--blue-300)}

.dashboard-footer-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dash-stat{text-align:center;padding:12px 6px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-md)}
.dash-stat strong{display:block;font-family:'Outfit',sans-serif;font-size:1.35rem;font-weight:700;color:var(--blue-300);line-height:1.2}
.dash-stat span{font-size:.64rem;color:rgba(255,255,255,.3);letter-spacing:.7px;text-transform:uppercase;margin-top:3px;display:block}

/* ══════════════════════════════
   MARQUEE STRIP
   ══════════════════════════════ */
.marquee-strip{
  background:var(--navy);
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:14px 0;
  overflow:hidden;
  position:relative;
}
.marquee-fade{position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.marquee-fade-left{left:0;background:linear-gradient(90deg,var(--navy),transparent)}
.marquee-fade-right{right:0;background:linear-gradient(270deg,var(--navy),transparent)}
.marquee-track{display:flex;width:max-content;animation:marqueeScroll 32s linear infinite}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-25%)}}
.marquee-set{display:inline-flex;align-items:center;flex-shrink:0;white-space:nowrap}
.marquee-set span{font-family:'Outfit',sans-serif;font-size:.78rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.3);padding:0 16px}
.marquee-set span:hover{color:rgba(255,255,255,.55)}
.marquee-dot{color:var(--blue-500)!important;padding:0 4px!important;letter-spacing:0!important}

/* ══════════════════════════════
   SERVICES
   ══════════════════════════════ */
.svc-bento{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:0}
.svc-small-grid{display:grid;grid-template-columns:1fr;gap:20px}

/* Featured large service card */
.svc-featured{
  grid-row:1 / 2;
  padding:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--r-xl);
  transition:all .4s;
  position:relative;
}
.svc-featured:hover{transform:translateY(-5px);box-shadow:0 20px 56px rgba(11,29,51,.09);border-color:var(--blue-100)}
.svc-featured::after{display:none}

.svc-featured .svc-num{
  position:absolute;top:-18px;right:24px;
  font-family:'Outfit',sans-serif;
  font-size:7rem;font-weight:800;
  color:var(--blue-50);
  line-height:1;pointer-events:none;user-select:none;
  transition:color .4s;
}
.svc-featured:hover .svc-num{color:var(--blue-100)}

.svc-featured .svc-inner{padding:40px 36px;display:flex;flex-direction:column;flex:1;position:relative;z-index:1}
.svc-featured .svc-icon{width:56px;height:56px;background:var(--blue-500);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:22px;flex-shrink:0;transition:all .4s}
.svc-featured:hover .svc-icon{background:var(--blue-600);box-shadow:0 8px 24px rgba(53,128,204,.3)}
.svc-featured .svc-icon svg{width:26px;height:26px;color:#fff;transition:none}
.svc-featured:hover .svc-icon svg{color:#fff}
.svc-featured .svc-body{display:flex;flex-direction:column;flex:1}
.svc-featured h3{font-size:1.4rem;font-weight:700;margin-bottom:12px;color:var(--navy)}
.svc-featured p{font-size:.92rem;color:var(--gray-400);line-height:1.7;margin-bottom:18px}

.svc-list{list-style:none;margin-bottom:28px;display:flex;flex-direction:column;gap:7px}
.svc-list li{display:flex;align-items:center;gap:9px;font-size:.85rem;color:var(--gray-500)}
.svc-list li::before{content:'';width:6px;height:6px;background:var(--blue-400);border-radius:50%;flex-shrink:0}

.svc-link{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--blue-500);color:#fff;border-radius:var(--r-full);font-size:.86rem;font-weight:600;transition:all .35s;align-self:flex-start;margin-top:auto}
.svc-link:hover{background:var(--blue-400);transform:translateX(3px);box-shadow:0 8px 24px rgba(53,128,204,.3)}
.svc-link svg{width:16px;height:16px;transition:transform .25s}
.svc-link:hover svg{transform:translateX(3px)}

.svc-accent{position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue-600),var(--blue-400),var(--blue-300));border-radius:0 0 var(--r-xl) var(--r-xl)}

/* Small service cards */
.svc{position:relative;overflow:hidden}
.svc:not(.svc-featured) .svc-num{
  position:absolute;top:-14px;right:16px;
  font-family:'Outfit',sans-serif;
  font-size:4.5rem;font-weight:800;
  color:var(--blue-50);
  line-height:1;pointer-events:none;user-select:none;
  transition:color .4s;
}
.svc:not(.svc-featured):hover .svc-num{color:var(--blue-100)}

/* ══════════════════════════════
   STATS SECTION
   ══════════════════════════════ */
.stats-section{
  background:var(--navy);
  padding:80px 0;
  position:relative;
  overflow:hidden;
}
.stats-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 70% at 20% 50%,rgba(53,128,204,.08),transparent),
    radial-gradient(ellipse 45% 60% at 85% 40%,rgba(81,153,221,.06),transparent);
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;position:relative;z-index:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-xl);overflow:hidden}
.stats-grid-2{grid-template-columns:repeat(2,1fr)}
.stats-grid-3{grid-template-columns:repeat(2,1fr)}
.stat-item{padding:40px 24px;text-align:center;background:var(--navy);transition:background .3s}
.stat-item:hover{background:#0f2540}
.stat-number{
  font-family:'Outfit',sans-serif;
  font-size:clamp(2.2rem,4.5vw,3rem);
  font-weight:800;
  color:var(--blue-300);
  line-height:1.1;
  margin-bottom:8px;
  letter-spacing:-1px;
  background:linear-gradient(135deg,var(--blue-300),var(--blue-400));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.stat-label{font-size:.78rem;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:1.5px;font-weight:500}

/* ══════════════════════════════
   CTA — DECORATION LINES
   ══════════════════════════════ */
.cta{position:relative}
.cta-decoration{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.cta-line{position:absolute;border-radius:2px;background:rgba(255,255,255,.03)}
.cta-line-1{width:1px;height:60%;top:20%;left:15%;transform:rotate(15deg)}
.cta-line-2{width:1px;height:80%;top:10%;left:50%;transform:rotate(-8deg)}
.cta-line-3{width:1px;height:55%;top:25%;right:18%;transform:rotate(12deg)}

.cta-contact-info{
  margin-top:20px;
  display:flex;align-items:center;justify-content:center;gap:14px;
  flex-wrap:wrap;
}
.cta-contact-link{
  font-size:.85rem;color:rgba(255,255,255,.4);
  transition:color .3s;letter-spacing:.3px;
}
.cta-contact-link:hover{color:rgba(255,255,255,.75)}
.cta-contact-sep{color:rgba(255,255,255,.2)}

/* ══════════════════════════════
   RESPONSIVE — NEW SECTIONS
   ══════════════════════════════ */
@media(max-width:1024px){
  .svc-bento{grid-template-columns:1fr}
  .svc-small-grid{grid-template-columns:1fr 1fr}
  .stats-grid,.stats-grid-3{grid-template-columns:repeat(2,1fr)}
  .hero-trust-strip{justify-content:center}
  .hero-scroll-hint{display:none}
}
@media(max-width:768px){
  .svc-small-grid{grid-template-columns:1fr}
  .svc-featured .svc-inner{padding:30px 26px}
  .svc-featured .svc-num{font-size:5rem}
  .stats-grid,.stats-grid-3{grid-template-columns:1fr;border-radius:var(--r-lg)}
  .stats-grid-3 .stat-item:last-child{border-top:1px solid rgba(255,255,255,.06)}
  .stat-item{padding:28px 16px}
  .stat-label{color:rgba(255,255,255,.6)}
  .stat-number{font-size:clamp(2.4rem,8vw,3rem)}
  .marquee-set span{font-size:.72rem;padding:0 12px}
  .svc-bento{gap:14px}
  .werk{padding:72px 0}
  .werk-img{aspect-ratio:3/2}
}

/* ══════════════════════════════
   PAGE HERO (Sub-pages)
   ══════════════════════════════ */
.page-hero{padding:140px 0 84px;background-color:var(--navy);background-size:cover;background-position:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 65% 80% at 75% 40%,rgba(53,128,204,.22),transparent),
  radial-gradient(ellipse 45% 65% at 8% 75%,rgba(41,104,173,.14),transparent),
  linear-gradient(rgba(11,29,51,.78),rgba(11,29,51,.76))}
.page-hero::after{content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:64px 64px}
.page-hero-inner{position:relative;z-index:2}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.78rem;color:rgba(255,255,255,.3);margin-bottom:22px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.3);transition:color .3s}
.breadcrumb a:hover{color:rgba(255,255,255,.65)}
.breadcrumb-sep{color:rgba(255,255,255,.18)}
.breadcrumb-current{color:rgba(255,255,255,.55)}
.page-hero h1{font-size:clamp(2.4rem,4.5vw,3.8rem);font-weight:800;color:#fff;line-height:1.06;margin-bottom:18px}
.page-hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--blue-300),var(--blue-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.page-hero-desc{font-size:1.1rem;color:rgba(255,255,255,.58);max-width:600px;line-height:1.72}
.page-hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.page-hero-glow{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}
.page-hero-glow-1{width:500px;height:500px;right:-80px;top:-60px;background:radial-gradient(circle,rgba(53,128,204,.14),transparent 70%)}
.page-hero-glow-2{width:300px;height:300px;left:10%;bottom:0;background:radial-gradient(circle,rgba(81,153,221,.08),transparent 70%)}

/* ══════════════════════════════
   PAGE SECTIONS
   ══════════════════════════════ */
.page-section{padding:100px 0}
.page-section-alt{background:var(--gray-50);border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100)}
.page-section-dark{background:var(--navy);position:relative;overflow:hidden}
.page-section-header{margin-bottom:56px}
.page-section-header.center{text-align:center}
.page-section-header.center .section-desc{margin:0 auto}

/* Feature grid */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.feature-item{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:32px 28px;transition:all .35s;position:relative;overflow:hidden}
.feature-item::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-400),var(--blue-300));border-radius:3px 3px 0 0;transform:scaleX(0);transition:transform .4s;transform-origin:left}
.feature-item:hover{border-color:var(--blue-100);box-shadow:0 12px 40px rgba(11,29,51,.06);transform:translateY(-3px)}
.feature-item:hover::after{transform:scaleX(1)}
.feature-icon{width:52px;height:52px;background:var(--blue-50);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:background .35s}
.feature-item:hover .feature-icon{background:var(--blue-500)}
.feature-icon svg{width:24px;height:24px;color:var(--blue-500);transition:color .35s}
.feature-item:hover .feature-icon svg{color:#fff}
.feature-item h3{font-size:1rem;font-weight:600;color:var(--navy);margin-bottom:8px}
.feature-item p{font-size:.87rem;color:var(--gray-400);line-height:1.68}

/* Info split layout */
.info-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.info-split-text .section-desc{margin-top:20px;margin-bottom:28px}

/* Check list */
.check-list{display:flex;flex-direction:column;gap:12px}
.check-list li{display:flex;align-items:flex-start;gap:12px;font-size:.93rem;color:var(--gray-600);line-height:1.62}
.check-icon{flex-shrink:0;width:22px;height:22px;background:var(--blue-50);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:1px}
.check-icon svg{width:13px;height:13px;color:var(--blue-500)}

/* Value / strength cards (about page) */
.page-section-dark .section-title{color:#fff}
.page-section-dark .section-desc{color:rgba(255,255,255,.5)}
.page-section-dark .container{position:relative;z-index:2}
.value-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:52px;position:relative;z-index:2}
.value-card{position:relative;overflow:hidden;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);border-radius:var(--r-xl);padding:36px 32px;box-shadow:0 4px 24px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.07);transition:background .3s,border-color .3s,transform .32s,box-shadow .32s}
.value-card:hover{background:rgba(255,255,255,.13);border-color:rgba(53,128,204,.5);transform:translateY(-5px);box-shadow:0 24px 56px rgba(0,0,0,.32),0 0 0 1px rgba(53,128,204,.2),inset 0 1px 0 rgba(255,255,255,.1)}
.value-num{position:absolute;top:-8px;right:18px;font-family:'Outfit',sans-serif;font-size:6.5rem;font-weight:800;color:rgba(255,255,255,.05);line-height:1;pointer-events:none;user-select:none;transition:color .3s}
.value-card:hover .value-num{color:rgba(53,128,204,.14)}
.value-card-icon{width:48px;height:48px;background:rgba(53,128,204,.22);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--blue-300);margin-bottom:22px;transition:background .3s,color .3s}
.value-card-icon svg{width:22px;height:22px}
.value-card:hover .value-card-icon{background:var(--blue-500);color:#fff}
.value-card h3{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:10px}
.value-card p{font-size:.875rem;color:rgba(255,255,255,.55);line-height:1.72}

/* Aanpak steps (about page) */
.aanpak-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px;position:relative}
.aanpak-steps::before{content:'';position:absolute;top:44px;left:calc(16.67% + 20px);right:calc(16.67% + 20px);height:1px;background:repeating-linear-gradient(90deg,var(--blue-200) 0,var(--blue-200) 8px,transparent 8px,transparent 18px);pointer-events:none;z-index:0}
.aanpak-step{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:40px 28px 36px;text-align:center;position:relative;z-index:1;transition:transform .3s,box-shadow .3s,border-color .3s}
.aanpak-step:hover{transform:translateY(-5px);box-shadow:0 20px 52px rgba(11,29,51,.09);border-color:var(--blue-100)}
.aanpak-step-badge{width:52px;height:52px;background:var(--white);border:2px solid var(--blue-200);color:var(--blue-500);border-radius:50%;font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;position:relative;z-index:1;transition:background .3s,border-color .3s,color .3s,box-shadow .3s}
.aanpak-step:hover .aanpak-step-badge{background:var(--blue-500);border-color:var(--blue-500);color:#fff;box-shadow:0 8px 24px rgba(53,128,204,.3)}
.aanpak-step-icon{width:46px;height:46px;background:var(--blue-50);border-radius:13px;display:flex;align-items:center;justify-content:center;color:var(--blue-500);margin:0 auto 18px;transition:background .3s,color .3s}
.aanpak-step-icon svg{width:21px;height:21px}
.aanpak-step:hover .aanpak-step-icon{background:var(--blue-500);color:#fff}
.aanpak-step h3{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.aanpak-step p{font-size:.875rem;color:var(--gray-500);line-height:1.72}
.aanpak-includes{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:32px}
.aanpak-include{display:flex;align-items:center;gap:10px;background:var(--white);border:1px solid var(--gray-100);border-radius:12px;padding:13px 16px;font-size:.855rem;font-weight:500;color:var(--gray-600);transition:border-color .2s,color .2s}
.aanpak-include:hover{border-color:var(--blue-200);color:var(--navy)}
.aanpak-include svg{flex-shrink:0;width:15px;height:15px;color:var(--blue-500)}

/* About split */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/5;box-shadow:0 32px 64px rgba(0,0,0,.18)}
.about-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.about-img:hover img{transform:scale(1.04)}
.about-text{display:flex;flex-direction:column;gap:20px}
.about-text p{font-size:.97rem;color:var(--gray-600);line-height:1.78}

/* ══════════════════════════════
   DIENSTEN OVERVIEW PAGE
   ══════════════════════════════ */
.dienst-row{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;padding:80px 0;border-bottom:1px solid var(--gray-100)}
.dienst-row:last-child{border-bottom:none}
.dienst-row.reverse .dienst-row-text{order:2}
.dienst-row.reverse .dienst-row-visual{order:1}
.dienst-row-num{font-family:'Outfit',sans-serif;font-size:5rem;font-weight:800;line-height:1;color:var(--blue-50);margin-bottom:-12px;display:block;letter-spacing:-2px}
.dienst-row-text .section-label{margin-bottom:6px}
.dienst-row h2{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;color:var(--navy);line-height:1.12;margin-bottom:16px}
.dienst-row-desc{font-size:.97rem;color:var(--gray-500);line-height:1.76;margin-bottom:28px}
.dienst-row-visual{position:relative}
.dienst-row-img{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/3;box-shadow:0 24px 56px rgba(0,0,0,.12)}
.dienst-row-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.dienst-row-visual:hover .dienst-row-img img{transform:scale(1.04)}
.dienst-row-badge{position:absolute;bottom:-16px;right:20px;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-full);padding:10px 18px;font-size:.8rem;font-weight:600;color:var(--navy);box-shadow:0 8px 24px rgba(11,29,51,.08);display:flex;align-items:center;gap:8px}
.dienst-row-badge svg{color:var(--blue-500)}

/* Diensten overview grid (compact, used on diensten.php intro) */
.dienst-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.dienst-card-sm{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:28px 24px;transition:all .35s;cursor:pointer;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:14px}
.dienst-card-sm::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-400),var(--blue-300));transform:scaleX(0);transition:transform .4s;transform-origin:left;border-radius:3px 3px 0 0}
.dienst-card-sm:hover{border-color:var(--blue-100);box-shadow:0 12px 36px rgba(11,29,51,.07);transform:translateY(-4px)}
.dienst-card-sm:hover::after{transform:scaleX(1)}
.dienst-card-sm .feature-icon{margin-bottom:0}
.dienst-card-sm h3{font-size:1rem;font-weight:700;color:var(--navy)}
.dienst-card-sm p{font-size:.84rem;color:var(--gray-400);line-height:1.6;flex:1}
.dienst-card-link{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;color:var(--blue-600);transition:gap .25s,color .25s;margin-top:auto}
.dienst-card-sm:hover .dienst-card-link{gap:10px;color:var(--blue-500)}

/* ══════════════════════════════
   404
   ══════════════════════════════ */
.not-found{min-height:calc(100vh - 80px);display:flex;align-items:center;background:var(--navy);position:relative;overflow:hidden}
.not-found::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(53,128,204,.12),transparent)}
.not-found-inner{display:flex;flex-direction:column;align-items:center;text-align:center;padding:120px 0 80px;position:relative;z-index:1}
.not-found-code{font-family:'Outfit',sans-serif;font-size:clamp(7rem,20vw,14rem);font-weight:800;line-height:1;background:linear-gradient(135deg,rgba(53,128,204,.25),rgba(81,153,221,.1));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;margin-bottom:8px;letter-spacing:-4px}
.not-found-title{font-family:'Outfit',sans-serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;color:#fff;margin-bottom:16px}
.not-found-desc{font-family:'DM Sans',sans-serif;font-size:1rem;color:rgba(255,255,255,.45);line-height:1.7;margin-bottom:40px;max-width:420px}
.not-found-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* ══════════════════════════════
   CONTACT & FORM STYLES
   ══════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:64px;align-items:start}
.contact-form-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:48px 44px;box-shadow:0 2px 24px rgba(11,29,51,.04)}
.contact-info-card{background:var(--navy);border-radius:var(--r-xl);padding:44px 40px;position:relative;overflow:hidden}
.contact-info-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 80% 20%,rgba(53,128,204,.18),transparent)}
.contact-info-card-inner{position:relative;z-index:1}
.contact-info-card .section-label{color:var(--blue-300)}
.contact-info-card .section-label::before{background:var(--blue-400)}
.contact-info-card h2{font-size:1.6rem;font-weight:800;color:#fff;margin:12px 0 10px;line-height:1.2}
.contact-info-card p{font-size:.9rem;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:32px}
.contact-detail{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.contact-detail-icon{width:42px;height:42px;background:rgba(53,128,204,.14);border:1px solid rgba(53,128,204,.22);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-detail-icon svg{width:18px;height:18px;color:var(--blue-300)}
.contact-detail-text{flex:1}
.contact-detail-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1.8px;color:rgba(255,255,255,.3);margin-bottom:3px}
.contact-detail-value{font-size:.92rem;color:rgba(255,255,255,.85);font-weight:500}
.contact-detail-value a{color:inherit;transition:color .25s}
.contact-detail-value a:hover{color:var(--blue-300)}
.contact-info-cities{display:flex;gap:8px;flex-wrap:wrap;margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,.07)}
.contact-city-tag{font-size:.75rem;padding:5px 12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-full);color:rgba(255,255,255,.55);font-weight:500}

/* Form elements */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--navy);margin-bottom:7px;letter-spacing:.3px}
.form-input,.form-select,.form-textarea{width:100%;padding:13px 16px;border:1.5px solid var(--gray-200);border-radius:var(--r-md);font-family:'DM Sans',sans-serif;font-size:.93rem;color:var(--gray-700);background:var(--white);transition:border-color .25s,box-shadow .25s;outline:none;-webkit-appearance:none;appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px rgba(53,128,204,.1)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--gray-300)}
.form-textarea{resize:vertical;min-height:130px;line-height:1.65}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a9aab' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:42px;cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-section-title{display:flex;align-items:center;font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--gray-100)}
.form-submit-row{margin-top:28px}
.form-submit-row .btn{width:100%;justify-content:center;padding:15px 32px;font-size:1rem}

/* Form feedback alerts */
.alert{padding:14px 18px;border-radius:var(--r-md);font-size:.88rem;font-weight:500;margin-bottom:24px;display:flex;align-items:flex-start;gap:10px;line-height:1.5}
.alert svg{flex-shrink:0;margin-top:1px}
.alert-success{background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.28);color:#166534}
.alert-success svg{color:#16a34a}
.alert-error{background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.25);color:#991b1b}
.alert-error svg{color:#dc2626}

/* Checkbox service selection */
.form-check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}
.form-check-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border:1.5px solid var(--gray-200);border-radius:var(--r-md);cursor:pointer;transition:all .2s;font-size:.86rem;color:var(--gray-600);user-select:none}
.form-check-item:has(input:checked),.form-check-item:hover{border-color:var(--blue-400);background:var(--blue-50);color:var(--blue-700)}
.form-check-item input[type="checkbox"]{accent-color:var(--blue-500);width:15px;height:15px;flex-shrink:0;cursor:pointer}

/* Offerte form progress strip */
.offerte-layout{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start}
.offerte-form-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:52px 48px;box-shadow:0 2px 32px rgba(11,29,51,.05)}
.offerte-sections{display:flex;flex-direction:column;gap:40px}
.offerte-section{display:flex;flex-direction:column;gap:0}
.offerte-section+.offerte-section{padding-top:32px;border-top:1px solid var(--gray-100)}
.offerte-sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:100px}
.offerte-sidebar-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:36px;box-shadow:0 2px 20px rgba(11,29,51,.04)}
.offerte-sidebar-card--dark{background:var(--navy);border-color:transparent;box-shadow:0 4px 32px rgba(11,29,51,.18)}
.offerte-sidebar-card h4{font-family:'Outfit',sans-serif;font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:16px}
.offerte-sidebar-card--dark h4{color:#fff}
.offerte-sidebar-contact-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--gray-100);font-size:1.05rem;color:var(--gray-600);text-decoration:none;transition:color .2s}
.offerte-sidebar-contact-item:last-of-type{border-bottom:none}
.offerte-sidebar-contact-item:hover{color:var(--blue-500)}
.offerte-sidebar-contact-item svg{flex-shrink:0;color:var(--blue-500)}
.offerte-sidebar-trust{display:flex;flex-direction:column;gap:0}
.offerte-sidebar-trust-item{display:flex;align-items:flex-start;gap:14px;font-size:1.05rem;color:var(--gray-500);line-height:1.6;padding:16px 0;border-bottom:1px solid var(--gray-100)}
.offerte-sidebar-trust-item:last-child{border-bottom:none;padding-bottom:0}
.offerte-sidebar-trust-item:first-child{padding-top:0}
.offerte-sidebar-trust-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:38px;height:38px;border-radius:10px;background:rgba(53,128,204,.1);color:var(--blue-500);margin-top:1px}
.offerte-sidebar-trust-item strong{display:block;font-size:1.05rem;color:var(--navy);margin-bottom:3px}
.offerte-sidebar-areas{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.offerte-sidebar-area-tag{font-size:.75rem;font-weight:600;padding:5px 12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-full);color:rgba(255,255,255,.85)}

/* Offerte CTA */
.offerte-cta-box{margin-top:20px;padding:24px;background:var(--blue-50);border:1px solid var(--blue-100);border-radius:var(--r-xl)}
.offerte-cta-title{font-size:1.3rem;color:var(--navy);margin-bottom:12px;font-weight:700}
.offerte-cta-desc{font-size:.88rem;color:var(--gray-600);margin-bottom:14px;line-height:1.6}
.offerte-cta-box .btn{font-size:.86rem;padding:11px 22px}

/* Responsive */
@media(max-width:1024px){
  .dienst-row,.contact-grid{grid-template-columns:1fr;gap:48px}
  .dienst-row.reverse .dienst-row-text,.dienst-row.reverse .dienst-row-visual{order:unset}
  .dienst-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1024px){
  .offerte-layout{grid-template-columns:1fr}
  .offerte-sidebar{position:static;flex-direction:row;flex-wrap:wrap}
  .offerte-sidebar-card{flex:1;min-width:220px}
}
@media(max-width:768px){
  .form-row{grid-template-columns:1fr}
  .form-check-grid{grid-template-columns:1fr}
  .contact-form-card{padding:32px 24px}
  .offerte-form-card{padding:32px 20px}
  .offerte-sidebar{flex-direction:column}
  .dienst-cards{grid-template-columns:1fr}
  .dienst-row{padding:56px 0}
}

/* Sub-page responsive */
@media(max-width:1024px){
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .info-split,.about-split{grid-template-columns:1fr;gap:48px}
}
@media(max-width:768px){
  .page-hero{padding:120px 0 60px}
  .feature-grid{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
  .aanpak-steps{grid-template-columns:1fr}
  .aanpak-steps::before{display:none}
  .aanpak-includes{grid-template-columns:1fr 1fr}
  .page-section{padding:72px 0}
  .about-img img{height:auto}
  .about-img{aspect-ratio:4/3}
  .werk-img{aspect-ratio:4/3}
  .dienst-row-img{aspect-ratio:4/3}
}

/* ══════════════════════════════
   RESPONSIVE — ADDITIONAL FIXES
   ══════════════════════════════ */

/* Hero dashboard — scale on mobile */
@media(max-width:768px){
  .hero-dashboard{padding:24px 20px;max-width:100%}
  .floor-row{grid-template-columns:72px 1fr 32px;gap:8px}
  .dashboard-footer-stats{gap:6px}
  .dash-stat{padding:10px 4px}
  .dash-stat strong{font-size:1.1rem}
}

/* Small screens (≤ 480px) */
@media(max-width:480px){
  .container{padding:0 16px}
  .page-hero{padding:100px 0 48px}
  .aanpak-includes{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
  .hero-btns,.page-hero-btns,.cta-btns{gap:10px}
  .btn{padding:12px 24px;font-size:.88rem}
  .offerte-form-card{padding:28px 16px}
  .page-section-header{margin-bottom:40px}
  .feature-grid{margin-top:32px}
}
/* Hide reCAPTCHA badge — attribution text is shown inline near forms */
.grecaptcha-badge{visibility:hidden!important}
