/* =====================================================================
   SPLATOO — mini design framework
   Tokens (fluid, clamp-based) · BEM components · utilities
   Naming: .block, .block__element, .block--modifier, state .is-*
   Legacy class names are kept as aliases during migration and will be
   removed once all markup is on BEM.
   ===================================================================== */

@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Space+Grotesk:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap");

/* ------------------------------------------------------------------ */
/* 1. TOKENS                                                           */
/* ------------------------------------------------------------------ */
:root{
  /* color — surfaces */
  --c-bg:#060807;
  --c-surface:#0b0e0d;
  --c-surface-2:#0f1312;
  --c-raised:#161b19;
  /* color — ink */
  --c-ink:#F4F5F2;
  --c-ink-2:rgba(244,245,242,.64);
  --c-ink-3:rgba(244,245,242,.4);
  --c-ink-4:rgba(244,245,242,.22);
  /* color — lines */
  --c-line:rgba(244,245,242,.1);
  --c-line-2:rgba(244,245,242,.18);
  /* color — accent */
  --c-accent:#C8FA1E;
  --c-accent-soft:rgba(200,250,30,.4);
  --c-accent-12:rgba(200,250,30,.12);
  --c-accent-06:rgba(200,250,30,.06);
  --c-on-accent:#07140A;          /* ink on lime buttons */
  --c-ink-on-accent:#070a05;      /* headings on lime band */
  --c-ink-on-accent-2:rgba(8,12,5,.74);

  /* typography families */
  --font-display:"Space Grotesk",sans-serif;
  --font-sans:"Manrope",sans-serif;
  --font-mono:"JetBrains Mono",monospace;

  /* typography — fluid scale (clamp: min, preferred, max) */
  --fs-hero:clamp(2.75rem,1.55rem + 5.9vw,5.75rem);    /* 44 → 92 */
  --fs-h1:clamp(2.375rem,1.5rem + 4.4vw,4.5rem);       /* 38 → 72 */
  --fs-h2:clamp(1.875rem,1.35rem + 2.5vw,3.25rem);     /* 30 → 52 */
  --fs-h2-sm:clamp(1.75rem,1.4rem + 1.8vw,2.875rem);   /* 28 → 46 */
  --fs-h3:clamp(1.25rem,1.1rem + .7vw,1.5rem);         /* 20 → 24 */
  --fs-lead:clamp(1.0625rem,1rem + .55vw,1.25rem);     /* 17 → 20 */
  --fs-body:1rem;                                      /* 16 */
  --fs-sm:.875rem;                                     /* 14 */
  --fs-xs:.8125rem;                                    /* 13 */
  --fs-eyebrow:.6875rem;                               /* 11 */
  --fs-mono:.625rem;                                   /* 10 */

  /* spacing scale */
  --space-3xs:.25rem; --space-2xs:.5rem; --space-xs:.75rem;
  --space-sm:1rem; --space-md:1.5rem; --space-lg:2rem;
  --space-xl:3rem; --space-2xl:4rem; --space-3xl:6rem;
  --space-section:clamp(4.5rem,3rem + 7vw,8.125rem);   /* 72 → 130 */
  --space-gutter:clamp(1.5rem,1rem + 2.4vw,3rem);      /* 24 → 48 */

  /* radii / borders / motion / layout */
  --radius:0;
  --ease:cubic-bezier(.22,1,.36,1);
  --container:1240px;
  --rail-w:64px;
  --header-h:72px;

  /* z-index scale */
  --z-rail:60; --z-toolbar:40; --z-fly:70;

  /* ---- legacy aliases (kept until migration completes) ---- */
  --lime:var(--c-accent); --bg:var(--c-bg); --panel:var(--c-surface);
  --panel2:var(--c-surface-2); --raised:var(--c-raised);
  --fg:var(--c-ink); --fg2:var(--c-ink-2); --fg3:var(--c-ink-3); --fg4:var(--c-ink-4);
  --border:var(--c-line); --border2:var(--c-line-2); --limeb:var(--c-accent-soft);
  --display:var(--font-display); --sans:var(--font-sans); --mono:var(--font-mono);
  --max:var(--container);
}

