/* ============================================================
   LivDES Marketing Site — shared styles
   Dark engineering, restrained Linear/Vercel aesthetic.
   All tokens come from tokens.css.
   ============================================================ */

@import url("tokens.css");

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg-app);
  color: var(--fg-2);
  font-family: var(--font-ui);
  -webkit-font-smoothing: antialiased;
}

body {
  overflow-x: hidden;
  font-family: var(--font-ui);
  font-weight: 300;
  font-size: 17px;
  line-height: 1.55;
  color: var(--fg-2);
}

img { display: block; max-width: 100%; }
button { font-family: inherit; }
a { color: inherit; text-decoration: none; }

/* ─── Layout primitives ────────────────────────────────────── */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

.section {
  padding: 72px 0;
  position: relative;
}
.section--hero { padding: 0; }
.section--compact { padding: 56px 0; }
.section--tight { padding: 40px 0; }
.section--divider { border-top: 1px solid var(--border-1); }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.eyebrow::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--color-primary);
  box-shadow: 0 0 8px rgba(251,179,21,0.7);
}
.eyebrow--plain::before { display: none; }

.section-head { max-width: 820px; margin-bottom: 40px; }
.section-head h2 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(32px, 3.6vw, 48px);
  line-height: 1.06;
  letter-spacing: -0.02em;
  margin: 14px 0 18px;
  color: var(--fg-1);
  text-wrap: pretty;
}
.section-head p {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.6;
  color: var(--fg-3);
  margin: 0;
  max-width: 740px;
}

/* Center-variant */
.section-head--center { margin: 0 auto 40px; text-align: center; max-width: 760px; }
.section-head--center .eyebrow { justify-content: center; }
.section-head--center p { margin: 0 auto; max-width: 680px; }

/* ─── Top navigation ──────────────────────────────────────── */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(5, 6, 9, 0.78);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease, background .2s ease;
}
.nav.is-scrolled {
  border-bottom-color: var(--border-1);
  background: rgba(5, 6, 9, 0.92);
}
.nav__inner {
  height: 64px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--fg-1);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.01em;
}
.brand__mark {
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
}
.brand__logo {
  height: 36px;
  width: auto;
  display: block;
}
.footer__brand .brand__logo { height: 30px; }
.nav__links {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  font-size: 14px;
  font-family: var(--font-ui);
  color: var(--fg-3);
  background: transparent;
  border: 0;
  border-radius: 6px;
  white-space: nowrap;
  transition: color .15s ease, background .15s ease;
  cursor: pointer;
}
.nav__link:hover { color: var(--fg-1); background: var(--bg-elevated); }
.nav__link.is-active { color: var(--fg-1); }
.nav__link.is-active::after {
  content: "";
  position: absolute;
  left: 12px; right: 12px; bottom: -2px;
  height: 2px;
  background: var(--color-primary);
  border-radius: 1px;
}
.nav__link .caret { width: 12px; height: 12px; opacity: .7; }

.nav__dropdown { position: relative; }
.nav__menu {
  position: absolute;
  top: calc(100% + 8px); left: 0;
  min-width: 320px;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  padding: 8px;
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
  transition: opacity .15s ease, transform .15s ease;
  box-shadow: var(--shadow-lg);
}
.nav__dropdown:hover .nav__menu,
.nav__dropdown:focus-within .nav__menu {
  opacity: 1; transform: translateY(0); pointer-events: auto;
}
.nav__menu-group { padding: 8px 10px; }
.nav__menu-group-title {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-4);
  padding: 6px 8px;
}
.nav__menu-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: background .12s ease;
}
.nav__menu-item:hover { background: var(--bg-elevated); }
.nav__menu-item__title { font-size: 14px; color: var(--fg-1); font-weight: 500; }
.nav__menu-item__sub { font-size: 12px; color: var(--fg-3); }
.nav__menu-item__icon {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-surface-1);
  border: 1px solid var(--border-2);
  border-radius: 6px;
  color: var(--color-primary);
  flex: 0 0 28px;
}
.nav__menu-item.is-soon .nav__menu-item__title { color: var(--fg-3); }
.nav__menu-item.is-soon { opacity: .6; cursor: not-allowed; }

.nav__spacer { flex: 1; }

.nav__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.nav__locale {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 32px; padding: 0 10px;
  border-radius: 6px;
  font-size: 13px;
  color: var(--fg-3);
  cursor: pointer;
  background: transparent;
  border: 1px solid transparent;
}
.nav__locale:hover { color: var(--fg-1); background: var(--bg-elevated); }
.nav__locale .caret { width: 12px; height: 12px; transition: transform .2s ease; opacity: .7; }
.lang-switch.is-open .nav__locale { color: var(--fg-1); background: var(--bg-elevated); border-color: var(--border-2); }
.lang-switch.is-open .nav__locale .caret { transform: rotate(180deg); }

/* ─── Language switcher dropdown ──────────────────────────── */
.lang-switch { position: relative; }
.lang-switch__menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 188px;
  background: var(--bg-panel);
  border: 1px solid var(--border-2);
  border-radius: 12px;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,.7);
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
  z-index: 1200;
}
.lang-switch.is-open .lang-switch__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.lang-switch__item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  width: 100%; padding: 9px 11px;
  background: transparent; border: 0; border-radius: 8px;
  color: var(--fg-2); font-family: var(--font-ui); font-size: 14px; text-align: left;
  cursor: pointer; transition: background .14s ease, color .14s ease;
}
.lang-switch__item:hover { background: var(--bg-app); color: var(--fg-1); }
.lang-switch__item.is-active { color: var(--color-primary); }
.lang-switch__item.is-active::after {
  content: "✓"; font-size: 12px; color: var(--color-primary);
}
.lang-switch__tag {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em;
  color: var(--fg-4); padding: 2px 6px; border: 1px solid var(--border-2); border-radius: 5px;
}
.lang-switch__item.is-active .lang-switch__tag { color: var(--color-primary); border-color: rgba(251,179,21,.4); }
.lang-switch__item.is-active::after { margin-left: -4px; }

/* RTL: mirror layout for Arabic, but keep technical/code panels LTR */
[dir="rtl"] .lang-switch__menu { right: auto; left: 0; }
[dir="rtl"] .lang-switch__item { text-align: right; }
[dir="rtl"] .hero__terminal,
[dir="rtl"] .cap-visual,
[dir="rtl"] .video-band__badge,
[dir="rtl"] .domain-card__prompt,
[dir="rtl"] .code,
[dir="rtl"] svg text,
[dir="rtl"] [class*="mono"] { direction: ltr; }
[dir="rtl"] .hero__sub, [dir="rtl"] .video-band__inner p { text-align: right; }

.nav__hamburger {
  display: none;
  width: 36px; height: 36px;
  align-items: center; justify-content: center;
  background: transparent;
  border: 1px solid var(--border-2);
  border-radius: 6px;
  color: var(--fg-1);
  cursor: pointer;
}

