/* ══════════════════════════════════════════════════════════════════
   STOBOX — Homepage v3 (page-specific overrides)
   Loads AFTER /css/v3-system.css. Only contains styles unique to
   the homepage (hero, ribbon, about, partners marquee, trust strip,
   problem grid, 7 layers, sectors/icp, technology, distribution,
   compass section, pricing journey, references, ecosystem stack,
   feature strip, ticker strip, clients grid).
   Tokens / nav / footer / disclaimer / atmosphere / dual-path CTA /
   card-hover system live in v3-system.css.
   ══════════════════════════════════════════════════════════════════ */

/* ── TICKER STRIP (top of page, above nav) ────────────────────── */
.tick{
  background: var(--ink);
  color: var(--bg);
  padding: 7px 0;
  border-bottom: 1px solid var(--rule);
  position: relative;
  z-index: 101;
  overflow: hidden;
}
.tick-track{
  display: inline-flex;
  gap: 48px;
  animation: tick 80s linear infinite;
  white-space: nowrap;
  width: max-content;
}
.tick-item{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .04em;
  color: var(--bg);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.tick-item::before{
  content: '●';
  color: var(--accent);
  font-size: 7px;
}
.tick-item .label{ color: rgba(255,255,255,0.50); text-transform: uppercase; letter-spacing: .12em; font-size: 10px }
.tick-item .val{ color: var(--bg); font-weight: 500 }
@keyframes tick{ to { transform: translateX(-50%) } }

/* ── HERO ─────────────────────────────────────────────────────── */
.hero{
  position: relative;
  padding: 0;
  overflow: hidden;
  /* nav (sticky, ~52px) + hero (incl. ribbon) = 100vh exactly */
  min-height: calc(100vh - 52px);
  width: 100%;
  display: flex;
  flex-direction: column;
  background: var(--bg-dark);
  color: var(--bg);
}
/* atmospheric grid behind text — white hairlines at low opacity */
.hero::before{
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  background-position: 0 0;
  mask-image: linear-gradient(to bottom, transparent, black 8%, black 75%, transparent);
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 8%, black 75%, transparent);
  pointer-events: none;
  z-index: 1;
}
/* radial vignette over the bg image, fades edges into the navy */
.hero::after{
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 80% at 50% 50%, transparent 30%, rgba(10,14,44,0.55) 70%, var(--bg-dark) 100%);
  pointer-events: none;
  z-index: 1;
}
/* atmospheric hero bg image */
.hero .sec-bg-img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.34;
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 0;
  display: block;
  animation: bg-drift-a 22s ease-in-out infinite;
}
/* Cobalt ambient glow — slow breathe pulse + cursor track via index.js */
@keyframes glow-breathe{
  0%, 100%{ opacity: 0.55; filter: blur(70px) }
  50%     { opacity: 1;    filter: blur(90px) }
}
@keyframes bg-drift{
  0%   { transform: translate3d(0,     0,    0) scale(1.05) }
  50%  { transform: translate3d(-1.5%, -1%, 0) scale(1.08) }
  100% { transform: translate3d(0,     0,    0) scale(1.05) }
}
.hero-glow{
  position: absolute;
  width: 70vw;
  height: 70vw;
  max-width: 900px;
  max-height: 900px;
  top: -10%;
  left: 35%;
  background:
    radial-gradient(circle at 50% 50%,
      rgba(99,91,255,0.45) 0%,
      rgba(99,91,255,0.20) 30%,
      rgba(99,91,255,0.05) 60%,
      transparent 80%);
  pointer-events: none;
  z-index: 1;
  animation: glow-breathe 7s ease-in-out infinite;
  transition: transform 1.2s cubic-bezier(.22,1,.36,1);
}
.hero-bg-img{ display: none }
.hero-grid{ display: none }

/* Single-column typographic content area, vertically centered */
.hero-content{
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: var(--maxw);
  width: 100%;
  margin: 0 auto;
  padding: 80px var(--gutter) 60px;
  position: relative;
  z-index: 2;
}

/* Full-bleed dark band; inner wrapper aligns with site grid */
.hero-ribbon{
  border-top: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: var(--bg-dark-2);
  position: relative;
  z-index: 3;
  padding: 0 var(--gutter);
}
.ribbon-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
}
.ribbon-item{
  padding: 26px 28px;
  border-right: 1px solid rgba(255,255,255,0.08);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ribbon-item:last-child{ border-right: 0 }
.ribbon-key{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.ribbon-val{
  font-family: var(--display);
  font-weight: 800;
  font-size: 36px;
  color: var(--bg);
  line-height: 1;
  letter-spacing: -0.022em;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.ribbon-unit{
  font-family: var(--mono);
  font-weight: 400;
  font-size: 10px;
  letter-spacing: .12em;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
}
@media (max-width: 1100px){
  .ribbon-inner{ grid-template-columns: repeat(3, 1fr) }
  .ribbon-item:nth-child(3n){ border-right: 0 }
  .ribbon-item:nth-child(-n+3){ border-bottom: 1px solid rgba(255,255,255,0.08) }
}
@media (max-width: 600px){
  .ribbon-inner{ grid-template-columns: repeat(2, 1fr) }
  .ribbon-item{ padding: 14px 16px }
  .ribbon-item:nth-child(2n){ border-right: 0 }
  .ribbon-item:nth-child(2n+1){ border-right: 1px solid rgba(255,255,255,0.08) }
  .ribbon-val{ font-size: 22px }
}
@media (max-width: 400px){
  .ribbon-inner{ grid-template-columns: 1fr }
  .ribbon-item{
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }
  .ribbon-item:last-child{ border-bottom: 0 }
  .ribbon-key{ white-space: normal; }
}

/* ──────────────────────────────────────────────────────────────────
   Overflow guard — grid items default to min-width: auto (= min-content),
   which can push their track wider than 1fr at narrow viewports and
   surface as horizontal page scroll. Force min-width: 0 on every known
   grid child to keep the track at 1fr no matter how wide the content
   wants to be.
   ────────────────────────────────────────────────────────────────── */
.ref-card,
.icp,
.tc,
.eco-col,
.dp,
.dist-card,
.pj-step,
.prob,
.tier,
.cti{
  min-width: 0;
}

.hero-meta{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px 24px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--ink-3);
  margin-bottom: 60px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--rule);
}
.hero-meta dt{ color: var(--ink-4); text-transform: uppercase; letter-spacing: .14em; font-size: 10px }
.hero-meta dd{ color: var(--ink-2); font-weight: 500 }
.hero-meta dd .accent{ color: var(--accent) }

.hero-eye{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent-hi);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
}
.hero-eye::before{
  content: '';
  width: 24px; height: 2px;
  background: var(--accent-hi);
}

