:root{
  --bg0:#1F1F20;
  --bg1:#232323;
  --panel:rgba(35,35,35,.68);
  --text:#e8e8ea;
  --muted:#b6b6bf;
  --accent:#50f2df;
  --stroke:rgba(255,255,255,.08);
}
*{box-sizing:border-box}
body.page{
  margin:0;color:var(--text);
  background:
    radial-gradient(900px 520px at 12% -10%, rgba(80,242,223,.10), transparent 55%),
    radial-gradient(700px 500px at 92% 10%, rgba(255,255,255,.05), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Ubuntu,sans-serif;
  letter-spacing:.01em;
}
body.page.fabricIntroActive{
  overflow:hidden;
}

/* --- Fullscreen intro: loader + network canvas --- */
.fabricIntroOverlay{
  position:fixed;
  inset:0;
  z-index:200;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:stretch;
  height:100vh;
  height:100dvh;
  max-height:100vh;
  max-height:100dvh;
  overflow:hidden;
  background:#1F1F20;
  opacity:1;
  transition:opacity .55s ease, visibility .55s ease;
  visibility:visible;
}
.fabricIntroOverlay.fabricIntroOverlay--fadeOut{
  opacity:0;
  pointer-events:none;
  visibility:hidden;
}
.fabricIntroLoader{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  background:#1F1F20;
  z-index:2;
}
.fabricIntroLoader.fabricIntroLoader--hidden{
  opacity:0;
  pointer-events:none;
  visibility:hidden;
}
.fabricIntroSpinner{
  width:36px;
  height:36px;
  border-radius:50%;
  border:2px solid rgba(91,232,255,.22);
  border-top-color:#5be8ff;
  animation:fabricIntroSpin .85s linear infinite;
}
.fabricIntroLoaderText{
  margin:0;
  font-size:12px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(184,220,255,.75);
}
.fabricIntroStage{
  position:relative;
  flex:1;
  min-height:0;
  width:100%;
  z-index:1;
}
.fabricIntroCanvas{
  display:block;
  width:100%;
  height:100%;
  min-height:0;
  touch-action:none;
  cursor:default;
}

.fabricLanding--hidden{
  visibility:hidden;
  pointer-events:none;
}
.fabricLanding--visible{
  visibility:visible;
  pointer-events:auto;
}

/* Pull hero under sticky topbar so gloss/canvas shows through transparent nav */
#fabricLanding{
  --fabric-topbar-overlap:58px;
}
#fabricLanding.fabricPageShell > .fabricMain{
  margin-top:calc(-1 * var(--fabric-topbar-overlap));
}

/* Sticky footer: shell fills viewport; main grows */
.fabricPageShell{
  display:flex;
  flex-direction:column;
  min-height:100vh;
  min-height:100dvh;
}
.fabricPageShell > main{
  flex:1 1 auto;
  min-height:0;
  width:100%;
  max-width:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
}