/* ─── Buttons ────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-family: var(--font-button);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease, color .12s ease, transform .08s ease;
  white-space: nowrap;
}
.btn:active { transform: scale(.98); }
.btn--primary {
  background: var(--color-primary);
  color: #0A0B0F;
  border-color: var(--color-primary);
  font-weight: 600;
}
.btn--primary:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); }
.btn--secondary {
  background: var(--bg-surface-1);
  color: var(--fg-1);
  border-color: var(--border-2);
}
.btn--secondary:hover { background: var(--bg-elevated); border-color: var(--border-3); }
.btn--ghost {
  background: transparent;
  color: var(--fg-2);
  border-color: transparent;
}
.btn--ghost:hover { color: var(--fg-1); background: var(--bg-elevated); }
.btn--lg { height: 44px; padding: 0 22px; font-size: 15px; }
.btn--link {
  background: transparent;
  border: 0;
  padding: 0;
  color: var(--color-primary);
  height: auto;
  font-size: 14px;
  font-weight: 500;
}
.btn--link:hover { text-decoration: underline; text-underline-offset: 4px; }
.btn .arr {
  display: inline-flex; transition: transform .15s ease;
}
.btn:hover .arr { transform: translateX(2px); }

/* ─── Hero ────────────────────────────────────────────────── */
.hero {
  position: relative;
  padding: 72px 0 64px;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(251,179,21,0.08) 0%, transparent 60%),
    linear-gradient(180deg, transparent 0%, var(--bg-app) 100%);
  pointer-events: none;
}
.hero__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 70%);
  pointer-events: none;
}
.hero__inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 64px;
  align-items: center;
}
.hero__copy h1 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(32px, 3.6vw, 50px);
  line-height: 1.04;
  letter-spacing: -0.025em;
  margin: 20px 0 20px;
  color: var(--fg-1);
  max-width: 520px;
}
.hero__copy h1 em {
  font-style: normal;
  color: var(--color-primary);
  display: inline-block;
}
.hero__copy h1 .ghost {
  display: inline-block;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(242,240,236,0.32);
}
.hero__tagline {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.hero__tagline span { color: var(--fg-4); margin: 0 8px; }
.hero__sub {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.55;
  color: var(--fg-3);
  max-width: 520px;
  margin: 0 0 28px;
}
.hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }

/* Hero visual — terminal + wireframe construction */
.hero__visual {
  position: relative;
  aspect-ratio: 1.05 / 1;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(28,29,33,0.6) 0%, rgba(18,18,18,0.4) 100%);
  border: 1px solid var(--border-1);
  overflow: hidden;
}
.hero__terminal {
  position: absolute;
  top: 16px; left: 16px; right: 16px;
  z-index: 3;
  background: rgba(18,18,18,0.85);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border-2);
  border-radius: 10px;
  padding: 12px 14px;
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg-2);
}
.hero__terminal-head {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-1);
}
.hero__terminal-head .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--color-primary);
  box-shadow: 0 0 6px rgba(251,179,21,.7);
  animation: pulse 1.8s ease-in-out infinite;
}
.hero__terminal-head .label {
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--fg-3);
}
.hero__terminal-head .meta {
  margin-left: auto; font-size: 10px; color: var(--fg-4); letter-spacing: .08em;
}
.hero__terminal-line { display: flex; gap: 8px; }
.hero__terminal-line .caret { color: var(--color-primary); }
.hero__terminal-line .cmd { color: var(--fg-1); }
.hero__terminal-line .cursor {
  display: inline-block; width: 7px; height: 14px;
  background: var(--color-primary); vertical-align: -2px;
  animation: blink 1s steps(2) infinite;
}
.hero__terminal-result {
  margin-top: 8px;
  font-size: 12px;
  color: var(--color-success);
  display: flex; align-items: center; gap: 6px;
  opacity: 0;
  transition: opacity .4s ease;
}
.hero__terminal-result.is-on { opacity: 1; }

@keyframes blink { 50% { opacity: 0; } }
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .4; transform: scale(.85); }
}

.hero__svg {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
}

/* ─── Credibility strip ──────────────────────────────────── */
.cred {
  border-top: 1px solid var(--border-1);
  border-bottom: 1px solid var(--border-1);
  background: rgba(28, 29, 33, 0.3);
}
.cred__inner {
  padding: 28px 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 48px;
  align-items: center;
}
.cred__claim {
  display: flex; align-items: center; gap: 16px;
  font-size: 13px;
  color: var(--fg-3);
  flex-wrap: wrap;
}
.cred__claim strong { color: var(--fg-1); font-weight: 600; }
.cred__claim .pill {
  display: inline-flex; align-items: center; gap: 6px;
  height: 24px; padding: 0 10px;
  background: rgba(3,201,136,.08);
  border: 1px solid rgba(3,201,136,.25);
  color: var(--color-success);
  border-radius: 12px;
  font-size: 11px; font-weight: 500;
  letter-spacing: .02em;
}
.cred__logos {
  display: flex; align-items: center; gap: 32px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--fg-3);
}
.cred__logos span { white-space: nowrap; }
.cred__logos .sep {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--border-3); display: inline-block;
}

/* ─── Comparison block ───────────────────────────────────── */
.compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  position: relative;
}
.compare__vs {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--bg-app);
  border: 1px solid var(--border-2);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .08em;
  color: var(--fg-3);
  z-index: 2;
}
.compare__col {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  padding: 32px;
}
.compare__col--bad { opacity: .85; }
.compare__col--good { border-color: rgba(251,179,21,.35); }
.compare__col h3 {
  margin: 0 0 4px;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 20px;
  color: var(--fg-1);
}
.compare__col .sub {
  margin: 0 0 24px;
  font-size: 13px;
  color: var(--fg-3);
}
.compare__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.compare__list li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 14px; line-height: 1.5; color: var(--fg-2);
}
.compare__list .ico {
  flex: 0 0 18px; width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; margin-top: 1px;
}
.compare__col--bad .ico { background: rgba(207,102,121,.12); color: var(--color-error); }
.compare__col--good .ico { background: rgba(251,179,21,.15); color: var(--color-primary); }

/* ─── SAM command cards ──────────────────────────────────── */
.sam-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.sam-card {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  padding: 24px;
  transition: border-color .15s ease, transform .15s ease;
}
.sam-card:hover {
  border-color: var(--border-2);
  transform: translateY(-2px);
}
.sam-card__head {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.sam-card__head .badge {
  display: inline-flex; align-items: center;
  height: 20px; padding: 0 8px;
  background: rgba(251,179,21,.12);
  border: 1px solid rgba(251,179,21,.3);
  color: var(--color-primary);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
}
.sam-card__cmd {
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.55;
  color: var(--fg-1);
  background: var(--bg-app);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 16px;
  position: relative;
}
.sam-card__cmd::before {
  content: ">";
  color: var(--color-primary);
  margin-right: 8px;
  font-weight: 700;
}
.sam-card__result {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--fg-2);
}
.sam-card__result .icon {
  flex: 0 0 16px; width: 16px; height: 16px;
  color: var(--color-success);
  margin-top: 2px;
}
.sam-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 17px;
  color: var(--fg-1);
  margin: 0 0 12px;
}