/* ------------------------------------------------------------------ */
/* 2. BASE                                                             */
/* ------------------------------------------------------------------ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--c-bg);color:var(--c-ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;padding-top:var(--header-h)}
body:has(.shell-rail){padding-left:var(--rail-w)}
a{color:inherit;text-decoration:none}
h1{font-family:var(--font-display);font-weight:500;letter-spacing:-.035em;line-height:.98}
h2{font-family:var(--font-display);font-weight:500;letter-spacing:-.025em;line-height:1.02}
h3{font-family:var(--font-display);font-weight:500;letter-spacing:-.01em}
p{line-height:1.6}

/* ------------------------------------------------------------------ */
/* 3. LAYOUT PRIMITIVES                                                */
/* ------------------------------------------------------------------ */
.container,.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--space-gutter)}
.section,section{padding:var(--space-section) 0}

/* ------------------------------------------------------------------ */
/* 4. UTILITIES                                                        */
/* ------------------------------------------------------------------ */
.u-accent,.lime{color:var(--c-accent)}
.u-center{text-align:center}

/* ------------------------------------------------------------------ */
/* 5. COMPONENTS                                                       */
/* ------------------------------------------------------------------ */

/* eyebrow ---------------------------------------------------------- */
.eyebrow{font-family:var(--font-mono);font-size:var(--fs-eyebrow);letter-spacing:.26em;text-transform:uppercase;color:var(--c-accent);display:inline-flex;align-items:center;gap:14px}
.eyebrow__line,.eyebrow .ln{height:1px;width:36px;background:var(--c-accent-soft)}

/* button ----------------------------------------------------------- */
.btn{font-family:var(--font-sans);font-weight:600;font-size:var(--fs-sm);border:0;cursor:pointer;padding:14px 26px;background:var(--c-accent);color:var(--c-on-accent);transition:.2s var(--ease);display:inline-flex;align-items:center;gap:9px}
.btn:hover{box-shadow:0 0 26px var(--c-accent-soft);transform:translateY(-1px)}
.btn--ghost,.btn-ghost{background:transparent;color:var(--c-ink);border:1px solid var(--c-line-2)}
.btn--ghost:hover,.btn-ghost:hover{border-color:var(--c-accent);color:var(--c-accent);box-shadow:none;transform:none}
.btn--sm,.btn-sm{padding:9px 18px;font-size:12px}

/* text link -------------------------------------------------------- */
.text-link,.txtlink{color:var(--c-ink-2);display:inline-flex;gap:8px;font-size:var(--fs-sm);transition:.2s var(--ease)}
.text-link:hover,.txtlink:hover{color:var(--c-ink)}

/* logo ------------------------------------------------------------- */
.logo{font-family:var(--font-display);font-weight:600;font-size:20px;display:inline-flex;align-items:center;line-height:0}
.logo b{color:var(--c-accent)}
.logo__img,.logo-img{height:25px;width:auto;display:block}

/* shared "sub" lead paragraph ------------------------------------- */
.sub{color:var(--c-ink-2);line-height:1.55}

/* toolbar (top bar) — full-width fixed header --------------------- */
.toolbar{position:fixed;top:0;left:0;right:0;z-index:var(--z-rail);display:flex;align-items:center;justify-content:space-between;height:var(--header-h);padding:0 28px;border-bottom:1px solid var(--c-line);background:rgba(6,8,7,.9);backdrop-filter:blur(12px)}
.toolbar__left,.tl{display:flex;align-items:center;gap:28px}
.toolbar__right,.tr{display:flex;align-items:center;gap:18px}
.toolbar__lang,.lang{font-family:var(--font-mono);font-size:12px;color:var(--c-ink-3);letter-spacing:.1em}