.hero h1{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(44px, 6.4vw, 116px);
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--bg);
  font-variation-settings: "wdth" 100;
  margin-bottom: 24px;
  text-transform: uppercase;
}
.hero h1 .line{ display: block; overflow: hidden }
.hero h1 .line span{
  display: inline-block;
  transform: translateY(102%);
  animation: rise .9s var(--ease) forwards;
}
.hero h1 .line:nth-child(1) span{ animation-delay: .1s }
.hero h1 .line:nth-child(2) span{ animation-delay: .22s }
.hero h1 .line:nth-child(3) span{ animation-delay: .34s }
.hero h1 em{
  font-style: normal;
  color: var(--accent-hi);
  font-variation-settings: "wdth" 100;
}
@keyframes rise{ to { transform: none } }

.hero-sub{
  font-family: var(--body);
  font-weight: 400;
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  max-width: 64ch;
  margin-bottom: 32px;
  opacity: 0;
  animation: fade .5s var(--ease) .2s forwards;
}
.hero-sub strong{ color: var(--bg); font-weight: 600 }
/* Override .btn-g inside hero — needs white border + white text on dark */
.hero .btn-g{
  border-color: rgba(255,255,255,0.4);
  color: var(--bg);
}
.hero .btn-g:hover{ background: var(--bg); color: var(--ink); border-color: var(--bg) }
@keyframes fade{ to { opacity: 1 } }

.hero-btns{
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  opacity: 0;
  animation: fade .5s var(--ease) .35s forwards;
}
@media (max-width: 560px){
  .hero-btns{ width: 100%; }
  .hero-btns .btn-p,
  .hero-btns .btn-g{
    flex: 1 1 auto;
    min-width: 0;
    text-align: center;
    justify-content: center;
    white-space: nowrap;
  }
}

