/* hero-blocks.css — landing-only class/id rules for the animation hero. Base tokens/nav/.hero remain in style.css. */
:root{--ink:#0f2540;--ink2:#27395a;--ink3:#465674;--ink4:#6a7891;--line:#d6deea;--paper:#f5f8fc;--paper2:#e9eff7;}

@keyframes gsh{0%,100%{background-position:0 50%}50%{background-position:100% 50%}}

#nav{position:fixed;top:0;left:0;right:0;z-index:500;height:68px;display:flex;align-items:center;gap:24px;padding:0 48px;background:rgba(9,22,40,.92);backdrop-filter:blur(28px);border-bottom:1px solid var(--gb)}

.hero-lead strong{color:var(--g4);font-weight:400}

@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

.ddot:first-child{background:#c9544c}

.ddot:nth-child(2){background:#c9a84c}

.ddot:nth-child(3){background:#5aa86a}

.demo-select:focus{border-color:var(--g3)}

.dp-btn-sm:hover{border-color:var(--gb4);color:var(--g4);background:var(--gb)}

.tli::before{content:'';position:absolute;left:13px;top:28px;bottom:0;width:1px;background:var(--gb3)}

.tli:last-child::before{display:none}

.tl-p strong{color:var(--g4);font-weight:400}

.tlbadge.done{color:#7fd0a3;border-color:rgba(90,168,106,.35)}

.tlr-body em{color:var(--cr2);font-style:italic}

.faq-item:hover{border-color:var(--gb4)}

.faq-a code{font-family:var(--fm);font-size:12px;background:var(--paper2);padding:1px 5px;color:var(--g2)}

.pfi.dim .pfic{color:#c8bfb2}

.news-card:hover .news-link{color:var(--g3)}

.ga-item:hover{border-color:var(--gb3)}

.ga-def strong{color:var(--g4);font-weight:400}

.ga-def code{font-family:var(--fm);font-size:12px;color:var(--g4)}

.ci-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}

.pn span:hover{color:var(--g4)}

.faddr{font-style:normal;font-size:12.5px;font-weight:300;color:var(--cr3);line-height:1.85;margin-top:16px}

.faddr a{color:var(--g4);text-decoration:none}

.faddr a:hover{text-decoration:underline}

.flegal{display:flex;flex-wrap:wrap;gap:18px}

.flegal a{font-size:11.5px;letter-spacing:.5px;color:var(--cr3);text-decoration:none;transition:color .25s}

.flegal a:hover{color:var(--g4)}

.mnote strong{color:var(--cr2);font-weight:400}

#mob-menu{display:none;position:fixed;inset:0;z-index:900;background:rgba(7,7,7,.97);backdrop-filter:blur(14px);flex-direction:column;align-items:center;justify-content:center;gap:0}

#mob-menu.open{display:flex}

#mob-menu::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold)}

#mob-menu a{font-family:var(--fh);font-size:26px;font-weight:400;color:var(--cr);letter-spacing:.5px;text-decoration:none;padding:13px 40px;transition:color .2s;width:100%;text-align:center;border-bottom:1px solid var(--gb)}

#mob-menu a:hover{color:var(--g4)}

@media(max-width:960px){
.nact .btn-gs{display:none}
#nav{padding:0 22px}
}

.ppx-sec{background:var(--bk);padding:34px 48px 86px;border-bottom:1px solid var(--gb)}

.ppx-head{text-align:center;max-width:680px;margin:0 auto 38px}

.ppx{max-width:1120px;margin:0 auto;font-family:'Inter','Jost',system-ui,sans-serif}

.ppx-stage{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;margin-bottom:50px}

.ppx-verify{max-width:600px;margin:0 auto}

@media(max-width:900px){
.ppx-stage{grid-template-columns:1fr;gap:34px}
.ppx-sec{padding:24px 20px 64px}
}

.hi-split{display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center;text-align:left;max-width:1240px}

.hi-left .hover{justify-content:flex-start}

.hi-left .hero-lead{margin:0 0 30px;max-width:560px}

.hi-left .hbtns{justify-content:flex-start;margin-bottom:0}

.hi-right{position:relative;min-width:0;display:flex;flex-direction:column;align-items:center;gap:16px}

.hi-right .tag-demo{max-width:100%}

.hero:has(.hi-split){padding-top:120px;padding-bottom:64px}

@media(max-width:960px){
.hi-split{grid-template-columns:1fr;text-align:center;gap:34px}
.hi-left .hover{justify-content:center}
.hi-left .hero-lead{margin:0 auto 30px}
.hi-left .hbtns{justify-content:center}
}

.hi-below{grid-column:1 / -1;text-align:center;margin-top:26px}

.hi-below .hero-lead{margin:0 auto 24px;max-width:760px}

.hi-below .hbtns{justify-content:center;margin-bottom:0}

.hi-split{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;max-width:920px}

.hi-left{display:flex;flex-direction:column;align-items:center;width:100%}

.hi-left .hover{justify-content:center}

.hi-right{width:100%;align-items:center}

.hi-below{margin-top:10px}

.hi-split{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;text-align:left;max-width:1200px}

.hi-left{display:flex;flex-direction:column;align-items:flex-start}

.hi-left .hover{justify-content:flex-start}

.hi-left .hero-lead{margin:24px 0 28px;max-width:520px}

.hi-left .hbtns{justify-content:flex-start;margin-bottom:0}

.hi-right{width:auto;align-items:center;justify-self:center}

@media(max-width:900px){
.hi-split{grid-template-columns:1fr;text-align:center;gap:32px;max-width:600px}
.hi-left{align-items:center;order:2}
.hi-left .hover{justify-content:center}
.hi-left .hero-lead{margin:18px auto 26px}
.hi-left .hbtns{justify-content:center}
.hi-right{order:1}
}

.hero:has(.hero-flow){padding-top:100px;padding-bottom:46px}

.hero-flow{display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px;max-width:1200px;margin:0 auto}

.hero-flow .hover{justify-content:center;margin-bottom:0}

.flow-row{display:flex;align-items:center;justify-content:center;gap:26px;width:100%;flex-wrap:nowrap}

.flow-row .tag-demo{flex:0 1 440px;max-width:440px}

.flow-below{max-width:760px}

.flow-below .hero-lead{margin:0 auto 20px;max-width:680px}

.flow-below .hbtns{justify-content:center;margin-bottom:0}

@media(max-width:900px){
.hero:has(.hero-flow){padding-top:96px}
.flow-row{flex-direction:column;gap:18px}
.flow-row .tag-demo{flex:0 1 auto;max-width:100%}
}

.hero:has(.hero-flow){padding-top:86px;padding-bottom:38px}

.hero-flow{gap:16px}

.flow-row{zoom:.9}

@media(max-width:900px){
.hero:has(.hero-flow){padding-top:84px}
.flow-row{zoom:1}
}

.flow-row.ppx .tag-demo, .flow-row.ppx .tag-demo:hover{border-color:transparent;background:transparent;box-shadow:none;transform:none}

.flow-row.ppx .tag-demo::before{display:none}

.flow-row.ppx .tag-photo{width:454px;height:335px}

@media(max-width:560px){
.flow-row.ppx .tag-photo{width:min(454px,86vw);height:auto;aspect-ratio:454 / 335}
}

.flow-row{gap:64px}

.flow-row .tag-demo{margin-right:8px}

@media(max-width:900px){
.flow-row{gap:24px}
.flow-row .tag-demo{margin-right:0}
}

.flow-row.ppx .tag-demo{flex-wrap:nowrap}

.flow-row.ppx .tag-cta{flex:0 0 auto}

.flow-row.ppx .tag-arrow-end{flex:none;align-self:center}

.flow-row{zoom:.72}

@media(max-width:900px){
.flow-row{zoom:1}
}

.hero:has(.hero-flow){padding-top:68px;padding-bottom:30px}

.hero:has(.hero-flow){
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:center;
  padding-top:84px;
  padding-bottom:36px;
}

.ppx-sec{
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  scroll-snap-align:start;
}

@media(max-width:560px){
.ppx-sec{min-height:100svh}
}

.ppx-page{min-height:100dvh;display:flex;flex-direction:column;scroll-snap-align:start}

.ppx-page > section{flex:1 0 auto;width:100%}

.hero:has(.hero-flow){border-bottom:none}

.hero-flow .flow-row{border:0!important;outline:0!important;box-shadow:none!important;background:transparent!important}

.flow-row.ppx .tag-demo, .flow-row.ppx .tag-demo:hover, .flow-row.ppx .tag-demo:focus, .flow-row.ppx .tag-demo:focus-visible{border:0!important;outline:0!important;box-shadow:none!important;background:transparent!important}

.ppx-sec{background:var(--bk) radial-gradient(110% 60% at 50% 0%, rgba(201,168,76,.05), transparent 55%)}

.ppx-sec{background:var(--bk) radial-gradient(110% 55% at 50% 0%, rgba(255,255,255,.03), transparent 58%)}

.ppx .hiw-flow{position:relative}

.fviz{position:absolute;top:0;left:0;right:auto;bottom:auto;width:53%;height:100%;
  pointer-events:none;opacity:0;transition:opacity .45s ease;z-index:8}

.hiw-flow.fv-on .fviz{opacity:1}

.fviz-svg{width:100%;height:100%;overflow:visible}

.fv-path{fill:none;stroke:rgba(0,196,140,.16);stroke-width:1.6}

.fv-flow{fill:none;stroke:#00C48C;stroke-width:2.6;stroke-dasharray:5 16;stroke-linecap:round;opacity:0;
  filter:drop-shadow(0 0 5px rgba(0,196,140,.6))}

.hiw-flow.fv-on .fv-flow{opacity:.92;animation:fvDash 1.05s linear infinite}

@keyframes fvDash{to{stroke-dashoffset:-42}}

.fv-dot{fill:#bff8e3;filter:drop-shadow(0 0 6px rgba(0,196,140,.9))}

.fv-box{opacity:0;transform:translateX(-26px) scale(.92);transform-origin:left center;transform-box:fill-box}

.hiw-flow.fv-on .fv-box{animation:fvBoxIn .5s cubic-bezier(.2,.9,.2,1) forwards}

.hiw-flow.fv-on .fv-box.b2{animation-delay:.1s}

.hiw-flow.fv-on .fv-box.b3{animation-delay:.2s}

.hiw-flow.fv-on .fv-box.b4{animation-delay:.3s}

@keyframes fvBoxIn{0%{opacity:0;transform:translateX(-26px) scale(.92)}60%{opacity:1;transform:translateX(0) scale(1.03)}100%{opacity:1;transform:translateX(0) scale(1)}}

.fv-rect{fill:rgba(8,24,42,.94);stroke:rgba(0,196,140,.55);stroke-width:1.6}

.hiw-flow.fv-on .fv-rect{animation:fvRing 2.4s ease-in-out infinite}

@keyframes fvRing{0%,100%{stroke:rgba(0,196,140,.5)}50%{stroke:rgba(0,196,140,.95)}}

.fv-bico{font-size:26px;text-anchor:middle}

.fv-bt{fill:#eafff7;font:600 15px 'Jost',sans-serif;letter-spacing:.02em}

.fv-bs{fill:rgba(180,232,212,.78);font:400 11px 'JetBrains Mono',monospace}

.fv-qr{fill:rgba(0,196,140,.10);stroke:#00C48C;stroke-width:1.8}

.hiw-flow.fv-on .fv-qr{animation:fvGlow 1.6s ease-in-out infinite}

@keyframes fvGlow{0%,100%{filter:drop-shadow(0 0 3px rgba(0,196,140,.45))}50%{filter:drop-shadow(0 0 16px rgba(0,196,140,.85))}}

.fv-qrpix{fill:#7df1c4;opacity:0}

.hiw-flow.fv-on .fv-qrpix{animation:fvFade .4s .55s forwards}

@keyframes fvFade{to{opacity:.92}}

.fv-qrlbl{text-anchor:middle;fill:#bff8e3;font:600 11px 'JetBrains Mono',monospace;letter-spacing:.14em}

@media(prefers-reduced-motion:reduce){
.fv-flow, .fv-rect, .fv-qr{animation:none}
}

@media(max-width:900px){
.fviz{width:100%}
}

.fviz{width:62%}

.hiw-flow .fv-s1 .hiw-vis{transition:transform .45s ease,opacity .45s ease,filter .45s ease}

.hiw-flow.fv-on .fv-s1 .hiw-steplabel, .hiw-flow.fv-on .fv-s1 h3, .hiw-flow.fv-on .fv-s1 p{opacity:.25;transition:opacity .4s ease}

.hiw-flow:has(.fv-s1:hover) .fviz{opacity:1}

.hiw-flow:has(.fv-s1:hover) .fv-flow{opacity:.92;animation:fvDash 1.05s linear infinite}

.hiw-flow:has(.fv-s1:hover) .fv-box{animation:fvBoxIn .5s cubic-bezier(.2,.9,.2,1) forwards}

.hiw-flow:has(.fv-s1:hover) .fv-box.b2{animation-delay:.1s}

.hiw-flow:has(.fv-s1:hover) .fv-box.b3{animation-delay:.2s}

.hiw-flow:has(.fv-s1:hover) .fv-box.b4{animation-delay:.3s}

.hiw-flow:has(.fv-s1:hover) .fv-rect{animation:fvRing 2.4s ease-in-out infinite}

.hiw-flow:has(.fv-s1:hover) .fv-qr{animation:fvGlow 1.6s ease-in-out infinite}

.hiw-flow:has(.fv-s1:hover) .fv-qrpix{animation:fvFade .4s .55s forwards}

.fviz{width:100%}

.hiw-flow .fv-s1 .hiw-vis{transition:transform .55s cubic-bezier(.2,.8,.2,1),opacity .5s ease,filter .5s ease}

.hiw-flow.fv-on .fv-s1 .hiw-vis, .hiw-flow:has(.fv-s1:hover) .fv-s1 .hiw-vis{transform:scale(.46) translateX(-46%);transform-origin:left top;opacity:.16;filter:blur(1px)}

.fv-target{opacity:0}

.hiw-flow.fv-on .fv-target, .hiw-flow:has(.fv-s1:hover) .fv-target{opacity:1}

.fv-tring{fill:none;stroke:#00C48C;stroke-width:2.2}

.hiw-flow.fv-on .fv-tring, .hiw-flow:has(.fv-s1:hover) .fv-tring{animation:fvT 1.5s ease-out infinite}

@keyframes fvT{0%{r:8;opacity:.9}100%{r:30;opacity:0}}

.fv-tdot{fill:#aef7dd;filter:drop-shadow(0 0 8px rgba(0,196,140,.9))}

.fviz{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:0;transition:opacity .45s ease;z-index:8}

.hiw-flow.fv-on .fviz, .hiw-flow:has(.fv-s1:hover) .fviz{opacity:1}

.fv-lines{position:absolute;inset:0;width:100%;height:100%;overflow:visible}

.fv-path{fill:none;stroke:rgba(0,196,140,.18);stroke-width:1.6;vector-effect:non-scaling-stroke}

.fv-flow{fill:none;stroke:#00C48C;stroke-width:2.4;stroke-dasharray:5 13;stroke-linecap:round;vector-effect:non-scaling-stroke;opacity:0;filter:drop-shadow(0 0 4px rgba(0,196,140,.6))}

.hiw-flow.fv-on .fv-flow, .hiw-flow:has(.fv-s1:hover) .fv-flow{opacity:.9;animation:fvDash 1s linear infinite}

@keyframes fvDash{to{stroke-dashoffset:-36}}

.fv-tring{fill:none;stroke:#00C48C;stroke-width:2;vector-effect:non-scaling-stroke}

.hiw-flow.fv-on .fv-tring, .hiw-flow:has(.fv-s1:hover) .fv-tring{animation:fvT 1.5s ease-out infinite}

@keyframes fvT{0%{r:1.2;opacity:.9}100%{r:5;opacity:0}}

.fv-tdot{fill:#aef7dd;filter:drop-shadow(0 0 6px rgba(0,196,140,.9))}

.fv-col{position:absolute;left:1%;top:50%;transform:translateY(-50%);width:23%;display:flex;flex-direction:column;gap:0;
  background:rgba(8,24,42,.97);border:1.5px solid rgba(0,196,140,.55);border-radius:16px;
  padding:9px 12px 10px;box-shadow:0 18px 40px -16px rgba(0,0,0,.7);overflow:hidden}

.fv-col::before{content:"YOUR SUPPLY CHAIN";display:block;font:700 9px 'JetBrains Mono',monospace;
  letter-spacing:.14em;color:rgba(95,233,192,.95);padding:1px 2px 8px}

.fv-bx{display:flex;align-items:center;gap:11px;padding:7px 2px;border-radius:0;
  background:transparent;border:0;border-bottom:1px solid rgba(0,196,140,.16);
  box-shadow:none;opacity:0;transform:translateX(-20px) scale(.92)}

.fv-bx:last-child{border-bottom:0}

.hiw-flow.fv-on .fv-bx, .hiw-flow:has(.fv-s1:hover) .fv-bx{animation:fvBxIn .5s cubic-bezier(.2,.9,.2,1) forwards}

.hiw-flow.fv-on .fv-bx.b2, .hiw-flow:has(.fv-s1:hover) .fv-bx.b2{animation-delay:.1s}

.hiw-flow.fv-on .fv-bx.b3, .hiw-flow:has(.fv-s1:hover) .fv-bx.b3{animation-delay:.2s}

.hiw-flow.fv-on .fv-bx.b4, .hiw-flow:has(.fv-s1:hover) .fv-bx.b4{animation-delay:.3s}

@keyframes fvBxIn{0%{opacity:0;transform:translateX(-26px) scale(.92)}60%{opacity:1;transform:translateX(0) scale(1.03)}100%{opacity:1;transform:translateX(0) scale(1)}}

.hiw-flow.fv-on .fv-bx, .hiw-flow:has(.fv-s1:hover) .fv-bx{animation-fill-mode:forwards}

.fv-i{font-size:18px;line-height:1;flex-shrink:0}

.fv-tx{display:flex;flex-direction:row;align-items:center;flex:1;gap:8px;line-height:1.2}

.fv-tx b{font:600 13px 'Jost',sans-serif;color:#eafff7}

.fv-tx i{font:400 9.5px 'JetBrains Mono',monospace;color:rgba(180,232,212,.78);font-style:normal;margin-left:auto;white-space:nowrap}

@media(max-width:900px){
.fv-col{width:60%;left:6%}
}

.hiw-flow.fv-on .fv-s1 .hiw-vis, .hiw-flow:has(.fv-s1:hover) .fv-s1 .hiw-vis{opacity:1;transform:none;filter:none}

.hiw-vis-supply{padding:9px;overflow:hidden;display:flex;align-items:stretch;gap:8px;background:none;border:none;box-shadow:none}

.hiw-vis-supply .fv-col{position:relative;left:auto;top:auto;transform:none;flex:1;width:auto;max-width:none;margin:0;z-index:2}

.fv-s1 .hiw-vis-supply .hiw-driver{position:absolute;inset:0;width:auto;height:auto;opacity:0;pointer-events:none}

.s1-data{flex:0 0 43%;min-width:0;display:flex;flex-direction:column;background:rgba(8,24,42,.55);border:1px solid rgba(0,196,140,.25);border-radius:10px;padding:8px 9px;overflow:hidden}

.s1-data-h{font:700 8px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#5fe9c0;margin-bottom:7px}

.s1-line{display:flex;flex-direction:column;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.07)}

.s1-line .k{font:400 8px 'JetBrains Mono',monospace;color:rgba(180,232,212,.65);letter-spacing:.04em}

.s1-line .v{font:600 10.5px 'Inter',sans-serif;color:#eafff7}

.s1-line .v.cur::after{content:"\25AE";color:#00C48C;animation:s1blink 1s step-end infinite;margin-left:1px}

@keyframes s1blink{50%{opacity:0}}

.fv-s1 .fv-bx{cursor:pointer;padding:5px 7px}

.fv-s1 .fv-bx.on{background:rgba(0,196,140,.12)}

.fv-s1 .fv-i{font-size:15px}

.fv-s1 .fv-tx{flex-direction:column;align-items:flex-start;gap:0}

.fv-s1 .fv-tx b{font-size:11px}

.fv-s1 .fv-tx i{font-size:8px;margin:0}

.hiw-flow.fv-on .fv-s1 .hiw-steplabel, .hiw-flow.fv-on .fv-s1 .hiw-eyebrow, .hiw-flow.fv-on .fv-s1 .hiw-node, .hiw-flow.fv-on .fv-s1 h3, .hiw-flow.fv-on .fv-s1 p{opacity:1}

.hiw-flow .fviz{display:none}

.hiw-flow .fv-s1{display:block;text-align:left;background:linear-gradient(180deg,rgba(0,196,140,.05),rgba(8,24,42,0));border:1px solid rgba(0,196,140,.2);border-radius:20px;padding:20px 26px}

.fv-s1 .s1-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}

.fv-s1 .s1-head .hiw-node{margin:0;flex:none}

.fv-s1 .s1-head-tx{display:flex;flex-direction:column;align-items:flex-start}

.fv-s1 .s1-head h3{margin:2px 0 0}

.fv-s1 .hiw-eyebrow{margin:0}

.fv-s1 > p{margin:16px 0 0;max-width:none}

.s1-diagram{position:relative;width:680px;max-width:100%;height:450px;margin:0 auto}

.s1-conn{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}

.s1-cline{fill:none;stroke:rgba(0,196,140,.18);stroke-width:1.6;vector-effect:non-scaling-stroke}

.s1-cflow{fill:none;stroke:#00C48C;stroke-width:2.4;stroke-dasharray:4 10;opacity:0;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 4px rgba(0,196,140,.6));transition:opacity .2s}

.s1-cflow.on{opacity:.95;animation:s1dash .7s linear infinite}

@keyframes s1dash{to{stroke-dashoffset:28}}

.s1-cdot{r:4.5;fill:#aef7dd;opacity:0;filter:drop-shadow(0 0 6px rgba(0,196,140,1))}

.s1-cdot.on{opacity:1}

.s1-stage{position:absolute;right:0;width:221px;height:78px;display:flex;align-items:center;gap:10px;padding:0 13px;box-sizing:border-box;border:1px solid rgba(0,196,140,.3);border-radius:12px;background:rgba(8,24,42,.96);cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;z-index:2}

.s1-stage.on{border-color:var(--green);transform:translateX(-4px);box-shadow:0 8px 20px -8px rgba(0,196,140,.5)}

.s1-stage .ic{font-size:24px;flex:none}

.s1-stage .tx{display:flex;flex-direction:column;line-height:1.25;min-width:0}

.s1-stage .tx b{font:600 17.5px 'Jost',sans-serif;color:#eafff7}

.s1-stage .tx i{font:400 13px 'JetBrains Mono',monospace;font-style:normal;color:rgba(180,232,212,.7);margin-top:1px}

.s1-pass{position:absolute;left:0;top:0;width:364px;height:450px;border:1.5px solid rgba(0,196,140,.3);border-radius:16px;background:rgba(8,24,42,.6);box-sizing:border-box;z-index:1}

.s1-pass-h{position:absolute;top:0;left:0;right:0;height:34px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid rgba(0,196,140,.2);font:700 12px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#5fe9c0}

.s1-pass-f{position:absolute;bottom:0;left:0;right:0;height:30px;display:flex;align-items:center;justify-content:center;gap:6px;font:700 12px 'JetBrains Mono',monospace;letter-spacing:.08em;color:#5fe9c0;border-top:1px solid rgba(0,196,140,.2)}

.s1-pin{position:absolute;left:16px;width:322px;height:73px;display:flex;flex-direction:column;justify-content:center;gap:2px;padding:0 13px;box-sizing:border-box;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(8,24,42,.85);transition:border-color .2s,transform .2s;z-index:2}

.s1-pin.on{border-color:var(--green);transform:translateX(4px)}

.s1-pin .hd{font:700 10.5px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#5fe9c0;margin-bottom:1px}

.s1-pin .row{display:flex;justify-content:space-between;gap:10px}

.s1-pin .row .k{font:400 13px 'Inter',sans-serif;color:rgba(180,232,212,.7)}

.s1-pin .row .v{font:600 15px 'JetBrains Mono',monospace;color:#eafff7}

.fv-s1 .stage-inner.hiw-driver{position:absolute !important;inset:0;width:auto;height:auto;opacity:0;pointer-events:none;overflow:hidden}

@media(max-width:760px){
.s1-diagram{transform:scale(.62);transform-origin:top center;margin-bottom:-110px}
}

.eureq{background:var(--bk1);padding:56px 48px;border-top:1px solid var(--gb);border-bottom:1px solid var(--gb)}

.band-wrap{max-width:1120px;margin:0 auto}

.band-lbl{display:block;text-align:center;font-family:var(--fm);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--g3);margin-bottom:26px}

.eureq-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:12px 14px;padding:0}

.eureq-list li{display:inline-flex;align-items:center;gap:9px;font-size:13.5px;font-weight:300;color:var(--cr2);padding:9px 16px;border:1px solid var(--gb);border-radius:99px;background:rgba(255,255,255,.02)}

.eureq-list .chk{width:19px;height:19px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(0,196,140,.15);color:#5fe9c0;font-size:11px;flex-shrink:0}

.trusted{background:var(--bk);padding:42px 48px 52px}

.trusted-lbl{text-align:center;font-family:var(--fm);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--cr4);margin-bottom:24px}

.trusted-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px 42px}

.trusted-logos span{font-family:var(--fh);font-size:25px;font-weight:600;letter-spacing:1px;color:var(--cr3);opacity:.55;transition:opacity .3s,color .3s}

.trusted-logos span:hover{opacity:1;color:var(--cr)}

@media(max-width:560px){
.eureq, .trusted{padding-left:20px;padding-right:20px}
.trusted-logos{gap:14px 26px}
.trusted-logos span{font-size:18px}
}

.hero-foot{max-width:1080px;margin:26px auto 0;padding:0 12px}

.hero-foot .eureq-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:7px 8px;padding:0;margin:0 0 16px}

.hero-foot .eureq-list li{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:300;color:var(--cr2);padding:5px 11px;border:1px solid var(--gb);border-radius:99px;background:rgba(255,255,255,.02);white-space:nowrap}

.hero-foot .eureq-list .chk{width:14px;height:14px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(0,196,140,.15);color:#5fe9c0;font-size:9px;flex-shrink:0}

.hero-foot .trusted-row{text-align:center;border-top:1px solid var(--gb);padding-top:14px}

.hero-foot .trusted-lbl{display:block;font-family:var(--fm);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--cr4);margin-bottom:9px}

.hero-foot .trusted-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:9px 24px}

.hero-foot .trusted-logos span{font-family:var(--fh);font-size:17px;font-weight:600;letter-spacing:.5px;color:var(--cr3);opacity:.5;transition:opacity .3s,color .3s}

.hero-foot .trusted-logos span:hover{opacity:1;color:var(--cr)}

@media(max-width:560px){
.hero-foot{margin-top:18px}
.hero-foot .eureq-list li{font-size:10px;padding:4px 9px}
.hero-foot .trusted-logos span{font-size:14px}
.hero-foot .trusted-logos{gap:7px 15px}
}

.hero:has(.hero-flow){padding-left:26px;padding-right:26px}

.hero-flow{max-width:1380px}

.flow-row{gap:128px}

.flow-below{max-width:1100px}

.flow-below .hero-lead{max-width:780px}

.hero-foot{max-width:1320px}

.hero-foot .eureq-list{gap:8px 10px}

@media(max-width:1100px){
.hero-flow{max-width:96vw}
}

@media(max-width:900px){
.flow-row{gap:24px}
.hero:has(.hero-flow){padding-left:18px;padding-right:18px}
}

.hero:has(.hero-flow){padding-top:82px;padding-bottom:18px}

.hero-flow{gap:8px}

.flow-row{zoom:.6}

.hero-foot{margin-top:8px}

.hero-foot .eureq-list{margin-bottom:9px;gap:6px 9px}

.hero-foot .eureq-list li{padding:4px 10px;font-size:10.5px}

.hero-foot .trusted-row{padding-top:9px}

.hero-foot .trusted-lbl{margin-bottom:7px}

.hero-foot .trusted-logos{gap:8px 22px}

.hero-foot .trusted-logos span{font-size:16px}

@media(max-width:900px){
.flow-row{zoom:1}
}

.flow-row{zoom:.80}

@media(max-width:900px){
.flow-row{zoom:1}
}

.hero-foot{margin-top:22px}

.hero-foot .eureq-list li{font-size:11px;padding:5px 12px;gap:6px}

.hero-foot .eureq-list .chk{width:13px;height:13px;font-size:9px}

.hero-foot .eureq-list{gap:6px 9px;margin-bottom:10px}

.hero-foot .trusted-lbl{font-size:9px;letter-spacing:1.8px;margin-bottom:8px}

.hero-foot .trusted-logos{gap:8px 20px}

.hero-foot .trusted-logos span{font-size:15px}

@media(max-width:560px){
.hero-foot .eureq-list li{font-size:10px}
.hero-foot .trusted-logos span{font-size:12px}
}


/* ==== Ported-hero layout fix: restore landing hero base (scoped to the animation hero only) ==== */
.hero:has(.hero-flow){display:block;min-height:0;position:relative;overflow:hidden;background:var(--bk);padding:150px 48px 90px;border-bottom:1px solid var(--gb)}
.hero:has(.hero-flow) .hbg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 55% at 50% 0%,rgba(138,104,32,.16) 0%,transparent 62%);pointer-events:none}
.hero:has(.hero-flow) .hr1{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,var(--gb2),transparent);pointer-events:none;left:18%}
.hero:has(.hero-flow) .hr2{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,var(--gb2),transparent);pointer-events:none;left:50%}
.hero:has(.hero-flow) .hr3{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,var(--gb2),transparent);pointer-events:none;left:82%}
.hero:has(.hero-flow) .hover{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:22px;animation:rise .8s ease both}
.hero:has(.hero-flow) .ht{font-family:var(--fb);font-size:14px;font-weight:600;letter-spacing:2.2px;text-transform:uppercase;text-align:center;background:var(--gold-t);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:gsh 6s ease infinite}
.hero:has(.hero-flow) .hl{width:40px;height:1px;background:var(--gold)}

/* ==== Ported-hero: cloth -> arrow -> tap-circle -> arrow -> passport, fit in one row, no overlap, circle kept ==== */
.hero:has(.hero-flow) .flow-row{display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;gap:34px;zoom:1;width:100%;max-width:1120px;margin:0 auto}
.hero:has(.hero-flow) .tag-demo{flex:0 1 400px;min-width:0;margin:0}
.hero:has(.hero-flow) .tag-photo{width:100%;height:auto;aspect-ratio:454 / 335}
.hero:has(.hero-flow) .tag-cta{flex:0 0 auto;margin:0}
.hero:has(.hero-flow) .tag-arrow,.hero:has(.hero-flow) .tag-arrow-end{flex:0 0 auto}
.hero:has(.hero-flow) .passport-wrap{flex:0 0 auto;margin:0;min-height:auto}

/* Fix: keep the "Tap to scan" circle between the cloth photo and the passport.
   The photo was width:100% of a fixed 400px .tag-demo, so the circle + arrows had
   no room and overflowed onto the passport. On desktop, size .tag-demo to its
   content and give the photo a fixed width so the circle sits in the middle. */
@media(min-width:901px){
  .hero:has(.hero-flow) .tag-demo{flex:0 0 auto;max-width:none;gap:18px}
  .hero:has(.hero-flow) .tag-photo{flex:0 0 auto;width:360px;height:auto;aspect-ratio:454 / 335}
}
/* On mobile the row stacks; stack .tag-demo vertically too, otherwise the photo
   fills the width and the circle overflows off the right edge. */
@media(max-width:900px){
  .hero:has(.hero-flow) .tag-demo{flex-direction:column;align-items:center;gap:14px;max-width:100%}
  .hero:has(.hero-flow) .tag-photo{width:min(360px,84vw)}
  .hero:has(.hero-flow) .tag-arrow{transform:rotate(90deg)}
  .hero:has(.hero-flow) .tag-arrow-end{animation:none;transform:rotate(90deg)}
}

/* ── Auto-fit the hero to whatever screen height it opens on (desktop). The hero
   becomes a full 100dvh panel with vertically-centred content; fit-hero.js scales
   the inner block (.hi) down with `zoom` whenever its natural height exceeds the
   available space, so the whole hero — including the .eureq-list checklist at the
   bottom — always fits one screen, on any laptop or monitor. Mobile (<=900px) keeps
   the normal stacked, scrollable layout. ── */
@media(min-width:901px){
  .hero:has(.hero-flow){
    height:100dvh;min-height:100dvh;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    padding-top:92px;padding-bottom:40px;
  }
  .hero:has(.hero-flow) .hi{width:100%}
}