@keyframes fabricIntroSpin{
  to{transform:rotate(360deg)}
}
.topbar{
  position:sticky;top:0;z-index:20;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px 16px;
  flex-wrap:wrap;
  padding:12px 16px;
  background:transparent;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  border-bottom:none;
  box-shadow:none;
}
.topbarFabricMark{
  flex-shrink:0;
  font-size:clamp(17px,2.2vw,22px);
  font-weight:800;
  letter-spacing:.08em;
  line-height:1;
  color:#5be8ff;
  text-decoration:none;
  text-shadow:0 0 24px rgba(91,232,255,.35);
  opacity:0;
  max-width:0;
  margin:0;
  overflow:hidden;
  white-space:nowrap;
  pointer-events:none;
  transition:opacity .22s ease, max-width .3s ease, margin .3s ease, filter .22s ease;
}
.topbarFabricMark:hover{
  color:#7ff0ff;
  filter:brightness(1.08);
}
.topbar.topbar--scrolled .topbarFabricMark{
  opacity:1;
  max-width:7.5em;
  margin-right:10px;
  pointer-events:auto;
}
.navcluster{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  flex-wrap:wrap;
  flex:1;
  min-width:0;
}
.topbarEnd{
  display:flex;
  align-items:baseline;
  justify-content:flex-end;
  gap:16px;
  flex-shrink:0;
}
.topbarBrand{
  font-size:11px;
  color:var(--muted);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:600;
  white-space:nowrap;
  flex-shrink:0;
}
.topbarLabelLink{
  font-size:11px;
  color:var(--muted);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:600;
  white-space:nowrap;
  text-decoration:none;
  transition:color .18s ease;
}
.topbarLabelLink:hover{color:var(--text)}
.topbarLabelLink:focus-visible{
  outline:2px solid rgba(91,232,255,.45);
  outline-offset:3px;
  border-radius:2px;
}
.navpill{
  position:relative;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:600;
  color:var(--text);
  text-decoration:none;
  padding:7px 11px;
  border-radius:11px;
  letter-spacing:.02em;
  background:rgba(14,15,18,.35);
  border:1px solid rgba(255,255,255,.1);
  transition:transform .22s ease, border-color .22s ease, background .22s ease, box-shadow .22s ease;
}
.navpillText{
  position:relative;
  z-index:2;
}
.navpill::after{
  content:"";
  position:absolute;
  top:-22%;
  left:0;
  width:32%;
  height:145%;
  pointer-events:none;
  z-index:1;
  background:linear-gradient(
    102deg,
    transparent 0%,
    rgba(91,232,255,.04) 28%,
    rgba(200,248,255,.16) 50%,
    rgba(80,242,223,.06) 70%,
    transparent 100%
  );
  filter:blur(1.1px);
  animation:fabricNavShineSynced 6.2s linear infinite;
}
.navcluster .navpill:nth-child(1)::after{animation-delay:0s}
.navcluster .navpill:nth-child(2)::after{animation-delay:.09s}
.navcluster .navpill:nth-child(3)::after{animation-delay:.18s}
.navcluster .navpill:nth-child(4)::after{animation-delay:.27s}
.navcluster .navpill:nth-child(5)::after{animation-delay:.36s}
.navpill:hover{
  transform:translateY(-1px);
  border-color:rgba(80,242,223,.32);
  background:rgba(14,15,18,.5);
  box-shadow:0 0 0 1px rgba(80,242,223,.06);
}

.fabricMain{
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
  min-height:0;
  width:100%;
}

