:root{
  --bg:#fbfbf8;--cream:#f7f4ee;--sky:#e7f3ff;--lav:#eee8ff;--yellow:#fff3c8;
  --text:#13141a;--muted:#667086;--line:rgba(18,20,27,.10);--card:#fff;--soft:#f6f7fb;
  --shadow:0 22px 70px rgba(31,36,50,.08);--shadow-strong:0 34px 100px rgba(31,36,50,.12);--radius:24px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}img,svg{max-width:100%;height:auto}.wrap{width:min(1280px,calc(100% - 56px));margin-inline:auto}.topbar{position:sticky;top:0;z-index:50;background:rgba(251,251,248,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.nav{height:78px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:22px}.brand-logo{display:inline-flex;align-items:center;gap:14px;font-weight:850;letter-spacing:-.035em;font-size:1.05rem;justify-self:start}.logo-img{width:44px;height:44px;border-radius:14px;display:block}.menu{display:flex;align-items:center;gap:18px;justify-content:center}.menu a{padding:11px 18px;border-radius:999px;color:#1d2330;font-weight:520;font-size:.96rem;transition:transform .28s cubic-bezier(.16,1,.3,1),box-shadow .28s,background .28s}.menu a:hover,.menu a.active{background:#fff;box-shadow:0 16px 44px rgba(20,25,35,.08);transform:translateY(-2px)}.cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;border-radius:12px;background:#151720;color:#fff;font-weight:800;box-shadow:0 18px 42px rgba(10,10,15,.17);transition:transform .32s cubic-bezier(.16,1,.3,1),box-shadow .32s}.cta:hover{transform:translateY(-3px);box-shadow:0 22px 52px rgba(10,10,15,.22)}.nav-cta{justify-self:end;border-radius:12px}.btn-soft{background:#fff;color:#151720;border:1px solid var(--line);box-shadow:none}.mobile-toggle{display:none}.hero,.page-hero{position:relative;padding:86px 0 74px;border-bottom:1px solid var(--line);isolation:isolate}.hero:before,.page-hero:before{content:"";position:absolute;inset:-160px -12vw auto -12vw;height:620px;background:radial-gradient(circle at 18% 28%,rgba(255,243,200,.78),transparent 30%),radial-gradient(circle at 70% 18%,rgba(231,243,255,.86),transparent 32%),radial-gradient(circle at 47% 6%,rgba(238,232,255,.72),transparent 38%);filter:blur(22px);z-index:-1;animation:aurora 14s ease-in-out infinite alternate}.split{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(420px,.92fr);gap:72px;align-items:center}.hero h1,.page-hero h1{font-size:clamp(3.3rem,6vw,6rem);line-height:1.04;letter-spacing:-.075em;margin:22px 0 20px;max-width:820px}.page-hero h1{font-size:clamp(3rem,5.4vw,5.3rem)}.lead{font-size:clamp(1.08rem,1.75vw,1.35rem);color:var(--muted);max-width:680px;margin:0}.kicker,.breadcrumb{display:inline-flex;align-items:center;border:1px solid var(--line);background:rgba(255,255,255,.74);border-radius:999px;padding:8px 14px;color:#606b80;font-size:.93rem}.actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:30px}.actions .btn-soft{background:transparent;border-color:transparent;border-bottom:1px solid rgba(20,24,34,.25);border-radius:0;padding-inline:0}.visual{width:100%;max-width:540px;justify-self:end;border:1px solid var(--line);border-radius:30px;overflow:hidden;background:rgba(255,255,255,.68);box-shadow:var(--shadow);transition:transform .7s cubic-bezier(.16,1,.3,1),box-shadow .7s}.visual img{display:block;width:100%;aspect-ratio:1.42/1;object-fit:cover}.visual:hover{transform:translateY(-8px) rotate(.35deg);box-shadow:var(--shadow-strong)}.visual.tall{max-width:430px}.visual.tall img{aspect-ratio:1/1}.section{padding:74px 0}.section.alt{background:linear-gradient(180deg,#fff,var(--cream))}.head{display:flex;justify-content:space-between;align-items:end;gap:28px;margin-bottom:30px}.head h2{font-size:clamp(1.9rem,3vw,3rem);letter-spacing:-.055em;line-height:1.05;margin:0}.head p{max-width:520px;color:var(--muted);margin:0}.grid{display:grid;gap:22px}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{position:relative;overflow:hidden;background:rgba(255,255,255,.78);border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:0 18px 58px rgba(31,36,50,.065);backdrop-filter:blur(12px);min-width:0;transition:transform .55s cubic-bezier(.16,1,.3,1),box-shadow .55s,border-color .55s}.card:after{content:"";position:absolute;right:-75px;top:-80px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(231,243,255,.95),transparent 70%);opacity:.55;pointer-events:none}.card:hover{transform:translateY(-8px);box-shadow:0 28px 80px rgba(31,36,50,.11);border-color:rgba(129,122,255,.22)}.product-card{min-height:250px}.product-card h3{margin-top:18px}.card h3{font-size:1.35rem;line-height:1.15;letter-spacing:-.04em;margin:0 0 12px}.card p{color:var(--muted);margin:0 0 20px}.pill,.badge-soon{display:inline-flex;align-items:center;border-radius:999px;padding:7px 11px;background:#fff;border:1px solid var(--line);color:#606b80;font-size:.8rem;font-weight:650;position:relative;z-index:1}.badge-soon{color:#b46a00;background:#fff9ea;border-color:#f2d695}.icon-bubble{display:flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:17px;background:linear-gradient(135deg,var(--lav),#fff);font-size:1.4rem;font-weight:900;color:#2d2c73;box-shadow:0 15px 35px rgba(31,36,50,.08)}.icon-bubble.blue{background:linear-gradient(135deg,var(--sky),#fff);color:#223a78}.icon-bubble.green{background:linear-gradient(135deg,#e1fff3,#fff);color:#08795a}.icon-bubble.purple{background:linear-gradient(135deg,var(--lav),#fff);color:#7b4ed8}.link{font-weight:800;color:#141822;display:inline-flex;transition:transform .3s cubic-bezier(.16,1,.3,1)}.link:hover{transform:translateX(5px)}.service-nav{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.service-nav a{padding:10px 13px;background:#fff;border:1px solid var(--line);border-radius:999px;color:#4d5870}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:22px}.mini-feature{padding:18px;border-radius:20px;background:#fff;border:1px solid var(--line)}.list{padding:0;margin:18px 0 0;list-style:none}.list li{padding:12px 0;border-bottom:1px solid var(--line);color:#525b66}.form{display:grid;gap:12px}.form input,.form select,.form textarea{width:100%;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:#fff;font:inherit}.form textarea{min-height:130px}.quote-box{font-size:1.25rem;color:#3a3f48}.footer{padding:56px 0;background:#151720;color:#fff}.footer-grid{display:grid;grid-template-columns:1.35fr repeat(3,1fr);gap:34px}.footer a{display:block;color:rgba(255,255,255,.72);margin:8px 0}.footer p,.footer .lead{color:rgba(255,255,255,.72)!important}.footer strong{color:#fff}.footer-logo{width:44px;height:44px;filter:brightness(0) invert(1);opacity:.95;margin-bottom:14px}
/* Motion */
@media(prefers-reduced-motion:no-preference){.reveal,.reveal-left,.reveal-right,.reveal-card,.reveal-pop{opacity:0;filter:blur(10px);will-change:transform,opacity,filter;transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1),filter 1s cubic-bezier(.16,1,.3,1);transition-delay:var(--delay,0ms)}.reveal{transform:translate3d(0,38px,0)}.reveal-left{transform:translate3d(-42px,20px,0)}.reveal-right{transform:translate3d(42px,20px,0)}.reveal-card{transform:translate3d(0,34px,0) scale(.95)}.reveal-pop{transform:translate3d(0,18px,0) scale(.9)}.is-visible{opacity:1;filter:blur(0);transform:translate3d(0,0,0) scale(1)}.is-visible.float-soft{animation:floatSoft 7.5s ease-in-out infinite 1s}.is-visible.float-slower{animation:floatSlow 9s ease-in-out infinite 1s}@keyframes aurora{0%{transform:translateX(-2%) scale(1);opacity:.82}100%{transform:translateX(2%) scale(1.05);opacity:.95}}@keyframes floatSoft{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes floatSlow{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-9px) rotate(.3deg)}}}
/* Page transition */
body{opacity:0;filter:blur(4px);transform:translateY(8px);transition:opacity .55s cubic-bezier(.16,1,.3,1),filter .55s cubic-bezier(.16,1,.3,1),transform .55s cubic-bezier(.16,1,.3,1)}body.page-ready{opacity:1;filter:blur(0);transform:translateY(0)}.page-transition{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;pointer-events:none;opacity:0;visibility:hidden;background:rgba(251,251,248,.84);backdrop-filter:blur(0);transition:opacity .48s cubic-bezier(.16,1,.3,1),visibility .48s,backdrop-filter .48s}.page-transition__orb{position:absolute;width:42vw;max-width:520px;aspect-ratio:1;border-radius:999px;background:radial-gradient(circle,rgba(255,243,200,.95),rgba(238,232,255,.56) 45%,rgba(231,243,255,.56) 70%,transparent 76%);filter:blur(24px);transform:scale(.86);transition:transform .62s cubic-bezier(.16,1,.3,1)}.page-transition__text{position:relative;font-weight:850;letter-spacing:-.06em;font-size:clamp(26px,4vw,54px);opacity:0;transform:translateY(14px);transition:opacity .46s,transform .46s}body.page-leaving .page-transition{opacity:1;visibility:visible;backdrop-filter:blur(14px)}body.page-leaving .page-transition__orb{transform:scale(1.08)}body.page-leaving .page-transition__text{opacity:1;transform:translateY(0)}
@media(max-width:1080px){.grid.cols-4{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr;gap:40px}.visual{justify-self:start;max-width:620px}.nav{grid-template-columns:1fr auto}.menu{display:none}.mobile-toggle{display:block;justify-self:end;border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 14px;font-weight:800}.menu.open{position:absolute;left:20px;right:20px;top:86px;display:flex;flex-direction:column;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:22px;padding:12px;box-shadow:var(--shadow)}.nav-cta{display:none}.brand-logo span{font-size:1rem}}@media(max-width:720px){.wrap{width:min(100% - 32px,1280px)}.hero,.page-hero{padding:58px 0 50px}.hero h1,.page-hero h1{font-size:clamp(2.65rem,13vw,4.2rem)}.grid.cols-4,.grid.cols-3,.grid.cols-2,.footer-grid,.feature-grid{grid-template-columns:1fr}.head{display:block}.card{padding:24px}.footer-grid{gap:22px}.actions{gap:12px}.visual{border-radius:24px}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;filter:none!important;transform:none!important;opacity:1!important}.page-transition{display:none!important}body{opacity:1!important}}


