/*
 * SOS Live 2.0 Homepage — Editorial Edition 2.0
 * All selectors are namespaced to .sos2 to prevent theme/Elementor collisions.
 */
.sos2 {
  --sos2-navy: #092A4C;
  --sos2-blue: #0057C8;
  --sos2-orange: #FF5A1F;
  --sos2-gold: #D9A441;
  --sos2-white: #FFFFFF;
  --sos2-container: 1320px;
  --sos2-ink: var(--sos2-navy);
  --sos2-muted: color-mix(in srgb, var(--sos2-navy) 68%, var(--sos2-white));
  --sos2-line: color-mix(in srgb, var(--sos2-navy) 14%, transparent);
  --sos2-soft: color-mix(in srgb, var(--sos2-blue) 6%, var(--sos2-white));
  --sos2-dark-soft: color-mix(in srgb, var(--sos2-navy) 88%, var(--sos2-blue));
  --sos2-shadow-sm: 0 12px 32px rgba(2, 21, 40, .10);
  --sos2-shadow-md: 0 24px 70px rgba(2, 21, 40, .16);
  --sos2-shadow-lg: 0 42px 110px rgba(2, 21, 40, .28);
  width: 100%;
  min-width: 0;
  overflow: clip;
  color: var(--sos2-ink);
  background: var(--sos2-white);
  font-family: "Montserrat", "Avenir Next", Avenir, "Segoe UI", Arial, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  isolation: isolate;
}
.sos2,
.sos2 *,
.sos2 *::before,
.sos2 *::after { box-sizing: border-box; }
.sos2 img { display: block; max-width: 100%; }
.sos2 a { color: inherit; text-decoration: none; }
.sos2 button,
.sos2 input,
.sos2 textarea,
.sos2 select { font: inherit; }
.sos2 button { cursor: pointer; }
.sos2 h1,
.sos2 h2,
.sos2 h3,
.sos2 h4,
.sos2 p,
.sos2 ul { margin-top: 0; }
.sos2 ul { padding-left: 0; }
.sos2 svg {
  width: 1em;
  height: 1em;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.sos2-container { width: min(calc(100% - 64px), var(--sos2-container)); margin-inline: auto; }
.sos2-anchor { position: absolute; top: -105px; }
.sos2-section { position: relative; padding-block: clamp(92px, 9vw, 150px); }
.sos2-skip-link {
  position: fixed; z-index: 100000; top: 12px; left: 12px; transform: translateY(-180%);
  padding: 11px 16px; border-radius: 6px; color: var(--sos2-white) !important;
  background: var(--sos2-orange); font-size: .78rem; font-weight: 800; transition: transform .18s ease;
}
.sos2-skip-link:focus { transform: translateY(0); }
.sos2 a:focus-visible,
.sos2 button:focus-visible { outline: 3px solid var(--sos2-gold); outline-offset: 4px; }

/* Shared typography and controls */
.sos2-eyebrow {
  display: inline-flex; align-items: center; gap: 14px; margin-bottom: 22px;
  color: var(--sos2-orange); font-size: .68rem; font-weight: 800; line-height: 1.25;
  letter-spacing: .14em; text-transform: uppercase;
}
.sos2-eyebrow::after { content: ""; width: 44px; height: 2px; background: currentColor; }
.sos2-eyebrow--dark { color: var(--sos2-orange); }
.sos2-eyebrow--hero { color: var(--sos2-orange); }
.sos2-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.sos2-button {
  display: inline-flex; min-height: 52px; align-items: center; justify-content: center; gap: 11px;
  padding: 14px 22px; border: 1px solid transparent; border-radius: 999px;
  font-size: .78rem; font-weight: 800; line-height: 1.15; letter-spacing: -.01em;
  transition: transform .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.sos2-button svg { flex: 0 0 auto; font-size: 1.28em; transition: transform .2s ease; }
.sos2-button:hover { transform: translateY(-2px); }
.sos2-button:hover svg { transform: translateX(4px); }
.sos2-button--orange { color: var(--sos2-white) !important; background: var(--sos2-orange); box-shadow: 0 14px 34px color-mix(in srgb, var(--sos2-orange) 26%, transparent); }
.sos2-button--orange:hover { color: var(--sos2-navy) !important; background: var(--sos2-white); }
.sos2-button--glass { color: var(--sos2-white) !important; border-color: rgba(255,255,255,.38); background: rgba(255,255,255,.08); backdrop-filter: blur(14px); }
.sos2-button--glass:hover { border-color: var(--sos2-white); background: rgba(255,255,255,.16); }
.sos2-button--white { color: var(--sos2-navy) !important; background: var(--sos2-white); box-shadow: 0 16px 40px rgba(0,0,0,.16); }
.sos2-button--white:hover { color: var(--sos2-white) !important; border-color: var(--sos2-white); background: transparent; }
.sos2-text-link {
  display: inline-flex; align-items: center; gap: 9px; color: var(--sos2-blue) !important;
  font-size: .8rem; font-weight: 800; line-height: 1.4;
}
.sos2-text-link svg { font-size: 1.22em; transition: transform .2s ease; }
.sos2-text-link:hover svg { transform: translateX(4px); }
.sos2-text-link--light { color: var(--sos2-white) !important; }
.sos2-text-link--orange { color: var(--sos2-orange) !important; }

/* Header — minimal, editorial, high confidence */
.sos2-site-chrome {
  position: sticky; z-index: 9000; top: 0; color: var(--sos2-white); background: var(--sos2-navy);
  box-shadow: 0 8px 26px rgba(2,21,40,.15);
}
.admin-bar .sos2 .sos2-site-chrome { top: 32px; }
.sos2-utility { min-height: 30px; border-bottom: 1px solid rgba(255,255,255,.10); background: color-mix(in srgb, var(--sos2-navy) 92%, black); }
.sos2-utility__inner { display: flex; min-height: 30px; align-items: center; justify-content: space-between; gap: 24px; }
.sos2-utility__inner > span,
.sos2-utility__inner a { display: inline-flex; align-items: center; gap: 7px; color: rgba(255,255,255,.68); font-size: .57rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.sos2-utility__inner > span i { width: 7px; height: 7px; border-radius: 50%; background: var(--sos2-orange); box-shadow: 0 0 0 4px color-mix(in srgb, var(--sos2-orange) 18%, transparent); }
.sos2-utility__inner > div { display: flex; gap: 22px; }
.sos2-utility__inner a:hover { color: var(--sos2-white); }
.sos2-utility__inner svg { font-size: 1.1em; }
.sos2-header { position: relative; border-bottom: 3px solid var(--sos2-orange); background: var(--sos2-navy); }
.sos2-header__inner { display: flex; min-height: 82px; align-items: center; gap: 30px; }
.sos2-brand { display: inline-flex; width: 236px; flex: 0 0 auto; align-items: center; }
.sos2-brand img { width: 100%; height: auto; }
.sos2-nav { display: flex; flex: 1 1 auto; align-items: center; justify-content: flex-end; }
.sos2-nav__list { display: flex; align-items: center; gap: 2px; margin: 0; padding: 0; list-style: none; }
.sos2-nav__item { position: relative; }
.sos2-nav__trigger,
.sos2-nav__link {
  display: inline-flex; min-height: 44px; align-items: center; gap: 7px; padding: 10px 12px;
  border: 0; border-radius: 999px; color: rgba(255,255,255,.82); background: transparent;
  font-size: .72rem; font-weight: 700; line-height: 1; transition: color .17s ease, background-color .17s ease;
}
.sos2-nav__trigger svg { font-size: 1.06em; transition: transform .18s ease; }
.sos2-nav__trigger:hover,
.sos2-nav__link:hover,
.sos2-nav__trigger[aria-expanded="true"] { color: var(--sos2-white); background: rgba(255,255,255,.08); }
.sos2-nav__trigger[aria-expanded="true"] svg { transform: rotate(180deg); }
.sos2-header__cta { min-height: 44px; margin-left: 4px; padding: 11px 18px; font-size: .7rem; flex: 0 0 auto; }
.sos2-menu-toggle { display: none; width: 46px; height: 46px; align-items: center; justify-content: center; margin-left: auto; border: 1px solid rgba(255,255,255,.28); border-radius: 50%; color: var(--sos2-white); background: transparent; }
.sos2-menu-toggle svg { font-size: 1.4rem; }
.sos2-menu-toggle__close { display: none; }
.sos2-menu-toggle[aria-expanded="true"] .sos2-menu-toggle__open { display: none; }
.sos2-menu-toggle[aria-expanded="true"] .sos2-menu-toggle__close { display: inline-flex; }
.sos2-nav__mobile-cta { display: none; }
.sos2-mega {
  position: absolute; z-index: 70; top: calc(100% + 18px); left: 50%; visibility: hidden;
  width: 620px; padding: 28px; transform: translate(-50%, -8px); border: 1px solid var(--sos2-line);
  border-radius: 18px; color: var(--sos2-navy); background: var(--sos2-white); box-shadow: var(--sos2-shadow-md);
  opacity: 0; transition: opacity .17s ease, transform .17s ease, visibility .17s;
}
.sos2-nav__item:last-child .sos2-mega { right: 0; left: auto; transform: translate(0, -8px); }
.sos2-mega::before { content: ""; position: absolute; top: -18px; right: 0; left: 0; height: 18px; }
.sos2-mega.is-open { visibility: visible; transform: translate(-50%, 0); opacity: 1; }
.sos2-nav__item:last-child .sos2-mega.is-open { transform: translate(0,0); }
.sos2-mega--wide { display: grid; width: min(890px, calc(100vw - 50px)); grid-template-columns: .9fr 1.1fr; gap: 36px; }
.sos2-mega--compact { width: 280px; }
.sos2-mega__intro { padding: 24px; border-radius: 14px; color: var(--sos2-white); background: linear-gradient(145deg, var(--sos2-navy), color-mix(in srgb, var(--sos2-navy) 68%, var(--sos2-blue))); }
.sos2-mega__intro > span { color: var(--sos2-orange); font-size: .58rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.sos2-mega__intro h3 { margin: 18px 0 11px; color: var(--sos2-white); font-size: 1.45rem; line-height: 1.14; letter-spacing: -.035em; }
.sos2-mega__intro p { color: rgba(255,255,255,.68); font-size: .72rem; line-height: 1.65; }
.sos2-mega__intro a { display: inline-flex; align-items: center; gap: 7px; margin-top: 8px; color: var(--sos2-white); font-size: .68rem; font-weight: 800; }
.sos2-mega__columns { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 30px; }
.sos2-mega__columns--two { grid-template-columns: repeat(2,minmax(0,1fr)); }
.sos2-mega--compact .sos2-mega__columns { grid-template-columns: 1fr; }
.sos2-mega__columns h4 { margin: 0 0 10px; color: var(--sos2-orange); font-size: .58rem; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }
.sos2-mega__columns h4.sos2-mega__spacer { margin-top: 20px; }
.sos2-mega__columns a { display: flex; justify-content: space-between; gap: 10px; padding: 6px 0; color: color-mix(in srgb, var(--sos2-navy) 76%, transparent); font-size: .74rem; font-weight: 650; line-height: 1.4; }
.sos2-mega__columns a:hover { color: var(--sos2-blue); }
.sos2-mega__columns small { color: var(--sos2-orange); font-size: .54rem; font-weight: 800; text-transform: uppercase; }

/* Hero — full-bleed editorial slider */
.sos2-hero { position: relative; min-height: 810px; color: var(--sos2-white); background: var(--sos2-navy); }
.sos2-hero__slides { position: relative; min-height: 810px; }
.sos2-hero__slide { position: absolute; z-index: 0; visibility: hidden; inset: 0; overflow: hidden; opacity: 0; transition: opacity .55s ease, visibility .55s; }
.sos2-hero__slide::before { content: ""; position: absolute; inset: 0; background-image: var(--sos2-slide-image); background-position: center; background-size: cover; transform: scale(1.015); transition: transform 8s ease; }
.sos2-hero__slide.is-active { z-index: 2; visibility: visible; opacity: 1; }
.sos2-hero__slide.is-active::before { transform: scale(1.055); }
.sos2-hero__veil { position: absolute; z-index: 1; inset: 0; background: linear-gradient(90deg, rgba(4,22,40,.96) 0%, rgba(4,22,40,.88) 38%, rgba(4,22,40,.52) 64%, rgba(4,22,40,.30) 100%), linear-gradient(0deg, rgba(4,22,40,.86) 0%, transparent 48%); }
.sos2-hero__veil::after { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 42px 42px; mask-image: linear-gradient(90deg, rgba(0,0,0,.7), transparent 70%); }
.sos2-hero__content { position: relative; z-index: 3; display: grid; min-height: 810px; grid-template-columns: minmax(0,1.1fr) minmax(330px,.9fr); align-items: center; gap: 64px; padding-block: 92px 176px; }
.sos2-hero__copy { max-width: 820px; }
.sos2-hero h1,
.sos2-hero h2 { margin: 0 0 28px; color: var(--sos2-white); font-size: clamp(3.45rem, 6.1vw, 6.7rem); font-weight: 700; line-height: .95; letter-spacing: -.062em; }
.sos2-hero h1 span,
.sos2-hero h2 span { display: block; margin-top: 8px; color: var(--sos2-white); font-weight: 500; }
.sos2-hero h1 span::after,
.sos2-hero h2 span::after { content: ""; display: block; width: min(420px, 64%); height: 7px; margin-top: 17px; border-radius: 4px; background: var(--sos2-blue); }
.sos2-hero__lede { max-width: 720px; margin-bottom: 34px; color: rgba(255,255,255,.76); font-size: clamp(1rem,1.45vw,1.17rem); line-height: 1.72; }
.sos2-hero__signal-stack { display: grid; align-self: center; justify-self: end; width: min(390px,100%); gap: 13px; }
.sos2-signal-card { display: flex; align-items: center; gap: 14px; padding: 17px 18px; border: 1px solid rgba(255,255,255,.20); border-radius: 15px; color: var(--sos2-white); background: rgba(9,42,76,.92); box-shadow: 0 20px 50px rgba(0,0,0,.25); backdrop-filter: blur(14px); }
.sos2-signal-card:nth-child(2) { transform: translateX(-28px); }
.sos2-signal-card:nth-child(3) { transform: translateX(14px); }
.sos2-signal-card > span { display: grid; width: 42px; height: 42px; flex: 0 0 auto; place-items: center; border-radius: 12px; color: var(--sos2-white); background: var(--sos2-blue); }
.sos2-signal-card--alert > span { background: var(--sos2-orange); }
.sos2-signal-card svg { font-size: 1.35rem; }
.sos2-signal-card strong { display: block; font-size: .69rem; letter-spacing: .06em; }
.sos2-signal-card small { display: block; margin-top: 3px; color: rgba(255,255,255,.65); font-size: .61rem; }
.sos2-hero__feature-card { justify-self: end; width: min(390px,100%); padding: 28px; border: 1px solid rgba(255,255,255,.18); border-top: 4px solid var(--sos2-orange); border-radius: 20px; color: var(--sos2-white); background: rgba(9,42,76,.90); box-shadow: var(--sos2-shadow-lg); backdrop-filter: blur(16px); }
.sos2-hero__feature-icon { display: grid; width: 54px; height: 54px; place-items: center; margin-bottom: 25px; border-radius: 14px; color: var(--sos2-white); background: var(--sos2-blue); }
.sos2-hero__feature-icon svg { font-size: 1.6rem; }
.sos2-hero__feature-card strong { display: block; font-size: 1.14rem; line-height: 1.35; }
.sos2-hero__feature-card p { margin: 12px 0 0; color: rgba(255,255,255,.68); font-size: .78rem; line-height: 1.65; }
.sos2-hero__feature-card small { display: inline-block; margin-top: 18px; padding: 7px 10px; border-radius: 999px; color: var(--sos2-navy); background: var(--sos2-gold); font-size: .56rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.sos2-hero__tabs { position: absolute; z-index: 10; right: 0; bottom: 0; left: 0; border-top: 1px solid rgba(255,255,255,.16); background: rgba(4,22,40,.75); backdrop-filter: blur(16px); }
.sos2-hero__tabs-inner { display: grid; grid-template-columns: repeat(auto-fit,minmax(0,1fr)); }
.sos2-hero__tab { position: relative; display: grid; min-height: 118px; grid-template-columns: 34px minmax(0,1fr); align-content: center; gap: 2px 13px; padding: 22px 28px; border: 0; border-right: 1px solid rgba(255,255,255,.13); color: rgba(255,255,255,.54); background: transparent; text-align: left; transition: color .2s ease, background-color .2s ease; }
.sos2-hero__tab::after { content: ""; position: absolute; right: 0; bottom: 0; left: 0; height: 4px; transform: scaleX(0); transform-origin: left; background: var(--sos2-orange); transition: transform .3s ease; }
.sos2-hero__tab > span { grid-row: 1 / span 2; color: var(--sos2-orange); font-size: .66rem; font-weight: 800; letter-spacing: .08em; }
.sos2-hero__tab strong { color: inherit; font-size: .78rem; line-height: 1.3; }
.sos2-hero__tab small { font-size: .58rem; line-height: 1.4; }
.sos2-hero__tab:hover,
.sos2-hero__tab.is-active { color: var(--sos2-white); background: rgba(255,255,255,.06); }
.sos2-hero__tab.is-active::after { transform: scaleX(1); }

/* Editorial introduction */
.sos2-intro { background: var(--sos2-white); }
.sos2-intro__grid { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(360px,.75fr); gap: clamp(60px,8vw,130px); align-items: start; }
.sos2-intro h2,
.sos2-architecture__heading h2,
.sos2-modules__heading h2,
.sos2-industries__heading h2,
.sos2-security__heading h2 { margin: 0; color: var(--sos2-navy); font-size: clamp(2.8rem,5.2vw,5.55rem); font-weight: 600; line-height: 1.02; letter-spacing: -.058em; }
.sos2-intro h2 span,
.sos2-architecture__heading h2 span,
.sos2-modules__heading h2 span,
.sos2-industries__heading h2 span { color: var(--sos2-blue); }
.sos2-intro__copy { padding-top: 48px; }
.sos2-intro__copy p { margin-bottom: 21px; color: var(--sos2-muted); font-size: .99rem; line-height: 1.78; }
.sos2-intro__copy .sos2-text-link { margin-top: 10px; }
.sos2-outcome-strip { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); margin-top: 82px; border-top: 1px solid var(--sos2-line); border-bottom: 1px solid var(--sos2-line); }
.sos2-outcome-strip > div { min-height: 164px; padding: 30px 28px; border-right: 1px solid var(--sos2-line); }
.sos2-outcome-strip > div:last-child { border-right: 0; }
.sos2-outcome-strip span { display: block; margin-bottom: 20px; color: var(--sos2-orange); font-size: .64rem; font-weight: 800; letter-spacing: .12em; }
.sos2-outcome-strip strong { display: block; margin-bottom: 8px; color: var(--sos2-navy); font-size: .84rem; line-height: 1.35; }
.sos2-outcome-strip small { display: block; color: var(--sos2-muted); font-size: .65rem; line-height: 1.55; }

/* Three Nokia-inspired editorial cards, entirely SOS-branded */
.sos2-editorial-cards { padding-bottom: clamp(92px,9vw,150px); background: var(--sos2-white); }
.sos2-editorial-cards__grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(0,1fr)); gap: 22px; }
.sos2-editorial-card { position: relative; display: flex; overflow: hidden; min-height: 570px; flex-direction: column; justify-content: space-between; padding: 30px; border-radius: 10px; color: var(--sos2-white) !important; background: var(--sos2-navy); box-shadow: var(--sos2-shadow-sm); isolation: isolate; }
.sos2-editorial-card::before { content: ""; position: absolute; z-index: -2; inset: 0; background-image: var(--sos2-card-image); background-position: center; background-size: cover; transition: transform .65s cubic-bezier(.2,.75,.2,1); }
.sos2-editorial-card::after { content: ""; position: absolute; z-index: -1; inset: 0; background: linear-gradient(180deg, rgba(5,22,39,.2) 0%, rgba(5,22,39,.72) 52%, rgba(5,22,39,.96) 100%); }
.sos2-editorial-card:hover::before { transform: scale(1.055); }
.sos2-editorial-card__tag { align-self: flex-start; padding: 8px 11px; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; color: var(--sos2-white); background: rgba(9,42,76,.72); font-size: .57rem; font-weight: 800; letter-spacing: .09em; backdrop-filter: blur(10px); }
.sos2-editorial-card h3 { max-width: 420px; margin: 0 0 14px; color: var(--sos2-white); font-size: clamp(1.8rem,2.5vw,2.65rem); font-weight: 600; line-height: 1.06; letter-spacing: -.045em; }
.sos2-editorial-card p { margin-bottom: 24px; color: rgba(255,255,255,.68); font-size: .78rem; line-height: 1.7; }
.sos2-editorial-card__link { display: inline-flex; align-items: center; justify-content: space-between; gap: 12px; width: 100%; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.22); color: var(--sos2-white); font-size: .68rem; font-weight: 800; }
.sos2-editorial-card__link svg { font-size: 1.35rem; }
.sos2-editorial-card--mobile::after { background: linear-gradient(180deg, rgba(0,87,200,.16), rgba(5,22,39,.92)); }

/* Platform architecture tabs */
.sos2-architecture { background: var(--sos2-soft); }
.sos2-architecture__heading { max-width: 1000px; margin-bottom: 74px; }
.sos2-architecture__heading > p:last-child { max-width: 730px; margin: 25px 0 0; color: var(--sos2-muted); font-size: .96rem; line-height: 1.75; }
.sos2-tabs { display: grid; grid-template-columns: 315px minmax(0,1fr); gap: 28px; }
.sos2-tabs__nav { display: flex; flex-direction: column; border-top: 1px solid var(--sos2-line); }
.sos2-tabs__nav button { position: relative; display: grid; grid-template-columns: 34px minmax(0,1fr); gap: 3px 12px; padding: 26px 15px 26px 0; border: 0; border-bottom: 1px solid var(--sos2-line); color: var(--sos2-muted); background: transparent; text-align: left; }
.sos2-tabs__nav button::before { content: ""; position: absolute; top: 0; bottom: 0; left: -18px; width: 4px; transform: scaleY(0); background: var(--sos2-orange); transition: transform .2s ease; }
.sos2-tabs__nav button > span { grid-row: 1 / span 2; color: var(--sos2-orange); font-size: .62rem; font-weight: 800; }
.sos2-tabs__nav button strong { color: var(--sos2-navy); font-size: .82rem; line-height: 1.35; }
.sos2-tabs__nav button small { font-size: .61rem; line-height: 1.45; }
.sos2-tabs__nav button.is-active { color: var(--sos2-navy); }
.sos2-tabs__nav button.is-active::before { transform: scaleY(1); }
.sos2-tab-panel { display: grid; min-height: 640px; grid-template-columns: minmax(0,1.36fr) minmax(300px,.64fr); gap: 0; overflow: hidden; border: 1px solid var(--sos2-line); border-radius: 12px; background: var(--sos2-white); box-shadow: var(--sos2-shadow-sm); }
.sos2-tab-panel[hidden] { display: none; }
.sos2-tab-panel__visual { min-height: 640px; background: var(--sos2-navy); }
.sos2-tab-panel__visual img { width: 100%; height: 100%; min-height: 640px; object-fit: cover; }
.sos2-tab-panel__copy { display: flex; flex-direction: column; justify-content: center; padding: clamp(32px,4vw,58px); }
.sos2-tab-panel__copy > span { margin-bottom: 22px; color: var(--sos2-orange); font-size: .63rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.sos2-tab-panel__copy h3 { margin-bottom: 20px; color: var(--sos2-navy); font-size: clamp(1.8rem,2.8vw,3rem); font-weight: 600; line-height: 1.08; letter-spacing: -.045em; }
.sos2-tab-panel__copy > p { color: var(--sos2-muted); font-size: .82rem; line-height: 1.72; }
.sos2-tab-panel__copy ul { display: grid; gap: 14px; margin: 20px 0 0; list-style: none; }
.sos2-tab-panel__copy li { display: flex; gap: 12px; color: var(--sos2-muted); font-size: .72rem; line-height: 1.55; }
.sos2-tab-panel__copy li > svg { width: 22px; height: 22px; flex: 0 0 auto; padding: 4px; border-radius: 50%; color: var(--sos2-white); background: var(--sos2-blue); }
.sos2-tab-panel__copy li strong { color: var(--sos2-navy); }

/* Workflow impact band */
.sos2-workflow { overflow: hidden; color: var(--sos2-white); background: var(--sos2-navy); }
.sos2-workflow__grid-bg { position: absolute; inset: 0; background-image: radial-gradient(circle at 82% 18%, color-mix(in srgb, var(--sos2-blue) 38%, transparent), transparent 30%), linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px); background-size: auto, 42px 42px, 42px 42px; }
.sos2-workflow .sos2-container { position: relative; }
.sos2-workflow__heading { max-width: 880px; margin-bottom: 75px; }
.sos2-workflow__heading h2 { margin: 0; color: var(--sos2-white); font-size: clamp(3rem,5.6vw,6.2rem); font-weight: 600; line-height: .98; letter-spacing: -.06em; }
.sos2-workflow__heading h2 span { color: var(--sos2-white); }
.sos2-workflow__heading p:last-child { max-width: 650px; margin: 26px 0 0; color: rgba(255,255,255,.66); font-size: .91rem; line-height: 1.72; }
.sos2-workflow__steps { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); border-top: 1px solid rgba(255,255,255,.18); border-bottom: 1px solid rgba(255,255,255,.18); }
.sos2-workflow__step { position: relative; min-height: 330px; padding: 34px 25px; border-right: 1px solid rgba(255,255,255,.15); }
.sos2-workflow__step:last-child { border-right: 0; }
.sos2-workflow__number { display: block; margin-bottom: 52px; color: var(--sos2-orange); font-size: .64rem; font-weight: 800; letter-spacing: .12em; }
.sos2-workflow__step i { display: grid; width: 58px; height: 58px; place-items: center; margin-bottom: 30px; border: 1px solid rgba(255,255,255,.20); border-radius: 50%; color: var(--sos2-white); background: rgba(255,255,255,.06); font-style: normal; }
.sos2-workflow__step i svg { font-size: 1.65rem; }
.sos2-workflow__step h3 { margin-bottom: 10px; color: var(--sos2-white); font-size: 1.18rem; font-weight: 700; }
.sos2-workflow__step p { margin: 0; color: rgba(255,255,255,.58); font-size: .67rem; line-height: 1.6; }