/* Hero data block (right side) — Bloomberg-style (legacy) */
.hero-data{
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  padding: 16px 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  opacity: 1;
  align-self: end;
}
.hero-data-head{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-4);
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 4px;
  display: flex;
  justify-content: space-between;
}
.hero-data-row{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  padding: 9px 0;
  border-bottom: 1px solid var(--rule-soft);
  gap: 16px;
}
.hero-data-row:last-child{ border-bottom: 0 }
.hero-data-key{
  font-family: var(--mono);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: .08em;
  color: var(--ink-2);
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.hero-data-key::before{
  content: '';
  width: 5px;
  height: 5px;
  background: var(--accent);
  border-radius: 50%;
  flex-shrink: 0;
}
.hero-data-val{
  font-family: var(--display);
  font-weight: 700;
  font-size: 26px;
  color: var(--ink);
  line-height: 1;
  letter-spacing: -0.01em;
}
.hero-data-val .unit{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 400;
  color: var(--ink-3);
  margin-left: 6px;
  letter-spacing: .04em;
}

@media (max-width: 1024px){
  .hero{ min-height: auto }
  .hero-content{ padding: 60px var(--gutter) 50px }
}

/* ── HERO HEADLINE — keep "EVERY LAYER MANAGED." on one line ─── */
@media (min-width: 768px){
  .hero h1 .line span{ white-space: nowrap }
}

/* ── FEATURE STRIP ────────────────────────────────────────────── */
.feat-strip{
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background: var(--bg);
}
.feat-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.feat-item{
  padding: 26px 28px;
  border-right: 1px solid var(--rule);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
  position: relative;
  transition: background var(--t-base) var(--ease);
}
.feat-item:last-child{ border-right: 0 }
.feat-item:hover{ background: var(--bg-2) }
.feat-icon{
  width: 32px; height: 32px;
  border: 1px solid var(--rule);
  border-radius: 1px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  flex-shrink: 0;
}
.feat-text{ min-width: 0 }
.feat-title{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
  margin-bottom: 2px;
}
.feat-sub{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

@media (max-width: 920px){
  .feat-inner{ grid-template-columns: repeat(2, 1fr) }
  .feat-item:nth-child(2){ border-right: 0 }
  .feat-item:nth-child(1), .feat-item:nth-child(2){ border-bottom: 1px solid var(--rule) }
}

/* ── ABOUT ────────────────────────────────────────────────────── */
.about{
  padding: 120px var(--gutter);
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.about-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 80px;
  align-items: start;
}
.about-eye{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 28px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.about-eye::before{ content: '§01'; color: var(--ink-4); letter-spacing: .04em }
.about-headline{
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(40px, 5vw, 80px);
  line-height: 0.96;
  letter-spacing: -0.018em;
  color: var(--ink);
  text-transform: uppercase;
  position: static;
}
.about-headline em{
  font-style: normal;
  color: var(--accent);
}
.about-list{
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--rule);
}
.about-item{
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 18px;
  padding: 28px 28px;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
  transition: background var(--t-base);
}
.about-item:hover{ background: var(--bg-2) }
.about-num{
  font-family: var(--display);
  font-weight: 700;
  font-size: 48px;
  color: var(--accent);
  line-height: 1;
  letter-spacing: -0.02em;
}
.about-text{}
.about-title{
  font-family: var(--body);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 8px;
  letter-spacing: -0.01em;
  line-height: 1.35;
}
.about-desc{
  font-family: var(--body);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--ink-2);
}

@media (max-width: 920px){
  .about{ padding: 70px var(--gutter) }
  .about-inner{ grid-template-columns: 1fr; gap: 40px }
  .about-headline{ position: static }
  .about-num{ font-size: 36px }
}

/* ── LATEST WRITING — horizontal blog rail ────────────────────── */
/* Lives at the bottom of the page, between the dark final CTA and
   the dark footer — slightly darker than the white sections above
   so it reads as its own band. */
.home-blog{
  padding: 100px 0 110px;
  background: var(--bg-3);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.home-blog-track .bl-card{ background: var(--bg); }
/* Head row: eyebrow + headline. Sits inside the centered max-width
   band so the first card below aligns with the headline's left edge.
   No top-right "see all" link — the dark View-more card at the end
   of the rail is the canonical CTA. */
.home-blog-head{
  max-width: var(--maxw);
  margin: 0 auto 44px;
  padding: 0 var(--gutter);
}
.home-blog-head .eye{ margin-bottom: 14px; }
/* Override the global .stitle — drop the 22ch cap so the headline
   reads on one line at desktop, plus a smaller scale for the rail. */
.home-blog-head .stitle{
  font-size: clamp(28px, 2.8vw, 44px);
  line-height: 1.04;
  letter-spacing: -0.018em;
  max-width: none;
  margin: 0;
}

/* Rail: full-bleed scroll viewport. The inner track pads itself to the
   centered max-width band on both sides, so card 1 aligns with the head
   above and the last card has matching breathing room on the right. */
.home-blog-rail{
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.home-blog-rail::-webkit-scrollbar{ display: none; }
.home-blog-rail:focus-visible{ outline: 2px solid var(--accent); outline-offset: 4px; }
.home-blog-track{
  display: flex;
  gap: 24px;
  /* 100vw (not 100%) keeps the calc stable inside width: max-content */
  padding-left: max(var(--gutter), calc((100vw - var(--maxw)) / 2 + var(--gutter)));
  padding-right: max(var(--gutter), calc((100vw - var(--maxw)) / 2 + var(--gutter)));
  padding-top: 6px;
  padding-bottom: 28px;
  width: max-content;
  scroll-snap-type: x mandatory;
}
/* 4 visible at desktop, computed from the visible band (min of viewport
   and maxw) minus two gutters and three gaps. */
.home-blog-track .bl-card{
  flex: 0 0 calc((min(100vw, var(--maxw)) - 2 * var(--gutter) - 3 * 24px) / 4);
  scroll-snap-align: start;
}
.home-blog-track .bl-card h3{ font-size: 17px; line-height: 1.12; }
.home-blog-track .bl-card-body{ padding: 20px 22px 22px; gap: 10px; }

/* "View more on the blog" — terminal CTA card matching rail card width */
.home-blog-more{
  flex: 0 0 calc((min(100vw, var(--maxw)) - 2 * var(--gutter) - 3 * 24px) / 4);
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: var(--bg-dark);
  color: var(--bg);
  border: 1px solid var(--bg-dark);
  border-radius: 1px;
  padding: 28px 26px;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: background var(--t-base), transform .45s var(--ease), box-shadow .45s var(--ease);
}
.home-blog-more::before{
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 20%, rgba(99,91,255,0.32) 0%, transparent 55%);
  pointer-events: none;
}
.home-blog-more:hover{
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(99,91,255,0.28);
  background: var(--bg-dark-2);
}
.home-blog-more-eye{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent-hi);
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.home-blog-more-eye::before{
  content: '';
  width: 24px; height: 2px;
  background: var(--accent-hi);
}
.home-blog-more-title{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(28px, 2.4vw, 36px);
  line-height: 0.96;
  letter-spacing: -0.022em;
  text-transform: uppercase;
  color: var(--bg);
  position: relative;
  z-index: 1;
  margin-top: auto;
}
.home-blog-more-arrow{
  font-family: var(--body);
  font-size: 28px;
  line-height: 1;
  color: var(--accent-hi);
  position: relative;
  z-index: 1;
  margin-top: 16px;
  transition: transform var(--t-base) var(--ease);
}
.home-blog-more:hover .home-blog-more-arrow{ transform: translateX(6px); }

@media (max-width: 1280px){
  .home-blog-track .bl-card{
    flex-basis: calc((min(100vw, var(--maxw)) - 2 * var(--gutter) - 2 * 24px) / 3);
  }
}
@media (max-width: 900px){
  .home-blog{ padding: 72px 0 80px; }
  .home-blog-head{ margin-bottom: 28px; }
  .home-blog-track .bl-card{
    flex-basis: calc(100vw - 2 * var(--gutter) - 64px);
  }
}
@media (max-width: 600px){
  .home-blog-track .bl-card{ flex-basis: 78vw; }
}

/* ── PARTNERS — Marquee ───────────────────────────────────────── */
.partners{
  padding: 50px 0;
  background: var(--bg-2);
  border-bottom: 1px solid var(--rule);
  overflow: hidden;
}
.partners-inner{ position: relative; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter) }
.p-lbl{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
}
.p-lbl::before, .p-lbl::after{
  content: '';
  flex: 1;
  height: 1px;
  background: var(--rule);
}
.p-marquee{
  position: relative;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, black 6%, black 94%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 6%, black 94%, transparent);
}
.p-track{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 72px;
  animation: marquee 60s linear infinite;
  width: max-content;
}
@keyframes marquee{ to { transform: translateX(-50%) } }
.plogo{ flex: 0 0 auto }
.plogo img{
  height: 32px;
  width: auto;
  opacity: .55;
  filter: grayscale(1);
  transition: opacity var(--t-base) var(--ease), filter var(--t-base);
}
.plogo img:hover{ opacity: 1; filter: none }