/* === Real fixes 2026-05-19: header/logo/buttons/product badges === */
.brand-logo{
  min-width:190px;
  gap:0;
}
.brand-logo span{
  display:none;
}
.logo-img{
  width:170px !important;
  height:auto !important;
  max-height:46px;
  border-radius:0 !important;
  object-fit:contain;
}
.nav-cta{
  width:auto !important;
  min-width:0 !important;
  max-width:max-content !important;
  padding:13px 22px !important;
  white-space:nowrap;
  justify-self:end;
}
.actions .btn-soft{
  padding:13px 20px !important;
  border-radius:12px !important;
  background:#fff !important;
  border:1px solid var(--line) !important;
  box-shadow:0 14px 34px rgba(31,36,50,.06) !important;
}
.actions .btn-soft:hover{
  background:#fff !important;
  box-shadow:0 20px 48px rgba(31,36,50,.12) !important;
}
.product-card .pill,
.product-card .badge-soon,
.card .pill,
.card .badge-soon{
  margin-bottom:16px;
  vertical-align:top;
}
.product-card h3{
  margin-top:0 !important;
  clear:both;
}
.product-card .icon-bubble + .pill,
.product-card .icon-bubble + .badge-soon{
  float:right;
  margin-top:0;
}
.footer-logo{
  width:170px !important;
  height:auto !important;
  filter:brightness(0) invert(1) !important;
  opacity:.96;
}
@media(max-width:1080px){
  .brand-logo{min-width:auto;}
  .logo-img{width:150px !important;max-height:42px;}
}
@media(max-width:720px){
  .logo-img{width:138px !important;}
  .actions .btn-soft{padding:12px 17px !important;}
}
/* WordPress theme compatibility */
.container{width:min(1280px,calc(100% - 56px));margin-inline:auto}.site-header{position:sticky;top:0;z-index:50;background:rgba(251,251,248,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.nav-wrap{height:78px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:22px}.brand{display:flex;align-items:center;gap:14px;font-weight:850}.brand img,.custom-logo{width:auto;max-width:168px;max-height:44px}.main-nav{display:flex;align-items:center;gap:18px;justify-content:center}.main-nav a{padding:11px 18px;border-radius:999px;color:#1d2330;font-weight:650;font-size:.96rem;transition:transform .28s cubic-bezier(.16,1,.3,1),box-shadow .28s,background .28s}.main-nav a:hover,.main-nav .current-menu-item>a{background:#fff;box-shadow:0 16px 44px rgba(20,25,35,.08);transform:translateY(-2px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;border-radius:12px;font-weight:800}.btn-primary{background:#151720;color:#fff;box-shadow:0 18px 42px rgba(10,10,15,.17)}.btn-secondary{background:transparent;color:#151720;border-bottom:1px solid rgba(20,24,34,.25);border-radius:0}.site-footer{padding:56px 0;background:#151720;color:#fff}.footer-brand img{filter:brightness(0) invert(1);opacity:.95;max-width:168px;max-height:44px}.footer-grid{display:grid;grid-template-columns:1.35fr repeat(3,1fr);gap:34px}.site-footer a{display:block;color:rgba(255,255,255,.72);margin:8px 0}.site-footer p{color:rgba(255,255,255,.72)}.footer-bottom{padding-top:28px;color:rgba(255,255,255,.58);font-size:.92rem}.wp-content{padding:74px 0}.nav-cta{width:auto;min-width:0;padding-inline:22px;justify-self:end}.product-card .pill,.product-card .badge-soon{margin-bottom:14px}.product-card h3{margin-top:0}.page-transition{position:fixed;inset:0;background:rgba(252,252,250,.94);z-index:9999;pointer-events:none;opacity:0;transform:translateY(8px);transition:opacity .45s ease,transform .45s ease}body.is-leaving .page-transition{opacity:1;transform:translateY(0)}
@media(max-width:1080px){.nav-wrap{grid-template-columns:1fr auto}.main-nav{display:none}.nav-cta{display:none}.footer-grid{grid-template-columns:1fr 1fr}}@media(max-width:720px){.container{width:min(100% - 32px,1280px)}.footer-grid{grid-template-columns:1fr}.brand img,.custom-logo{max-width:142px}}


/* === Fix reale 2026-05-19: no doppio scroll / menu WP / transizione sicura === */
html{
  width:100%;
  max-width:100%;
  min-height:100%;
  overflow-x:clip !important;
  overflow-y:auto !important;
}
body{
  width:100%;
  max-width:100%;
  min-height:100%;
  overflow-x:clip !important;
  overflow-y:visible !important;
  opacity:1 !important;
  filter:none !important;
  transform:none !important;
}
#content,
.wp-site-blocks,
.site,
.site-main,
.wp-content,
.entry-content{
  height:auto !important;
  max-height:none !important;
  overflow:visible !important;
}
.site-header,
.hero,
.page-hero,
.section,
.site-footer{
  max-width:100%;
  overflow-x:clip;
}
.main-nav ul,
.main-nav li{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}
.main-nav ul{
  display:flex;
  align-items:center;
  gap:18px;
}
.main-nav li::marker{content:"";}
.main-nav li{display:flex;align-items:center;}
.brand img.brand-logo,
.brand .custom-logo{
  display:block;
  width:auto !important;
  max-width:168px !important;
  max-height:44px !important;
  height:auto !important;
  border-radius:0 !important;
}
.nav-cta.btn{
  width:auto !important;
  min-width:0 !important;
  max-width:max-content !important;
  padding:13px 22px !important;
  white-space:nowrap;
}
.page-transition{
  position:fixed !important;
  inset:0 !important;
  width:100vw !important;
  height:100vh !important;
  overflow:hidden !important;
}
@supports not (overflow: clip){
  html,body{overflow-x:hidden !important;}
}

/* === DEFINITIVE FIX 2026-05-19: single scroll container ===
   Chrome/WordPress can show two vertical scrollbars when both html and body
   participate in document scrolling. We force one scroll container only. */
html{
  height:100% !important;
  min-height:100% !important;
  overflow:hidden !important;
  width:100% !important;
  max-width:100% !important;
}
body.zs-body,
body{
  height:100% !important;
  min-height:100% !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  width:100% !important;
  max-width:100% !important;
  position:relative;
  -webkit-overflow-scrolling:touch;
}
#page,
.site,
.site-main,
#primary,
#content,
.wp-site-blocks,
.wp-content,
.entry-content,
main{
  min-height:auto !important;
  height:auto !important;
  max-height:none !important;
  overflow:visible !important;
}
.site-header{
  position:sticky;
  top:0;
}
.page-transition{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  overflow:hidden !important;
}

/* === Zen 2026 update: SEO pages + real people imagery === */
.page-hero-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.72fr);gap:58px;align-items:center}.page-photo{border:1px solid var(--line);border-radius:30px;overflow:hidden;background:#fff;box-shadow:var(--shadow);max-width:440px;justify-self:end}.page-photo img{display:block;width:100%;aspect-ratio:1.35/1;object-fit:cover}.zs-service-content{max-width:1040px;margin:0 auto;color:#333944}.zs-service-content .lead{font-size:clamp(1.18rem,1.8vw,1.45rem);color:#536075;max-width:900px;margin-bottom:28px}.zs-service-content h2{font-size:clamp(1.75rem,2.7vw,2.75rem);line-height:1.08;letter-spacing:-.055em;margin:52px 0 16px;color:#151720}.zs-service-content p{font-size:1.07rem;color:#596579;max-width:900px}.zs-service-content ul{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px 18px;padding:0;margin:24px 0 12px;list-style:none}.zs-service-content li{position:relative;padding:17px 18px 17px 46px;border:1px solid var(--line);border-radius:19px;background:rgba(255,255,255,.82);box-shadow:0 14px 38px rgba(31,36,50,.05);color:#4f5a70}.zs-service-content li:before{content:"✓";position:absolute;left:17px;top:17px;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;background:var(--yellow);color:#151720;font-weight:900;font-size:.78rem}.zs-quote-section{margin-top:60px;padding:34px;border-radius:30px;border:1px solid var(--line);background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(231,243,255,.45),rgba(238,232,255,.36));box-shadow:var(--shadow);display:grid;grid-template-columns:minmax(0,.86fr) minmax(320px,1.14fr);gap:34px;align-items:start}.zs-quote-copy h2{margin:14px 0 12px!important;font-size:clamp(1.85rem,3vw,2.85rem)}.zs-quote-copy p{margin:0;color:#596579}.zs-fluent-form,.zs-quote-form{padding:22px;border-radius:24px;background:#fff;border:1px solid var(--line);box-shadow:0 16px 44px rgba(31,36,50,.045)}.zs-fluent-form .ff-el-group{margin-bottom:14px!important}.zs-fluent-form input,.zs-fluent-form select,.zs-fluent-form textarea{border-radius:14px!important;border:1px solid var(--line)!important;padding:13px 15px!important}.zs-fluent-form .ff-btn-submit{border-radius:14px!important;background:#151720!important;color:#fff!important;font-weight:800!important;padding:13px 22px!important;border:0!important}.visual.real-photo,.people-visual{border-radius:30px;overflow:hidden}.people-row{display:grid;grid-template-columns:minmax(360px,.85fr) minmax(0,1.15fr);gap:58px;align-items:center}.people-row img{width:100%;aspect-ratio:1.35/1;object-fit:cover}@media(max-width:1080px){.page-hero-grid,.zs-quote-section,.people-row{grid-template-columns:1fr}.page-photo{justify-self:start}.zs-service-content ul{grid-template-columns:1fr}}@media(max-width:720px){.page-photo{display:block;max-width:100%}.zs-quote-section{padding:24px}.zs-service-content p{font-size:1rem}.zs-service-content h2{margin-top:38px}.zs-service-content li{padding-right:15px}}


/* === Home real people update === */
.home-hero .home-photo-card{position:relative;max-width:500px;box-shadow:0 34px 100px rgba(31,36,50,.13)}
.home-hero .home-photo-card img{aspect-ratio:1.08/1;object-fit:cover;object-position:center}
.photo-caption{position:absolute;left:18px;right:18px;bottom:18px;padding:16px 18px;border:1px solid rgba(255,255,255,.55);border-radius:20px;background:rgba(255,255,255,.78);backdrop-filter:blur(18px);box-shadow:0 18px 42px rgba(31,36,50,.10);display:grid;gap:2px}
.photo-caption strong{font-size:1rem;letter-spacing:-.03em;color:#151720}.photo-caption span{font-size:.92rem;color:#596579}.home-human-section{background:linear-gradient(180deg,var(--bg),#fff)}.home-human-section h2,.home-work-photo-section h2{font-size:clamp(2rem,3.4vw,3.35rem);line-height:1.05;letter-spacing:-.06em;margin:18px 0 18px}.home-human-features .mini-feature{display:grid;gap:6px}.home-human-features .mini-feature strong{font-size:1.02rem;color:#151720;letter-spacing:-.025em}.home-human-features .mini-feature span{color:#596579}.compact-split{grid-template-columns:minmax(0,1fr) minmax(340px,.72fr);gap:58px}.compact-split .visual{max-width:480px}.compact-split .visual img{aspect-ratio:1.18/1;object-fit:cover}.home-work-photo-section{position:relative;overflow:hidden}.home-work-photo-section:before{content:"";position:absolute;inset:auto -12vw -180px -12vw;height:360px;background:radial-gradient(circle at 18% 30%,rgba(255,243,200,.68),transparent 32%),radial-gradient(circle at 65% 20%,rgba(238,232,255,.58),transparent 36%),radial-gradient(circle at 82% 48%,rgba(231,243,255,.72),transparent 34%);filter:blur(26px);pointer-events:none}
@media(max-width:1080px){.compact-split{grid-template-columns:1fr}.home-hero .home-photo-card img{aspect-ratio:1.35/1}.photo-caption{position:relative;left:auto;right:auto;bottom:auto;margin:12px;border-color:var(--line)}}
@media(max-width:720px){.home-human-section h2,.home-work-photo-section h2{font-size:clamp(2rem,10vw,3rem)}.home-hero .home-photo-card{max-width:100%}.home-hero .home-photo-card img,.compact-split .visual img{aspect-ratio:1.05/1}.photo-caption{padding:14px}}

/* Customizer support */
.site-header.is-static{position:relative;top:auto;}
.site-header.is-sticky{position:sticky;top:0;}
.footer-brand .custom-logo{filter:brightness(0) invert(1);opacity:.95;}
.footer-logo{filter:brightness(0) invert(1);opacity:.95;}
.site-footer .footer-line {
  display: block;
  color: rgba(255,255,255,.72);
  line-height: 1.65;
  margin: 0 0 6px;
}

/* === Header custom logo hard fix: no nested WP logo link, stable layout === */
.site-header .nav-wrap{
  display:grid !important;
  grid-template-columns:minmax(190px,1fr) auto minmax(150px,1fr) !important;
  align-items:center !important;
  gap:24px !important;
  min-height:78px !important;
  height:auto !important;
  padding-block:10px !important;
}
.site-header .brand{
  justify-self:start !important;
  display:inline-flex !important;
  align-items:center !important;
  min-width:0 !important;
  max-width:260px !important;
  line-height:0 !important;
}
.site-header .brand-logo-img,
.site-header .brand img,
.site-header .custom-logo{
  display:block !important;
  width:auto !important;
  height:auto !important;
  max-width:190px !important;
  max-height:52px !important;
  object-fit:contain !important;
  border-radius:0 !important;
}
.site-header .main-nav{
  justify-self:center !important;
  min-width:0 !important;
}
.site-header .nav-cta{
  justify-self:end !important;
  width:auto !important;
  min-width:0 !important;
  max-width:max-content !important;
  padding:13px 22px !important;
  white-space:nowrap !important;
  margin:0 !important;
}
@media(max-width:1080px){
  .site-header .nav-wrap{grid-template-columns:1fr auto !important;}
  .site-header .brand-logo-img,.site-header .brand img,.site-header .custom-logo{max-width:170px !important;max-height:48px !important;}
}
@media(max-width:720px){
  .site-header .brand-logo-img,.site-header .brand img,.site-header .custom-logo{max-width:150px !important;max-height:44px !important;}
}

/* === Mobile navigation + spacing fixes 2026-05-19 === */
.mobile-menu-toggle{
  display:none;
  appearance:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.86);
  width:46px;
  height:46px;
  border-radius:16px;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  box-shadow:0 14px 34px rgba(31,36,50,.08);
  cursor:pointer;
  justify-self:end;
  z-index:80;
}
.mobile-menu-toggle span{
  display:block;
  width:18px;
  height:2px;
  border-radius:99px;
  background:#151720;
  transition:transform .28s cubic-bezier(.16,1,.3,1),opacity .28s;
}
.mobile-menu-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-toggle.is-open span:nth-child(2){opacity:0}
.mobile-menu-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.main-nav .primary-menu-list{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  list-style:none;
  padding:0;
  margin:0;
}
.main-nav .primary-menu-list li{margin:0;padding:0;list-style:none;}
.main-nav .primary-menu-list li::marker{content:"";}

@media(max-width:1080px){
  .site-header .nav-wrap{
    grid-template-columns:minmax(0,1fr) auto !important;
    min-height:72px !important;
    position:relative;
  }
  .mobile-menu-toggle{display:inline-flex !important;}
  .site-header .nav-cta{display:none !important;}
  .site-header .main-nav{
    position:absolute !important;
    left:0;
    right:0;
    top:calc(100% + 10px);
    display:block !important;
    opacity:0;
    visibility:hidden;
    transform:translateY(-8px) scale(.98);
    pointer-events:none;
    transition:opacity .28s cubic-bezier(.16,1,.3,1),transform .28s cubic-bezier(.16,1,.3,1),visibility .28s;
    z-index:70;
  }
  .site-header .main-nav.is-open{
    opacity:1;
    visibility:visible;
    transform:translateY(0) scale(1);
    pointer-events:auto;
  }
  .main-nav .primary-menu-list,
  .site-header .main-nav > ul{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:flex-start !important;
    gap:6px !important;
    padding:12px !important;
    margin:0 !important;
    list-style:none !important;
    background:rgba(255,255,255,.96);
    border:1px solid var(--line);
    border-radius:24px;
    box-shadow:0 24px 70px rgba(31,36,50,.14);
    backdrop-filter:blur(18px);
  }
  .site-header .main-nav a{
    display:flex !important;
    width:100% !important;
    justify-content:center !important;
    padding:14px 16px !important;
    border-radius:16px !important;
  }
}

@media(max-width:720px){
  .hero,.page-hero{padding-top:46px !important;padding-bottom:42px !important;}
  .section{padding-top:54px !important;padding-bottom:54px !important;}
  .kicker,.breadcrumb,.pill,.badge-soon{margin-bottom:14px !important;}
  .product-card .pill,.product-card .badge-soon,.card .pill,.card .badge-soon{margin-bottom:16px !important;}
  .card h3{margin-top:0 !important;}
  .head{margin-bottom:24px !important;}
  .head p{margin-top:12px !important;}
  .actions{margin-top:24px !important;}
  .site-header .brand-logo-img,.site-header .brand img,.site-header .custom-logo{max-width:142px !important;max-height:42px !important;}
  .site-header .nav-wrap{padding-block:8px !important;}
}

/* Product pages: external product CTA instead of quote form */
.zs-product-cta{
  margin-top:60px;
  padding:34px;
  border-radius:30px;
  border:1px solid var(--line);
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(255,242,190,.35),rgba(220,238,255,.42),rgba(231,221,248,.32));
  box-shadow:var(--shadow);
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:28px;
  align-items:center;
}
.zs-product-cta h2{
  margin:16px 0 10px!important;
  font-size:clamp(1.85rem,3vw,2.85rem);
  line-height:1.05;
  letter-spacing:-.055em;
}
.zs-product-cta p{margin:0;color:#596579;max-width:720px;font-size:1.06rem}
.zs-product-cta-action{display:flex;justify-content:flex-end;align-items:center}
.zs-product-cta .btn{white-space:nowrap}
@media(max-width:820px){
  .zs-product-cta{grid-template-columns:1fr;padding:24px;margin-top:42px}
  .zs-product-cta-action{justify-content:flex-start}
  .zs-product-cta .btn{white-space:normal;width:100%;justify-content:center;text-align:center}
}


/* === Zen Software 2.1.0 production fixes === */
.site-footer .custom-logo,
.site-footer .custom-logo-link img,
.site-footer .footer-logo,
.site-footer .footer-logo img {
  filter: brightness(0) invert(1);
  opacity: .95;
}

.footer-legal-links {
  width: min(1180px, calc(100% - 48px));
  margin: 28px auto 0;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.14);
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  align-items: center;
  color: rgba(255,255,255,.72);
  font-size: 14px;
}

.footer-legal-links a,
.footer-legal-links button,
.footer-legal-links .cmplz-show-banner {
  color: rgba(255,255,255,.82) !important;
  text-decoration: none;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  font: inherit !important;
  cursor: pointer;
}

.footer-legal-links a:hover,
.footer-legal-links button:hover,
.footer-legal-links .cmplz-show-banner:hover {
  color: #fff !important;
}

.zen-form-fallback {
  padding: 22px;
  border: 1px solid rgba(18,20,27,.10);
  border-radius: 20px;
  background: rgba(255,255,255,.72);
}

.zen-product-cta {
  margin-top: 30px;
}

.entry-content .zen-btn,
.zen-product-cta .zen-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 13px 22px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 800;
}

