/* =========================================================
   UQT  ·  Design tokens & global styles
   ---------------------------------------------------------
   All animations gate on prefers-reduced-motion at the end.
   ========================================================= */

:root{
  /* surfaces */
  --bg:#0B0F10;
  --bg-2:#0A0D0E;
  --bg-3:#0E1314;
  --surface:#11161A;
  --surface-2:#141B1F;
  --surface-3:#19222A;

  /* lines */
  --line:rgba(244,245,244,0.07);
  --line-2:rgba(244,245,244,0.12);
  --line-3:rgba(244,245,244,0.20);

  /* brand */
  --teal:#4ED7C8;
  --teal-hi:#6BE3D5;
  --teal-dim:rgba(78,215,200,0.18);
  --teal-aura:rgba(78,215,200,0.10);
  --platinum:#C8CCD0;

  /* text */
  --text:#F4F5F4;
  --text-2:#D6DADC;
  --muted:#98A1A8;
  --muted-2:#6B7479;
  --muted-3:#4A5258;

  /* category colours */
  --bank:#A9C8FF;
  --fx:#4ED7C8;
  --digital:#E3B8FF;
  --infra:#FFCF9E;

  /* shape */
  --radius:14px;
  --radius-lg:18px;
  --radius-xl:24px;

  /* motion */
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  /* layout */
  --maxw:1280px;
  --nav-h:72px;
  --nav-h-compact:60px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:'Inter',system-ui,sans-serif;
  font-feature-settings:"ss01","cv11","ss03";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
  overflow-x:hidden;
}
::selection{background:var(--teal);color:#06201D}

a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;padding:0}
img,svg{display:block;max-width:100%}

:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:6px}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;position:relative}
@media (max-width:720px){.wrap{padding:0 20px}}

section{padding:140px 0;position:relative}
@media (max-width:900px){section{padding:96px 0}}
@media (max-width:540px){section{padding:72px 0}}

/* ---------- typography ---------- */
h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-0.025em;line-height:1.05;color:var(--text)}
h1{font-size:clamp(48px,7.2vw,104px);font-weight:600;letter-spacing:-0.04em;line-height:0.98}
h2{font-size:clamp(34px,4.6vw,64px);letter-spacing:-0.03em;line-height:1.02}
h3{font-size:20px;letter-spacing:-0.01em;font-weight:500}
p{margin:0;color:var(--muted)}

.lead{
  font-size:clamp(17px,1.4vw,21px);
  color:var(--text-2);
  max-width:60ch;
  line-height:1.55;
  font-weight:400;
}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);font-weight:500;
  padding:8px 14px;
  border:1px solid var(--line-2);
  border-radius:999px;
  background:rgba(255,255,255,0.015);
}
.eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 4px rgba(78,215,200,0.14);
}

.section-label{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--muted-2);font-weight:500;
  display:flex;align-items:center;gap:14px;margin-bottom:28px;
}
.section-label::before{
  content:"";width:28px;height:1px;background:linear-gradient(90deg,var(--teal),transparent);
}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}

.section-head{
  display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:end;
  margin-bottom:64px;
}
@media (max-width:900px){.section-head{grid-template-columns:1fr;gap:24px}}
.section-head h2{max-width:18ch}
.section-head .lead{max-width:46ch}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  transition:background .35s var(--ease), border-color .35s var(--ease),
             backdrop-filter .35s var(--ease), height .3s var(--ease),
             transform .35s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,13,14,0.78);
  backdrop-filter:saturate(160%) blur(16px);
  -webkit-backdrop-filter:saturate(160%) blur(16px);
  border-bottom-color:var(--line-2);
  height:var(--nav-h-compact);
}
.nav.hidden{transform:translateY(-100%)}

.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;
}

.brand{
  display:flex;align-items:center;gap:12px;
  font-weight:600;letter-spacing:-0.02em;font-size:18px;
  color:var(--text);
}
.brand-mark{
  width:32px;height:32px;display:inline-block;color:var(--teal);
  transition:transform .6s var(--ease);
}
.brand:hover .brand-mark{transform:rotate(60deg)}
.brand-word{font-weight:600;letter-spacing:0.02em}

.nav-links{
  display:flex;align-items:center;gap:8px;
  position:relative;
}
.nav-links a{
  font-size:13.5px;color:var(--muted);
  padding:8px 14px;border-radius:8px;
  transition:color .2s;
  position:relative;
}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--text)}
.nav-indicator{
  position:absolute;left:0;bottom:-8px;
  height:1.5px;width:0;background:var(--teal);
  transition:transform .4s var(--ease), width .4s var(--ease), opacity .3s;
  opacity:0;pointer-events:none;border-radius:2px;
}
.nav.scrolled .nav-indicator{opacity:.75}