/* nav segmented (in toolbar) -------------------------------------- */
.nav,.seg{display:flex;border:1px solid var(--c-line)}
.nav__link,.seg a{font-size:13px;color:var(--c-ink-2);padding:10px 20px;border-right:1px solid var(--c-line);transition:.2s var(--ease)}
.nav__link:last-child,.seg a:last-child{border-right:0}
.nav__link:hover,.seg a:hover{color:var(--c-ink)}
.nav__link.is-active,.nav__link.on,.seg a.on{background:var(--c-raised);color:var(--c-ink)}

/* shell rail (fixed left) ----------------------------------------- */
.shell-rail{position:fixed;left:0;top:var(--header-h);bottom:0;width:var(--rail-w);background:var(--c-surface);border-right:1px solid var(--c-line);z-index:var(--z-toolbar);display:flex;flex-direction:column;align-items:center;padding:18px 0 18px;gap:6px}
.shell-rail__tool,.rtool{position:relative;width:46px;height:46px;display:flex;align-items:center;justify-content:center;color:var(--c-ink-3);cursor:pointer;border:1px solid transparent;background:transparent;transition:.16s var(--ease);text-decoration:none}
.shell-rail__tool svg,.rtool svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.6}
.shell-rail__tool:hover,.rtool:hover{color:var(--c-ink)}
.shell-rail__tool.is-active,.shell-rail__tool.on,.rtool.on{color:var(--c-accent);border-color:var(--c-accent-soft);background:var(--c-accent-06)}
.shell-rail__tool--cta,.rtool.rcta{color:var(--c-accent)}
.shell-rail__spacer,.shell-rail .sp{flex:1}
.shell-rail__tool[data-tip]::after,.rtool[data-tip]::after{content:attr(data-tip);position:absolute;left:46px;top:50%;transform:translateY(-50%);background:var(--c-raised);border:1px solid var(--c-line-2);color:var(--c-ink);font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.12em;text-transform:uppercase;padding:6px 10px;white-space:nowrap;opacity:0;pointer-events:none;transition:.15s var(--ease);z-index:var(--z-fly)}
.shell-rail__tool:hover::after,.rtool:hover::after{opacity:1}
.shell-rail__fly,.rflywrap .rfly{position:absolute;left:46px;top:0;background:rgba(8,10,9,.97);backdrop-filter:blur(8px);border:1px solid var(--c-line-2);min-width:184px;padding:6px;opacity:0;pointer-events:none;transform:translateX(-6px);transition:.18s var(--ease);z-index:var(--z-fly)}
.shell-rail__group:hover .shell-rail__fly,.rflywrap:hover .rfly{opacity:1;pointer-events:auto;transform:none}
.shell-rail__group:hover::after,.rflywrap:hover::after{opacity:0}
.shell-rail__fly a,.rfly a{display:block;font-family:var(--font-sans);font-size:13px;color:var(--c-ink-2);padding:9px 12px}
.shell-rail__fly a:hover,.rfly a:hover{color:var(--c-ink);background:var(--c-raised)}

