
:root{--blue:#0d6bff;--green:#18d11d;--bg:#050505;--bg2:#0a0a0b;--line:rgba(255,255,255,.12);--muted:#a1a1aa;--text:#f5f5f7}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-feature-settings:"ss01" 1,"cv01" 1;text-rendering:optimizeLegibility}.site-bg{position:fixed;inset:0;z-index:-2;background:radial-gradient(900px 520px at 8% -8%,rgba(13,107,255,.20),transparent 65%),radial-gradient(760px 480px at 96% 4%,rgba(24,209,29,.15),transparent 68%),radial-gradient(900px 520px at 74% 76%,rgba(13,107,255,.10),transparent 72%),linear-gradient(180deg,#050505,#0a0a0b 46%,#050505)}.site-bg:after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:112px 112px;mask-image:linear-gradient(to bottom,transparent,black 8%,black 86%,transparent);opacity:.2}.blue{color:var(--blue)}.green{color:var(--green)}.muted{color:var(--muted)}.glass{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));border:1px solid var(--line);box-shadow:0 1px 0 rgba(255,255,255,.08) inset,0 36px 120px rgba(0,0,0,.38)}.panel{background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid var(--line);box-shadow:0 1px 0 rgba(255,255,255,.06) inset}.panel-blue{border-color:rgba(13,107,255,.38);box-shadow:0 1px 0 rgba(255,255,255,.07) inset,0 0 0 1px rgba(13,107,255,.06),0 24px 80px rgba(13,107,255,.08)}.panel-green{border-color:rgba(24,209,29,.34);box-shadow:0 1px 0 rgba(255,255,255,.07) inset,0 0 0 1px rgba(24,209,29,.05),0 24px 80px rgba(24,209,29,.07)}.eyebrow{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:#9ca3af}.btn-primary{background:linear-gradient(180deg,#fff,#e6edff);color:#050505;border:1px solid rgba(255,255,255,.45);box-shadow:0 16px 60px rgba(13,107,255,.16)}.btn-dark{background:rgba(255,255,255,.045);border:1px solid var(--line);color:white}.nav-link{color:#a1a1aa;transition:color .2s ease}.nav-link:hover,.nav-link.active{color:#fff}.hairline{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent)}.brand-bar{height:2px;background:linear-gradient(90deg,var(--blue),rgba(13,107,255,.05),var(--green))}.stack{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);box-shadow:0 1px 0 rgba(255,255,255,.05) inset}.reveal{opacity:0;transform:translateY(18px);transition:opacity .75s ease,transform .75s ease}.reveal.is-visible{opacity:1;transform:none}.section-step{min-height:calc(100vh - 5rem);scroll-margin-top:5rem;display:grid;align-items:center}.step-link{position:relative;color:#71717a}.step-link:before{content:"";position:absolute;left:0;top:50%;width:.55rem;height:.55rem;border-radius:999px;background:#3f3f46;transform:translateY(-50%);transition:.2s}.step-link.active{color:white}.step-link.active:before{background:linear-gradient(135deg,var(--blue),var(--green));box-shadow:0 0 24px rgba(13,107,255,.4)}.detail-card [data-detail-list] li{display:flex;gap:.6rem;align-items:flex-start}.detail-card [data-detail-list] li:before{content:"";width:.4rem;height:.4rem;border-radius:999px;background:linear-gradient(135deg,var(--blue),var(--green));margin-top:.55rem;flex:none}.mini-map{position:relative;min-height:340px;background:radial-gradient(circle at 50% 30%,rgba(13,107,255,.12),transparent 38%),rgba(255,255,255,.025);overflow:hidden}.mini-map:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:38px 38px;mask-image:radial-gradient(circle at center,black,transparent 78%);opacity:.7}.node{position:absolute;border:1px solid rgba(255,255,255,.14);background:rgba(8,8,10,.82);backdrop-filter:blur(10px);border-radius:18px;padding:16px;box-shadow:0 1px 0 rgba(255,255,255,.05) inset}.node strong{display:block;font-weight:600}.node small{color:#a1a1aa}.line{position:absolute;height:1px;background:linear-gradient(90deg,transparent,var(--blue),transparent);transform-origin:left center}.line.greenline{background:linear-gradient(90deg,transparent,var(--green),transparent)}.line.dashed{background:none;border-top:1px dashed rgba(24,209,29,.7)}.metric{font-variant-numeric:tabular-nums}.doc-surface{background:#f6f7f9;color:#0a0a0b}.doc-surface .doc-card{background:white;border:1px solid rgba(0,0,0,.09);box-shadow:0 18px 70px rgba(0,0,0,.08)}@media(max-width:1023px){.section-step{min-height:auto;padding:4rem 0}.desktop-only{display:none!important}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}}

/* v3: refined vertical architecture and hero map */
.hero-system-map{position:relative;min-height:620px;border:1px solid rgba(255,255,255,.12);border-radius:32px;background:radial-gradient(760px 420px at 44% 18%,rgba(13,107,255,.17),transparent 58%),radial-gradient(620px 360px at 74% 58%,rgba(24,209,29,.10),transparent 68%),linear-gradient(180deg,rgba(255,255,255,.052),rgba(255,255,255,.018));box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 28px 120px rgba(0,0,0,.42);overflow:hidden;isolation:isolate}.hero-system-map:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(circle at 50% 42%,black,transparent 78%);opacity:.55}.hero-system-map:after{content:"";position:absolute;inset:1px;border-radius:31px;background:linear-gradient(90deg,rgba(13,107,255,.16),transparent 33%,transparent 66%,rgba(24,209,29,.12));pointer-events:none;opacity:.55}.system-map-lines{position:absolute;inset:0;z-index:1;width:100%;height:100%;filter:drop-shadow(0 0 12px rgba(13,107,255,.18))}.map-link{fill:none;stroke-width:2.2;stroke-linecap:round}.blue-link{stroke:rgba(13,107,255,.84)}.green-link{stroke:rgba(24,209,29,.78)}.net-link{stroke:rgba(24,209,29,.5);stroke-dasharray:8 8}.map-card{position:absolute;z-index:2;border:1px solid rgba(255,255,255,.13);background:linear-gradient(180deg,rgba(12,12,14,.92),rgba(8,8,10,.82));backdrop-filter:blur(14px);border-radius:22px;padding:18px 20px;box-shadow:0 1px 0 rgba(255,255,255,.06) inset;min-width:178px}.map-card strong{display:block;font-size:1.04rem;font-weight:650;letter-spacing:-.025em}.map-card small{display:block;margin-top:.35rem;color:#a1a1aa;line-height:1.35}.map-card img{height:34px;width:auto;margin-bottom:.85rem}.map-core{left:40%;top:9%;width:285px;border-color:rgba(13,107,255,.42);background:radial-gradient(300px 220px at 35% 18%,rgba(13,107,255,.20),transparent 64%),rgba(8,8,10,.9)}.map-core strong{font-size:1.42rem}.map-core ul{margin-top:1rem;display:grid;gap:.38rem}.map-core li{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.035);border-radius:10px;padding:.42rem .7rem;font-size:.76rem;color:#d4d4d8}.map-manager{left:7%;top:17%;border-color:rgba(13,107,255,.27)}.map-operator{right:6%;top:17%;border-color:rgba(24,209,29,.28)}.map-router{left:8%;top:50%;border-color:rgba(13,107,255,.27)}.map-gateway{left:38%;top:62%;width:310px;border-color:rgba(24,209,29,.38);background:radial-gradient(360px 220px at 50% 50%,rgba(24,209,29,.16),transparent 70%),rgba(8,8,10,.9)}.map-plc{right:7%;top:48%;border-color:rgba(13,107,255,.27)}.map-index{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:rgba(255,255,255,.05);margin-bottom:.85rem;font-size:.7rem;font-weight:750}.map-chip{position:absolute;z-index:3;border:1px solid rgba(255,255,255,.12);background:rgba(5,5,5,.68);backdrop-filter:blur(10px);border-radius:999px;padding:.45rem .72rem;font-size:.72rem;line-height:1.1;color:#d4d4d8;white-space:nowrap}.chip-config{left:29%;top:26%}.chip-bidir{right:26%;top:27%}.chip-control{right:20%;top:41%}.chip-measure{left:43%;top:48%;color:#c8facc;border-color:rgba(24,209,29,.18)}.map-slaves{position:absolute;z-index:2;left:10%;right:10%;bottom:6%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.map-slaves div{border:1px solid rgba(24,209,29,.23);background:rgba(8,8,10,.78);border-radius:18px;padding:1rem;color:#fff;font-weight:600}.map-slaves small{display:block;margin-top:.3rem;color:#a1a1aa;font-weight:400}.architecture-wrap{max-width:1840px;margin-inline:auto;padding-inline:clamp(1.25rem,3vw,3.5rem)}.architecture-grid{display:grid;grid-template-columns:minmax(240px,280px) minmax(0,820px) minmax(340px,410px);gap:clamp(2rem,5vw,7rem);align-items:start;justify-content:space-between}.architecture-menu-wrap,.architecture-detail-wrap{position:sticky;top:6rem;align-self:start}.architecture-menu{position:relative;border:1px solid rgba(255,255,255,.11);background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border-radius:28px;padding:1rem;box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 28px 100px rgba(0,0,0,.28)}.architecture-menu:before{content:"";position:absolute;left:2.28rem;top:5.2rem;bottom:1.8rem;width:1px;background:linear-gradient(to bottom,var(--blue),rgba(255,255,255,.12),var(--green));opacity:.55}.menu-kicker{padding:.25rem .75rem 1rem;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:#a1a1aa}.architecture-menu .step-link{position:relative;z-index:1;display:grid;grid-template-columns:2.25rem minmax(0,1fr);gap:.8rem;align-items:center;margin:.18rem 0;padding:.72rem .75rem;border:1px solid transparent;border-radius:18px;color:#a1a1aa;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}.architecture-menu .step-link:before{display:none}.architecture-menu .step-link strong{display:block;color:#d4d4d8;font-size:.9rem;font-weight:600;letter-spacing:-.015em}.architecture-menu .step-link small{display:block;margin-top:.14rem;color:#71717a;font-size:.73rem}.architecture-menu .step-link .step-no{display:grid;place-items:center;width:2.25rem;height:2.25rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#09090b;color:#a1a1aa;font-size:.74rem;font-weight:700}.architecture-menu .step-link.active{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));border-color:rgba(255,255,255,.14);color:#fff;transform:translateX(4px)}.architecture-menu .step-link.active strong{color:#fff}.architecture-menu .step-link.active small{color:#a1a1aa}.architecture-menu .step-link.active .step-no{border-color:rgba(13,107,255,.45);background:linear-gradient(135deg,rgba(13,107,255,.32),rgba(24,209,29,.18));color:#fff;box-shadow:0 0 34px rgba(13,107,255,.24)}.architecture-content{min-width:0}.architecture-content .section-step{padding-block:clamp(2rem,4vh,3.5rem)}.architecture-detail-wrap{justify-self:end;width:min(100%,410px)}.architecture-detail-wrap .detail-card{background:radial-gradient(460px 260px at 90% 0%,rgba(24,209,29,.09),transparent 64%),radial-gradient(460px 260px at 0% 20%,rgba(13,107,255,.11),transparent 62%),linear-gradient(180deg,rgba(255,255,255,.062),rgba(255,255,255,.026))}.architecture-detail-wrap .detail-card:before{content:"Aktywna warstwa";display:inline-flex;margin-bottom:.85rem;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:.34rem .62rem;color:#a1a1aa;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;background:rgba(255,255,255,.035)}
@media (min-width:1280px){.architecture-wrap{padding-right:clamp(2rem,4vw,5rem);padding-left:clamp(2rem,4vw,5rem)}}
@media (max-width:1279px){.architecture-grid{grid-template-columns:minmax(210px,240px) minmax(0,1fr) minmax(300px,340px);gap:2rem}.hero-system-map{min-height:560px}.map-core{left:36%;}.map-gateway{left:34%}.map-chip{font-size:.66rem}}
@media (max-width:1023px){.architecture-wrap{padding-inline:1.25rem}.architecture-grid{display:block}.hero-system-map{min-height:auto;display:grid;gap:1rem;padding:1rem}.system-map-lines,.map-chip{display:none}.map-card,.map-slaves{position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important}.map-card{min-width:0}.map-core{order:1}.map-manager{order:2}.map-operator{order:3}.map-router{order:4}.map-gateway{order:5}.map-plc{order:6}.map-slaves{order:7;left:auto;right:auto;grid-template-columns:1fr}.hero-system-map:before{background-size:44px 44px}}
@media (max-width:640px){.hero-system-map{border-radius:24px}.map-card{border-radius:18px}.map-slaves{gap:.75rem}}

/* 2026-05-06: hero-system-map wide/right-edge fix */
@media (min-width:1024px){
  .hero-shell{width:100%;max-width:none!important;grid-template-columns:minmax(320px,.75fr) minmax(660px,1.45fr)!important;gap:clamp(2rem,3vw,4.25rem)!important;padding-left:max(1.25rem,calc((100vw - 1280px)/2 + 2rem))!important;padding-right:0!important;}
  .hero-copy{max-width:620px;}
  .hero-map-col{min-width:0;}
  .hero-map-col .hero-system-map{min-height:700px;border-top-right-radius:0;border-bottom-right-radius:0;}
  .hero-system-map .map-card{padding:15px 16px;min-width:150px;}
  .hero-system-map .map-card strong{font-size:.95rem;}
  .hero-system-map .map-card small{font-size:.75rem;line-height:1.28;}
  .hero-system-map .map-core{left:36%;top:7%;width:260px;}
  .hero-system-map .map-core strong{font-size:1.16rem;}
  .hero-system-map .map-core ul{grid-template-columns:repeat(2,minmax(0,1fr));gap:.34rem;margin-top:.8rem;}
  .hero-system-map .map-core li{font-size:.66rem;padding:.34rem .46rem;}
  .hero-system-map .map-manager{left:5%;top:13%;width:188px;}
  .hero-system-map .map-operator{right:4%;top:13%;width:190px;}
  .hero-system-map .map-router{left:5%;top:47%;width:215px;}
  .hero-system-map .map-plc{right:4%;top:47%;width:210px;}
  .hero-system-map .map-gateway{left:36%;top:61%;width:285px;}
  .hero-system-map .chip-config{left:23%;top:25%;}
  .hero-system-map .chip-bidir{right:22%;top:25%;}
  .hero-system-map .chip-control{right:16%;top:40%;}
  .hero-system-map .chip-measure{left:38%;top:51%;}
  .hero-system-map .map-slaves{left:7%;right:7%;bottom:5%;gap:.8rem;}
  .hero-system-map .map-slaves div{padding:.9rem;font-size:.92rem;}
  .hero-system-map .map-slaves small{font-size:.75rem;}
}
@media (min-width:1440px){
  .hero-shell{grid-template-columns:minmax(410px,.72fr) minmax(900px,1.4fr)!important;padding-left:max(2rem,calc((100vw - 1280px)/2 + 2rem))!important;}
  .hero-map-col .hero-system-map{min-height:720px;}
  .hero-system-map .map-card{padding:17px 18px;}
  .hero-system-map .map-core{left:37%;width:290px;}
  .hero-system-map .map-gateway{left:38%;top:60%;width:310px;}
  .hero-system-map .map-manager{left:6%;}
  .hero-system-map .map-router{left:6%;}
  .hero-system-map .map-operator{right:5%;}
  .hero-system-map .map-plc{right:5%;}
}
@media (min-width:1024px) and (max-width:1179px){
  .hero-shell{display:block!important;padding-right:1.25rem!important;}
  .hero-copy{max-width:760px;}
  .hero-map-col{margin-top:2.5rem;}
  .hero-map-col .hero-system-map{border-radius:32px;min-height:660px;}
}



/* 2026-05-06: hero-system-map full-width grid layout */
@media (min-width:1024px){
  .hero-shell{width:100%;max-width:none!important;grid-template-columns:minmax(340px,.76fr) minmax(0,1.52fr)!important;gap:clamp(2rem,3vw,4.5rem)!important;align-items:stretch;padding-left:max(1.25rem,calc((100vw - 1280px)/2 + 2rem))!important;padding-right:0!important;}
  .hero-copy{max-width:620px;align-self:center;}
  .hero-map-col{min-width:0;display:flex;}
  .hero-map-col .hero-system-map.hero-system-map--grid{width:100%;min-height:clamp(760px,78vh,940px);padding:clamp(1.15rem,1.7vw,1.75rem);display:grid;grid-template-rows:auto auto 1fr;gap:clamp(.95rem,1.2vw,1.25rem);border-top-right-radius:0;border-bottom-right-radius:0;}
  .hero-system-map.hero-system-map--grid .map-overview{display:grid;gap:.45rem;max-width:64ch;position:relative;z-index:2;}
  .hero-system-map.hero-system-map--grid .map-overview .map-kicker{margin:0;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#9ca3af;}
  .hero-system-map.hero-system-map--grid .map-overview h2{margin:0;font-size:clamp(1.55rem,1.8vw,2.1rem);line-height:1.05;letter-spacing:-.04em;}
  .hero-system-map.hero-system-map--grid .map-overview p{margin:0;max-width:56ch;color:#a1a1aa;line-height:1.55;}
  .hero-system-map.hero-system-map--grid .map-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem;position:relative;z-index:2;}
  .hero-system-map.hero-system-map--grid .map-chip{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;white-space:normal;text-align:center;min-height:64px;display:flex;align-items:center;justify-content:center;padding:.85rem .95rem;border-radius:18px;font-size:.78rem;line-height:1.3;}
  .hero-system-map.hero-system-map--grid .map-diagram{position:relative;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:auto auto auto;gap:clamp(.75rem,1vw,1.05rem);align-items:stretch;}
  .hero-system-map.hero-system-map--grid .map-diagram:before{content:"";position:absolute;inset:11% 2.2% 14% 2.2%;border-radius:28px;background:linear-gradient(90deg,transparent 0,transparent 24%,rgba(255,255,255,.04) 24%,rgba(255,255,255,.04) 25%,transparent 25%,transparent 49%,rgba(255,255,255,.04) 49%,rgba(255,255,255,.04) 50%,transparent 50%,transparent 74%,rgba(255,255,255,.04) 74%,rgba(255,255,255,.04) 75%,transparent 75%);pointer-events:none;opacity:.4;}
  .hero-system-map.hero-system-map--grid .map-card{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;inset:auto!important;width:100%!important;min-width:0;height:100%;z-index:2;display:flex;flex-direction:column;justify-content:flex-start;}
  .hero-system-map.hero-system-map--grid .map-manager{grid-column:1 / span 3;grid-row:1;}
  .hero-system-map.hero-system-map--grid .map-core{grid-column:4 / span 6;grid-row:1 / span 2;min-height:310px;}
  .hero-system-map.hero-system-map--grid .map-operator{grid-column:10 / span 3;grid-row:1;}
  .hero-system-map.hero-system-map--grid .map-router{grid-column:1 / span 3;grid-row:2;}
  .hero-system-map.hero-system-map--grid .map-gateway{grid-column:4 / span 6;grid-row:2;}
  .hero-system-map.hero-system-map--grid .map-plc{grid-column:10 / span 3;grid-row:2;}
  .hero-system-map.hero-system-map--grid .map-slaves{grid-column:1 / -1;grid-row:3;position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:inherit;}
  .hero-system-map.hero-system-map--grid .map-slaves div{min-height:108px;display:flex;flex-direction:column;justify-content:center;}
  .hero-system-map.hero-system-map--grid .map-core img{height:38px;}
  .hero-system-map.hero-system-map--grid .map-core strong{font-size:1.18rem;}
  .hero-system-map.hero-system-map--grid .map-core ul{grid-template-columns:repeat(2,minmax(0,1fr));gap:.38rem;margin-top:.85rem;}
  .hero-system-map.hero-system-map--grid .map-core li{font-size:.7rem;padding:.38rem .5rem;}
  .hero-system-map.hero-system-map--grid .map-card strong{font-size:.98rem;}
  .hero-system-map.hero-system-map--grid .map-card small{font-size:.76rem;line-height:1.32;}
}
@media (min-width:1440px){
  .hero-shell{grid-template-columns:minmax(390px,.72fr) minmax(0,1.58fr)!important;padding-left:max(2rem,calc((100vw - 1280px)/2 + 2rem))!important;}
  .hero-map-col .hero-system-map.hero-system-map--grid{min-height:clamp(780px,76vh,980px);}
  .hero-system-map.hero-system-map--grid .map-overview h2{font-size:clamp(1.75rem,1.7vw,2.35rem);}
}
@media (max-width:1023px){
  .hero-shell{display:block!important;padding-right:1.25rem!important;}
  .hero-copy{max-width:760px;}
  .hero-map-col{margin-top:2.5rem;}
  .hero-map-col .hero-system-map.hero-system-map--grid{min-height:auto;display:grid;gap:1rem;padding:1rem;}
  .hero-system-map.hero-system-map--grid .map-strip{grid-template-columns:repeat(2,minmax(0,1fr));}
  .hero-system-map.hero-system-map--grid .map-diagram{grid-template-columns:1fr;grid-template-rows:auto;}
  .hero-system-map.hero-system-map--grid .map-diagram:before{display:none;}
  .hero-system-map.hero-system-map--grid .map-card,.hero-system-map.hero-system-map--grid .map-slaves{position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;grid-column:auto!important;grid-row:auto!important;}
  .hero-system-map.hero-system-map--grid .map-core{order:1;}
  .hero-system-map.hero-system-map--grid .map-manager{order:2;}
  .hero-system-map.hero-system-map--grid .map-operator{order:3;}
  .hero-system-map.hero-system-map--grid .map-router{order:4;}
  .hero-system-map.hero-system-map--grid .map-gateway{order:5;}
  .hero-system-map.hero-system-map--grid .map-plc{order:6;}
  .hero-system-map.hero-system-map--grid .map-slaves{order:7;grid-template-columns:1fr;gap:.85rem;}
  .hero-system-map.hero-system-map--grid .map-slaves div{min-height:0;}
}
@media (max-width:640px){
  .hero-system-map.hero-system-map--grid{border-radius:24px;}
  .hero-system-map.hero-system-map--grid .map-card{border-radius:18px;}
  .hero-system-map.hero-system-map--grid .map-slaves{gap:.75rem;}
}


/* 2026-05-06: hero-system-map full-width flow layout v2 */
.hero-shell{display:flex!important;flex-direction:column!important;align-items:stretch!important;width:min(100%,1920px)!important;max-width:none!important;}
.hero-copy{max-width:78ch;}
.hero-map-col{width:100%;}
.hero-system-map.hero-system-map--flow{width:100%;min-height:0;padding:clamp(1rem,1.4vw,1.5rem);display:grid;grid-template-rows:auto auto 1fr;gap:clamp(1rem,1.35vw,1.35rem);}
.hero-system-map.hero-system-map--flow .map-overview{display:grid;gap:.45rem;max-width:78ch;position:relative;z-index:2;}
.hero-system-map.hero-system-map--flow .map-overview .map-kicker{margin:0;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#9ca3af;}
.hero-system-map.hero-system-map--flow .map-overview h2{margin:0;font-size:clamp(1.5rem,2.2vw,2.25rem);line-height:1.04;letter-spacing:-.04em;}
.hero-system-map.hero-system-map--flow .map-overview p{margin:0;max-width:62ch;color:#a1a1aa;line-height:1.55;}
.hero-system-map.hero-system-map--flow .map-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem;position:relative;z-index:2;}
.hero-system-map.hero-system-map--flow .map-chip{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;white-space:normal;text-align:center;min-height:64px;display:flex;align-items:center;justify-content:center;padding:.85rem .95rem;border-radius:18px;font-size:.78rem;line-height:1.3;}
.hero-system-map.hero-system-map--flow .map-flow{position:relative;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:auto auto auto;gap:clamp(.8rem,1vw,1.05rem);align-items:stretch;min-height:clamp(720px,72vh,920px);padding-top:.2rem;}
.hero-system-map.hero-system-map--flow .map-grid{position:relative;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:auto auto auto;gap:clamp(.8rem,1vw,1.05rem);align-items:stretch;min-height:clamp(720px,72vh,920px);z-index:1;}
.hero-system-map.hero-system-map--flow .system-map-lines{position:absolute;inset:.2rem 0 0;z-index:0;width:100%;height:100%;filter:drop-shadow(0 0 12px rgba(13,107,255,.18));pointer-events:none;}
.hero-system-map.hero-system-map--flow .map-card{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;inset:auto!important;width:100%!important;min-width:0;height:100%;z-index:2;display:flex;flex-direction:column;justify-content:flex-start;}
.hero-system-map.hero-system-map--flow .map-router{grid-column:1 / span 3;grid-row:1;}
.hero-system-map.hero-system-map--flow .map-core{grid-column:4 / span 6;grid-row:1 / span 2;min-height:300px;}
.hero-system-map.hero-system-map--flow .map-operator{grid-column:10 / span 3;grid-row:1;}
.hero-system-map.hero-system-map--flow .map-manager{grid-column:1 / span 3;grid-row:2;}
.hero-system-map.hero-system-map--flow .map-gateway{grid-column:4 / span 6;grid-row:2;}
.hero-system-map.hero-system-map--flow .map-plc{grid-column:10 / span 3;grid-row:2;}
.hero-system-map.hero-system-map--flow .map-slaves{grid-column:1 / -1;grid-row:3;position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:inherit;}
.hero-system-map.hero-system-map--flow .map-slaves div{min-height:108px;display:flex;flex-direction:column;justify-content:center;}
.hero-system-map.hero-system-map--flow .map-core img{height:38px;}
.hero-system-map.hero-system-map--flow .map-core strong{font-size:1.18rem;}
.hero-system-map.hero-system-map--flow .map-core ul{grid-template-columns:repeat(2,minmax(0,1fr));gap:.38rem;margin-top:.85rem;}
.hero-system-map.hero-system-map--flow .map-core li{font-size:.7rem;padding:.38rem .5rem;}
.hero-system-map.hero-system-map--flow .map-card strong{font-size:.98rem;}
.hero-system-map.hero-system-map--flow .map-card small{font-size:.76rem;line-height:1.32;}
@media (max-width:1279px){
  .hero-shell{width:100%!important;padding-left:1.25rem!important;padding-right:1.25rem!important;}
  .hero-system-map.hero-system-map--flow .map-flow{min-height:640px;}
}
@media (max-width:1023px){
  .hero-shell{padding-right:1.25rem!important;}
  .hero-map-col{margin-top:1rem;}
  .hero-system-map.hero-system-map--flow{gap:1rem;padding:1rem;}
  .hero-system-map.hero-system-map--flow .map-strip{grid-template-columns:repeat(2,minmax(0,1fr));}
  .hero-system-map.hero-system-map--flow .map-flow{grid-template-columns:1fr;grid-template-rows:auto;min-height:auto;}
  .hero-system-map.hero-system-map--flow .map-card,.hero-system-map.hero-system-map--flow .map-slaves{position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;grid-column:auto!important;grid-row:auto!important;}
  .hero-system-map.hero-system-map--flow .system-map-lines{display:none;}
  .hero-system-map.hero-system-map--flow .map-core{order:1;}
  .hero-system-map.hero-system-map--flow .map-router{order:2;}
  .hero-system-map.hero-system-map--flow .map-operator{order:3;}
  .hero-system-map.hero-system-map--flow .map-manager{order:4;}
  .hero-system-map.hero-system-map--flow .map-gateway{order:5;}
  .hero-system-map.hero-system-map--flow .map-plc{order:6;}
  .hero-system-map.hero-system-map--flow .map-slaves{order:7;grid-template-columns:1fr;gap:.85rem;}
}
@media (max-width:640px){
  .hero-system-map.hero-system-map--flow{border-radius:24px;}
  .hero-system-map.hero-system-map--flow .map-card{border-radius:18px;}
  .hero-system-map.hero-system-map--flow .map-slaves{gap:.75rem;}
}


/* 2026-05-06: jQuery flowchart hero diagram */
.hero-system-map.hero-system-map--flowchart{display:grid;gap:clamp(1rem,1.5vw,1.35rem);}
.hero-system-map.hero-system-map--flowchart .map-overview{display:grid;gap:.45rem;max-width:78ch;position:relative;z-index:2;}
.hero-system-map.hero-system-map--flowchart .map-overview .map-kicker{margin:0;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#9ca3af;}
.hero-system-map.hero-system-map--flowchart .map-overview h2{margin:0;font-size:clamp(1.5rem,2.2vw,2.25rem);line-height:1.04;letter-spacing:-.04em;}
.hero-system-map.hero-system-map--flowchart .map-overview p{margin:0;max-width:62ch;color:#a1a1aa;line-height:1.55;}
.hero-system-map.hero-system-map--flowchart .map-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem;position:relative;z-index:2;}
.hero-system-map.hero-system-map--flowchart .map-chip{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;white-space:normal;text-align:center;min-height:64px;display:flex;align-items:center;justify-content:center;padding:.85rem .95rem;border-radius:18px;font-size:.78rem;line-height:1.3;}
.hero-system-map.hero-system-map--flowchart .map-chart-shell{display:none;}
html.js-flowchart-ready .hero-system-map.hero-system-map--flowchart .map-chart-shell{display:block;}
html.js-flowchart-ready .hero-system-map.hero-system-map--flowchart .map-fallback{display:none;}
.hero-system-map.hero-system-map--flowchart .map-chart-viewport{position:relative;width:100%;overflow:hidden;}
.hero-system-map.hero-system-map--flowchart .synk-flowchart.flowchart-container{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.12);border-radius:32px;background:radial-gradient(760px 420px at 44% 18%,rgba(13,107,255,.17),transparent 58%),radial-gradient(620px 360px at 74% 58%,rgba(24,209,29,.10),transparent 68%),linear-gradient(180deg,rgba(255,255,255,.052),rgba(255,255,255,.018));box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 28px 120px rgba(0,0,0,.42);}
.hero-system-map.hero-system-map--flowchart .synk-flowchart:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(circle at 50% 42%,black,transparent 78%);opacity:.55;pointer-events:none;}
.hero-system-map.hero-system-map--flowchart .synk-flowchart:after{content:"";position:absolute;inset:1px;border-radius:31px;background:linear-gradient(90deg,rgba(13,107,255,.16),transparent 33%,transparent 66%,rgba(24,209,29,.12));pointer-events:none;opacity:.55;}
.hero-system-map.hero-system-map--flowchart .flowchart-links-layer,.hero-system-map.hero-system-map--flowchart .flowchart-operators-layer,.hero-system-map.hero-system-map--flowchart .flowchart-temporary-link-layer{position:absolute;top:0;left:0;width:100%;height:100%;}
.hero-system-map.hero-system-map--flowchart .flowchart-links-layer{z-index:1;}
.hero-system-map.hero-system-map--flowchart .flowchart-operators-layer{z-index:2;}
.hero-system-map.hero-system-map--flowchart .flowchart-temporary-link-layer{z-index:3;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator{position:absolute;pointer-events:auto;box-sizing:border-box;cursor:default;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-card{border:1px solid rgba(255,255,255,.13);background:linear-gradient(180deg,rgba(12,12,14,.92),rgba(8,8,10,.82));backdrop-filter:blur(14px);border-radius:22px;padding:18px 20px;box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 18px 60px rgba(0,0,0,.22);min-width:178px;color:#fff;}
.hero-system-map.hero-system-map--flowchart .map-card strong,.hero-system-map.hero-system-map--flowchart .flowchart-operator-title{display:block;font-size:1.04rem;font-weight:650;letter-spacing:-.025em;line-height:1.2;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-title{width:100%;padding:0 0 .75rem;background:transparent;border-bottom:0;height:auto;overflow:visible;text-overflow:clip;white-space:normal;cursor:default;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-body{padding:0;cursor:default;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator .flowchart-operator-inputs-outputs{display:block;width:100%;margin-top:.75rem;margin-bottom:0;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator .flowchart-operator-inputs,
.hero-system-map.hero-system-map--flowchart .flowchart-operator .flowchart-operator-outputs{display:block;width:100%;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-connector{position:relative;padding-top:4px;padding-bottom:4px;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-connector-label{display:none;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-connector-arrow{width:0;height:0;border-top:10px solid transparent;border-bottom:10px solid transparent;border-left:10px solid rgba(255,255,255,.28);position:absolute;top:0;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-connector-small-arrow{display:none;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-inputs .flowchart-operator-connector-arrow{left:-1px;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-outputs .flowchart-operator-connector-arrow{right:-10px;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator-connector:hover .flowchart-operator-connector-arrow{border-left-color:rgba(255,255,255,.42);}
.hero-system-map.hero-system-map--flowchart .flowchart-link{fill:none;stroke-width:2.4;}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-router{width:230px;border-color:rgba(13,107,255,.27);}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-operator{width:220px;border-color:rgba(24,209,29,.28);}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-manager{width:220px;border-color:rgba(13,107,255,.27);}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-plc{width:230px;border-color:rgba(13,107,255,.27);}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-slave{width:260px;border-color:rgba(24,209,29,.18);}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-core{width:340px;border-color:rgba(13,107,255,.42);background:radial-gradient(300px 220px at 35% 18%,rgba(13,107,255,.20),transparent 64%),rgba(8,8,10,.9);}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-gateway{width:330px;border-color:rgba(24,209,29,.38);background:radial-gradient(360px 220px at 50% 50%,rgba(24,209,29,.16),transparent 70%),rgba(8,8,10,.9);}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-core ul{margin-top:1rem;display:grid;gap:.38rem;grid-template-columns:repeat(2,minmax(0,1fr));}
.hero-system-map.hero-system-map--flowchart .flowchart-operator.map-core li{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.035);border-radius:10px;padding:.42rem .7rem;font-size:.76rem;color:#d4d4d8;}
.hero-system-map.hero-system-map--flowchart .map-fallback{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;}
.hero-system-map.hero-system-map--flowchart .map-fallback .map-card{position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;min-width:0;}
@media (max-width:1279px){
  .hero-system-map.hero-system-map--flowchart .map-strip{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:1023px){
  .hero-system-map.hero-system-map--flowchart .map-chart-shell{display:none!important;}
  .hero-system-map.hero-system-map--flowchart .map-fallback{grid-template-columns:1fr;}
}
@media (max-width:640px){
  .hero-system-map.hero-system-map--flowchart .map-fallback{gap:.75rem;}
  .hero-system-map.hero-system-map--flowchart .map-fallback .map-card{border-radius:18px;}
}

/* 2026-05-06: static hero fallback flowchart when JS/plugin is not available */
.hero-system-map.hero-system-map--flowchart .map-fallback{position:relative;display:block;min-height:760px;border:1px solid rgba(255,255,255,.12);border-radius:32px;background:radial-gradient(760px 420px at 44% 18%,rgba(13,107,255,.17),transparent 58%),radial-gradient(620px 360px at 74% 58%,rgba(24,209,29,.10),transparent 68%),linear-gradient(180deg,rgba(255,255,255,.052),rgba(255,255,255,.018));box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 28px 120px rgba(0,0,0,.42);overflow:hidden;isolation:isolate;padding:1.25rem;}
.hero-system-map.hero-system-map--flowchart .map-fallback:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(circle at 50% 42%,black,transparent 78%);opacity:.55;pointer-events:none;}
.hero-system-map.hero-system-map--flowchart .map-fallback:after{content:"";position:absolute;inset:1px;border-radius:31px;background:linear-gradient(90deg,rgba(13,107,255,.16),transparent 33%,transparent 66%,rgba(24,209,29,.12));pointer-events:none;opacity:.55;}
.hero-system-map.hero-system-map--flowchart .map-flow-lines{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;filter:drop-shadow(0 0 10px rgba(13,107,255,.16));}
.hero-system-map.hero-system-map--flowchart .map-flow-lines .map-link{fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;}
.hero-system-map.hero-system-map--flowchart .map-flow-lines .blue-link{stroke:rgba(13,107,255,.86);}
.hero-system-map.hero-system-map--flowchart .map-flow-lines .green-link{stroke:rgba(24,209,29,.8);}
.hero-system-map.hero-system-map--flowchart .map-flow-lines .dashed{stroke-dasharray:8 10;}
.hero-system-map.hero-system-map--flowchart .map-fallback .map-card{position:absolute;z-index:2;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;min-width:0;}
.hero-system-map.hero-system-map--flowchart .map-router{left:6%;top:11%;width:230px;}
.hero-system-map.hero-system-map--flowchart .map-manager{left:6%;top:47%;width:230px;}
.hero-system-map.hero-system-map--flowchart .map-core{left:50%;top:26%;width:330px;transform:translateX(-50%);}
.hero-system-map.hero-system-map--flowchart .map-operator{right:6%;top:11%;width:230px;}
.hero-system-map.hero-system-map--flowchart .map-plc{right:6%;top:47%;width:230px;}
.hero-system-map.hero-system-map--flowchart .map-gateway{left:50%;top:58%;width:330px;transform:translateX(-50%);}
.hero-system-map.hero-system-map--flowchart .map-slave-digital{left:34%;top:79%;width:180px;transform:translateX(-50%);}
.hero-system-map.hero-system-map--flowchart .map-slave-analog{left:50%;top:79%;width:180px;transform:translateX(-50%);}
.hero-system-map.hero-system-map--flowchart .map-slave-humidity{left:66%;top:79%;width:180px;transform:translateX(-50%);}
.hero-system-map.hero-system-map--flowchart .map-router small,.hero-system-map.hero-system-map--flowchart .map-manager small,.hero-system-map.hero-system-map--flowchart .map-operator small,.hero-system-map.hero-system-map--flowchart .map-plc small,.hero-system-map.hero-system-map--flowchart .map-slave small{display:block;line-height:1.35;}
.hero-system-map.hero-system-map--flowchart .map-core ul{margin-top:1rem;display:grid;gap:.38rem;grid-template-columns:repeat(2,minmax(0,1fr));}
.hero-system-map.hero-system-map--flowchart .map-core li{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.035);border-radius:10px;padding:.42rem .7rem;font-size:.76rem;color:#d4d4d8;}
@media (max-width:1023px){
  .hero-system-map.hero-system-map--flowchart .map-fallback{min-height:auto;padding:1rem;display:grid;grid-template-columns:1fr;gap:.85rem;}
  .hero-system-map.hero-system-map--flowchart .map-flow-lines{display:none;}
  .hero-system-map.hero-system-map--flowchart .map-fallback .map-card{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;transform:none!important;}
  .hero-system-map.hero-system-map--flowchart .map-core,.hero-system-map.hero-system-map--flowchart .map-gateway,.hero-system-map.hero-system-map--flowchart .map-slave-digital,.hero-system-map.hero-system-map--flowchart .map-slave-analog,.hero-system-map.hero-system-map--flowchart .map-slave-humidity{left:auto;top:auto;}
}


/* 2026-05-06: fix fallback card layout as a real flow grid */
.hero-system-map.hero-system-map--flowchart .map-fallback{display:grid !important;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:auto auto auto;gap:1rem;align-items:start;}
.hero-system-map.hero-system-map--flowchart .map-fallback .map-card{position:relative !important;left:auto !important;right:auto !important;top:auto !important;bottom:auto !important;transform:none !important;width:auto !important;min-width:0;}
.hero-system-map.hero-system-map--flowchart .map-router{grid-column:1 / span 3;grid-row:1;}
.hero-system-map.hero-system-map--flowchart .map-operator{grid-column:10 / span 3;grid-row:1;}
.hero-system-map.hero-system-map--flowchart .map-core{grid-column:4 / span 6;grid-row:1 / span 2;}
.hero-system-map.hero-system-map--flowchart .map-manager{grid-column:1 / span 3;grid-row:2;}
.hero-system-map.hero-system-map--flowchart .map-plc{grid-column:10 / span 3;grid-row:2;}
.hero-system-map.hero-system-map--flowchart .map-gateway{grid-column:4 / span 6;grid-row:2;}
.hero-system-map.hero-system-map--flowchart .map-slave-digital{grid-column:3 / span 2;grid-row:3;}
.hero-system-map.hero-system-map--flowchart .map-slave-analog{grid-column:6 / span 2;grid-row:3;}
.hero-system-map.hero-system-map--flowchart .map-slave-humidity{grid-column:9 / span 2;grid-row:3;}
@media (max-width:1023px){
  .hero-system-map.hero-system-map--flowchart .map-fallback{grid-template-columns:1fr !important;grid-template-rows:none;}
  .hero-system-map.hero-system-map--flowchart .map-router,.hero-system-map.hero-system-map--flowchart .map-operator,.hero-system-map.hero-system-map--flowchart .map-core,.hero-system-map.hero-system-map--flowchart .map-manager,.hero-system-map.hero-system-map--flowchart .map-gateway,.hero-system-map.hero-system-map--flowchart .map-plc,.hero-system-map.hero-system-map--flowchart .map-slave-digital,.hero-system-map.hero-system-map--flowchart .map-slave-analog,.hero-system-map.hero-system-map--flowchart .map-slave-humidity{grid-column:auto !important;grid-row:auto !important;}
}


/* 2026-05-06: jsPlumb hero diagram */
.hero-system-map.hero-system-map--plumb{display:grid;gap:clamp(1rem,1.35vw,1.35rem);padding:clamp(1rem,1.4vw,1.35rem);min-height:clamp(760px,78vh,980px)}
.hero-system-map.hero-system-map--plumb .map-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem;position:relative;z-index:3}
.hero-system-map.hero-system-map--plumb .plumb-chip{display:flex;align-items:center;justify-content:center;min-height:64px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(5,5,5,.68);backdrop-filter:blur(10px);padding:.85rem .95rem;font-size:.78rem;line-height:1.3;color:#d4d4d8;text-align:center;box-shadow:0 1px 0 rgba(255,255,255,.04) inset}
.hero-system-map.hero-system-map--plumb .plumb-stage{position:relative;z-index:2;overflow:hidden;border:1px solid rgba(255,255,255,.12);border-radius:32px;background:radial-gradient(760px 420px at 44% 18%,rgba(13,107,255,.17),transparent 58%),radial-gradient(620px 360px at 74% 58%,rgba(24,209,29,.10),transparent 68%),linear-gradient(180deg,rgba(255,255,255,.052),rgba(255,255,255,.018));box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 28px 120px rgba(0,0,0,.42)}
.hero-system-map.hero-system-map--plumb .plumb-stage:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(circle at 50% 42%,black,transparent 78%);opacity:.55;pointer-events:none}
.hero-system-map.hero-system-map--plumb .plumb-stage:after{content:"";position:absolute;inset:1px;border-radius:31px;background:linear-gradient(90deg,rgba(13,107,255,.16),transparent 33%,transparent 66%,rgba(24,209,29,.12));pointer-events:none;opacity:.55}
.hero-system-map.hero-system-map--plumb .plumb-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-auto-rows:minmax(92px,auto);gap:clamp(.75rem,1vw,1.05rem);padding:clamp(1rem,1.2vw,1.25rem)}
.hero-system-map.hero-system-map--plumb .plumb-card{position:relative;z-index:3;min-width:0;border:1px solid rgba(255,255,255,.13);background:linear-gradient(180deg,rgba(12,12,14,.92),rgba(8,8,10,.82));backdrop-filter:blur(14px);border-radius:22px;padding:18px 20px;box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 18px 60px rgba(0,0,0,.22);color:#fff;display:flex;flex-direction:column;gap:.55rem;justify-content:flex-start}
.hero-system-map.hero-system-map--plumb .plumb-card img{height:34px;width:auto}
.hero-system-map.hero-system-map--plumb .plumb-card strong{display:block;font-size:1.02rem;font-weight:650;letter-spacing:-.025em;line-height:1.18}
.hero-system-map.hero-system-map--plumb .plumb-card small{display:block;color:#a1a1aa;line-height:1.35}
.hero-system-map.hero-system-map--plumb .plumb-card ul{margin-top:.6rem;display:grid;gap:.38rem;grid-template-columns:repeat(2,minmax(0,1fr))}
.hero-system-map.hero-system-map--plumb .plumb-card li{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.035);border-radius:10px;padding:.42rem .7rem;font-size:.76rem;color:#d4d4d8}
.hero-system-map.hero-system-map--plumb .plumb-index{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;font-size:.7rem;font-weight:750;letter-spacing:.04em;border:1px solid transparent}
.hero-system-map.hero-system-map--plumb .plumb-index.plumb-blue{color:#fff;background:rgba(13,107,255,.24);border-color:rgba(13,107,255,.34)}
.hero-system-map.hero-system-map--plumb .plumb-index.plumb-green{color:#fff;background:rgba(24,209,29,.18);border-color:rgba(24,209,29,.28)}
.hero-system-map.hero-system-map--plumb .plumb-router{grid-column:1 / span 3;grid-row:1;border-color:rgba(13,107,255,.27)}
.hero-system-map.hero-system-map--plumb .plumb-manager{grid-column:1 / span 3;grid-row:2;border-color:rgba(13,107,255,.27)}
.hero-system-map.hero-system-map--plumb .plumb-core{grid-column:4 / span 6;grid-row:1 / span 2;border-color:rgba(13,107,255,.42);background:radial-gradient(300px 220px at 35% 18%,rgba(13,107,255,.20),transparent 64%),rgba(8,8,10,.9)}
.hero-system-map.hero-system-map--plumb .plumb-core .plumb-title{font-size:1.42rem}
.hero-system-map.hero-system-map--plumb .plumb-operator{grid-column:10 / span 3;grid-row:1;border-color:rgba(24,209,29,.28)}
.hero-system-map.hero-system-map--plumb .plumb-plc{grid-column:10 / span 3;grid-row:2;border-color:rgba(13,107,255,.27)}
.hero-system-map.hero-system-map--plumb .plumb-gateway{grid-column:4 / span 6;grid-row:3;border-color:rgba(24,209,29,.38);background:radial-gradient(360px 220px at 50% 50%,rgba(24,209,29,.16),transparent 70%),rgba(8,8,10,.9)}
.hero-system-map.hero-system-map--plumb .plumb-slave-digital{grid-column:1 / span 4;grid-row:4;border-color:rgba(24,209,29,.23)}
.hero-system-map.hero-system-map--plumb .plumb-slave-analog{grid-column:5 / span 4;grid-row:4;border-color:rgba(24,209,29,.23)}
.hero-system-map.hero-system-map--plumb .plumb-slave-humidity{grid-column:9 / span 4;grid-row:4;border-color:rgba(24,209,29,.23)}
.hero-system-map.hero-system-map--plumb .jtk-connector{pointer-events:none;filter:drop-shadow(0 0 12px rgba(13,107,255,.18))}
.hero-system-map.hero-system-map--plumb .jtk-overlay{pointer-events:none}
@media (max-width:1279px){.hero-system-map.hero-system-map--plumb .plumb-card{padding:16px 17px}.hero-system-map.hero-system-map--plumb .plumb-core .plumb-title{font-size:1.2rem}}
@media (max-width:1023px){.hero-system-map.hero-system-map--plumb{min-height:auto;padding:1rem}.hero-system-map.hero-system-map--plumb .map-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-system-map.hero-system-map--plumb .plumb-stage{border-radius:24px}.hero-system-map.hero-system-map--plumb .plumb-grid{grid-template-columns:1fr;grid-auto-rows:auto}.hero-system-map.hero-system-map--plumb .plumb-card{grid-column:auto!important;grid-row:auto!important;border-radius:18px}.hero-system-map.hero-system-map--plumb .plumb-card ul{grid-template-columns:1fr}.hero-system-map.hero-system-map--plumb .plumb-slave-digital,.hero-system-map.hero-system-map--plumb .plumb-slave-analog,.hero-system-map.hero-system-map--plumb .plumb-slave-humidity{grid-column:auto!important;grid-row:auto!important}}
@media (max-width:640px){.hero-system-map.hero-system-map--plumb .plumb-stage{border-radius:22px}.hero-system-map.hero-system-map--plumb .plumb-card{border-radius:16px;padding:15px 16px}.hero-system-map.hero-system-map--plumb .plumb-chip{border-radius:16px;font-size:.72rem}}


/* 2026-05-06: vertical mini-maps with jsPlumb */
.mini-map.mini-map--vertical{display:grid;gap:.95rem;padding:1rem;background:radial-gradient(circle at 50% 30%,rgba(13,107,255,.12),transparent 38%),rgba(255,255,255,.025);overflow:hidden;min-height:unset}
.mini-map.mini-map--vertical:before{background-size:48px 48px;opacity:.62}
.mini-map.mini-map--vertical .mini-map-label{position:relative;z-index:2;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#9ca3af}
.mini-map.mini-map--vertical .mini-map-stage{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr);gap:.95rem;align-items:start}
.mini-map.mini-map--vertical .mini-node{position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;min-width:0;display:flex;flex-direction:column;gap:.28rem;border:1px solid rgba(255,255,255,.14);background:rgba(8,8,10,.84);backdrop-filter:blur(10px);border-radius:18px;padding:16px;box-shadow:0 1px 0 rgba(255,255,255,.05) inset}
.mini-map.mini-map--vertical .mini-node strong{display:block;font-weight:650;line-height:1.2}
.mini-map.mini-map--vertical .mini-node small{display:block;color:#a1a1aa;line-height:1.38}
.mini-map.mini-map--vertical .mini-node.panel-blue{border-color:rgba(13,107,255,.38);box-shadow:0 1px 0 rgba(255,255,255,.07) inset,0 0 0 1px rgba(13,107,255,.06),0 24px 80px rgba(13,107,255,.08)}
.mini-map.mini-map--vertical .mini-node.panel-green{border-color:rgba(24,209,29,.34);box-shadow:0 1px 0 rgba(255,255,255,.07) inset,0 0 0 1px rgba(24,209,29,.05),0 24px 80px rgba(24,209,29,.07)}
.mini-map.mini-map--vertical .jtk-connector{pointer-events:none;filter:drop-shadow(0 0 10px rgba(13,107,255,.18))}
.mini-map.mini-map--vertical[data-mini-theme="green"] .jtk-connector{filter:drop-shadow(0 0 10px rgba(24,209,29,.15))}
@media (max-width:1023px){.mini-map.mini-map--vertical{padding:.9rem}.mini-map.mini-map--vertical .mini-node{border-radius:16px;padding:14px}}
@media (max-width:640px){.mini-map.mini-map--vertical{border-radius:24px}.mini-map.mini-map--vertical .mini-node{border-radius:14px;padding:13px 14px}}


/* 2026-05-06: audience section full-width photo background */
.section-audience-bg{position:relative;isolation:isolate;overflow:hidden;background-image:linear-gradient(180deg,rgba(4,8,14,.78),rgba(4,8,14,.64) 40%,rgba(5,8,12,.78)),url("../assets/rozladunek-ziarna-pszenicy-elewator-zbozowy.jpg");background-size:cover;background-position:center center;background-repeat:no-repeat;}
.section-audience-bg .panel{background:linear-gradient(180deg,rgba(8,10,14,.78),rgba(8,10,14,.56));backdrop-filter:blur(2px);border-color:rgba(255,255,255,.18);}
.section-audience-bg .eyebrow{color:#dbeafe;}
.section-audience-bg p.text-zinc-400{color:#d4d4d8;}
@media (max-width:1023px){.section-audience-bg{background-position:center top;}}


/* 2026-05-06: layer names hover hints */
.layer-term-hint{position:relative;display:inline;color:inherit;font-weight:600;text-decoration:underline;text-decoration-style:dotted;text-decoration-color:rgba(255,255,255,.56);text-underline-offset:3px;cursor:help;transition:text-decoration-color .2s ease,color .2s ease}
.layer-term-hint:hover,.layer-term-hint:focus-visible{color:#fff;text-decoration-color:rgba(255,255,255,.95)}
.layer-term-hint::after{content:attr(data-layer-tooltip);position:absolute;left:50%;bottom:calc(100% + 10px);transform:translateX(-50%) translateY(4px);min-width:max-content;max-width:320px;padding:.42rem .62rem;border:1px solid rgba(10,10,12,.44);border-radius:10px;background:#fff;color:#0b0b0c;font-size:.67rem;letter-spacing:.08em;text-transform:uppercase;line-height:1.25;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;z-index:80;box-shadow:0 16px 42px rgba(0,0,0,.28);transition:opacity .16s ease,transform .16s ease,visibility .16s ease}
.layer-term-hint::before{content:"";position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);border-width:6px 6px 0 6px;border-style:solid;border-color:#fff transparent transparent transparent;opacity:0;visibility:hidden;pointer-events:none;z-index:81;transition:opacity .16s ease,visibility .16s ease}
.layer-term-hint:hover::after,.layer-term-hint:focus-visible::after,.layer-term-hint:hover::before,.layer-term-hint:focus-visible::before{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
@media (max-width:1023px){.layer-term-hint::after,.layer-term-hint::before{display:none}}


/* 2026-05-06: offer section full-width photo background */
.section-offer-bg{position:relative;isolation:isolate;overflow:hidden;background-image:linear-gradient(180deg,rgba(7,10,14,.82),rgba(7,10,14,.66) 42%,rgba(7,10,14,.8)),url("../assets/klosy-pszenicy-na-tle-silosow-rolniczych.jpg");background-size:cover;background-position:center center;background-repeat:no-repeat;}
.section-offer-bg .panel{background:linear-gradient(180deg,rgba(8,10,14,.8),rgba(8,10,14,.58));backdrop-filter:blur(2px);border-color:rgba(255,255,255,.18);}
.section-offer-bg .eyebrow{color:#dbeafe;}
.section-offer-bg h2{color:#fff;}
.section-offer-bg p.text-zinc-400{color:#e4e4e7;}
@media (max-width:1023px){.section-offer-bg{background-position:center top;}}


/* 2026-05-06: architecture-menu axis alignment tweak */
.architecture-menu:before{left:3rem;top:5rem;bottom:3rem;width:2px;}


/* 2026-05-06: allow layer tooltips to escape mini-map bounds */
.mini-map.mini-map--vertical{overflow:visible!important;isolation:visible;}
.mini-map.mini-map--vertical .mini-map-stage{overflow:visible;position:relative;z-index:4;}
.mini-map.mini-map--vertical .mini-node{overflow:visible;}
.mini-map.mini-map--vertical .layer-term-hint::after,
.mini-map.mini-map--vertical .layer-term-hint::before{z-index:120;}

.section-contact-cards-bg{position:relative;isolation:isolate;overflow:hidden;background-image:linear-gradient(180deg,rgba(7,10,14,.82),rgba(7,10,14,.66) 42%,rgba(7,10,14,.8)),url("../assets/dlonie-rolnika-pelne-ziarna-zbiory.jpg");background-size:cover;background-position:center center;background-repeat:no-repeat;}
.section-contact-cards-bg .panel{background:linear-gradient(180deg,rgba(8,10,14,.8),rgba(8,10,14,.58));backdrop-filter:blur(2px);border-color:rgba(255,255,255,.18);}
.section-contact-cards-bg h3{color:#fff;}
.section-contact-cards-bg p.text-zinc-400{color:#e4e4e7;}
@media (max-width:1023px){.section-contact-cards-bg{background-position:center top;}}

.section-wdrozenia-cards-bg{position:relative;isolation:isolate;overflow:hidden;background-image:linear-gradient(180deg,rgba(7,10,14,.82),rgba(7,10,14,.66) 42%,rgba(7,10,14,.8)),url("../assets/silosy-zbozowe-z-suszarnia-przemyslowa.jpg");background-size:cover;background-position:center center;background-repeat:no-repeat;}
.section-wdrozenia-cards-bg .panel{background:linear-gradient(180deg,rgba(8,10,14,.8),rgba(8,10,14,.58));backdrop-filter:blur(2px);border-color:rgba(255,255,255,.18);}
.section-wdrozenia-cards-bg h3{color:#fff;}
.section-wdrozenia-cards-bg p.text-zinc-400{color:#e4e4e7;}
@media (max-width:1023px){.section-wdrozenia-cards-bg{background-position:center top;}}

/* Hero intro split + scroll mouse */
.hero-copy-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:1.75rem;align-items:start;}
.hero-copy-left{max-width:28rem;}
.hero-copy-right{max-width:42rem;}
.hero-lead{color:#d4d4d8;}
.scroll-mouse{display:inline-flex;align-items:center;gap:.7rem;color:#e4e4e7;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;opacity:.92;transition:opacity .2s ease,transform .2s ease;}
.scroll-mouse:hover{opacity:1;transform:translateY(1px);}
.scroll-mouse-icon{position:relative;display:inline-flex;width:1.5rem;height:2.35rem;border:1.5px solid rgba(255,255,255,.55);border-radius:999px;align-items:flex-start;justify-content:center;padding-top:.38rem;background:rgba(255,255,255,.02);}
.scroll-mouse-wheel{display:block;width:.24rem;height:.44rem;border-radius:999px;background:#fff;animation:scrollWheel 1.5s ease-in-out infinite;}
.scroll-mouse-label{color:#d4d4d8;}
@keyframes scrollWheel{0%{transform:translateY(0);opacity:1;}55%{transform:translateY(.48rem);opacity:.15;}100%{transform:translateY(0);opacity:1;}}
@media (min-width:1024px){
  .hero-copy-grid{grid-template-columns:minmax(0,.84fr) minmax(0,1.16fr);gap:clamp(1.6rem,3vw,3.2rem);}
  .hero-copy-right{padding-top:.35rem;}
}

/* Hero intro 50/50 hard layout */
.hero-copy{max-width:none!important;width:100%!important;}
.hero-copy-grid{width:100%!important;max-width:none!important;}
.hero-copy-left,.hero-copy-right{max-width:none!important;}
.hero-copy-right .hero-lead{max-width:none!important;}
@media (min-width:1024px){
  .hero-copy-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:clamp(2rem,3vw,3.5rem)!important;align-items:start!important;}
}

/* Hero shell centered like rest of site */
.hero-shell{width:100%!important;max-width:80rem!important;margin-left:auto!important;margin-right:auto!important;padding-left:1.25rem!important;padding-right:1.25rem!important;}
@media (min-width:1024px){
  .hero-shell{padding-left:2rem!important;padding-right:2rem!important;}
}

/* Mini-map vertical spacing increase */
.mini-map.mini-map--vertical .mini-map-stage{gap:3rem!important;}
@media (max-width:1023px){.mini-map.mini-map--vertical .mini-map-stage{gap:2.8rem!important;}}
@media (max-width:640px){.mini-map.mini-map--vertical .mini-map-stage{gap:2.5rem!important;}}

/* nav dropdown upgrade */
.nav-two-line{display:inline-flex;flex-direction:column;line-height:1.05;gap:1px;white-space:normal;text-align:left}.nav-two-line span{display:block}.nav-two-line--mobile{line-height:1.15}.nav-dropdown{position:relative;z-index:70;padding-bottom:22px;margin-bottom:-22px}.nav-dropdown-trigger{display:inline-flex;align-items:center;gap:.4rem}.nav-dropdown::after{content:none}.nav-dropdown-arrow{display:block!important;width:10px!important;height:10px!important;min-width:10px;min-height:10px;max-width:10px;max-height:10px;flex:none;opacity:.75;transition:transform .2s ease;transform-origin:center}.nav-dropdown:hover .nav-dropdown-arrow,.nav-dropdown:focus-within .nav-dropdown-arrow{transform:rotate(180deg)}.nav-mega{position:absolute;left:50%;top:calc(100% + 12px);transform:translateX(-50%) translateY(10px);width:min(860px,92vw);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding:14px;border:1px solid rgba(255,255,255,.14);border-radius:18px;background:linear-gradient(180deg,rgba(8,8,10,.97),rgba(12,12,14,.97));box-shadow:0 24px 80px rgba(0,0,0,.45),0 1px 0 rgba(255,255,255,.08) inset;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s ease,transform .22s ease,visibility .22s ease;z-index:90}.nav-mega::before{content:"";position:absolute;inset:-16px;pointer-events:auto;z-index:0}.nav-dropdown:hover .nav-mega,.nav-dropdown:focus-within .nav-mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}.nav-mega-item{display:block;padding:14px;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:rgba(255,255,255,.02);color:#d4d4d8;transition:border-color .2s ease,background .2s ease,color .2s ease}.nav-mega-item:hover,.nav-mega-item.active{border-color:rgba(13,107,255,.45);background:rgba(13,107,255,.12);color:#fff}.nav-mega-kicker{display:block;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:#9ca3af}.nav-mega-item strong{display:block;margin-top:.35rem;font-size:1rem;color:#fff}.nav-mega-item small{display:block;margin-top:.4rem;font-size:.78rem;line-height:1.35;color:#a1a1aa}@media(max-width:1023px){.nav-mega{display:none}}

.nav-mega-item{position:relative;z-index:1}