.nav-actions{display:flex;align-items:center;gap:10px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:42px;padding:0 18px;border-radius:10px;
  font-size:14px;font-weight:500;letter-spacing:-0.005em;
  transition:transform .25s var(--ease), background .2s, border-color .2s, color .2s, box-shadow .25s;
  white-space:nowrap;cursor:pointer;
}
.btn-primary{
  background:var(--teal);color:#06201D;
  box-shadow:0 0 0 0 var(--teal-aura), 0 8px 30px rgba(78,215,200,0.18);
}
.btn-primary:hover{
  background:var(--teal-hi);transform:translateY(-1px);
  box-shadow:0 0 0 6px var(--teal-aura), 0 12px 40px rgba(78,215,200,0.25);
}
.btn-ghost{
  background:transparent;color:var(--text);
  border:1px solid var(--line-2);
}
.btn-ghost:hover{border-color:var(--line-3);transform:translateY(-1px);background:rgba(255,255,255,0.02)}
.btn-lg{height:52px;padding:0 26px;font-size:15px;border-radius:12px}
.btn-xl{height:60px;padding:0 32px;font-size:16px;border-radius:14px;font-weight:500}
.btn .arrow{transition:transform .28s var(--ease);display:inline-block}
.btn:hover .arrow{transform:translateX(4px)}

.hamburger{
  display:none;width:42px;height:42px;
  border:1px solid var(--line-2);border-radius:10px;position:relative;
  background:rgba(255,255,255,0.015);
}
.hamburger span{
  position:absolute;left:11px;right:11px;height:1.5px;background:var(--text);
  transition:transform .3s var(--ease), opacity .25s;
}
.hamburger span:nth-child(1){top:15px}
.hamburger span:nth-child(2){top:20px}
.hamburger span:nth-child(3){top:25px}
.hamburger.open span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

@media (max-width:960px){
  .nav-links{display:none}
  .nav-actions .btn{display:none}
  .hamburger{display:block}
  .mobile-menu{
    position:fixed;inset:var(--nav-h-compact) 0 0 0;
    background:rgba(10,13,14,0.98);
    backdrop-filter:blur(20px);
    transform:translateY(-100%);
    transition:transform .4s var(--ease), visibility 0s linear .4s, opacity .3s linear;
    z-index:99;padding:32px 20px 80px;
    overflow-y:auto;
    visibility:hidden;opacity:0;pointer-events:none;
  }
  .mobile-menu.open{
    transform:translateY(0);
    visibility:visible;opacity:1;pointer-events:auto;
    transition:transform .4s var(--ease), visibility 0s linear 0s, opacity .25s linear;
  }
  .mobile-menu a{
    display:block;padding:20px 4px;font-size:24px;color:var(--text);
    border-bottom:1px solid var(--line);font-weight:500;letter-spacing:-0.02em;
  }
  .mobile-actions{display:flex;flex-direction:column;gap:10px;margin-top:32px}
  .mobile-actions .btn{height:54px;width:100%}
}
@media (min-width:961px){
  .mobile-menu{display:none}
}

/* ---------- mobile sticky CTA ---------- */
.sticky-cta{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:90;
  background:rgba(11,15,16,0.92);
  backdrop-filter:blur(14px);
  border:1px solid var(--line-2);
  border-radius:14px;
  padding:10px;
  display:none;
  align-items:center;gap:10px;
  transform:translateY(140%);
  transition:transform .4s var(--ease);
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta .btn{flex:1;height:48px}
@media (max-width:720px){.sticky-cta{display:flex}}

/* ---------- hero ---------- */
.hero{
  padding:calc(var(--nav-h) + 80px) 0 80px;
  position:relative;overflow:hidden;min-height:90vh;
  display:flex;align-items:center;
}

.hero-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
}
.hero-bg-layer{
  position:absolute;inset:-10%;
  will-change:transform;
}
.hero-stars{
  background-image: radial-gradient(circle at center, rgba(244,245,244,0.55) 0.5px, transparent 1px);
  background-size: 60px 60px;
  opacity:0.18;
  animation: drift 90s linear infinite;
}
@keyframes drift{
  from{background-position:0 0}
  to{background-position:600px 300px}
}
.hero-rings{
  display:flex;align-items:center;justify-content:center;
}
.hero-ring{
  position:absolute;border:1px solid rgba(244,245,244,0.035);border-radius:50%;
  animation:spin 120s linear infinite;
}
.hero-ring:nth-child(1){width:80vmin;height:80vmin}
.hero-ring:nth-child(2){width:120vmin;height:120vmin;animation-duration:180s;animation-direction:reverse}
.hero-ring:nth-child(3){width:160vmin;height:160vmin;animation-duration:240s}
.hero-ring::after{
  content:"";position:absolute;width:4px;height:4px;border-radius:50%;
  background:var(--teal);box-shadow:0 0 12px var(--teal);
  top:-2px;left:50%;
}
@keyframes spin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
.hero-glow{
  position:absolute;width:1200px;height:1200px;
  right:-280px;top:-280px;
  background:radial-gradient(closest-side, rgba(78,215,200,0.13), rgba(78,215,200,0) 70%);
  filter:blur(20px);
}
.hero-glow.bottom{
  left:-280px;right:auto;top:auto;bottom:-400px;
  background:radial-gradient(closest-side, rgba(78,215,200,0.06), rgba(78,215,200,0) 70%);
  width:800px;height:800px;
}