/* --- Fabric hero: ribbon / gloss (dark palette, cyan-teal highlights) --- */
.fabricHeroPolished{
  position:relative;
  isolation:isolate;
  flex:1 1 auto;
  min-height:0;
  width:100%;
  min-width:0;
  padding:0;
  overflow:hidden;
  color:var(--text);
  background:transparent;
}
/* Node mesh behind ribbons (same layer idea as Comet landing) */
.fabricHeroPolished .fabricHeroCanvasWrap{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  opacity:.38;
}
.fabricHeroPolished #fabricHeroCanvas{
  display:block;
  width:100%;
  height:100%;
}
.fabricHeroPolished .fabricGlossBase{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 18%,rgba(91,232,255,.045) 0%,transparent 40%),
    radial-gradient(circle at 82% 28%,rgba(80,242,223,.035) 0%,transparent 36%),
    radial-gradient(circle at 50% 88%,rgba(24,28,34,.72) 0%,transparent 48%),
    linear-gradient(145deg,#0e0f11 0%,#141518 35%,#101114 65%,#16171a 100%);
}
.fabricHeroPolished .fabricGlossBloom{
  position:absolute;
  inset:-22%;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(ellipse at 32% 28%,rgba(91,232,255,.08) 0%,rgba(91,232,255,.03) 22%,transparent 52%),
    radial-gradient(ellipse at 68% 42%,rgba(80,242,223,.06) 0%,rgba(80,242,223,.02) 20%,transparent 40%),
    radial-gradient(ellipse at 48% 72%,rgba(28,32,40,.5) 0%,rgba(12,14,18,.2) 28%,transparent 48%);
  filter:blur(46px);
  transform:rotate(-10deg) scale(1.22);
  opacity:.72;
}
.fabricHeroPolished .fabricGlossMotion{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  transform-origin:50% 50%;
}
.fabricHeroPolished .fabricGlossMotion.fabricGlossMotion--flip90{
  transform:rotate(90deg);
}
.fabricHeroPolished .fabricGlossStreak{
  position:absolute;
  top:-32%;
  left:-10%;
  width:58%;
  height:210%;
  z-index:1;
  pointer-events:none;
  background:linear-gradient(
    var(--gradient-angle-streak,100deg),
    transparent 0%,
    rgba(45,55,68,.35) 14%,
    rgba(55,68,82,.45) 32%,
    rgba(72,88,102,.38) 40%,
    rgba(91,232,255,.42) 48%,
    rgba(80,242,223,.32) 52%,
    rgba(50,60,72,.28) 60%,
    rgba(91,232,255,.12) 68%,
    transparent 100%
  );
  filter:blur(18px);
  transform:skewX(-20deg) rotate(12deg);
  opacity:.55;
  animation:fabricOpenShineMove 28s linear 0s 1 forwards;
  will-change:transform,opacity;
}
.fabricHeroPolished .fabricGlossStreak--delayed{
  top:-24%;
  right:-6%;
  left:auto;
  width:52%;
  height:198%;
  --gradient-angle-streak:88deg;
  filter:blur(20px);
  transform:skewX(16deg) rotate(-8deg);
  opacity:.44;
  animation:fabricOpenShineMoveLate 26s linear 18s 1 both;
  will-change:transform,opacity;
}
.fabricHeroPolished .fabricGlossStreak--third{
  top:18%;
  left:-14%;
  width:48%;
  height:185%;
  --gradient-angle-streak:104deg;
  filter:blur(22px);
  transform:skewX(-14deg) rotate(18deg);
  opacity:.4;
  animation:fabricOpenShineMoveThird 27s linear 24s 1 both;
  will-change:transform,opacity;
}
.fabricHeroPolished .glossStreak.glossRibbon--extra{
  position:absolute;
  z-index:1;
  pointer-events:none;
  animation:none;
  left:auto;
  right:auto;
  background:linear-gradient(
    var(--gradient-angle-streak,100deg),
    transparent 0%,
    rgba(38,48,58,.42) 14%,
    rgba(52,64,78,.4) 32%,
    rgba(68,82,96,.36) 40%,
    rgba(91,232,255,.34) 48%,
    rgba(80,242,223,.24) 52%,
    rgba(48,58,70,.3) 62%,
    rgba(91,232,255,.1) 70%,
    transparent 100%
  );
  transform:skewX(-16deg) rotate(10deg);
  will-change:transform,opacity;
}
.fabricHeroPolished .fabricGlossShine2{
  position:absolute;
  top:-18%;
  right:-18%;
  width:48%;
  height:155%;
  z-index:1;
  pointer-events:none;
  background:linear-gradient(
    100deg,
    transparent 0%,
    rgba(91,232,255,.08) 18%,
    rgba(120,245,255,.22) 38%,
    rgba(91,232,255,.1) 58%,
    transparent 72%
  );
  filter:blur(26px);
  transform:rotate(-10deg);
  opacity:.36;
  animation:fabricOpenShineMoveReverse 34s linear 0s 1 forwards;
  will-change:transform;
}
.fabricHeroPolished .fabricGlossRipple{
  position:absolute;
  inset:-10%;
  z-index:2;
  pointer-events:none;
  overflow:hidden;
  filter:blur(26px);
  mix-blend-mode:screen;
  opacity:.62;
}
.fabricHeroPolished .glossLine{
  position:absolute;
  left:50%;
  top:50%;
  width:var(--width,160vw);
  height:var(--height,14vh);
  border-radius:999px;
  pointer-events:none;
  opacity:var(--opacity,.2);
  background:linear-gradient(
    var(--gradient-angle,100deg),
    transparent 0%,
    rgba(45,58,72,.25) 14%,
    rgba(60,78,92,.32) 32%,
    rgba(72,92,108,.28) 40%,
    rgba(91,232,255,.38) 48%,
    rgba(80,242,223,.28) 52%,
    rgba(48,58,70,.22) 60%,
    rgba(91,232,255,.14) 68%,
    transparent 100%
  );
  transform:translate3d(0,0,0) rotate(var(--angle,0deg)) scaleY(var(--scale,1));
  will-change:transform,opacity;
}
.fabricHeroPolished .fabricGlossSurface{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:
    radial-gradient(ellipse at 22% 88%,rgba(0,0,0,.52) 0%,transparent 42%),
    radial-gradient(ellipse at 78% 82%,rgba(0,0,0,.45) 0%,transparent 36%),
    radial-gradient(ellipse at 50% 48%,rgba(91,232,255,.035) 0%,transparent 44%),
    linear-gradient(180deg,rgba(0,0,0,.12) 0%,transparent 28%,transparent 72%,rgba(0,0,0,.18) 100%);
}
.fabricHeroPolished .fabricGlossGrain{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
  opacity:.028;
  background-image:repeating-linear-gradient(
    0deg,
    rgba(255,255,255,.06) 0 1px,
    transparent 1px 3px
  );
}
.fabricHeroInner{
  position:relative;
  z-index:10;
  max-width:1100px;
  width:100%;
  margin:0 auto;
  padding:22px 18px 56px;
  box-sizing:border-box;
}
#fabricLanding .fabricHeroPolished{
  display:flex;
  flex-direction:column;
}
#fabricLanding .fabricHeroInner{
  flex:1 1 auto;
  padding-top:calc(22px + var(--fabric-topbar-overlap));
}
#fabricLanding .fabricHeroPolished > .footer{
  position:relative;
  z-index:10;
  flex-shrink:0;
  margin-top:auto;
  margin-bottom:0;
  background:transparent;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  border-top:1px solid rgba(255,255,255,.08);
  color:#a4a4ac;
}
#fabricLanding .fabricHeroPolished > .footer .socialLinks a{
  background:rgba(14,15,18,.35);
  border:1px solid rgba(255,255,255,.1);
  color:#c2c2c8;
}
#fabricLanding .fabricHeroPolished > .footer .socialLinks a:hover{
  background:rgba(22,22,24,.55);
  border-color:rgba(200,200,208,.32);
  color:#e8e8ec;
}
#fabricLanding .fabricHeroPolished > .footer .contactBtn{
  background:rgba(18,18,20,.5);
  border-color:rgba(180,180,188,.32);
  color:#d6d6dc;
}
#fabricLanding .fabricHeroPolished > .footer .contactBtn:hover{
  background:rgba(28,28,30,.62);
  border-color:rgba(210,210,218,.4);
  color:#f0f0f2;
}
#fabricLanding .fabricHeroPolished > .footer .footerCacheBtn{
  color:#96969e;
  border-color:rgba(255,255,255,.12);
}
#fabricLanding .fabricHeroPolished > .footer .footerCacheBtn:hover{
  color:#d8d8dc;
  border-color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.07);
}
#fabricLanding .fabricHeroPolished > .footer .footerCacheBtn:focus-visible{
  outline:2px solid rgba(150,150,158,.5);
  outline-offset:2px;
}
#fabricLanding .fabricHeroPolished > .footer .footerBrand{
  color:#d2d2d6;
}
#fabricLanding .fabricHeroPolished > .footer .footerLinks a{
  color:#b4b4bc;
}
#fabricLanding .fabricHeroPolished > .footer .footerLinks a:hover{
  color:#e6e6ea;
}
#fabricLanding .fabricHeroPolished > .footer .footerLinks a[aria-current="page"]{
  color:#cfcfd4;
}