/* ─── Workflow flow strip ────────────────────────────────── */
.flow {
  position: relative;
  padding: 32px 0 48px;
}
.flow__track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.flow__step {
  position: relative;
  padding: 24px 24px 24px 0;
}
.flow__step:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 12px; top: 50%;
  transform: translateY(-50%);
  width: 24px; height: 1px;
  background: var(--border-2);
}
.flow__step:not(:last-child)::before {
  content: "›";
  position: absolute;
  right: 4px; top: 50%;
  transform: translateY(-50%);
  color: var(--color-primary);
  font-family: var(--font-mono);
  font-size: 16px;
}
.flow__step .num {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-4);
  letter-spacing: .1em;
  margin-bottom: 12px;
}
.flow__step .name {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 17px;
  color: var(--fg-1);
  margin-bottom: 6px;
}
.flow__step .desc {
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg-3);
}
.flow__sam-bar {
  margin-top: 16px;
  height: 44px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
  background: linear-gradient(90deg, rgba(251,179,21,.15) 0%, rgba(251,179,21,.04) 100%);
  border: 1px solid rgba(251,179,21,.3);
  border-radius: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-2);
}
.flow__sam-bar .sam-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 600; color: var(--color-primary);
  text-transform: uppercase; letter-spacing: .12em;
  font-size: 10px;
}
.flow__sam-bar .sam-tag::before {
  content: ""; width: 6px; height: 6px;
  background: var(--color-primary); border-radius: 50%;
  box-shadow: 0 0 6px rgba(251,179,21,.6);
}

/* ─── Capability tiles ──────────────────────────────────── */
.tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border-1);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  overflow: hidden;
}
.tile {
  background: var(--bg-app);
  padding: 32px;
  transition: background .15s ease;
}
.tile:hover { background: var(--bg-panel); }
.tile__icon {
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-surface-1);
  border: 1px solid var(--border-2);
  border-radius: 10px;
  color: var(--color-primary);
  margin-bottom: 20px;
}
.tile__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 18px;
  color: var(--fg-1);
  margin: 0 0 8px;
}
.tile__desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--fg-3);
  margin: 0;
}

/* ─── Stat band ─────────────────────────────────────────── */
.stats {
  background: var(--bg-panel);
  border-top: 1px solid var(--border-1);
  border-bottom: 1px solid var(--border-1);
}
.stats__inner {
  padding: 64px 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
  position: relative;
}
.stat__num {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1;
  color: var(--color-primary);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  margin-bottom: 8px;
}
.stat__num .unit { font-size: .5em; color: var(--fg-2); margin-left: 4px; }
.stat__label {
  font-size: 13px;
  line-height: 1.45;
  color: var(--fg-3);
  text-wrap: balance;
}
.stats__caption {
  grid-column: 1 / -1;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-4);
  letter-spacing: .04em;
  padding-top: 32px;
  border-top: 1px solid var(--border-1);
  margin-top: 16px;
}

/* ─── Role chips row ────────────────────────────────────── */
.chips-row {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.role-chip {
  display: inline-flex; align-items: center; gap: 8px;
  height: 36px; padding: 0 14px 0 12px;
  background: var(--bg-panel);
  border: 1px solid var(--border-2);
  border-radius: 18px;
  font-size: 13px; color: var(--fg-1);
}
.role-chip .swatch {
  width: 18px; height: 18px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 600;
  color: #0c0c0d;
}

/* ─── Security checklist ────────────────────────────────── */
.security {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border-1);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  overflow: hidden;
}
.security__item {
  background: var(--bg-app);
  padding: 20px 20px;
  display: flex; align-items: center; gap: 12px;
}
.security__item .ico {
  width: 28px; height: 28px;
  flex: 0 0 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(251,179,21,.12);
  border-radius: 6px;
  color: var(--color-primary);
}
.security__item .name {
  font-size: 14px; font-weight: 500; color: var(--fg-1);
}
.security__item .desc {
  font-size: 12px; color: var(--fg-3); margin-top: 2px;
}

/* ─── Industry cards ────────────────────────────────────── */
.industries {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.industry {
  position: relative;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  min-height: 180px;
  transition: border-color .15s ease, transform .15s ease;
  cursor: pointer;
}
.industry.is-active:hover {
  border-color: rgba(251,179,21,.4);
  transform: translateY(-2px);
}
.industry.is-soon {
  cursor: not-allowed;
  background: transparent;
  border-style: dashed;
  border-color: var(--border-2);
}
.industry.is-soon .industry__name { color: var(--fg-3); }
.industry__icon {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-surface-1);
  border-radius: 8px;
  color: var(--color-primary);
}
.industry.is-soon .industry__icon { color: var(--fg-4); background: transparent; border: 1px dashed var(--border-2); }
.industry__name {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 18px;
  color: var(--fg-1);
  margin: 0;
}
.industry__meta {
  margin-top: auto;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12px;
  color: var(--fg-3);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.industry__meta .arr { color: var(--color-primary); }
.industry .badge-soon {
  position: absolute; top: 16px; right: 16px;
  display: inline-flex; align-items: center;
  height: 20px; padding: 0 8px;
  background: var(--bg-surface-1);
  border: 1px solid var(--border-2);
  border-radius: 10px;
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--fg-3);
}

/* ─── Roadmap horizontal ────────────────────────────────── */
.roadmap {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid var(--border-1);
  border-radius: 12px;
  overflow: hidden;
}
.roadmap__step {
  flex: 1;
  padding: 28px;
  position: relative;
  background: var(--bg-app);
}
.roadmap__step + .roadmap__step { border-left: 1px solid var(--border-1); }
.roadmap__step .label {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--fg-4);
  margin-bottom: 12px;
}
.roadmap__step.is-now .label { color: var(--color-primary); }
.roadmap__step .name {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 17px;
  color: var(--fg-1);
  margin-bottom: 6px;
}
.roadmap__step .what { font-size: 13px; color: var(--fg-3); }
.roadmap__step .marker {
  position: absolute;
  top: 28px; right: 28px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--border-3);
}
.roadmap__step.is-now .marker {
  background: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(251,179,21,.15);
}
.roadmap__step.is-next .marker { background: var(--fg-3); }