.hero-grid{
  display:grid;grid-template-columns: 1.05fr 1fr;
  gap:80px;align-items:center;
  position:relative;z-index:2;
}
@media (max-width:1024px){.hero-grid{grid-template-columns:1fr;gap:60px}}
.hero-copy h1{margin-top:28px;text-wrap:balance}
.hero-copy .lead{margin-top:32px;max-width:50ch}
.hero-actions{margin-top:44px;display:flex;gap:12px;flex-wrap:wrap}

.hero-trust{
  margin-top:48px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted-2);
  font-family:'JetBrains Mono',monospace;
}
.hero-trust .dot{width:4px;height:4px;border-radius:50%;background:var(--muted-3)}

/* matching graphic */
.graphic{
  position:relative;aspect-ratio:1/1;width:100%;max-width:560px;margin-left:auto;
}
@media (max-width:1024px){.graphic{margin:0 auto;max-width:480px}}
.graphic .ring{
  position:absolute;border-radius:50%;border:1px dashed rgba(244,245,244,0.05);
  inset:14%;
}
.graphic .ring.r2{inset:0;border-style:solid;border-color:rgba(244,245,244,0.04)}
.graphic .ring.r3{inset:-12%;border-style:dotted;border-color:rgba(78,215,200,0.07);animation:spin 90s linear infinite}

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

.g-center{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:34%;min-width:170px;
  background:linear-gradient(180deg, rgba(78,215,200,0.06), rgba(78,215,200,0.02));
  border:1px solid rgba(78,215,200,0.32);
  border-radius:14px;
  padding:18px 18px 16px;
  backdrop-filter:blur(10px);
  box-shadow:0 0 0 1px rgba(78,215,200,0.08), 0 30px 80px rgba(0,0,0,0.45);
  z-index:4;
}
.g-center .dot{
  width:8px;height:8px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 6px rgba(78,215,200,0.18);
  margin-bottom:12px;animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 6px rgba(78,215,200,0.18)}
  50%{box-shadow:0 0 0 12px rgba(78,215,200,0.04)}
}
.g-center .label{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;
  color:var(--muted);text-transform:uppercase;margin-bottom:4px;
}
.g-center .name{font-size:14px;font-weight:600;letter-spacing:-0.01em;color:var(--text)}
.g-center .counter{
  margin-top:10px;padding-top:10px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--muted-2);letter-spacing:0.08em;
}
.g-center .counter b{color:var(--teal);font-weight:500;font-size:11px}

.g-node{
  position:absolute;
  background:var(--surface);
  border:1px solid var(--line-2);
  border-radius:10px;
  padding:8px 12px;
  font-size:11px;font-weight:500;color:var(--text);
  display:inline-flex;align-items:center;gap:8px;
  white-space:nowrap;
  z-index:3;
  box-shadow:0 8px 24px rgba(0,0,0,0.4);
  transform:translate(-50%,-50%);
  opacity:0;
  animation:node-in .7s var(--ease) forwards;
}
.g-node::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--platinum);opacity:.7;flex-shrink:0;
}
.g-node.bank::before{background:var(--bank)}
.g-node.fx::before{background:var(--fx)}
.g-node.crypto::before{background:var(--digital)}
.g-node .pct{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);
  border-left:1px solid var(--line);padding-left:8px;
}
@keyframes node-in{
  from{opacity:0;transform:translate(-50%,-50%) scale(.85)}
  to{opacity:1;transform:translate(-50%,-50%) scale(1)}
}

.g-line{stroke:var(--teal);stroke-width:1;fill:none;opacity:0.5}
.g-line-bg{stroke:rgba(244,245,244,0.05);stroke-width:1;fill:none}

/* ---------- marquee strip (trust) ---------- */
.trust-strip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
  padding:36px 0;
}
.trust-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-left:1px solid var(--line);
}
@media (max-width:720px){.trust-row{grid-template-columns:repeat(2,1fr)}}
.trust-item{
  padding:8px 28px;
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
}
.trust-item .figure{
  font-size:clamp(28px,3vw,40px);
  font-weight:500;letter-spacing:-0.02em;
  color:var(--text);font-family:'JetBrains Mono',monospace;
  line-height:1;
}
.trust-item .figure .suffix{color:var(--teal);font-weight:500;margin-left:1px}
.trust-item .label{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--muted-2);
}