/* ── TRUST STRIP ──────────────────────────────────────────────── */
.trust{
  padding: 60px var(--gutter);
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
}
.trust-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr) 1fr;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.tstat{
  padding: 36px 28px;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
}
.tstat:first-child{ padding-left: 0 }
.tval{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(56px, 6vw, 96px);
  line-height: 0.92;
  color: var(--ink);
  margin-bottom: 12px;
  letter-spacing: -0.025em;
}
.tlbl{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: auto;
}
.tdiv{ display: none }
.trust-tags{
  padding: 36px 0 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
}
.ttag{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  border: 1px solid var(--rule);
  padding: 5px 10px;
  border-radius: 1px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.ttag::before{
  content: '';
  width: 6px; height: 6px;
  background: var(--accent);
  display: inline-block;
}

@media (max-width: 920px){
  .trust{ padding: 60px var(--gutter) }
  .trust-inner{ grid-template-columns: 1fr 1fr }
  .tstat{ padding: 24px 16px; border-bottom: 1px solid var(--rule) }
  .tstat:nth-child(2){ border-right: 0 }
  .trust-tags{ grid-column: 1 / -1; padding: 24px 0; flex-direction: row; flex-wrap: wrap }
}

/* ── PROBLEM — three failures ────────────────────────────────── */
.prob-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 70px;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.prob{
  padding: 40px 28px 40px 0;
  border-right: 1px solid var(--rule);
  position: relative;
  transition: background var(--t-base);
}
.prob:nth-child(2), .prob:nth-child(3){ padding-left: 28px }
.prob:last-child{ border-right: 0 }
.prob:hover{ background: var(--bg) }
.sec.alt .prob:hover{ background: var(--bg-3) }
.prob-n{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  color: var(--accent);
  margin-bottom: 20px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
}
.prob-n::before{
  content: '';
  width: 12px; height: 2px;
  background: var(--accent);
}
.prob-t{
  font-family: var(--display);
  font-weight: 700;
  font-size: 24px;
  line-height: 1.05;
  color: var(--ink);
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: -0.012em;
}
.prob-b{
  font-family: var(--body);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.65;
  color: var(--ink-2);
}
.prob-b strong{ color: var(--ink); font-weight: 600 }

@media (max-width: 920px){
  .prob-grid{ grid-template-columns: 1fr }
  .prob, .prob:nth-child(2), .prob:nth-child(3){
    padding: 28px 0;
    border-right: 0;
    border-bottom: 1px solid var(--rule);
  }
  .prob:last-child{ border-bottom: 0 }
}

/* ── 7 LAYERS ─────────────────────────────────────────────────── */
.layers-wrap{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: 70px;
  border: 1px solid rgba(255,255,255,0.12);
  background: var(--bg-dark-2);
  position: relative;
  z-index: 2;
}

.layer-list{
  display: flex;
  flex-direction: column;
  background: var(--bg-dark-2);
  border-right: 1px solid rgba(255,255,255,0.10);
}
.li{
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 22px 24px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
  position: relative;
}
.li:last-child{ border-bottom: 0 }
.li::before{
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--accent);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--t-base) var(--ease);
}
.li.active::before{ transform: none }
.li:hover{ background: rgba(255,255,255,0.05) }
.li.active{ background: rgba(99,91,255,0.18) }
.li-n{
  font-family: var(--display);
  font-weight: 700;
  font-size: 28px;
  color: rgba(255,255,255,0.55);
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.li.active .li-n{ color: var(--accent-hi) }
.li-body{ min-width: 0 }
.li-name{
  font-family: var(--body);
  font-size: 15px;
  font-weight: 600;
  color: var(--bg);
  margin-bottom: 4px;
  letter-spacing: -0.005em;
}
.li-sub{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.70);
}
.lbadge{
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 9px;
  border: 1px solid rgba(255,255,255,0.35);
  color: rgba(255,255,255,0.9);
  border-radius: 1px;
  white-space: nowrap;
}
.lbadge.own{
  background: var(--accent);
  color: #ffffff;
  border-color: var(--accent);
}
.lbadge.par{
  color: rgba(255,255,255,0.85);
  border-color: rgba(255,255,255,0.35);
}