.entry-content .zen-btn-primary,
.zen-product-cta .zen-btn-primary {
  background: #13141a;
  color: #fff;
  box-shadow: 0 18px 44px rgba(20,20,30,.16);
}

@media (max-width: 768px) {
  .footer-legal-links {
    width: min(100% - 32px, 1180px);
    gap: 12px;
    flex-direction: column;
    align-items: flex-start;
  }

  .kicker,
  .badge,
  .pill {
    margin-bottom: 12px;
  }
}


/* === Zen Software Theme 2.1.1 - Footer cookie/social polish === */
.site-footer .cmplz-cookiebanner,
.site-footer .cmplz-cookiebanner-container,
.site-footer .cmplz-document .cmplz-dropdown,
.site-footer .cmplz-dropdown,
.site-footer .cmplz-category,
.site-footer .cmplz-categories,
.site-footer .cmplz-cookiebanner .cmplz-categories,
.site-footer .cmplz-no-js {
  display: none !important;
}

.footer-legal-links .zen-cookie-preferences,
.footer-legal-links .cmplz-show-banner {
  color: rgba(255,255,255,.82) !important;
  text-decoration: none !important;
  transition: color .25s ease, opacity .25s ease;
  cursor: pointer;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  font: inherit !important;
}

.footer-legal-links .zen-cookie-preferences:hover,
.footer-legal-links .cmplz-show-banner:hover {
  color: #fff !important;
  opacity: .95;
}