/* page hero -------------------------------------------------------- */
.hero,.phero{padding:var(--space-section) 0;position:relative;overflow:hidden}
/* soft lime glow behind the headline — all page heroes */
.hero::before,.phero::before,.ghero::before,.contact-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(70% 60% at 26% 30%,var(--c-accent-12),transparent 62%)}
/* film grain texture (SVG fractal noise) — all page heroes */
.hero::after,.phero::after,.ghero::after,.contact-hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:140px 140px}
.hero__grid,.gridbg{position:absolute;inset:0;background:repeating-linear-gradient(0deg,var(--c-accent-06) 0 1px,transparent 1px 52px),repeating-linear-gradient(90deg,var(--c-accent-06) 0 1px,transparent 1px 52px);mask-image:radial-gradient(120% 90% at 70% 0,#000,transparent 70%);z-index:1}
.hero .container,.hero .wrap,.phero .wrap{position:relative;z-index:2}
.hero__title,.hero h1,.phero h1{font-size:var(--fs-hero);margin-top:24px;max-width:14ch}
.hero__sub,.hero .sub,.phero .sub{color:var(--c-ink-2);font-size:var(--fs-lead);line-height:1.55;margin-top:26px;max-width:560px}
.hero__cta,.hero .cta,.phero .cta{display:flex;align-items:center;gap:22px;margin-top:38px}

/* interactive flow-line divider (canvas) -------------------------- */
.flowline{display:block}
.pageline{width:100%;height:40px;margin:-20px 0;position:relative;z-index:5;pointer-events:none}

/* section head ----------------------------------------------------- */
.section-head,.shead{max-width:680px;margin-bottom:60px}
.section-head__title,.section-head h2,.shead h2{font-size:var(--fs-h2-sm);margin-top:24px}
.section-head__sub,.section-head .sub,.shead .sub{color:var(--c-ink-2);font-size:18px;line-height:1.6;margin-top:22px}

/* grids ------------------------------------------------------------ */
.grid-3,.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid-2,.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}

/* card ------------------------------------------------------------- */
.card{border:1px solid var(--c-line);background:var(--c-surface);padding:30px 28px 34px;transition:.2s var(--ease)}
.card:hover{border-color:var(--c-line-2)}
.card__index,.card .idx{font-family:var(--font-mono);font-size:12px;color:var(--c-accent);letter-spacing:.14em}
.card__title,.card h3{font-size:20px;margin:16px 0 12px}
.card__text,.card p{color:var(--c-ink-2);font-size:var(--fs-sm)}

/* tile (image card) ------------------------------------------------ */
.tile{position:relative;aspect-ratio:16/11;border:1px solid var(--c-line);overflow:hidden;background:var(--c-surface-2);cursor:pointer;transition:.22s var(--ease)}
.tile:hover{border-color:var(--c-line-2)}
.tile__overlay,.tile .ovl{position:absolute;inset:0;background:linear-gradient(0deg,rgba(6,8,7,.92) 8%,rgba(6,8,7,.15) 60%,transparent);z-index:2}
.tile__meta,.tile .meta{position:absolute;left:20px;right:20px;bottom:18px;z-index:3}
.tile__name,.tile .nm{font-family:var(--font-display);font-weight:500;font-size:20px;letter-spacing:-.01em}
.tile__badge,.tile .bn{color:var(--c-ink-2);font-size:13px;margin-top:6px;line-height:1.4}
.tile__cta,.tile .go{font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--c-accent);margin-top:14px;display:flex;align-items:center;gap:7px;opacity:0;transform:translateY(6px);transition:.22s var(--ease)}
.tile:hover .tile__cta,.tile:hover .go{opacity:1;transform:none}