/* ---------- pillars ---------- */
.pillars{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
@media (max-width:900px){.pillars{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.pillars{grid-template-columns:1fr}}
.pillar{
  background:var(--bg);
  padding:36px 30px 32px;
  transition:background .3s, transform .35s var(--ease);
  display:flex;flex-direction:column;gap:14px;
  min-height:240px;
  position:relative;
}
.pillar:hover{background:var(--surface)}
.pillar .num{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--teal);letter-spacing:0.18em;
}
.pillar h3{font-size:18px;font-weight:600;letter-spacing:-0.01em;text-wrap:balance}
.pillar p{font-size:14px;line-height:1.55}
.pillar .pillar-ico{
  width:38px;height:38px;color:var(--teal);opacity:.85;
  margin-bottom:4px;
}

/* ---------- tabs (solutions) ---------- */
.tabs{margin-top:8px}
.tab-bar{
  display:flex;gap:4px;
  border-bottom:1px solid var(--line);
  position:relative;
  overflow-x:auto;
  scrollbar-width:none;
}
.tab-bar::-webkit-scrollbar{display:none}
.tab-btn{
  font-size:14px;font-weight:500;color:var(--muted);
  padding:18px 22px;
  position:relative;
  transition:color .25s;
  display:flex;align-items:center;gap:10px;
  white-space:nowrap;
}
.tab-btn .tab-dot{
  width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.6;
}
.tab-btn[data-cat="banking"] .tab-dot{background:var(--bank)}
.tab-btn[data-cat="fx"] .tab-dot{background:var(--fx)}
.tab-btn[data-cat="digital"] .tab-dot{background:var(--digital)}
.tab-btn[data-cat="infra"] .tab-dot{background:var(--infra)}

.tab-btn:hover{color:var(--text-2)}
.tab-btn.active{color:var(--text)}
.tab-indicator{
  position:absolute;left:0;bottom:-1px;height:2px;background:var(--teal);
  transition:transform .45s var(--ease), width .45s var(--ease);
  border-radius:2px;
}

.tab-panels{position:relative;padding-top:48px;min-height:380px}
.tab-panel{
  display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:start;
  position:absolute;inset:48px 0 0 0;
  opacity:0;pointer-events:none;
  transform:translateY(8px);
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.tab-panel.active{opacity:1;pointer-events:auto;transform:none;position:relative;inset:auto}
@media (max-width:900px){.tab-panel{grid-template-columns:1fr;gap:32px}}

.tab-panel h3{
  font-size:clamp(28px,3vw,40px);letter-spacing:-0.025em;font-weight:600;
  margin-bottom:18px;text-wrap:balance;
}
.tab-panel p{font-size:16px;line-height:1.65;max-width:48ch}
.tab-panel .panel-meta{
  margin-top:32px;display:flex;flex-wrap:wrap;gap:24px;
}
.tab-panel .meta-item{font-size:13px}
.tab-panel .meta-item .k{
  display:block;font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.16em;color:var(--muted-2);text-transform:uppercase;margin-bottom:4px;
}
.tab-panel .meta-item .v{color:var(--text);font-weight:500}

.panel-list{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.panel-list-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 18px;border-bottom:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--muted-2);letter-spacing:0.14em;text-transform:uppercase;
}
.panel-list-head .pl-status{display:inline-flex;align-items:center;gap:6px;color:var(--teal)}
.panel-list-head .pl-status::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 3px rgba(78,215,200,0.16)}

.panel-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--line);
  font-size:13px;
  transition:background .2s;
}
.panel-row:last-child{border-bottom:0}
.panel-row:hover{background:rgba(78,215,200,0.025)}
.panel-row .pr-left{display:flex;align-items:center;gap:10px}
.panel-row .pr-mono{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted-2)}
.panel-row .pr-name{color:var(--text)}
.panel-row .pr-meta{color:var(--muted);font-size:12px}

.panel-cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:28px;
  font-size:14px;font-weight:500;color:var(--teal);
  border-bottom:1px solid rgba(78,215,200,0.35);padding-bottom:4px;
  transition:gap .25s var(--ease), border-color .25s;
}
.panel-cta:hover{gap:14px;border-color:var(--teal)}

/* ---------- sticky scrollytelling ---------- */
.scrolly{
  background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.scrolly-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;
  position:relative;
}
@media (max-width:960px){.scrolly-grid{grid-template-columns:1fr;gap:32px}}

.scrolly-visual{
  position:sticky;top:calc(var(--nav-h-compact) + 60px);
  height:600px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  overflow:hidden;
}
@media (max-width:960px){
  .scrolly-visual{position:relative;top:auto;height:420px}
}

.scrolly-stage{position:absolute;inset:0}
.scrolly-state{
  position:absolute;inset:0;
  opacity:0;transform:scale(0.98);
  transition:opacity .6s var(--ease), transform .8s var(--ease);
  display:flex;align-items:center;justify-content:center;
  padding:40px;
}
.scrolly-state.active{opacity:1;transform:none}