.layer-panel{
  background: var(--bg);
  color: var(--ink);
  padding: 40px 36px;
  position: sticky;
  top: 80px;
  min-height: 480px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
  border-left: 1px solid rgba(255,255,255,0.10);
}
.lp-num{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.lp-num::before{
  content: '';
  width: 16px; height: 2px;
  background: var(--accent);
}
.lp-title{
  font-family: var(--display);
  font-weight: 700;
  font-size: 38px;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: -0.018em;
}
.lp-desc{
  font-family: var(--body);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.65;
  color: var(--ink-2);
  margin-bottom: 24px;
}
.lp-items{ margin-bottom: 24px; border-top: 1px solid var(--rule) }
.lp-item{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--ink-2);
  padding: 10px 0 10px 22px;
  border-bottom: 1px solid var(--rule-soft);
  position: relative;
}
.lp-item::before{
  content: '+';
  position: absolute;
  left: 0; top: 9px;
  color: var(--accent);
  font-weight: 600;
  font-size: 14px;
  font-family: var(--mono);
}
.lp-item:last-child{ border-bottom: 0 }
.lp-tools-lbl{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
}
.lp-pills{ display: flex; flex-wrap: wrap; gap: 6px }
.lp-pill{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .08em;
  padding: 4px 9px;
  border: 1px solid var(--rule-hard);
  color: var(--ink);
  text-transform: uppercase;
  border-radius: 1px;
  background: var(--bg-2);
}

@media (max-width: 920px){
  .layers-wrap{ grid-template-columns: 1fr }
  .layer-list{ border-right: 0 }
  .layer-panel{ position: static; padding: 28px 22px; min-height: 0; border-left: 0; border-top: 1px solid var(--ink-3) }
}

/* ── SECTORS ──────────────────────────────────────────────────── */
.icp-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 70px;
  border: 1px solid var(--rule);
  background: var(--ink);
  gap: 1px;
}
.icp{
  background: var(--bg);
  padding: 50px 40px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: background var(--t-base);
  min-height: 360px;
}
.sec.alt .icp{ background: var(--bg-2) }
.icp:hover{ background: var(--bg) }
.sec.alt .icp:hover{ background: var(--bg) }
.icp-icon{
  width: 36px; height: 36px;
  border: 1px solid var(--rule);
  border-radius: 1px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  margin-bottom: 28px;
}
.icp-hook{
  font-family: var(--body);
  font-weight: 500;
  font-style: italic;
  font-size: 16px;
  line-height: 1.45;
  color: var(--ink-2);
  margin-bottom: 22px;
  letter-spacing: -0.005em;
  padding-left: 16px;
  border-left: 3px solid var(--accent);
}
.icp-name{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
}
.icp-sector{
  font-family: var(--display);
  font-size: clamp(28px, 2.5vw, 38px);
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 20px;
  text-transform: uppercase;
  line-height: 0.95;
  letter-spacing: -0.022em;
}
.icp-desc{
  font-family: var(--body);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--ink-2);
  margin-bottom: auto;
}
.icp-cta{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  margin-top: 32px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-top: 1px solid var(--rule);
  padding-top: 16px;
  transition: color var(--t-fast), gap var(--t-base) var(--ease);
}
.icp-cta::after{ content: '→' }
.icp:hover .icp-cta{ color: var(--accent); gap: 14px }

@media (max-width: 920px){
  .icp-grid{ grid-template-columns: 1fr }
  .icp{ padding: 32px 24px; min-height: 0 }
}

/* ── TECHNOLOGY ───────────────────────────────────────────────── */
.tech-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-top: 70px;
  border: 1px solid rgba(255,255,255,0.12);
  gap: 1px;
  background: rgba(255,255,255,0.10);
  position: relative;
  z-index: 2;
}
/* Stobox Compass card — featured product treatment */
.tc.tc-compass{
  background: #1c1c5e;
  box-shadow:
    inset 0 4px 0 var(--accent),
    0 0 0 1px rgba(165,180,252,0.18);
}
.tc.tc-compass .tc-lbl{ color: var(--accent-hi) }
.tc.tc-compass .tc-link{ color: var(--accent-hi) }
.tc.tc-compass:hover{
  background: #24249a;
  box-shadow:
    inset 0 4px 0 var(--accent),
    0 24px 60px -22px rgba(99,91,255,0.55),
    0 0 0 1px rgba(165,180,252,0.30);
}
@media (max-width: 1100px){
  .tech-grid{ grid-template-columns: repeat(2, 1fr) }
}
@media (max-width: 600px){
  .tech-grid{ grid-template-columns: 1fr }
}
.tc{
  background: var(--bg-dark-2);
  padding: 44px 32px;
  display: flex;
  flex-direction: column;
  transition: background var(--t-base);
  position: relative;
  color: var(--bg);
}
.tc:hover{ background: var(--bg-dark) }
.tc-lbl{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent-hi);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.tc-lbl::before{
  content: '';
  width: 16px; height: 2px;
  background: var(--accent-hi);
}
.tc-name{
  font-family: var(--display);
  font-weight: 800;
  font-size: 44px;
  color: var(--bg);
  margin-bottom: 20px;
  line-height: 0.95;
  letter-spacing: -0.022em;
  text-transform: uppercase;
}
.tc-out{
  font-family: var(--body);
  font-weight: 600;
  font-size: 16px;
  line-height: 1.35;
  color: var(--accent-hi);
  margin-bottom: 18px;
  letter-spacing: -0.005em;
}
.tc-desc{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.65;
  color: rgba(255,255,255,0.78);
  margin-bottom: auto;
}
.tc-link{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  color: var(--bg);
  margin-top: 30px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-top: 1px solid rgba(255,255,255,0.12);
  padding-top: 16px;
  transition: color var(--t-fast), gap var(--t-base) var(--ease);
}
.tc-link::after{ content: '→' }
.tc:hover .tc-link{ color: var(--accent-hi); gap: 14px }

@media (max-width: 920px){
  .tech-grid{ grid-template-columns: 1fr }
  .tc{ padding: 32px 22px }
}

