/* ============================================================
   FUSION ACURHYAL · Launch Platform
   Premium · Clinical · Minimal — Black / White / Off-white / Fusion Red
   ============================================================ */

:root{
  --w:#ffffff;
  --paper:#faf9f7;        /* warm off-white */
  --paper-2:#f4f3f1;      /* soft grey */
  --ink:#121316;          /* near-black */
  --ink-2:#46484e;        /* charcoal body */
  --muted:#82858c;
  --faint:#aeb0b6;
  --line:#e8e7e3;
  --line-2:#f0efec;

  --red:#b21f2c;          /* Fusion red */
  --red-d:#8d1822;
  --red-soft:#fbeef0;
  --red-tint:rgba(178,31,44,.045);

  --display:"Be Vietnam Pro","Helvetica Neue",Arial,sans-serif;
  --serif:"Cormorant",Georgia,serif;
  --body:"Be Vietnam Pro","Helvetica Neue",Arial,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;

  --maxw:1280px;
  --gut:clamp(20px,5vw,76px);
  --ease:cubic-bezier(.22,.61,.27,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--w); color:var(--ink);
  font-family:var(--body); font-size:17px; font-weight:400; line-height:1.62; letter-spacing:.002em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--red); color:#fff; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:300; line-height:1.04; letter-spacing:-.02em; margin:0; }
p{ margin:0; text-wrap:pretty; }