.footer-social-icons {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
}

.footer-social-icons a {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  color: rgba(255,255,255,.78);
  text-decoration: none;
  transition: transform .25s ease, color .25s ease, border-color .25s ease, background .25s ease;
}

.footer-social-icons a:hover {
  transform: translateY(-2px);
  color: #fff;
  border-color: rgba(255,255,255,.32);
  background: rgba(255,255,255,.06);
}

.footer-social-icons svg {
  width: 17px;
  height: 17px;
  display: block;
  fill: currentColor;
}


/* === Zen Software Theme 2.1.2 - Global WhatsApp and footer consistency === */
.zen-whatsapp-badge {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 9999;
  width: 58px;
  height: 58px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #25d366;
  color: #fff;
  box-shadow: 0 18px 48px rgba(37, 211, 102, .32);
  text-decoration: none;
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
}

.zen-whatsapp-badge:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 22px 58px rgba(37, 211, 102, .42);
  filter: brightness(1.03);
}

.zen-whatsapp-badge svg {
  width: 32px;
  height: 32px;
  fill: currentColor;
}

@media (max-width: 768px) {
  .zen-whatsapp-badge {
    width: 52px;
    height: 52px;
    right: 18px;
    bottom: 18px;
  }

  .zen-whatsapp-badge svg {
    width: 29px;
    height: 29px;
  }
}