/* ── DISTRIBUTION ─────────────────────────────────────────────── */
.dist-grid{
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 1px;
  margin-top: 70px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.dist-partners{
  background: var(--bg);
  display: flex;
  flex-direction: column;
}
.dp{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  padding: 24px 28px;
  border-bottom: 1px solid var(--rule);
  align-items: start;
  transition: background var(--t-fast);
}
.dp:hover{ background: var(--blue-ice) }
.dp:last-child{ border-bottom: 0 }
.dp-name{
  font-family: var(--display);
  font-weight: 700;
  font-size: 24px;
  color: var(--ink);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: -0.015em;
}
.dp-desc{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--ink-2);
}
.dp-tag{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent);
  background: var(--accent-bg);
  padding: 4px 9px;
  border-radius: 1px;
  white-space: nowrap;
}

.dist-card{
  background: var(--blue-ice);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
}
.dist-card h3{
  font-family: var(--display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  color: var(--ink);
  margin-bottom: 18px;
  text-transform: uppercase;
  letter-spacing: -0.018em;
}
.dist-card p{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.65;
  color: var(--ink-2);
  margin-bottom: 16px;
}
.dist-card .btn-p{
  margin-top: auto;
  align-self: flex-start;
  font-size: 13px;
}
.dist-note{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 20px !important;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
}

@media (max-width: 920px){
  .dist-grid{ grid-template-columns: 1fr }
  .dp{ grid-template-columns: 1fr; padding: 22px }
  .dp-tag{ justify-self: start; margin-top: 6px }
  .dist-card{ padding: 32px 22px }
}

/* ── PRICING — CHAPTERS / TABLE ───────────────────────────────── */
.pricing-journey{
  margin-top: 70px;
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--rule);
}
.pj-step{
  padding: 50px 28px;
  border-bottom: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 40px;
  align-items: start;
  transition: background var(--t-base);
}

.pj-num-box{
  font-family: var(--display);
  text-align: left;
}
.pj-nv{
  font-weight: 800;
  font-size: 64px;
  line-height: 0.9;
  color: var(--accent);
  letter-spacing: -0.03em;
}
.pj-nl{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 8px;
}
.pj-info-wrap{ padding-left: 40px; border-left: 1px solid var(--rule) }
.pj-info{ margin-bottom: 18px }
.pj-info h3{
  font-family: var(--display);
  font-weight: 700;
  font-size: 36px;
  color: var(--ink);
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: -0.018em;
  line-height: 1;
}
.pj-meta{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 400;
  letter-spacing: .04em;
  color: var(--ink-3);
  line-height: 1.6;
  text-transform: uppercase;
}
.pj-price{
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin: 24px 0 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--rule);
}
.pj-pv{
  font-family: var(--display);
  font-weight: 800;
  font-size: 64px;
  color: var(--ink);
  line-height: 0.95;
  letter-spacing: -0.025em;
}
.pj-pn{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--ink-3);
  text-transform: uppercase;
}

.pj-body{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-bottom: 32px;
  border-top: 1px solid var(--rule);
  padding-top: 28px;
}
.pj-col h4{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  align-items: center;
  gap: 8px;
}
.pj-col h4::before{
  content: '';
  width: 12px; height: 2px;
  background: var(--accent);
}
.pj-col ul{ list-style: none }
.pj-col li{
  font-family: var(--body);
  font-size: 13.5px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--ink-2);
  padding: 9px 0 9px 22px;
  position: relative;
  border-bottom: 1px solid var(--rule-soft);
}
.pj-col li::before{
  content: '+';
  position: absolute;
  left: 0; top: 8px;
  color: var(--accent);
  font-weight: 600;
  font-family: var(--mono);
  font-size: 14px;
}
.pj-col li:last-child{ border-bottom: 0 }
.pj-col li a{ color: var(--accent); border-bottom: 1px solid var(--accent-bd); font-weight: 500 }
.pj-col li a:hover{ color: var(--accent-lo); border-bottom-color: var(--accent-lo) }

.pj-cta-row{
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.pj-btn{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.005em;
  padding: 12px 20px;
  border-radius: 1px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: background var(--t-base) var(--ease), border-color var(--t-base), color var(--t-base);
  border: 1px solid;
}
.pj-btn::after{ content: '→' }
.pj-btn.primary{ background: var(--accent); border-color: var(--accent); color: var(--bg) }
.pj-btn.primary:hover{ background: var(--accent-lo); border-color: var(--accent-lo) }
.pj-btn.soft{ background: transparent; border-color: var(--ink); color: var(--ink) }
.pj-btn.soft:hover{ background: var(--ink); color: var(--bg) }
.pj-link{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-3);
  border-bottom: 1px solid var(--rule);
  padding-bottom: 4px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.pj-link:hover{ color: var(--accent); border-color: var(--accent) }

@media (max-width: 920px){
  .pj-step{ grid-template-columns: 1fr; gap: 16px }
  .pj-info-wrap{ padding-left: 0; border-left: 0 }
  .pj-body{ grid-template-columns: 1fr; gap: 24px }
}

.pricing-note{
  margin-top: 50px;
  padding: 30px 32px;
  background: var(--ink);
  color: var(--bg);
  border-left: 3px solid var(--accent);
  font-family: var(--body);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;
}
.pricing-note strong{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent-hi);
  display: block;
  margin-bottom: 10px;
  font-weight: 500;
}
.pricing-note a{
  color: var(--accent-hi);
  border-bottom: 1px solid var(--accent-hi);
  font-weight: 500;
}

/* ── PRICING — Step 01 emphasis is the cobalt $9,500 only ─────── */
.pj-step:first-child .pj-pv{ color: var(--accent) }