/* ─── CTA band ──────────────────────────────────────────── */
.cta-band {
  text-align: center;
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}
.cta-band::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 50% 50%, rgba(251,179,21,.1) 0%, transparent 65%);
  pointer-events: none;
}
.cta-band h2 {
  position: relative;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(32px, 3.8vw, 52px);
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 0 0 22px;
  text-wrap: balance;
}
.cta-band p {
  position: relative;
  font-size: 17px;
  font-weight: 300;
  color: var(--fg-3);
  margin: 0 auto 32px;
  max-width: 480px;
}
.cta-band__ctas { position: relative; display: inline-flex; gap: 12px; }

/* ─── Footer ────────────────────────────────────────────── */
.footer {
  border-top: 1px solid var(--border-1);
  padding: 72px 0 32px;
  background: var(--bg-app);
}
.footer__cols {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--border-1);
}
.footer__brand .brand { margin-bottom: 16px; }
.footer__brand .tagline {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 16px;
}
.footer__brand .blurb {
  font-size: 13px;
  line-height: 1.6;
  color: var(--fg-3);
  max-width: 280px;
}
.footer__col h4 {
  margin: 0 0 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight: 500;
}
.footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.footer__col li a { font-size: 14px; color: var(--fg-2); transition: color .12s; }
.footer__col li a:hover { color: var(--color-primary); }
.footer address {
  font-style: normal;
  font-size: 14px;
  line-height: 1.6;
  color: var(--fg-2);
}
.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 32px;
  font-size: 12px;
  color: var(--fg-4);
  gap: 24px; flex-wrap: wrap;
}
.footer__bottom__links { display: flex; gap: 24px; }
.footer__social { display: flex; gap: 12px; }
.footer__social a {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--border-2);
  border-radius: 6px;
  color: var(--fg-3);
  transition: color .12s, border-color .12s;
}
.footer__social a:hover { color: var(--fg-1); border-color: var(--border-3); }

/* ─── Page hero variants (sub-pages) ────────────────────── */
.page-hero {
  padding: 72px 0 64px;
  border-bottom: 1px solid var(--border-1);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(251,179,21,.06), transparent 60%);
  pointer-events: none;
}
.page-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
  position: relative;
}
.page-hero h1 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(40px, 5vw, 68px);
  line-height: 1.04;
  letter-spacing: -0.025em;
  margin: 14px 0 24px;
  color: var(--fg-1);
  text-wrap: balance;
}
.page-hero h1 em { font-style: normal; color: var(--color-primary); }
.page-hero h1.page-hero__h1--dc { font-size: clamp(32px, 3.6vw, 46px); }
.page-hero p.lead {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.6;
  color: var(--fg-3);
  margin: 0 0 32px;
  max-width: 540px;
}
.page-hero__ctas { display: flex; gap: 12px; }
.page-hero__art {
  position: relative;
  aspect-ratio: 1.1 / 1;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 16px;
  overflow: hidden;
}

/* ─── Generic two-col content row ───────────────────────── */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.two-col--reverse > :first-child { order: 2; }

/* ─── About: core values grid ─────────────────────────────── */
.values-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.value-card {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 16px;
  padding: 28px 24px;
  transition: border-color .2s ease, transform .2s ease;
}
.value-card:hover { border-color: rgba(251,179,21,.4); transform: translateY(-3px); }
.value-card__icon {
  width: 42px; height: 42px; border-radius: 11px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(251,179,21,.12); color: var(--color-primary);
  margin-bottom: 18px;
}
.value-card h3 {
  font-family: var(--font-heading); font-weight: 600; font-size: 19px;
  letter-spacing: -.01em; color: var(--fg-1); margin: 0 0 8px;
}
.value-card p { font-size: 14.5px; line-height: 1.55; color: var(--fg-3); margin: 0; }
@media (max-width: 920px) {
  .values-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .values-grid { grid-template-columns: 1fr; }
}

/* ─── Big statement section (used on SAM, hero callouts) ── */
.statement {
  padding: 72px 0;
  text-align: center;
}
.statement h2 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(28px, 3.6vw, 48px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 0 auto 18px;
  max-width: 880px;
  text-wrap: balance;
}
.statement p {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.55;
  color: var(--fg-3);
  max-width: 560px;
  margin: 0 auto;
}
.statement--inverse {
  background: var(--bg-panel);
  border-top: 1px solid var(--border-1);
  border-bottom: 1px solid var(--border-1);
}

/* ─── SAM action long card (vertical sequence) ──────────── */
.sam-action {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 48px;
  align-items: center;
  padding: 36px 0;
  border-top: 1px solid var(--border-1);
}
.sam-action:first-of-type { border-top: 0; }
.sam-action--reverse > :first-child { order: 2; }
.sam-action__step {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: 12px;
}
.sam-action h3 {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0 0 10px;
  color: var(--fg-1);
}
.sam-action p {
  font-size: 15px;
  font-weight: 300;
  line-height: 1.55;
  color: var(--fg-3);
  margin: 0 0 12px;
}
.sam-action__visual {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  padding: 22px;
  font-family: var(--font-mono);
  font-size: 13px;
  min-height: 260px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* ─── Press / media cards ───────────────────────────────── */
.press {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.press__card {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
  transition: border-color .15s ease, transform .15s ease;
  cursor: pointer;
}
.press__card:hover { border-color: var(--border-2); transform: translateY(-2px); }
.press__card .source {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--fg-3);
  display: flex; align-items: center; justify-content: space-between;
}
.press__card h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.3;
  color: var(--fg-1);
  margin: 0;
  flex: 1;
}
.press__card .read {
  font-size: 12px;
  color: var(--color-primary);
  display: inline-flex; align-items: center; gap: 4px;
}

.case-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.case {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color .15s ease, transform .15s ease;
}
.case:hover { border-color: var(--border-2); transform: translateY(-2px); }
.case__img {
  aspect-ratio: 16 / 10;
  background: var(--bg-app);
  position: relative;
  overflow: hidden;
}
.case__body { padding: 20px 24px 24px; }
.case__meta {
  display: flex; gap: 8px; align-items: center;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 10px;
}
.case__meta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--border-3); }
.case h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 18px;
  color: var(--fg-1);
  margin: 0 0 8px;
}
.case p {
  font-size: 13px;
  color: var(--fg-3);
  margin: 0;
  line-height: 1.5;
}

/* ─── GIS / wireframe visuals ──────────────────────────── */
.gis-card {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  overflow: hidden;
}

/* ─── Numbered list (used in industry pages) ────────────── */
.steps-list { display: flex; flex-direction: column; gap: 16px; counter-reset: stp; }
.step-row {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 16px;
  padding: 20px;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 10px;
}
.step-row .n {
  counter-increment: stp;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-primary);
  letter-spacing: .12em;
}
.step-row .n::before { content: "0" counter(stp); }
.step-row h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 16px;
  color: var(--fg-1);
  margin: 0 0 4px;
}
.step-row p { font-size: 14px; color: var(--fg-3); margin: 0; line-height: 1.5; }