/* coming-soon card — inverse lime ---------------------------------- */
.coming{grid-column:span 2;border:0;background:var(--c-accent);color:var(--c-ink-on-accent);display:flex;flex-direction:column;justify-content:center;padding:36px 40px;position:relative;overflow:hidden}
.coming__tag,.coming .cmtag{font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.18em;text-transform:uppercase;color:#0a0e06;position:relative;z-index:1}
.coming__title,.coming h3{font-family:var(--font-display);font-weight:500;font-size:24px;margin:12px 0 8px;letter-spacing:-.01em;color:var(--c-ink-on-accent);position:relative;z-index:1}
.coming__text,.coming p{color:var(--c-ink-on-accent-2);font-size:var(--fs-sm);line-height:1.55;margin-bottom:20px;max-width:440px;position:relative;z-index:1}
.coming__form,.cmform{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1}
.coming__form input,.cmform input{background:rgba(8,12,5,.06);border:1px solid rgba(8,12,5,.28);color:#0a0e06;font-family:var(--font-sans);font-size:var(--fs-sm);padding:13px 15px;outline:none;min-width:240px;transition:.18s var(--ease)}
.coming__form input::placeholder,.cmform input::placeholder{color:rgba(8,12,5,.5)}
.coming__form input:focus,.cmform input:focus{border-color:#0a0e06;background:rgba(8,12,5,.1)}
.coming .btn{background:#080b05;color:#f4f5f2;border:1px solid #080b05}
.coming .btn:hover{background:#1b2113;color:#fff;box-shadow:none}

/* form ------------------------------------------------------------- */
.form{display:flex;flex-direction:column;gap:12px}
.form input,.form textarea,.form select{background:var(--c-bg);border:1px solid var(--c-line-2);color:var(--c-ink);font-family:var(--font-sans);font-size:var(--fs-sm);padding:13px 15px;outline:none;transition:.18s var(--ease)}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--c-accent)}
.form__row,.form .two{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* media panel (placeholder framed slot) --------------------------- */
.media-panel{position:relative;border:1px solid var(--c-line-2);background:radial-gradient(120% 120% at 50% 40%,var(--c-accent-12),transparent 60%),var(--c-surface-2)}
.media-panel__cap{position:absolute;left:16px;bottom:14px;font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--c-ink-3)}

/* footer ----------------------------------------------------------- */
.footer{border-top:1px solid var(--c-line);background:var(--c-surface)}
.footer__grid,.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:64px 0 48px}
.footer__col,.fcol{}
.footer__col h5,.fcol h5{font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--c-ink-3);margin-bottom:18px}
.footer__col a,.fcol a{display:block;color:var(--c-ink-2);font-size:var(--fs-sm);margin-bottom:11px;transition:.18s var(--ease)}
.footer__col a:hover,.fcol a:hover{color:var(--c-ink)}
.footer__col--brand,.fbrand{}
.footer__col--brand .logo,.fbrand .logo{font-size:20px;margin-bottom:16px}
.footer__col--brand .logo__img,.fbrand .logo-img{height:26px}
.footer__col--brand p,.fbrand p{color:var(--c-ink-3);font-size:13px;line-height:1.6;max-width:240px}
.footer__bottom,.fbot{display:flex;justify-content:space-between;padding:22px 0;border-top:1px solid var(--c-line);font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--c-ink-4)}

/* ------------------------------------------------------------------ */
/* 6. SCENE HERO (interactive use-case hero, themed iframe)            */
/* ------------------------------------------------------------------ */
.scene-hero,.uhero{position:relative;height:calc(100vh - var(--header-h));min-height:560px;overflow:hidden;border-bottom:1px solid var(--c-line);background:#05070a}
.scene-hero__frame,.uhero .frame{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;background:#05070a;z-index:1}
.scene-hero__scrim,.uhero .scrim{position:absolute;inset:0;background:radial-gradient(130% 120% at 0% 100%,rgba(6,8,7,.95) 0%,rgba(6,8,7,.72) 26%,rgba(6,8,7,.3) 48%,transparent 64%);z-index:2;pointer-events:none}
.scene-hero__corner,.uhero .corner{position:absolute;width:15px;height:15px;border:1.5px solid var(--c-accent);z-index:3;pointer-events:none}
.uhero .corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}.uhero .corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.uhero .corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}.uhero .corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.scene-hero__top,.uhero .vtop{position:absolute;top:18px;left:40px;right:130px;display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--c-ink-3);z-index:3;pointer-events:none}
.uhero .vtop .d{display:inline-block;width:6px;height:6px;background:var(--c-accent);margin-right:7px;vertical-align:1px;animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.2}}
.scene-hero__panel,.uhero .panel{position:absolute;left:48px;bottom:48px;max-width:620px;z-index:5;pointer-events:none}
.uhero .panel .btn,.uhero .panel .txtlink{pointer-events:auto}
.uhero .panel h1{font-family:var(--font-display);font-weight:500;font-size:clamp(38px,4.6vw,72px);line-height:.98;letter-spacing:-.035em;margin-top:18px}
.uhero .panel h1 .lime{color:var(--c-accent)}
.uhero .panel .sub{margin-top:18px;color:var(--c-ink);font-size:18px;line-height:1.5;max-width:480px}
.uhero .panel .cta{display:flex;align-items:center;gap:22px;margin-top:30px}