/* Landing chrome only - greys (hero gloss/canvas + .tile cards unchanged) */
#fabricLanding .topbarFabricMark{
  color:#c8c8d0;
  text-shadow:0 0 22px rgba(255,255,255,.06);
}
#fabricLanding .topbarFabricMark:hover{
  color:#e4e4e8;
  filter:brightness(1.05);
}
#fabricLanding .topbarLabelLink:focus-visible{
  outline:2px solid rgba(150,150,158,.45);
  outline-offset:3px;
}
#fabricLanding .navpill::after{
  background:linear-gradient(
    102deg,
    transparent 0%,
    rgba(255,255,255,.03) 28%,
    rgba(210,210,215,.1) 50%,
    rgba(255,255,255,.04) 70%,
    transparent 100%
  );
}
#fabricLanding .navpill:hover{
  border-color:rgba(190,190,198,.32);
  background:rgba(14,15,18,.5);
  box-shadow:0 0 0 1px rgba(255,255,255,.05);
}
#fabricLanding .logoWord{
  color:#ffffff;
}
#fabricLanding .hero .tag{
  margin-top:clamp(28px,4vw,40px);
}
#fabricLanding .hero .sub{
  margin-top:14px;
}
#fabricLanding .hero .sub .subOiLabel:focus-visible{
  outline:2px solid rgba(145,145,152,.55);
  outline-offset:2px;
}
#fabricLanding .fabricExplain p{
  color:#b4b4ba;
}
#fabricLanding .fabricExplainMore:focus-visible{
  outline:2px solid rgba(145,145,152,.45);
  outline-offset:2px;
}
#fabricLanding .tile.accent{
  border-color:var(--stroke);
  box-shadow:none;
}
#fabricLanding a.tile.accent:hover{
  border-color:rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
}
#fabricLanding .tile--media .tileMedia{
  background:#ffffff;
  /* Taller media strip vs base 20/11 (~1.5× height for same width) */
  aspect-ratio:40 / 33;
}
/* Companies tiles - base grid width; tall media strip kept (40/33) */
#fabricLanding .fabricHeroInner{
  max-width:min(1100px,98vw);
}
#fabricLanding .tiles{
  grid-template-columns:repeat(auto-fit, minmax(min(100%,158px), 220px));
  gap:12px;
}
@media (max-width:520px){
  #fabricLanding .tiles{
    grid-template-columns:1fr;
  }
  #fabricLanding .tile--media h3{font-size:clamp(11px,3.2vw,12px)}
  #fabricLanding .tile--media p{font-size:clamp(10px,2.8vw,11px)}
  #fabricLanding .tile--media .tileBody{padding:10px 12px 12px}
}
#fabricLanding .tile{
  border-radius:14px;
  min-height:120px;
}
#fabricLanding .tile--media .tileBody{
  padding:12px 14px 14px;
}
#fabricLanding .tile--media h3{
  margin:0 0 6px;
  font-size:12px;
  line-height:1.35;
  letter-spacing:.01em;
}
#fabricLanding .tile--media.accent h3{
  color:var(--text);
}
#fabricLanding .tile--media p{
  font-size:11px;
  line-height:1.5;
}