/* ─── Workflow diagram (industry page) ──────────────────── */
.workflow {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-top: 32px;
}
.workflow__node {
  padding: 20px 16px;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 10px;
  text-align: center;
  position: relative;
}
.workflow__node + .workflow__node::before {
  content: "→";
  position: absolute;
  left: -16px; top: 50%;
  transform: translateY(-50%);
  color: var(--fg-4);
  font-family: var(--font-mono);
  font-size: 14px;
}
.workflow__node .icn {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-surface-1);
  border-radius: 8px;
  color: var(--color-primary);
  margin-bottom: 12px;
}
.workflow__node .name {
  font-size: 13px; font-weight: 500; color: var(--fg-1);
  font-family: var(--font-heading);
}
.workflow__node .sub {
  font-size: 11px; color: var(--fg-3);
  margin-top: 4px;
}

/* ─── Inline command (used in copy) ─────────────────────── */
.code {
  font-family: var(--font-mono);
  font-size: .92em;
  padding: 2px 6px;
  background: var(--bg-surface-1);
  border: 1px solid var(--border-1);
  border-radius: 4px;
  color: var(--fg-1);
}

/* ─── Reveal-on-scroll ───────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s cubic-bezier(.2,.8,.2,1), transform .6s cubic-bezier(.2,.8,.2,1);
}
.reveal.is-in { opacity: 1; transform: none; }

/* Ambient gradient overlay for select sections */
.section--glow { position: relative; isolation: isolate; }
.section--glow::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 55% 45% at 12% 25%, rgba(251,179,21,0.06) 0%, transparent 70%),
    radial-gradient(ellipse 45% 55% at 92% 80%, rgba(0,229,255,0.045) 0%, transparent 70%);
  pointer-events: none;
  z-index: -1;
}
.section--glow-soft { position: relative; isolation: isolate; }
.section--glow-soft::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(251,179,21,0.045) 0%, transparent 70%);
  pointer-events: none;
  z-index: -1;
}

/* ─── New patterns (V3 polish) ──────────────────────────── */

/* Replacement comparison — "we replace X with Y" row */
.replace {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.replace__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 56px minmax(0, 1fr);
  align-items: center;
  gap: 0;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .2s ease, transform .2s ease;
}
.replace__row:hover { border-color: var(--border-2); transform: translateY(-1px); }
.replace__cell {
  padding: 13px 22px;
  font-size: 15px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.replace__cell--from { color: var(--fg-3); text-decoration: line-through; text-decoration-color: rgba(207,102,121,.45); text-decoration-thickness: 1.5px; }
.replace__cell--from .ico {
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(207,102,121,.10); color: var(--color-error);
  border-radius: 8px; flex: 0 0 28px;
  text-decoration: none;
}
.replace__arrow {
  display: flex; align-items: center; justify-content: center;
  color: var(--color-primary);
  font-family: var(--font-mono);
  font-size: 18px;
  background: var(--bg-app);
  border-left: 1px solid var(--border-1);
  border-right: 1px solid var(--border-1);
  height: 100%;
}
.replace__cell--to {
  background: rgba(251,179,21,.04);
  color: var(--fg-1);
  font-weight: 500;
}
.replace__cell--to .ico {
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(251,179,21,.15); color: var(--color-primary);
  border-radius: 8px; flex: 0 0 28px;
}

/* SAM section with right-side illustration */
.sam-split {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 64px;
  align-items: center;
}
.sam-list {
  display: flex; flex-direction: column;
  gap: 14px;
}
.sam-item {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 18px;
  padding: 22px 24px;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  transition: border-color .2s ease, background .2s ease;
}
.sam-item:hover { border-color: var(--border-2); background: var(--bg-elevated); }
.sam-item__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .14em;
  color: var(--color-primary);
  padding-top: 4px;
}
.sam-item h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 18px;
  color: var(--fg-1);
  margin: 0 0 8px;
}
.sam-item .cmd {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--color-primary);
  background: var(--bg-app);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  padding: 6px 10px;
  display: inline-block;
  margin-bottom: 10px;
}
.sam-item p {
  font-size: 14px;
  font-weight: 300;
  color: var(--fg-3);
  margin: 0;
  line-height: 1.55;
}

/* Capabilities — scroll-pinned sequence */
.caps-scroll {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 64px;
}
.caps-scroll__sticky {
  position: sticky;
  top: 96px;
  height: fit-content;
  aspect-ratio: 1 / 1;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 20px;
  overflow: hidden;
  background-image: radial-gradient(circle at 30% 20%, rgba(251,179,21,0.06) 0%, transparent 55%);
}
.caps-scroll__sticky .cap-visual {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .5s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.caps-scroll__sticky .cap-visual.is-active { opacity: 1; }

/* Multi-frame cap visuals — auto-cycle between two illustrations */
.cap-visual .cap-frame { opacity: 0; transition: opacity .55s ease; }
.cap-visual .cap-frame.is-on { opacity: 1; }

/* Provenance watermark — sits in the sticky panel's bottom gutter, above the
   active illustration, so every cap visual is marked without clutter. */
.cap-watermark {
  position: absolute;
  right: 18px;
  bottom: 8px;
  z-index: 6;
  display: flex;
  align-items: center;
  gap: 7px;
  pointer-events: none;
  opacity: .4;
}
.cap-watermark img { height: 11px; width: auto; display: block; }
.cap-watermark span {
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fg-3);
  white-space: nowrap;
}

.caps-list { display: flex; flex-direction: column; gap: 32px; padding: 6vh 0; }
.cap-item {
  padding: 0;
  border-top: 1px solid var(--border-1);
  cursor: pointer;
  transition: opacity .25s ease;
  opacity: .4;
  min-height: 12vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.cap-item.is-active { opacity: 1; }
.caps-list .cap-item:first-child { border-top: none; padding-top: 0; }
.caps-list .cap-item:not(:first-child) { padding-top: 28px; }
.cap-item.is-active h3 { color: var(--color-primary); }
.cap-item__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .14em;
  color: var(--color-primary);
  margin-bottom: 12px;
  white-space: nowrap;
}
.cap-item h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: -.015em;
  color: var(--fg-1);
  margin: 0 0 12px;
  line-height: 1.15;
}
.cap-item p {
  font-size: 15px;
  font-weight: 300;
  line-height: 1.55;
  color: var(--fg-3);
  margin: 0;
  max-width: 460px;
}