/* ── PRICING — Step 02 typical range note ─────────────────────── */
.pj-range{
  font-family: var(--body);
  font-style: italic;
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0 0 14px;
}
.pj-range span{
  font-style: normal;
  font-weight: 600;
  color: var(--accent);
}
.pj-range sup{
  font-style: normal;
  font-size: 0.7em;
  color: var(--accent);
  margin-left: 1px;
}
.pj-range-note{
  font-family: var(--body);
  font-style: italic;
  font-size: 11.5px;
  line-height: 1.55;
  color: var(--ink-3);
  margin-bottom: 28px;
  padding: 10px 14px;
  border-left: 2px solid var(--rule);
  background: var(--bg-2);
}

/* ── CLIENTS ──────────────────────────────────────────────────── */
.clients{
  padding: 80px var(--gutter);
  background: var(--bg-2);
  border-bottom: 1px solid var(--rule);
}
.clients-inner{ max-width: var(--maxw); margin: 0 auto }
.clients-lbl{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 40px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.clients-lbl::before, .clients-lbl::after{
  content: '';
  flex: 1;
  height: 1px;
  background: var(--rule);
}
.clients-grid{
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border: 1px solid var(--rule);
  background: var(--rule);
  gap: 1px;
}
.clogo{
  background: var(--bg-2);
  padding: 28px 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-base);
}
.clogo:hover{ background: var(--bg) }
.clogo img{
  height: 26px;
  opacity: .55;
  filter: grayscale(1);
  transition: opacity var(--t-base), filter var(--t-base);
}
.clogo:hover img{ opacity: 1; filter: none }

@media (max-width: 920px){
  .clients-grid{ grid-template-columns: repeat(3, 1fr) }
}

/* ── TESTIMONIALS / CLIENT OUTCOMES ────────────────────────────── */
.testi-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 70px;
  border: 1px solid var(--rule);
  background: var(--rule);
  gap: 1px;
}
.testi-card{
  background: var(--bg);
  padding: 36px 30px 28px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: background var(--t-base);
}
.testi-card:hover{ background: var(--blue-ice) }
.testi-card::before{
  content: '\201C';
  position: absolute;
  top: 4px;
  right: 22px;
  font-family: var(--display);
  font-size: 84px;
  font-weight: 800;
  color: var(--accent);
  opacity: 0.18;
  line-height: 1;
}
.testi-asset{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 22px;
  position: relative;
  z-index: 1;
}
.testi-quote{
  font-family: var(--display);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.2;
  color: var(--ink);
  letter-spacing: -0.012em;
  text-transform: uppercase;
  margin-bottom: 28px;
  flex: 1;
  position: relative;
  z-index: 1;
}
.testi-attr{
  border-top: 1px solid var(--rule);
  padding-top: 18px;
  position: relative;
  z-index: 1;
}
.testi-name{
  font-family: var(--body);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 2px;
}
.testi-role{
  font-family: var(--body);
  font-size: 12px;
  color: var(--ink-3);
}
@media (max-width: 920px){ .testi-grid{ grid-template-columns: 1fr } }

/* ── SELECTED REFERENCES ──────────────────────────────────────── */
.ref-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-top: 60px;
  border: 1px solid var(--rule);
  background: var(--rule);
  gap: 1px;
}
.ref-card{
  background: var(--bg);
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  transition: background var(--t-base);
}
.sec.alt .ref-card{ background: var(--bg-2) }
.ref-card:hover, .sec.alt .ref-card:hover{ background: var(--blue-ice) }
.ref-asset{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
}
.ref-amount{
  font-family: var(--display);
  font-weight: 800;
  font-size: 56px;
  color: var(--ink);
  line-height: 0.9;
  letter-spacing: -0.025em;
  margin-bottom: 18px;
}
.ref-meta{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--ink-2);
  margin-top: auto;
}
@media (max-width: 920px){ .ref-grid{ grid-template-columns: repeat(2, 1fr) } }