/* === Zen Software Theme 2.1.3 - footer/Complianz consistency === */

/* Hide only the ugly inline manage-consent fallback inside the footer. The real banner remains untouched. */
.site-footer .cmplz-manage-consent-container,
.site-footer .cmplz-cookiebanner-container,
.site-footer .cmplz-cookiebanner,
.site-footer .cmplz-categories,
.site-footer .cmplz-category,
.site-footer .cmplz-dropdown,
.site-footer .cmplz-no-js,
.site-footer details,
.site-footer summary,
.site-footer input[type="checkbox"] {
  display: none !important;
}

.site-footer .footer-legal-links .cmplz-show-banner,
.site-footer .footer-legal-links .zen-cookie-preferences {
  display: inline-flex !important;
  color: rgba(255,255,255,.86) !important;
  text-decoration: none !important;
  cursor: pointer;
}

.site-footer .footer-legal-links .cmplz-show-banner:hover,
.site-footer .footer-legal-links .zen-cookie-preferences:hover {
  color: #fff !important;
}

/* Keep footer social icons inline and prevent raw social text layout. */
.site-footer .footer-social-icons {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
}

.site-footer .footer-social-icons a {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  color: rgba(255,255,255,.78);
  text-decoration: none;
  transition: transform .25s ease, color .25s ease, border-color .25s ease, background .25s ease;
}