/* ------------------------------------------------------------------ */
/* 7. CTA BAND (inverse lime)                                          */
/* ------------------------------------------------------------------ */
.cta-band,section.cta-lime{position:relative;background:var(--c-accent);color:var(--c-ink-on-accent);border:0}
.cta-band .eyebrow,section.cta-lime .eyebrow{color:#0a0e06}
.cta-band .eyebrow__line,.cta-band .eyebrow .ln,section.cta-lime .eyebrow .ln{background:#0a0e06;opacity:.55}
.cta-band h2,section.cta-lime h2{color:var(--c-ink-on-accent)}
.cta-band p,.cta-band .sub,section.cta-lime p,section.cta-lime .sub{color:var(--c-ink-on-accent-2)}
.cta-band .btn,section.cta-lime .btn{background:#080b05;color:#f4f5f2;border:1px solid #080b05}
.cta-band .btn:hover,section.cta-lime .btn:hover{background:#1b2113;color:#fff}
.cta-band .btn--ghost,.cta-band .btn-ghost,section.cta-lime .btn-ghost{background:transparent;color:#080b05;border:1px solid rgba(8,12,5,.42)}
.cta-band .btn--ghost:hover,.cta-band .btn-ghost:hover,section.cta-lime .btn-ghost:hover{background:rgba(8,12,5,.09);color:#080b05}
.cta-band .form input,.cta-band .form textarea,section.cta-lime .form input,section.cta-lime .form textarea{background:rgba(8,12,5,.05);border:1px solid rgba(8,12,5,.26);color:#0a0e06}
.cta-band .form input::placeholder,.cta-band .form textarea::placeholder,section.cta-lime .form input::placeholder,section.cta-lime .form textarea::placeholder{color:rgba(8,12,5,.5)}
.cta-band .form input:focus,.cta-band .form textarea:focus,section.cta-lime .form input:focus,section.cta-lime .form textarea:focus{border-color:#0a0e06;background:rgba(8,12,5,.08)}

/* ------------------------------------------------------------------ */
/* 8. RESPONSIVE                                                       */
/* ------------------------------------------------------------------ */
@media(max-width:1000px){
  .grid-3,.g3{grid-template-columns:1fr 1fr}
  .footer__grid,.fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{padding-left:0}
  .rail,.shell-rail{display:none}
  .coming{grid-column:span 1}
  .coming__form input,.cmform input{min-width:0;flex:1}
}
@media(max-width:640px){
  .grid-3,.g3,.grid-2,.g2{grid-template-columns:1fr}
}

/* TOC scrollspy active state */
.toc a.is-active{color:var(--c-accent)}
.lnav a.is-active{color:var(--c-ink);border-color:var(--c-accent)}

/* ------------------------------------------------------------------ */
/* 9. MOTION — FOUC-safe pre-hide for GSAP reveals                     */
/*    (only when motion is allowed; JS removes .motion if GSAP fails)  */
/* ------------------------------------------------------------------ */
@media (prefers-reduced-motion:no-preference){
  html.motion .hero>.container>*, html.motion .phero>.container>*,
  html.motion .ghero>.container>*, html.motion .uhero .panel>*,
  html.motion .section-head, html.motion .card, html.motion .tile,
  html.motion .coming, html.motion .steps li, html.motion .compare,
  html.motion .split, html.motion .refs li, html.motion .footer__col,
  html.motion .embed, html.motion .media-panel, html.motion .lane, html.motion .srow{
    opacity:0;transform:translateY(14px)
  }
}