/* ── STOBOX COMPASS — product CTA section ────────────────────── */
.compass-grid{
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  margin-top: 50px;
  align-items: start;
}
.compass-features{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 28px;
  margin: 28px 0 32px;
  padding: 24px 0;
  border-top: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.cf{
  font-family: var(--body);
  font-size: 13.5px;
  font-weight: 500;
  line-height: 1.45;
  color: rgba(255,255,255,0.85);
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
}
.cf-icon{
  color: var(--accent-hi);
  font-family: var(--mono);
  font-weight: 600;
  font-size: 14px;
  flex-shrink: 0;
}
.compass-cta-row{
  display: inline-flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.compass-link{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  border-bottom: 1px solid rgba(255,255,255,0.20);
  padding-bottom: 4px;
  transition: color var(--t-fast), border-color var(--t-fast);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.compass-link::after{ content: '→' }
.compass-link:hover{ color: var(--accent-hi); border-color: var(--accent-hi) }

.compass-tiers{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.10);
  position: relative;
  z-index: 2;
}
.cti{
  background: var(--bg-dark-2);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: background var(--t-base);
}
.cti:hover{ background: var(--bg-dark) }
.cti.popular{
  background: #1c1c5e;
  outline: 1px solid var(--accent);
  outline-offset: -1px;
  z-index: 1;
}
.cti.popular:hover{ background: #24249a }
.cti-badge{
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent-hi);
  margin-bottom: 10px;
}
.cti-name{
  font-family: var(--display);
  font-weight: 700;
  font-size: 26px;
  color: var(--bg);
  letter-spacing: -0.018em;
  margin-bottom: 14px;
  text-transform: uppercase;
  line-height: 1;
}
.cti-price{
  font-family: var(--display);
  font-weight: 800;
  font-size: 42px;
  line-height: 1;
  color: var(--accent-hi);
  letter-spacing: -0.025em;
  margin-bottom: 12px;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.cti-price span{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  color: rgba(255,255,255,0.55);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.cti-meta{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-top: auto;
}

@media (max-width: 1024px){
  .compass-grid{ grid-template-columns: 1fr; gap: 36px }
}
@media (max-width: 560px){
  .compass-features{ grid-template-columns: 1fr }
  .compass-tiers{ grid-template-columns: 1fr }
}

/* ── ECOSYSTEM — categorized partner stack ────────────────────── */
.ecosystem-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin-top: 60px;
  border: 1px solid var(--rule);
  background: var(--rule);
}
.eco-col{
  background: var(--bg);
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
}
.eco-cat{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eco-cat::before{
  content: '';
  width: 16px; height: 2px;
  background: var(--accent);
}
.eco-cat-sub{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--ink-3);
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--rule);
}
.eco-list{ display: flex; flex-direction: column }
.eco-item{
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 20px;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid var(--rule-soft);
  transition: padding-left var(--t-fast) var(--ease);
  text-decoration: none;
}
.eco-item:last-child{ border-bottom: 0 }
.eco-item:hover{ padding-left: 6px }
.eco-item img{
  height: 56px;
  width: 160px;
  object-fit: contain;
  object-position: left center;
  filter: grayscale(1);
  opacity: .78;
  transition: opacity var(--t-base) var(--ease), filter var(--t-base);
}
.eco-item:hover img{ opacity: 1; filter: none }
.eco-meta{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
  line-height: 1.45;
}
.eco-item:hover .eco-meta{ color: var(--ink) }
@media (max-width: 1200px){
  .eco-item{ grid-template-columns: 130px 1fr; gap: 16px; }
  .eco-item img{ height: 46px; width: 130px; }
}

@media (max-width: 920px){
  .ecosystem-grid{ grid-template-columns: 1fr }
  .eco-col{ padding: 28px 22px }
}

/* ── HOMEPAGE-only reduced-motion overrides ────────────────────── */
@media (prefers-reduced-motion: reduce){
  .hero h1 .line span, .hero-sub, .hero-btns, .hero-data{
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }
  .tick-track, .p-track{ animation: none !important }
  .hero .sec-bg-img{ animation: bg-drift-a 60s ease-in-out infinite !important }
  .hero-glow{ animation: glow-breathe 20s ease-in-out infinite !important }
}

/* ══════════════════════════════════════════════════════════════════
   COMPASS MINI-SCREENER — homepage interactive preview
   3-question micro-diagnostic before the existing dark Compass CTA.
   Visible result + per-verdict UTMs on the deep-link to /compass.
   ══════════════════════════════════════════════════════════════════ */
.cms-shell{
  margin-top: 60px;
  border: 1px solid var(--rule);
  background: var(--bg);
  position: relative;
  min-height: 360px;
}
.cms-step,
.cms-result{
  padding: 56px 56px 32px;
  display: block;
}
.cms-step-eye{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
}
.cms-step-q{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.022em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 32px;
  max-width: 22ch;
}
.cms-choices{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.cms-choice{
  background: transparent;
  border: 1px solid var(--rule-hard);
  padding: 14px 22px;
  font-family: var(--body);
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--ink);
  cursor: pointer;
  border-radius: 1px;
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.cms-choice:hover{
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-bg);
}
.cms-choice.is-selected{
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg);
  transform: translateY(-1px);
}

/* ── Result card ──────────────────────────────────────────────── */
.cms-result-eye{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}
.cms-result-band{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  border: 1px solid;
  margin-bottom: 18px;
  border-radius: 1px;
}
.cms-result-band[data-band="ready"]{
  color: #047857;
  border-color: rgba(4,120,87,0.30);
  background: rgba(4,120,87,0.07);
}
.cms-result-band[data-band="close-with-gaps"]{
  color: #b45309;
  border-color: rgba(180,83,9,0.30);
  background: rgba(180,83,9,0.07);
}
.cms-result-band[data-band="not-ready"]{
  color: #be123c;
  border-color: rgba(190,18,60,0.30);
  background: rgba(190,18,60,0.07);
}
.cms-result-title{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.022em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 14px;
  max-width: 24ch;
}
.cms-result-desc{
  font-family: var(--body);
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--ink-2);
  max-width: 64ch;
  margin-bottom: 26px;
}
.cms-result-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  margin-bottom: 26px;
}
.cms-result-cell{
  background: var(--bg);
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cms-result-label{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.cms-result-value{
  font-family: var(--display);
  font-weight: 800;
  font-size: 17px;
  line-height: 1.2;
  letter-spacing: -0.012em;
  color: var(--ink);
  text-transform: uppercase;
}
.cms-result-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}
.cms-result-restart{
  background: transparent;
  border: 0;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  padding: 8px 4px;
  border-bottom: 1px solid var(--rule-hard);
  transition: color var(--t-fast), border-color var(--t-fast);
}
.cms-result-restart:hover{ color: var(--accent); border-color: var(--accent) }
.cms-result-foot{
  font-family: var(--body);
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--ink-3);
  font-style: italic;
  margin-top: 22px;
  max-width: 64ch;
}

/* Progress bar at the bottom of the shell */
.cms-progress{
  position: relative;
  height: 4px;
  background: var(--rule-soft);
  border-top: 1px solid var(--rule);
}
.cms-progress-track{ position: absolute; inset: 0 }
.cms-progress-bar{
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--accent);
  width: 33.33%;
  transition: width var(--t-base) var(--ease);
}

@media (max-width: 760px){
  .cms-step, .cms-result{ padding: 36px 24px 24px }
  .cms-result-row{ grid-template-columns: 1fr }
  .cms-choice{ padding: 12px 18px; font-size: 13.5px }
}