.site-footer .footer-social-icons a:hover {
  transform: translateY(-2px);
  color: #fff;
  border-color: rgba(255,255,255,.32);
  background: rgba(255,255,255,.06);
}

.site-footer .footer-social-icons svg {
  width: 17px;
  height: 17px;
  display: block;
  fill: currentColor;
}

/* Safety: WhatsApp badge should always sit above theme content but below cookie banner modals. */
.zen-whatsapp-badge {
  z-index: 9990 !important;
}


/* === Zen Software Theme 2.1.4 - clean rebuilt footer === */
.site-footer {
  background: #15161d;
  color: rgba(255,255,255,.72);
  padding: 72px 0 42px;
  overflow: hidden;
}

.site-footer-inner {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.35fr .7fr .9fr 1fr;
  gap: 68px;
  align-items: start;
}

.footer-brand p,
.site-footer p {
  color: rgba(255,255,255,.68);
  font-size: 18px;
  line-height: 1.55;
  margin: 22px 0 0;
}

.footer-copy {
  margin-top: 48px !important;
  font-size: 15px !important;
  color: rgba(255,255,255,.55) !important;
}

.footer-logo-link {
  display: inline-flex;
  align-items: center;
  max-width: 180px;
  text-decoration: none;
}

.footer-logo-img,
.footer-logo-link img {
  max-height: 58px;
  width: auto;
  max-width: 180px;
  display: block;
  filter: brightness(0) invert(1);
  opacity: .95;
}