@keyframes fabricOpenShineMove{
  0%{transform:translate3d(-34%,2%,0) skewX(-20deg) rotate(11deg);opacity:0}
  14%{transform:translate3d(-10%,-3%,0) skewX(-20deg) rotate(13deg);opacity:.72}
  39%{transform:translate3d(22%,-7%,0) skewX(-20deg) rotate(14deg);opacity:.72}
  57%{transform:translate3d(48%,0,0) skewX(-20deg) rotate(12deg);opacity:0}
  100%{transform:translate3d(122%,4%,0) skewX(-20deg) rotate(11deg);opacity:0}
}
@keyframes fabricOpenShineMoveLate{
  0%{transform:translate3d(28%,5%,0) skewX(16deg) rotate(-8deg);opacity:0}
  12%{transform:translate3d(10%,-3%,0) skewX(16deg) rotate(-10deg);opacity:.58}
  28%{transform:translate3d(-6%,-9%,0) skewX(15deg) rotate(-11deg);opacity:.58}
  38%{transform:translate3d(-18%,-5%,0) skewX(16deg) rotate(-9deg);opacity:.58}
  55%{transform:translate3d(-42%,2%,0) skewX(16deg) rotate(-8deg);opacity:0}
  100%{transform:translate3d(-108%,6%,0) skewX(16deg) rotate(-8deg);opacity:0}
}
@keyframes fabricOpenShineMoveThird{
  0%{transform:translate3d(-40%,8%,0) skewX(-14deg) rotate(18deg);opacity:0}
  15%{transform:translate3d(-12%,4%,0) skewX(-14deg) rotate(18deg);opacity:.52}
  40%{transform:translate3d(24%,-2%,0) skewX(-14deg) rotate(18deg);opacity:.52}
  58%{transform:translate3d(52%,-6%,0) skewX(-14deg) rotate(18deg);opacity:0}
  100%{transform:translate3d(118%,-10%,0) skewX(-14deg) rotate(18deg);opacity:0}
}
@keyframes fabricOpenShineMoveReverse{
  from{transform:translate3d(38%,0,0) rotate(-10deg)}
  to{transform:translate3d(-122%,0,0) rotate(-10deg)}
}