/* Rich GIS visual container */
.gis-rich {
  position: relative;
  aspect-ratio: 16 / 11;
  background: linear-gradient(180deg, #0A0C10 0%, #050609 100%);
  border: 1px solid var(--border-1);
  border-radius: 16px;
  overflow: hidden;
}
.gis-rich__chip {
  position: absolute;
  display: inline-flex; align-items: center; gap: 8px;
  height: 24px; padding: 0 10px;
  background: rgba(13,15,20,.85);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border-2);
  border-radius: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .08em;
  color: var(--fg-2);
  z-index: 2;
}
.gis-rich__chip .dot {
  width: 6px; height: 6px; border-radius: 50%;
}

/* Shift comparison (single horizontal Before → After) */
.shift {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 56px minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
}
.shift__card {
  padding: 36px;
  border-radius: 16px;
  border: 1px solid var(--border-1);
  background: var(--bg-panel);
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.shift__card--today {
  border-color: rgba(207,102,121,.22);
  background: linear-gradient(180deg, rgba(207,102,121,.04) 0%, rgba(13,15,20,1) 100%);
}
.shift__card--ours {
  border-color: rgba(251,179,21,.30);
  background: linear-gradient(180deg, rgba(251,179,21,.05) 0%, rgba(13,15,20,1) 100%);
}
.shift__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.shift__label .dot {
  width: 5px; height: 5px; border-radius: 50%;
}
.shift__card--today .shift__label { color: var(--color-error); }
.shift__card--today .shift__label .dot { background: var(--color-error); }
.shift__card--ours .shift__label { color: var(--color-primary); }
.shift__card--ours .shift__label .dot { background: var(--color-primary); box-shadow: 0 0 6px rgba(251,179,21,.6); }
.shift__time {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--fg-1);
}
.shift__time small {
  display: block;
  font-family: var(--font-ui);
  font-weight: 300;
  font-size: 14px;
  color: var(--fg-3);
  letter-spacing: 0;
  margin-top: 8px;
}
.shift__chips {
  display: flex; flex-direction: column; gap: 10px;
  margin-top: 4px;
}
.shift__chip {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px;
  color: var(--fg-2);
  font-weight: 300;
}
.shift__chip .ico {
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  flex: 0 0 22px;
  font-size: 11px;
}
.shift__card--today .shift__chip .ico { background: rgba(207,102,121,.12); color: var(--color-error); }
.shift__card--ours .shift__chip .ico { background: rgba(251,179,21,.14); color: var(--color-primary); }
.shift__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
}
.shift__arrow svg { width: 32px; height: 32px; }

@media (max-width: 1100px) {
  .shift { grid-template-columns: 1fr; gap: 16px; }
  .shift__arrow { transform: rotate(90deg); padding: 8px 0; }
}

/* ─── Responsive ────────────────────────────────────────── */
@media (max-width: 1100px) {
  .hero__inner { grid-template-columns: 1fr; gap: 40px; }
  .page-hero__inner { grid-template-columns: 1fr; gap: 40px; }
  .two-col { grid-template-columns: 1fr; gap: 40px; }
  .sam-split { grid-template-columns: 1fr; gap: 40px; }
  .caps-scroll { grid-template-columns: 1fr; gap: 40px; }
  .caps-scroll__sticky { position: relative; top: 0; }
  .replace__row { grid-template-columns: minmax(0, 1fr) 44px minmax(0, 1fr); }
  .stats__inner { grid-template-columns: repeat(3, 1fr); }
  .tiles { grid-template-columns: repeat(2, 1fr); }
  .security { grid-template-columns: repeat(2, 1fr); }
  .industries { grid-template-columns: repeat(2, 1fr); }
  .case-grid, .press { grid-template-columns: repeat(2, 1fr); }
  .workflow { grid-template-columns: repeat(2, 1fr); }
  .workflow__node + .workflow__node::before { display: none; }
}
@media (max-width: 760px) {
  .container { padding: 0 20px; }
  .nav__links { display: none; }
  .section { padding: 80px 0; }
  .hero { padding: 80px 0 56px; }
  .page-hero { padding: 80px 0 56px; }
  .cta-band { padding: 96px 0; }
  .replace__row { grid-template-columns: 1fr; }
  .replace__arrow { display: none; }
  .replace__cell { padding: 16px 20px; }
  .nav__hamburger { display: inline-flex; }
  .nav__locale { display: none; }
  .cred__inner { grid-template-columns: 1fr; gap: 24px; }
  .cred__logos { flex-wrap: wrap; gap: 16px; }
  .sam-grid { grid-template-columns: 1fr; }
  .flow__track { grid-template-columns: 1fr; }
  .flow__step:not(:last-child)::after,
  .flow__step:not(:last-child)::before { display: none; }
  .compare { grid-template-columns: 1fr; gap: 16px; }
  .compare__vs { display: none; }
  .stats__inner { grid-template-columns: repeat(2, 1fr); }
  .tiles, .security, .industries { grid-template-columns: 1fr; }
  .case-grid, .press { grid-template-columns: 1fr; }
  .roadmap { flex-direction: column; }
  .roadmap__step + .roadmap__step { border-left: 0; border-top: 1px solid var(--border-1); }
  .sam-action { grid-template-columns: 1fr; gap: 24px; }
  .sam-action--reverse > :first-child { order: 0; }
  .footer__cols { grid-template-columns: 1fr 1fr; }
  .section { padding: 64px 0; }
  .cta-band { padding: 80px 0; }
}

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; }
  * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}

/* ─── Modals ──────────────────────────────────────────────── */
.modal-root { position: fixed; inset: 0; z-index: 2000; pointer-events: none; }
.modal-root.is-open { pointer-events: auto; }
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(3, 4, 6, 0.78);
  backdrop-filter: blur(6px);
  opacity: 0; transition: opacity .28s ease;
}
.modal-overlay.is-on { opacity: 1; }
.modal {
  position: fixed; left: 50%; top: 50%;
  transform: translate(-50%, -46%);
  width: min(920px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 18px;
  box-shadow: 0 40px 120px -30px rgba(0,0,0,.8);
  opacity: 0; visibility: hidden;
  transition: opacity .3s ease, transform .3s cubic-bezier(.2,.8,.2,1), visibility .3s;
  z-index: 2001;
}
.modal.is-on { opacity: 1; visibility: visible; transform: translate(-50%, -50%); }
.modal--form { padding: 40px clamp(24px, 4vw, 48px); }
.modal__close {
  position: absolute; top: 18px; right: 18px;
  width: 38px; height: 38px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-app); border: 1px solid var(--border-2);
  color: var(--fg-2); cursor: pointer; transition: all .18s ease; z-index: 3;
}
.modal__close:hover { color: var(--fg-1); border-color: var(--border-3, var(--fg-4)); }
.modal__close--onvideo { background: rgba(13,15,20,.7); }
.modal__head { max-width: 560px; margin-bottom: 28px; }
.modal__head .eyebrow { margin-bottom: 14px; }
.modal__head h2 {
  font-family: var(--font-heading); font-weight: 700;
  font-size: clamp(24px, 3vw, 34px); line-height: 1.1; letter-spacing: -.02em;
  color: var(--fg-1); margin: 0 0 12px;
}
.modal__head p { font-size: 15px; font-weight: 300; line-height: 1.55; color: var(--fg-3); margin: 0; max-width: 520px; }