.footer-logo-text {
  color: #fff;
  font-weight: 850;
  font-size: 22px;
}

.footer-col h3 {
  color: #fff;
  font-size: 18px;
  margin: 0 0 24px;
}

.footer-col a,
.footer-col span {
  display: block;
  color: rgba(255,255,255,.66);
  text-decoration: none;
  font-size: 18px;
  font-weight: 650;
  line-height: 1.35;
  margin: 0 0 16px;
  transition: color .22s ease, transform .22s ease;
}

.footer-col a:hover {
  color: #fff;
  transform: translateX(2px);
}

.footer-social-icons {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  gap: 12px;
  margin-top: 20px;
}

.footer-social-icons a {
  width: 36px;
  height: 36px;
  margin: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  color: rgba(255,255,255,.78);
  text-decoration: none;
  transition: transform .25s ease, color .25s ease, border-color .25s ease, background .25s ease;
}

.footer-social-icons a:hover {
  transform: translateY(-2px);
  color: #fff;
  border-color: rgba(255,255,255,.32);
  background: rgba(255,255,255,.06);
}

.footer-social-icons svg {
  width: 17px;
  height: 17px;
  display: block;
  fill: currentColor;
}

.footer-legal-links {
  width: min(1180px, calc(100% - 48px));
  margin: 44px auto 0;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.14);
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  align-items: center;
}