.scrolly-stepper{
  position:absolute;left:24px;top:24px;right:24px;
  display:flex;gap:8px;z-index:5;
}
.scrolly-step-bar{
  flex:1;height:2px;border-radius:2px;background:rgba(244,245,244,0.08);
  overflow:hidden;
}
.scrolly-step-bar i{
  display:block;height:100%;width:0;background:var(--teal);
  transition:width .6s var(--ease);
}
.scrolly-step-bar.active i{width:100%}
.scrolly-step-bar.passed i{width:100%;opacity:.4}

.scrolly-steps{display:flex;flex-direction:column;gap:32px;padding:60px 0 200px}
.scrolly-step{
  padding:24px 28px;
  border-left:2px solid var(--line);
  opacity:0.42;
  transition:opacity .4s var(--ease), border-color .4s var(--ease);
}
.scrolly-step.active{opacity:1;border-color:var(--teal)}
.scrolly-step .s-num{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--teal);letter-spacing:0.18em;margin-bottom:10px;display:block;
}
.scrolly-step h3{font-size:24px;font-weight:600;letter-spacing:-0.02em;margin-bottom:10px;text-wrap:balance}
.scrolly-step p{font-size:15px;line-height:1.6}

/* visual states */
.viz-profile{display:flex;flex-direction:column;gap:10px;width:100%;max-width:340px}
.viz-row{
  display:flex;align-items:center;gap:10px;
  background:rgba(244,245,244,0.025);
  border:1px solid var(--line);
  border-radius:10px;padding:12px 14px;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--muted);
  position:relative;overflow:hidden;
}
.viz-row .k{color:var(--muted-2);min-width:80px}
.viz-row .v{color:var(--text)}
.viz-row::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--teal);
  opacity:0;animation:viz-tick 2.5s ease-out infinite;
}
.scrolly-state.active .viz-row::after{opacity:.8}
@keyframes viz-tick{
  0%,100%{opacity:0}
  50%{opacity:.6}
}

.viz-network{
  position:relative;width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
}
.viz-network svg{width:100%;height:100%;max-width:480px;max-height:480px}

.viz-rank{display:flex;flex-direction:column;gap:10px;width:100%;max-width:380px}
.viz-rank-row{
  display:grid;grid-template-columns:24px 1fr 60px 50px;align-items:center;gap:12px;
  padding:12px 14px;
  background:rgba(244,245,244,0.02);
  border:1px solid var(--line);
  border-radius:10px;
}
.viz-rank-row .vr-num{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted-2)}
.viz-rank-row .vr-name{font-size:13px;color:var(--text)}
.viz-rank-row .vr-bar{
  height:4px;background:rgba(244,245,244,0.06);border-radius:4px;overflow:hidden;
}
.viz-rank-row .vr-bar i{
  display:block;height:100%;width:0;background:var(--teal);border-radius:4px;
  transition:width 1s var(--ease);
}
.scrolly-state.active .viz-rank-row .vr-bar i{width:var(--w, 80%)}
.viz-rank-row .vr-pct{
  font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--teal);text-align:right;
}

.viz-match{display:flex;flex-direction:column;gap:8px;width:100%;max-width:380px}
.viz-match-card{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-radius:12px;
  background:linear-gradient(180deg, rgba(78,215,200,0.06), rgba(78,215,200,0.02));
  border:1px solid rgba(78,215,200,0.25);
}
.viz-match-card .vm-name{font-size:14px;color:var(--text);font-weight:500}
.viz-match-card .vm-tag{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.12em;
  color:var(--teal);text-transform:uppercase;
  padding:4px 8px;border-radius:6px;border:1px solid rgba(78,215,200,0.3);
}
.viz-match-foot{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:8px;font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--muted-2);letter-spacing:0.1em;
}

/* ---------- matching engine panel ---------- */
.me-grid{
  display:grid;grid-template-columns:1fr 1.18fr;gap:80px;align-items:center;
}
@media (max-width:1024px){.me-grid{grid-template-columns:1fr;gap:48px}}
.me-panel{
  background:linear-gradient(180deg,var(--surface) 0%, var(--surface-2) 100%);
  border:1px solid var(--line-2);
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,0.5);
}
.me-panel-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--muted);letter-spacing:0.12em;
}
.me-dots{display:flex;gap:6px}
.me-dots i{width:8px;height:8px;border-radius:50%;background:var(--line-2);display:inline-block}
.me-status{display:inline-flex;align-items:center;gap:8px;color:var(--teal)}
.me-status::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 3px rgba(78,215,200,0.18)}