/* Product card rail */
.sos2-modules { background: var(--sos2-white); }
.sos2-modules__heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 30px; margin-bottom: 62px; }
.sos2-rail-controls { display: flex; gap: 10px; flex: 0 0 auto; }
.sos2-rail-controls button { display: grid; width: 50px; height: 50px; place-items: center; border: 1px solid var(--sos2-line); border-radius: 50%; color: var(--sos2-navy); background: var(--sos2-white); transition: color .18s ease, background-color .18s ease, transform .18s ease; }
.sos2-rail-controls button:hover { color: var(--sos2-white); background: var(--sos2-navy); transform: translateY(-2px); }
.sos2-rail-controls svg { font-size: 1.25rem; }
.sos2-module-rail { display: flex; gap: 18px; overflow-x: auto; padding: 4px 4px 28px; scroll-behavior: smooth; scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: var(--sos2-blue) var(--sos2-soft); }
.sos2-module-card { position: relative; display: flex; min-width: min(360px,78vw); min-height: 430px; flex: 0 0 min(360px,78vw); flex-direction: column; padding: 30px; border: 1px solid var(--sos2-line); border-radius: 10px; background: var(--sos2-white); box-shadow: 0 8px 30px rgba(2,21,40,.05); scroll-snap-align: start; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.sos2-module-card:hover { transform: translateY(-7px); border-color: color-mix(in srgb, var(--sos2-blue) 35%, transparent); box-shadow: var(--sos2-shadow-md); }
.sos2-module-card__index { display: block; margin-bottom: 50px; color: var(--sos2-orange); font-size: .62rem; font-weight: 800; letter-spacing: .12em; }
.sos2-module-card__icon { display: grid; width: 62px; height: 62px; place-items: center; margin-bottom: 28px; border-radius: 18px; color: var(--sos2-blue); background: color-mix(in srgb, var(--sos2-blue) 9%, var(--sos2-white)); }
.sos2-module-card__icon svg { font-size: 1.75rem; }
.sos2-module-card > small { margin-bottom: 8px; color: var(--sos2-blue); font-size: .58rem; font-weight: 800; letter-spacing: .10em; text-transform: uppercase; }
.sos2-module-card h3 { margin-bottom: 15px; color: var(--sos2-navy); font-size: 1.48rem; font-weight: 700; letter-spacing: -.03em; }
.sos2-module-card p { margin-bottom: 32px; color: var(--sos2-muted); font-size: .76rem; line-height: 1.7; }
.sos2-module-card__arrow { display: grid; width: 42px; height: 42px; place-items: center; margin-top: auto; border: 1px solid var(--sos2-line); border-radius: 50%; color: var(--sos2-navy); transition: color .18s ease, background-color .18s ease; }
.sos2-module-card:hover .sos2-module-card__arrow { color: var(--sos2-white); background: var(--sos2-blue); }

/* LiveLockdown impact section */
.sos2-lockdown { overflow: hidden; color: var(--sos2-white); background: linear-gradient(118deg, #4b0711 0%, color-mix(in srgb, var(--sos2-orange) 70%, #5f0014) 42%, var(--sos2-navy) 100%); }
.sos2-lockdown__glow { position: absolute; top: -240px; left: -180px; width: 720px; height: 720px; border-radius: 50%; background: radial-gradient(circle, rgba(255,255,255,.16), transparent 68%); }
.sos2-lockdown__grid { position: relative; display: grid; grid-template-columns: minmax(0,.83fr) minmax(480px,1.17fr); align-items: center; gap: clamp(50px,7vw,110px); }
.sos2-lockdown__copy h2 { margin: 0 0 25px; color: var(--sos2-white); font-size: clamp(2.6rem,4.8vw,5.2rem); font-weight: 600; line-height: 1.01; letter-spacing: -.058em; }
.sos2-lockdown__copy > p { margin-bottom: 28px; color: rgba(255,255,255,.72); font-size: .94rem; line-height: 1.75; }
.sos2-lockdown__actions { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 25px; }
.sos2-lockdown__actions span { padding: 8px 11px; border: 1px solid rgba(255,255,255,.25); border-radius: 999px; color: var(--sos2-white); background: rgba(255,255,255,.07); font-size: .59rem; font-weight: 700; }
.sos2-lockdown__copy > small { display: block; color: rgba(255,255,255,.52); font-size: .61rem; line-height: 1.55; }
.sos2-lockdown__visual { overflow: hidden; border: 1px solid rgba(255,255,255,.18); border-radius: 18px; box-shadow: 0 36px 90px rgba(45,0,7,.38); }
.sos2-lockdown__visual img { width: 100%; height: auto; }

/* Industry mosaic */
.sos2-industries { background: var(--sos2-white); }
.sos2-industries__heading { max-width: 980px; margin-bottom: 68px; }
.sos2-industry-grid { display: grid; grid-template-columns: repeat(12,minmax(0,1fr)); grid-auto-rows: minmax(260px,auto); gap: 20px; }
.sos2-industry-card { position: relative; overflow: hidden; min-height: 520px; grid-column: span 6; border-radius: 10px; color: var(--sos2-white) !important; background: var(--sos2-navy); isolation: isolate; }
.sos2-industry-card--large { min-height: 700px; grid-column: span 7; grid-row: span 2; }
.sos2-industry-card:nth-child(2) { grid-column: span 5; }
.sos2-industry-card:nth-child(3) { grid-column: span 5; }
.sos2-industry-card--wide { min-height: 470px; grid-column: span 12; }
.sos2-industry-card > img { position: absolute; z-index: -2; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.sos2-industry-card::after { content: ""; position: absolute; z-index: -1; inset: 0; background: linear-gradient(180deg, transparent 16%, rgba(4,22,40,.34) 48%, rgba(4,22,40,.96) 100%); }
.sos2-industry-card:hover > img { transform: scale(1.045); }
.sos2-industry-card > div { position: absolute; right: 0; bottom: 0; left: 0; padding: 34px; }
.sos2-industry-card > div > span { display: grid; width: 48px; height: 48px; place-items: center; margin-bottom: 18px; border-radius: 50%; color: var(--sos2-white); background: var(--sos2-blue); }
.sos2-industry-card > div > span svg { font-size: 1.35rem; }
.sos2-industry-card small { display: block; margin-bottom: 9px; color: var(--sos2-orange); font-size: .59rem; font-weight: 800; letter-spacing: .12em; }
.sos2-industry-card h3 { max-width: 720px; margin-bottom: 12px; color: var(--sos2-white); font-size: clamp(1.5rem,2.65vw,3rem); font-weight: 600; line-height: 1.08; letter-spacing: -.045em; }
.sos2-industry-card p { max-width: 650px; margin-bottom: 0; color: rgba(255,255,255,.68); font-size: .73rem; line-height: 1.62; }
.sos2-industry-card > div > svg { position: absolute; right: 34px; bottom: 38px; font-size: 1.7rem; }
.sos2-industry-card--wide > div { max-width: 760px; }

/* LiveExtend roadmap section */
.sos2-liveextend { overflow: hidden; color: var(--sos2-white); background: linear-gradient(135deg, var(--sos2-navy) 0%, color-mix(in srgb, var(--sos2-navy) 64%, var(--sos2-blue)) 62%, var(--sos2-blue) 100%); }
.sos2-liveextend__pattern { position: absolute; inset: 0; background-image: radial-gradient(circle at 85% 15%, rgba(255,255,255,.12), transparent 26%), linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: auto, 38px 38px, 38px 38px; }
.sos2-liveextend__grid { position: relative; display: grid; grid-template-columns: minmax(440px,1.05fr) minmax(0,.95fr); align-items: center; gap: clamp(55px,8vw,120px); }
.sos2-liveextend__visual { overflow: hidden; border: 1px solid rgba(255,255,255,.16); border-radius: 18px; box-shadow: var(--sos2-shadow-lg); }
.sos2-liveextend__copy h2 { margin: 0 0 24px; color: var(--sos2-white); font-size: clamp(2.55rem,4.6vw,5rem); font-weight: 600; line-height: 1.01; letter-spacing: -.055em; }
.sos2-liveextend__copy > p { margin-bottom: 27px; color: rgba(255,255,255,.70); font-size: .9rem; line-height: 1.75; }
.sos2-liveextend__features { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 9px; margin-bottom: 27px; }
.sos2-liveextend__features span { position: relative; padding: 11px 12px 11px 31px; border: 1px solid rgba(255,255,255,.16); border-radius: 8px; color: rgba(255,255,255,.82); background: rgba(255,255,255,.055); font-size: .63rem; line-height: 1.45; }
.sos2-liveextend__features span::before { content: ""; position: absolute; top: 16px; left: 13px; width: 7px; height: 7px; border-radius: 50%; background: var(--sos2-orange); }
.sos2-liveextend__use-cases { margin-bottom: 26px; padding: 16px 18px; border-left: 3px solid var(--sos2-gold); background: rgba(255,255,255,.055); }
.sos2-liveextend__use-cases small { color: var(--sos2-gold); font-size: .56rem; font-weight: 800; letter-spacing: .12em; }
.sos2-liveextend__use-cases p { margin: 5px 0 0; color: rgba(255,255,255,.72); font-size: .68rem; }
.sos2-liveextend__guardrail { margin: 18px 0 0 !important; color: rgba(255,255,255,.48) !important; font-size: .58rem !important; line-height: 1.55 !important; }

/* Security */
.sos2-security { background: var(--sos2-soft); }
.sos2-security__heading { display: grid; grid-template-columns: minmax(0,1fr) minmax(360px,.65fr); gap: 70px; align-items: end; margin-bottom: 60px; }
.sos2-security__heading .sos2-eyebrow { grid-column: 1 / -1; margin-bottom: -35px; }
.sos2-security__heading > p:last-child { margin: 0 0 9px; color: var(--sos2-muted); font-size: .9rem; line-height: 1.72; }
.sos2-security__grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); border-top: 1px solid var(--sos2-line); border-bottom: 1px solid var(--sos2-line); }
.sos2-security-card { min-height: 320px; padding: 36px 27px; border-right: 1px solid var(--sos2-line); }
.sos2-security-card:last-child { border-right: 0; }
.sos2-security-card > span { display: grid; width: 55px; height: 55px; place-items: center; margin-bottom: 58px; border-radius: 50%; color: var(--sos2-blue); background: var(--sos2-white); box-shadow: var(--sos2-shadow-sm); }
.sos2-security-card > span svg { font-size: 1.45rem; }
.sos2-security-card h3 { margin-bottom: 12px; color: var(--sos2-navy); font-size: .98rem; line-height: 1.35; }
.sos2-security-card p { margin: 0; color: var(--sos2-muted); font-size: .68rem; line-height: 1.65; }
.sos2-claims { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 35px; padding: 21px; border: 1px solid color-mix(in srgb, var(--sos2-gold) 55%, transparent); border-radius: 8px; background: color-mix(in srgb, var(--sos2-gold) 7%, var(--sos2-white)); }
.sos2-claims strong { flex-basis: 100%; margin-bottom: 7px; color: var(--sos2-navy); font-size: .7rem; }
.sos2-claims span { padding: 7px 10px; border-radius: 999px; color: var(--sos2-navy); background: var(--sos2-white); font-size: .58rem; font-weight: 700; }
.sos2-claims small { flex-basis: 100%; margin-top: 6px; color: var(--sos2-muted); font-size: .55rem; }

/* Final CTA */
.sos2-final-cta { position: relative; overflow: hidden; color: var(--sos2-white); background: var(--sos2-orange); }
.sos2-final-cta__gradient { position: absolute; inset: 0; background: radial-gradient(circle at 82% 18%, rgba(255,255,255,.22), transparent 24%), linear-gradient(112deg, var(--sos2-orange) 0%, color-mix(in srgb, var(--sos2-orange) 58%, #9c0a29) 46%, var(--sos2-navy) 100%); }
.sos2-final-cta__inner { position: relative; display: grid; min-height: 520px; grid-template-columns: minmax(0,1fr) 300px; align-items: center; gap: 70px; padding-block: 86px; }
.sos2-final-cta h2 { max-width: 910px; margin: 0 0 24px; color: var(--sos2-white); font-size: clamp(3rem,5.5vw,6rem); font-weight: 600; line-height: .98; letter-spacing: -.06em; }
.sos2-final-cta__inner > div:first-child > p:last-child { max-width: 730px; margin: 0; color: rgba(255,255,255,.72); font-size: .92rem; line-height: 1.72; }
.sos2-final-cta__actions { display: flex; flex-direction: column; align-items: flex-start; gap: 24px; }
.sos2-final-cta__actions .sos2-button { width: 100%; }

/* Footer */
.sos2-footer { color: var(--sos2-white); background: color-mix(in srgb, var(--sos2-navy) 94%, black); }
.sos2-footer__top { display: grid; grid-template-columns: minmax(300px,.8fr) minmax(0,1.2fr); gap: 80px; padding-block: 76px 58px; }
.sos2-footer__brand img { width: 272px; height: auto; margin-bottom: 24px; }
.sos2-footer__brand p { max-width: 460px; margin-bottom: 22px; color: rgba(255,255,255,.62); font-size: .76rem; line-height: 1.7; }
.sos2-footer__links { display: grid; grid-template-columns: repeat(auto-fit,minmax(0,1fr)); gap: 34px; }
.sos2-footer__links h3 { margin-bottom: 17px; color: var(--sos2-white); font-size: .67rem; font-weight: 800; letter-spacing: .10em; text-transform: uppercase; }
.sos2-footer__links a { display: block; padding: 4px 0; color: rgba(255,255,255,.58); font-size: .68rem; transition: color .15s ease; }
.sos2-footer__links a:hover { color: var(--sos2-white); }
.sos2-footer__bottom { display: flex; align-items: center; justify-content: space-between; gap: 25px; padding-block: 21px 25px; border-top: 1px solid rgba(255,255,255,.11); color: rgba(255,255,255,.45); font-size: .56rem; line-height: 1.5; }
.sos2-footer__bottom a { color: rgba(255,255,255,.67); }

/* Reveal motion: restrained, never blocks content without JS */
.sos2.sos2-js .sos2-reveal { opacity: 0; transform: translateY(22px); transition: opacity .58s ease, transform .58s cubic-bezier(.2,.75,.2,1); }
.sos2.sos2-js .sos2-reveal[data-sos2-delay="1"] { transition-delay: .08s; }
.sos2.sos2-js .sos2-reveal[data-sos2-delay="2"] { transition-delay: .16s; }
.sos2.sos2-js .sos2-reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 1180px) {
  .sos2-container { width: min(calc(100% - 44px), var(--sos2-container)); }
  .sos2-brand { width: 210px; }
  .sos2-header__inner { gap: 18px; }
  .sos2-nav__trigger, .sos2-nav__link { padding-inline: 9px; font-size: .67rem; }
  .sos2-header__cta { padding-inline: 14px; }
  .sos2-hero__content { grid-template-columns: minmax(0,1.15fr) minmax(300px,.75fr); gap: 38px; }
  .sos2-hero h1, .sos2-hero h2 { font-size: clamp(3.4rem,6vw,5.8rem); }
  .sos2-tabs { grid-template-columns: 280px minmax(0,1fr); }
  .sos2-tab-panel { grid-template-columns: minmax(0,1.15fr) minmax(280px,.85fr); }
  .sos2-lockdown__grid { grid-template-columns: minmax(0,.8fr) minmax(440px,1.2fr); }
}

@media (max-width: 1020px) {
  .sos2-menu-toggle { display: inline-flex; }
  .sos2-header__cta { display: none; }
  .sos2-nav { position: absolute; top: 100%; right: 0; left: 0; display: none; overflow-y: auto; max-height: calc(100vh - 112px); padding: 20px; border-top: 1px solid rgba(255,255,255,.10); background: var(--sos2-navy); box-shadow: var(--sos2-shadow-md); }
  .sos2-nav.is-open { display: block; }
  .sos2-nav__list { display: block; }
  .sos2-nav__item { border-bottom: 1px solid rgba(255,255,255,.11); }
  .sos2-nav__trigger, .sos2-nav__link { width: 100%; justify-content: space-between; padding: 16px 2px; border-radius: 0; font-size: .82rem; }
  .sos2-nav__trigger:hover, .sos2-nav__trigger[aria-expanded="true"], .sos2-nav__link:hover { background: transparent; }
  .sos2-mega,
  .sos2-mega--wide,
  .sos2-mega--compact,
  .sos2-nav__item:last-child .sos2-mega { position: static; display: none; visibility: visible; width: 100%; grid-template-columns: 1fr; gap: 18px; padding: 0 0 20px; transform: none; border: 0; border-radius: 0; color: var(--sos2-white); background: transparent; box-shadow: none; opacity: 1; }
  .sos2-mega.is-open, .sos2-nav__item:last-child .sos2-mega.is-open { display: grid; transform: none; }
  .sos2-mega__intro { display: none; }
  .sos2-mega__columns, .sos2-mega__columns--two { grid-template-columns: 1fr 1fr; }
  .sos2-mega__columns h4 { color: var(--sos2-orange); }
  .sos2-mega__columns a { color: rgba(255,255,255,.70); }
  .sos2-nav__mobile-cta { display: flex; width: 100%; margin-top: 20px; }
  .sos2-hero, .sos2-hero__slides { min-height: 820px; }
  .sos2-hero__content { min-height: 820px; grid-template-columns: 1fr; align-content: center; padding-block: 74px 176px; }
  .sos2-hero__copy { max-width: 800px; }
  .sos2-hero__signal-stack, .sos2-hero__feature-card { display: none; }
  .sos2-intro__grid { grid-template-columns: 1fr; gap: 20px; }
  .sos2-intro__copy { max-width: 760px; padding-top: 0; }
  .sos2-outcome-strip { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .sos2-outcome-strip > div:nth-child(2) { border-right: 0; }
  .sos2-outcome-strip > div:nth-child(-n+2) { border-bottom: 1px solid var(--sos2-line); }
  .sos2-editorial-cards__grid { grid-template-columns: 1fr 1fr; }
  .sos2-editorial-card:last-child { grid-column: 1 / -1; min-height: 460px; }
  .sos2-tabs { grid-template-columns: 1fr; }
  .sos2-tabs__nav { display: grid; grid-template-columns: repeat(auto-fit,minmax(0,1fr)); border-top: 1px solid var(--sos2-line); }
  .sos2-tabs__nav button { border-right: 1px solid var(--sos2-line); }
  .sos2-tabs__nav button::before { top: auto; right: 0; bottom: -1px; left: 0; width: auto; height: 4px; transform: scaleX(0); }
  .sos2-tabs__nav button.is-active::before { transform: scaleX(1); }
  .sos2-tab-panel { min-height: 0; grid-template-columns: 1fr; }
  .sos2-tab-panel__visual, .sos2-tab-panel__visual img { min-height: 0; }
  .sos2-tab-panel__copy { padding: 44px; }
  .sos2-workflow__steps { grid-template-columns: repeat(5,minmax(190px,1fr)); overflow-x: auto; }
  .sos2-workflow__step { min-height: 300px; }
  .sos2-lockdown__grid, .sos2-liveextend__grid { grid-template-columns: 1fr; }
  .sos2-lockdown__copy, .sos2-liveextend__copy { max-width: 850px; }
  .sos2-lockdown__visual, .sos2-liveextend__visual { width: min(850px,100%); }
  .sos2-security__heading { grid-template-columns: 1fr; gap: 24px; }
  .sos2-security__heading .sos2-eyebrow { grid-column: auto; margin-bottom: 0; }
  .sos2-security__heading > p:last-child { max-width: 720px; }
  .sos2-security__grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .sos2-security-card:nth-child(2) { border-right: 0; }
  .sos2-security-card:nth-child(-n+2) { border-bottom: 1px solid var(--sos2-line); }
  .sos2-final-cta__inner { grid-template-columns: 1fr; }
  .sos2-final-cta__actions { max-width: 320px; }
}

@media (max-width: 782px) { .admin-bar .sos2 .sos2-site-chrome { top: 46px; } }

@media (max-width: 740px) {
  .sos2-container { width: min(calc(100% - 28px), var(--sos2-container)); }
  .sos2-section { padding-block: 82px; }
  .sos2-utility { display: none; }
  .sos2-header__inner { min-height: 72px; }
  .sos2-brand { width: 188px; }
  .sos2-nav { max-height: calc(100vh - 72px); }
  .sos2-mega__columns, .sos2-mega__columns--two { grid-template-columns: 1fr; }
  .sos2-hero, .sos2-hero__slides, .sos2-hero__content { min-height: 760px; }
  .sos2-hero__content { padding-block: 62px 165px; }
  .sos2-hero__slide::before { background-position: 58% center; }
  .sos2-hero__veil { background: linear-gradient(90deg, rgba(4,22,40,.96), rgba(4,22,40,.75)), linear-gradient(0deg, rgba(4,22,40,.9), transparent 55%); }
  .sos2-hero h1, .sos2-hero h2 { font-size: clamp(2.85rem,12vw,4.7rem); line-height: .97; }
  .sos2-hero__lede { font-size: .94rem; }
  .sos2-hero__tabs-inner { grid-template-columns: repeat(auto-fit,minmax(0,1fr)); }
  .sos2-hero__tab { min-height: 105px; grid-template-columns: 1fr; gap: 3px; padding: 17px 12px; }
  .sos2-hero__tab > span { grid-row: auto; }
  .sos2-hero__tab small { display: none; }
  .sos2-intro h2, .sos2-architecture__heading h2, .sos2-modules__heading h2, .sos2-industries__heading h2, .sos2-security__heading h2 { font-size: 2.75rem; }
  .sos2-outcome-strip { margin-top: 55px; grid-template-columns: 1fr; }
  .sos2-outcome-strip > div { border-right: 0; border-bottom: 1px solid var(--sos2-line); }
  .sos2-outcome-strip > div:last-child { border-bottom: 0; }
  .sos2-editorial-cards__grid { grid-template-columns: 1fr; }
  .sos2-editorial-card, .sos2-editorial-card:last-child { min-height: 510px; grid-column: auto; }
  .sos2-tabs__nav { grid-template-columns: 1fr; }
  .sos2-tabs__nav button { border-right: 0; }
  .sos2-tab-panel__copy { padding: 31px 24px; }
  .sos2-workflow__heading h2 { font-size: 3.15rem; }
  .sos2-modules__heading { align-items: flex-start; flex-direction: column; }
  .sos2-module-card { min-width: 82vw; flex-basis: 82vw; min-height: 410px; }
  .sos2-lockdown__copy h2, .sos2-liveextend__copy h2 { font-size: 2.8rem; }
  .sos2-industry-grid { grid-template-columns: 1fr; }
  .sos2-industry-card, .sos2-industry-card--large, .sos2-industry-card:nth-child(2), .sos2-industry-card:nth-child(3), .sos2-industry-card--wide { min-height: 520px; grid-column: 1; grid-row: auto; }
  .sos2-industry-card > div { padding: 25px; }
  .sos2-industry-card > div > svg { right: 25px; bottom: 29px; }
  .sos2-liveextend__features { grid-template-columns: 1fr; }
  .sos2-security__grid { grid-template-columns: 1fr; }
  .sos2-security-card { border-right: 0; border-bottom: 1px solid var(--sos2-line); }
  .sos2-security-card:last-child { border-bottom: 0; }
  .sos2-final-cta__inner { min-height: 540px; padding-block: 72px; }
  .sos2-final-cta h2 { font-size: 3.2rem; }
  .sos2-footer__top { grid-template-columns: 1fr; gap: 46px; }
  .sos2-footer__links { gap: 20px; }
  .sos2-footer__bottom { align-items: flex-start; flex-direction: column; }
}

@media (max-width: 520px) {
  .sos2-brand { width: 176px; }
  .sos2-menu-toggle { width: 42px; height: 42px; }
  .sos2-actions { flex-direction: column; align-items: stretch; }
  .sos2-actions .sos2-button { width: 100%; }
  .sos2-hero h1, .sos2-hero h2 { font-size: clamp(2.6rem,12.5vw,3.75rem); }
  .sos2-hero__tab { padding-inline: 8px; }
  .sos2-hero__tab strong { font-size: .64rem; }
  .sos2-editorial-card { padding: 23px; }
  .sos2-tabs__nav button { padding: 20px 6px 20px 0; }
  .sos2-industry-card h3 { padding-right: 28px; font-size: 1.75rem; }
  .sos2-final-cta h2 { font-size: 2.75rem; }
  .sos2-footer__links { grid-template-columns: 1fr 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .sos2 *, .sos2 *::before, .sos2 *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; }
  .sos2.sos2-js .sos2-reveal { opacity: 1; transform: none; }
  .sos2-hero__slide::before { transform: none !important; }
}