.hero{
  padding:8px 6px 4px;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.logo{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  line-height:1;
  animation:rise .88s ease both;
}
.logoLockup{
  display:inline-flex;
  align-items:baseline;
  justify-content:center;
  flex-wrap:nowrap;
  gap:0;
  font-size:clamp(40px,10vw,96px);
  margin:0 auto;
}
.logoWord{
  flex:0 0 auto;
  font-size:1em;
  font-weight:800;
  letter-spacing:.06em;
  color:#5be8ff;
}
.logoSuffix{
  flex:0 0 auto;
  font-size:0.3em;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:lowercase;
  color:rgba(232,232,237,.76);
  padding-bottom:0.14em;
  line-height:1;
}
.tag{
  margin:20px auto 0;max-width:50ch;
  font-size:12px;color:var(--text);
  opacity:.9;
  animation:fade .88s .12s ease both;
}
.sub{
  margin:8px auto 0;max-width:58ch;
  font-size:11px;color:var(--muted);
  line-height:1.65;
  animation:fade .88s .22s ease both;
}
.sub .subOiLabel{
  display:inline;
  margin:0;
  padding:0;
  font:inherit;
  color:inherit;
  text-decoration:none;
  border:0;
  border-radius:0;
  background:none;
  vertical-align:baseline;
  transition:color .15s ease;
}
.sub .subOiLabel:hover{
  color:var(--text);
}
.sub .subOiLabel:focus-visible{
  outline:2px solid rgba(91,232,255,.55);
  outline-offset:2px;
  border-radius:2px;
}
.fabricExplain{
  margin:36px auto 8px;
  max-width:min(56ch,100%);
  text-align:center;
  animation:fade .88s .32s ease both;
}
#fabricLanding .fabricExplain{
  margin-top:clamp(48px,7vw,80px);
}
.fabricExplainHeading{
  margin:0 0 16px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--muted);
}
#fabricLanding .fabricExplainHeading{
  color:#a0a0a8;
}
.fabricExplain p{
  margin:0 0 1.05em;
  font-size:13px;
  line-height:1.68;
  color:#c4c8d4;
}
.fabricExplain p:last-of-type{margin-bottom:0}
.fabricExplain strong{
  color:var(--text);
  font-weight:700;
}
.fabricExplainActions{
  margin-top:16px;
}
.fabricExplainMore{
  display:inline-block;
  font-size:10px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  text-decoration:none;
  padding:5px 12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  background:rgba(255,255,255,.03);
  transition:color .15s ease,border-color .15s ease,background .15s ease;
}
.fabricExplainMore:hover{
  color:var(--text);
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
}
.fabricExplainMore:focus-visible{
  outline:2px solid rgba(91,232,255,.45);
  outline-offset:2px;
}

.companies{margin-top:30px}
.tiles{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(158px, 220px));
  justify-content:center;
  gap:12px;
}
@media (max-width:520px){
  .tiles{
    grid-template-columns:1fr;
    justify-content:stretch;
  }
}
.tile{
  padding:14px 14px 16px;
  border-radius:14px;
  background:var(--panel);
  border:1px solid var(--stroke);
  backdrop-filter:blur(16px) saturate(150%);
  min-height:120px;
  transform:translateY(10px);
  opacity:0;
  animation:tileIn .72s ease forwards;
}
a.tile{
  color:inherit;
  text-decoration:none;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:flex-start;
}
a.tile:hover{
  border-color:rgba(80,242,223,.32);
  background:rgba(255,255,255,.05);
}
.tile:nth-child(1){animation-delay:.05s}
.tile:nth-child(2){animation-delay:.12s}
.tile:nth-child(3){animation-delay:.19s}
.tile:nth-child(4){animation-delay:.26s}
.tile:nth-child(5){animation-delay:.33s}
.tile:nth-child(6){animation-delay:.40s}
.tile:nth-child(7){animation-delay:.47s}
.tile h3{margin:0 0 8px;font-size:12px;font-weight:700;letter-spacing:.02em}
.tile p{margin:0;font-size:11px;color:var(--muted);line-height:1.55}
.tile.accent{
  border-color:rgba(80,242,223,.35);
  box-shadow:0 0 0 1px rgba(80,242,223,.12) inset;
}
.tile.accent h3{color:var(--accent)}
.tile.tile--media{
  padding:0;
  overflow:hidden;
  text-align:left;
  display:flex;
  flex-direction:column;
  align-items:stretch;
}
.tile--media .tileMedia{
  position:relative;
  width:100%;
  aspect-ratio:20/11;
  flex-shrink:0;
  background:#0a0d12;
}
.tile--media .tileMedia img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}
.tile--media .tileBody{
  padding:12px 14px 14px;
}
.tile--media h3{
  margin:0 0 6px;
  font-size:12px;
  font-weight:700;
  line-height:1.35;
  letter-spacing:.01em;
}
.tile--media p{
  margin:0;
  font-size:11px;
  line-height:1.5;
  color:var(--muted);
  display:-webkit-box;
  -webkit-line-clamp:4;
  line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.tile.tile--media:hover .tileMedia img{opacity:.94}
.tile--media.accent h3{color:var(--accent)}

.fabricAbout{
  max-width:720px;
  margin:0 auto;
  padding:32px 22px 56px;
}
.fabricAboutBack{
  display:inline-block;
  margin-bottom:20px;
  font-size:12px;
  font-weight:600;
  color:var(--accent);
  text-decoration:none;
}
.fabricAboutBack:hover{text-decoration:underline}
.fabricAboutTitle{
  margin:0 0 12px;
  font-size:clamp(22px,4vw,28px);
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--text);
}
.fabricAboutLead{
  margin:0 0 16px;
  font-size:14px;
  color:var(--text);
  line-height:1.55;
  opacity:.95;
}
.fabricAboutBody{
  margin:0 0 14px;
  font-size:13px;
  color:var(--muted);
  line-height:1.65;
}
.fabricAboutBody:last-child{margin-bottom:0}
.fabricAboutInline{
  color:var(--accent);
  font-weight:600;
  text-decoration:none;
}
.fabricAboutInline:hover{text-decoration:underline}
.footerLinks a[aria-current="page"]{
  color:#5be8ff;
  font-weight:600;
}