.me-rows{padding:8px 0}
.me-row{
  display:grid;grid-template-columns:32px 1fr auto 130px;align-items:center;gap:18px;
  padding:18px 22px;border-bottom:1px solid var(--line);
  transition:background .2s;cursor:pointer;
}
.me-row:last-child{border-bottom:0}
.me-row:hover{background:rgba(78,215,200,0.03)}
.me-row .rank{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted-2)}
.me-row .who .name{font-size:14px;font-weight:500;color:var(--text)}
.me-row .who .sub{font-size:12px;color:var(--muted);margin-top:2px}
.me-row .tag{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;
  padding:5px 10px;border-radius:999px;
  border:1px solid var(--line-2);color:var(--muted);
}
.me-row .tag.bank{color:var(--bank);border-color:rgba(169,200,255,0.25)}
.me-row .tag.fx{color:var(--fx);border-color:rgba(78,215,200,0.3)}
.me-row .tag.crypto{color:var(--digital);border-color:rgba(227,184,255,0.25)}
.me-row .score{display:flex;align-items:center;gap:10px;justify-content:flex-end}
.me-row .score .bar{
  flex:1;height:4px;border-radius:4px;background:rgba(244,245,244,0.06);overflow:hidden;
  max-width:70px;
}
.me-row .score .bar i{
  display:block;height:100%;background:var(--teal);border-radius:4px;
  width:0;transition:width 1s var(--ease);
}
.me-row.in .score .bar i{width:var(--w, 80%)}
.me-row .score .pct{
  font-family:'JetBrains Mono',monospace;font-size:13px;
  color:var(--teal);font-weight:500;width:42px;text-align:right;
}
.me-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 22px;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--muted-2);letter-spacing:0.12em;
}
.me-foot .me-refresh{
  display:inline-flex;align-items:center;gap:8px;color:var(--teal);
  transition:color .2s;
}
.me-foot .me-refresh:hover{color:var(--teal-hi)}
.me-foot .me-refresh svg{transition:transform .6s var(--ease)}
.me-foot .me-refresh.spin svg{transform:rotate(360deg)}

/* ---------- specialists / agents ---------- */
.agents{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  overflow:hidden;
}
@media (max-width:960px){.agents{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.agents{grid-template-columns:1fr}}
.agent{
  background:var(--bg);
  padding:32px 28px 28px;
  display:flex;flex-direction:column;gap:18px;
  position:relative;
  transition:background .3s;
  cursor:pointer;
}
.agent:hover{background:var(--surface)}
.agent-portrait{
  width:88px;height:88px;border-radius:50%;
  position:relative;
  background:linear-gradient(135deg, var(--surface-3), var(--surface));
  display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono',monospace;font-size:18px;font-weight:500;
  color:var(--platinum);letter-spacing:0.05em;
  overflow:hidden;
}
.agent-portrait::before{
  content:"";position:absolute;inset:-1px;
  border-radius:50%;
  background:conic-gradient(from 180deg, var(--teal) 0deg, transparent 90deg, transparent 360deg);
  opacity:0;mask:radial-gradient(circle, transparent 60%, black 62%);
  -webkit-mask:radial-gradient(circle, transparent 60%, black 62%);
  transition:opacity .4s var(--ease), transform 1s var(--ease);
}
.agent:hover .agent-portrait::before{opacity:1;transform:rotate(360deg)}
.agent-portrait::after{
  content:"";position:absolute;inset:6px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, rgba(244,245,244,0.08), transparent 60%);
}

.agent .a-title{
  font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--muted-2);font-family:'JetBrains Mono',monospace;
}
.agent .a-name{font-size:18px;font-weight:600;letter-spacing:-0.01em;color:var(--text)}
.agent .a-remit{font-size:13px;color:var(--muted);line-height:1.55}

.agent-meta{
  margin-top:auto;padding-top:18px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--muted-2);letter-spacing:0.12em;text-transform:uppercase;
}
.agent-meta .a-region{display:flex;align-items:center;gap:6px}
.agent-meta .a-region::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--teal)}
.agent-cta{
  color:var(--teal);display:inline-flex;align-items:center;gap:6px;
  transition:gap .25s var(--ease);
}
.agent:hover .agent-cta{gap:10px}

.agent-expand{
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease);
}
.agent.open .agent-expand{max-height:280px}
.agent-expand-inner{
  padding-top:18px;margin-top:8px;
  border-top:1px solid var(--line);
  font-size:13px;color:var(--muted);line-height:1.55;
}
.agent-expand-inner ul{margin:8px 0 0;padding:0 0 0 18px;display:flex;flex-direction:column;gap:4px}
.agent-expand-inner ul li{color:var(--text-2);font-size:12.5px}

/* ---------- coverage / regions ---------- */
.coverage{
  display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center;
  position:relative;
}
@media (max-width:1024px){.coverage{grid-template-columns:1fr;gap:40px}}

.regions{
  display:flex;flex-wrap:wrap;gap:8px;
  margin:32px 0 24px;
}
.region-pill{
  padding:10px 16px;border-radius:999px;
  border:1px solid var(--line-2);
  font-size:13px;color:var(--text);
  display:inline-flex;align-items:center;gap:10px;
  transition:background .2s, border-color .2s, color .2s;
  font-family:'JetBrains Mono',monospace;letter-spacing:0.06em;
}
.region-pill .pill-count{
  font-size:11px;color:var(--muted);
  border-left:1px solid var(--line);padding-left:10px;
}
.region-pill:hover{border-color:var(--line-3)}
.region-pill.active{
  background:rgba(78,215,200,0.08);
  border-color:rgba(78,215,200,0.4);
  color:var(--text);
}
.region-pill.active .pill-count{color:var(--teal)}

