/* =========================================================================
   SPS HUB — bespoke industrial design system
   Type: Saira Condensed (display) · Archivo (sub) · JetBrains Mono (labels)
         · Inter (body).  Dark, editorial, motion-led.
   All colors flow from --accent / --accent2 which are swapped per company.
   ========================================================================= */

#sps-hub-root{
  --bg:#070809; --bg2:#0d0f13; --panel:#111419; --panel2:#161a21;
  --line:rgba(255,255,255,.09); --line2:rgba(255,255,255,.16);
  --text:#f1f4f8; --muted:#8a93a2; --muted2:#aeb6c2;
  --accent:#2f7fd1; --accent2:#7bb6f6;
  --display:'Saira Condensed',Arial Narrow,sans-serif;
  --sub:'Archivo',system-ui,Arial,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --body:'Inter',system-ui,Arial,sans-serif;
  --maxw:1240px; --ease:cubic-bezier(.2,.7,.2,1);

  position:relative; color:var(--text); background:var(--bg);
  font-family:var(--body); line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow:hidden; isolation:isolate;
}
:where(#sps-hub-root *){box-sizing:border-box;margin:0;padding:0}
#sps-hub-root img{display:block;max-width:100%}
#sps-hub-root button{font:inherit;cursor:pointer;color:inherit;background:none;border:none}
#sps-hub-root ::selection{background:var(--accent);color:#fff}
.sps-wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

/* ---- layered steel backdrop ------------------------------------------- */
.sps-bg{position:absolute;inset:0;z-index:0;pointer-events:none;transition:background 1s var(--ease);
  background:
    radial-gradient(1300px 680px at 78% -12%, color-mix(in srgb,var(--accent) 26%,transparent), transparent 60%),
    radial-gradient(1000px 560px at -8% 112%, color-mix(in srgb,var(--accent) 16%,transparent), transparent 55%),
    linear-gradient(180deg,var(--bg),var(--bg2));}
.sps-bg::before{content:"";position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:72px 72px;mask-image:radial-gradient(circle at 50% 24%,#000 26%,transparent 76%)}
.sps-bg::after{content:"";position:absolute;inset:0;mix-blend-mode:overlay;opacity:.05;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
.sps-cursor{position:fixed;width:520px;height:520px;border-radius:50%;z-index:1;pointer-events:none;
  transform:translate(-50%,-50%);transition:background .8s var(--ease);mix-blend-mode:screen;opacity:.5;
  background:radial-gradient(circle, color-mix(in srgb,var(--accent) 30%,transparent), transparent 62%)}

/* ---- top bar ----------------------------------------------------------- */
.sps-bar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:16px 32px;backdrop-filter:blur(16px) saturate(1.2);
  background:linear-gradient(180deg,rgba(7,8,9,.9),rgba(7,8,9,.35));border-bottom:1px solid var(--line)}
.sps-brand{display:flex;align-items:center;gap:14px;cursor:pointer}
.sps-brand .plate{height:38px;display:flex;align-items:center;padding:6px 12px;border-radius:9px;
  background:rgba(255,255,255,.96);box-shadow:0 4px 24px rgba(0,0,0,.45);transition:.4s var(--ease)}
.sps-brand .plate img{height:24px;width:auto}
.sps-brand small{font-family:var(--mono);letter-spacing:.12em;text-transform:lowercase;color:var(--muted);font-size:11px}
.sps-nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.sps-nav button{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:12px;color:var(--muted);
  padding:9px 13px;border-radius:8px;border:1px solid transparent;transition:.25s var(--ease)}
.sps-nav button:hover{color:#fff;border-color:var(--line2)}
.sps-nav button.on{color:#fff;border-color:color-mix(in srgb,var(--accent) 55%,transparent);
  background:color-mix(in srgb,var(--accent) 16%,transparent)}
.sps-portal{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:12px;
  padding:10px 18px;border-radius:8px;background:var(--accent);color:#fff;transition:.25s var(--ease)}
.sps-portal:hover{filter:brightness(1.12);transform:translateY(-1px)}

/* ---- views ------------------------------------------------------------- */
.sps-view{position:relative;z-index:2;display:none}
.sps-view.show{display:block;animation:spsFade .6s var(--ease)}
@keyframes spsFade{from{opacity:0}to{opacity:1}}

/* ---- shared hero ------------------------------------------------------- */
.sps-hero{padding:96px 0 64px}
.sps-eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.22em;font-size:12px;
  color:var(--accent2);display:flex;align-items:center;gap:12px}
.sps-eyebrow::before{content:"";width:34px;height:1px;background:var(--accent2)}
.sps-display{font-family:var(--display);font-weight:800;line-height:.86;letter-spacing:.005em;text-transform:uppercase;
  font-size:clamp(52px,11vw,148px);margin:18px 0 22px}
.sps-display .ln{display:block;overflow:hidden}
.sps-display .ln > span{display:block;transform:translateY(108%);transition:transform .9s var(--ease)}
.show .sps-display .ln > span{transform:none}
.sps-display .ln:nth-child(2) > span{transition-delay:.08s}
.sps-display .ln:nth-child(3) > span{transition-delay:.16s}
.sps-display .stroke{-webkit-text-stroke:1.5px var(--text);color:transparent}
.sps-lead{max-width:660px;color:var(--muted2);font-size:clamp(16px,1.6vw,20px)}
.sps-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.sps-btn{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:13px;
  padding:15px 28px;border-radius:10px;border:1px solid var(--line2);transition:.28s var(--ease);position:relative;overflow:hidden}
.sps-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.sps-btn.primary:hover{filter:brightness(1.12);transform:translateY(-2px);box-shadow:0 14px 40px color-mix(in srgb,var(--accent) 40%,transparent)}
.sps-btn.ghost:hover{border-color:var(--accent);color:var(--accent2)}

/* ---- hub --------------------------------------------------------------- */
.sps-hubgrid{display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:center}
@media(max-width:900px){.sps-hubgrid{grid-template-columns:1fr}}
.sps-kpis{display:flex;gap:40px;margin-top:48px;flex-wrap:wrap}
.sps-kpi b{font-family:var(--display);font-weight:800;font-size:clamp(30px,4vw,46px);display:block;line-height:1}
.sps-kpi span{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:11px}
.sps-emblem{aspect-ratio:1;border:1px solid var(--line);border-radius:26px;position:relative;overflow:hidden;
  background:radial-gradient(130% 130% at 28% 18%,color-mix(in srgb,var(--accent) 30%,transparent),transparent 60%),var(--panel)}
.sps-emblem .ring{position:absolute;border-radius:50%}
.sps-emblem .r1{inset:12%;border:1px dashed rgba(255,255,255,.2);animation:spsSpin 30s linear infinite}
.sps-emblem .r2{inset:26%;border:1px solid rgba(255,255,255,.1);animation:spsSpin 20s linear infinite reverse}
.sps-emblem .r3{inset:40%;border:1px solid color-mix(in srgb,var(--accent) 50%,transparent);animation:spsSpin 14s linear infinite}
@keyframes spsSpin{to{transform:rotate(360deg)}}
.sps-emblem .core{position:absolute;inset:0;display:grid;place-items:center}
.sps-emblem .core .plate{background:rgba(255,255,255,.97);padding:20px 24px;border-radius:16px;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.sps-emblem .core .plate img{height:56px}

.sps-sechead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin:84px 0 28px;flex-wrap:wrap}
.sps-sechead h2{font-family:var(--sub);font-weight:800;font-size:clamp(26px,3.6vw,42px);letter-spacing:-.015em}
.sps-sechead .tagn{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--muted);max-width:420px;text-align:right}

.sps-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:920px){.sps-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.sps-cards{grid-template-columns:1fr}}
.sps-card{position:relative;border:1px solid var(--line);border-radius:18px;padding:24px;background:var(--panel);
  min-height:206px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);cursor:pointer}
.sps-card.soon{cursor:default;opacity:.5}
.sps-card .cardglow{position:absolute;inset:0;opacity:0;transition:.4s var(--ease);
  background:radial-gradient(130% 90% at 50% -10%,color-mix(in srgb,var(--c,#888) 40%,transparent),transparent 60%)}
.sps-card:not(.soon):hover{transform:translateY(-8px);border-color:color-mix(in srgb,var(--c,#888) 70%,transparent);
  box-shadow:0 30px 70px rgba(0,0,0,.55)}
.sps-card:not(.soon):hover .cardglow{opacity:1}
.sps-card .lp{background:rgba(255,255,255,.96);border-radius:11px;padding:11px 13px;width:fit-content;position:relative;z-index:1}
.sps-card .lp img{height:30px;width:auto}
.sps-card .lp.text{background:rgba(255,255,255,.07);color:var(--muted2);font-family:var(--mono);font-size:12px;letter-spacing:.06em}
.sps-card h3{font-family:var(--sub);font-weight:800;font-size:19px;margin-top:16px;position:relative;z-index:1}
.sps-card .meta{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:11px;position:relative;z-index:1;margin-top:2px}
.sps-card .badge{position:absolute;top:18px;right:18px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;
  font-size:10px;padding:4px 9px;border-radius:30px;z-index:1;font-weight:600}
.sps-card .badge.live{background:var(--c,#888);color:#06080a}
.sps-card .badge.soon{background:rgba(255,255,255,.1);color:var(--muted)}
.sps-card .org{position:absolute;bottom:18px;right:20px;font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.1em;z-index:1}
.sps-card .enter{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--c,#fff);
  display:flex;align-items:center;gap:8px;position:relative;z-index:1;margin-top:12px}
.sps-card:hover .enter svg{transform:translateX(6px)}
.sps-card .enter svg{transition:.3s var(--ease)}

/* ---- company content --------------------------------------------------- */
.sps-marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:16px 0;margin-top:34px;background:color-mix(in srgb,var(--accent) 7%,transparent)}
.sps-marquee .track{display:flex;gap:42px;white-space:nowrap;width:max-content;animation:spsSlide 26s linear infinite;
  font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#cfd6e2;font-size:clamp(18px,2.4vw,30px)}
.sps-marquee .track span{opacity:.5}
@keyframes spsSlide{to{transform:translateX(-50%)}}
.sps-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:26px}
@media(max-width:820px){.sps-cols{grid-template-columns:1fr}}
.sps-feat{border:1px solid var(--line);border-radius:16px;padding:26px;background:var(--panel);transition:.35s var(--ease)}
.sps-feat:hover{border-color:color-mix(in srgb,var(--accent) 55%,transparent);transform:translateY(-5px);background:var(--panel2)}
.sps-feat .n{font-family:var(--mono);color:var(--accent2);font-size:12px;letter-spacing:.1em}
.sps-feat h4{font-family:var(--sub);font-weight:800;font-size:19px;margin:12px 0 8px}
.sps-feat p{color:var(--muted);font-size:14px}
.sps-split{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
@media(max-width:820px){.sps-split{grid-template-columns:1fr}}
.sps-stat{border:1px solid var(--line);border-radius:18px;padding:34px;
  background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 14%,transparent),transparent),var(--panel)}
.sps-stat .big{font-family:var(--display);font-weight:800;font-size:clamp(44px,7vw,78px);line-height:.9;color:#fff}
.sps-rows{display:flex;flex-direction:column;gap:14px}
.sps-rows .row{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line);padding-bottom:13px}
.sps-rows .row b{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:500;font-size:12px}
.sps-rows .row span{text-align:right}
.sps-band{margin-top:74px;border:1px solid var(--line);border-radius:22px;padding:56px 40px;text-align:center;
  background:radial-gradient(120% 150% at 50% 0%,color-mix(in srgb,var(--accent) 28%,transparent),transparent 60%),var(--panel)}
.sps-band h3{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(30px,5vw,58px);letter-spacing:.01em;line-height:.95}
.sps-band p{color:var(--muted2);max-width:580px;margin:16px auto 28px}

.sps-foot{border-top:1px solid var(--line);margin-top:78px;padding:42px 0;color:var(--muted);font-size:13px;position:relative;z-index:2}
.sps-foot .sps-wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:center}
.sps-foot a{color:var(--accent2);cursor:pointer}
.sps-foot .mono{font-family:var(--mono);font-size:11px;letter-spacing:.06em}

/* ---- reveal ------------------------------------------------------------ */
.sps-rev{opacity:0;transform:translateY(28px);transition:.8s var(--ease)}
.sps-rev.in{opacity:1;transform:none}

/* ---- the transition curtain (the hook) -------------------------------- */
.sps-curtain{position:fixed;inset:0;z-index:9999;pointer-events:none;display:grid;grid-template-columns:repeat(7,1fr)}
.sps-curtain .slab{background:var(--tx,#111);transform:scaleY(0);transform-origin:top;
  transition:transform .52s cubic-bezier(.76,0,.24,1)}
.sps-curtain.cover .slab{transform:scaleY(1)}
.sps-curtain.open .slab{transform-origin:bottom;transform:scaleY(0)}
.sps-curtain .slab:nth-child(1){transition-delay:0s}
.sps-curtain .slab:nth-child(2){transition-delay:.04s}
.sps-curtain .slab:nth-child(3){transition-delay:.08s}
.sps-curtain .slab:nth-child(4){transition-delay:.12s}
.sps-curtain .slab:nth-child(5){transition-delay:.08s}
.sps-curtain .slab:nth-child(6){transition-delay:.04s}
.sps-curtain .slab:nth-child(7){transition-delay:0s}
/* diagonal-wipe variant */
.sps-curtain.wipe .slab{transform-origin:left;transform:scaleX(0) skewX(-8deg)}
.sps-curtain.wipe.cover .slab{transform:scaleX(1) skewX(-8deg)}
.sps-curtain.wipe.open .slab{transform-origin:right;transform:scaleX(0) skewX(-8deg)}
/* flood variant: single sheet */
.sps-curtain.flood{grid-template-columns:1fr}
.sps-curtain.flood .slab:not(:first-child){display:none}
.sps-curtain.flood .slab{transition:transform .5s var(--ease)}

.sps-curtain .badge2{position:fixed;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .22s ease}
.sps-curtain.cover .badge2{opacity:1;transition-delay:.3s}
.sps-curtain .badge2 .in2{display:flex;flex-direction:column;align-items:center;gap:18px;transform:translateY(12px);transition:.45s var(--ease)}
.sps-curtain.cover .badge2 .in2{transform:none}
.sps-curtain .badge2 .plate{background:rgba(255,255,255,.98);padding:18px 26px;border-radius:16px}
.sps-curtain .badge2 .plate img{height:48px}
.sps-curtain .badge2 .nm{font-family:var(--mono);text-transform:lowercase;letter-spacing:.18em;color:#fff;font-size:13px;opacity:.9}
.sps-curtain .spark{position:fixed;left:0;right:0;height:2px;top:50%;background:linear-gradient(90deg,transparent,#fff,transparent);filter:blur(.5px);opacity:0}
.sps-curtain.cover .spark{animation:spsSpark .7s ease .12s}
@keyframes spsSpark{0%{opacity:0;transform:scaleX(0)}45%{opacity:1}100%{opacity:0;transform:scaleX(1)}}

.sps-hint{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:50;font-family:var(--mono);
  text-transform:uppercase;letter-spacing:.12em;font-size:10px;color:var(--muted);
  background:rgba(7,8,9,.72);border:1px solid var(--line);padding:9px 18px;border-radius:30px;backdrop-filter:blur(8px)}

/* =========================================================================
   ORBIT — web of companies (v0.2)
   ========================================================================= */
.sps-orbit{position:relative;aspect-ratio:1;width:100%;max-width:560px;margin:0 auto;user-select:none}
.orb-web{position:absolute;inset:0;width:100%;height:100%;overflow:visible;z-index:1}
.orb-line{stroke:color-mix(in srgb,var(--accent) 42%,transparent);stroke-width:1;transition:stroke .4s,opacity .4s,stroke-width .4s}
.orb-line.chosen{stroke:#fff;stroke-width:2.4}
.orb-line.faded{opacity:.12}
.orb-rings{position:absolute;inset:0;z-index:0}
.orb-rings i{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.07)}
.orb-rings i:nth-child(1){inset:8%;animation:spsSpin 40s linear infinite}
.orb-rings i:nth-child(2){inset:22%;border-style:dashed;border-color:rgba(255,255,255,.1);animation:spsSpin 28s linear infinite reverse}
.orb-rings i:nth-child(3){inset:40%;border-color:color-mix(in srgb,var(--accent) 36%,transparent)}
.orb-core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3}
.orb-core .plate{background:rgba(255,255,255,.97);padding:16px 20px;border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.55)}
.orb-core .plate img{height:46px}
.orb-nodes{position:absolute;inset:0;z-index:4}
.orb-node{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:7px;background:none;transition:transform .45s var(--ease),opacity .45s var(--ease)}
.orb-node .np{display:grid;place-items:center;width:62px;height:62px;border-radius:14px;background:rgba(255,255,255,.96);box-shadow:0 10px 30px rgba(0,0,0,.5);border:2px solid transparent;transition:.35s var(--ease)}
.orb-node .np img{max-width:42px;max-height:30px;width:auto}
.orb-node .np.dim{background:rgba(255,255,255,.07);color:var(--muted);font-family:var(--mono);font-size:9px;letter-spacing:.04em;text-align:center;padding:4px;line-height:1.1}
.orb-node .nlabel{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--muted);opacity:0;transition:.3s;white-space:nowrap}
.orb-node:not(.soon){cursor:pointer}
.orb-node.soon{opacity:.42}
.orb-node:not(.soon):hover,.orb-node.hot{transform:translate(-50%,-50%) scale(1.16)}
.orb-node:not(.soon):hover .np,.orb-node.hot .np{border-color:var(--c);box-shadow:0 14px 40px color-mix(in srgb,var(--c) 50%,transparent)}
.orb-node:not(.soon):hover .nlabel,.orb-node.hot .nlabel{opacity:1;color:#fff}
.sps-orbit.spotlight .orb-node.faded,.sps-tx-orbit.spotlight .orb-node.faded{opacity:.12}
.orb-node.chosen{transform:translate(-50%,-50%) scale(1.55);z-index:6}
.orb-node.chosen .np{border-color:#fff;box-shadow:0 0 0 6px color-mix(in srgb,var(--c) 35%,transparent),0 20px 60px color-mix(in srgb,var(--c) 70%,transparent);animation:spsBump .5s var(--ease)}
.orb-node.chosen .nlabel{opacity:1;color:#fff}
@keyframes spsBump{0%{transform:scale(1)}55%{transform:scale(1.7)}100%{transform:scale(1.55)}}

/* transition overlay */
.sps-tx{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:0;visibility:hidden;background:radial-gradient(circle at 50% 50%,rgba(7,8,9,.86),rgba(7,8,9,.97));display:grid;place-items:center;transition:opacity .45s var(--ease),visibility .45s}
.sps-tx.show{opacity:1;visibility:visible}
.sps-tx-orbit{position:relative;width:min(86vw,86vh);height:min(86vw,86vh)}
.sps-tx.intro .sps-tx-orbit{animation:spsIntro 1.1s var(--ease)}
.sps-tx.settle{opacity:0}
@keyframes spsIntro{0%{transform:scale(.6) rotate(-20deg);opacity:0}60%{opacity:1}100%{transform:scale(1) rotate(0)}}
.sps-flood{position:fixed;width:12px;height:12px;margin:-6px 0 0 -6px;border-radius:50%;z-index:9995;transform:scale(0);opacity:1;pointer-events:none}
.sps-flood.go{transition:transform .62s cubic-bezier(.7,0,.3,1);transform:scale(460)}
.sps-flood.out{opacity:0;transition:opacity .5s ease}

/* =========================================================================
   COMPANY — deeper sections
   ========================================================================= */
.sps-story{display:grid;grid-template-columns:1.4fr .9fr;gap:36px;align-items:start;margin-top:8px;border-top:1px solid var(--line);padding-top:46px}
@media(max-width:820px){.sps-story{grid-template-columns:1fr;gap:24px}}
.sps-story .st-eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.18em;color:var(--accent2);font-size:12px;margin-bottom:14px}
.sps-story .st-copy p{font-size:clamp(18px,2.2vw,26px);line-height:1.5;color:#e7ebf1;font-family:var(--sub);font-weight:600;letter-spacing:-.01em}
.sps-story .st-facts{border-left:1px solid var(--line);padding-left:28px}
@media(max-width:820px){.sps-story .st-facts{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:20px}}
.sps-chipsec{margin-top:54px}
.sps-chipsec h3{font-family:var(--sub);font-weight:800;font-size:clamp(20px,2.6vw,28px);margin-bottom:18px}
.chiprow{display:flex;flex-wrap:wrap;gap:10px}
.chip{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:#dfe5ee;border:1px solid var(--line2);padding:10px 16px;border-radius:30px;background:var(--panel);transition:.28s var(--ease)}
.chip:hover{border-color:var(--accent);color:#fff;background:color-mix(in srgb,var(--accent) 16%,transparent);transform:translateY(-2px)}
.sps-numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:54px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:34px 0}
@media(max-width:760px){.sps-numbers{grid-template-columns:repeat(2,1fr);gap:28px}}
.sps-num b{font-family:var(--display);font-weight:800;font-size:clamp(34px,5vw,58px);line-height:.9;color:#fff;display:block}
.sps-num span{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:11px;margin-top:8px;display:block}
.sps-timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:24px}
@media(max-width:820px){.sps-timeline{grid-template-columns:1fr 1fr}}
.sps-tl-item{border-top:2px solid var(--accent);padding-top:14px}
.sps-tl-item .yr{font-family:var(--display);font-weight:800;font-size:24px;color:var(--accent2)}
.sps-tl-item .ev{color:var(--muted2);font-size:14px;margin-top:6px}

/* =========================================================================
   VARIANTS — each company a slightly different world
   ========================================================================= */
.v-heritage .sps-display{letter-spacing:0}
.v-heritage .chip{border-radius:6px}
.v-ease .sps-hero{text-align:center}
.v-ease .sps-hero .sps-eyebrow{justify-content:center}
.v-ease .sps-hero .sps-lead{margin-left:auto;margin-right:auto}
.v-ease .sps-hero .sps-actions{justify-content:center}
.v-ease .chip{border-radius:40px;background:color-mix(in srgb,var(--accent) 10%,var(--panel))}
.v-ease .sps-feat{border-radius:22px}
.v-craft .sps-chipsec h3,.v-craft .sps-sechead h2{font-family:var(--display)}
.v-craft .chip{border-radius:4px;text-transform:uppercase;letter-spacing:.1em;font-size:11px}
.v-craft .sps-feat{position:relative}
.v-craft .sps-feat::before{content:"";position:absolute;top:12px;right:12px;width:10px;height:10px;border-top:2px solid var(--accent);border-right:2px solid var(--accent);opacity:.7}

@media(prefers-reduced-motion:reduce){
  #sps-hub-root *{animation:none!important;transition:none!important}
  .sps-display .ln > span{transform:none}
}

/* =========================================================================
   FULL-SCREEN TAKEOVER  — [sps_hub fullscreen="1"] (works on any theme)
   ========================================================================= */
#sps-hub-root.sps-fullscreen{position:fixed;inset:0;width:100vw;height:100vh;z-index:99990;overflow-y:auto;overflow-x:hidden}
html:has(#sps-hub-root.sps-fullscreen){overflow:hidden}
body.admin-bar #sps-hub-root.sps-fullscreen{top:32px;height:calc(100vh - 32px)}
@media screen and (max-width:782px){body.admin-bar #sps-hub-root.sps-fullscreen{top:46px;height:calc(100vh - 46px)}}
html.sps-fs-lock, html.sps-fs-lock body{overflow:hidden !important;margin:0 !important;height:100%}

/* =========================================================================
   v0.2.3 — cleaner layout pass
   ========================================================================= */
.sps-display{font-size:clamp(44px,8vw,104px)}
.sps-hero{padding:72px 0 56px}
.sps-orbit{min-height:460px}
.sps-bar{gap:24px}
.sps-nav{margin-left:auto;margin-right:14px;gap:8px}
.sps-nav button{padding:9px 14px}
.sps-brand small{display:none}
@media(min-width:1100px){.sps-brand small{display:block}}
/* keep the hub two-column from feeling cramped on very wide screens */
@media(min-width:1500px){.sps-hubgrid{grid-template-columns:1.1fr .9fr;gap:64px}}