/* ---------- type scale ---------- */
.kicker{
  font-family:var(--mono); font-size:11.5px; font-weight:400; letter-spacing:.22em; text-transform:uppercase;
  color:var(--red); display:inline-flex; align-items:center; gap:.7em;
}
.kicker::before{ content:""; width:18px; height:1px; background:var(--red); display:inline-block; }
.kicker.on-dark{ color:#e98a93; }
.kicker.on-dark::before{ background:#e98a93; }
.kicker.neutral{ color:var(--muted); }
.kicker.neutral::before{ background:var(--muted); }

.h-xl{ font-size:clamp(42px,7.6vw,116px); font-weight:200; letter-spacing:-.035em; line-height:.98; }
.h-lg{ font-size:clamp(32px,5.4vw,76px); font-weight:200; letter-spacing:-.03em; line-height:1.02; }
.h-md{ font-size:clamp(26px,3.6vw,48px); font-weight:300; letter-spacing:-.022em; line-height:1.06; }
.h-sm{ font-size:clamp(21px,2.2vw,30px); font-weight:300; letter-spacing:-.015em; line-height:1.12; }
em.ac{ font-style:normal; color:var(--red); }
.serif{ font-family:var(--serif); font-style:italic; font-weight:400; letter-spacing:0; }
.cap{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--muted); line-height:1.55; text-transform:uppercase; }
.lead{ font-size:clamp(16px,1.35vw,19.5px); font-weight:300; color:var(--ink-2); line-height:1.62; }
.lead-sm{ font-size:16px; font-weight:300; color:var(--ink-2); line-height:1.6; }

/* ---------- layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gut); }
.section{ padding:clamp(76px,10vw,148px) 0; }
.section.sm{ padding:clamp(54px,7vw,100px) 0; }
.bleed{ width:100%; }
.dark{ background:var(--ink); color:#fff; }
.dark h1,.dark h2,.dark h3,.dark h4{ color:#fff; }
.dark .lead,.dark .lead-sm{ color:rgba(255,255,255,.66); }
.dark .cap{ color:rgba(255,255,255,.5); }

.sec-head{ max-width:880px; }
.sec-head .h-lg,.sec-head .h-md{ margin-top:22px; }
.sec-head .lead{ margin-top:22px; max-width:640px; }
.eyerow{ display:flex; align-items:baseline; gap:18px; flex-wrap:wrap; }
.eyerow .idx{ font-family:var(--mono); font-size:12px; color:var(--faint); letter-spacing:.04em; }

/* hairline that draws in on reveal */
.drawline{ height:1px; background:var(--red); width:100%; transform:scaleX(0); transform-origin:left; transition:transform 1.1s var(--ease); }
.reveal.in .drawline{ transform:scaleX(1); }

/* ---------- buttons (outline only) ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.75em; font-family:var(--display);
  font-weight:400; font-size:14.5px; letter-spacing:.01em; line-height:1;
  padding:16px 26px; border:1px solid var(--line); background:transparent; color:var(--ink);
  position:relative; overflow:hidden;
  transition:color .4s var(--ease), border-color .4s var(--ease);
}
.btn::before{ content:""; position:absolute; inset:0; background:var(--red-tint); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease); z-index:0; }
.btn > *{ position:relative; z-index:1; }
.btn:hover::before{ transform:scaleX(1); }
.btn .ar{ transition:transform .4s var(--ease); font-style:normal; }
.btn:hover .ar{ transform:translate(3px,-3px); }

.btn--red{ border-color:var(--red); color:var(--red); }
.btn--red:hover{ border-color:var(--red-d); color:var(--red-d); }
.btn--ink{ border-color:rgba(18,19,22,.22); color:var(--ink); }
.btn--ink:hover{ border-color:var(--ink); }
.btn--ghost-d{ border-color:rgba(255,255,255,.24); color:#fff; }
.btn--ghost-d::before{ background:rgba(255,255,255,.07); }
.btn--ghost-d:hover{ border-color:rgba(255,255,255,.65); color:#fff; }
.btn--red-d{ border-color:rgba(233,138,147,.5); color:#f4b8be; }
.btn--red-d::before{ background:rgba(178,31,44,.22); }
.btn--red-d:hover{ border-color:#e98a93; color:#fff; }
.btn--lg{ padding:19px 32px; font-size:15.5px; }
.btn--sm{ padding:12px 18px; font-size:13px; }
.btn--block{ width:100%; justify-content:center; }

.tlink{ font-family:var(--display); font-weight:400; font-size:14px; display:inline-flex; align-items:center; gap:.5em; color:var(--ink); border-bottom:1px solid var(--red); padding-bottom:4px; transition:gap .3s var(--ease); }
.tlink:hover{ gap:.85em; }
.dark .tlink{ color:#fff; }

.tag{ font-family:var(--mono); font-size:11px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-2); border:1px solid var(--line); padding:6px 12px; border-radius:100px; }
.dark .tag{ color:rgba(255,255,255,.72); border-color:rgba(255,255,255,.2); }
.tag.red{ color:var(--red); border-color:rgba(178,31,44,.32); }

/* ============================================================
   NAV
   ============================================================ */
.nav{ position:fixed; top:0; left:0; right:0; z-index:80; transition:background .4s var(--ease), border-color .4s var(--ease); border-bottom:1px solid transparent; }
.nav.scrolled{ background:rgba(255,255,255,.82); backdrop-filter:blur(18px) saturate(1.4); -webkit-backdrop-filter:blur(18px) saturate(1.4); border-color:var(--line); }
.nav__in{ max-width:1440px; margin:0 auto; padding:0 var(--gut); height:74px; display:flex; align-items:center; gap:24px; }
.logo{ font-family:var(--display); font-weight:500; font-size:18px; letter-spacing:.04em; display:flex; align-items:center; gap:10px; }
.logo .sq{ width:9px; height:9px; background:var(--red); display:inline-block; transform:rotate(45deg); }
.logo small{ font-family:var(--mono); font-size:9px; letter-spacing:.2em; color:var(--muted); text-transform:uppercase; border-left:1px solid var(--line); padding-left:10px; font-weight:400; }
.nav__links{ display:flex; gap:2px; margin-left:auto; }
.nav__links a{ font-family:var(--display); font-size:13.5px; font-weight:300; color:var(--ink-2); padding:9px 13px; transition:color .25s; position:relative; }
.nav__links a::after{ content:""; position:absolute; left:13px; right:13px; bottom:5px; height:1px; background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease); }
.nav__links a:hover{ color:var(--ink); } .nav__links a:hover::after,.nav__links a.active::after{ transform:scaleX(1); }
.nav__cta{ display:flex; align-items:center; gap:10px; margin-left:8px; }
.burger{ display:none; width:44px; height:44px; border:1px solid var(--line); background:var(--w); flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.burger span{ width:18px; height:1.4px; background:var(--ink); transition:transform .3s var(--ease),opacity .3s; }
.burger.open span:nth-child(1){ transform:translateY(5.4px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-5.4px) rotate(-45deg); }

.drawer-nav{ position:fixed; inset:74px 0 0; z-index:75; background:var(--w); padding:24px var(--gut) 40px; transform:translateY(-10px); opacity:0; pointer-events:none; transition:opacity .35s var(--ease),transform .35s var(--ease); overflow:auto; }
.drawer-nav.open{ opacity:1; transform:none; pointer-events:auto; }
.drawer-nav a{ display:block; font-family:var(--display); font-weight:300; font-size:26px; letter-spacing:-.01em; padding:16px 0; border-bottom:1px solid var(--line); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top:74px; min-height:100svh; display:flex; flex-direction:column; }
.hero__grid{ flex:1; display:grid; grid-template-columns:1.04fr .96fr; }
.hero__left{ padding:clamp(30px,4vw,64px) var(--gut) clamp(24px,3vw,40px); display:flex; flex-direction:column; justify-content:center; }
.hero__left .wrapinner{ max-width:640px; margin-left:auto; margin-right:clamp(8px,3vw,56px); width:100%; }
.hero__title{ margin-top:30px; }
.hero__rule{ width:84px; height:1px; background:var(--red); margin:30px 0; transform:scaleX(0); transform-origin:left; }
.hero.lit .hero__rule{ transform:scaleX(1); transition:transform 1.2s var(--ease) .5s; }
.hero__sub{ max-width:500px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:38px; }
.hero__meta{ display:flex; gap:26px; margin-top:40px; flex-wrap:wrap; }
.hero__meta .m{ display:flex; flex-direction:column; gap:5px; }
.hero__meta .m .v{ font-family:var(--display); font-weight:300; font-size:23px; letter-spacing:-.01em; }
.hero__meta .m .v sup{ font-size:.5em; color:var(--red); font-weight:400; vertical-align:super; margin-left:2px; }
.hero__meta .m .k{ font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }

.hero__right{ position:relative; background:#0d0e10 url("assets/poster-1.jpg") center/cover no-repeat; overflow:hidden; }
.hero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.12); opacity:0; transition:transform 2.4s var(--ease), opacity 1.6s var(--ease); }
.hero.lit .hero__video{ transform:scale(1); opacity:1; }
.hero__right::after{ content:""; position:absolute; inset:0; background:linear-gradient(160deg,rgba(0,0,0,.04),rgba(0,0,0,.14)); pointer-events:none; }
.hero__badge{ position:absolute; left:0; bottom:0; z-index:3; display:flex; align-items:center; gap:11px; padding:13px 20px; background:var(--red); color:#fff; font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; }
.hero__vtag{ position:absolute; right:22px; top:22px; z-index:3; display:flex; align-items:center; gap:9px; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#fff; }
.hero__vtag .dot{ width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 0 0 rgba(178,31,44,.6); animation:pulse 2s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(178,31,44,.5);} 70%{box-shadow:0 0 0 10px rgba(178,31,44,0);} 100%{box-shadow:0 0 0 0 rgba(178,31,44,0);} }

/* ============================================================
   POSITIONING (one-line)
   ============================================================ */
.pos{ background:var(--paper); }
.pos__in{ display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(36px,6vw,90px); align-items:center; }
.pos__statement{ font-family:var(--display); font-weight:200; font-size:clamp(30px,4.4vw,58px); letter-spacing:-.028em; line-height:1.08; }
.pos__statement .serif{ display:inline; }
.pos__list{ list-style:none; margin:30px 0 0; padding:0; display:grid; gap:0; }
.pos__list li{ display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:baseline; padding:18px 0; border-top:1px solid var(--line); }
.pos__list li:last-child{ border-bottom:1px solid var(--line); }
.pos__list .n{ font-family:var(--mono); font-size:11px; color:var(--red); letter-spacing:.06em; }
.pos__list .t{ font-size:16px; color:var(--ink-2); font-weight:300; }
.pos__list .t b{ font-weight:500; color:var(--ink); }
.pos__media{ position:relative; aspect-ratio:4/5; background:linear-gradient(170deg,#fff,#efeeec); border:1px solid var(--line); overflow:hidden; }
.pos__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.06); transition:transform 1.6s var(--ease); }
.reveal.in .pos__media img{ transform:scale(1); }
.pos__cap{ position:absolute; left:18px; bottom:16px; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

/* ============================================================
   STATS / WHY DIFFERENT (dark)
   ============================================================ */
.why .prow{ display:grid; grid-template-columns:minmax(0,1fr) 1.15fr; gap:clamp(20px,4vw,64px); align-items:center; padding:clamp(26px,3.4vw,46px) 0; border-top:1px solid rgba(255,255,255,.13); }
.why .prow:last-child{ border-bottom:1px solid rgba(255,255,255,.13); }
.why .pnum{ font-family:var(--display); font-weight:100; font-size:clamp(54px,9.5vw,128px); line-height:.86; letter-spacing:-.05em; color:#fff; }
.why .pnum sup{ font-size:.26em; font-weight:300; color:var(--red); vertical-align:super; letter-spacing:0; margin-left:.1em; }
.why .pnum.txt{ font-size:clamp(40px,6vw,82px); font-weight:200; }
.why .pmeta .code{ font-family:var(--mono); font-size:11px; color:#e98a93; letter-spacing:.1em; margin-bottom:14px; display:block; }
.why .pmeta h3{ font-size:clamp(20px,2vw,27px); font-weight:300; letter-spacing:-.015em; }
.why .pmeta p{ color:rgba(255,255,255,.6); margin-top:12px; font-size:15.5px; font-weight:300; max-width:460px; }

/* molecular svg accent */
.molecule{ width:100%; height:auto; overflow:visible; }
.molecule .ln{ stroke:rgba(255,255,255,.28); stroke-width:1; stroke-dasharray:1; stroke-dashoffset:1; }
.molecule .nd{ fill:#e98a93; opacity:0; }
.reveal.in .molecule .ln{ animation:draw 1.4s var(--ease) forwards; }
.reveal.in .molecule .nd{ animation:fadeNode .6s var(--ease) forwards .9s; }
@keyframes draw{ to{ stroke-dashoffset:0; } }
@keyframes fadeNode{ to{ opacity:1; } }

/* ============================================================
   MESSAGE HOUSE (3 layers)
   ============================================================ */
.mh{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.mhcard{ background:var(--w); padding:clamp(28px,3vw,44px); display:flex; flex-direction:column; min-height:340px; transition:background .4s var(--ease); }
.mhcard:hover{ background:var(--paper); }
.mhcard .lay{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--red); }
.mhcard .ix{ font-family:var(--display); font-weight:200; font-size:54px; color:var(--line); letter-spacing:-.04em; margin:18px 0 auto; line-height:1; transition:color .4s var(--ease); }
.mhcard:hover .ix{ color:var(--red-soft); }
.mhcard h3{ font-size:25px; font-weight:300; letter-spacing:-.02em; margin-bottom:14px; }
.mhcard p{ color:var(--ink-2); font-size:15px; font-weight:300; line-height:1.6; }

/* ============================================================
   STIM / LIFT
   ============================================================ */
.sl{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.slcard{ background:var(--w); border:1px solid var(--line); padding:clamp(30px,3.4vw,52px); display:flex; flex-direction:column; position:relative; overflow:hidden; transition:border-color .4s var(--ease), transform .5s var(--ease); }
.slcard::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--red); transform:scaleY(0); transform-origin:top; transition:transform .6s var(--ease); }
.slcard:hover{ border-color:#dcdad5; transform:translateY(-4px); }
.slcard:hover::before{ transform:scaleY(1); }
.slcard .tag-line{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--red); text-transform:uppercase; }
.slcard .name{ font-family:var(--display); font-weight:200; font-size:clamp(54px,7vw,92px); letter-spacing:-.05em; line-height:.9; margin:14px 0 4px; }
.slcard .name small{ font-family:var(--mono); font-size:13px; font-weight:400; letter-spacing:.06em; color:var(--muted); vertical-align:super; }
.slcard .role{ font-size:17px; font-weight:300; color:var(--ink); max-width:30ch; }
.slcard .block{ margin-top:30px; padding-top:24px; border-top:1px solid var(--line-2); }
.slcard .bl{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
.slcard .fitlist{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.slcard .fitlist li{ display:flex; gap:12px; font-size:15px; font-weight:300; color:var(--ink-2); align-items:flex-start; }
.slcard .fitlist li::before{ content:""; width:5px; height:5px; background:var(--red); margin-top:8px; flex:none; transform:rotate(45deg); }
.slcard .biz{ font-size:14.5px; font-weight:300; color:var(--ink-2); line-height:1.6; }
.slcard .spec{ display:flex; gap:24px; margin-top:18px; flex-wrap:wrap; }
.slcard .spec .s .v{ font-family:var(--display); font-weight:300; font-size:21px; }
.slcard .spec .s .v small{ font-size:.55em; color:var(--muted); }
.slcard .spec .s .k{ font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-top:6px; }
.slcard .foot{ margin-top:auto; padding-top:28px; }

/* ============================================================
   APPLICATION MAP (tabs)
   ============================================================ */
.appmap{ display:grid; grid-template-columns:300px 1fr; gap:clamp(28px,5vw,70px); align-items:start; }
.am__nav{ display:flex; flex-direction:column; }
.am__nav .it{ text-align:left; background:none; border:0; border-top:1px solid var(--line); padding:18px 0; display:flex; align-items:center; gap:14px; font-family:var(--display); font-weight:300; font-size:19px; letter-spacing:-.01em; color:var(--faint); transition:color .3s var(--ease), padding-left .3s var(--ease); }
.am__nav .it:last-child{ border-bottom:1px solid var(--line); }
.am__nav .it .ix{ font-family:var(--mono); font-size:11px; font-weight:400; }
.am__nav .it:hover{ color:var(--ink-2); }
.am__nav .it.active{ color:var(--ink); padding-left:14px; }
.am__nav .it.active .ix{ color:var(--red); }
.am__panel{ display:none; }
.am__panel.active{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); animation:fadeUp .5s var(--ease); }
.am__hero{ grid-column:1/-1; background:var(--ink); color:#fff; padding:clamp(28px,3vw,46px); display:flex; flex-direction:column; gap:14px; }
.am__hero .pk{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:#e98a93; }
.am__hero h3{ font-size:clamp(28px,3.4vw,46px); font-weight:200; letter-spacing:-.03em; }
.am__hero p{ color:rgba(255,255,255,.66); font-weight:300; max-width:50ch; }
.am__cell{ background:var(--w); padding:clamp(22px,2.4vw,32px); display:flex; flex-direction:column; gap:8px; }
.am__cell .bl{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.am__cell .vv{ font-size:18px; font-weight:300; color:var(--ink); letter-spacing:-.01em; }
.am__cell .dirpill{ display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:12px; color:var(--red); border:1px solid rgba(178,31,44,.3); padding:7px 13px; border-radius:100px; width:fit-content; margin-top:2px; }
.am__foot{ grid-column:1/-1; background:var(--paper); padding:22px clamp(22px,2.4vw,32px); display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:16px; }
.am__foot .note{ font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:.03em; }

/* ============================================================
   CUSTOMER FIT
   ============================================================ */
.fit{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.fitcard{ background:var(--w); padding:clamp(26px,2.6vw,40px); display:flex; flex-direction:column; min-height:330px; transition:background .4s var(--ease); }
.fitcard:hover{ background:var(--paper); }
.fitcard .seg{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--red); }
.fitcard h3{ font-size:24px; font-weight:300; letter-spacing:-.02em; margin:16px 0 0; }
.fitcard .need{ font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:.02em; margin-top:18px; text-transform:uppercase; }
.fitcard .need-t{ font-size:14.5px; font-weight:300; color:var(--ink-2); margin-top:8px; line-height:1.55; }
.fitcard .msg{ font-size:16px; font-weight:300; color:var(--ink); margin-top:18px; line-height:1.5; }
.fitcard .foot{ margin-top:auto; padding-top:24px; }
.fitcard .foot .tlink{ font-size:13.5px; }

/* ============================================================
   B2C BRIDGE
   ============================================================ */
.bridge{ background:var(--paper); }
.flow{ display:grid; grid-template-columns:repeat(5,1fr); gap:0; border:1px solid var(--line); background:var(--w); }
.flow .fnode{ padding:clamp(24px,2.6vw,34px) clamp(18px,2vw,26px); border-right:1px solid var(--line); display:flex; flex-direction:column; gap:12px; position:relative; transition:background .35s var(--ease); }
.flow .fnode:last-child{ border-right:0; }
.flow .fnode:hover{ background:var(--paper); }
.flow .fnode .fn{ font-family:var(--mono); font-size:11px; color:var(--red); letter-spacing:.05em; }
.flow .fnode .ft{ font-size:17px; font-weight:300; letter-spacing:-.01em; line-height:1.25; }
.flow .fnode .fd{ font-size:13px; font-weight:300; color:var(--muted); line-height:1.5; }
.flow .fnode .arrow{ position:absolute; right:-9px; top:50%; transform:translateY(-50%); z-index:2; width:18px; height:18px; background:var(--w); border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:9px; color:var(--red); }
.flow .fnode:last-child .arrow{ display:none; }
.fnode.terminal{ background:var(--ink); }
.fnode.terminal .ft{ color:#fff; }
.fnode.terminal .fn{ color:#e98a93; }
.fnode.terminal .fd{ color:rgba(255,255,255,.55); }

/* ============================================================
   CLINICAL CONFIDENCE (dark)
   ============================================================ */
.conf__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.12); margin-top:clamp(34px,4vw,56px); }
.confcell{ background:var(--ink); padding:clamp(26px,2.6vw,38px); display:flex; flex-direction:column; gap:12px; min-height:210px; transition:background .4s var(--ease); }
.confcell:hover{ background:#191b1f; }
.confcell .cn{ font-family:var(--mono); font-size:11px; color:#e98a93; letter-spacing:.06em; }
.confcell h4{ font-size:20px; font-weight:300; letter-spacing:-.015em; margin-top:auto; }
.confcell p{ color:rgba(255,255,255,.58); font-size:14px; font-weight:300; line-height:1.55; }

/* ============================================================
   TRAINING / WORKSHOP
   ============================================================ */
.train{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,76px); align-items:start; }
.modlist{ list-style:none; margin:0; padding:0; border-top:1px solid var(--line); }
.modlist li{ display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:center; padding:17px 0; border-bottom:1px solid var(--line); font-size:16px; font-weight:300; color:var(--ink); transition:padding-left .3s var(--ease), color .3s; }
.modlist li:hover{ padding-left:10px; }
.modlist li .mn{ font-family:var(--mono); font-size:11px; color:var(--red); }
.sched{ border-top:1px solid var(--line); }
.srow{ display:grid; grid-template-columns:140px 1fr; gap:18px; align-items:center; padding:22px 0; border-bottom:1px solid var(--line); }
.srow .city{ font-family:var(--display); font-weight:300; font-size:22px; letter-spacing:-.01em; }
.months{ display:flex; gap:7px; flex-wrap:wrap; }
.mpill{ font-family:var(--mono); font-size:11.5px; padding:7px 12px; border:1px solid var(--line); color:var(--ink-2); }
.mpill.hot{ border-color:var(--red); color:var(--red); }

/* ============================================================
   DEPLOYMENT SYSTEM (ecosystem)
   ============================================================ */
.eco{ border:1px solid var(--line); }
.eco__core{ padding:clamp(28px,3vw,46px); border-bottom:1px solid var(--line); display:grid; grid-template-columns:auto 1fr; gap:clamp(24px,4vw,60px); align-items:center; }
.eco__core .et{ font-family:var(--display); font-weight:200; font-size:clamp(30px,4vw,56px); letter-spacing:-.03em; line-height:1; }
.eco__core .ek{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--red); margin-bottom:12px; }
.eco__core .ed{ font-size:16px; font-weight:300; color:var(--ink-2); max-width:48ch; }
.eco__ring{ display:grid; grid-template-columns:repeat(6,1fr); }
.enode{ padding:26px 22px; border-right:1px solid var(--line); display:flex; flex-direction:column; gap:9px; transition:background .3s var(--ease); }
.enode:last-child{ border-right:0; }
.enode:hover{ background:var(--paper); }
.enode .ek{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--red); }
.enode .et{ font-family:var(--display); font-weight:300; font-size:17px; letter-spacing:-.01em; }
.enode .ed{ font-size:12.5px; font-weight:300; color:var(--muted); line-height:1.5; }

/* ============================================================
   IMPACT METRICS
   ============================================================ */
.impact{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.imcell{ background:var(--w); padding:clamp(24px,2.4vw,34px); display:flex; flex-direction:column; gap:14px; min-height:160px; transition:background .35s var(--ease); }
.imcell:hover{ background:var(--paper); }
.imcell .imn{ font-family:var(--mono); font-size:11px; color:var(--red); letter-spacing:.04em; }
.imcell h4{ font-size:16px; font-weight:300; letter-spacing:-.01em; line-height:1.3; margin-top:auto; }

/* ============================================================
   FORM
   ============================================================ */
.card{ background:var(--w); color:var(--ink); padding:clamp(26px,3vw,36px); border:1px solid var(--line); }
.card.float{ box-shadow:0 50px 110px -60px rgba(18,19,22,.55); }
.card h3{ font-size:23px; font-weight:300; letter-spacing:-.02em; }
.card .cap{ margin-top:7px; }
.field{ margin-top:16px; }
.field label{ display:block; font-family:var(--mono); font-size:10.5px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-2); margin-bottom:8px; }
.field label .rq{ color:var(--red); }
.input,.select,textarea.input{ width:100%; font-family:var(--body); font-size:15px; font-weight:300; color:var(--ink); background:var(--paper); border:1px solid transparent; border-bottom:1px solid var(--line); padding:13px; transition:border-color .25s,background .25s,box-shadow .25s; }
.input::placeholder{ color:var(--faint); }
.input:focus,.select:focus,textarea.input:focus{ outline:none; background:#fff; border-color:var(--line); border-bottom-color:var(--red); box-shadow:0 1px 0 var(--red); }
.select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2382858c' stroke-width='1.3' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 13px center; padding-right:32px; }
.field.bad .input,.field.bad .select{ border-bottom-color:var(--red); box-shadow:0 1px 0 var(--red); background:var(--red-soft); }
.field .er{ font-family:var(--mono); font-size:11px; color:var(--red); margin-top:6px; display:none; }
.field.bad .er{ display:block; }
.r2{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.choices{ display:flex; flex-wrap:wrap; gap:7px; }
.choice{ position:relative; }
.choice input{ position:absolute; inset:0; opacity:0; cursor:pointer; }
.choice span{ display:inline-flex; font-family:var(--display); font-size:13px; font-weight:300; padding:9px 14px; border:1px solid var(--line); color:var(--ink-2); background:#fff; transition:all .2s var(--ease); }
.choice input:checked + span{ border-color:var(--red); color:var(--red); background:var(--red-tint); }
.consent{ display:flex; gap:9px; align-items:flex-start; margin-top:18px; font-size:12.5px; font-weight:300; color:var(--muted); line-height:1.5; }
.consent input{ margin-top:3px; width:16px; height:16px; accent-color:var(--red); flex:none; }
.fnote{ font-family:var(--mono); font-size:10.5px; color:var(--faint); margin-top:14px; letter-spacing:.02em; }
.success{ display:none; padding:14px 4px; }
.success.show{ display:block; }
.success .ok{ width:50px; height:50px; border:1px solid var(--red); color:var(--red); display:flex; align-items:center; justify-content:center; }
.success h3{ margin-top:18px; }
.success p{ color:var(--ink-2); margin-top:8px; font-size:14.5px; font-weight:300; }
.route-pill{ display:inline-flex; align-items:center; gap:8px; margin-top:18px; font-family:var(--mono); font-size:11.5px; padding:9px 14px; border:1px solid var(--line); color:var(--ink); letter-spacing:.03em; }
.route-pill .d{ width:7px; height:7px; border-radius:50%; background:var(--red); }

/* ============================================================
   FOOTER + lead drawer + mobile cta
   ============================================================ */
.cta-final{ background:var(--ink); color:#fff; }
.cta-final .h-lg{ color:#fff; max-width:18ch; }
.cta-final .lead{ color:rgba(255,255,255,.66); max-width:560px; margin-top:24px; }
.cta-final .row{ display:flex; flex-wrap:wrap; gap:13px; margin-top:40px; }

.footer{ background:var(--ink); color:rgba(255,255,255,.6); padding:64px 0 40px; border-top:1px solid rgba(255,255,255,.1); }
.footer a:hover{ color:#fff; }
.footer__top{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.12); }
.footer .logo{ color:#fff; }
.footer h5{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.38); margin:0 0 16px; }
.footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; font-size:14px; font-weight:300; }
.footer__bot{ display:flex; justify-content:space-between; gap:16px; padding-top:24px; font-family:var(--mono); font-size:10.5px; color:rgba(255,255,255,.38); flex-wrap:wrap; letter-spacing:.03em; }

.scrim{ position:fixed; inset:0; z-index:90; background:rgba(18,19,22,.5); backdrop-filter:blur(3px); opacity:0; pointer-events:none; transition:opacity .4s var(--ease); }
.scrim.open{ opacity:1; pointer-events:auto; }
.lead-drawer{ position:fixed; top:0; right:0; bottom:0; z-index:95; width:min(460px,92vw); background:var(--w); transform:translateX(100%); transition:transform .45s var(--ease); overflow:auto; padding:30px clamp(22px,3vw,36px) 40px; }
.lead-drawer.open{ transform:none; }
.lead-drawer .x{ position:absolute; top:22px; right:22px; width:40px; height:40px; border:1px solid var(--line); background:#fff; display:flex; align-items:center; justify-content:center; }

.mobcta{ position:fixed; left:0; right:0; bottom:0; z-index:70; display:none; gap:10px; padding:11px var(--gut) calc(11px + env(safe-area-inset-bottom)); background:rgba(255,255,255,.94); backdrop-filter:blur(12px); border-top:1px solid var(--line); }
.mobcta .btn{ flex:1; }

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); filter:blur(6px); transition:opacity 1s var(--ease), transform 1s var(--ease), filter 1s var(--ease); }
.reveal.in{ opacity:1; transform:none; filter:blur(0); }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; } .reveal.d5{ transition-delay:.4s; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; filter:none; transition:none; }
  .hero__video{ opacity:1; transform:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero{ min-height:auto; }
  .hero__right{ min-height:48vh; order:-1; }
  .pos__in,.train{ grid-template-columns:1fr; }
  .appmap{ grid-template-columns:1fr; gap:24px; }
  .am__nav{ flex-direction:row; flex-wrap:wrap; gap:8px; }
  .am__nav .it{ border:1px solid var(--line); padding:11px 15px; font-size:15px; }
  .am__nav .it:last-child{ border-bottom:1px solid var(--line); }
  .am__nav .it.active{ padding-left:15px; border-color:var(--red); }
  .mh,.fit{ grid-template-columns:1fr 1fr; }
  .eco__ring{ grid-template-columns:repeat(3,1fr); }
  .impact{ grid-template-columns:1fr 1fr; }
  .why .prow{ grid-template-columns:1fr; gap:16px; }
}
@media (max-width:760px){
  body{ font-size:16px; }
  .nav__links{ display:none; }
  .nav__cta .btn--ink{ display:none; }
  .burger{ display:flex; }
  .sl{ grid-template-columns:1fr; }
  .mh,.fit,.impact{ grid-template-columns:1fr; }
  .am__panel.active{ grid-template-columns:1fr; }
  .flow{ grid-template-columns:1fr; }
  .flow .fnode{ border-right:0; border-bottom:1px solid var(--line); }
  .flow .fnode .arrow{ right:50%; top:auto; bottom:-9px; transform:translateX(50%) rotate(90deg); }
  .conf__grid{ grid-template-columns:1fr; }
  .eco__core{ grid-template-columns:1fr; }
  .eco__ring{ grid-template-columns:repeat(2,1fr); }
  .enode:nth-child(2n){ border-right:0; }
  .srow{ grid-template-columns:1fr; gap:10px; }
  .mobcta{ display:flex; }
  .footer__top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:440px){
  .footer__top{ grid-template-columns:1fr; }
  .r2{ grid-template-columns:1fr; }
  .eco__ring{ grid-template-columns:1fr; }
  .enode{ border-right:0; }
}

/* ============================================================
   ADD · POSITIONING media — ambient float + reflective shimmer
   ============================================================ */
.pos__media{ will-change:transform; }
.reveal.in .pos__media{ animation:posFloat 9s ease-in-out 1.5s infinite; }
@keyframes posFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-7px); } }
.pos__media::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(105deg, transparent 38%, rgba(255,255,255,.42) 50%, transparent 62%);
  transform:translateX(-130%); opacity:0;
}
.reveal.in .pos__media::before{ animation:posShimmer 8s ease-in-out 2.2s infinite; }
@keyframes posShimmer{
  0%{ transform:translateX(-130%); opacity:0; }
  10%{ opacity:1; }
  38%{ transform:translateX(130%); opacity:0; }
  100%{ transform:translateX(130%); opacity:0; }
}

/* ============================================================
   ADD · hero underline draw
   ============================================================ */
.ul-draw{
  background-image:linear-gradient(var(--red),var(--red));
  background-repeat:no-repeat; background-position:0 100%;
  background-size:0% 2px; padding-bottom:.07em;
  transition:background-size 1.2s var(--ease) .9s;
}
.hero.lit .ul-draw{ background-size:100% 2px; }
@media (prefers-reduced-motion:reduce){ .ul-draw{ background-size:100% 2px; transition:none; } }

/* ============================================================
   ADD · TRUST / NUMBERS / CREDIBILITY
   ============================================================ */
.trust{ position:relative; overflow:hidden; background:#fff; }
.trust__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.55; }
.trust__bg svg{ width:100%; height:100%; display:block; }
.trust__bg line{ stroke:var(--line); stroke-width:1; }
.trust__bg circle{ fill:#dcdbd7; }
.trust__bg .mol{ transform-origin:center; animation:molFloat 22s ease-in-out infinite; }
@keyframes molFloat{ 0%,100%{ transform:translate3d(0,0,0); } 50%{ transform:translate3d(14px,-14px,0); } }
.trust .wrap{ position:relative; z-index:1; }

.tnums{ display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.tnum{ background:#fff; padding:clamp(24px,2.2vw,34px); display:flex; flex-direction:column; min-height:230px; transition:background .4s var(--ease); }
.tnum:hover{ background:var(--paper); }
.tnum .big{ font-family:var(--display); font-weight:100; font-size:clamp(38px,4.4vw,66px); letter-spacing:-.045em; line-height:.9; color:var(--ink); }
.tnum .big sup{ font-size:.26em; font-weight:300; color:var(--red); vertical-align:super; margin-left:.12em; letter-spacing:0; }
.tnum .big.txt{ font-size:clamp(28px,3vw,46px); font-weight:200; letter-spacing:-.03em; }
.tnum .big .sl{ color:var(--faint); margin:0 .04em; font-weight:200; }
.tnum .tk{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--red); margin-top:auto; padding-top:20px; }
.tnum p{ font-size:13.5px; font-weight:300; color:var(--ink-2); margin-top:10px; line-height:1.5; }
.trust__note{ font-family:var(--mono); font-size:12px; color:var(--muted); letter-spacing:.03em; margin-top:clamp(26px,3vw,38px); }

/* ============================================================
   ADD · STIM / LIFT — hero product cards
   ============================================================ */
.slx-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.slx{ display:grid; grid-template-columns:minmax(0,200px) minmax(0,1fr); background:#fff; border:1px solid var(--line); overflow:hidden; outline:none; position:relative;
  transition:border-color .5s var(--ease), transform .6s var(--ease), box-shadow .6s var(--ease); }
.slx::after{ content:""; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--red); transform:scaleY(0); transform-origin:top; transition:transform .6s var(--ease); z-index:4; }
.slx:hover,.slx:focus-visible{ border-color:#dcdad5; transform:translateY(-5px); box-shadow:0 44px 90px -56px rgba(18,19,22,.45); }
.slx:hover::after,.slx:focus-visible::after{ transform:scaleY(1); }
.slx__media{ position:relative; overflow:hidden; background:linear-gradient(168deg,#ffffff,#eceae7); min-height:460px; }
.slx__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:68% 44%; filter:grayscale(.12) contrast(1.03); transform:translateY(0) scale(1.04); transition:transform .85s var(--ease); }
.slx:hover .slx__media img,.slx:focus-visible .slx__media img{ transform:translateY(-16px) scale(1.08); }
.slx__rib{ position:absolute; top:15px; left:15px; z-index:3; font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.slx__glow{ position:absolute; left:50%; bottom:-4%; transform:translateX(-50%); width:72%; height:48%; background:radial-gradient(ellipse at center bottom, rgba(178,31,44,.18), transparent 70%); opacity:0; transition:opacity .8s var(--ease); z-index:2; }
.slx:hover .slx__glow,.slx:focus-visible .slx__glow{ opacity:1; }
.slx__body{ padding:clamp(26px,2.6vw,40px); display:flex; flex-direction:column; }
.slx__name{ font-family:var(--display); font-weight:200; font-size:clamp(40px,4.2vw,62px); letter-spacing:-.05em; line-height:.92; display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; }
.slx__name .ml{ font-family:var(--mono); font-size:10.5px; font-weight:400; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.slx__rule{ height:1px; width:48px; background:var(--red); margin:18px 0; transition:width .6s var(--ease); }
.slx:hover .slx__rule,.slx:focus-visible .slx__rule{ width:96px; }
.slx__role{ font-size:16px; font-weight:300; color:var(--ink); max-width:30ch; }
.slx__block{ margin-top:24px; padding-top:20px; border-top:1px solid var(--line-2); }
.slx__block .bl{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:12px; }
.slx__fit{ list-style:none; margin:0; padding:0; display:grid; gap:9px; }
.slx__fit li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; font-weight:300; color:var(--ink-2); opacity:.78; transform:translateX(-4px); transition:opacity .5s var(--ease), transform .5s var(--ease); }
.slx:hover .slx__fit li,.slx:focus-visible .slx__fit li{ opacity:1; transform:none; }
.slx__fit li:nth-child(2){ transition-delay:.05s; }
.slx__fit li:nth-child(3){ transition-delay:.1s; }
.slx__fit li::before{ content:""; width:5px; height:5px; background:var(--red); margin-top:7px; flex:none; transform:rotate(45deg); }
.slx__biz{ font-size:14px; font-weight:300; color:var(--ink-2); line-height:1.6; }
.slx__foot{ margin-top:auto; padding-top:26px; }

@media (max-width:1080px){
  .tnums{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:860px){
  .slx-wrap{ grid-template-columns:1fr; }
  .slx{ grid-template-columns:minmax(0,220px) minmax(0,1fr); }
}
@media (max-width:640px){
  .tnums{ grid-template-columns:repeat(2,1fr); }
  .slx{ grid-template-columns:1fr; }
  .slx__media{ min-height:330px; }
  .slx__media img{ object-position:58% 26%; }
}
@media (prefers-reduced-motion:reduce){ .trust__bg .mol{ animation:none; } }

/* ============================================================
   ADD · AMBIENT MOTION LAYER
   ============================================================ */
/* particle-network canvases */
.pnet{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; }
.hero__right{ } .hero__right .pnet{ z-index:2; mix-blend-mode:screen; opacity:.85; }
.dark, .cta-final, .fusion{ position:relative; overflow:hidden; }
.dark .pnet, .cta-final .pnet{ z-index:0; opacity:.85; }
.fusion .pnet{ z-index:0; opacity:.7; }
.dark .wrap, .cta-final .wrap, .fusion .wrap{ position:relative; z-index:1; }

/* suffix on count-ups */
.suf{ color:var(--red); font-weight:200; }

/* trust stats — soft underline draw + glow pulse */
.tnum .big{ position:relative; }
.tnum .big::after{ content:""; position:absolute; left:0; bottom:-11px; height:2px; width:34px; background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .9s var(--ease); }
.reveal.in .tnum .big::after{ transform:scaleX(1); animation:statGlow 3.6s ease-in-out infinite 1.1s; }
@keyframes statGlow{ 0%,100%{ opacity:.45; } 50%{ opacity:1; } }

/* ============================================================
   ADD · ABOUT FUSION section
   ============================================================ */
.fusion{ background:var(--paper); }
.fusion__head{ max-width:780px; }
.fusion__head .lead{ margin-top:22px; max-width:640px; }
.fusion__flow{ position:relative; height:1px; background:var(--line); margin:clamp(34px,4vw,56px) 0 0; }
.fusion__flow .dot{ position:absolute; top:50%; left:0; width:7px; height:7px; border-radius:50%; background:var(--red); transform:translate(-50%,-50%); box-shadow:0 0 0 5px rgba(178,31,44,.08); animation:flowDot 6.5s var(--ease) infinite; }
@keyframes flowDot{ 0%{ left:0; opacity:0; } 8%{ opacity:1; } 92%{ opacity:1; } 100%{ left:100%; opacity:0; } }
.fnums{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:24px; }
.fnum{ background:var(--paper); padding:clamp(28px,3vw,46px); display:flex; flex-direction:column; min-height:200px; transition:background .4s var(--ease); }
.fnum:hover{ background:#fff; }
.fnum .big{ font-family:var(--display); font-weight:100; font-size:clamp(44px,5.4vw,82px); letter-spacing:-.05em; line-height:.9; color:var(--ink); display:flex; align-items:baseline; gap:.16em; }
.fnum .big .num{ display:inline-flex; align-items:baseline; }
.fnum .big .u{ font-weight:300; font-size:.24em; letter-spacing:.01em; color:var(--muted); }
.fnum .fk{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--red); margin-top:auto; padding-top:22px; }
.fusion__foot{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:20px; margin-top:clamp(26px,3vw,40px); }
.fusion__foot .chips{ display:flex; gap:10px; flex-wrap:wrap; }

/* ============================================================
   ADD · AUTO-CYCLE HIGHLIGHTS
   ============================================================ */
/* 3-layer message house */
.mh{ position:relative; }
.mh__beam{ position:absolute; top:0; left:0; right:0; height:2px; z-index:3; pointer-events:none; overflow:hidden; }
.mh__beam::before{ content:""; position:absolute; top:0; left:0; height:2px; width:30%; background:linear-gradient(90deg, transparent, var(--red), transparent); animation:beam 4.6s linear infinite; }
@keyframes beam{ 0%{ transform:translateX(-110%); } 100%{ transform:translateX(360%); } }
.mhcard{ position:relative; }
.mhcard::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .7s var(--ease); z-index:2; }
.mhcard.is-active::before{ transform:scaleX(1); }
.mhcard.is-active{ background:var(--paper); }
.mhcard.is-active .ix{ color:var(--red-soft); }

/* STIM / LIFT auto emphasis + scan line */
.slx__scan{ position:absolute; left:0; right:0; top:0; height:36%; z-index:3; pointer-events:none; opacity:0;
  background:linear-gradient(180deg, rgba(178,31,44,0), rgba(178,31,44,.12) 50%, rgba(178,31,44,0)); }
.slx.is-active .slx__scan{ animation:scan 2.8s var(--ease); }
@keyframes scan{ 0%{ opacity:0; transform:translateY(-40%); } 16%{ opacity:1; } 84%{ opacity:1; } 100%{ opacity:0; transform:translateY(300%); } }
.slx.is-active{ border-color:#dcdad5; }
.slx.is-active::after{ transform:scaleY(1); }
.slx.is-active .slx__media img{ transform:translateY(-10px) scale(1.05); }
.slx.is-active .slx__glow{ opacity:1; }
.slx.is-active .slx__rule{ width:84px; }
.slx.is-active .slx__fit li{ opacity:1; transform:none; }

/* customer fit breathing + signal node */
.fitcard{ position:relative; }
.fitcard::after{ content:""; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--red); transform:scaleY(0); transform-origin:top; transition:transform .6s var(--ease); }
.fitcard.is-active::after{ transform:scaleY(1); }
.fitcard.is-active{ background:var(--paper); }
.fitcard .seg::after{ content:""; display:inline-block; width:5px; height:5px; border-radius:50%; background:var(--faint); margin-left:9px; vertical-align:middle; transition:background .4s var(--ease); }
.fitcard.is-active .seg::after{ background:var(--red); animation:nodePulse 1.7s ease-in-out infinite; }
@keyframes nodePulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(178,31,44,.5); } 70%{ box-shadow:0 0 0 7px rgba(178,31,44,0); } }

/* application map — sliding indicator */
.am__nav{ position:relative; }
.am__ind{ position:absolute; left:0; top:0; width:2px; height:0; background:var(--red); opacity:0; z-index:2; transition:top .45s var(--ease), left .45s var(--ease), width .45s var(--ease), height .45s var(--ease), opacity .3s; }

@media (max-width:860px){ .fnums{ grid-template-columns:1fr 1fr; } }

@media (prefers-reduced-motion:reduce){
  .pnet{ display:none; }
  .fusion__flow .dot, .mh__beam::before, .slx.is-active .slx__scan, .fitcard.is-active .seg::after, .reveal.in .tnum .big::after,
  .reveal.in .pos__media, .reveal.in .pos__media::before, .trust__bg .mol{ animation:none; }
}