.coverage-readout{
  background:var(--surface);
  border:1px solid var(--line-2);
  border-radius:var(--radius-lg);
  padding:28px;
  margin-top:16px;
}
.coverage-readout .cr-head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:24px;font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--muted-2);letter-spacing:0.14em;text-transform:uppercase;
}
.coverage-readout .cr-total{
  font-size:48px;font-weight:500;letter-spacing:-0.03em;
  color:var(--text);font-family:'JetBrains Mono',monospace;
  margin-bottom:6px;line-height:1;
  display:flex;align-items:baseline;gap:8px;
}
.coverage-readout .cr-total .suffix{color:var(--teal);font-size:24px}
.coverage-readout .cr-breakdown{
  display:flex;flex-direction:column;gap:8px;margin-top:20px;
}
.cr-bar-row{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--muted)}
.cr-bar-row .k{width:90px;font-family:'JetBrains Mono',monospace;letter-spacing:0.1em}
.cr-bar-row .bar{flex:1;height:3px;background:rgba(244,245,244,0.06);border-radius:3px;overflow:hidden}
.cr-bar-row .bar i{display:block;height:100%;background:var(--teal);transition:width .8s var(--ease)}
.cr-bar-row .v{
  font-family:'JetBrains Mono',monospace;color:var(--text);min-width:36px;text-align:right;
}

.globe-art{
  position:relative;aspect-ratio:1/1;width:100%;max-width:520px;margin:0 auto;
}
.globe-art svg{width:100%;height:100%;overflow:visible}
.globe-art .pin{
  position:absolute;width:10px;height:10px;border-radius:50%;
  background:var(--teal);transform:translate(-50%,-50%);
  box-shadow:0 0 0 4px rgba(78,215,200,0.18);
}
.globe-art .pin::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:1px solid var(--teal);opacity:0;
  animation:pin-pulse 3s ease-out infinite;
}
@keyframes pin-pulse{
  0%{opacity:.7;transform:scale(.6)}
  100%{opacity:0;transform:scale(2)}
}

/* ---------- why uqt ---------- */
.why-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
}
@media (max-width:960px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.why-grid{grid-template-columns:1fr}}
.why{
  background:var(--bg);padding:36px 28px 32px;
  display:flex;flex-direction:column;gap:10px;min-height:220px;
}
.why .big{
  font-size:clamp(40px,5vw,64px);font-weight:500;letter-spacing:-0.04em;
  color:var(--teal);font-family:'JetBrains Mono',monospace;line-height:1;
  margin-bottom:4px;
}
.why .big .suffix{font-size:0.5em;color:var(--muted)}
.why h3{font-size:17px;font-weight:600;letter-spacing:-0.01em;color:var(--text)}
.why p{font-size:13.5px;line-height:1.55}

/* ---------- compliance ---------- */
.compliance{
  background:linear-gradient(180deg,var(--bg) 0%, var(--bg-2) 100%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.compliance-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;
}
@media (max-width:900px){.compliance-grid{grid-template-columns:1fr;gap:32px}}
.compliance h2{max-width:14ch}
.compliance .body{
  font-size:17px;line-height:1.7;color:var(--text-2);max-width:60ch;
}
.checks{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.check{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line)}
.check:last-child{border-bottom:0}
.check svg{flex-shrink:0;margin-top:3px;color:var(--teal)}
.check span{font-size:14px;color:var(--text-2)}

/* ---------- faq ---------- */
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;text-align:left;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:28px 8px;
  font-size:18px;font-weight:500;letter-spacing:-0.015em;color:var(--text);
  transition:color .2s;
}
.faq-q:hover{color:var(--teal-hi)}
.faq-icon{
  width:32px;height:32px;flex-shrink:0;
  border-radius:50%;border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;
  position:relative;color:var(--muted);
  transition:border-color .25s, color .25s, transform .35s var(--ease);
}
.faq-icon::before,.faq-icon::after{
  content:"";position:absolute;background:currentColor;
}
.faq-icon::before{width:10px;height:1.5px}
.faq-icon::after{width:1.5px;height:10px;transition:transform .3s var(--ease)}
.faq-item.open .faq-icon{color:var(--teal);border-color:rgba(78,215,200,0.4);transform:rotate(45deg)}
.faq-item.open .faq-icon::after{transform:scaleY(0)}

.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .45s var(--ease);
}
.faq-a-inner{
  padding:0 8px 28px;max-width:70ch;
  font-size:15px;line-height:1.65;color:var(--muted);
}
.faq-item.open .faq-a{max-height:360px}