.demo-form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 20px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field--full { margin-top: 16px; }
.field > span { font-size: 13px; color: var(--fg-2); font-weight: 500; }
.field > span i { color: var(--color-primary); font-style: normal; margin-left: 2px; }
.field input, .field select, .field textarea {
  width: 100%; box-sizing: border-box;
  background: var(--bg-app); border: 1px solid var(--border-2); border-radius: 9px;
  padding: 11px 13px; color: var(--fg-1);
  font-family: var(--font-ui); font-size: 14px;
  transition: border-color .16s ease, box-shadow .16s ease;
}
.field textarea { resize: vertical; min-height: 96px; }
.field input::placeholder, .field textarea::placeholder { color: var(--fg-4); }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(251,179,21,.14);
}
.field select { appearance: none; cursor: pointer; }
.field__phone { display: flex; gap: 8px; align-items: stretch; }
.field__cc {
  flex: 0 0 110px;
  padding: 0 10px;
  background: var(--bg-app); border: 1px solid var(--border-2); border-radius: 9px;
  color: var(--fg-1); font-family: var(--font-mono); font-size: 13px;
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237c7f86' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 8px center;
  padding-right: 24px;
}
.field__phone .field__cc { width: 110px; }
.field__cc:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(251,179,21,.14); }
.field__phone input { flex: 1; min-width: 0; }
.field__error { font-size: 12px; display: none; margin-top: -2px; }
.field span.field__error { color: #e53e3e; font-weight: 400; }
.field--invalid .field__error { display: block; }
.field--invalid input,
.field--invalid select,
.field--invalid textarea,
.field--invalid .field__cc,
.field--invalid .field__phone input { border-color: var(--color-error, #cf6679) !important; }
.field--invalid input:focus,
.field--invalid select:focus,
.field--invalid textarea:focus { box-shadow: 0 0 0 3px rgba(207,102,121,.18); }
.demo-form__foot {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  margin-top: 24px; flex-wrap: wrap;
}
.demo-form__note { font-size: 12px; color: var(--fg-4); }
.demo-form__done { text-align: center; padding: 32px 8px 12px; }
.demo-form__done-icon {
  width: 60px; height: 60px; border-radius: 50%; margin: 0 auto 20px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(3,201,136,.12); border: 1px solid rgba(3,201,136,.4); color: var(--color-success);
}
.demo-form__done h3 { font-family: var(--font-heading); font-weight: 700; font-size: 24px; color: var(--fg-1); margin: 0 0 10px; }
.demo-form__done p { font-size: 15px; font-weight: 300; color: var(--fg-3); margin: 0 auto 24px; max-width: 380px; line-height: 1.55; }

.modal--video { width: min(1040px, calc(100vw - 32px)); border-radius: 14px; overflow: hidden; }
.modal__video-frame { aspect-ratio: 16/9; background: #000; }
.modal__video-slot, .modal__video-slot iframe, .modal__video-slot video { width: 100%; height: 100%; display: block; border: 0; }
.modal__video-slot video { object-fit: contain; background: #000; }

@media (max-width: 720px) {
  .demo-form__grid { grid-template-columns: 1fr; }
  .modal--form { padding: 32px 20px; }
  .modal__head h2 { font-size: 24px; }
}

/* ─── Full-bleed background-video band ────────────────────── */
.video-band {
  position: relative;
  min-height: 66vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  border-top: 1px solid var(--border-1);
  border-bottom: 1px solid var(--border-1);
  background: #05060a url("assets/grid-floor.png") center / cover no-repeat;
}
.video-band__media {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0;
  transition: opacity .6s ease;
}
.video-band__media.is-ready { opacity: 1; }
.video-band__scrim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(90deg, rgba(5,6,9,.92) 0%, rgba(5,6,9,.72) 42%, rgba(5,6,9,.30) 100%),
    linear-gradient(0deg, rgba(5,6,9,.85) 0%, transparent 36%);
}
.video-band__inner { position: relative; z-index: 2; width: 100%; padding: 56px 0; }
.video-band__inner h2 {
  font-family: var(--font-heading); font-weight: 800;
  font-size: clamp(34px, 4.6vw, 58px); line-height: 1.04; letter-spacing: -.025em;
  color: var(--fg-1); margin: 16px 0 18px; max-width: 20ch; text-wrap: balance;
}
.video-band__inner p {
  font-size: 18px; font-weight: 300; line-height: 1.55; color: var(--fg-2);
  max-width: 600px; margin: 0 0 32px;
}
.eyebrow--onvideo { color: var(--color-primary); }
.hero-proof {
  display: flex; flex-wrap: wrap; gap: 10px 22px; margin-top: 28px;
}
.hero-proof span {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-heading); font-weight: 600; font-size: 14px; color: var(--fg-1);
}
.hero-proof span i { color: var(--color-primary); }
.video-band__ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.video-band__badge {
  position: absolute; right: 0; bottom: 28px; z-index: 2;
  display: flex; align-items: center; gap: 14px;
  font-family: var(--font-mono); font-size: 11px; color: var(--fg-3);
}
.video-band__live {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 11px; border: 1px solid rgba(3,201,136,.4);
  background: rgba(3,201,136,.08); border-radius: 14px; color: var(--color-success);
  letter-spacing: .08em;
}
.video-band__live span {
  width: 6px; height: 6px; border-radius: 50%; background: var(--color-success);
  box-shadow: 0 0 6px rgba(3,201,136,.7);
}
.video-band__sess { color: var(--fg-4); }
@media (max-width: 720px) {
  .video-band { min-height: 60vh; }
  .video-band__inner { padding: 48px 0; }
  .video-band__badge { left: 0; right: auto; }
}

/* ─── Domain showcase cards ───────────────────────────────── */
.domains {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.domain-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 16px;
  padding: 22px;
  transition: border-color .2s ease, transform .2s ease;
}
.domain-card:hover { border-color: rgba(251,179,21,.4); transform: translateY(-3px); }
.domain-card__head { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.domain-card__icon {
  width: 30px; height: 30px; border-radius: 8px; flex: 0 0 30px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(251,179,21,.12); color: var(--color-primary);
}
.domain-card__name { font-family: var(--font-heading); font-weight: 600; font-size: 16px; color: var(--fg-1); }
.domain-card__tag {
  margin-left: auto; font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 999px;
  background: rgba(3,201,136,.1); border: 1px solid rgba(3,201,136,.4); color: var(--color-success);
}
.domain-card__tag--beta { background: rgba(0,229,255,.08); border-color: rgba(0,229,255,.4); color: var(--color-secondary); }
.domain-card__art {
  background: var(--bg-app);
  border: 1px solid var(--border-1);
  border-radius: 10px;
  padding: 8px;
  margin-bottom: 14px;
}
.domain-card__art svg { display: block; width: 100%; height: auto; }
.domain-card__art--photo { position: relative; overflow: hidden; padding: 0; }
.domain-card__art--photo img { display: block; width: 100%; aspect-ratio: 320 / 150; object-fit: cover; object-position: 50% 58%; border-radius: 9px; }
.domain-card__chainage {
  position: absolute; left: 10px; bottom: 8px;
  font-family: var(--font-mono); font-size: 8px; letter-spacing: 1px;
  color: rgba(190,195,205,.7);
}
.domain-card__wm {
  position: absolute; right: 9px; bottom: 8px;
  display: flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 8px; letter-spacing: .5px;
  color: rgba(190,195,205,.55); opacity: .85;
}
.domain-card__wm img { height: 9px; width: auto; opacity: .7; }
.sam-illus-wm {
  position: absolute; right: 14px; bottom: 12px; z-index: 3;
  display: flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .5px;
  color: rgba(190,195,205,.5); pointer-events: none;
}
.sam-illus-wm img { height: 9px; width: auto; opacity: .6; }

/* ── SAM "every domain" showcase band ─────────────────────── */
.dom-show { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 12px; }
.dom-show__card { background: var(--bg-panel); border: 1px solid var(--border-1); border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; }
.dom-show__media { position: relative; aspect-ratio: 16 / 10; overflow: hidden; background: #070b12; border-bottom: 1px solid var(--border-1); }
.dom-show__media > img, .dom-show__media > svg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.dom-show__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,6,9,0) 55%, rgba(5,6,9,.55) 100%); pointer-events: none; }
.dom-show__tag { position: absolute; top: 12px; right: 12px; z-index: 2; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--color-success); display: flex; align-items: center; gap: 6px; background: rgba(0,0,0,.4); backdrop-filter: blur(4px); padding: 4px 9px; border-radius: 999px; border: 1px solid var(--border-2); }
.dom-show__tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--color-success); }
.dom-show__tag--beta { color: var(--color-secondary); }
.dom-show__tag--beta::before { background: var(--color-secondary); }
.dom-show__wm { position: absolute; top: 12px; left: 12px; z-index: 2; display: flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .5px; color: rgba(220,225,235,.5); }
.dom-show__wm img { height: 9px; width: auto; opacity: .55; }
.dom-show__cmd { position: absolute; left: 12px; bottom: 12px; z-index: 2; font-family: var(--font-mono); font-size: 11px; line-height: 1.3; color: var(--color-primary); background: rgba(0,0,0,.5); backdrop-filter: blur(4px); padding: 6px 10px; border-radius: 7px; border: 1px solid rgba(251,179,21,.25); max-width: calc(100% - 24px); }
.dom-show__cmd span { color: var(--fg-3); }
.dom-show__body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 13px; }
.dom-show__name { display: flex; align-items: center; gap: 9px; font-family: var(--font-ui); font-weight: 500; font-size: 16px; color: var(--fg-1); }
.dom-show__name > span:first-child { width: 26px; height: 26px; border-radius: 7px; background: rgba(251,179,21,.12); border: 1px solid rgba(251,179,21,.25); display: inline-flex; align-items: center; justify-content: center; color: var(--color-primary); }
.dom-show__desc { font-size: 13.5px; line-height: 1.55; color: var(--fg-3); margin: 0; }
.dom-show__data { list-style: none; margin: 2px 0 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1px; background: var(--border-1); border: 1px solid var(--border-1); border-radius: 10px; overflow: hidden; }
.dom-show__data li { background: var(--bg-app); padding: 11px 13px; display: flex; flex-direction: column; gap: 3px; }
.dom-show__data .k { font-family: var(--font-mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; color: var(--fg-4); }
.dom-show__data .v { font-family: var(--font-ui); font-size: 16px; font-weight: 500; color: var(--fg-1); line-height: 1.1; }
.dom-show__data .v small { font-size: .58em; color: var(--fg-3); font-weight: 400; letter-spacing: .02em; }
@media (max-width: 900px) { .dom-show { grid-template-columns: 1fr; } }
@media (prefers-reduced-motion: reduce) {
  .sam-w .sam-row, .sam-w [class*="sam-m"] { opacity: 1 !important; transform: none !important; animation: none !important; }
  .sam-svg-b svg * { opacity: 1 !important; stroke-dashoffset: 0 !important; animation: none !important; }
}
/* Panel watermark for product-UI illustrations */
.cap-wm {
  position: absolute; right: 12px; bottom: 10px; z-index: 6;
  display: flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .5px;
  color: rgba(190,195,205,.45); pointer-events: none;
}
.cap-wm img { height: 9px; width: auto; opacity: .55; }
/* DC journey UI primitives */
.dcui { position: absolute; inset: 24px; background: var(--bg-panel); border: 1px solid var(--border-1); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; }
.dcui__bar { display: flex; align-items: center; gap: 6px; padding: 9px 14px; border-bottom: 1px solid var(--border-1); font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); flex-wrap: wrap; }
.dcui__tab { padding: 3px 9px; border: 1px solid var(--border-2); border-radius: 5px; color: var(--fg-3); font-size: 9px; }
.dcui__tab--on { background: rgba(0,229,255,.10); border-color: rgba(0,229,255,.4); color: var(--color-secondary); }
.dcui__tab--amber { background: rgba(251,179,21,.12); border-color: rgba(251,179,21,.45); color: var(--color-primary); }
.dcui__dot { width: 5px; height: 5px; border-radius: 50%; background: var(--color-success); box-shadow: 0 0 5px rgba(3,201,136,.6); }
.domain-card__prompt {
  font-family: var(--font-mono); font-size: 11.5px; line-height: 1.5;
  color: var(--fg-2); background: var(--bg-app);
  border: 1px solid var(--border-1); border-radius: 8px;
  padding: 10px 12px; margin-bottom: 14px;
}
.domain-card__prompt span { color: var(--color-primary); margin-right: 4px; }
.domain-card__out { list-style: none; padding: 0; margin: 0 0 18px; display: flex; flex-direction: column; gap: 9px; }
.domain-card__out li { display: flex; gap: 9px; align-items: flex-start; font-size: 13.5px; color: var(--fg-2); line-height: 1.4; }
.domain-card__out li i { color: var(--color-success); flex: 0 0 auto; margin-top: 3px; }
.domain-card__link {
  margin-top: auto; display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-ui); font-size: 13px; font-weight: 500; color: var(--color-primary);
  text-decoration: none; transition: gap .18s ease;
}
.domain-card__link:hover { gap: 10px; }
@media (max-width: 920px) {
  .domains { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
}