.footer-legal-links a,
.footer-legal-links button {
  color: rgba(255,255,255,.84) !important;
  text-decoration: none !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  font: inherit !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer;
  appearance: none;
}

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

/* Kill only ugly Complianz inline/fallback elements inside footer */
.site-footer .cmplz-cookiebanner,
.site-footer .cmplz-cookiebanner-container,
.site-footer .cmplz-manage-consent-container,
.site-footer .cmplz-categories,
.site-footer .cmplz-category,
.site-footer .cmplz-dropdown,
.site-footer .cmplz-no-js,
.site-footer details,
.site-footer summary,
.site-footer input[type="checkbox"] {
  display: none !important;
}

@media (max-width: 900px) {
  .site-footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 42px;
  }
}

@media (max-width: 640px) {
  .site-footer {
    padding: 54px 0 34px;
  }

  .site-footer-inner,
  .footer-legal-links {
    width: min(100% - 32px, 1180px);
  }

  .site-footer-inner {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .footer-legal-links {
    gap: 14px;
    align-items: flex-start;
    flex-direction: column;
  }
}


/* === Zen Software Theme 2.1.5 - WordPress admin bar fix === */
#wpadminbar {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: 999999 !important;
}

html.wp-toolbar {
  padding-top: 32px !important;
}

body.admin-bar .site-header,
body.admin-bar header.site-header,
body.admin-bar .zen-header {
  top: 32px;
}

@media screen and (max-width: 782px) {
  html.wp-toolbar {
    padding-top: 46px !important;
  }

  body.admin-bar .site-header,
  body.admin-bar header.site-header,
  body.admin-bar .zen-header {
    top: 46px;
  }
}