/* ---------- who we serve ---------- */
.serve-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
}
@media (max-width:900px){.serve-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.serve-grid{grid-template-columns:1fr}}
.serve{
  background:var(--bg);padding:26px;min-height:160px;
  display:flex;flex-direction:column;justify-content:space-between;gap:18px;
  transition:background .25s;position:relative;overflow:hidden;
}
.serve:hover{background:var(--surface)}
.serve .idx{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted-2);
  letter-spacing:0.16em;
}
.serve .name{font-size:17px;font-weight:500;letter-spacing:-0.01em;line-height:1.25;color:var(--text)}
.serve .desc{
  font-size:12px;color:var(--muted);line-height:1.55;
  opacity:0;max-height:0;
  transition:opacity .3s, max-height .35s var(--ease);
}
.serve:hover .desc{opacity:1;max-height:100px}

/* ---------- for providers ---------- */
.providers-cta{
  border:1px solid var(--line-2);
  border-radius:var(--radius-xl);
  padding:56px;
  display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:center;
  background:
    radial-gradient(circle at 90% 0%, rgba(78,215,200,0.07), transparent 50%),
    var(--surface);
  position:relative;overflow:hidden;
}
@media (max-width:760px){.providers-cta{grid-template-columns:1fr;padding:36px;gap:24px}}
.providers-cta h2{font-size:clamp(28px,3.6vw,44px);max-width:18ch;letter-spacing:-0.025em}
.providers-cta p{font-size:15px;max-width:46ch;color:var(--text-2);margin-top:18px}
.providers-cta .actions{display:flex;justify-content:flex-end}
@media (max-width:760px){.providers-cta .actions{justify-content:flex-start}}

/* ---------- about ---------- */
.about{
  display:grid;grid-template-columns:1fr 1.4fr;gap:60px;
}
@media (max-width:900px){.about{grid-template-columns:1fr;gap:24px}}
.about h2{font-size:clamp(28px,3.4vw,44px)}
.about p{font-size:16px;line-height:1.7;max-width:60ch;color:var(--text-2)}
.about .meta{
  margin-top:28px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line);
}
@media (max-width:720px){.about .meta{grid-template-columns:1fr;gap:8px}}
.about .meta div{padding:22px 16px 0 0}
.about .meta .k{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.16em;
  color:var(--muted-2);text-transform:uppercase;margin-bottom:6px;
}
.about .meta .v{font-size:13px;color:var(--text)}

/* ---------- final cta ---------- */
.final{
  text-align:center;padding:160px 0 120px;position:relative;overflow:hidden;
}
.final::before{
  content:"";position:absolute;left:50%;top:30%;transform:translate(-50%,-50%);
  width:1000px;height:600px;
  background:radial-gradient(ellipse at center, rgba(78,215,200,0.12), transparent 60%);
  pointer-events:none;z-index:0;
}
.final-ring{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:1100px;height:1100px;border-radius:50%;
  border:1px solid rgba(78,215,200,0.06);
  pointer-events:none;z-index:0;
}
.final-ring.r2{width:1500px;height:1500px;border-color:rgba(78,215,200,0.04)}
.final h2{
  font-size:clamp(54px,8vw,128px);font-weight:600;letter-spacing:-0.04em;
  position:relative;z-index:1;line-height:0.98;text-wrap:balance;
}
.final p{
  margin:28px auto 40px;max-width:50ch;font-size:17px;
  color:var(--text-2);position:relative;z-index:1;
}
.final-actions{
  display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center;
  position:relative;z-index:1;
}

/* ---------- footer ---------- */
footer{
  border-top:1px solid var(--line);
  padding:72px 0 40px;background:var(--bg-2);
  position:relative;overflow:hidden;
}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
@media (max-width:900px){.foot-top{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:540px){.foot-top{grid-template-columns:1fr}}
.foot-brand .brand{margin-bottom:22px}
.foot-brand p{font-size:13px;max-width:42ch;line-height:1.6;color:var(--muted)}
.foot-col h4{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;
  color:var(--muted-2);text-transform:uppercase;margin-bottom:18px;font-weight:500;
}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:13px;color:var(--muted);transition:color .2s}
.foot-col a:hover{color:var(--text)}
.foot-bottom{
  margin-top:56px;padding-top:24px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  font-size:12px;color:var(--muted-2);
}
.disclaimer{
  margin-top:24px;padding:22px;
  background:rgba(244,245,244,0.02);
  border:1px solid var(--line);
  border-radius:12px;
  font-size:12px;line-height:1.65;color:var(--muted);
}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s}
.reveal.d2{transition-delay:.12s}
.reveal.d3{transition-delay:.18s}
.reveal.d4{transition-delay:.24s}
.reveal.d5{transition-delay:.30s}

/* ---------- grain ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:200;
  opacity:.03;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{opacity:1;transform:none}
}