.footer{
  margin:0;
  margin-top:auto;
  padding:16px 22px;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:12px 16px;
  color:#b7bdc8;
  font-size:12px;
  background:rgba(24,24,26,.75);
  border-top:1px solid rgba(255,255,255,.08);
}
.footerBrandWrap{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-self:start;
}
.footerBrand{
  font-weight:600;
  color:#d6dbe5;
}
.footerCacheBtn{
  margin:0;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:#9aa3b0;
  font:inherit;
  font-size:11px;
  font-weight:600;
  letter-spacing:.02em;
  cursor:pointer;
  white-space:nowrap;
}
.footerCacheBtn:hover{
  color:#8ff2ff;
  border-color:rgba(91,232,255,.35);
  background:rgba(91,232,255,.08);
}
.footerCacheBtn:focus-visible{
  outline:2px solid rgba(91,232,255,.45);
  outline-offset:2px;
}
.footerLinks{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  justify-self:center;
  text-align:center;
}
.footerLinks a{
  color:#c0c6d1;
  text-decoration:none;
}
.footerLinks a:hover{color:#5be8ff}
.footerActions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  justify-self:end;
}
.contactBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid rgba(91,232,255,.35);
  background:rgba(91,232,255,.08);
  color:#8ff2ff;
  font-weight:600;
  text-decoration:none;
}
button.contactBtn{
  font:inherit;
  cursor:pointer;
  appearance:none;
}
.contactBtn:hover{background:rgba(91,232,255,.14)}
.socialLinks{
  display:flex;
  align-items:center;
  gap:8px;
}
.socialLinks a{
  width:30px;
  height:30px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:#d8deea;
  text-decoration:none;
}
.socialLinks a:hover{
  background:rgba(91,232,255,.16);
  border-color:rgba(91,232,255,.35);
  color:#8ff2ff;
}
.socialLinks svg{
  width:16px;
  height:16px;
  fill:currentColor;
}
@media (max-width:720px){
  .footer{
    grid-template-columns:1fr;
    justify-items:center;
  }
  .footerBrandWrap{justify-self:center}
  .footerBrand{justify-self:center}
  .footerLinks{justify-self:center}
  .footerActions{
    justify-self:center;
    justify-content:center;
  }
}

@keyframes rise{
  from{transform:translateY(18px);opacity:0}
  to{transform:translateY(0);opacity:1}
}
@keyframes fade{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes tileIn{
  to{opacity:1;transform:translateY(0)}
}
@keyframes fabricNavShineSynced{
  0%{transform:translate3d(-130%,0,0) rotate(8deg);opacity:0}
  10%{opacity:.38}
  56%{opacity:.38}
  70%{opacity:0}
  100%{transform:translate3d(320%,0,0) rotate(8deg);opacity:0}
}

@media (prefers-reduced-motion: reduce){
  .fabricHeroPolished .fabricGlossStreak,
  .fabricHeroPolished .fabricGlossStreak--delayed,
  .fabricHeroPolished .fabricGlossStreak--third,
  .fabricHeroPolished .glossStreak.glossRibbon--extra,
  .fabricHeroPolished .fabricGlossShine2{
    animation:none !important;
    opacity:0 !important;
  }
  .topbarFabricMark{transition:none}
  .navpill::after{animation:none !important;opacity:0}
}
