:root {
  --bg: #f3f5ff;
  --bg-soft: rgba(255, 255, 255, 0.72);
  --surface: rgba(255, 255, 255, 0.92);
  --surface-strong: #ffffff;
  --surface-dark: #11183a;
  --line: rgba(17, 24, 58, 0.1);
  --line-strong: rgba(17, 24, 58, 0.18);
  --text: #11183a;
  --text-soft: rgba(17, 24, 58, 0.72);
  --text-faint: rgba(17, 24, 58, 0.56);
  --indigo: #4f46e5;
  --violet: #7c3aed;
  --rose: #f43f5e;
  --teal: #0f766e;
  --amber: #f59e0b;
  --navy: #0c1333;
  --shadow: 0 28px 80px rgba(57, 57, 109, 0.14);
  --shadow-soft: 0 16px 40px rgba(17, 24, 58, 0.08);
  --radius-sm: 14px;
  --radius: 24px;
  --radius-lg: 32px;
  --shell: min(1240px, calc(100vw - 32px));
  --font-body: "Outfit", sans-serif;
  --font-heading: "Plus Jakarta Sans", "Outfit", sans-serif;
  --font-mono: "IBM Plex Mono", monospace;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(79, 70, 229, 0.16), transparent 34%),
    radial-gradient(circle at 85% 12%, rgba(244, 63, 94, 0.16), transparent 24%),
    linear-gradient(180deg, #f8f9ff 0%, #eef2ff 48%, #f3f5ff 100%);
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.6;
  min-height: 100vh;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(79, 70, 229, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79, 70, 229, 0.03) 1px, transparent 1px);
  background-size: 36px 36px;
  mask-image: radial-gradient(circle at center, black 35%, transparent 78%);
  pointer-events: none;
  z-index: -1;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

p,
ul,
ol,
blockquote {
  margin: 0 0 1.15rem;
}

ul,
ol {
  padding-left: 1.2rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0 0 1rem;
  color: var(--navy);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.08;
}

h1 {
  font-size: clamp(3rem, 6vw, 5.5rem);
}

h2 {
  font-size: clamp(2rem, 4vw, 3.4rem);
}

h3 {
  font-size: clamp(1.3rem, 2vw, 1.7rem);
}

.site-shell {
  width: var(--shell);
  margin: 0 auto;
}

.site-canvas {
  min-height: 100vh;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  padding: 18px 0;
  transition: padding 180ms ease;
}

body.is-scrolled .site-header {
  padding: 10px 0;
}

.site-header__inner {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 24px;
  padding: 16px 22px;
  border: 1px solid rgba(255, 255, 255, 0.62);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(18px);
  box-shadow: 0 12px 34px rgba(17, 24, 58, 0.08);
}

.site-branding {
  min-width: 0;
}

.site-brand,
.custom-logo-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.site-brand {
  position: relative;
  transition: transform 180ms ease, opacity 180ms ease;
}

.site-brand:hover {
  transform: translateY(-1px);
}

/* SVG inline logo variant */
.site-brand--svg {
  gap: 14px;
}

.site-logo-mark {
  flex-shrink: 0;
  display: block;
  overflow: visible;
  filter: drop-shadow(0 14px 22px rgba(79, 70, 229, 0.14));
  transition: transform 180ms ease, filter 180ms ease;
}

.site-brand:hover .site-logo-mark {
  transform: scale(1.03);
  filter: drop-shadow(0 18px 28px rgba(79, 70, 229, 0.24));
}

.site-logo-mark .brand-mark__frame,
.site-logo-mark .brand-mark__core,
.site-logo-mark .brand-mark__rail,
.site-logo-mark .brand-mark__dot {
  transition: opacity 180ms ease, transform 180ms ease, stroke 180ms ease, fill 180ms ease;
  transform-origin: center;
  transform-box: fill-box;
}

.site-brand:hover .site-logo-mark .brand-mark__frame {
  stroke: rgba(199, 210, 254, 0.42);
  fill: rgba(255, 255, 255, 0.08);
}

.site-brand:hover .site-logo-mark .brand-mark__rail,
.site-brand:hover .site-logo-mark .brand-mark__dot {
  opacity: 1;
  transform: translateY(-0.75px);
}

.custom-logo-link img {
  max-height: 42px;
  width: auto;
}

/* PNG logo variant */
.site-brand--logo {
  gap: 0;
}

.site-logo-img {
  display: block;
  height: 46px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  transition: opacity 180ms ease, transform 180ms ease;
}

.site-brand--logo:hover .site-logo-img {
  opacity: 0.88;
  transform: translateY(-1px);
}


.site-brand__mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--indigo), var(--rose));
  color: #fff;
  font-size: 1.1rem;
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(79, 70, 229, 0.28);
}

.site-brand__copy {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.site-brand__name {
  color: var(--navy);
  font-size: 1.08rem;
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.15;
}

/* "AI" gets the indigo accent */
.site-brand__name em {
  font-style: normal;
  color: var(--indigo);
}

.site-brand__tag {
  color: var(--text-faint);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  line-height: 1.2;
}

.site-brand--inverse .site-brand__name {
  color: #fff;
}

.site-brand--inverse .site-brand__name em {
  color: #c4b5fd;
}

.site-brand--inverse .site-brand__tag {
  color: rgba(199, 210, 254, 0.68);
}

.site-navigation {
  justify-self: center;
}

/* ── Top-level list ─────────────────────────────────────── */
.site-menu,
.footer-menu {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Top-level items */
.site-menu > li {
  position: relative;
}

/* Top-level links and dropdown toggles */
.site-menu > li > a,
.site-menu > li > button.nav-group-toggle {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 10px 14px;
  border-radius: 999px;
  border: none;
  background: none;
  color: var(--text-soft);
  font-size: 0.9rem;
  font-family: inherit;
  font-weight: 500;
  cursor: pointer;
  transition:
    color 180ms ease,
    background-color 180ms ease,
    transform 180ms ease;
  white-space: nowrap;
}

.site-menu > li > a:hover,
.site-menu > li > button.nav-group-toggle:hover,
.site-menu > li.is-open > button.nav-group-toggle,
.site-menu .current-menu-item > a,
.site-menu .current_page_item > a {
  color: var(--navy);
  background: rgba(79, 70, 229, 0.09);
}

/* Dropdown chevron icon */
.nav-group-toggle::after {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  transition: transform 220ms ease;
  flex-shrink: 0;
}
.site-menu > li.is-open > .nav-group-toggle::after {
  transform: rotate(-135deg) translateY(-2px);
}

/* ── Dropdown panel ──────────────────────────────────────── */
.site-menu .sub-menu {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 200px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 14px;
  box-shadow:
    0 4px 6px rgba(0,0,0,0.04),
    0 16px 40px rgba(79,70,229,0.14);
  list-style: none;
  margin: 0;
  padding: 8px;
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 180ms ease,
    transform 180ms ease;
  z-index: 900;
}

.site-menu > li.is-open > .sub-menu,
.site-menu > li:focus-within > .sub-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

/* Dropdown items */
.site-menu .sub-menu a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  color: var(--text-soft);
  font-size: 0.875rem;
  font-weight: 500;
  transition:
    color 150ms ease,
    background 150ms ease;
  white-space: nowrap;
}

.site-menu .sub-menu a:hover,
.site-menu .sub-menu .current-menu-item a,
.site-menu .sub-menu .current_page_item a {
  color: var(--navy);
  background: rgba(79, 70, 229, 0.07);
}

/* Dropdown item accent dot */
.site-menu .sub-menu li::before {
  display: none;
}

/* Footer menu — stays flat */
.footer-menu a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  color: var(--text-soft);
  font-weight: 500;
  transition:
    color 180ms ease,
    background-color 180ms ease;
}
.footer-menu a:hover {
  color: var(--navy);
  background: rgba(79, 70, 229, 0.08);
}


.site-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 999px;
  background: rgba(79, 70, 229, 0.08);
  cursor: pointer;
}

.site-nav-toggle>span:not(.screen-reader-text) {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 99px;
  background: var(--navy);
}

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 24px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  color: #fff;
  font-weight: 600;
  letter-spacing: -0.01em;
  box-shadow: 0 18px 34px rgba(79, 70, 229, 0.22);
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    opacity 180ms ease;
}

.button:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 38px rgba(79, 70, 229, 0.26);
}

.button--secondary {
  background: rgba(255, 255, 255, 0.66);
  border-color: rgba(17, 24, 58, 0.08);
  color: var(--navy);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.42), var(--shadow-soft);
}

.button--ghost {
  background: rgba(79, 70, 229, 0.08);
  color: var(--indigo);
  border-color: rgba(79, 70, 229, 0.1);
  box-shadow: none;
}

.button--small {
  min-height: 44px;
  padding: 0 18px;
}

.section {
  padding: 54px 0;
}

.section--tight {
  padding: 28px 0 54px;
}

.section--contrast {
  background: linear-gradient(180deg, rgba(17, 24, 58, 0.02), rgba(17, 24, 58, 0.06));
}

.section--workflow {
  position: relative;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  color: var(--indigo);
  font-family: "IBM Plex Mono", monospace;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  width: 38px;
  height: 1px;
  background: currentColor;
  opacity: 0.45;
}

.eyebrow--soft {
  color: rgba(255, 255, 255, 0.74);
}

.section-heading {
  max-width: 760px;
  margin-bottom: 28px;
}

.section-title {
  max-width: 12ch;
}

.section-lede,
.page-hero__intro,
.hero__lede,
.proof-strip p {
  color: var(--text-soft);
  font-size: clamp(1.02rem, 1.3vw, 1.18rem);
}

.hero {
  padding-top: 34px;
  padding-bottom: 54px;
}

.hero--has-orbs {
  position: relative;
  overflow: hidden;
}

.hero__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: 30px;
  align-items: stretch;
}

.hero__copy,
.hero__panel,
.content-card,
.article-card,
.feature-card,
.challenge-card,
.module-card,
.workflow-card,
.pricing-card,
.contact-sidecard,
.proof-strip,
.cta-panel {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.82));
  box-shadow: var(--shadow);
}

.hero__copy {
  padding: clamp(34px, 4.6vw, 58px);
  overflow: hidden;
}

.hero__copy::before {
  content: "";
  position: absolute;
  inset: auto -12% -34% auto;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79, 70, 229, 0.14), transparent 68%);
  pointer-events: none;
}

.hero__panel {
  padding: 24px;
  background:
    linear-gradient(160deg, rgba(12, 19, 51, 0.96), rgba(32, 44, 103, 0.96)),
    linear-gradient(135deg, var(--indigo), var(--rose));
  color: #fff;
  overflow: hidden;
}

.hero__panel::before {
  content: "";
  position: absolute;
  inset: auto auto -120px -80px;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(244, 63, 94, 0.26), transparent 60%);
  pointer-events: none;
}

.hero__panel h2,
.hero__panel p {
  color: #fff;
}

.hero__signal {
  padding: 12px;
}

.hero__signal p:last-child {
  color: rgba(255, 255, 255, 0.76);
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin: 30px 0 24px;
}

.hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.hero__chips li {
  padding: 10px 16px;
  border: 1px solid rgba(79, 70, 229, 0.12);
  border-radius: 999px;
  background: rgba(79, 70, 229, 0.05);
  color: var(--navy);
  font-family: "IBM Plex Mono", monospace;
  font-size: 0.8rem;
}

.hero__mini-grid,
.coverage-grid,
.feature-grid,
.challenge-grid,
.learning-grid,
.atlas-grid,
.module-grid,
.service-grid,
.workflow-grid,
.update-grid,
.metric-strip,
.pricing-grid,
.insights-grid {
  display: grid;
  gap: 18px;
}

.hero__mini-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 24px;
}

.metric-card {
  padding: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.08);
}

.metric-card strong {
  display: block;
  margin-bottom: 10px;
  color: #fff;
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.1;
}

.metric-card span {
  display: block;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.95rem;
}

.metric-card--indigo strong {
  color: #c7d2fe;
}

.metric-card--rose strong {
  color: #fecdd3;
}

.metric-card--teal strong {
  color: #99f6e4;
}

.metric-card--amber strong {
  color: #fde68a;
}

.proof-strip {
  padding: 24px 28px;
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.08), rgba(244, 63, 94, 0.08));
}

.coverage-grid,
.feature-grid,
.challenge-grid,
.learning-grid,
.atlas-grid,
.module-grid,
.service-grid,
.workflow-grid,
.update-grid,
.pricing-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.atlas-grid--full,
.metric-strip {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.coverage-card,
.learning-card,
.atlas-card,
.service-card,
.update-card,
.feature-card,
.challenge-card,
.module-card,
.workflow-card,
.pricing-card,
.article-card {
  padding: 28px;
}

.coverage-card,
.learning-card,
.atlas-card,
.service-card,
.update-card,
.metric-panel {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.82));
  box-shadow: var(--shadow-soft);
}

.metric-panel {
  padding: 22px 24px;
}

.metric-panel strong {
  display: block;
  margin-bottom: 8px;
  color: var(--navy);
  font-size: clamp(1.7rem, 2vw, 2.4rem);
  line-height: 1;
}

.metric-panel span {
  color: var(--text-soft);
}

.coverage-card h3,
.learning-card h3,
.atlas-card h3,
.service-card h3,
.update-card h3,
.feature-card h3,
.challenge-card h3,
.module-card h3,
.workflow-card h3,
.pricing-card h3,
.article-card h2 {
  font-size: 1.4rem;
}

.feature-card p,
.challenge-card p,
.coverage-card p,
.learning-card p,
.atlas-card p,
.service-card p,
.update-card p,
.module-card p,
.workflow-card p,
.pricing-card li,
.article-card p {
  color: var(--text-soft);
}

.card-kicker,
.card-meta,
.challenge-card span,
.pricing-card__name,
.module-card__eyebrow,
.article-card__meta {
  display: inline-flex;
  margin-bottom: 14px;
  color: var(--text-faint);
  font-family: "IBM Plex Mono", monospace;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.card-meta {
  margin-top: 18px;
  margin-bottom: 0;
  font-size: 0.72rem;
}

.detail-list {
  margin: 18px 0 0;
  padding-left: 1.1rem;
}

.detail-list--tight {
  margin-top: 16px;
}

.detail-list li {
  margin-bottom: 0.6rem;
  color: var(--text-soft);
}

.detail-list li strong {
  color: var(--navy);
}

.detail-list li span {
  display: block;
  margin-top: 6px;
  color: var(--text-soft);
}

.section-link {
  margin-top: 24px;
}

.module-card {
  overflow: hidden;
}

.module-card::after {
  content: "";
  position: absolute;
  inset: auto -24px -46px auto;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  opacity: 0.16;
}

.module-card--indigo::after {
  background: radial-gradient(circle, var(--indigo), transparent 70%);
}

.module-card--violet::after {
  background: radial-gradient(circle, var(--violet), transparent 70%);
}

.module-card--rose::after {
  background: radial-gradient(circle, var(--rose), transparent 70%);
}

.module-card--teal::after {
  background: radial-gradient(circle, var(--teal), transparent 70%);
}

.module-card--amber::after {
  background: radial-gradient(circle, var(--amber), transparent 70%);
}

/* Module card header (name + tagline row) */
.module-card__header {
  margin-bottom: 12px;
}

.module-card__tagline {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-top: 4px;
}

/* Feature card with icon */
.feature-card--accented {
  position: relative;
}

.feature-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  margin-bottom: 16px;
}

.feature-card--indigo .feature-card__icon { background: rgba(79,70,229,.1);  color: var(--indigo); }
.feature-card--teal   .feature-card__icon { background: rgba(20,184,166,.1); color: var(--teal); }
.feature-card--violet .feature-card__icon { background: rgba(124,58,237,.1); color: var(--violet); }
.feature-card--rose   .feature-card__icon { background: rgba(244,63,94,.1);  color: var(--rose); }
.feature-card--amber  .feature-card__icon { background: rgba(245,158,11,.1); color: var(--amber); }

/* Hero headline gradient dot */
.hero__dot {
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Strap band */
.section--strap {
  background: linear-gradient(135deg, rgba(79,70,229,0.05), rgba(124,58,237,0.03));
  border-top: 1px solid rgba(79,70,229,0.08);
  border-bottom: 1px solid rgba(79,70,229,0.08);
}

/* Pricing card CTA button at bottom */
.pricing-card .button {
  margin-top: auto;
}

.pricing-card--featured .button {
  background: #fff;
  color: var(--indigo);
}

.pricing-card--featured .button:hover {
  background: rgba(255,255,255,0.9);
}


.workflow-card {
  padding-top: 24px;
}

.meta-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(79, 70, 229, 0.08);
  color: var(--indigo);
  font-weight: 700;
}

.meta-pill--soft {
  background: rgba(244, 63, 94, 0.08);
  color: var(--rose);
}

.workflow-card__step {
  display: inline-grid;
  place-items: center;
  width: 54px;
  height: 54px;
  margin-bottom: 18px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.12), rgba(124, 58, 237, 0.12));
  color: var(--indigo);
  font-family: "IBM Plex Mono", monospace;
  font-size: 0.9rem;
  font-weight: 700;
}

.pricing-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.pricing-card ul {
  margin: 0;
  padding-left: 1.1rem;
}

.pricing-card--featured {
  background:
    linear-gradient(180deg, rgba(79, 70, 229, 0.96), rgba(124, 58, 237, 0.94)),
    var(--surface-strong);
  color: #fff;
  border-color: rgba(79, 70, 229, 0.18);
}

.pricing-card--featured h3,
.pricing-card--featured li,
.pricing-card--featured .pricing-card__name {
  color: #fff;
}

.cta-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
  padding: 28px 30px;
  background:
    radial-gradient(circle at top right, rgba(244, 63, 94, 0.12), transparent 22%),
    linear-gradient(135deg, rgba(79, 70, 229, 0.06), rgba(124, 58, 237, 0.04)),
    rgba(255, 255, 255, 0.9);
}

.cta-panel--compact h2 {
  font-size: clamp(1.45rem, 2vw, 2rem);
  max-width: 24ch;
}

.cta-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.page-hero {
  padding-top: 24px;
}

.page-hero .site-shell {
  padding: 38px 42px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at right top, rgba(244, 63, 94, 0.13), transparent 28%),
    linear-gradient(135deg, rgba(79, 70, 229, 0.08), rgba(124, 58, 237, 0.03)),
    rgba(255, 255, 255, 0.86);
  box-shadow: var(--shadow);
}

.page-hero h1 {
  max-width: 12ch;
}

.content-card {
  padding: clamp(26px, 4vw, 42px);
}

.entry-content>*:last-child {
  margin-bottom: 0;
}

.entry-content h2,
.entry-content h3 {
  margin-top: 1.8rem;
}

.entry-content ul li,
.entry-content ol li {
  margin-bottom: 0.6rem;
}

.entry-content strong {
  color: var(--navy);
}

.entry-content blockquote {
  padding: 18px 22px;
  border-left: 4px solid var(--indigo);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  background: rgba(79, 70, 229, 0.06);
}

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
  gap: 24px;
  align-items: start;
}

.contact-sidecard {
  padding: 28px;
  position: sticky;
  top: 108px;
}

.contact-sidecard ul {
  padding-left: 1.1rem;
}

.contact-sidecard__notice {
  margin-top: 22px;
  padding: 18px;
  border: 1px solid rgba(79, 70, 229, 0.12);
  border-radius: 20px;
  background: rgba(79, 70, 229, 0.05);
}

.insights-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.article-card a:hover {
  color: var(--indigo);
}

.article-card__link,
.back-link a {
  color: var(--indigo);
  font-weight: 600;
}

.pagination {
  margin-top: 24px;
}

.pagination .nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid rgba(79, 70, 229, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
}

.pagination .current {
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  color: #fff;
}

.back-link {
  margin-top: 20px;
}

.site-footer {
  padding: 40px 0 56px;
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 0.9fr;
  gap: 28px;
  padding: 34px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(17, 24, 58, 0.98), rgba(36, 49, 114, 0.98)),
    linear-gradient(135deg, var(--indigo), var(--rose));
  box-shadow: var(--shadow);
}

.site-footer__grid h2,
.site-footer__grid h3,
.site-footer__grid p,
.site-footer__grid a {
  color: #fff;
}

.site-footer__brand p,
.site-footer__grid .footer-menu a {
  color: rgba(255, 255, 255, 0.74);
}

.site-footer__grid .footer-menu {
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}

.site-footer__grid .footer-menu a {
  padding: 0;
  background: transparent;
}

.site-footer__grid .footer-menu a:hover {
  color: #fff;
  transform: none;
}

.site-footer__bar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-top: 16px;
  padding: 0 10px;
  color: var(--text-faint);
  font-size: 0.92rem;
}

[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 420ms ease,
    transform 420ms ease;
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

.wp-block-button__link {
  border-radius: 999px;
}

@media (max-width: 1120px) {
  .site-header__inner {
    grid-template-columns: auto 1fr auto;
    gap: 18px;
  }

  .header-cta {
    display: none;
  }

  .hero__layout,
  .contact-layout,
  .site-footer__grid,
  .cta-panel {
    grid-template-columns: 1fr;
  }

  /* Hero panel: at ≤1120px it stacks below copy.
     overflow:hidden on the panel collapses its height when stacked.
     Remove overflow, set a sensible min-height.  */
  .hero__panel {
    overflow: visible;
    min-height: 340px;
    order: 2; /* Always AFTER the copy column */
  }

  /* Hero copy: ensure full padding and no height collapse, always first */
  .hero__copy {
    overflow: visible;
    order: 1;
  }


  .feature-grid,
  .challenge-grid,
  .coverage-grid,
  .learning-grid,
  .atlas-grid,
  .module-grid,
  .service-grid,
  .workflow-grid,
  .update-grid,
  .metric-strip,
  .pricing-grid,
  .insights-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  /* On mobile, hide the hero panel entirely — copy + CTAs are more valuable */
  .hero__panel {
    display: none;
  }

  /* Reset hero layout to single natural column */
  .hero__layout {
    grid-template-columns: 1fr;
  }

  :root {
    --shell: min(1240px, calc(100vw - 22px));
  }

  .site-header__inner {
    grid-template-columns: auto auto;
    justify-content: space-between;
    border-radius: 30px;
  }

  .site-nav-toggle {
    display: inline-flex;
  }

  .site-navigation {
    display: none;
    grid-column: 1 / -1;
    justify-self: stretch;
    padding-top: 8px;
  }

  .site-header.is-nav-open .site-navigation {
    display: block;
  }

  .site-menu {
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
  }

  .site-menu > li > a,
  .site-menu > li > button.nav-group-toggle {
    justify-content: space-between;
    width: 100%;
    border-radius: 10px;
    padding: 12px 16px;
    font-size: 0.95rem;
  }

  /* Mobile sub-menu — static, not absolute */
  .site-menu .sub-menu {
    position: static;
    transform: none;
    left: auto;
    top: auto;
    border-radius: 10px;
    box-shadow: none;
    border: none;
    background: rgba(79, 70, 229, 0.04);
    margin: 2px 0 4px 0;
    padding: 4px 0 4px 12px;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transition:
      max-height 280ms ease,
      opacity 200ms ease;
  }

  .site-menu > li.is-open > .sub-menu,
  .site-menu > li:focus-within > .sub-menu {
    max-height: 400px;
    opacity: 1;
    pointer-events: auto;
    transform: none;
  }

  .site-menu .sub-menu a {
    border-radius: 8px;
    padding: 10px 14px;
  }


  .hero__mini-grid,
  .feature-grid,
  .challenge-grid,
  .coverage-grid,
  .learning-grid,
  .atlas-grid,
  .module-grid,
  .service-grid,
  .workflow-grid,
  .update-grid,
  .metric-strip,
  .pricing-grid,
  .insights-grid {
    grid-template-columns: 1fr;
  }

  .page-hero .site-shell,
  .content-card,
  .coverage-card,
  .learning-card,
  .atlas-card,
  .service-card,
  .update-card,
  .metric-panel,
  .feature-card,
  .challenge-card,
  .module-card,
  .workflow-card,
  .pricing-card,
  .article-card,
  .contact-sidecard {
    padding: 24px;
  }
}

@media (max-width: 640px) {
  h1 {
    font-size: clamp(2.4rem, 12vw, 3.4rem);
  }

  h2 {
    font-size: clamp(1.7rem, 8vw, 2.4rem);
  }

  .hero__actions,
  .cta-panel__actions,
  .hero__chips {
    flex-direction: column;
    align-items: stretch;
  }

  .hero__chips li,
  .button,
  .button--secondary,
  .button--ghost {
    width: 100%;
  }

  .hero__mini-grid {
    grid-template-columns: 1fr;
  }

  .site-footer__bar {
    flex-direction: column;
  }
}

/* ==========================================================================
   Helpers Store
   ========================================================================== */

/* Hero */
.helpers-hero {
  padding-top: 24px;
}

.helpers-hero .site-shell {
  padding: 38px 42px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at right top, rgba(79, 70, 229, .13), transparent 32%),
    radial-gradient(circle at left bottom, rgba(124, 58, 237, .08), transparent 28%),
    linear-gradient(135deg, rgba(79, 70, 229, .06), rgba(124, 58, 237, .03));
  box-shadow: var(--shadow);
}

.helpers-hero__lede {
  color: var(--text-soft);
  font-size: clamp(1rem, 1.3vw, 1.16rem);
  max-width: 70ch;
  margin-bottom: 32px;
}

.helpers-hero__stats {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
}

.helpers-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.helpers-stat strong {
  font-size: clamp(1.8rem, 2.5vw, 2.4rem);
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.04em;
  line-height: 1;
}

.helpers-stat span {
  font-size: 0.82rem;
  color: var(--text-faint);
  font-family: "IBM Plex Mono", monospace;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* Toolbar */
.helpers-toolbar {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  padding: 18px 22px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .86));
  box-shadow: var(--shadow-soft);
}

.helpers-search-wrap {
  position: relative;
  flex: 1 1 260px;
  min-width: 0;
}

.helpers-search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--text-faint);
  pointer-events: none;
}

.helpers-search {
  width: 100%;
  padding: 12px 14px 12px 42px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: rgba(255, 255, 255, .9);
  color: var(--text);
  font-family: "Outfit", sans-serif;
  font-size: .95rem;
  outline: none;
  transition: border-color 180ms ease, box-shadow 180ms ease;
}

.helpers-search:focus {
  border-color: var(--indigo);
  box-shadow: 0 0 0 3px rgba(79, 70, 229, .12);
}

.helpers-search::placeholder {
  color: var(--text-faint);
}

.helpers-filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.helpers-filter {
  display: inline-flex;
  align-items: center;
  padding: 9px 16px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: transparent;
  color: var(--text-soft);
  font-family: "Outfit", sans-serif;
  font-size: .86rem;
  font-weight: 500;
  cursor: pointer;
  transition: color 160ms, background-color 160ms, border-color 160ms, transform 160ms;
}

.helpers-filter:hover {
  color: var(--navy);
  background: rgba(79, 70, 229, .06);
  border-color: rgba(79, 70, 229, .2);
  transform: translateY(-1px);
}

.helpers-filter--active {
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 6px 16px rgba(79, 70, 229, .28);
}

.helpers-filter--active:hover {
  color: #fff;
  transform: translateY(-1px);
}

.helpers-sort-wrap {
  flex-shrink: 0;
}

.helpers-sort {
  padding: 11px 34px 11px 16px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: rgba(255, 255, 255, .9);
  color: var(--text);
  font-family: "Outfit", sans-serif;
  font-size: .86rem;
  font-weight: 500;
  cursor: pointer;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2311183a' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;
}

.helpers-sort:focus {
  border-color: var(--indigo);
}

/* Results count */
.helpers-results-count {
  margin-bottom: 16px;
  color: var(--text-faint);
  font-size: .88rem;
}

.helpers-results-count strong {
  color: var(--navy);
}

/* Grid */
.helpers-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

/* Card */
.helper-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .84));
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.helper-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 32px 64px rgba(57, 57, 109, .14), 0 0 0 1px rgba(79, 70, 229, .12);
  border-color: rgba(79, 70, 229, .18);
}

.helper-card[hidden] {
  display: none;
}

.helper-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 22px 22px 0;
  gap: 12px;
}

.helper-card__icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  flex-shrink: 0;
}

.helper-card__icon svg {
  width: 26px;
  height: 26px;
}

.helper-card__icon--indigo {
  background: linear-gradient(135deg, rgba(79, 70, 229, .14), rgba(79, 70, 229, .06));
  color: var(--indigo);
}

.helper-card__icon--violet {
  background: linear-gradient(135deg, rgba(124, 58, 237, .14), rgba(124, 58, 237, .06));
  color: var(--violet);
}

.helper-card__icon--rose {
  background: linear-gradient(135deg, rgba(244, 63, 94, .14), rgba(244, 63, 94, .06));
  color: var(--rose);
}

.helper-card__icon--teal {
  background: linear-gradient(135deg, rgba(15, 118, 110, .14), rgba(15, 118, 110, .06));
  color: var(--teal);
}

.helper-card__icon--amber {
  background: linear-gradient(135deg, rgba(245, 158, 11, .14), rgba(245, 158, 11, .06));
  color: var(--amber);
}

.helper-card__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}

.helper-card__category {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(79, 70, 229, .07);
  color: var(--indigo);
  font-family: "IBM Plex Mono", monospace;
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.helper-card__installs {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--text-faint);
  font-family: "IBM Plex Mono", monospace;
  font-size: .72rem;
  font-weight: 500;
}

.helper-card__installs svg {
  width: 13px;
  height: 13px;
  color: var(--teal);
}

.helper-card__body {
  flex: 1;
  padding: 18px 22px 14px;
}

.helper-card__name {
  font-size: 1.08rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: -.02em;
  line-height: 1.2;
  margin-bottom: 10px;
}

.helper-card__desc {
  color: var(--text-soft);
  font-size: .9rem;
  line-height: 1.55;
  margin-bottom: 14px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  overflow: hidden;
}

.helper-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.helper-card__tags li {
  padding: 4px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text-faint);
  font-size: .74rem;
  font-family: "IBM Plex Mono", monospace;
  letter-spacing: .04em;
  transition: border-color 160ms, color 160ms;
}

.helper-card:hover .helper-card__tags li {
  border-color: rgba(79, 70, 229, .14);
  color: var(--text-soft);
}

.helper-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 22px 20px;
  border-top: 1px solid var(--line);
  margin-top: auto;
}

.helper-card__rating {
  display: flex;
  align-items: center;
  gap: 3px;
}

.helper-card__star {
  width: 14px;
  height: 14px;
  color: var(--line-strong);
  fill: transparent;
  stroke: currentColor;
  stroke-width: 2;
  transition: color 180ms;
}

.helper-card__star--filled {
  color: var(--amber);
  fill: var(--amber);
  stroke: var(--amber);
}

.helper-card__rating-val {
  margin-left: 5px;
  color: var(--text-faint);
  font-family: "IBM Plex Mono", monospace;
  font-size: .76rem;
  font-weight: 600;
}

.helper-card__actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.helper-card__docs-link {
  color: var(--text-faint);
  font-size: .82rem;
  font-weight: 500;
  text-decoration: underline;
  text-decoration-color: transparent;
  transition: color 160ms, text-decoration-color 160ms;
}

.helper-card__docs-link:hover {
  color: var(--indigo);
  text-decoration-color: var(--indigo);
}

/* Empty state */
.helpers-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 80px 24px;
  text-align: center;
  gap: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .7);
}

.helpers-empty[hidden] {
  display: none;
}

.helpers-empty svg {
  width: 52px;
  height: 52px;
  color: var(--text-faint);
}

.helpers-empty p {
  color: var(--text-soft);
  font-size: 1.1rem;
  margin: 0;
}

/* Install Modal */
.helpers-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.helpers-modal[hidden] {
  display: none;
}

.helpers-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(12, 19, 51, .64);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  cursor: pointer;
}

.helpers-modal__panel {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 540px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #fff, #f8f9ff);
  box-shadow: 0 40px 100px rgba(12, 19, 51, .3);
  overflow: hidden;
  animation: modal-in 240ms cubic-bezier(.16, 1, .3, 1) both;
}

@keyframes modal-in {
  from {
    opacity: 0;
    transform: translateY(16px) scale(.97);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.helpers-modal__close {
  position: absolute;
  top: 18px;
  right: 18px;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: rgba(255, 255, 255, .8);
  color: var(--text-faint);
  cursor: pointer;
  transition: color 160ms, border-color 160ms, transform 160ms;
}

.helpers-modal__close:hover {
  color: var(--navy);
  border-color: var(--line-strong);
  transform: scale(1.06);
}

.helpers-modal__close svg {
  width: 16px;
  height: 16px;
}

.helpers-modal__header {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 28px 28px 22px;
  border-bottom: 1px solid var(--line);
}

.helpers-modal__icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(79, 70, 229, .12), rgba(124, 58, 237, .06));
  color: var(--indigo);
  flex-shrink: 0;
}

.helpers-modal__icon svg {
  width: 26px;
  height: 26px;
}

.helpers-modal__header h2 {
  font-size: 1.4rem;
  color: var(--navy);
  margin-bottom: 4px;
}

.helpers-modal__subtitle {
  color: var(--text-faint);
  font-family: "IBM Plex Mono", monospace;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin: 0;
}

.helpers-modal__body {
  padding: 24px 28px;
}

.helpers-modal__body ol {
  margin: 0;
  padding-left: 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.helpers-modal__body li {
  color: var(--text-soft);
  line-height: 1.55;
}

.helpers-modal__body code {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 8px;
  background: rgba(17, 24, 58, .06);
  color: var(--indigo);
  font-family: "IBM Plex Mono", monospace;
  font-size: .84rem;
  font-weight: 500;
  word-break: break-all;
}

.helpers-modal__footer {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 20px 28px 24px;
  border-top: 1px solid var(--line);
}

/* Responsive */
@media (max-width:1024px) {
  .helpers-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:768px) {
  .helpers-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .helpers-filters {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 4px;
  }

  .helpers-filter {
    white-space: nowrap;
  }

  .helpers-grid {
    grid-template-columns: 1fr;
  }

  .helpers-hero .site-shell {
    padding: 28px 22px;
  }

  .helpers-hero__stats {
    gap: 20px;
  }

  .helpers-modal__panel {
    max-width: 100%;
  }
}

/* ==========================================================================
   Developers Page
   ========================================================================== */
.dev-hero {
  padding-top: 24px;
}

.dev-hero .site-shell {
  padding: 38px 42px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius-lg);
  background: radial-gradient(circle at right top, rgba(79, 70, 229, .12), transparent 30%),
    radial-gradient(circle at left bottom, rgba(124, 58, 237, .08), transparent 28%),
    linear-gradient(135deg, rgba(12, 19, 51, .04), rgba(79, 70, 229, .02));
  box-shadow: var(--shadow);
}

.dev-hero__lede {
  color: var(--text-soft);
  font-size: clamp(1rem, 1.3vw, 1.16rem);
  max-width: 72ch;
  margin-bottom: 28px;
}

.dev-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 28px;
}

.dev-lang-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dev-lang-strip span {
  padding: 6px 14px;
  border: 1px solid rgba(79, 70, 229, .15);
  border-radius: 999px;
  background: rgba(79, 70, 229, .05);
  color: var(--indigo);
  font-family: "IBM Plex Mono", monospace;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
}

/* Quickstart steps */
.dev-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.dev-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 0 24px;
  position: relative;
  padding-bottom: 32px;
}

.dev-step:last-child {
  padding-bottom: 0;
}

.dev-step::before {
  content: '';
  position: absolute;
  left: 27px;
  top: 56px;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--indigo), transparent);
  opacity: .2;
}

.dev-step:last-child::before {
  display: none;
}

.dev-step__num {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  color: #fff;
  font-family: "IBM Plex Mono", monospace;
  font-size: .88rem;
  font-weight: 700;
  box-shadow: 0 8px 20px rgba(79, 70, 229, .28);
  flex-shrink: 0;
}

.dev-step__body {
  padding-top: 12px;
}

.dev-step__body h3 {
  font-size: 1.1rem;
  margin-bottom: 12px;
}

.dev-code {
  margin: 0;
  padding: 16px 20px;
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, #0c1333, #111b44);
  color: #c7d2fe;
  font-family: "IBM Plex Mono", monospace;
  font-size: .84rem;
  line-height: 1.7;
  overflow-x: auto;
  box-shadow: var(--shadow-soft);
  border: 1px solid rgba(79, 70, 229, .14);
}

.dev-code--sm {
  font-size: .78rem;
  padding: 12px 16px;
}

.dev-code code {
  background: none;
  padding: 0;
  color: inherit;
  font-size: inherit;
}

/* ── Code tabs ────────────────────────────────────────────── */
.code-tabs {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  margin-bottom: 0;
  border-bottom: 2px solid rgba(79, 70, 229, 0.12);
  padding-bottom: 0;
}

.code-tab {
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  background: none;
  color: var(--text-soft);
  font-size: 0.875rem;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  border-radius: 8px 8px 0 0;
  transition: color 160ms ease, background 160ms ease;
}

.code-tab:hover {
  color: var(--navy);
  background: rgba(79, 70, 229, 0.05);
}

.code-tab.is-active {
  color: var(--indigo);
  border-bottom-color: var(--indigo);
  font-weight: 600;
}

/* ── Code panel ───────────────────────────────────────────── */
.code-panel {
  display: none;
  border: 1px solid rgba(79, 70, 229, 0.14);
  border-radius: 0 0 var(--radius) var(--radius);
  background: #0c1333;
  overflow: hidden;
}

.code-panel.is-active {
  display: block;
}

/* Sub-tabs (scenarios within a language) */
.code-subtabs {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
  padding: 12px 16px 0;
  background: rgba(255, 255, 255, 0.03);
  border-bottom: 1px solid rgba(79, 70, 229, 0.14);
}

.code-subtab {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  border: 1px solid transparent;
  border-radius: 8px 8px 0 0;
  background: none;
  color: rgba(199, 210, 254, 0.6);
  font-size: 0.8rem;
  font-family: "IBM Plex Mono", monospace;
  cursor: pointer;
  transition: color 140ms ease, background 140ms ease;
}

.code-subtab:hover {
  color: #c7d2fe;
  background: rgba(79, 70, 229, 0.12);
}

.code-subtab.is-active {
  color: #fff;
  background: rgba(79, 70, 229, 0.22);
  border-color: rgba(79, 70, 229, 0.3);
}

/* Code example block */
.code-example {
  display: none;
}

.code-example.is-active {
  display: block;
}

/* Toolbar (label + copy button) */
.code-example__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 20px;
  background: rgba(255, 255, 255, 0.04);
  border-bottom: 1px solid rgba(79, 70, 229, 0.1);
}

.code-example__label {
  color: rgba(199, 210, 254, 0.5);
  font-size: 0.76rem;
  font-family: "IBM Plex Mono", monospace;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.code-copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border: 1px solid rgba(79, 70, 229, 0.3);
  border-radius: 6px;
  background: rgba(79, 70, 229, 0.1);
  color: rgba(199, 210, 254, 0.8);
  font-size: 0.75rem;
  font-family: inherit;
  cursor: pointer;
  transition: background 150ms ease, color 150ms ease;
}

.code-copy-btn:hover {
  background: rgba(79, 70, 229, 0.25);
  color: #fff;
}

.code-copy-btn.is-copied {
  background: rgba(16, 185, 129, 0.2);
  border-color: rgba(16, 185, 129, 0.4);
  color: #6ee7b7;
}

/* Full-height code block */
.dev-code--full {
  border-radius: 0;
  border: none;
  box-shadow: none;
  max-height: 460px;
  overflow-y: auto;
}


/* SDK grid */
.dev-sdk-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.dev-sdk-card {
  padding: 22px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .84));
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform 200ms, box-shadow 200ms;
}

.dev-sdk-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow);
}

.dev-sdk-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.dev-sdk-card__lang {
  font-weight: 700;
  font-size: 1rem;
  color: var(--navy);
}

.dev-sdk-card__badge {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  font-family: "IBM Plex Mono", monospace;
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .06em;
}

.dev-sdk-card__badge--indigo {
  background: rgba(79, 70, 229, .1);
  color: var(--indigo);
}

.dev-sdk-card__badge--violet {
  background: rgba(124, 58, 237, .1);
  color: var(--violet);
}

.dev-sdk-card__badge--teal {
  background: rgba(15, 118, 110, .1);
  color: var(--teal);
}

.dev-sdk-card__badge--rose {
  background: rgba(244, 63, 94, .1);
  color: var(--rose);
}

.dev-sdk-card__badge--amber {
  background: rgba(245, 158, 11, .1);
  color: var(--amber);
}

.dev-sdk-card__note {
  color: var(--text-faint);
  font-size: .84rem;
  margin: 0;
}

/* API grid */
.dev-api-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.dev-api-card {
  padding: 22px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .84));
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform 200ms;
}

.dev-api-card:hover {
  transform: translateY(-2px);
}

.dev-api-card__top {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.dev-api-card__top h3 {
  font-size: 1rem;
  margin: 0;
}

.dev-api-card__count {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  font-family: "IBM Plex Mono", monospace;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  align-self: flex-start;
}

.dev-api-card__count--indigo {
  background: rgba(79, 70, 229, .1);
  color: var(--indigo);
}

.dev-api-card__count--violet {
  background: rgba(124, 58, 237, .1);
  color: var(--violet);
}

.dev-api-card__count--rose {
  background: rgba(244, 63, 94, .1);
  color: var(--rose);
}

.dev-api-card__count--teal {
  background: rgba(15, 118, 110, .1);
  color: var(--teal);
}

.dev-api-card__count--amber {
  background: rgba(245, 158, 11, .1);
  color: var(--amber);
}

.dev-api-card__base {
  font-family: "IBM Plex Mono", monospace;
  font-size: .74rem;
  color: var(--text-faint);
}

.dev-api-card p {
  color: var(--text-soft);
  font-size: .88rem;
  margin: 0;
}

/* Architecture grid */
.dev-arch-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.dev-arch-card {
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(255, 255, 255, .82));
  box-shadow: var(--shadow-soft);
}

.dev-arch-card__icon {
  font-size: 1.8rem;
  margin-bottom: 12px;
  line-height: 1;
}

.dev-arch-card h3 {
  font-size: 1rem;
  margin-bottom: 10px;
}

.dev-arch-card p {
  color: var(--text-soft);
  font-size: .88rem;
  margin-bottom: 14px;
}

/* Resource grid */
.dev-resource-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.dev-resource-card {
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .84));
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform 200ms;
}

.dev-resource-card:hover {
  transform: translateY(-2px);
}

.dev-resource-card__tag {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  font-family: "IBM Plex Mono", monospace;
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .06em;
  align-self: flex-start;
}

.dev-resource-card__tag--indigo {
  background: rgba(79, 70, 229, .1);
  color: var(--indigo);
}

.dev-resource-card__tag--violet {
  background: rgba(124, 58, 237, .1);
  color: var(--violet);
}

.dev-resource-card__tag--rose {
  background: rgba(244, 63, 94, .1);
  color: var(--rose);
}

.dev-resource-card__tag--teal {
  background: rgba(15, 118, 110, .1);
  color: var(--teal);
}

.dev-resource-card__tag--amber {
  background: rgba(245, 158, 11, .1);
  color: var(--amber);
}

.dev-resource-card h3 {
  font-size: 1rem;
  color: var(--navy);
  margin: 0;
}

.dev-resource-card p {
  color: var(--text-soft);
  font-size: .88rem;
  margin: 0;
}

/* ==========================================================================
   Compliance & Security Page
   ========================================================================== */
.comp-hero {
  padding-top: 24px;
}

.comp-hero .site-shell {
  padding: 38px 42px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius-lg);
  background: radial-gradient(circle at right top, rgba(244, 63, 94, .1), transparent 28%),
    radial-gradient(circle at left bottom, rgba(79, 70, 229, .08), transparent 28%),
    linear-gradient(135deg, rgba(12, 19, 51, .04), rgba(79, 70, 229, .02));
  box-shadow: var(--shadow);
}

.comp-hero__lede {
  color: var(--text-soft);
  font-size: clamp(1rem, 1.3vw, 1.16rem);
  max-width: 72ch;
  margin-bottom: 28px;
}

.comp-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.comp-badge {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: 999px;
  border: 1px solid rgba(79, 70, 229, .15);
  background: linear-gradient(135deg, rgba(79, 70, 229, .08), rgba(124, 58, 237, .04));
  color: var(--navy);
  font-weight: 600;
  font-size: .84rem;
  transition: transform 160ms, box-shadow 160ms;
}

.comp-badge:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(79, 70, 229, .12);
}

/* Cert card accents */
.coverage-card--indigo::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 4px;
  height: 100%;
  border-radius: 4px 0 0 4px;
  background: var(--indigo);
}

.coverage-card--violet::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 4px;
  height: 100%;
  border-radius: 4px 0 0 4px;
  background: var(--violet);
}

.coverage-card--rose::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 4px;
  height: 100%;
  border-radius: 4px 0 0 4px;
  background: var(--rose);
}

.coverage-card--teal::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 4px;
  height: 100%;
  border-radius: 4px 0 0 4px;
  background: var(--teal);
}

.coverage-card--amber::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 4px;
  height: 100%;
  border-radius: 4px 0 0 4px;
  background: var(--amber);
}

/* FAQ grid */
.comp-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.comp-faq-card {
  padding: 26px;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .84));
  box-shadow: var(--shadow-soft);
}

.comp-faq-card h3 {
  font-size: 1.04rem;
  color: var(--navy);
  margin-bottom: 12px;
}

.comp-faq-card p {
  color: var(--text-soft);
  font-size: .92rem;
  margin: 0;
}

/* ==========================================================================
   Success Stories
   ========================================================================== */
.story-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.story-card {
  position: relative;
  padding: 28px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .78);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .84));
  box-shadow: var(--shadow-soft);
  transition: transform 200ms, box-shadow 200ms;
}

.story-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}

.story-card__quote {
  font-size: clamp(1rem, 1.2vw, 1.14rem);
  color: var(--navy);
  font-weight: 500;
  line-height: 1.55;
  margin-bottom: 22px;
  font-style: italic;
}

.story-card__quote::before {
  content: '\201C';
  font-size: 2rem;
  color: var(--indigo);
  line-height: .6;
  display: block;
  margin-bottom: 8px;
}

.story-card__author {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}

.story-card__avatar {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  flex-shrink: 0;
  font-weight: 700;
  color: #fff;
  font-size: .88rem;
}

.story-card__avatar--indigo {
  background: linear-gradient(135deg, var(--indigo), var(--violet));
}

.story-card__avatar--rose {
  background: linear-gradient(135deg, var(--rose), var(--violet));
}

.story-card__avatar--teal {
  background: linear-gradient(135deg, var(--teal), var(--indigo));
}

.story-card__author-name {
  font-weight: 700;
  color: var(--navy);
  font-size: .92rem;
}

.story-card__author-role {
  color: var(--text-faint);
  font-size: .8rem;
}

.story-card__metrics {
  display: flex;
  gap: 16px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.story-card__metric {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.story-card__metric strong {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -.03em;
}

.story-card__metric span {
  font-size: .74rem;
  color: var(--text-faint);
  font-family: "IBM Plex Mono", monospace;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.story-card__tag {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  margin-bottom: 14px;
  background: rgba(79, 70, 229, .07);
  color: var(--indigo);
  font-family: "IBM Plex Mono", monospace;
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .06em;
}

/* Responsive additions */
@media (max-width:1024px) {
  .dev-sdk-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dev-api-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dev-arch-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .story-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:768px) {

  .dev-hero .site-shell,
  .comp-hero .site-shell {
    padding: 28px 22px;
  }

  .dev-sdk-grid,
  .dev-api-grid,
  .dev-arch-grid,
  .dev-resource-grid {
    grid-template-columns: 1fr;
  }

  .story-grid,
  .comp-faq-grid {
    grid-template-columns: 1fr;
  }

  .dev-step {
    grid-template-columns: 44px 1fr;
  }

  .dev-step__num {
    width: 44px;
    height: 44px;
  }
}

/* ── Brand mission section ───────────────────────────────── */
.brand-mission {
  background: linear-gradient(160deg, #f8f7ff 0%, #ffffff 60%, #f0f4ff 100%);
  border-top: 1px solid rgba(79, 70, 229, 0.08);
}

/* Strap line hero callout */
.brand-strap {
  text-align: center;
  padding: 60px 0 56px;
  border-bottom: 1px solid rgba(79, 70, 229, 0.1);
  margin-bottom: 64px;
}

.brand-strap__img {
  width: 280px;
  height: auto;
  margin: 0 auto 32px;
  display: block;
}

.brand-strap__quote {
  margin: 0 0 24px;
  padding: 0;
  border: none;
  font-size: clamp(2.4rem, 6vw, 4rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1.1;
}

.brand-strap__trust {
  color: var(--navy);
}

.brand-strap__rest {
  color: var(--text-soft);
  font-weight: 400;
}

.brand-strap__era {
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.brand-strap__message {
  max-width: 680px;
  margin: 0 auto;
  color: var(--text-soft);
  font-size: 1.05rem;
  line-height: 1.7;
}

/* Three-column brand pillars */
.brand-pillars {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.brand-pillar {
  padding: 32px 28px;
  border-radius: var(--radius);
  border: 1px solid rgba(79, 70, 229, 0.1);
  background: #fff;
  box-shadow: 0 4px 20px rgba(79, 70, 229, 0.06);
  transition: box-shadow 220ms ease, transform 220ms ease;
}

.brand-pillar:hover {
  box-shadow: 0 8px 32px rgba(79, 70, 229, 0.12);
  transform: translateY(-3px);
}

.brand-pillar--vision { border-top: 3px solid var(--indigo); }
.brand-pillar--goals  { border-top: 3px solid var(--violet); }
.brand-pillar--values { border-top: 3px solid var(--rose); }

.brand-pillar__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  margin-bottom: 18px;
}

.brand-pillar--vision .brand-pillar__icon { background: rgba(79, 70, 229, 0.08); color: var(--indigo); }
.brand-pillar--goals  .brand-pillar__icon { background: rgba(124, 58, 237, 0.08); color: var(--violet); }
.brand-pillar--values .brand-pillar__icon { background: rgba(244, 63, 94, 0.08);  color: var(--rose); }

.brand-pillar__title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 12px;
  letter-spacing: -0.02em;
}

.brand-pillar__body {
  color: var(--text-soft);
  line-height: 1.7;
  margin: 0;
}

.brand-pillar__list {
  margin: 0;
  padding: 0 0 0 18px;
  color: var(--text-soft);
  line-height: 1.8;
}

.brand-pillar__list li {
  margin-bottom: 8px;
}

.brand-pillar__list li:last-child {
  margin-bottom: 0;
}

@media (max-width: 860px) {
  .brand-pillars {
    grid-template-columns: 1fr;
  }
  .brand-strap {
    padding: 40px 0 40px;
  }
}

/* ─────────────────────────────────────────────────────────────
   SPRINT 1 & 2 COMPONENT STYLES
   ───────────────────────────────────────────────────────────── */

/* ── Sticky header CTA (JS adds .is-scrolled to .site-header) */
.site-header {
  transition: box-shadow 200ms ease;
}
.site-header.is-scrolled {
  box-shadow: 0 2px 24px rgba(79,70,229,0.10);
}

/* ── Scroll-triggered bottom bar ── */
.scroll-cta-bar {
  position: fixed;
  bottom: -80px;
  left: 0;
  right: 0;
  z-index: 9200;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding: 14px 24px;
  background: #0c1333;
  /* Fallback for any var() that resolves as transparent */
  background: linear-gradient(135deg, #0c1333 0%, #1e1b4b 100%);
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 500;
  transition: bottom 300ms cubic-bezier(0.4, 0, 0.2, 1);
  border-top: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 -4px 24px rgba(0,0,0,0.3);
}
.scroll-cta-bar.is-visible {
  bottom: 0;
}
.scroll-cta-bar p,
.scroll-cta-bar strong {
  margin: 0;
  color: #ffffff !important;
}
.scroll-cta-bar .button {
  background: #4f46e5 !important;
  color: #ffffff !important;
  border: none !important;
  box-shadow: 0 4px 14px rgba(79,70,229,0.45) !important;
  flex-shrink: 0;
}
.scroll-cta-bar .button:hover {
  background: #4338ca !important;
  transform: translateY(-1px);
}

/* ─── Demo / Contact page ─────────────────────────────────── */
.demo-hero h1 {
  max-width: 18ch;
}

.demo-hero__lede {
  max-width: 54ch;
  color: var(--text-soft);
  font-size: 1.05rem;
  line-height: 1.7;
}

/* What happens next - 3 steps */
.demo-steps {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.demo-step {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  flex: 1;
  min-width: 180px;
}

.demo-step__num {
  display: inline-grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(79,70,229,0.12), rgba(124,58,237,0.12));
  color: var(--indigo);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.8rem;
  font-weight: 700;
  flex-shrink: 0;
}

.demo-step strong {
  display: block;
  font-size: 0.95rem;
  color: var(--navy);
}

.demo-step span {
  display: block;
  font-size: 0.82rem;
  color: var(--text-soft);
  margin-top: 2px;
}

.demo-step__arrow {
  color: var(--text-faint);
  font-size: 1.2rem;
  margin-top: 10px;
}

/* Form + sidebar layout */
.demo-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 40px;
  align-items: start;
}

.demo-form-wrap h2 {
  margin-bottom: 6px;
}

.demo-form-wrap__sub {
  color: var(--text-soft);
  font-size: 0.9rem;
  margin-bottom: 28px;
}

.demo-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.demo-form__row {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.demo-form__row label {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--navy);
}

.demo-form__row input,
.demo-form__row select,
.demo-form__row textarea {
  padding: 11px 14px;
  border: 1.5px solid rgba(79,70,229,0.18);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.9);
  font-size: 0.9rem;
  font-family: inherit;
  color: var(--navy);
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.demo-form__row input:focus,
.demo-form__row select:focus,
.demo-form__row textarea:focus {
  outline: none;
  border-color: var(--indigo);
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1);
}

.demo-form__privacy {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  color: var(--text-soft);
}

.demo-form__privacy a { color: var(--indigo); }

.demo-form__submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  justify-content: center;
}

.demo-form__success {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 20px;
  border-radius: var(--radius);
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.25);
  color: #065f46;
  font-weight: 600;
}

/* Sidebar */
.demo-sidebar {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.demo-sidebar__block {
  padding: 22px 24px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: rgba(248,247,255,0.8);
}

.demo-sidebar__list {
  margin: 10px 0 0;
  padding-left: 1.1rem;
  color: var(--text-soft);
  font-size: 0.9rem;
  line-height: 1.7;
}

.demo-sidebar__quote {
  padding: 20px 24px;
  border-left: 3px solid var(--indigo);
  border-radius: 0 var(--radius) var(--radius) 0;
  background: rgba(79,70,229,0.04);
  border-right: 1px solid rgba(79,70,229,0.08);
  border-top: 1px solid rgba(79,70,229,0.08);
  border-bottom: 1px solid rgba(79,70,229,0.08);
}

.demo-sidebar__quote p {
  font-size: 0.9rem;
  color: var(--navy);
  font-style: italic;
  margin: 0 0 10px;
}

.demo-sidebar__quote footer {
  font-size: 0.78rem;
  color: var(--text-soft);
  font-style: normal;
}

.demo-sidebar__contact {
  background: var(--navy);
}

.demo-sidebar__contact .eyebrow {
  color: rgba(255,255,255,0.5);
}

.demo-sidebar__email {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #c7d2fe;
  font-size: 0.9rem;
  text-decoration: none;
  margin-top: 8px;
}
.demo-sidebar__email:hover { color: #fff; }

/* Trust badges */
.trust-badges {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-top: 14px;
}

.trust-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  background: rgba(79,70,229,0.05);
  border: 1px solid rgba(79,70,229,0.1);
  font-size: 0.8rem;
  color: var(--navy);
  font-weight: 600;
}

.trust-badge svg { color: var(--indigo); flex-shrink: 0; }

/* Metric strip on demo page */
.demo-metric-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 20px;
}

.demo-metric {
  text-align: center;
}

.demo-metric strong {
  display: block;
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.04em;
}

.demo-metric span {
  display: block;
  font-size: 0.78rem;
  color: var(--text-soft);
  margin-top: 4px;
}

/* ─── ROI Calculator page ─────────────────────────────────── */
.roi-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 40px;
  align-items: start;
}

.roi-inputs h2 {
  margin-bottom: 28px;
}

.roi-field {
  margin-bottom: 28px;
}

.roi-field label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: 10px;
}

.roi-slider-wrap {
  display: flex;
  align-items: center;
  gap: 14px;
}

.roi-slider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(to right, var(--indigo) 0%, rgba(79,70,229,0.15) 0%);
  outline: none;
  cursor: pointer;
}

.roi-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--indigo);
  border: 3px solid #fff;
  box-shadow: 0 2px 6px rgba(79,70,229,0.35);
  cursor: pointer;
}

.roi-slider__val {
  min-width: 90px;
  text-align: right;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--indigo);
  font-family: 'IBM Plex Mono', monospace;
}

/* Results card */
.roi-results__card {
  padding: 28px 24px;
  border-radius: var(--radius);
  background: linear-gradient(160deg, #0f0c3c, #1a1560);
  color: #fff;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: 90px;
}

.roi-results__card .eyebrow {
  color: rgba(199,210,254,0.6);
}

.roi-headline {
  display: flex;
  align-items: flex-start;
  gap: 4px;
}

.roi-headline__currency {
  font-size: 2rem;
  font-weight: 300;
  color: rgba(199,210,254,0.7);
  margin-top: 8px;
}

.roi-headline__amount {
  font-size: clamp(2.8rem, 6vw, 4rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, #c7d2fe, #a5b4fc);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}

.roi-headline__label {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.5);
  margin: 0;
}

.roi-breakdown {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
  background: rgba(255,255,255,0.06);
  border-radius: var(--radius-sm);
}

.roi-breakdown__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.85rem;
}

.roi-breakdown__item span { color: rgba(255,255,255,0.55); }
.roi-breakdown__item strong { color: #c7d2fe; font-weight: 700; }

.roi-disclaimer {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.35);
  line-height: 1.5;
}

.roi-cta-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.roi-cta-block .button { width: 100%; justify-content: center; }
.roi-cta-block .button--secondary { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.75); border-color: rgba(255,255,255,0.15); }

/* Bar chart */
.roi-comparison {
  margin-top: 24px;
}

.roi-comparison .eyebrow { color: rgba(199,210,254,0.5); }

.roi-bar-chart {
  display: flex;
  align-items: flex-end;
  gap: 24px;
  height: 200px;
  padding-top: 20px;
}

.roi-bar-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  flex: 1;
}

.roi-bar-group span {
  font-size: 0.72rem;
  color: rgba(199,210,254,0.5);
  text-align: center;
}

.roi-bar {
  width: 100%;
  border-radius: 6px 6px 0 0;
  transition: height 400ms cubic-bezier(0.4, 0, 0.2, 1);
}

.roi-bar--before { background: rgba(244,63,94,0.5); height: 180px; }
.roi-bar--after  { background: rgba(79,70,229,0.65); height: 60px; }

/* Method grid */
.roi-method-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 20px;
  margin-top: 32px;
}

.roi-method-card {
  padding: 24px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.8);
  border: 1px solid rgba(79,70,229,0.1);
}

.roi-method-card h3 {
  font-size: 1rem;
  color: var(--navy);
  margin: 0 0 10px;
}

.roi-method-card p {
  font-size: 0.875rem;
  color: var(--text-soft);
  margin: 0;
  line-height: 1.65;
}

/* ─── About page ──────────────────────────────────────────── */
.about-story-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 60px;
  align-items: center;
}

.about-story-brand {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.about-strap-quote {
  margin: 0;
  padding: 0;
  border: none;
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.04em;
}

.about-name-breakdown {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.about-name-part strong {
  display: inline-block;
  font-size: 1.1rem;
  color: var(--navy);
  min-width: 50px;
}

.about-name-part span {
  font-size: 0.875rem;
  color: var(--text-soft);
  margin-left: 12px;
}

/* MVV grid */
.about-mvv-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 24px;
  margin-top: 36px;
}

.about-mvv-card {
  padding: 28px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.8);
  border: 1px solid rgba(79,70,229,0.1);
  box-shadow: 0 2px 12px rgba(79,70,229,0.05);
}

.about-mvv-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
  margin-bottom: 16px;
}

.about-mvv-card h3 {
  font-size: 1.05rem;
  margin: 0 0 10px;
  color: var(--navy);
}

.about-mvv-card ul {
  margin: 0;
  padding-left: 1.1rem;
  font-size: 0.875rem;
  color: var(--text-soft);
  line-height: 1.7;
}

/* Team grid */
.team-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 24px;
  margin-top: 36px;
}

.team-card {
  padding: 26px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.team-card__avatar {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  margin-bottom: 16px;
}

.team-card__avatar--indigo { background: rgba(79,70,229,.12); color: var(--indigo); }
.team-card__avatar--violet { background: rgba(124,58,237,.12); color: var(--violet); }
.team-card__avatar--teal   { background: rgba(20,184,166,.12); color: var(--teal); }
.team-card__avatar--rose   { background: rgba(244,63,94,.12);  color: var(--rose); }
.team-card__avatar--amber  { background: rgba(245,158,11,.12); color: var(--amber); }

.team-card__name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 4px;
}

.team-card__role {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--indigo);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 14px;
}

.team-card__bio {
  font-size: 0.85rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0;
}

/* By-the-numbers strip */
.about-numbers {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 20px;
  margin-top: 36px;
}

.about-number {
  padding: 24px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.8);
  border: 1px solid rgba(79,70,229,0.1);
  text-align: center;
}

.about-number strong {
  display: block;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.about-number span {
  display: block;
  font-size: 0.8rem;
  color: var(--text-soft);
  margin-top: 6px;
}

/* Company info */
.about-info-grid {
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: 24px;
  margin-top: 16px;
}

.about-info-card {
  padding: 28px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: #fff;
}

.about-info-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 14px;
  font-size: 0.875rem;
}

.about-info-table th,
.about-info-table td {
  padding: 9px 12px;
  text-align: left;
  border-bottom: 1px solid rgba(79,70,229,0.07);
}

.about-info-table th {
  color: var(--text-soft);
  font-weight: 500;
  width: 45%;
}

.about-info-table td {
  color: var(--navy);
  font-weight: 600;
}

/* ─── Comparison pages ────────────────────────────────────── */
.compare-summary-row {
  display: flex;
  align-items: center;
  gap: 16px;
}

.compare-summary-card {
  flex: 1;
  padding: 24px;
  border-radius: var(--radius);
}

.compare-summary-card--us {
  background: linear-gradient(135deg, rgba(79,70,229,0.08), rgba(124,58,237,0.05));
  border: 1.5px solid rgba(79,70,229,0.2);
}

.compare-summary-card--them {
  background: rgba(248,247,255,0.8);
  border: 1px solid rgba(79,70,229,0.1);
}

.compare-summary-vs {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--text-faint);
  flex-shrink: 0;
}

.compare-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  box-shadow: 0 2px 12px rgba(79,70,229,0.06);
}

.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.compare-table thead {
  background: linear-gradient(135deg, var(--navy), #1e1b4b);
  color: #fff;
}

.compare-table th {
  padding: 14px 20px;
  text-align: left;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.compare-table th.compare-table__us { color: #c7d2fe; }
.compare-table th.compare-table__them { color: rgba(255,255,255,0.55); }

.compare-table td {
  padding: 13px 20px;
  border-bottom: 1px solid rgba(79,70,229,0.07);
  color: var(--text-soft);
}

.compare-table tr:last-child td { border-bottom: none; }
.compare-table tr:nth-child(even) { background: rgba(79,70,229,0.02); }

.compare-table td:first-child { color: var(--navy); font-weight: 500; }

.compare-tick {
  font-size: 0.9rem;
  font-weight: 700;
}

.compare-tick--yes     { color: #059669; }
.compare-tick--no      { color: #dc2626; }
.compare-tick--neutral { color: var(--text-soft); }
.compare-tick--partial { color: var(--amber); font-size: 0.78rem; font-weight: 500; }

.compare-verdict {
  max-width: 68ch;
}

.compare-verdict p {
  color: var(--text-soft);
  line-height: 1.7;
}

.compare-quote {
  margin: 40px 0 0;
  padding: 24px 28px;
  border-left: 4px solid var(--indigo);
  border-radius: 0 var(--radius) var(--radius) 0;
  background: rgba(79,70,229,0.04);
  border-right: 1px solid rgba(79,70,229,0.1);
  border-top: 1px solid rgba(79,70,229,0.1);
  border-bottom: 1px solid rgba(79,70,229,0.1);
}

.compare-quote p {
  font-size: 1.05rem;
  font-style: italic;
  color: var(--navy);
  margin: 0 0 12px;
  line-height: 1.6;
}

.compare-quote footer {
  font-size: 0.82rem;
  color: var(--text-soft);
}

.compare-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.compare-link-card {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 20px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.15);
  background: rgba(79,70,229,0.04);
  color: var(--navy);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  transition: background 150ms ease, border-color 150ms ease;
}

.compare-link-card:hover {
  background: rgba(79,70,229,0.1);
  border-color: var(--indigo);
  color: var(--indigo);
}

/* ─── Responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .demo-layout,
  .roi-layout,
  .about-story-layout,
  .about-info-grid,
  .about-mvv-grid,
  .roi-method-grid {
    grid-template-columns: 1fr;
  }

  .team-grid,
  .about-numbers {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }

  .demo-metric-strip {
    grid-template-columns: repeat(2, 1fr);
  }

  .compare-summary-row {
    flex-direction: column;
  }

  .compare-summary-vs { display: none; }

  .roi-results__card { position: static; }
  .demo-steps { flex-direction: column; }
  .demo-step__arrow { display: none; }
}

@media (max-width: 600px) {
  .team-grid,
  .about-numbers {
    grid-template-columns: 1fr;
  }

  .trust-badges { grid-template-columns: 1fr; }
  .demo-metric-strip { grid-template-columns: repeat(2, 1fr); }
}

/* ─────────────────────────────────────────────────────────────
   SPRINT 3 COMPONENT STYLES
   ───────────────────────────────────────────────────────────── */

/* ── Proof strip (problem context band) ──────────────────── */
.proof-strip {
  max-width: 76ch;
}

.proof-strip p {
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--text-soft);
  margin: 0;
}

/* ── Solutions page — metrics row ────────────────────────── */
.solutions-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 16px;
}

.solutions-metric {
  padding: 22px 20px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  text-align: center;
}

.solutions-metric strong {
  display: block;
  font-size: clamp(1.5rem, 3.5vw, 2.2rem);
  font-weight: 800;
  letter-spacing: -0.04em;
}

.solutions-metric span {
  display: block;
  font-size: 0.78rem;
  color: var(--text-soft);
  margin-top: 5px;
  line-height: 1.4;
}

.solutions-metric--indigo { background: rgba(79,70,229,.05);  border-color: rgba(79,70,229,.12);  }
.solutions-metric--indigo strong { color: var(--indigo); }

.solutions-metric--teal   { background: rgba(20,184,166,.05); border-color: rgba(20,184,166,.12); }
.solutions-metric--teal strong { color: var(--teal); }

.solutions-metric--violet { background: rgba(124,58,237,.05); border-color: rgba(124,58,237,.12); }
.solutions-metric--violet strong { color: var(--violet); }

.solutions-metric--rose   { background: rgba(244,63,94,.05);  border-color: rgba(244,63,94,.12);  }
.solutions-metric--rose strong { color: var(--rose); }

.solutions-metric--amber  { background: rgba(245,158,11,.05); border-color: rgba(245,158,11,.12); }
.solutions-metric--amber strong { color: var(--amber); }

/* ── Solutions — module tags ─────────────────────────────── */
.solutions-modules-row {
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: 40px;
  padding: 28px 32px;
  background: rgba(248,247,255,0.8);
  border: 1px solid rgba(79,70,229,0.1);
  border-radius: var(--radius);
  align-items: start;
}

.solutions-module-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.solutions-module-tag {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

/* ── Solutions — quote ───────────────────────────────────── */
.solutions-quote {
  max-width: 68ch;
  padding: 28px 32px;
  border-left: 4px solid var(--indigo);
  border-radius: 0 var(--radius) var(--radius) 0;
  background: rgba(79,70,229,0.04);
  border-right: 1px solid rgba(79,70,229,0.1);
  border-top: 1px solid rgba(79,70,229,0.1);
  border-bottom: 1px solid rgba(79,70,229,0.1);
}

.solutions-quote p {
  font-size: 1.05rem;
  font-style: italic;
  color: var(--navy);
  line-height: 1.65;
  margin: 0 0 14px;
}

.solutions-quote footer {
  font-size: 0.82rem;
  color: var(--text-soft);
}

/* ── Solutions — other industry links ────────────────────── */
.solutions-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 20px;
}

/* ── Role pages — pain/solution cards ───────────────────── */
.for-pains-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 20px;
  margin-top: 32px;
}

.for-pain-card {
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  overflow: hidden;
}

.for-pain-card__problem {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 20px;
  background: rgba(244,63,94,0.05);
  border-bottom: 1px solid rgba(244,63,94,0.12);
  font-size: 0.9rem;
  font-weight: 600;
  color: #991b1b;
}

.for-pain-card__problem svg { color: #dc2626; flex-shrink: 0; }

.for-pain-card__solution {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 18px 20px;
  background: rgba(255,255,255,0.9);
}

.for-pain-card__solution svg { color: #059669; flex-shrink: 0; margin-top: 2px; }

.for-pain-card__solution p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--text-soft);
  line-height: 1.65;
}

/* ── Role pages — what you'll see ───────────────────────── */
.for-what-you-see {
  max-width: 72ch;
}

.for-what-you-see h2 {
  margin: 10px 0 20px;
}

.for-access-list {
  margin: 0;
  padding-left: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.for-access-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  background: rgba(79,70,229,0.04);
  border: 1px solid rgba(79,70,229,0.1);
  font-size: 0.9rem;
  color: var(--navy);
}

.for-access-list li::before {
  content: "✓";
  color: #059669;
  font-weight: 700;
  flex-shrink: 0;
}

/* ── Case studies ────────────────────────────────────────── */
.case-study {
  padding: 40px 0;
}

.case-study__header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 28px;
}

.case-study__avatar {
  width: 60px;
  height: 60px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  flex-shrink: 0;
}

.case-study__avatar--indigo { background: rgba(79,70,229,.12);  color: var(--indigo); }
.case-study__avatar--violet { background: rgba(124,58,237,.12); color: var(--violet); }
.case-study__avatar--teal   { background: rgba(20,184,166,.12); color: var(--teal); }
.case-study__avatar--rose   { background: rgba(244,63,94,.12);  color: var(--rose); }
.case-study__avatar--amber  { background: rgba(245,158,11,.12); color: var(--amber); }

.case-study__company {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 6px;
}

.case-study__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-size: 0.82rem;
  color: var(--text-soft);
}

.case-study__body {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 40px;
  align-items: start;
}

.case-study__narrative {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.case-study__block .eyebrow {
  margin-bottom: 6px;
}

.case-study__block p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-soft);
  line-height: 1.7;
}

.case-study__quote {
  margin: 0;
  padding: 20px 22px;
  border-left: 3px solid var(--indigo);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  background: rgba(79,70,229,0.04);
  border-right: 1px solid rgba(79,70,229,0.08);
  border-top: 1px solid rgba(79,70,229,0.08);
  border-bottom: 1px solid rgba(79,70,229,0.08);
}

.case-study__quote p {
  font-size: 0.9rem;
  font-style: italic;
  color: var(--navy);
  margin: 0 0 10px;
  line-height: 1.6;
}

.case-study__quote footer {
  font-size: 0.78rem;
  color: var(--text-soft);
}

/* Results panel */
.case-study__results {
  position: sticky;
  top: 90px;
  padding: 24px;
  border-radius: var(--radius);
  background: linear-gradient(160deg, #0f0c3c, #1a1560);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.case-study__results .eyebrow {
  color: rgba(199,210,254,0.55);
  margin-bottom: 4px;
}

.case-study__result {
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
}

.case-study__result strong {
  display: block;
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-bottom: 4px;
}

.case-study__result span {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.4;
}

.case-study__result--indigo strong { color: #c7d2fe; }
.case-study__result--violet strong { color: #ddd6fe; }
.case-study__result--teal   strong { color: #99f6e4; }
.case-study__result--rose   strong { color: #fda4af; }
.case-study__result--amber  strong { color: #fde68a; }

.case-study__divider {
  border: none;
  border-top: 1px solid rgba(79,70,229,0.1);
  margin: 0;
}

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-layout {
  display: grid;
  grid-template-columns: 220px minmax(0,1fr);
  gap: 60px;
  align-items: start;
}

.faq-nav {
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.faq-nav__link {
  display: block;
  padding: 9px 14px;
  border-radius: var(--radius-sm);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-soft);
  transition: background 120ms ease, color 120ms ease;
}

.faq-nav__link:hover {
  background: rgba(79,70,229,0.06);
  color: var(--indigo);
}

.faq-sections {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.faq-section__title {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 20px;
  padding-bottom: 14px;
  border-bottom: 2px solid rgba(79,70,229,0.1);
}

.faq-item {
  border-bottom: 1px solid rgba(79,70,229,0.08);
}

.faq-item__q {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--navy);
  font-family: inherit;
  line-height: 1.4;
  transition: color 120ms ease;
}

.faq-item__q:hover { color: var(--indigo); }

.faq-item__chevron {
  flex-shrink: 0;
  transition: transform 200ms ease;
  margin-top: 2px;
  color: var(--text-faint);
}

.faq-item__q[aria-expanded="true"] .faq-item__chevron {
  transform: rotate(180deg);
  color: var(--indigo);
}

.faq-item__a {
  padding: 0 0 20px;
}

.faq-item__a p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-soft);
  line-height: 1.75;
}

/* ─── Sprint 3 Responsive ────────────────────────────────── */
@media (max-width: 940px) {
  .solutions-metrics,
  .solutions-links { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .solutions-modules-row { grid-template-columns: 1fr; }
  .for-pains-grid { grid-template-columns: 1fr; }
  .case-study__body { grid-template-columns: 1fr; }
  .case-study__results { position: static; }
  .faq-layout { grid-template-columns: 1fr; }
  .faq-nav { display: none; }
}

@media (max-width: 600px) {
  .solutions-metrics { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .solutions-links   { grid-template-columns: 1fr; }
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 4 — WOW FACTOR: ANIMATIONS, MEGA-NAV, FOOTER V2
   ═════════════════════════════════════════════════════════════ */

/* ── Global keyframes ────────────────────────────────────── */
@keyframes gradientShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@keyframes blobFloat {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%       { transform: translate(30px, -20px) scale(1.05); }
  66%       { transform: translate(-20px, 15px) scale(0.97); }
}

@keyframes blobFloat2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%       { transform: translate(-35px, 25px) scale(1.06); }
  66%       { transform: translate(25px, -15px) scale(0.96); }
}

@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}

@keyframes tickerScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 20px rgba(79,70,229,0.3); }
  50%       { box-shadow: 0 0 40px rgba(79,70,229,0.55), 0 0 80px rgba(124,58,237,0.2); }
}

@keyframes countUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes heroOrb {
  0%, 100% { transform: translate(-50%, -50%) rotate(0deg) scale(1); opacity: 0.4; }
  50%       { transform: translate(-50%, -50%) rotate(180deg) scale(1.15); opacity: 0.6; }
}

/* ── Gradient text utility ───────────────────────────────── */
.gradient-text {
  background: linear-gradient(135deg, #4F46E5 0%, #7C3AED 40%, #14B8A6 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradientShift 4s ease infinite;
}

/* ── Hero ambient glow / orbs ────────────────────────────── */
.hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}

.hero-orb--1 {
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(79,70,229,0.35) 0%, transparent 70%);
  top: -10%;
  right: -5%;
  animation: blobFloat 10s ease-in-out infinite;
}

.hero-orb--2 {
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(124,58,237,0.3) 0%, transparent 70%);
  bottom: -80px;
  left: 5%;
  animation: blobFloat2 13s ease-in-out infinite;
}

.hero-orb--3 {
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, rgba(20,184,166,0.25) 0%, transparent 70%);
  top: 40%;
  right: 15%;
  animation: blobFloat 8s ease-in-out 2s infinite;
}

/* ── Hero orb wrapper — hard clips all blurred orbs to hero bounds ─ */
/* This is more reliable than contain:paint for filter:blur across   */
/* all current Blink/WebKit versions.                                */
.hero-orbs-wrap {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

/* hero--has-orbs base (Sprint 4) */
.hero--has-orbs {
  position: relative;
  overflow: hidden;
  /* Prevent filter: blur() on child orbs from expanding scroll area */
  isolation: isolate;
  /* Clip the paint layer at the border-box boundary */
  contain: paint;
}
/* Only elevate the shell above canvas — NOT the orbs */
.hero--has-orbs > .site-shell { position: relative; z-index: 3; }

/* ── Button shimmer / glow variants ─────────────────────── */
.button {
  position: relative;
  overflow: hidden;
}
.button::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,0.18) 50%, transparent 60%);
  background-size: 200% auto;
  opacity: 0;
  transition: opacity 200ms ease;
}
.button:hover::after {
  opacity: 1;
  animation: shimmer 500ms ease forwards;
}
.button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.35);
}
.button--ghost:hover {
  box-shadow: 0 8px 24px rgba(79,70,229,0.15);
}
.button:active { transform: translateY(0); }

/* ── Glassmorphism card modifier ─────────────────────────── */
.card--glass {
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.65);
  box-shadow: 0 4px 24px rgba(79,70,229,0.08);
}

/* ── Counter number animation ────────────────────────────── */
.count-up {
  display: inline-block;
}
.count-up.is-animating {
  animation: countUp 400ms ease forwards;
}

/* ── Logo ticker ─────────────────────────────────────────── */
.logo-ticker {
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}

.logo-ticker__track {
  display: flex;
  gap: 40px;
  width: max-content;
  animation: tickerScroll 28s linear infinite;
  align-items: center;
}

.logo-ticker:hover .logo-ticker__track {
  animation-play-state: paused;
}

.logo-ticker__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 999px;
  border: 1px solid rgba(79,70,229,0.12);
  background: rgba(255,255,255,0.8);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--navy);
  white-space: nowrap;
  flex-shrink: 0;
  letter-spacing: 0.02em;
}

/* ── Announcement bar ────────────────────────────────────── */
.announce-bar {
  background: linear-gradient(135deg, #1e1b4b 0%, #312e81 50%, #1e1b4b 100%);
  background-size: 200% 200%;
  animation: gradientShift 6s ease infinite;
  padding: 8px 0;
  font-size: 0.82rem;
  color: rgba(199,210,254,0.85);
}

.announce-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.announce-bar__badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(79,70,229,0.4);
  border: 1px solid rgba(199,210,254,0.3);
  font-size: 0.7rem;
  font-weight: 700;
  color: #c7d2fe;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  flex-shrink: 0;
}

.announce-bar a {
  color: #c7d2fe;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.announce-bar a:hover { color: #fff; }

.announce-bar__close {
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(199,210,254,0.45);
  padding: 4px;
  border-radius: 6px;
  margin-left: auto;
  transition: color 150ms ease;
}
.announce-bar__close:hover { color: #c7d2fe; }

/* ── Site header v2 ──────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 800;
  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(79,70,229,0.08);
  transition: box-shadow 200ms ease, background 200ms ease;
}

.site-header.is-scrolled {
  background: rgba(255,255,255,0.97);
  box-shadow: 0 2px 24px rgba(79,70,229,0.1);
}

.site-header__inner {
  display: flex;
  align-items: center;
  gap: 0;
  height: 64px;
}

.site-header__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  flex-shrink: 0;
}

/* ── Mega Nav ────────────────────────────────────────────── */
.mega-nav {
  flex: 1;
  margin: 0 24px;
}

.mega-nav__list {
  display: flex;
  align-items: center;
  gap: 2px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.mega-nav__item {
  position: static;
}

.mega-nav__trigger,
.mega-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 12px;
  border-radius: 8px;
  background: none;
  border: none;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--navy);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background 150ms ease, color 150ms ease;
}

.mega-nav__trigger:hover,
.mega-nav__link:hover {
  background: rgba(79,70,229,0.07);
  color: var(--indigo);
}

.mega-nav__trigger[aria-expanded="true"] {
  background: rgba(79,70,229,0.07);
  color: var(--indigo);
}

.mega-nav__caret {
  transition: transform 200ms ease;
  flex-shrink: 0;
  color: var(--text-faint);
}

.mega-nav__trigger[aria-expanded="true"] .mega-nav__caret {
  transform: rotate(180deg);
  color: var(--indigo);
}

/* ── Mega panels ─────────────────────────────────────────── */
.mega-panel {
  position: fixed;
  top: 64px; /* height of header */
  left: 0;
  right: 0;
  z-index: 799;
  background: rgba(255,255,255,0.98);
  border-top: 1px solid rgba(79,70,229,0.1);
  border-bottom: 3px solid rgba(79,70,229,0.12);
  box-shadow: 0 20px 60px rgba(79,70,229,0.12);
  backdrop-filter: blur(20px);
  display: none;
  animation: fadeSlideIn 150ms ease forwards;
}

.mega-panel.is-open {
  display: block;
}

.mega-panel__inner {
  display: flex;
  gap: 0;
  padding-top: 28px;
  padding-bottom: 28px;
  align-items: flex-start;
}

.mega-panel__section {
  flex: 1;
  padding-right: 32px;
  border-right: 1px solid rgba(79,70,229,0.08);
  margin-right: 32px;
}

.mega-panel__section:last-child {
  border-right: none;
  padding-right: 0;
  margin-right: 0;
}

.mega-panel__section--wide {
  flex: 2;
}

.mega-panel__label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin: 0 0 14px;
}

.mega-panel__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}

.mega-panel__grid--2 {
  grid-template-columns: repeat(2, 1fr);
}

.mega-panel__list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.mega-panel__section-cta {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid rgba(79,70,229,0.08);
}

.mega-panel__section-cta .mega-panel__label {
  margin-bottom: 10px;
}

/* Mega links */
.mega-link {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--navy);
  transition: background 120ms ease;
}

.mega-link:hover {
  background: rgba(79,70,229,0.06);
}

.mega-link strong {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: 2px;
  transition: color 120ms ease;
}

.mega-link:hover strong {
  color: var(--indigo);
}

.mega-link span {
  display: block;
  font-size: 0.78rem;
  color: var(--text-soft);
  line-height: 1.4;
}

.mega-link--compact strong { font-size: 0.82rem; }
.mega-link--compact span  { font-size: 0.75rem; }

/* Compact icon — smaller than the full mega-link icon */
.mega-link--compact .mega-link__icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  flex-shrink: 0;
  align-self: center;
}

/* Ensure icon+copy align correctly in both compact and full variants */
.mega-link {
  align-items: center;
}
.mega-link .mega-link__copy {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

/* Mega link icons */
.mega-link__icon {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  flex-shrink: 0;
}

.mega-link__icon--indigo { background: rgba(79,70,229,0.1);  color: var(--indigo); }
.mega-link__icon--violet { background: rgba(124,58,237,0.1); color: var(--violet); }
.mega-link__icon--teal   { background: rgba(20,184,166,0.1); color: var(--teal); }
.mega-link__icon--rose   { background: rgba(244,63,94,0.1);  color: var(--rose); }
.mega-link__icon--amber  { background: rgba(245,158,11,0.1); color: var(--amber); }

.mega-link__copy { flex: 1; }

/* Featured promo in panel */
.mega-panel__featured {
  flex-shrink: 0;
  width: 220px;
}

.mega-panel__promo {
  background: linear-gradient(160deg, #0f0c3c, #1a1560);
  border-radius: var(--radius);
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mega-panel__promo-headline {
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.4;
  margin: 0;
}

/* ── Mobile nav (hamburger) ──────────────────────────────── */
.site-nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  background: none;
  border: none;
  cursor: pointer;
  margin-left: auto;
  margin-right: 8px;
}

.site-nav-toggle span:not(.screen-reader-text) {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--navy);
  border-radius: 2px;
  transition: transform 250ms ease, opacity 250ms ease;
}

/* ── Meta pill (for case studies etc) ────────────────────── */
.meta-pill {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

/* ── Footer v2 ───────────────────────────────────────────── */
.site-footer-v2 {
  background: linear-gradient(180deg, #060617 0%, #0a0820 100%);
  color: rgba(199,210,254,0.6);
  font-size: 0.875rem;
  position: relative;
  overflow: hidden;
}

/* Subtle background glow */
.site-footer-v2::before {
  content: '';
  position: absolute;
  top: -200px;
  left: 50%;
  transform: translateX(-50%);
  width: 800px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(79,70,229,0.12) 0%, transparent 70%);
  pointer-events: none;
}

/* CTA band */
.footer-cta-band {
  border-bottom: 1px solid rgba(79,70,229,0.15);
  padding: 60px 0;
  position: relative;
}

.footer-cta-band__inner {
  display: grid;
  grid-template-columns: minmax(0,1.4fr) minmax(0,1fr);
  gap: 40px;
  align-items: center;
}

.footer-cta-band h2 {
  color: #fff;
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  letter-spacing: -0.04em;
  margin: 8px 0 0;
  line-height: 1.2;
}

.footer-cta-band .eyebrow {
  color: rgba(199,210,254,0.55);
}

.footer-cta-band__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
}

.footer-cta-band__calc {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(199,210,254,0.55);
  text-decoration: none;
  font-size: 0.82rem;
  font-weight: 600;
  padding: 6px 0;
  transition: color 150ms ease;
}
.footer-cta-band__calc:hover { color: #c7d2fe; }

/* Footer grid */
.footer-grid {
  display: grid;
  grid-template-columns: 240px 1fr 1fr 1fr;
  gap: 48px;
  padding: 56px 0 48px;
  border-bottom: 1px solid rgba(79,70,229,0.12);
}

/* Brand column */
.footer-brand__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  margin-bottom: 16px;
}

.footer-brand__desc {
  font-size: 0.82rem;
  color: rgba(199,210,254,0.45);
  line-height: 1.65;
  margin: 0 0 20px;
}

.footer-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 20px;
}

.footer-trust-badge {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(79,70,229,0.25);
  background: rgba(79,70,229,0.06);
  font-size: 0.68rem;
  font-weight: 700;
  color: rgba(199,210,254,0.7);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.footer-brand__tagline {
  font-size: 0.78rem;
  color: rgba(199,210,254,0.3);
  margin: 0;
  font-style: italic;
  letter-spacing: 0.04em;
}

/* Footer columns */
.footer-col__title {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin: 0 0 12px;
}

.footer-col__subtitle {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(199,210,254,0.3);
  margin: 0 0 6px;
}

.footer-col__links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.footer-col__links a {
  color: rgba(199,210,254,0.5);
  text-decoration: none;
  font-size: 0.85rem;
  transition: color 120ms ease;
  line-height: 1.4;
}

.footer-col__links a:hover {
  color: #c7d2fe;
}

/* Footer bottom bar */
.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  padding-top: 20px;
  padding-bottom: 24px;
  font-size: 0.78rem;
  color: rgba(199,210,254,0.3);
}

.footer-bottom__links {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.footer-bottom__links a {
  color: rgba(199,210,254,0.35);
  text-decoration: none;
  transition: color 120ms ease;
}
.footer-bottom__links a:hover { color: rgba(199,210,254,0.7); }

.footer-bottom__uk {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0;
}

.footer-bottom__uk svg { color: var(--indigo); }

/* ── Integrations page ───────────────────────────────────── */
.int-category {
  margin-bottom: 52px;
}

.int-category__title {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 20px;
  padding-bottom: 14px;
  border-bottom: 2px solid rgba(79,70,229,0.1);
  display: flex;
  align-items: center;
  gap: 12px;
}

.int-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 16px;
}

.int-card {
  padding: 20px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: #fff;
  transition: transform 150ms ease, box-shadow 150ms ease, border-color 150ms ease;
}

.int-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.1);
  border-color: rgba(79,70,229,0.2);
}

.int-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.int-card__avatar {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.int-badge {
  display: inline-flex;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.int-badge--green  { background: rgba(16,185,129,0.1); color: #059669; border: 1px solid rgba(16,185,129,0.2); }
.int-badge--blue   { background: rgba(59,130,246,0.1); color: #1d4ed8; border: 1px solid rgba(59,130,246,0.2); }
.int-badge--amber  { background: rgba(245,158,11,0.1); color: #b45309; border: 1px solid rgba(245,158,11,0.2); }
.int-badge--neutral{ background: rgba(107,114,128,0.1);color: #4b5563; border: 1px solid rgba(107,114,128,0.2); }
.int-badge--violet { background: rgba(124,58,237,0.1); color: #6d28d9; border: 1px solid rgba(124,58,237,0.2); }

.int-card__name {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 4px;
}

.int-card__desc {
  font-size: 0.78rem;
  color: var(--text-soft);
  margin: 0;
  line-height: 1.5;
}

/* ── Hero page improvements ──────────────────────────────── */
.page-hero {
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 50% at 70% 40%, rgba(79,70,229,0.08) 0%, transparent 70%);
  pointer-events: none;
}

.page-hero__intro {
  max-width: 60ch;
  color: var(--text-soft);
  font-size: 1.05rem;
  line-height: 1.7;
  margin-top: 16px;
}

/* ── Data reveal stagger ─────────────────────────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 500ms ease, transform 500ms ease;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}
[data-stagger] > * {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 400ms ease, transform 400ms ease;
}
[data-stagger] > *.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Sprint 4 responsive ─────────────────────────────────── */
@media (max-width: 1100px) {
  .mega-panel__grid { grid-template-columns: repeat(2, 1fr); }
  .int-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-cta-band__inner { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
  /* Mobile nav */
  .site-nav-toggle { display: flex; }

  .mega-nav {
    position: fixed;
    top: 64px;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255,255,255,0.98);
    backdrop-filter: blur(20px);
    padding: 20px 0;
    overflow-y: auto;
    transform: translateX(-100%);
    transition: transform 260ms ease;
    margin: 0;
    z-index: 900;
    flex: none;
  }

  .mega-nav.is-open { transform: translateX(0); }

  .mega-nav__list { flex-direction: column; align-items: stretch; padding: 0 20px; gap: 0; }
  .mega-nav__trigger, .mega-nav__link { width: 100%; border-radius: 0; border-bottom: 1px solid rgba(79,70,229,0.06); padding: 14px 0; }

  .mega-panel {
    position: static;
    box-shadow: none;
    border: none;
    background: rgba(79,70,229,0.03);
    border-radius: var(--radius-sm);
    margin: 4px 0 8px;
    animation: none;
  }

  .mega-panel__inner { flex-direction: column; gap: 12px; padding: 12px; }
  .mega-panel__section { border-right: none; margin-right: 0; padding-right: 0; }
  .mega-panel__featured { width: 100%; }
  .mega-panel__grid { grid-template-columns: 1fr; }
  .mega-panel__grid--2 { grid-template-columns: 1fr; }

  .site-header__actions .button--ghost { display: none; }

  .int-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 600px) {
  .int-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-cta-band { padding: 40px 0; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 10px; }
  .announce-bar__inner { justify-content: flex-start; }
  .logo-ticker__track { animation-duration: 18s; }
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 5 — HOMEPAGE WOW + ABOUT + EXIT POPUP
   ═════════════════════════════════════════════════════════════ */

/* ── Hero signal card ────────────────────────────────────── */
.hero__signal-card {
  background: linear-gradient(160deg, #0f0c3c 0%, #1a1560 60%, #0f2a4a 100%);
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.2);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: 0 24px 60px rgba(79,70,229,0.25), inset 0 1px 0 rgba(255,255,255,0.06);
  animation: pulseGlow 4s ease-in-out infinite;
}

.hero__signal-header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.hero__signal-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #10b981;
  box-shadow: 0 0 10px #10b981;
  animation: blobFloat 2s ease-in-out infinite;
}

.hero__signal-stat strong {
  display: block;
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.05em;
  line-height: 1;
}

.hero__signal-stat span {
  font-size: 0.78rem;
  color: rgba(199,210,254,0.5);
  display: block;
  margin-top: 4px;
}

/* Transaction feed */
.hero__signal-feed {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: rgba(0,0,0,0.2);
  border-radius: var(--radius-sm);
  padding: 10px;
  border: 1px solid rgba(255,255,255,0.05);
}

.hero__feed-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
  padding: 5px 6px;
  border-radius: 6px;
  font-size: 0.7rem;
  font-family: 'IBM Plex Mono', monospace;
  color: rgba(199,210,254,0.5);
  transition: background 200ms ease;
}

.hero__feed-row--in {
  background: rgba(79,70,229,0.12);
  color: rgba(199,210,254,0.85);
}

.hero__feed-label { font-weight: 500; }
.hero__feed-cat   { color: #c7d2fe; font-weight: 600; text-align: center; }

.hero__feed-conf {
  text-align: right;
  color: #10b981;
  font-weight: 700;
}

/* ── Hero social proof strip ─────────────────────────────── */
.hero__proof {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 20px;
}

.hero__proof-avatars {
  display: flex;
}

.hero__proof-avatar {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4F46E5, #7C3AED);
  font-size: 0.6rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: 0.04em;
  border: 2px solid #fff;
  margin-left: -8px;
}

.hero__proof-avatar:first-child { margin-left: 0; }

.hero__proof p {
  font-size: 0.82rem;
  color: var(--text-soft);
  margin: 0;
}

.hero__proof strong { color: var(--navy); }

/* ── Hero in / gradient headline ─────────────────────────── */
.hero-in {
  color: var(--navy);
}

/* ── Button glow variant ─────────────────────────────────── */
.button--glow {
  box-shadow: 0 0 0 0 rgba(79,70,229,0.5);
  animation: pulseGlow 3s ease-in-out infinite;
}

.button--glow:hover {
  box-shadow: 0 8px 32px rgba(79,70,229,0.5), 0 0 60px rgba(124,58,237,0.2);
  animation: none;
}

/* ── Pricing badge ───────────────────────────────────────── */
.pricing-card {
  position: relative;
}

.pricing-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  padding: 4px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, #4F46E5, #7C3AED);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(79,70,229,0.4);
}

/* ── Ticker label ────────────────────────────────────────── */
.fp-ticker-wrap {
  overflow: hidden;
}

.fp-ticker-wrap .site-shell {
  margin-bottom: 12px;
}

.fp-ticker-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin: 0;
}

/* ── Stats strip ─────────────────────────────────────────── */
.fp-stats-strip {
  background: linear-gradient(135deg, rgba(79,70,229,0.04) 0%, rgba(124,58,237,0.04) 100%);
  border-top: 1px solid rgba(79,70,229,0.08);
  border-bottom: 1px solid rgba(79,70,229,0.08);
}

.fp-stats-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap: 0;
}

.fp-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 24px 12px;
  border-right: 1px solid rgba(79,70,229,0.08);
}

.fp-stat:last-child { border-right: none; }

.fp-stat__num {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  color: var(--indigo);
  line-height: 1;
}

.fp-stat__suf {
  font-size: 1rem;
  font-weight: 700;
  color: var(--indigo);
  line-height: 1;
  align-self: flex-end;
  margin-bottom: 2px;
}

.fp-stat__label {
  font-size: 0.72rem;
  color: var(--text-soft);
  margin-top: 6px;
  line-height: 1.3;
  letter-spacing: 0.02em;
}

/* ── Solutions sector links ──────────────────────────────── */
.fp-solution-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 32px;
}

.fp-solution-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 20px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: rgba(255,255,255,0.7);
  text-decoration: none;
  color: var(--navy);
  transition: transform 150ms ease, box-shadow 150ms ease, border-color 150ms ease, background 150ms ease;
  position: relative;
}

.fp-solution-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.1);
  border-color: rgba(79,70,229,0.2);
  background: #fff;
}

.fp-solution-card strong {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy);
}

.fp-solution-card span:not(.fp-solution-card__arrow) {
  font-size: 0.78rem;
  color: var(--text-soft);
  line-height: 1.4;
}

.fp-solution-card__arrow {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--indigo);
  font-size: 1rem;
  transition: transform 150ms ease;
}

.fp-solution-card:hover .fp-solution-card__arrow {
  transform: translateY(-50%) translateX(3px);
}

/* ── CTA panel glow ──────────────────────────────────────── */
.cta-panel--glow {
  background: linear-gradient(160deg, #0f0c3c 0%, #1a1560 50%, #0a2a4a 100%);
  border: 1px solid rgba(79,70,229,0.3);
  box-shadow: 0 0 80px rgba(79,70,229,0.15), inset 0 1px 0 rgba(255,255,255,0.06);
}

.cta-panel--glow .eyebrow { color: rgba(199,210,254,0.55); }
.cta-panel--glow h2 { color: #fff; }
.cta-panel--glow p  { color: rgba(199,210,254,0.65); }

/* ── Exit-intent popup ───────────────────────────────────── */
.exit-popup {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.exit-popup[hidden] { display: none; }

.exit-popup__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10,8,32,0.75);
  backdrop-filter: blur(6px);
}

.exit-popup__box {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: calc(var(--radius) * 1.5);
  padding: 36px 32px;
  max-width: 520px;
  width: 100%;
  box-shadow: 0 32px 80px rgba(79,70,229,0.25), 0 0 0 1px rgba(79,70,229,0.1);
  transform: translateY(16px) scale(0.97);
  opacity: 0;
  transition: transform 280ms cubic-bezier(0.34,1.56,0.64,1), opacity 250ms ease;
}

.exit-popup.is-open .exit-popup__box {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.exit-popup__close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: rgba(79,70,229,0.06);
  border: none;
  border-radius: 8px;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  cursor: pointer;
  color: var(--text-soft);
  transition: background 150ms ease, color 150ms ease;
}

.exit-popup__close:hover {
  background: rgba(79,70,229,0.12);
  color: var(--indigo);
}

.exit-popup__icon {
  margin-bottom: 14px;
}

.exit-popup__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--indigo);
  margin: 0 0 8px;
}

.exit-popup__headline {
  font-size: clamp(1.2rem, 3vw, 1.5rem);
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.03em;
  line-height: 1.25;
  margin: 0 0 12px;
}

.exit-popup__body {
  font-size: 0.875rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin: 0 0 22px;
}

.exit-popup__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}

.exit-popup__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  font-size: 0.72rem;
  color: var(--text-faint);
}

/* ── About page ──────────────────────────────────────────── */
.about-story-layout {
  display: grid;
  grid-template-columns: minmax(0,1.4fr) minmax(0,1fr);
  gap: 60px;
  align-items: start;
}

.about-story-layout p {
  color: var(--text-soft);
  line-height: 1.7;
  margin: 0 0 12px;
  font-size: 0.95rem;
}

.about-story-layout h2 {
  margin: 10px 0 20px;
}

.about-story-callout blockquote {
  padding: 28px 28px 24px;
  border-left: 4px solid var(--indigo);
  border-radius: 0 var(--radius) var(--radius) 0;
  background: rgba(79,70,229,0.04);
  border-right: 1px solid rgba(79,70,229,0.09);
  border-top: 1px solid rgba(79,70,229,0.09);
  border-bottom: 1px solid rgba(79,70,229,0.09);
}

.about-story-callout blockquote p {
  font-size: 1.05rem;
  font-style: italic;
  color: var(--navy);
  line-height: 1.6;
  margin: 0 0 12px;
}

.about-story-callout blockquote footer {
  font-size: 0.82rem;
  color: var(--text-soft);
}

/* Timeline */
.about-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-left: 2px solid rgba(79,70,229,0.15);
  padding-left: 32px;
  margin-left: 40px;
  margin-top: 32px;
}

.about-timeline__item {
  position: relative;
  padding-bottom: 36px;
}

.about-timeline__item::before {
  content: '';
  position: absolute;
  left: -39px;
  top: 6px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--indigo);
  border: 3px solid #fff;
  box-shadow: 0 0 0 3px rgba(79,70,229,0.2);
}

.about-timeline__year {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--indigo);
  margin-bottom: 6px;
}

.about-timeline__content h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 6px;
}

.about-timeline__content p {
  font-size: 0.875rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin: 0;
}

/* Values grid */
.about-values-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 20px;
  margin-top: 32px;
}

.about-value-card {
  padding: 24px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: rgba(255,255,255,0.7);
  transition: transform 150ms ease, box-shadow 150ms ease;
}

.about-value-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.1);
}

.about-value-card__icon {
  font-size: 1.6rem;
  margin-bottom: 14px;
  display: block;
}

.about-value-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 8px;
}

.about-value-card p {
  font-size: 0.85rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin: 0;
}

/* Team grid */
.about-team-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 20px;
  margin-top: 36px;
}

.about-team-card {
  padding: 24px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: #fff;
  transition: transform 150ms ease, box-shadow 150ms ease;
}

.about-team-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.1);
}

.about-team-card__avatar {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: linear-gradient(135deg, #4F46E5, #7C3AED);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  display: grid;
  place-items: center;
  margin-bottom: 14px;
}

.about-team-card__name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 4px;
}

.about-team-card__title {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--indigo);
  margin: 0 0 12px;
  letter-spacing: 0.02em;
}

.about-team-card__bio {
  font-size: 0.82rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin: 0;
}

/* Credentials */
.about-credentials {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.about-credentials__badges {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 16px;
}

.about-cred-badge {
  padding: 20px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.12);
  background: rgba(255,255,255,0.6);
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: box-shadow 150ms ease, transform 150ms ease;
}

.about-cred-badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.1);
}

.about-cred-badge__icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(79,70,229,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--indigo);
  margin-bottom: 4px;
}

.about-cred-badge strong {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy);
}

.about-cred-badge span {
  font-size: 0.78rem;
  color: var(--text-soft);
  line-height: 1.4;
}

.about-credentials__note {
  font-size: 0.82rem;
  color: var(--text-faint);
  line-height: 1.65;
  margin: 0;
  padding: 14px 18px;
  border-radius: var(--radius-sm);
  background: rgba(79,70,229,0.04);
  border: 1px solid rgba(79,70,229,0.1);
}

/* ── UK Company registration strip ──────────────────────── */
.about-company-reg {
  border-top: 1px solid rgba(79,70,229,0.06);
  border-bottom: 1px solid rgba(79,70,229,0.06);
  background: rgba(255,255,255,0.5);
}

.about-company-reg__inner {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}

.about-company-reg__col {
  flex: 1;
  min-width: 180px;
  padding: 1.25rem 1.5rem;
}

.about-company-reg__divider {
  width: 1px;
  height: 60px;
  background: rgba(79,70,229,0.1);
  flex-shrink: 0;
}

.about-company-reg__label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin: 0 0 4px;
}

.about-company-reg__value {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 2px;
}

.about-company-reg__sub {
  font-size: 0.75rem;
  color: var(--text-soft);
  margin: 0;
}

.about-company-reg__sub strong { color: var(--navy); }

@media (max-width: 780px) {
  .about-company-reg__inner { flex-direction: column; align-items: flex-start; }
  .about-company-reg__divider { width: 100%; height: 1px; }
  .about-company-reg__col { padding: 1rem 0; }
}


/* ─── Sprint 5 Responsive ────────────────────────────────── */
@media (max-width: 1000px) {
  .fp-stats-grid            { grid-template-columns: repeat(3, 1fr); }
  .fp-solution-links        { grid-template-columns: repeat(2, 1fr); }
  .about-values-grid        { grid-template-columns: repeat(2, 1fr); }
  .about-team-grid          { grid-template-columns: repeat(2, 1fr); }
  .about-credentials__badges{ grid-template-columns: repeat(2, 1fr); }
  .about-story-layout       { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
  .fp-stats-grid     { grid-template-columns: repeat(2, 1fr); }
  .fp-solution-links { grid-template-columns: 1fr; }
  .about-values-grid { grid-template-columns: 1fr; }
  .about-team-grid   { grid-template-columns: 1fr; }
  .about-credentials__badges { grid-template-columns: 1fr 1fr; }
  .about-timeline    { margin-left: 16px; padding-left: 20px; }
  .exit-popup__box   { padding: 24px 20px; }
  .exit-popup__actions { flex-direction: column; }
}

/* ═════════════════════════════════════════════════════════════
   WOW FX CSS — Sprint 5
   ═════════════════════════════════════════════════════════════ */

/* ── 1. Cursor spotlight ─────────────────────────────────── */
.cursor-spotlight {
  position: fixed;
  top: -350px;
  left: -350px;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(79,70,229,0.10) 0%, rgba(79,70,229,0.04) 35%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  will-change: transform;
  transition: opacity 300ms ease;
}

/* ── 2. Dot-grid canvas ──────────────────────────────────── */
.hero-dot-grid {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

/* Hero orbs must not affect layout */
.hero-orb {
  position: absolute !important;
  pointer-events: none;
  z-index: 2;
}

/* Ensure hero content sits above canvas and orbs */
.hero--has-orbs .site-shell {
  position: relative;
  z-index: 4;
}

/* ── 3. Typewriter cursor blink ──────────────────────────── */
.hero__typewriter {
  display: inline;
}

.hero__typewriter::after {
  content: '|';
  display: inline-block;
  margin-left: 2px;
  font-weight: 300;
  color: var(--indigo);
  animation: cursorBlink 0.9s step-end infinite;
}

@keyframes cursorBlink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

/* ── 4. 3D card tilt shine overlay ──────────────────────── */
.feature-card,
.module-card,
.story-card,
.fp-solution-card,
.about-value-card,
.about-team-card,
.int-card {
  --shine-x: 50%;
  --shine-y: 50%;
  isolation: isolate;
}

.feature-card::before,
.module-card::before,
.story-card::before,
.about-value-card::before,
.about-team-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(
    circle at var(--shine-x, 50%) var(--shine-y, 50%),
    rgba(255,255,255,0.07) 0%,
    transparent 60%
  );
  pointer-events: none;
  opacity: 0;
  transition: opacity 150ms ease;
  z-index: 1;
}

.feature-card:hover::before,
.module-card:hover::before,
.story-card:hover::before,
.about-value-card:hover::before,
.about-team-card:hover::before {
  opacity: 1;
}

/* ── 5. Live counter bump pulse ──────────────────────────── */
@keyframes counterBump {
  0%   { transform: scale(1);    color: inherit; }
  40%  { transform: scale(1.08); color: var(--indigo); }
  100% { transform: scale(1);    color: inherit; }
}

.counter-bump {
  animation: counterBump 280ms cubic-bezier(0.34,1.56,0.64,1);
}

/* ── 6. Section heading shimmer sweep ────────────────────── */
.section-title,
h1 {
  position: relative;
  overflow: hidden;
}

.section-title::after,
h1::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,0.18) 50%,
    transparent 100%
  );
  transform: skewX(-20deg);
  pointer-events: none;
  opacity: 0;
}

.section-title.did-reveal::after,
h1.did-reveal::after {
  animation: headingSweep 700ms ease forwards;
}

@keyframes headingSweep {
  0%   { left: -100%; opacity: 1; }
  100% { left: 160%;  opacity: 0; }
}

/* ── 7. Button ghost ─────────────────────────────────────── */
.button--ghost {
  background: transparent;
  border: 1px solid rgba(79,70,229,0.3);
  color: var(--indigo);
  box-shadow: none;
}

.button--ghost:hover {
  background: rgba(79,70,229,0.06);
  border-color: var(--indigo);
}

/* ── 8. CTA panel compact ────────────────────────────────── */
.cta-panel--compact {
  flex-direction: column;
  text-align: center;
  align-items: center;
  gap: 28px;
}

.cta-panel--compact h2 {
  font-size: clamp(1.4rem, 3vw, 2rem);
  max-width: 680px;
  margin-inline: auto;
}

/* ── 9. Page hero intro text ─────────────────────────────── */
.page-hero__intro {
  font-size: clamp(1rem, 2vw, 1.15rem);
  color: var(--text-soft);
  max-width: 640px;
  line-height: 1.7;
  margin: 20px 0 0;
}

/* ── 10. Extra hero polish ───────────────────────────────── */
/* Subtle animated gradient behind hero headline */
.hero h1 {
  background: linear-gradient(135deg, #0D0D1F 40%, #4F46E5 70%, #7C3AED 90%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  background-size: 200% 100%;
  animation: gradientShift 6s ease infinite alternate;
}

/* Trust chips glow */
.hero__chips li {
  background: rgba(79,70,229,0.06);
  border: 1px solid rgba(79,70,229,0.14);
  padding: 4px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--navy);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background 150ms ease, border-color 150ms ease, transform 150ms ease;
}

.hero__chips li:hover {
  background: rgba(79,70,229,0.12);
  border-color: rgba(79,70,229,0.28);
  transform: translateY(-1px);
}

.hero__chips {
  list-style: none;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 6 — INSIGHTS · FORM UX · PERF · A11Y
   ═════════════════════════════════════════════════════════════ */

/* ── Insights: Tag bar ───────────────────────────────────── */
.ins-tag-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 28px;
}

.ins-tag {
  padding: 6px 18px;
  border-radius: 999px;
  border: 1px solid rgba(79,70,229,0.18);
  background: rgba(255,255,255,0.7);
  color: var(--navy);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 150ms ease, border-color 150ms ease, color 150ms ease, transform 120ms ease;
  backdrop-filter: blur(6px);
}

.ins-tag:hover {
  background: rgba(79,70,229,0.08);
  border-color: rgba(79,70,229,0.3);
  transform: translateY(-1px);
}

.ins-tag--active {
  background: var(--indigo);
  border-color: var(--indigo);
  color: #fff;
  box-shadow: 0 4px 12px rgba(79,70,229,0.35);
}

/* ── Insights: Featured 3-up grid ───────────────────────── */
.ins-featured-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 20px;
}

.ins-featured-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 28px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: rgba(255,255,255,0.85);
  text-decoration: none;
  color: var(--navy);
  transition: transform 150ms ease, box-shadow 150ms ease;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.ins-featured-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--indigo);
  transition: height 200ms ease;
}

.ins-featured-card--teal::before   { background: var(--teal); }
.ins-featured-card--violet::before { background: var(--violet); }

.ins-featured-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(79,70,229,0.12);
}

.ins-featured-card h2 {
  font-size: clamp(1rem, 2vw, 1.18rem);
  font-weight: 700;
  color: var(--navy);
  line-height: 1.35;
  margin: 0;
  letter-spacing: -0.02em;
}

.ins-featured-card p {
  font-size: 0.87rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin: 0;
  flex: 1;
}

/* ── Insights: Card tag badge ────────────────────────────── */
.ins-card-tag {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
  align-self: flex-start;
}

.ins-card-tag--teal   { background: rgba(15,118,110,0.08);  color: var(--teal); }
.ins-card-tag--violet { background: rgba(124,58,237,0.08);  color: var(--violet); }
.ins-card-tag--rose   { background: rgba(244,63,94,0.08);   color: var(--rose); }
.ins-card-tag--amber  { background: rgba(245,158,11,0.08);  color: var(--amber); }

/* ── Insights: Meta / read-more ─────────────────────────── */
.ins-card-meta {
  font-size: 0.75rem;
  color: var(--text-faint);
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.ins-read-more {
  color: var(--indigo);
  font-weight: 700;
  margin-left: auto;
  transition: transform 150ms ease;
}

.ins-featured-card:hover .ins-read-more {
  transform: translateX(3px);
}

/* ── Insights: Newsletter stripe ─────────────────────────── */
.ins-newsletter-stripe {
  background: linear-gradient(135deg, rgba(79,70,229,0.04) 0%, rgba(124,58,237,0.04) 100%);
  border-top: 1px solid rgba(79,70,229,0.09);
  border-bottom: 1px solid rgba(79,70,229,0.09);
}

.ins-newsletter {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}

.ins-newsletter h2 {
  font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  letter-spacing: -0.03em;
  margin: 6px 0 8px;
}

.ins-newsletter p {
  font-size: 0.9rem;
  color: var(--text-soft);
  margin: 0;
}

.ins-newsletter__form {
  display: flex;
  gap: 10px;
  align-items: center;
  min-width: 360px;
}

.ins-newsletter__form input[type="email"] {
  flex: 1;
  padding: 12px 18px;
  border: 1px solid rgba(79,70,229,0.2);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.9);
  font-size: 0.9rem;
  color: var(--navy);
  outline: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.ins-newsletter__form input[type="email"]:focus {
  border-color: var(--indigo);
  box-shadow: 0 0 0 3px rgba(79,70,229,0.12);
}

/* ── Insights: Article card grid ─────────────────────────── */
.ins-article-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
  margin-top: 32px;
}

.ins-article-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 22px;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.09);
  background: rgba(255,255,255,0.75);
  text-decoration: none;
  color: var(--navy);
  transition: transform 150ms ease, box-shadow 150ms ease, border-color 150ms ease;
}

.ins-article-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.09);
  border-color: rgba(79,70,229,0.18);
}

.ins-article-card h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.4;
  margin: 0;
  letter-spacing: -0.01em;
  flex: 1;
}

/* ── Insights: Load more ─────────────────────────────────── */
.ins-load-more {
  display: flex;
  justify-content: center;
  margin-top: 36px;
  padding-top: 20px;
  border-top: 1px solid rgba(79,70,229,0.08);
}

/* ── Form field validation states ───────────────────────── */
.demo-form input:invalid:not(:placeholder-shown),
.demo-form select:invalid:not(:placeholder-shown),
.demo-form textarea:invalid:not(:placeholder-shown) {
  border-color: rgba(244,63,94,0.5);
  background-color: rgba(244,63,94,0.02);
}

.demo-form input:valid:not(:placeholder-shown) {
  border-color: rgba(16,185,129,0.5);
}

@keyframes fieldShake {
  0%,100% { transform: translateX(0); }
  25%      { transform: translateX(-4px); }
  75%      { transform: translateX(4px); }
}

.demo-form .field--shake {
  animation: fieldShake 250ms ease;
}

/* Form success state */
.demo-form__success {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-radius: var(--radius-sm);
  background: rgba(16,185,129,0.06);
  border: 1px solid rgba(16,185,129,0.25);
  color: var(--navy);
  font-size: 0.9rem;
  animation: successSlideIn 350ms cubic-bezier(0.34,1.56,0.64,1);
}

.demo-form__success:not([hidden]) { display: flex; }

@keyframes successSlideIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── prefers-reduced-motion (a11y critical) ──────────────── */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration:   0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration:  0.01ms !important;
    scroll-behavior: auto !important;
  }

  .cursor-spotlight   { display: none !important; }
  .hero-dot-grid      { display: none !important; }
  .hero-orb           { display: none !important; }
  .logo-ticker__track { animation: none !important; transform: none !important; }
}

/* ── will-change budget ──────────────────────────────────── */
/* Only apply where GPU promotion actually helps */
.cursor-spotlight { will-change: transform; }
.hero-dot-grid    { will-change: auto; }
.hero-orb         { will-change: transform; }

/* Remove will-change from cards — tilt sets inline styles directly */
.feature-card,
.module-card,
.story-card,
.about-value-card,
.about-team-card {
  will-change: auto;
}

/* ── Sprint 6 Responsive ─────────────────────────────────── */
@media (max-width: 1000px) {
  .ins-featured-grid    { grid-template-columns: 1fr 1fr; }
  .ins-article-grid     { grid-template-columns: 1fr 1fr; }
  .ins-newsletter       { grid-template-columns: 1fr; gap: 20px; }
  .ins-newsletter__form { min-width: 0; }
}

@media (max-width: 680px) {
  .ins-featured-grid    { grid-template-columns: 1fr; }
  .ins-article-grid     { grid-template-columns: 1fr; }
  .ins-newsletter__form { flex-direction: column; }
  .ins-tag-bar          { gap: 6px; }
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 7 — PRICING · COOKIE CONSENT · LEGAL · BREADCRUMBS
   ═════════════════════════════════════════════════════════════ */

/* ── Pricing: billing toggle ─────────────────────────────── */
.pricing-toggle {
  display: inline-flex;
  gap: 0;
  border: 1px solid rgba(79,70,229,0.2);
  border-radius: 999px;
  background: rgba(255,255,255,0.7);
  margin-top: 24px;
  padding: 3px;
  backdrop-filter: blur(8px);
}

.pricing-toggle__btn {
  padding: 8px 22px;
  border-radius: 999px;
  border: none;
  background: transparent;
  color: var(--text-soft);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background 150ms ease, color 150ms ease;
}

.pricing-toggle__btn--active {
  background: var(--indigo);
  color: #fff;
  box-shadow: 0 2px 8px rgba(79,70,229,0.3);
}

.pricing-toggle__badge {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(16,185,129,0.15);
  color: #059669;
}

.pricing-toggle__btn--active .pricing-toggle__badge {
  background: rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.9);
}

/* ── Pricing: proof strip ────────────────────────────────── */
.pricing-proof-strip {
  background: rgba(79,70,229,0.02);
  border-bottom: 1px solid rgba(79,70,229,0.08);
}

/* ── Pricing: tier cards ─────────────────────────────────── */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 20px;
  align-items: start;
}

.pricing-card {
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.12);
  background: rgba(255,255,255,0.95);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  position: relative;
  transition: transform 200ms cubic-bezier(0.34,1.3,0.64,1), box-shadow 200ms ease;
  box-shadow: 0 4px 20px rgba(17,24,58,0.06), 0 1px 4px rgba(17,24,58,0.04);
}

.pricing-card:hover { transform: translateY(-5px); box-shadow: 0 24px 56px rgba(79,70,229,0.13); }

/* ——— Teal (Starter) card ——— */
.pricing-card--teal {
  border-color: rgba(15,118,110,0.2);
  background: rgba(255,255,255,0.95);
}
.pricing-card--teal .pricing-card__name { color: #0f766e; }
.pricing-card--teal .pricing-card__price strong { color: #0f766e; }
.pricing-card--teal .pricing-card__meta {
  background: rgba(15,118,110,0.04);
  border-color: rgba(15,118,110,0.1);
}

/* ——— Indigo (Growth) featured card ——— */
.pricing-card--indigo {
  background: linear-gradient(160deg, #4338ca 0%, #6d28d9 55%, #4f46e5 100%);
  border: none;
  box-shadow:
    0 0 0 1px rgba(99,102,241,0.4),
    0 20px 60px rgba(79,70,229,0.45),
    0 4px 16px rgba(0,0,0,0.2);
  transform: scale(1.035);
  z-index: 2;
}
.pricing-card--indigo:hover {
  transform: scale(1.035) translateY(-5px);
  box-shadow:
    0 0 0 1px rgba(99,102,241,0.5),
    0 30px 80px rgba(79,70,229,0.5),
    0 6px 20px rgba(0,0,0,0.25);
}
.pricing-card--indigo .pricing-card__name { color: #fff; }
.pricing-card--indigo .pricing-card__price strong { color: #fff; }
.pricing-card--indigo .pricing-card__sub { color: rgba(199,210,254,0.75); }
.pricing-card--indigo .pricing-card__meta {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.15);
  color: rgba(199,210,254,0.85);
}
.pricing-card--indigo .pricing-card__feature { color: rgba(255,255,255,0.9); }
.pricing-card--indigo .pricing-card__feature--yes svg { stroke: #6ee7b7; }
.pricing-card--indigo .pricing-card__feature--no { color: rgba(255,255,255,0.4); }
.pricing-card--indigo .pricing-card__feature--no svg { stroke: rgba(255,255,255,0.25); }
.pricing-card--indigo .pricing-card__badge {
  background: #fff;
  color: var(--indigo);
  box-shadow: 0 4px 14px rgba(0,0,0,0.2);
}
.pricing-card--indigo .button {
  background: #fff !important;
  color: #4338ca !important;
  font-weight: 700;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
}
.pricing-card--indigo .button:hover {
  background: #f0f0ff !important;
  transform: translateY(-2px);
}

/* ——— Violet (Enterprise) card ——— */
.pricing-card--violet {
  border-color: rgba(124,58,237,0.2);
  background: linear-gradient(160deg, rgba(124,58,237,0.04), rgba(79,70,229,0.02));
}
.pricing-card--violet .pricing-card__name { color: #7c3aed; }
.pricing-card--violet .pricing-card__price strong { color: #7c3aed; }
.pricing-card--violet .pricing-card__meta {
  background: rgba(124,58,237,0.04);
  border-color: rgba(124,58,237,0.1);
}
.pricing-card--violet .button {
  background: linear-gradient(135deg, #7c3aed, #4f46e5) !important;
  color: #fff !important;
}

.pricing-card__badge {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--indigo);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 16px;
  border-radius: 999px;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(79,70,229,0.35);
}

.pricing-card__head { display: flex; flex-direction: column; gap: 6px; }

.pricing-card__name {
  font-size: 1.1rem;
  font-weight: 800;
  margin: 0;
  color: var(--navy);
}

.pricing-card__price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.pricing-card__price strong {
  font-size: clamp(1.8rem,3vw,2.4rem);
  font-weight: 900;
  color: var(--navy);
  letter-spacing: -0.04em;
  line-height: 1;
}

.pricing-card__sub {
  font-size: 0.78rem;
  color: var(--text-faint);
}

.pricing-card__meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--text-soft);
  padding: 14px;
  border-radius: var(--radius-sm);
  background: rgba(79,70,229,0.03);
  border: 1px solid rgba(79,70,229,0.07);
}

.pricing-card__features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pricing-card__feature {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.83rem;
  line-height: 1.4;
}

.pricing-card__feature svg { flex-shrink: 0; margin-top: 2px; }

.pricing-card__feature--yes svg { stroke: #059669; }
.pricing-card__feature--no  { color: var(--text-faint); }
.pricing-card__feature--no  svg { stroke: rgba(17,24,58,0.3); }

/* ── Pricing: social proof + trust signals layout ───────── */
.pricing-social-proof {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem;
  align-items: start;
}

.pricing-quote--panel {
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(79,70,229,0.12);
  border-radius: var(--radius);
  padding: 2.5rem;
  position: relative;
  box-shadow: 0 4px 24px rgba(17,24,58,0.06);
}

.pricing-quote__mark {
  position: absolute;
  top: 1.25rem;
  left: 2rem;
  font-size: 4rem;
  line-height: 1;
  color: rgba(79,70,229,0.12);
  font-family: Georgia, serif;
}

.pricing-quote--panel blockquote {
  border: none;
  background: transparent;
  padding: 0.5rem 0 0;
  border-radius: 0;
}

.pricing-quote--panel blockquote p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--navy);
  font-style: italic;
  margin: 0 0 1.5rem;
}

.pricing-quote__author {
  display: flex;
  align-items: center;
  gap: 0.875rem;
}

.pricing-quote__name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 2px;
}

.pricing-quote__role {
  font-size: 0.8rem;
  color: var(--text-soft);
}

.pricing-quote__role strong {
  color: var(--navy);
}

/* Trust signals list */
.pricing-trust-signals {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid rgba(79,70,229,0.1);
  border-radius: var(--radius);
  overflow: hidden;
}

.pricing-trust-signal {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.4rem;
  border-bottom: 1px solid rgba(79,70,229,0.07);
  background: rgba(255,255,255,0.9);
  transition: background 150ms ease;
}

.pricing-trust-signal:last-child { border-bottom: none; }

.pricing-trust-signal:hover { background: rgba(79,70,229,0.02); }

.pricing-trust-signal__icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(79,70,229,0.07);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--indigo);
}

.pricing-trust-signal strong {
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.2;
}

.pricing-trust-signal span {
  font-size: 0.78rem;
  color: var(--text-soft);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .pricing-social-proof {
    grid-template-columns: 1fr;
  }
}

/* ── Pricing: comparison table ────────────────────────────── */
.pricing-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
}

.pricing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.pricing-table th,
.pricing-table td {
  padding: 10px 16px;
  text-align: center;
  border-bottom: 1px solid rgba(79,70,229,0.06);
}

.pricing-table th:first-child,
.pricing-table td:first-child {
  text-align: left;
  font-weight: 600;
  color: var(--navy);
  background: rgba(255,255,255,0.6);
}

.pricing-table__featured {
  background: rgba(79,70,229,0.05);
  font-weight: 600;
  color: var(--indigo);
}

.pricing-table thead th {
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-soft);
  background: rgba(79,70,229,0.04);
  padding: 14px 16px;
  border-bottom: 2px solid rgba(79,70,229,0.12);
}

.pricing-table tbody tr:hover td { background: rgba(79,70,229,0.02); }

/* ── Pricing: quote ──────────────────────────────────────── */
.pricing-quote {
  max-width: 780px;
  margin: 0 auto;
}

.pricing-quote blockquote {
  border: 1px solid rgba(79,70,229,0.12);
  background: rgba(255,255,255,0.85);
  border-radius: var(--radius);
  padding: 32px 36px;
  position: relative;
}

.pricing-quote blockquote::before {
  content: '"';
  position: absolute;
  top: -10px; left: 28px;
  font-size: 5rem;
  line-height: 1;
  color: var(--indigo);
  opacity: 0.15;
  font-family: Georgia, serif;
}

.pricing-quote p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--navy);
  font-style: italic;
  margin: 0 0 12px;
}

.pricing-quote blockquote footer {
  font-size: 0.82rem;
  color: var(--text-soft);
  font-style: normal;
}

/* ── Pricing: FAQ grid ───────────────────────────────────── */
.pricing-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 1px;
  background: rgba(79,70,229,0.08);
  border-radius: var(--radius);
  overflow: hidden;
  margin-top: 32px;
}

.pricing-faq-item {
  background: rgba(255,255,255,0.92);
  padding: 4px;
}

.pricing-faq-item .faq-item__q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 18px 20px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--navy);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  gap: 12px;
  transition: color 150ms ease;
}
.pricing-faq-item .faq-item__q:hover { color: var(--indigo); }
.pricing-faq-item .faq-item__q[aria-expanded="true"] { color: var(--indigo); }
.pricing-faq-item .faq-item__q[aria-expanded="true"] .faq-item__chevron {
  transform: rotate(180deg);
}
.pricing-faq-item .faq-item__chevron {
  flex-shrink: 0;
  transition: transform 250ms ease;
}
.pricing-faq-item .faq-item__a {
  padding: 0 20px 18px;
  font-size: 0.88rem;
  color: var(--text-soft);
  line-height: 1.7;
}
.pricing-faq-item .faq-item__a p { margin: 0; }

/* ── Cookie Consent Banner ───────────────────────────────── */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9000;
  padding: 16px;
  background: rgba(17,24,58,0.97);
  backdrop-filter: blur(16px);
  border-top: 1px solid rgba(79,70,229,0.3);
  animation: cookieSlideUp 400ms cubic-bezier(0.34,1.2,0.64,1);
}

@keyframes cookieSlideUp {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

.cookie-banner__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
}

.cookie-banner__copy {
  flex: 1;
  min-width: 240px;
}

.cookie-banner__copy strong {
  color: #fff;
  font-size: 0.95rem;
  display: block;
  margin-bottom: 4px;
}

.cookie-banner__copy p {
  color: rgba(199,210,254,0.8);
  font-size: 0.82rem;
  margin: 0;
  line-height: 1.5;
}

.cookie-banner__copy a {
  color: rgba(165,180,252,1);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.cookie-banner__actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.cookie-banner__settings {
  background: none;
  border: none;
  color: rgba(199,210,254,0.7);
  font-size: 0.8rem;
  cursor: pointer;
  text-decoration: underline;
  padding: 4px;
  transition: color 150ms ease;
}

.cookie-banner__settings:hover { color: #fff; }

/* ── Cookie preference modal ─────────────────────────────── */
.cookie-modal { position: fixed; inset: 0; z-index: 9100; }

.cookie-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(4px);
}

.cookie-modal__box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(520px, 92vw);
  background: #fff;
  border-radius: var(--radius);
  padding: 32px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.25);
  display: flex;
  flex-direction: column;
  gap: 20px;
  animation: modalPop 250ms cubic-bezier(0.34,1.4,0.64,1);
}

@keyframes modalPop {
  from { opacity: 0; transform: translate(-50%,-48%) scale(0.95); }
  to   { opacity: 1; transform: translate(-50%,-50%) scale(1); }
}

.cookie-modal__title {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0;
  padding-right: 28px;
}

.cookie-modal__intro {
  font-size: 0.85rem;
  color: var(--text-soft);
  margin: 0;
}

.cookie-pref {
  border: 1px solid rgba(79,70,229,0.1);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
}

.cookie-pref__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.cookie-pref__row strong { font-size: 0.9rem; color: var(--navy); }

.cookie-pref__row p {
  font-size: 0.78rem;
  color: var(--text-faint);
  margin: 3px 0 0;
}

/* Toggle switch */
.cookie-switch { cursor: pointer; }
.cookie-switch input { display: none; }

.cookie-switch__track {
  display: block;
  width: 44px;
  height: 24px;
  border-radius: 999px;
  background: rgba(79,70,229,0.15);
  position: relative;
  transition: background 200ms ease;
  flex-shrink: 0;
}

.cookie-switch__track::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
  transition: transform 200ms cubic-bezier(0.34,1.4,0.64,1);
}

.cookie-switch input:checked + .cookie-switch__track {
  background: var(--indigo);
}

.cookie-switch input:checked + .cookie-switch__track::after {
  transform: translateX(20px);
}

.cookie-toggle {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(16,185,129,0.1);
  color: #059669;
}

.cookie-modal__footer {
  padding-top: 8px;
  border-top: 1px solid rgba(79,70,229,0.08);
}

/* Footer cookie button styles */
.footer-cookie-btn {
  background: none;
  border: none;
  color: rgba(199,210,254,0.6);
  font-size: inherit;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.footer-cookie-btn:hover { color: rgba(199,210,254,1); }

/* ── Legal page layout ────────────────────────────────────── */
.legal-layout {
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}

.legal-nav {
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.legal-nav a {
  font-size: 0.82rem;
  color: var(--text-soft);
  text-decoration: none;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  transition: background 130ms ease, color 130ms ease;
  border-left: 2px solid transparent;
}

.legal-nav a:hover {
  background: rgba(79,70,229,0.06);
  color: var(--indigo);
  border-left-color: var(--indigo);
}

.legal-body { max-width: 720px; }

.legal-section {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(79,70,229,0.07);
}

.legal-section:last-child { border-bottom: none; }

.legal-section h2 {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 12px;
  letter-spacing: -0.02em;
}

.legal-section h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin: 16px 0 6px;
}

.legal-section p, .legal-section li {
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--text-soft);
}

.legal-section ul { padding-left: 20px; margin: 8px 0; }
.legal-section li { margin-bottom: 6px; }
.legal-section a { color: var(--indigo); text-decoration: underline; text-underline-offset: 2px; }

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.83rem;
  margin: 12px 0;
}

.legal-table th {
  text-align: left;
  padding: 8px 12px;
  background: rgba(79,70,229,0.04);
  border-bottom: 2px solid rgba(79,70,229,0.1);
  font-weight: 700;
  color: var(--navy);
}

.legal-table td {
  padding: 8px 12px;
  border-bottom: 1px solid rgba(79,70,229,0.06);
  color: var(--text-soft);
  line-height: 1.5;
}

.legal-cookie-btn {
  background: none;
  border: none;
  color: var(--indigo);
  text-decoration: underline;
  cursor: pointer;
  font-size: inherit;
  padding: 0;
}

address { font-style: normal; font-size: 0.9rem; color: var(--text-soft); line-height: 1.8; }

/* ── Sprint 7 Responsive ─────────────────────────────────── */
@media (max-width: 900px) {
  .pricing-grid        { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
  .pricing-faq-grid    { grid-template-columns: 1fr; }
  .legal-layout        { grid-template-columns: 1fr; }
  .legal-nav           { position: static; flex-direction: row; flex-wrap: wrap; }
}

@media (max-width: 600px) {
  .cookie-banner__inner   { flex-direction: column; align-items: flex-start; }
  .cookie-banner__actions { flex-wrap: wrap; }
  .pricing-table-wrap     { border-radius: 0; margin: 0 -20px; }
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 8 — DARK MODE · PROGRESS · BACK-TO-TOP · FLOAT CTA
               PRODUCT TOUR · CHANGELOG · 404 · TRANSITIONS
   ═════════════════════════════════════════════════════════════ */

/* ── 1. Dark Mode — comprehensive token + surface overrides ── */

/* Smooth transition ONLY when user explicitly toggles (JS adds this class) */
html.theme-transitioning,
html.theme-transitioning *,
html.theme-transitioning *::before,
html.theme-transitioning *::after {
  transition:
    background-color 320ms ease,
    border-color 320ms ease,
    color 320ms ease,
    box-shadow 320ms ease !important;
}

/* ── Dark theme CSS token overrides ── */
html[data-theme="dark"] {
  --bg:             #0f1117;
  --bg-soft:        rgba(20, 25, 40, 0.88);
  --surface:        rgba(22, 28, 45, 0.96);
  --surface-strong: #161d2e;
  --surface-dark:   #08090f;
  --line:           rgba(99, 120, 200, 0.14);
  --line-strong:    rgba(99, 120, 200, 0.24);
  --text:           #e8eaf6;
  --text-soft:      rgba(232, 234, 246, 0.72);
  --text-faint:     rgba(232, 234, 246, 0.42);
  --navy:           #e8eaf6;
  --shadow:         0 28px 80px rgba(0, 0, 0, 0.6);
  --shadow-soft:    0 16px 40px rgba(0, 0, 0, 0.4);
  color-scheme: dark;
}

/* Light theme should always use light color-scheme */
:root,
html[data-theme="light"] {
  color-scheme: light;
}

/* ── Dark: page & body background ── */
html[data-theme="dark"] body,
html[data-theme="dark"] .site-canvas {
  background-color: #0f1117;
}

/* ── Dark: all light glass/white card backgrounds ── */
html[data-theme="dark"] .hero__copy,
html[data-theme="dark"] .content-card,
html[data-theme="dark"] .article-card,
html[data-theme="dark"] .feature-card,
html[data-theme="dark"] .challenge-card,
html[data-theme="dark"] .module-card,
html[data-theme="dark"] .workflow-card,
html[data-theme="dark"] .contact-sidecard,
html[data-theme="dark"] .proof-strip,
html[data-theme="dark"] .cta-panel,
html[data-theme="dark"] .page-hero .site-shell,
html[data-theme="dark"] .coverage-card,
html[data-theme="dark"] .learning-card,
html[data-theme="dark"] .atlas-card,
html[data-theme="dark"] .service-card,
html[data-theme="dark"] .update-card,
html[data-theme="dark"] .metric-panel,
html[data-theme="dark"] .ins-article,
html[data-theme="dark"] .ins-newsletter,
html[data-theme="dark"] .pricing-quote blockquote {
  background: linear-gradient(180deg, rgba(22, 28, 45, 0.96), rgba(18, 23, 38, 0.92));
  border-color: rgba(99, 120, 200, 0.15);
}

/* ── Dark: pricing card ── */
html[data-theme="dark"] .pricing-card {
  background: rgba(22, 28, 45, 0.96);
  border-color: rgba(99, 120, 200, 0.15);
}

/* ── Dark: featured pricing card stays indigo ── */
html[data-theme="dark"] .pricing-card--indigo {
  background: linear-gradient(135deg, rgba(67, 56, 202, 0.9), rgba(109, 40, 217, 0.85));
  border-color: rgba(99, 102, 241, 0.3);
}

/* ── Dark: CTA panel ── */
html[data-theme="dark"] .cta-panel {
  background:
    radial-gradient(circle at top right, rgba(244, 63, 94, 0.08), transparent 20%),
    linear-gradient(135deg, rgba(79, 70, 229, 0.12), rgba(124, 58, 237, 0.08)),
    rgba(18, 23, 38, 0.95);
}

/* ── Dark: section bands ── */
html[data-theme="dark"] .section--contrast {
  background: rgba(16, 21, 35, 0.7);
}

html[data-theme="dark"] .section--strap {
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.06), rgba(124, 58, 237, 0.04));
  border-top-color:    rgba(99, 120, 200, 0.1);
  border-bottom-color: rgba(99, 120, 200, 0.1);
}

html[data-theme="dark"] .section--workflow {
  background: rgba(13, 17, 26, 0.5);
}

/* ── Dark: site header ── */
html[data-theme="dark"] .site-header {
  background: rgba(12, 15, 24, 0.94);
  border-bottom-color: rgba(99, 120, 200, 0.12);
}

html[data-theme="dark"] .site-header .site-header__inner {
  background: rgba(15, 19, 30, 0.94);
  border-color: rgba(99, 120, 200, 0.12);
}

/* ── Dark: announcement bar ── */
html[data-theme="dark"] .announce-bar {
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.15), rgba(124, 58, 237, 0.1));
  border-bottom-color: rgba(99, 120, 200, 0.12);
}

/* ── Dark: mega nav ── */
html[data-theme="dark"] .mega-nav__trigger,
html[data-theme="dark"] .mega-nav__link {
  color: var(--text-soft);
}

html[data-theme="dark"] .mega-nav__trigger:hover,
html[data-theme="dark"] .mega-nav__link:hover {
  color: #c7d2fe;
}

html[data-theme="dark"] .mega-panel {
  background: #0f1822;
  border-color: rgba(99, 120, 200, 0.12);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
}

html[data-theme="dark"] .mega-link:hover {
  background: rgba(79, 70, 229, 0.1);
}

html[data-theme="dark"] .mega-panel__promo {
  background: linear-gradient(160deg, rgba(79, 70, 229, 0.2), rgba(12, 17, 30, 0.8));
}

/* ── Dark: hero chips ── */
html[data-theme="dark"] .hero__chips li {
  background: rgba(79, 70, 229, 0.12);
  border-color: rgba(99, 120, 200, 0.2);
  color: var(--text-soft);
}

/* ── Dark: proof strip (text + gradient) ── */
html[data-theme="dark"] .proof-strip {
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.1), rgba(244, 63, 94, 0.06));
}

/* ── Dark: typography adjustments ── */
html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3,
html[data-theme="dark"] h4 {
  color: var(--navy); /* --navy is remapped to light text in dark mode */
}

html[data-theme="dark"] .metric-panel strong,
html[data-theme="dark"] .detail-list li strong,
html[data-theme="dark"] .entry-content strong {
  color: var(--text);
}

/* ── Dark: buttons ── */
html[data-theme="dark"] .button--ghost {
  background: rgba(79, 70, 229, 0.1);
  border-color: rgba(99, 102, 241, 0.35);
  color: #c7d2fe;
}

html[data-theme="dark"] .button--ghost:hover {
  background: rgba(79, 70, 229, 0.2);
}

html[data-theme="dark"] .button--secondary {
  background: rgba(22, 28, 45, 0.9);
  border-color: rgba(99, 120, 200, 0.25);
  color: var(--text);
}

/* ── Dark: pagination ── */
html[data-theme="dark"] .pagination .page-numbers {
  background: rgba(22, 28, 45, 0.8);
  border-color: rgba(99, 120, 200, 0.15);
  color: var(--text-soft);
}

/* ── Dark: form inputs ── */
html[data-theme="dark"] input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select {
  background: rgba(22, 28, 45, 0.9);
  border-color: rgba(99, 120, 200, 0.2);
  color: var(--text);
}

html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder {
  color: var(--text-faint);
}

/* ── Dark: tables ── */
html[data-theme="dark"] .pricing-table th,
html[data-theme="dark"] .pricing-table td {
  border-bottom-color: rgba(99, 120, 200, 0.07);
}

html[data-theme="dark"] .pricing-table th:first-child,
html[data-theme="dark"] .pricing-table td:first-child {
  background: rgba(22, 28, 45, 0.6);
}

html[data-theme="dark"] .pricing-table thead th {
  background: rgba(79, 70, 229, 0.08);
  border-bottom-color: rgba(99, 120, 200, 0.15);
}

html[data-theme="dark"] .pricing-table tbody tr:hover td {
  background: rgba(79, 70, 229, 0.04);
}

html[data-theme="dark"] .legal-table th {
  background: rgba(79, 70, 229, 0.06);
  border-bottom-color: rgba(99, 120, 200, 0.14);
}

html[data-theme="dark"] .legal-table td {
  border-bottom-color: rgba(99, 120, 200, 0.07);
  color: var(--text-soft);
}

/* ── Dark: cookie modal ── */
html[data-theme="dark"] .cookie-modal__box {
  background: #161d2e;
  border: 1px solid rgba(99, 120, 200, 0.15);
}

html[data-theme="dark"] .cookie-pref {
  border-color: rgba(99, 120, 200, 0.12);
}

/* ── Dark: legal nav ── */
html[data-theme="dark"] .legal-nav a:hover {
  background: rgba(79, 70, 229, 0.1);
}

/* ── Dark: legal section dividers ── */
html[data-theme="dark"] .legal-section {
  border-bottom-color: rgba(99, 120, 200, 0.08);
}

/* ── Dark: changelog ── */
html[data-theme="dark"] .cl-release {
  background: rgba(18, 23, 38, 0.9);
  border-color: rgba(99, 120, 200, 0.12);
}

html[data-theme="dark"] .cl-release__head {
  background: rgba(79, 70, 229, 0.04);
  border-bottom-color: rgba(99, 120, 200, 0.08);
}

html[data-theme="dark"] .cl-item {
  border-top-color: rgba(99, 120, 200, 0.05);
}

/* ── Dark: 404 cards ── */
html[data-theme="dark"] .e404-card {
  background: rgba(18, 23, 38, 0.9);
  border-color: rgba(99, 120, 200, 0.12);
}

html[data-theme="dark"] .e404-search input {
  background: rgba(22, 28, 45, 0.9);
  border-color: rgba(99, 120, 200, 0.2);
  color: var(--text);
}

/* ── Dark: tour shell ── */
html[data-theme="dark"] .tour-shell {
  background: rgba(18, 23, 38, 0.7);
  border-color: rgba(99, 120, 200, 0.14);
}

html[data-theme="dark"] .tour-tabs {
  background: rgba(12, 15, 25, 0.5);
  border-bottom-color: rgba(99, 120, 200, 0.1);
}

html[data-theme="dark"] .tour-tab--active {
  background: rgba(79, 70, 229, 0.1);
}

html[data-theme="dark"] .tour-panel__info {
  border-right-color: rgba(99, 120, 200, 0.08);
}

/* ── Dark: insights cards ── */
html[data-theme="dark"] .ins-article {
  background: rgba(18, 23, 38, 0.9);
  border-color: rgba(99, 120, 200, 0.12);
}

html[data-theme="dark"] .ins-newsletter {
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.15), rgba(124, 58, 237, 0.1));
  border-color: rgba(99, 120, 200, 0.18);
}

/* ── Dark: footer v2 ── */
html[data-theme="dark"] .site-footer-v2 {
  background: #05070e;
}

/* ── Dark: back to top ── */
html[data-theme="dark"] .back-to-top {
  background: rgba(22, 28, 45, 0.96);
  border-color: rgba(79, 70, 229, 0.3);
  color: #a5b4fc;
}

/* ── Theme toggle button ─────────────────────────────────── */
.theme-toggle {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--text-soft);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 200ms ease, color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
  flex-shrink: 0;
}

.theme-toggle:hover {
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
  transform: rotate(20deg);
}

.theme-toggle__sun  { display: block; }
.theme-toggle__moon { display: none; }

html[data-theme="dark"] .theme-toggle__sun  { display: none; }
html[data-theme="dark"] .theme-toggle__moon { display: block; }

/* ── 2. Reading progress bar ─────────────────────────────── */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, var(--indigo), var(--violet));
  z-index: 9999;
  transition: width 80ms linear;
  border-radius: 0 2px 2px 0;
}

/* ── 3. Back to top ──────────────────────────────────────── */
.back-to-top {
  position: fixed;
  bottom: 28px;
  right: 28px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(79,70,229,0.2);
  background: rgba(255,255,255,0.9);
  color: var(--indigo);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 24px rgba(79,70,229,0.15);
  backdrop-filter: blur(8px);
  z-index: 8800;
  transition: transform 200ms cubic-bezier(0.34,1.4,0.64,1), box-shadow 200ms ease, opacity 200ms ease;
  animation: bttIn 300ms cubic-bezier(0.34,1.4,0.64,1);
}

@keyframes bttIn {
  from { opacity: 0; transform: translateY(16px) scale(0.8); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.back-to-top:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 32px rgba(79,70,229,0.25);
}

html[data-theme="dark"] .back-to-top {
  background: rgba(22,27,46,0.95);
  color: var(--indigo);
  border-color: rgba(79,70,229,0.3);
}

/* ── 4. Floating demo CTA ────────────────────────────────── */
.float-cta {
  position: fixed;
  bottom: 84px;
  right: 24px;
  z-index: 8700;
  display: flex;
  align-items: center;
  gap: 0;
  background: #4f46e5 !important;
  border-radius: 999px;
  box-shadow: 0 12px 32px rgba(79,70,229,0.5), 0 4px 16px rgba(0,0,0,0.3);
  animation: floatIn 400ms cubic-bezier(0.34,1.3,0.64,1);
  /* Ensure nothing from page colour scheme bleeds through */
  color-scheme: dark;
}

@keyframes floatIn {
  from { opacity: 0; transform: translateY(20px) scale(0.9); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.float-cta__btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px 10px 14px;
  color: #ffffff !important;
  text-decoration: none;
  font-size: 0.84rem;
  font-weight: 700;
  border-radius: 999px 0 0 999px;
  transition: background 150ms ease;
}

.float-cta__btn:hover { background: rgba(255,255,255,0.12); }

.float-cta__close {
  width: 34px;
  height: 34px;
  border: none;
  background: none;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 4px;
  border-radius: 0 999px 999px 0;
  transition: color 150ms ease;
}

.float-cta__close:hover { color: #fff; }

/* ── 5. View Transitions ─────────────────────────────────── */
@keyframes vtFadeIn  { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
@keyframes vtFadeOut { from { opacity: 1; transform: none; } to { opacity: 0; transform: translateY(-4px); } }

::view-transition-old(root) { animation: vtFadeOut 200ms ease forwards; }
::view-transition-new(root) { animation: vtFadeIn  220ms ease forwards; }

/* ── 6. Product Tour ─────────────────────────────────────── */
.tour-shell {
  margin-top: 40px;
  border: 1px solid rgba(79,70,229,0.12);
  border-radius: var(--radius);
  overflow: hidden;
  background: rgba(255,255,255,0.5);
  backdrop-filter: blur(12px);
}

html[data-theme="dark"] .tour-shell {
  background: rgba(22,27,46,0.6);
  border-color: rgba(130,140,200,0.15);
}

.tour-tabs {
  display: flex;
  border-bottom: 1px solid rgba(79,70,229,0.1);
  background: rgba(79,70,229,0.03);
  overflow-x: auto;
  scrollbar-width: none;
}

.tour-tabs::-webkit-scrollbar { display: none; }

.tour-tab {
  padding: 14px 22px;
  border: none;
  background: none;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-soft);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  position: relative;
  transition: color 150ms ease;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}

.tour-tab:hover { color: var(--indigo); }

.tour-tab--active {
  color: var(--indigo);
  border-bottom-color: var(--indigo);
  background: rgba(79,70,229,0.06);
}

.tour-tab__icon { font-size: 1rem; }

.tour-panel { padding: 0; }

.tour-panel__layout {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 0;
  min-height: 400px;
}

.tour-panel__info {
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: center;
  border-right: 1px solid rgba(79,70,229,0.08);
}

.tour-panel__info h3 {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0;
  letter-spacing: -0.02em;
}

.tour-panel__info p {
  font-size: 0.9rem;
  line-height: 1.65;
  color: var(--text-soft);
  margin: 0;
}

.tour-panel__stats {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.tour-panel__stats li {
  font-size: 0.85rem;
  color: var(--text-soft);
  display: flex;
  align-items: center;
  gap: 8px;
}

.tour-panel__stats li::before {
  content: '→';
  color: var(--indigo);
  font-size: 0.8rem;
}

.tour-panel__stats strong {
  color: var(--navy);
}

.tour-panel__terminal {
  background: #0d1117;
}

/* Dark terminal */
.tour-terminal {
  height: 100%;
  display: flex;
  flex-direction: column;
  background: #0d1117;
  min-height: 380px;
}

.tour-terminal__bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: #161b2e;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}

.tour-terminal__bar span:not(.tour-terminal__title) {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
}

.tour-terminal__bar span:nth-child(1) { background: #ff5f57; }
.tour-terminal__bar span:nth-child(2) { background: #febc2e; }
.tour-terminal__bar span:nth-child(3) { background: #28c840; }

.tour-terminal__title {
  font-size: 0.75rem;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  color: rgba(255,255,255,0.5);
  margin-left: 8px;
}

.tour-terminal__body {
  flex: 1;
  overflow: auto;
  padding: 20px;
}

.tour-code {
  margin: 0;
  font-family: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;
  font-size: 0.8rem;
  line-height: 1.7;
  white-space: pre;
  color: #e2e8f7;
}

/* Syntax highlight tokens */
.tc-key     { color: #79c0ff; }
.tc-str     { color: #a5d6ff; }
.tc-num     { color: #ff9e64; }
.tc-comment { color: rgba(130,170,255,0.45); font-style: italic; }

/* ── 7. Changelog styles ─────────────────────────────────── */
.cl-layout {
  display: grid;
  grid-template-columns: 180px minmax(0,1fr);
  gap: 48px;
  align-items: start;
}

.cl-nav a {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 10px;
}

.cl-nav__version {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--navy);
  font-family: 'JetBrains Mono', monospace;
}

.cl-nav__date {
  font-size: 0.72rem;
  color: var(--text-faint);
}

.cl-releases {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.cl-release {
  border-radius: var(--radius);
  border: 1px solid rgba(79,70,229,0.1);
  background: rgba(255,255,255,0.8);
  overflow: hidden;
}

html[data-theme="dark"] .cl-release {
  background: rgba(22,27,46,0.8);
}

.cl-release__head {
  padding: 24px 28px;
  border-bottom: 1px solid rgba(79,70,229,0.08);
  background: rgba(79,70,229,0.02);
}

.cl-release__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.cl-version {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1rem;
  font-weight: 800;
  color: var(--indigo);
}

.cl-date {
  font-size: 0.8rem;
  color: var(--text-faint);
}

.cl-type-badge {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 999px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.cl-major { background: rgba(244,63,94,0.1);   color: #be185d; }
.cl-minor { background: rgba(79,70,229,0.1);    color: var(--indigo); }
.cl-patch { background: rgba(15,118,110,0.1);   color: var(--teal); }

.cl-release__title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0;
  letter-spacing: -0.02em;
}

.cl-highlight {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  font-weight: 600;
  color: #059669;
  background: rgba(16,185,129,0.08);
  border-radius: 999px;
  padding: 3px 10px;
  margin-top: 10px;
}

.cl-items {
  list-style: none;
  padding: 0;
  margin: 0;
}

.cl-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 28px;
  border-top: 1px solid rgba(79,70,229,0.05);
  font-size: 0.87rem;
  line-height: 1.6;
  color: var(--text-soft);
}

.cl-item__badge {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 900;
  margin-top: 1px;
}

.cl-item--new    .cl-item__badge { background: rgba(79,70,229,0.1); color: var(--indigo); }
.cl-item--impr   .cl-item__badge { background: rgba(16,185,129,0.1); color: #059669; }
.cl-item--fix    .cl-item__badge { background: rgba(15,118,110,0.1); color: var(--teal); }
.cl-item--perf   .cl-item__badge { background: rgba(245,158,11,0.1); color: #d97706; }
.cl-item--deprec .cl-item__badge { background: rgba(244,63,94,0.1); color: #be185d; }
.cl-item--deprec { opacity: 0.7; }

/* Legend badges */
.cl-legend {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.cl-badge {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.cl-badge.cl-item--new    { background: rgba(79,70,229,0.1); color: var(--indigo); }
.cl-badge.cl-item--impr   { background: rgba(16,185,129,0.1); color: #059669; }
.cl-badge.cl-item--fix    { background: rgba(15,118,110,0.1); color: var(--teal); }
.cl-badge.cl-item--perf   { background: rgba(245,158,11,0.1); color: #d97706; }
.cl-badge.cl-item--deprec { background: rgba(244,63,94,0.1); color: #be185d; }

/* ── 8. 404 page ─────────────────────────────────────────── */
.e404-code {
  font-size: clamp(5rem,18vw,12rem);
  font-weight: 900;
  letter-spacing: -0.05em;
  line-height: 1;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0.18;
  margin-bottom: -20px;
  user-select: none;
}

.e404-search {
  display: flex;
  gap: 10px;
  max-width: 480px;
  margin-top: 20px;
}

.e404-search input {
  flex: 1;
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line-strong);
  background: var(--surface);
  font-size: 0.9rem;
  color: var(--text);
  outline-offset: 2px;
}

.e404-search input:focus {
  outline: 2px solid var(--indigo);
  border-color: transparent;
}

.e404-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.e404-card {
  border: 1px solid rgba(79,70,229,0.1);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.8);
  padding: 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-decoration: none;
  transition: transform 150ms ease, box-shadow 150ms ease, border-color 150ms ease;
}

html[data-theme="dark"] .e404-card {
  background: rgba(22,27,46,0.8);
}

.e404-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(79,70,229,0.1);
  border-color: rgba(79,70,229,0.25);
}

.e404-card__icon { font-size: 1.5rem; }

.e404-card strong {
  font-size: 0.9rem;
  color: var(--navy);
}

.e404-card span {
  font-size: 0.78rem;
  color: var(--text-faint);
}

/* ── Sprint 8 Responsive ─────────────────────────────────── */
@media (max-width: 1000px) {
  .tour-panel__layout  { grid-template-columns: 1fr; }
  .tour-panel__info    { border-right: none; border-bottom: 1px solid rgba(79,70,229,0.08); }
  .tour-terminal       { min-height: 260px; }
  .cl-layout           { grid-template-columns: 1fr; }
  .e404-grid           { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 600px) {
  .float-cta           { bottom: 72px; right: 14px; }
  .back-to-top         { bottom: 22px; right: 14px; }
  .e404-grid           { grid-template-columns: 1fr; }
  .tour-tabs           { flex-wrap: nowrap; }
  .e404-search         { flex-direction: column; }
}

/* ── prefers-reduced-motion: Sprint 8 additions ──────────── */
@media (prefers-reduced-motion: reduce) {
  .back-to-top,
  .float-cta,
  .cookie-banner,
  .reading-progress,
  ::view-transition-old(root),
  ::view-transition-new(root) {
    animation: none !important;
    transition-duration: 0.01ms !important;
  }
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 9 — CMD PALETTE · TOASTS · GRAIN · SPOTLIGHT
   ═════════════════════════════════════════════════════════════ */

/* ── Film grain texture ──────────────────────────────────── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 160px 160px;
}

html[data-theme="dark"] body::before {
  opacity: 0.055;
}

/* ── Cursor spotlight ────────────────────────────────────── */
html.cursor-spotlight-active body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9997;
  pointer-events: none;
  background: radial-gradient(
    600px circle at var(--cursor-x, -400px) var(--cursor-y, -400px),
    rgba(79, 70, 229, 0.055),
    transparent 60%
  );
}

html[data-theme="dark"].cursor-spotlight-active body::after {
  background: radial-gradient(
    500px circle at var(--cursor-x, -400px) var(--cursor-y, -400px),
    rgba(99, 102, 241, 0.09),
    transparent 60%
  );
}

/* ── ⌘K header trigger ───────────────────────────────────── */
.cmd-trigger {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--text-soft);
  font-size: 0.8rem;
  cursor: pointer;
  transition: background 150ms ease, border-color 150ms ease, color 150ms ease;
  white-space: nowrap;
}

.cmd-trigger:hover {
  background: rgba(79,70,229,0.06);
  border-color: rgba(79,70,229,0.25);
  color: var(--indigo);
}

.cmd-trigger__label { font-weight: 500; }

.cmd-trigger__kbd {
  font-size: 0.68rem;
  padding: 2px 6px;
  border-radius: 5px;
  background: rgba(79,70,229,0.08);
  color: var(--text-faint);
  font-family: inherit;
  border: 1px solid var(--line);
}

@media (max-width: 900px) {
  .cmd-trigger__label,
  .cmd-trigger__kbd { display: none; }
  .cmd-trigger { padding: 7px 9px; }
}

/* ── Command Palette overlay ─────────────────────────────── */
.cmd-palette { position: fixed; inset: 0; z-index: 10000; }

.cmd-overlay {
  position: absolute;
  inset: 0;
  background: rgba(10, 12, 25, 0.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  animation: cmdFadeIn 180ms ease;
}

@keyframes cmdFadeIn { from { opacity: 0; } to { opacity: 1; } }

.cmd-box {
  position: absolute;
  top: 15%;
  left: 50%;
  transform: translateX(-50%);
  width: min(620px, calc(100vw - 32px));
  background: rgba(255, 255, 255, 0.97);
  border-radius: var(--radius);
  box-shadow: 0 48px 120px rgba(0, 0, 0, 0.28), 0 0 0 1px rgba(79,70,229,0.12);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: cmdSlideIn 220ms cubic-bezier(0.22, 1.2, 0.36, 1);
}

html[data-theme="dark"] .cmd-box {
  background: rgba(14, 18, 32, 0.98);
  box-shadow: 0 48px 120px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(99,120,200,0.15);
}

@keyframes cmdSlideIn {
  from { opacity: 0; transform: translateX(-50%) translateY(-12px) scale(0.97); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}

.cmd-search-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
}

html[data-theme="dark"] .cmd-search-row {
  border-bottom-color: rgba(99,120,200,0.12);
}

.cmd-icon { color: var(--text-faint); flex-shrink: 0; }

.cmd-input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: 1rem;
  color: var(--text);
  outline: none;
  font-family: inherit;
}

.cmd-input::placeholder { color: var(--text-faint); }

html[data-theme="dark"] .cmd-input { color: var(--text); }

.cmd-esc-badge {
  font-size: 0.68rem;
  padding: 3px 7px;
  border-radius: 6px;
  background: var(--bg);
  border: 1px solid var(--line);
  color: var(--text-faint);
  font-family: inherit;
  flex-shrink: 0;
}

.cmd-results {
  max-height: 380px;
  overflow-y: auto;
  padding: 6px;
  scrollbar-width: thin;
  scrollbar-color: rgba(79,70,229,0.2) transparent;
}

.cmd-group-label {
  padding: 6px 14px 4px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.cmd-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: background 100ms ease;
}

.cmd-item--active,
.cmd-item:hover {
  background: rgba(79,70,229,0.07);
}

html[data-theme="dark"] .cmd-item--active,
html[data-theme="dark"] .cmd-item:hover {
  background: rgba(79,70,229,0.12);
}

.cmd-item__icon { font-size: 1rem; flex-shrink: 0; width: 24px; text-align: center; }

.cmd-item__copy {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}

.cmd-item__label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--navy);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cmd-item__hint {
  font-size: 0.75rem;
  color: var(--text-faint);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cmd-item__arrow { color: var(--text-faint); flex-shrink: 0; opacity: 0; transition: opacity 100ms ease; }
.cmd-item--active .cmd-item__arrow { opacity: 1; color: var(--indigo); }

.cmd-empty {
  padding: 24px;
  text-align: center;
  font-size: 0.9rem;
  color: var(--text-faint);
}

.cmd-footer {
  padding: 10px 20px;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 20px;
  font-size: 0.72rem;
  color: var(--text-faint);
}

html[data-theme="dark"] .cmd-footer {
  border-top-color: rgba(99,120,200,0.1);
}

.cmd-footer kbd {
  display: inline-block;
  padding: 1px 5px;
  border-radius: 4px;
  background: var(--bg);
  border: 1px solid var(--line);
  font-family: inherit;
  margin-right: 3px;
}

/* Prevent body scroll when palette open */
body.cmd-open { overflow: hidden; }

/* ── Social Proof Toasts ─────────────────────────────────── */
.sp-toast-container {
  position: fixed;
  bottom: 24px;
  left: 24px;
  z-index: 8500;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}

.sp-toast {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.97);
  border: 1px solid rgba(79,70,229,0.1);
  box-shadow: 0 12px 36px rgba(0,0,0,0.12), 0 2px 8px rgba(79,70,229,0.08);
  pointer-events: all;
  max-width: 300px;
  opacity: 0;
  transform: translateY(16px) scale(0.96);
  transition: opacity 350ms ease, transform 350ms cubic-bezier(0.34,1.3,0.64,1);
  backdrop-filter: blur(8px);
}

html[data-theme="dark"] .sp-toast {
  background: rgba(18, 23, 38, 0.97);
  border-color: rgba(99,120,200,0.15);
}

.sp-toast--visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.sp-toast__avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 800;
  flex-shrink: 0;
  letter-spacing: -0.02em;
}

.sp-toast__body {
  flex: 1;
  font-size: 0.8rem;
  line-height: 1.4;
  color: var(--text-soft);
  min-width: 0;
}

.sp-toast__body strong { color: var(--navy); }

.sp-toast__body span {
  display: block;
  color: var(--text-faint);
  font-size: 0.72rem;
  margin-top: 1px;
}

.sp-toast__close {
  background: none;
  border: none;
  color: var(--text-faint);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 2px 4px;
  line-height: 1;
  flex-shrink: 0;
  border-radius: 4px;
  transition: color 100ms ease, background 100ms ease;
}

.sp-toast__close:hover {
  color: var(--navy);
  background: rgba(79,70,229,0.06);
}

@media (max-width: 600px) {
  .sp-toast-container { left: 12px; right: 12px; bottom: 80px; }
  .sp-toast { max-width: 100%; }
  .cmd-box { top: 5%; }
}

/* ── Sprint 9 reduced motion ─────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  body::before,
  body::after,
  html.cursor-spotlight-active body::after { display: none; }
  .sp-toast { transition-duration: 0.01ms !important; }
  .cmd-box  { animation: none !important; }
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 10 — INTEGRATIONS · COMPARE TABLE · ROI CALCULATOR
   ═════════════════════════════════════════════════════════════ */

/* ── Integration logo strip ──────────────────────────────── */
.integrations-strip__label {
  text-align: center;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 16px;
}

.integrations-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  align-items: center;
}

.integrations-strip__item {
  padding: 7px 16px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(79,70,229,0.04);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-soft);
  transition: border-color 150ms ease, background 150ms ease, color 150ms ease;
  white-space: nowrap;
}

.integrations-strip__item:hover {
  border-color: rgba(79,70,229,0.2);
  background: rgba(79,70,229,0.07);
  color: var(--navy);
}

html[data-theme="dark"] .integrations-strip__item {
  background: rgba(99,120,200,0.05);
  border-color: rgba(99,120,200,0.12);
}

/* ── Competitor comparison table ─────────────────────────── */
.compare-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.compare-table th,
.compare-table td {
  padding: 14px 20px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

.compare-table thead th {
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  background: rgba(79,70,229,0.04);
  color: var(--navy);
}

html[data-theme="dark"] .compare-table thead th {
  background: rgba(79,70,229,0.07);
}

.compare-table tbody tr:last-child td { border-bottom: none; }

.compare-table tbody tr:hover td {
  background: rgba(79,70,229,0.025);
}

.compare-table__col--grey {
  background: rgba(130,140,200,0.03);
  color: var(--text-soft);
  text-align: center;
}

.compare-table__col--hero {
  background: rgba(79,70,229,0.04);
  font-weight: 700;
  text-align: center;
  color: var(--indigo);
  border-left: 2px solid rgba(79,70,229,0.15);
}

html[data-theme="dark"] .compare-table__col--hero {
  background: rgba(79,70,229,0.08);
}

.compare-check {
  color: #059669;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.compare-check::before { content: '✓ '; }

.compare-x {
  color: var(--text-faint);
  font-style: italic;
}

.compare-x::before { content: '✗ '; color: #ef4444; font-style: normal; }

.compare-partial { color: #d97706; font-weight: 600; }
.compare-partial::before { content: '~ '; }

.compare-table__footnote {
  font-size: 0.74rem;
  color: var(--text-faint);
  padding: 10px 20px;
  border-top: 1px solid var(--line);
}

html[data-theme="dark"] .compare-table { background: rgba(18,23,38,0.6); }

/* ── ROI Calculator ──────────────────────────────────────── */
.roi-layout {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 32px;
  align-items: start;
}

.roi-inputs {
  background: rgba(255,255,255,0.85);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 32px;
  box-shadow: var(--shadow-soft);
  position: sticky;
  top: 108px;
}

html[data-theme="dark"] .roi-inputs {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.roi-inputs__title {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 24px;
}

.roi-field { margin-bottom: 24px; }

.roi-field__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.roi-field__header label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-soft);
}

.roi-field__val {
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--indigo);
  font-family: 'IBM Plex Mono', monospace;
}

.roi-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--indigo), var(--violet));
  outline: none;
  cursor: pointer;
  margin: 0;
}

.roi-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: white;
  border: 2px solid var(--indigo);
  box-shadow: 0 2px 8px rgba(79,70,229,0.3);
  cursor: pointer;
  transition: box-shadow 150ms ease, transform 150ms ease;
}

.roi-slider::-webkit-slider-thumb:hover {
  box-shadow: 0 4px 16px rgba(79,70,229,0.4);
  transform: scale(1.15);
}

html[data-theme="dark"] .roi-slider::-webkit-slider-thumb { background: #1a1f35; }

.roi-field__hints {
  display: flex;
  justify-content: space-between;
  font-size: 0.7rem;
  color: var(--text-faint);
  margin-top: 4px;
}

.roi-assumptions {
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  background: rgba(79,70,229,0.05);
  border: 1px solid rgba(79,70,229,0.1);
  font-size: 0.8rem;
  color: var(--text-soft);
  line-height: 1.5;
}

/* Results panel */
.roi-results {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.roi-results__header {
  background: linear-gradient(135deg, rgba(79,70,229,0.08), rgba(124,58,237,0.05));
  border: 1px solid rgba(79,70,229,0.12);
  border-radius: var(--radius);
  padding: 28px 32px;
  text-align: center;
}

.roi-total {
  font-size: clamp(2.4rem, 5vw, 3.5rem);
  font-weight: 900;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.04em;
  line-height: 1.1;
  margin: 8px 0 4px;
  font-family: var(--font-heading);
  transition: all 200ms ease;
}

.roi-results__sub { font-size: 0.85rem; color: var(--text-faint); margin: 0; }

.roi-breakdown {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.roi-item {
  padding: 16px 18px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
}

.roi-item--indigo { background: rgba(79,70,229,0.06);  border-color: rgba(79,70,229,0.12); }
.roi-item--teal   { background: rgba(20,184,166,0.06); border-color: rgba(20,184,166,0.12); }
.roi-item--violet { background: rgba(124,58,237,0.06); border-color: rgba(124,58,237,0.12); }
.roi-item--rose   { background: rgba(244,63,94,0.06);  border-color: rgba(244,63,94,0.12); }

.roi-item__label { font-size: 0.75rem; font-weight: 600; color: var(--text-faint); margin-bottom: 4px; }
.roi-item__value { font-size: 1rem; font-weight: 800; color: var(--navy); font-family: 'IBM Plex Mono', monospace; }
.roi-item__sub   { font-size: 0.72rem; color: var(--text-faint); margin-top: 2px; }

.roi-payback {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px;
  background: rgba(255,255,255,0.85);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 20px;
  text-align: center;
}

html[data-theme="dark"] .roi-payback {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.12);
}

.roi-payback__num {
  display: block;
  font-size: 1.4rem;
  font-weight: 900;
  color: var(--indigo);
  font-family: 'IBM Plex Mono', monospace;
  letter-spacing: -0.03em;
}

.roi-payback__label {
  font-size: 0.72rem;
  color: var(--text-faint);
  font-weight: 600;
  display: block;
  margin-top: 2px;
}

.roi-cta-block { display: flex; flex-wrap: wrap; gap: 12px; }

.roi-disclaimer {
  font-size: 0.72rem;
  color: var(--text-faint);
  line-height: 1.5;
  margin: 0;
}

/* Proof cards */
.roi-proof-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
}

.roi-proof-card {
  padding: 24px 20px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.8);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
  text-align: center;
  transition: transform 150ms ease, box-shadow 150ms ease;
}

html[data-theme="dark"] .roi-proof-card {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.12);
}

.roi-proof-card:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(79,70,229,0.1); }

.roi-proof-card__stat {
  font-size: 2rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.04em;
}

.roi-proof-card__label { font-size: 0.82rem; font-weight: 600; color: var(--navy); margin: 4px 0 2px; }
.roi-proof-card__who   { font-size: 0.72rem; color: var(--text-faint); }

/* ── Sprint 10 responsive ────────────────────────────────── */
@media (max-width: 1000px) {
  .roi-layout       { grid-template-columns: 1fr; }
  .roi-inputs       { position: static; }
  .roi-breakdown    { grid-template-columns: 1fr; }
  .roi-proof-grid   { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 700px) {
  .compare-table th,
  .compare-table td { padding: 10px 12px; font-size: 0.78rem; }
  .roi-payback      { grid-template-columns: repeat(2,1fr); }
  .roi-proof-grid   { grid-template-columns: 1fr; }
}

/* ═════════════════════════════════════════════════════════════
   SPRINT 11 — GLOSSARY · FOR-ROLE PAGES
   ═════════════════════════════════════════════════════════════ */

/* ── Glossary search bar ─────────────────────────────────── */
.glossary-search-row {
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: 520px;
  margin: 28px auto 0;
  background: rgba(255,255,255,0.9);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px 16px;
  box-shadow: 0 4px 24px rgba(79,70,229,0.08);
}

html[data-theme="dark"] .glossary-search-row {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.glossary-search-row svg { color: var(--text-faint); flex-shrink: 0; }

#glossary-search {
  border: none;
  outline: none;
  background: transparent;
  font-size: 0.92rem;
  color: var(--text);
  width: 100%;
  font-family: var(--font-body);
}

#glossary-search::placeholder { color: var(--text-faint); }

/* ── A-Z nav ─────────────────────────────────────────────── */
.glossary-alpha-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}

.glossary-alpha-nav__link {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text-soft);
  text-decoration: none;
  border: 1px solid var(--line);
  transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
}

.glossary-alpha-nav__link:hover {
  background: rgba(79,70,229,0.07);
  color: var(--indigo);
  border-color: rgba(79,70,229,0.2);
}

/* ── Glossary grid ───────────────────────────────────────── */
.glossary-grid {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.glossary-letter-group { display: flex; flex-direction: column; gap: 16px; }

.glossary-letter-heading {
  font-size: 2.5rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.05em;
  line-height: 1;
  font-family: var(--font-heading);
}

.glossary-term {
  padding: 20px 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.85);
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

html[data-theme="dark"] .glossary-term {
  background: rgba(18,23,38,0.8);
  border-color: rgba(99,120,200,0.1);
}

.glossary-term:hover {
  border-color: rgba(79,70,229,0.2);
  box-shadow: 0 4px 20px rgba(79,70,229,0.06);
}

.glossary-term__name {
  font-size: 1rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 8px;
}

.glossary-term__def {
  font-size: 0.88rem;
  line-height: 1.65;
  color: var(--text-soft);
  margin: 0;
}

.glossary-no-results {
  text-align: center;
  color: var(--text-faint);
  padding: 40px 0;
  font-size: 0.9rem;
}

/* ── Glossary related links grid ─────────────────────────── */
.glossary-links-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
}

.glossary-link-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 20px 18px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.85);
  text-decoration: none;
  transition: transform 150ms ease, box-shadow 150ms ease, border-color 150ms ease;
}

html[data-theme="dark"] .glossary-link-card {
  background: rgba(18,23,38,0.85);
  border-color: rgba(99,120,200,0.1);
}

.glossary-link-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(79,70,229,0.1);
  border-color: rgba(79,70,229,0.2);
}

.glossary-link-card__icon { font-size: 1.4rem; }

.glossary-link-card strong {
  font-size: 0.9rem;
  color: var(--navy);
  font-weight: 700;
}

.glossary-link-card span {
  font-size: 0.78rem;
  color: var(--text-faint);
  line-height: 1.45;
}

/* ── For-Role page: pain/solution grid ───────────────────── */
.for-pains-grid {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.for-pain-card {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 20px;
  align-items: center;
  padding: 24px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.85);
}

html[data-theme="dark"] .for-pain-card {
  background: rgba(18,23,38,0.85);
  border-color: rgba(99,120,200,0.1);
}

.for-pain-card__problem {
  padding: 16px;
  border-radius: var(--radius-sm);
  background: rgba(239,68,68,0.04);
  border: 1px solid rgba(239,68,68,0.1);
}

.for-pain-card__solution {
  padding: 16px;
  border-radius: var(--radius-sm);
  background: rgba(5,150,105,0.04);
  border: 1px solid rgba(5,150,105,0.12);
}

.for-pain-card__tag {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(239,68,68,0.1);
  color: #dc2626;
  margin-bottom: 8px;
}

.for-pain-card__tag--solved {
  background: rgba(5,150,105,0.1);
  color: #059669;
}

.for-pain-card__problem p,
.for-pain-card__solution p {
  font-size: 0.86rem;
  line-height: 1.6;
  color: var(--text-soft);
  margin: 0;
}

.for-pain-card__arrow {
  color: var(--indigo);
  width: 32px;
  display: flex;
  justify-content: center;
}

/* ── For-Role capability table ───────────────────────────── */
.for-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.for-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.for-table th,
.for-table td {
  padding: 14px 20px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}

.for-table thead th {
  font-size: 0.82rem;
  font-weight: 800;
  background: rgba(79,70,229,0.04);
  color: var(--navy);
}

.for-table__answer {
  color: var(--text-soft);
  font-size: 0.85rem;
}

.for-table tbody tr:last-child td { border-bottom: none; }

html[data-theme="dark"] .for-table { background: rgba(18,23,38,0.7); }

/* ── For-Role testimonial ────────────────────────────────── */
.for-testimonial {
  max-width: 760px;
  margin: 0 auto;
  padding: 36px 40px;
  border-left: 3px solid var(--indigo);
  background: rgba(79,70,229,0.04);
  border-radius: 0 var(--radius) var(--radius) 0;
}

.for-testimonial p {
  font-size: 1.1rem;
  line-height: 1.65;
  font-style: italic;
  color: var(--navy);
  margin: 0 0 16px;
}

.for-testimonial footer {
  font-size: 0.82rem;
  color: var(--text-faint);
  font-weight: 600;
}

/* ── Sprint 11 responsive ────────────────────────────────── */
@media (max-width: 1000px) {
  .glossary-links-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 700px) {
  .for-pain-card {
    grid-template-columns: 1fr;
  }
  .for-pain-card__arrow { transform: rotate(90deg); }
  .glossary-links-grid { grid-template-columns: 1fr; }
  .glossary-alpha-nav__link { width: 30px; height: 30px; font-size: 0.72rem; }
}

/* ═════════════════════════════════════════════════════════════
   SINGLE.PHP — PREMIUM ARTICLE TEMPLATE
   ═════════════════════════════════════════════════════════════ */

/* ── Reading progress bar ────────────────────────────────── */
.art-progress-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  z-index: 9999;
  background: transparent;
}
.art-progress-bar__fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--indigo), var(--violet));
  transition: width 80ms linear;
}

/* ── Article Hero ────────────────────────────────────────── */
.art-hero { padding-top: 80px; }

.art-breadcrumb {
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: 0.78rem;
  color: var(--text-faint);
  margin-bottom: 24px;
}
.art-breadcrumb a { color: var(--text-faint); text-decoration: none; }
.art-breadcrumb a:hover { color: var(--indigo); }

.art-hero__tag-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.art-tag {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
}

.art-meta {
  font-size: 0.8rem;
  color: var(--text-faint);
}

.art-hero__title {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--navy);
  max-width: 800px;
  margin: 0 0 20px;
}

.art-hero__lede {
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--text-soft);
  max-width: 700px;
  margin: 0 0 28px;
}

.art-hero__byline {
  display: flex;
  align-items: center;
  gap: 12px;
}

.art-hero__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
}

.art-hero__byline strong {
  display: block;
  font-size: 0.85rem;
  color: var(--navy);
}

.art-hero__byline span {
  font-size: 0.75rem;
  color: var(--text-faint);
}

/* ── Article body layout ─────────────────────────────────── */
.art-body-wrap {
  padding: 56px 0 80px;
}

.art-body-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 56px;
  align-items: start;
}

/* ── Sidebar ─────────────────────────────────────────────── */
.art-sidebar {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.art-toc {
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.85);
}

html[data-theme="dark"] .art-toc {
  background: rgba(18,23,38,0.85);
  border-color: rgba(99,120,200,0.1);
}

.art-toc__heading {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin: 0 0 12px;
}

.art-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.art-toc__item a {
  display: block;
  font-size: 0.78rem;
  line-height: 1.4;
  padding: 4px 8px;
  border-radius: 6px;
  color: var(--text-soft);
  text-decoration: none;
  transition: background 120ms ease, color 120ms ease;
}

.art-toc__item a:hover,
.art-toc__item a.is-active {
  background: rgba(79,70,229,0.06);
  color: var(--indigo);
}

.art-toc__item--sub a {
  padding-left: 20px;
  font-size: 0.73rem;
  color: var(--text-faint);
}

/* Sidebar CTA card */
.art-sidebar-cta {
  padding: 20px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: linear-gradient(135deg, rgba(79,70,229,0.04), rgba(124,58,237,0.04));
}

html[data-theme="dark"] .art-sidebar-cta {
  background: rgba(18,23,38,0.85);
  border-color: rgba(79,70,229,0.15);
}

.art-sidebar-cta .eyebrow { font-size: 0.65rem; margin-bottom: 6px; }
.art-sidebar-cta p { font-size: 0.82rem; color: var(--text-soft); margin: 0 0 14px; line-height: 1.5; }
.art-sidebar-cta .button { width: 100%; text-align: center; margin-bottom: 8px; font-size: 0.82rem; padding: 10px 16px; }
.art-sidebar-cta__link { display: block; font-size: 0.75rem; text-align: center; color: var(--text-faint); text-decoration: none; }
.art-sidebar-cta__link:hover { color: var(--indigo); }

/* ── Article content typography ──────────────────────────── */
.art-content {
  min-width: 0;
  font-size: 1rem;
  line-height: 1.75;
  color: var(--text-soft);
}

.art-content .art-lede {
  font-size: 1.08rem;
  line-height: 1.7;
  color: var(--text);
  font-weight: 500;
  margin-bottom: 32px;
}

.art-content h2 {
  font-size: 1.45rem;
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.02em;
  margin: 48px 0 16px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}

.art-content h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 32px 0 12px;
}

.art-content p { margin: 0 0 20px; }

.art-content ul,
.art-content ol {
  padding-left: 24px;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.art-content li { line-height: 1.65; }

.art-content strong { color: var(--navy); font-weight: 700; }

.art-content a {
  color: var(--indigo);
  text-decoration: underline;
  text-decoration-color: rgba(79,70,229,0.3);
  text-underline-offset: 2px;
}
.art-content a:hover { text-decoration-color: var(--indigo); }

.art-content blockquote {
  margin: 32px 0;
  padding: 20px 24px;
  border-left: 3px solid var(--indigo);
  background: rgba(79,70,229,0.04);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-style: italic;
  color: var(--text);
}

.art-content table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  margin: 28px 0;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--line);
}
.art-content th,
.art-content td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}
.art-content thead th {
  background: rgba(79,70,229,0.04);
  font-weight: 800;
  color: var(--navy);
  font-size: 0.82rem;
}
.art-content tbody tr:last-child td { border-bottom: none; }

html[data-theme="dark"] .art-content table { border-color: rgba(99,120,200,0.12); }
html[data-theme="dark"] .art-content thead th { background: rgba(79,70,229,0.08); }

/* ── Article footer ──────────────────────────────────────── */
.art-footer { padding-top: 0; }

.art-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 40px;
}

.art-tag-pill {
  font-size: 0.75rem;
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--text-soft);
  text-decoration: none;
  transition: border-color 150ms ease, color 150ms ease;
}
.art-tag-pill:hover { border-color: var(--indigo); color: var(--indigo); }

.art-related { margin-bottom: 40px; }
.art-related .eyebrow { margin-bottom: 16px; }

.art-related-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
}

.art-related-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  text-decoration: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
  background: rgba(255,255,255,0.85);
}

html[data-theme="dark"] .art-related-card {
  background: rgba(18,23,38,0.85);
  border-color: rgba(99,120,200,0.1);
}

.art-related-card:hover {
  border-color: rgba(79,70,229,0.2);
  box-shadow: 0 4px 20px rgba(79,70,229,0.06);
}

.art-related-card strong {
  font-size: 0.88rem;
  color: var(--navy);
  line-height: 1.4;
}

.art-related-card .art-meta { font-size: 0.74rem; }

.back-link a {
  font-size: 0.85rem;
  color: var(--text-faint);
  text-decoration: none;
}
.back-link a:hover { color: var(--indigo); }

/* ── Article responsive ──────────────────────────────────── */
@media (max-width: 1100px) {
  .art-body-shell {
    grid-template-columns: 200px 1fr;
    gap: 36px;
  }
}

@media (max-width: 860px) {
  .art-body-shell {
    grid-template-columns: 1fr;
  }
  .art-sidebar {
    position: static;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .art-related-grid { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .art-sidebar { grid-template-columns: 1fr; }
  .art-hero__title { font-size: 1.5rem; }
  .art-content h2 { font-size: 1.2rem; }
}

/* ─────────────────────────────────────────────────────────
   Hero panel: always-visible, no IntersectionObserver dep.
   Above-the-fold elements must NOT use data-reveal because
   the observer may fire before layout settles, leaving the
   panel at opacity:0 and creating a large empty gap.
   ───────────────────────────────────────────────────────── */
.hero__panel--animate {
  opacity: 1 !important;
  transform: none !important;
  animation: heroPanelSlideIn 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.1s both;
}

@keyframes heroPanelSlideIn {
  from { opacity: 0; transform: translateX(20px) scale(0.98); }
  to   { opacity: 1; transform: translateX(0)    scale(1);    }
}

/* Guarantee hero section never collapses to empty gap */
.hero__layout {
  min-height: 500px;
}

/* Hero actions wrap neatly with 3 buttons */
.hero__actions {
  flex-wrap: wrap;
  gap: 10px 12px;
}

/* Narrow viewport: stack hero columns */
@media (max-width: 900px) {
  .hero__layout { grid-template-columns: 1fr !important; }
  .hero__panel  { min-height: 300px; }
}

/* ══════════════════════════════════════════════════════════
   SOLUTION OF CHOICE — Trust & Social Proof Upgrades
   ══════════════════════════════════════════════════════════ */

/* ── Partner logo strip ──────────────────────────────────── */
.partner-strip {
  background: var(--surface-2, var(--surface));
  border-block: 1px solid var(--border);
}
.partner-strip__label {
  text-align: center;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 1.5rem;
}
.partner-strip__logos {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  justify-content: center;
  align-items: center;
}
.partner-logo {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 14px 7px 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text);
  transition: border-color 200ms, box-shadow 200ms;
  white-space: nowrap;
}
.partner-logo:hover {
  border-color: var(--indigo);
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1);
}
.partner-logo__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.partner-strip__sub {
  text-align: center;
  font-size: 0.78rem;
  color: var(--text-faint);
  margin-top: 1.25rem;
}
.partner-strip__sub a { color: var(--indigo); font-weight: 600; text-decoration: none; }

/* ── Trust certification badges ──────────────────────────── */
.trust-cert-strip {
  background: linear-gradient(135deg, rgba(79,70,229,0.04) 0%, rgba(124,58,237,0.04) 100%);
  border-block: 1px solid var(--border);
}
.trust-cert-strip__label {
  text-align: center;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 1.25rem;
}
.trust-cert-strip__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  justify-content: center;
  align-items: center;
}
.trust-cert-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  transition: border-color 200ms, box-shadow 200ms, transform 150ms;
}
.trust-cert-badge svg { color: var(--indigo); flex-shrink: 0; }
a.trust-cert-badge:hover {
  border-color: var(--indigo);
  box-shadow: 0 4px 16px rgba(79,70,229,0.15);
  transform: translateY(-1px);
  color: var(--indigo);
}
.trust-cert-strip__pen-test {
  text-align: center;
  font-size: 0.75rem;
  color: var(--text-faint);
  margin-top: 1rem;
}
.trust-cert-strip__pen-test strong { color: var(--text-soft); }

/* ── Story card stars + verified + tag-row ───────────────── */
.story-card__stars {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-bottom: 10px;
}
.story-card__verified {
  font-size: 0.7rem;
  font-weight: 600;
  color: #0D9488;
  background: rgba(13,148,136,0.1);
  border: 1px solid rgba(13,148,136,0.2);
  border-radius: 100px;
  padding: 2px 8px;
  margin-left: 6px;
}
.story-card__tag-row { margin-top: 10px; margin-bottom: 2px; }
.story-card__tag {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--indigo);
  background: rgba(79,70,229,0.08);
  border: 1px solid rgba(79,70,229,0.15);
  border-radius: 100px;
  padding: 3px 10px;
}

/* Dark mode adjustments */
html[data-theme="dark"] .partner-logo,
html[data-theme="dark"] .trust-cert-badge { background: rgba(255,255,255,0.04); }
html[data-theme="dark"] .trust-cert-strip {
  background: linear-gradient(135deg, rgba(79,70,229,0.08) 0%, rgba(124,58,237,0.06) 100%);
}

/* ══════════════════════════════════════════════════════════
   ABOUT PAGE — Premium Team Cards, Advisors, Press
   ══════════════════════════════════════════════════════════ */

/* ── Team grid ───────────────────────────────────────────── */
.about-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.5rem;
}

.about-team-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.5rem;
  transition: border-color 200ms, box-shadow 200ms, transform 150ms;
}

.about-team-card:hover {
  border-color: var(--indigo);
  box-shadow: 0 8px 32px rgba(79,70,229,0.12);
  transform: translateY(-2px);
}

.about-team-card__header {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
}

.about-team-card__avatar {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  flex-shrink: 0;
  color: #fff;
}

/* Avatar colour variants */
.about-team-card__avatar--indigo { background: linear-gradient(135deg, #4F46E5, #7C3AED); }
.about-team-card__avatar--teal   { background: linear-gradient(135deg, #0D9488, #0891B2); }
.about-team-card__avatar--violet { background: linear-gradient(135deg, #7C3AED, #9333EA); }
.about-team-card__avatar--rose   { background: linear-gradient(135deg, #E11D48, #BE185D); }
.about-team-card__avatar--amber  { background: linear-gradient(135deg, #D97706, #B45309); }

.about-team-card__meta {
  flex: 1;
  min-width: 0;
}

.about-team-card__name {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 2px;
  line-height: 1.3;
}

.about-team-card__title {
  font-size: 0.8rem;
  color: var(--text-soft);
  margin: 0;
  line-height: 1.4;
}

.about-team-card__linkedin {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  color: var(--text-faint);
  background: var(--surface-2, rgba(255,255,255,0.04));
  border: 1px solid var(--border);
  text-decoration: none;
  flex-shrink: 0;
  transition: color 200ms, border-color 200ms, background 200ms;
}

.about-team-card__linkedin:hover {
  color: #0A66C2;
  border-color: #0A66C2;
  background: rgba(10,102,194,0.06);
}

.about-team-card__bio {
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--text-soft);
  margin: 0 0 1rem;
}

.about-team-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.about-team-card__tag {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 3px 9px;
  border-radius: 100px;
  background: rgba(79,70,229,0.07);
  border: 1px solid rgba(79,70,229,0.12);
  color: var(--indigo);
}

/* ── Advisory board ──────────────────────────────────────── */
.about-advisors-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.25rem;
}

.about-advisor-card {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1.25rem;
}

.about-advisor-card__avatar {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(79,70,229,0.15), rgba(124,58,237,0.15));
  border: 1px solid rgba(79,70,229,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--indigo);
  flex-shrink: 0;
}

.about-advisor-card__name {
  font-size: 0.92rem;
  font-weight: 700;
  margin: 0 0 2px;
}

.about-advisor-card__role {
  font-size: 0.75rem;
  color: var(--indigo);
  font-weight: 600;
  margin: 0 0 6px;
}

.about-advisor-card__note {
  font-size: 0.8rem;
  color: var(--text-soft);
  line-height: 1.5;
  margin: 0;
}

/* ── Press mention strip ─────────────────────────────────── */
.about-press {
  border-block: 1px solid var(--border);
  background: var(--surface-2, var(--surface));
  text-align: center;
}

.about-press__label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 1.25rem;
}

.about-press__logos {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 1rem;
}

.about-press__logo {
  padding: 8px 18px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text-soft);
  letter-spacing: 0.01em;
  opacity: 0.7;
  transition: opacity 200ms, border-color 200ms;
}

.about-press__logo:hover { opacity: 1; border-color: var(--indigo); }

.about-press__contact {
  font-size: 0.8rem;
  color: var(--text-faint);
}

.about-press__contact a {
  color: var(--indigo);
  font-weight: 600;
  text-decoration: none;
}

@media (max-width: 600px) {
  .about-team-grid {
    grid-template-columns: 1fr;
  }
  .about-team-card__header {
    flex-wrap: wrap;
  }
}

/* ══════════════════════════════════════════════════════════
   2-STEP DEMO FORM — Progress indicator + step styles
   ══════════════════════════════════════════════════════════ */

/* ── Step progress indicator ─────────────────────────────── */
.demo-form-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 1.75rem;
}

.demo-form-step {
  display: flex;
  align-items: center;
  gap: 8px;
}

.demo-form-step__num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--border);
  color: var(--text-faint);
  font-size: 0.78rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 250ms, color 250ms, box-shadow 250ms;
  flex-shrink: 0;
}

.demo-form-step__label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-faint);
  transition: color 250ms;
  white-space: nowrap;
}

/* The connecting line between step numbers */
.demo-form-step__line {
  flex: 1;
  height: 2px;
  background: var(--border);
  margin: 0 12px;
  border-radius: 2px;
  transition: background 250ms;
}

/* Active step */
.demo-form-step--active .demo-form-step__num {
  background: var(--indigo);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(79,70,229,0.15);
}

.demo-form-step--active .demo-form-step__label {
  color: var(--indigo);
}

/* Completed step */
.demo-form-step--done .demo-form-step__num {
  background: #0D9488;
  color: #fff;
}

.demo-form-step--done .demo-form-step__num::before {
  content: '✓';
  font-size: 0.7rem;
}

.demo-form-step--done .demo-form-step__num { font-size: 0; } /* Hide number when done */

.demo-form-step--done + .demo-form-step__line {
  background: #0D9488;
}

.demo-form-step--done .demo-form-step__label { color: #0D9488; }

/* ── Fieldset resets ─────────────────────────────────────── */
.demo-form__step {
  border: none;
  padding: 0;
  margin: 0;
}

/* ── Inline field errors ─────────────────────────────────── */
.demo-form__error {
  display: none;
  font-size: 0.75rem;
  color: #E11D48;
  margin-top: 4px;
  font-weight: 500;
}

/* Red ring on invalid fields after validation attempt */
.demo-form__row input:user-invalid,
.demo-form__row select:user-invalid {
  border-color: #E11D48;
  box-shadow: 0 0 0 3px rgba(225,29,72,0.12);
}

/* Privacy note micro-text */
.demo-form__opt {
  font-size: 0.75rem;
  color: var(--text-faint);
  font-weight: 400;
}

.demo-form__step-note {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: var(--text-faint);
  margin-top: 0.75rem;
}

.demo-form__step-note svg { flex-shrink: 0; }

/* ── Step 2 action bar (Back + Submit side by side) ──────── */
.demo-form__step2-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 0.5rem;
}

.demo-form__back {
  flex-shrink: 0;
}

/* Ghost button variant */
.button--ghost {
  background: transparent;
  border: 1.5px solid var(--border);
  color: var(--text-soft);
  padding: 10px 16px;
  border-radius: 10px;
  font-size: 0.85rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  transition: border-color 200ms, color 200ms;
}

.button--ghost:hover {
  border-color: var(--text-soft);
  color: var(--text);
}

/* ── Success state — polished panel ──────────────────────── */
.demo-form__success {
  text-align: center;
  padding: 2.5rem 1.5rem;
  animation: fadeInUp 400ms cubic-bezier(0.22,1,0.36,1) both;
}

.demo-form__success-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(13,148,136,0.12), rgba(13,148,136,0.06));
  border: 2px solid rgba(13,148,136,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
  color: #0D9488;
  animation: successPop 500ms cubic-bezier(0.18,1.4,0.4,1) both;
}

@keyframes successPop {
  from { transform: scale(0.5); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}

.demo-form__success h3 {
  font-size: 1.4rem;
  margin: 0 0 0.5rem;
}

.demo-form__success p {
  font-size: 0.9rem;
  color: var(--text-soft);
  margin-bottom: 0.5rem;
}

.demo-form__success-note {
  font-size: 0.8rem !important;
  color: var(--text-faint) !important;
}

.demo-form__success-note a { color: var(--indigo); font-weight: 600; text-decoration: none; }

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Step transition animation ───────────────────────────── */
.demo-form__step:not([hidden]) {
  animation: stepIn 280ms cubic-bezier(0.22,1,0.36,1) both;
}

@keyframes stepIn {
  from { opacity: 0; transform: translateX(16px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Responsive: stack step label below number on narrow screens */
@media (max-width: 480px) {
  .demo-form-steps {
    gap: 4px;
  }
  .demo-form-step__label {
    display: none;
  }
  .demo-form__step2-actions {
    flex-direction: column-reverse;
    align-items: stretch;
  }
  .demo-form__step2-actions .button {
    text-align: center;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════════════
   PDF Export / Download Modal
═══════════════════════════════════════════════════════════ */
.roi-export-modal {
  position: fixed;
  inset: 0;
  z-index: 9500;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.roi-export-modal[hidden] { display: none; }

.roi-export-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.roi-export-modal__panel {
  position: relative;
  z-index: 1;
  background: var(--surface-2, #1a1d2e);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 20px;
  padding: 2.5rem;
  max-width: 440px;
  width: 100%;
  box-shadow: 0 24px 80px rgba(0,0,0,0.55);
  animation: modalSlideIn 0.28s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes modalSlideIn {
  from { opacity: 0; transform: scale(0.92) translateY(12px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}

.roi-export-modal__close {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 50%;
  padding: 0.4rem;
  color: var(--text-muted, #9ca0b4);
  cursor: pointer;
  line-height: 0;
  transition: background 0.2s, color 0.2s;
}
.roi-export-modal__close:hover {
  background: rgba(255,255,255,0.14);
  color: var(--text, #e2e4f0);
}

.roi-export-modal__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(99,102,241,0.20) 0%, rgba(139,92,246,0.20) 100%);
  border: 1px solid rgba(139,92,246,0.30);
  color: #a78bfa;
  margin-bottom: 1.25rem;
}

.roi-export-modal__panel h2 {
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 0 0.5rem;
  color: var(--text, #e2e4f0);
}

.roi-export-modal__panel > p {
  color: var(--text-muted, #9ca0b4);
  font-size: 0.95rem;
  margin-bottom: 1.5rem;
  line-height: 1.6;
}

.roi-export-modal__field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

.roi-export-modal__field label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-muted, #9ca0b4);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.roi-export-modal__field input {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  padding: 0.7rem 1rem;
  color: var(--text, #e2e4f0);
  font-size: 0.95rem;
  transition: border-color 0.2s, box-shadow 0.2s;
  width: 100%;
}

.roi-export-modal__field input:focus {
  outline: none;
  border-color: var(--accent, #6366f1);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.20);
}

.roi-export-modal__panel .button {
  width: 100%;
  justify-content: center;
  margin-top: 0.5rem;
}

.roi-export-modal__note {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.78rem;
  color: var(--text-muted, #9ca0b4);
  margin-top: 0.9rem !important;
  margin-bottom: 0 !important;
}

.roi-export-modal__success-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(34,197,94,0.20) 0%, rgba(16,185,129,0.20) 100%);
  border: 1px solid rgba(34,197,94,0.30);
  color: #4ade80;
  margin: 0 auto 1rem;
}

/* ═══════════════════════════════════════════════════════════
   Ghost button — dark-surface variant
   (used in ROI panel, export modal, CS download buttons)
   Does NOT override the global .button--ghost which uses
   indigo tones for light backgrounds.
═══════════════════════════════════════════════════════════ */
.button--ghost--dark {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.18);
  color: rgba(199,210,254,0.8);
  padding: 0.6rem 1.1rem;
  font-size: 0.875rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
  font-weight: 500;
  text-decoration: none;
}
.button--ghost--dark:hover {
  border-color: rgba(255,255,255,0.35);
  color: #fff;
  background: rgba(255,255,255,0.08);
}
.button--ghost--dark svg { flex-shrink: 0; }

/* ═══════════════════════════════════════════════════════════
   ROI CTA block — updated layout
═══════════════════════════════════════════════════════════ */
.roi-cta-block {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1.75rem;
}

.roi-cta-block .button--glow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: center;
  width: 100%;
}

.roi-cta-block__secondary {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.roi-cta-block__secondary .button--ghost--dark {
  flex: 1;
  min-width: 140px;
  justify-content: center;
}

/* ═══════════════════════════════════════════════════════════
   Case Study Hero Actions
═══════════════════════════════════════════════════════════ */
.cs-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.75rem;
  align-items: center;
}

/* ═══════════════════════════════════════════════════════════
   Sector Filter Tabs
═══════════════════════════════════════════════════════════ */
.cs-filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 1rem 0 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.cs-filter-tab {
  padding: 0.45rem 1.1rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: transparent;
  color: var(--text-muted, #9ca0b4);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
  white-space: nowrap;
}

.cs-filter-tab:hover {
  border-color: rgba(99,102,241,0.55);
  color: var(--text, #e2e4f0);
}

.cs-filter-tab--active {
  border-color: var(--accent, #6366f1);
  background: rgba(99,102,241,0.15);
  color: #a5b4fc;
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════
   Case Study Header — Download button positioning
═══════════════════════════════════════════════════════════ */
.case-study__header {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
}

.cs-dl-btn {
  margin-left: auto;
  flex-shrink: 0;
  font-size: 0.8rem;
  padding: 0.4rem 0.85rem;
}

@media (max-width: 600px) {
  .cs-dl-btn { width: 100%; justify-content: center; }
  .roi-export-modal__panel { padding: 1.75rem 1.25rem; }
  .roi-cta-block__secondary { flex-direction: column; }
  .cs-hero-actions { flex-direction: column; align-items: flex-start; }
}

/* ROI total positive state */
.roi-total--positive { color: #4ade80; text-shadow: 0 0 32px rgba(74,222,128,0.35); }

/* ═══════════════════════════════════════════════════════════
   SPRINT 12 — SOCIAL PROOF UPGRADE
   Featured testimonial hero · Review badges · Partner wordmarks
═══════════════════════════════════════════════════════════ */

/* ── Featured testimonial hero block ────────────────────── */
.testimonial-hero {
  position: relative;
  background: linear-gradient(135deg,
    rgba(79,70,229,0.12) 0%,
    rgba(124,58,237,0.08) 50%,
    rgba(15,118,110,0.08) 100%
  );
  border: 1px solid rgba(99,102,241,0.22);
  border-radius: var(--radius);
  padding: 3rem 3.5rem;
  margin-bottom: 3rem;
  overflow: hidden;
}

.testimonial-hero::before {
  content: '';
  position: absolute;
  bottom: -60px;
  right: -60px;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(79,70,229,0.15), transparent 70%);
  pointer-events: none;
}

.testimonial-hero__quote-mark {
  position: absolute;
  top: 1.5rem;
  left: 2.5rem;
  font-size: 5rem;
  line-height: 1;
  color: rgba(99,102,241,0.2);
  font-family: Georgia, serif;
  pointer-events: none;
}

.testimonial-hero__quote {
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  font-weight: 500;
  line-height: 1.65;
  color: rgba(255,255,255,0.92);
  margin: 0 0 2rem;
  padding-top: 1rem;
  border: none;
  font-style: normal;
  letter-spacing: -0.01em;
}

.testimonial-hero__footer {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}

.testimonial-hero__author {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex: 1;
  min-width: 240px;
}

.testimonial-hero__avatar {
  width: 52px !important;
  height: 52px !important;
  font-size: 1rem !important;
  flex-shrink: 0;
}

.testimonial-hero__name {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 2px;
}

.testimonial-hero__role {
  font-size: 0.84rem;
  color: rgba(199,210,254,0.7);
}

.testimonial-hero__role strong {
  color: rgba(199,210,254,0.9);
}

.testimonial-hero__metrics {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}

.testimonial-hero__metric {
  text-align: center;
}

.testimonial-hero__metric strong {
  display: block;
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.03em;
  line-height: 1.1;
}

.testimonial-hero__metric span {
  font-size: 0.75rem;
  color: rgba(199,210,254,0.6);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.3;
  margin-top: 2px;
  display: block;
  max-width: 10ch;
}

/* ── Story grid secondary (3-col) ────────────────────────── */
.story-grid--secondary {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

/* Company name on story card */
.story-card__company {
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(99,102,241,0.8);
  margin-top: 1px;
}

/* ── Review platform badges row ──────────────────────────── */
.review-badges {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 3rem;
  padding: 1.5rem 2rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-sm);
}

.review-badge {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.review-badge__stars {
  display: flex;
  gap: 2px;
}

.review-badge__score {
  font-size: 0.9rem;
  font-weight: 700;
  color: #fff;
}

.review-badge__source {
  font-size: 0.8rem;
  color: rgba(199,210,254,0.6);
  font-weight: 500;
}

.review-badge__divider {
  width: 1px;
  height: 28px;
  background: rgba(255,255,255,0.12);
  flex-shrink: 0;
}

.review-badge__total {
  font-size: 0.84rem;
  color: rgba(199,210,254,0.6);
}

.review-badge__total strong {
  color: rgba(255,255,255,0.85);
}

/* ── Partner logo wordmarks ──────────────────────────────── */
.partner-logo--wordmark {
  padding: 10px 16px;
  background: var(--surface, rgba(255,255,255,0.85));
  border: 1px solid var(--line, rgba(17,24,58,0.08));
  border-radius: 10px;
  display: flex;
  align-items: center;
  transition: box-shadow 200ms ease, border-color 200ms ease, transform 200ms ease;
}

.partner-logo--wordmark:hover {
  box-shadow: 0 4px 16px rgba(79,70,229,0.12);
  border-color: rgba(79,70,229,0.2);
  transform: translateY(-2px);
}

.partner-logo--wordmark svg {
  height: 32px;
  width: auto;
  max-width: 140px;
}

html[data-theme="dark"] .partner-logo--wordmark {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.1);
}

html[data-theme="dark"] .partner-logo--wordmark:hover {
  background: rgba(255,255,255,0.09);
  border-color: rgba(99,102,241,0.35);
}

/* ── Responsive adjustments ──────────────────────────────── */
@media (max-width: 768px) {
  .testimonial-hero {
    padding: 2rem 1.5rem;
  }
  .testimonial-hero__quote-mark {
    font-size: 3.5rem;
    top: 1rem;
    left: 1.25rem;
  }
  .testimonial-hero__footer {
    flex-direction: column;
    gap: 1.25rem;
  }
  .testimonial-hero__metrics {
    gap: 1.25rem;
    width: 100%;
    justify-content: space-between;
  }
  .review-badges {
    gap: 1rem;
    padding: 1rem;
  }
  .review-badge__divider { display: none; }
}

/* ════════════════════════════════════════════════════════════════
   HERO GAP FIX — Hard constraint via ID specificity
   Overrides any earlier rule that inflates the hero section height.
   ════════════════════════════════════════════════════════════════ */
#hero {
  /* Ensure height is content-driven, not inflated by orbs or canvas */
  height: auto !important;
  /* Clip everything — canvas, orbs, blur effects — at the hero boundary */
  overflow: hidden !important;
  /* Belt-and-suspenders: also use clip-path for filter bleed */
  clip-path: inset(0);
}

#hero .hero-dot-grid,
#hero .hero-orbs-wrap,
#hero .hero-orb {
  /* Absolutely contained — cannot affect scroll height */
  position: absolute !important;
  pointer-events: none !important;
}

/* ════════════════════════════════════════════════════════════════
   DEVELOPER PORTAL — Full CSS Treatment
   ════════════════════════════════════════════════════════════════ */

/* ── Dev Hero ─────────────────────────────────────────────────── */
.dev-hero {
  background:
    linear-gradient(160deg, rgba(12,19,51,0.97) 0%, rgba(30,27,75,0.97) 60%, rgba(79,70,229,0.15) 100%),
    var(--body-bg);
  color: #fff;
  padding-top: 60px;
  padding-bottom: 60px;
  position: relative;
  overflow: hidden;
}

.dev-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(99,102,241,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,102,241,0.06) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
}

.dev-hero .eyebrow { color: rgba(165,180,252,0.8); }

.dev-hero h1 {
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
  margin: 10px 0 18px;
  color: #fff;
  max-width: 14ch;
}

.dev-hero__lede {
  max-width: 56ch;
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  color: rgba(255,255,255,0.7);
  line-height: 1.65;
  margin-bottom: 28px;
}

.dev-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 32px;
}

/* Language strip */
.dev-lang-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dev-lang-strip span {
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.65);
  letter-spacing: 0.04em;
}

/* ── Quickstart steps ─────────────────────────────────────────── */
.dev-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.dev-step {
  position: relative;
  padding: 24px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}

.dev-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--indigo), var(--violet));
  color: #fff;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.82rem;
  font-weight: 700;
  margin-bottom: 14px;
  flex-shrink: 0;
}

.dev-step h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 10px;
}

/* ── Code blocks ──────────────────────────────────────────────── */
.dev-code {
  background: #0d1117;
  border: 1px solid rgba(99,102,241,0.2);
  border-radius: 10px;
  padding: 16px 18px;
  margin: 0;
  overflow-x: auto;
}

.dev-code code {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.82rem;
  color: #c9d1d9;
  line-height: 1.7;
  white-space: pre;
}

.dev-code--full {
  border-radius: 0 0 12px 12px;
  border-top: none;
  max-height: 360px;
  overflow-y: auto;
}

.dev-code--sm { padding: 12px 14px; }
.dev-code--sm code { font-size: 0.76rem; }

/* ── Code tab navigation ──────────────────────────────────────── */
.code-tabs {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
  margin-bottom: 0;
  border-bottom: 2px solid rgba(79,70,229,0.15);
  padding-bottom: 0;
}

.code-tab {
  padding: 10px 18px;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-soft);
  transition: color 150ms ease, border-color 150ms ease;
}

.code-tab.is-active,
.code-tab[aria-selected="true"] {
  color: var(--indigo);
  border-bottom-color: var(--indigo);
}

.code-tab:hover:not(.is-active) { color: var(--navy); }

/* Sub-scenario tabs */
.code-subtabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  padding: 14px 16px;
  background: #161b22;
  border-radius: 12px 12px 0 0;
  border: 1px solid rgba(99,102,241,0.2);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.code-subtab {
  padding: 5px 12px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid transparent;
  color: rgba(201,209,217,0.6);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.74rem;
  cursor: pointer;
  transition: all 120ms ease;
}

.code-subtab.is-active {
  background: rgba(99,102,241,0.2);
  border-color: rgba(99,102,241,0.4);
  color: #a5b4fc;
}

.code-subtab:hover:not(.is-active) {
  background: rgba(255,255,255,0.06);
  color: rgba(201,209,217,0.9);
}

/* Code panels */
.code-panel { display: none; }
.code-panel.is-active { display: block; }

.code-example { display: none; }
.code-example.is-active { display: block; }

/* Code example toolbar */
.code-example__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: #161b22;
  border-radius: 12px 12px 0 0;
  border: 1px solid rgba(99,102,241,0.2);
  border-bottom: none;
}

.code-example__label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem;
  color: rgba(201,209,217,0.5);
}

.code-copy-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px solid rgba(99,102,241,0.3);
  background: rgba(99,102,241,0.1);
  color: rgba(165,180,252,0.8);
  font-size: 0.74rem;
  cursor: pointer;
  transition: all 120ms ease;
}

.code-copy-btn:hover {
  background: rgba(99,102,241,0.25);
  border-color: rgba(99,102,241,0.5);
  color: #a5b4fc;
}

/* ── SDK grid ─────────────────────────────────────────────────── */
.dev-sdk-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.dev-sdk-card {
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px 24px;
  box-shadow: var(--shadow-soft);
  transition: transform 150ms ease, box-shadow 150ms ease;
}

.dev-sdk-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(79,70,229,0.1);
}

.dev-sdk-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.dev-sdk-card__lang {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--navy);
}

.dev-sdk-card__badge {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
}

.dev-sdk-card__badge--indigo { background: rgba(79,70,229,0.1);  color: var(--indigo); }
.dev-sdk-card__badge--teal   { background: rgba(20,184,166,0.1); color: #0f766e; }
.dev-sdk-card__badge--violet { background: rgba(124,58,237,0.1); color: var(--violet); }
.dev-sdk-card__badge--rose   { background: rgba(244,63,94,0.1);  color: var(--rose); }
.dev-sdk-card__badge--amber  { background: rgba(245,158,11,0.1); color: #b45309; }

.dev-sdk-card__note {
  font-size: 0.78rem;
  color: var(--text-soft);
  margin: 10px 0 0;
}

/* ── API service cards ────────────────────────────────────────── */
.dev-api-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.dev-api-card {
  padding: 22px 20px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform 150ms ease, box-shadow 150ms ease;
}

.dev-api-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(79,70,229,0.08);
}

.dev-api-card__top {
  margin-bottom: 12px;
}

.dev-api-card__count {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 999px;
  display: inline-block;
  margin-bottom: 8px;
}

.dev-api-card__count--indigo { background: rgba(79,70,229,0.1);  color: var(--indigo); }
.dev-api-card__count--teal   { background: rgba(20,184,166,0.1); color: #0f766e; }
.dev-api-card__count--violet { background: rgba(124,58,237,0.1); color: var(--violet); }
.dev-api-card__count--rose   { background: rgba(244,63,94,0.1);  color: var(--rose); }
.dev-api-card__count--amber  { background: rgba(245,158,11,0.1); color: #b45309; }

.dev-api-card h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 6px;
}

.dev-api-card__base {
  display: block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  color: var(--text-faint);
  margin-bottom: 10px;
}

.dev-api-card p {
  font-size: 0.82rem;
  color: var(--text-soft);
  line-height: 1.55;
  margin: 0;
}

/* ── Architecture grid ────────────────────────────────────────── */
.dev-arch-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.dev-arch-card {
  padding: 24px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform 150ms ease;
}

.dev-arch-card:hover { transform: translateY(-2px); }

.dev-arch-card__icon {
  font-size: 1.5rem;
  margin-bottom: 12px;
  line-height: 1;
}

.dev-arch-card h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 8px;
}

.dev-arch-card p {
  font-size: 0.82rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0 0 14px;
}

/* ── Resource cards ───────────────────────────────────────────── */
.dev-resource-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.dev-resource-card {
  padding: 22px 24px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform 150ms ease, box-shadow 150ms ease;
  cursor: pointer;
}

.dev-resource-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(79,70,229,0.1);
}

.dev-resource-card__tag {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
  margin-bottom: 10px;
}

.dev-resource-card__tag--indigo { background: rgba(79,70,229,0.1);  color: var(--indigo); }
.dev-resource-card__tag--teal   { background: rgba(20,184,166,0.1); color: #0f766e; }
.dev-resource-card__tag--violet { background: rgba(124,58,237,0.1); color: var(--violet); }
.dev-resource-card__tag--rose   { background: rgba(244,63,94,0.1);  color: var(--rose); }
.dev-resource-card__tag--amber  { background: rgba(245,158,11,0.1); color: #b45309; }

.dev-resource-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 6px;
}

.dev-resource-card p {
  font-size: 0.82rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0;
}

/* ── Dev page responsive ──────────────────────────────────────── */
@media (max-width: 1100px) {
  .dev-api-grid  { grid-template-columns: repeat(2, 1fr); }
  .dev-arch-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .dev-steps     { grid-template-columns: repeat(2, 1fr); }
  .dev-sdk-grid  { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .dev-steps          { grid-template-columns: 1fr; }
  .dev-sdk-grid       { grid-template-columns: 1fr; }
  .dev-api-grid       { grid-template-columns: 1fr; }
  .dev-arch-grid      { grid-template-columns: 1fr; }
  .dev-resource-grid  { grid-template-columns: 1fr; }
  .code-tabs          { gap: 0; }
  .code-tab           { padding: 8px 12px; font-size: 0.74rem; }
}

/* Dark mode dev overrides */
html[data-theme="dark"] .dev-step,
html[data-theme="dark"] .dev-sdk-card,
html[data-theme="dark"] .dev-api-card,
html[data-theme="dark"] .dev-arch-card,
html[data-theme="dark"] .dev-resource-card {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

/* ════════════════════════════════════════════════════════════════
   CASE STUDIES PAGE
   ════════════════════════════════════════════════════════════════ */

/* ── Hero actions strip ───────────────────────────────────────── */
.cs-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

/* ── Sector filter tabs ───────────────────────────────────────── */
.cs-filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-bottom: 0;
}

.cs-filter-tab {
  padding: 8px 18px;
  border-radius: 999px;
  border: 1.5px solid var(--line);
  background: rgba(255,255,255,0.7);
  color: var(--text-soft);
  font-size: 0.84rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 150ms ease;
}

.cs-filter-tab:hover {
  border-color: rgba(79,70,229,0.4);
  color: var(--indigo);
  background: rgba(79,70,229,0.04);
}

.cs-filter-tab--active,
.cs-filter-tab[aria-selected="true"] {
  background: var(--indigo);
  border-color: var(--indigo);
  color: #fff;
}

html[data-theme="dark"] .cs-filter-tab {
  background: rgba(255,255,255,0.05);
  border-color: rgba(99,120,200,0.2);
}

html[data-theme="dark"] .cs-filter-tab--active {
  background: var(--indigo);
  border-color: var(--indigo);
}

/* ── Individual case study card ───────────────────────────────── */
.case-study {
  padding: 40px 0;
}

.case-study__header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
}

/* Avatar / initials */
.case-study__avatar {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 1.1rem;
  letter-spacing: -0.02em;
  color: #fff;
  flex-shrink: 0;
}

.case-study__avatar--indigo { background: linear-gradient(135deg, #4f46e5, #7c3aed); }
.case-study__avatar--violet { background: linear-gradient(135deg, #7c3aed, #a855f7); }
.case-study__avatar--teal   { background: linear-gradient(135deg, #0d9488, #14b8a6); }
.case-study__avatar--rose   { background: linear-gradient(135deg, #f43f5e, #e11d48); }
.case-study__avatar--amber  { background: linear-gradient(135deg, #d97706, #f59e0b); }

.case-study__company {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 4px;
}

.case-study__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  flex-wrap: wrap;
  font-size: 0.84rem;
  color: var(--text-soft);
}

.meta-pill {
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(79,70,229,0.08);
  border: 1px solid rgba(79,70,229,0.15);
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--indigo);
  letter-spacing: 0.03em;
}

/* Scenario/email action button at header level — push to far right */
.case-study__header > .button { margin-left: auto; flex-shrink: 0; }

/* ── Two-column body ──────────────────────────────────────────── */
.case-study__body {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 40px;
  align-items: start;
}

/* Narrative */
.case-study__narrative {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.case-study__block p:first-child {
  /* eyebrow inside block */
  margin-bottom: 6px;
}

.case-study__block p:last-child {
  font-size: 0.95rem;
  color: var(--text-body);
  line-height: 1.7;
  margin: 0;
}

.case-study__quote {
  margin: 8px 0 0;
  padding: 20px 24px;
  border-left: 3px solid var(--indigo);
  background: rgba(79,70,229,0.04);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.case-study__quote p {
  font-size: 1rem;
  font-style: italic;
  color: var(--navy);
  line-height: 1.65;
  margin: 0 0 10px;
}

.case-study__quote footer {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-soft);
}

/* Results sidebar */
.case-study__results {
  background: rgba(255,255,255,0.9);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow-soft);
  position: sticky;
  top: 108px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

html[data-theme="dark"] .case-study__results {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.case-study__results > .eyebrow {
  margin-bottom: 4px;
}

.case-study__result {
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
}

.case-study__result strong {
  display: block;
  font-size: 1.3rem;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: 3px;
  font-family: 'IBM Plex Mono', monospace;
}

.case-study__result span {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-soft);
  line-height: 1.35;
}

/* Colour variants */
.case-study__result--indigo { background: rgba(79,70,229,0.07);  border-color: rgba(79,70,229,0.13); }
.case-study__result--indigo strong { color: #4f46e5; }

.case-study__result--violet { background: rgba(124,58,237,0.07); border-color: rgba(124,58,237,0.13); }
.case-study__result--violet strong { color: #7c3aed; }

.case-study__result--teal   { background: rgba(20,184,166,0.07); border-color: rgba(20,184,166,0.13); }
.case-study__result--teal strong   { color: #0d9488; }

.case-study__result--rose   { background: rgba(244,63,94,0.07);  border-color: rgba(244,63,94,0.13); }
.case-study__result--rose strong   { color: #f43f5e; }

.case-study__result--amber  { background: rgba(245,158,11,0.07); border-color: rgba(245,158,11,0.13); }
.case-study__result--amber strong  { color: #d97706; }

/* Divider between studies */
.case-study__divider {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--line) 20%, var(--line) 80%, transparent);
  margin: 0;
}

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 900px) {
  .case-study__body {
    grid-template-columns: 1fr;
  }
  .case-study__results {
    position: static;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    align-items: start;
  }
  .case-study__results > .eyebrow,
  .case-study__results > .button {
    grid-column: 1 / -1;
  }
}

@media (max-width: 580px) {
  .case-study__results {
    grid-template-columns: 1fr;
  }
  .case-study__header {
    flex-wrap: wrap;
  }
  .case-study__header > .button {
    margin-left: 0;
    width: 100%;
    justify-content: center;
  }
  .cs-filter-tab { padding: 7px 14px; font-size: 0.78rem; }
}

/* ════════════════════════════════════════════════════════════════
   COMPARE PAGES
   ════════════════════════════════════════════════════════════════ */

/* ── Summary cards (us vs them) ──────────────────────────────── */
.compare-summary-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 20px;
  align-items: center;
}

.compare-summary-card {
  padding: 28px 32px;
  border-radius: var(--radius);
  border: 2px solid transparent;
}

.compare-summary-card--us {
  background: linear-gradient(135deg, rgba(79,70,229,0.06), rgba(124,58,237,0.04));
  border-color: rgba(79,70,229,0.2);
}

.compare-summary-card--them {
  background: rgba(255,255,255,0.7);
  border-color: var(--line);
}

html[data-theme="dark"] .compare-summary-card--them {
  background: rgba(255,255,255,0.04);
}

.compare-summary-card .eyebrow {
  margin-bottom: 8px;
}

.compare-summary-card p:last-child {
  font-size: 0.9rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0;
}

.compare-summary-vs {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--navy);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 0.85rem;
  letter-spacing: -0.02em;
  flex-shrink: 0;
}

/* ── Comparison table ─────────────────────────────────────────── */
.compare-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  border: 1px solid var(--line);
}

.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.compare-table thead {
  background: var(--navy);
  color: #fff;
}

.compare-table thead th {
  padding: 16px 20px;
  font-weight: 700;
  text-align: left;
  font-size: 0.84rem;
  letter-spacing: 0.02em;
}

/* Trustinera column header highlight */
.compare-table th.compare-table__us {
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
}

.compare-table tbody tr {
  border-bottom: 1px solid var(--line);
  transition: background 100ms ease;
}

.compare-table tbody tr:hover {
  background: rgba(79,70,229,0.03);
}

.compare-table tbody tr:last-child {
  border-bottom: none;
}

.compare-table td {
  padding: 14px 20px;
  color: var(--text-body);
  vertical-align: middle;
}

/* Trustinera column body highlight */
.compare-table td.compare-table__us {
  background: rgba(79,70,229,0.03);
}

html[data-theme="dark"] .compare-table td.compare-table__us {
  background: rgba(79,70,229,0.07);
}

/* Tick / cross indicators */
.compare-tick {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 700;
}

.compare-tick--yes {
  color: #16a34a;
  font-size: 1.1rem;
}

.compare-tick--no {
  color: var(--text-faint);
  font-size: 1.1rem;
}

.compare-tick--neutral {
  color: var(--text-soft);
  font-size: 1.1rem;
}

.compare-tick--partial {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-soft);
}

/* ── Verdict section ──────────────────────────────────────────── */
.compare-verdict {
  max-width: 720px;
  margin: 0 auto 40px;
  text-align: center;
}

.compare-verdict h2 {
  font-size: 1.8rem;
  font-weight: 800;
  margin: 8px 0 16px;
  color: var(--navy);
}

.compare-verdict p {
  font-size: 0.95rem;
  color: var(--text-soft);
  line-height: 1.75;
}

/* Compare quote */
.compare-quote {
  max-width: 640px;
  margin: 0 auto;
  padding: 24px 32px;
  border-left: 3px solid var(--indigo);
  background: rgba(79,70,229,0.05);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.compare-quote p {
  font-size: 1rem;
  font-style: italic;
  color: var(--navy);
  line-height: 1.65;
  margin: 0 0 12px;
}

.compare-quote footer {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-soft);
}

/* ── Comparison link cards ────────────────────────────────────── */
.compare-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.compare-link-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  background: rgba(255,255,255,0.85);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--navy);
  font-size: 0.88rem;
  font-weight: 600;
  transition: all 150ms ease;
}

.compare-link-card:hover {
  border-color: rgba(79,70,229,0.3);
  background: rgba(79,70,229,0.04);
  color: var(--indigo);
  transform: translateX(3px);
}

html[data-theme="dark"] .compare-link-card {
  background: rgba(255,255,255,0.04);
  color: var(--text-soft);
}

html[data-theme="dark"] .compare-link-card:hover {
  color: var(--indigo);
}

/* ── Compare responsive ───────────────────────────────────────── */
@media (max-width: 880px) {
  .compare-summary-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .compare-summary-vs {
    margin: 0 auto;
  }
  .compare-links {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 580px) {
  .compare-links { grid-template-columns: 1fr; }
  .compare-table thead th,
  .compare-table td { padding: 12px 14px; font-size: 0.82rem; }
}

/* ════════════════════════════════════════════════════════════════
   FAQ PAGE
   ════════════════════════════════════════════════════════════════ */

/* Two-column layout */
.faq-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 48px;
  align-items: start;
}

/* Sticky side nav */
.faq-nav {
  position: sticky;
  top: 108px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.faq-nav__link {
  padding: 9px 14px;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-soft);
  text-decoration: none;
  transition: all 120ms ease;
  border: 1px solid transparent;
}

.faq-nav__link:hover {
  background: rgba(79,70,229,0.06);
  color: var(--indigo);
  border-color: rgba(79,70,229,0.12);
}

.faq-nav__link.is-active {
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
  border-color: rgba(79,70,229,0.18);
}

/* FAQ sections */
.faq-sections {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.faq-section__title {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(79,70,229,0.1);
}

/* Accordion items */
.faq-item {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: border-color 100ms ease;
}

.faq-item:has(.faq-item__q[aria-expanded="true"]) {
  border-color: rgba(79,70,229,0.25);
}

.faq-item__q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  background: rgba(255,255,255,0.85);
  border: none;
  cursor: pointer;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--navy);
  text-align: left;
  transition: background 100ms ease;
}

html[data-theme="dark"] .faq-item__q {
  background: rgba(18,23,38,0.85);
}

.faq-item__q:hover { background: rgba(79,70,229,0.04); }
.faq-item__q[aria-expanded="true"] { background: rgba(79,70,229,0.04); }

.faq-item__chevron {
  flex-shrink: 0;
  color: var(--text-faint);
  transition: transform 200ms ease;
}

.faq-item__q[aria-expanded="true"] .faq-item__chevron {
  transform: rotate(180deg);
  color: var(--indigo);
}

.faq-item__a {
  padding: 0 20px 18px;
  background: rgba(79,70,229,0.02);
}

.faq-item__a p {
  font-size: 0.9rem;
  color: var(--text-soft);
  line-height: 1.75;
  margin: 0;
  padding-top: 4px;
}

@media (max-width: 800px) {
  .faq-layout {
    grid-template-columns: 1fr;
  }
  .faq-nav {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .faq-nav__link { font-size: 0.8rem; padding: 7px 10px; }
}

/* ════════════════════════════════════════════════════════════════
   INTEGRATIONS PAGE
   ════════════════════════════════════════════════════════════════ */

/* Category blocks */
.int-category {
  margin-bottom: 48px;
}

.int-category__title {
  font-size: 1rem;
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.01em;
  margin: 0 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(79,70,229,0.1);
}

/* Integration card grid */
.int-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 14px;
}

.int-card {
  padding: 18px 20px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-soft);
  transition: transform 130ms ease, box-shadow 130ms ease;
}

.int-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(79,70,229,0.08);
}

html[data-theme="dark"] .int-card {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.int-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

/* Brand-coloured avatar */
.int-card__avatar {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.int-card__name {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 4px;
}

.int-card__desc {
  font-size: 0.76rem;
  color: var(--text-faint);
  margin: 0;
  line-height: 1.4;
}

/* Status badges */
.int-badge {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 999px;
}

.int-badge--green   { background: rgba(22,163,74,0.1);   color: #16a34a; }
.int-badge--blue    { background: rgba(59,130,246,0.1);  color: #2563eb; }
.int-badge--amber   { background: rgba(245,158,11,0.1);  color: #b45309; }
.int-badge--neutral { background: rgba(100,116,139,0.1); color: #64748b; }
.int-badge--violet  { background: rgba(124,58,237,0.1);  color: var(--violet); }

@media (max-width: 640px) {
  .int-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ════════════════════════════════════════════════════════════════
   CHANGELOG PAGE
   ════════════════════════════════════════════════════════════════ */

/* Two-column layout */
.cl-layout {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 48px;
  align-items: start;
}

/* Sidebar nav */
.cl-nav {
  position: sticky;
  top: 108px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cl-nav a {
  padding: 9px 12px;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  transition: background 120ms ease;
  border: 1px solid transparent;
}

.cl-nav a:hover {
  background: rgba(79,70,229,0.06);
  border-color: rgba(79,70,229,0.12);
}

.cl-nav__version {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--navy);
}

.cl-nav__date {
  font-size: 0.72rem;
  color: var(--text-faint);
}

/* Legend in hero */
.cl-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.cl-badge {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

/* Release articles */
.cl-releases {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.cl-release {
  padding: 28px 32px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}

html[data-theme="dark"] .cl-release {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.cl-release__head { margin-bottom: 16px; }

.cl-release__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

/* Version number */
.cl-version {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.03em;
}

/* Release type badge */
.cl-type-badge {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
}

.cl-major { background: linear-gradient(135deg, rgba(79,70,229,0.15), rgba(124,58,237,0.15)); color: var(--indigo); border: 1px solid rgba(79,70,229,0.2); }
.cl-minor { background: rgba(20,184,166,0.1);  color: #0d9488; border: 1px solid rgba(20,184,166,0.2); }
.cl-patch { background: rgba(100,116,139,0.08); color: #64748b; border: 1px solid rgba(100,116,139,0.15); }

.cl-date {
  font-size: 0.8rem;
  color: var(--text-faint);
  margin-left: auto;
}

.cl-release__title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 10px;
  line-height: 1.3;
}

/* Highlight callout */
.cl-highlight {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: rgba(79,70,229,0.07);
  border: 1px solid rgba(79,70,229,0.15);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--indigo);
  margin-bottom: 16px;
}

/* Change items list */
.cl-items {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cl-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 0.88rem;
  color: var(--text-soft);
  line-height: 1.6;
}

.cl-item__badge {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  flex-shrink: 0;
  margin-top: 1px;
}

/* Change type colours */
.cl-item--new    .cl-item__badge { background: rgba(79,70,229,0.12);   color: var(--indigo); }
.cl-item--impr   .cl-item__badge { background: rgba(20,184,166,0.12);  color: #0d9488; }
.cl-item--fix    .cl-item__badge { background: rgba(22,163,74,0.12);   color: #16a34a; }
.cl-item--perf   .cl-item__badge { background: rgba(245,158,11,0.12);  color: #b45309; }
.cl-item--deprec .cl-item__badge { background: rgba(244,63,94,0.12);   color: var(--rose); }

/* Same colours on the legend badges */
.cl-badge.cl-item--new    { background: rgba(79,70,229,0.1);   color: var(--indigo); }
.cl-badge.cl-item--impr   { background: rgba(20,184,166,0.1);  color: #0d9488; }
.cl-badge.cl-item--fix    { background: rgba(22,163,74,0.1);   color: #16a34a; }
.cl-badge.cl-item--perf   { background: rgba(245,158,11,0.1);  color: #b45309; }
.cl-badge.cl-item--deprec { background: rgba(244,63,94,0.1);   color: var(--rose); }

/* Responsive */
@media (max-width: 800px) {
  .cl-layout {
    grid-template-columns: 1fr;
  }
  .cl-nav {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6px;
  }
  .cl-nav a {
    flex-direction: row;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
  }
  .cl-date { margin-left: 0; }
}

@media (max-width: 500px) {
  .cl-release { padding: 20px 18px; }
}

/* ════════════════════════════════════════════════════════════════
   SOLUTIONS (INDUSTRY) PAGES
   ════════════════════════════════════════════════════════════════ */

/* Problem callout strip */
.proof-strip {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.proof-strip p {
  font-size: 1.05rem;
  color: var(--text-soft);
  line-height: 1.75;
  margin: 0;
}

/* Metrics strip — 4-up stat row */
.solutions-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.solutions-metric {
  padding: 20px 24px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  background: rgba(255,255,255,0.9);
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

html[data-theme="dark"] .solutions-metric {
  background: rgba(18,23,38,0.9);
}

.solutions-metric strong {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
}

.solutions-metric span {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-soft);
  line-height: 1.35;
}

/* Per-accent colouring */
.solutions-metric--indigo { border-color: rgba(79,70,229,0.18);  background: rgba(79,70,229,0.05); }
.solutions-metric--indigo strong { color: #4f46e5; }
.solutions-metric--teal   { border-color: rgba(20,184,166,0.18); background: rgba(20,184,166,0.05); }
.solutions-metric--teal   strong { color: #0d9488; }
.solutions-metric--violet { border-color: rgba(124,58,237,0.18); background: rgba(124,58,237,0.05); }
.solutions-metric--violet strong { color: #7c3aed; }
.solutions-metric--rose   { border-color: rgba(244,63,94,0.18);  background: rgba(244,63,94,0.05); }
.solutions-metric--rose   strong { color: #f43f5e; }
.solutions-metric--amber  { border-color: rgba(245,158,11,0.18); background: rgba(245,158,11,0.05); }
.solutions-metric--amber  strong { color: #d97706; }

/* Modules row */
.solutions-modules-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
  padding: 28px 32px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}

html[data-theme="dark"] .solutions-modules-row {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.solutions-module-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.solutions-module-tag {
  padding: 6px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(79,70,229,0.1), rgba(124,58,237,0.08));
  border: 1px solid rgba(79,70,229,0.2);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--indigo);
}

/* Cross-sell link grid (reuses .compare-link-card) */
.solutions-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

/* Solutions quote */
.solutions-quote {
  max-width: 680px;
  margin: 0 auto;
  padding: 26px 32px;
  border-left: 3px solid var(--indigo);
  background: rgba(79,70,229,0.04);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.solutions-quote p {
  font-size: 1rem;
  font-style: italic;
  color: var(--navy);
  line-height: 1.65;
  margin: 0 0 10px;
}

.solutions-quote footer {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-soft);
}

@media (max-width: 900px) {
  .solutions-metrics { grid-template-columns: repeat(2, 1fr); }
  .solutions-modules-row { grid-template-columns: 1fr; gap: 20px; }
  .solutions-links { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 580px) {
  .solutions-metrics { grid-template-columns: repeat(2, 1fr); }
  .solutions-links { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════════
   COMPLIANCE & SECURITY PAGE
   ════════════════════════════════════════════════════════════════ */

/* Hero */
.comp-hero { position: relative; }

.comp-hero__lede {
  max-width: 64ch;
  font-size: clamp(0.95rem, 1.2vw, 1.1rem);
  color: var(--text-soft);
  line-height: 1.7;
  margin: 12px 0 24px;
}

/* Compliance badge strip */
.comp-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.comp-badge {
  padding: 5px 13px;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: rgba(79,70,229,0.08);
  border: 1px solid rgba(79,70,229,0.18);
  color: var(--indigo);
  transition: all 120ms ease;
}

.comp-badge:hover {
  background: rgba(79,70,229,0.14);
}

/* Trust metric strip */
.metric-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.metric-panel {
  padding: 20px 24px;
  background: rgba(255,255,255,0.9);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

html[data-theme="dark"] .metric-panel {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.metric-panel strong {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.4rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--indigo);
}

.metric-panel span {
  font-size: 0.78rem;
  color: var(--text-soft);
  font-weight: 600;
}

/* Certification cards */
.coverage-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.coverage-card {
  padding: 24px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  border-top: 3px solid var(--indigo);
  transition: transform 130ms ease;
}

.coverage-card:hover { transform: translateY(-2px); }

html[data-theme="dark"] .coverage-card {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.coverage-card h3 {
  font-size: 1rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 10px;
}

.coverage-card p {
  font-size: 0.85rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin: 0;
}

/* Top border accent colours */
.coverage-card--indigo { border-top-color: #4f46e5; }
.coverage-card--violet { border-top-color: #7c3aed; }
.coverage-card--rose   { border-top-color: #f43f5e; }
.coverage-card--teal   { border-top-color: #0d9488; }
.coverage-card--amber  { border-top-color: #d97706; }

/* Data & privacy service cards */
.service-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.service-card {
  padding: 22px 24px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform 130ms ease;
}

.service-card:hover { transform: translateY(-2px); }

html[data-theme="dark"] .service-card {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.card-kicker {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--indigo);
  margin: 0 0 6px;
}

.service-card h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 8px;
}

.service-card p {
  font-size: 0.82rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0;
}

/* Sentrise / module cards */
.module-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.module-card {
  padding: 24px 26px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform 130ms ease;
}

.module-card:hover { transform: translateY(-2px); }

html[data-theme="dark"] .module-card {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.module-card__eyebrow {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 6px;
}

.module-card--rose   .module-card__eyebrow { color: #f43f5e; }
.module-card--violet .module-card__eyebrow { color: #7c3aed; }
.module-card--indigo .module-card__eyebrow { color: #4f46e5; }
.module-card--teal   .module-card__eyebrow { color: #0d9488; }

.module-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 8px;
}

.module-card > p {
  font-size: 0.85rem;
  color: var(--text-soft);
  line-height: 1.6;
  margin: 0 0 14px;
}

/* Detail list (bullet points inside module cards) */
.detail-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.detail-list li {
  font-size: 0.8rem;
  color: var(--text-soft);
  padding-left: 16px;
  position: relative;
  line-height: 1.4;
}

.detail-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #16a34a;
  font-size: 0.75rem;
  font-weight: 700;
}

.detail-list--tight { gap: 4px; }

/* Compliance FAQ grid */
.comp-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.comp-faq-card {
  padding: 22px 24px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-soft);
}

html[data-theme="dark"] .comp-faq-card {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.comp-faq-card h3 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 8px;
}

.comp-faq-card p {
  font-size: 0.82rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin: 0;
}

@media (max-width: 1000px) {
  .coverage-grid { grid-template-columns: repeat(2, 1fr); }
  .service-grid  { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 700px) {
  .metric-strip   { grid-template-columns: repeat(2, 1fr); }
  .module-grid    { grid-template-columns: 1fr; }
  .comp-faq-grid  { grid-template-columns: 1fr; }
  .coverage-grid  { grid-template-columns: 1fr; }
  .service-grid   { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════════
   ANNUAL REPORT PAGE
   ════════════════════════════════════════════════════════════════ */

/* The page uses mostly inline styles — just provide the responsive
   grid override that the inline <style> tag already handles,
   plus polish the sticky form card */

.report-grid {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 4rem;
  align-items: start;
}

.report-grid > div:last-child {
  position: sticky;
  top: 5rem;
}

@media (max-width: 840px) {
  .report-grid {
    grid-template-columns: 1fr;
  }
  .report-grid > div:last-child {
    position: static;
  }
}

/* ════════════════════════════════════════════════════════════════
   CONTACT / BOOK A DEMO PAGE  (highest-priority conversion page)
   ════════════════════════════════════════════════════════════════ */

/* Hero */
.demo-hero {
  text-align: center;
}

.demo-hero h1 {
  font-size: clamp(2rem, 4vw, 3rem);
}

.demo-hero .hero__dot {
  color: var(--indigo);
}

.demo-hero__lede {
  max-width: 58ch;
  margin: 12px auto 0;
  font-size: clamp(0.95rem, 1.1vw, 1.05rem);
  color: var(--text-soft);
  line-height: 1.7;
}

/* What-happens-next steps strip */
.demo-steps {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.demo-step {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-soft);
}

html[data-theme="dark"] .demo-step {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

.demo-step__num {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.78rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.demo-step strong {
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--navy);
}

.demo-step span {
  font-size: 0.76rem;
  color: var(--text-soft);
  line-height: 1.35;
}

.demo-step__arrow {
  font-size: 1.2rem;
  color: var(--text-faint);
  flex-shrink: 0;
}

/* Main 2-col layout */
.demo-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 48px;
  align-items: start;
}

/* Form wrap */
.demo-form-wrap {
  padding: 32px 36px;
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 8px 40px rgba(79,70,229,0.08);
}

html[data-theme="dark"] .demo-form-wrap {
  background: rgba(18,23,38,0.95);
  border-color: rgba(99,120,200,0.18);
}

.demo-form-wrap h2 {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--navy);
  margin: 16px 0 4px;
}

.demo-form-wrap__sub {
  font-size: 0.85rem;
  color: var(--text-soft);
  margin: 0 0 24px;
}

/* 2-step progress indicator */
.demo-form-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 4px;
}

.demo-form-step {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
}

.demo-form-step__num {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--line);
  color: var(--text-faint);
  font-size: 0.72rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 200ms ease;
  flex-shrink: 0;
}

.demo-form-step--active .demo-form-step__num {
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
}

.demo-form-step--done .demo-form-step__num {
  background: #16a34a;
  color: #fff;
}

.demo-form-step__label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-faint);
  transition: color 200ms ease;
}

.demo-form-step--active .demo-form-step__label { color: var(--navy); }
.demo-form-step--done  .demo-form-step__label { color: #16a34a; }

.demo-form-step__line {
  flex: 1;
  height: 2px;
  background: var(--line);
  margin: 0 10px;
}

/* Form fields */
.demo-form__step {
  border: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.demo-form__row {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.demo-form__row label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--navy);
}

.demo-form__row label span[aria-hidden] {
  color: var(--rose);
  margin-left: 2px;
}

.demo-form__opt {
  font-weight: 400;
  color: var(--text-faint);
  font-size: 0.78rem;
}

.demo-form input,
.demo-form select,
.demo-form textarea {
  width: 100%;
  padding: 11px 14px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 8px;
  color: var(--text-body);
  font-size: 0.9rem;
  font-family: inherit;
  transition: border-color 120ms ease, box-shadow 120ms ease;
  appearance: none;
}

.demo-form input:focus,
.demo-form select:focus,
.demo-form textarea:focus {
  outline: none;
  border-color: var(--indigo);
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1);
}

.demo-form input:invalid:not(:placeholder-shown),
.demo-form select:invalid {
  border-color: var(--rose);
}

.demo-form textarea { resize: vertical; min-height: 80px; }

.demo-form__error {
  font-size: 0.75rem;
  color: var(--rose);
  font-weight: 600;
  display: none;
}

.demo-form__next,
.demo-form__submit {
  width: 100%;
  justify-content: center;
  gap: 8px;
  margin-top: 4px;
}

.demo-form__step-note {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: var(--text-faint);
  margin: 0;
}

.demo-form__privacy {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.76rem;
  color: var(--text-faint);
}

.demo-form__privacy a { color: var(--indigo); }

.demo-form__step2-actions {
  display: flex;
  gap: 10px;
}

.demo-form__back { flex-shrink: 0; }
.demo-form__submit { flex: 1; }

/* Success state */
.demo-form__success {
  padding: 24px;
  text-align: center;
}

.demo-form__success-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(34,197,94,0.1);
  border: 2px solid rgba(34,197,94,0.3);
  color: #22c55e;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
}

.demo-form__success h3 {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 8px;
}

.demo-form__success p { color: var(--text-soft); font-size: 0.9rem; }
.demo-form__success-note { font-size: 0.82rem !important; margin-top: 12px; }
.demo-form__success-note a { color: var(--indigo); }

/* Sidebar */
.demo-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: 108px;
}

.demo-sidebar__block {
  padding: 20px 22px;
  background: rgba(255,255,255,0.88);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-soft);
}

html[data-theme="dark"] .demo-sidebar__block {
  background: rgba(18,23,38,0.9);
  border-color: rgba(99,120,200,0.15);
}

/* Trust badge grid */
.trust-badges {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}

.trust-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: rgba(79,70,229,0.04);
  border: 1px solid rgba(79,70,229,0.1);
  border-radius: 8px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--navy);
}

.trust-badge svg { color: var(--indigo); flex-shrink: 0; }

/* What to bring list */
.demo-sidebar__list {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.demo-sidebar__list li {
  font-size: 0.82rem;
  color: var(--text-soft);
  padding-left: 16px;
  position: relative;
  line-height: 1.45;
}

.demo-sidebar__list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--indigo);
  font-size: 0.72rem;
}

/* Sidebar quote */
.demo-sidebar__quote {
  margin: 0;
  padding: 18px 20px;
  background: rgba(79,70,229,0.04);
  border-left: 3px solid var(--indigo);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.demo-sidebar__quote p {
  font-size: 0.85rem;
  font-style: italic;
  color: var(--navy);
  line-height: 1.6;
  margin: 0 0 8px;
}

.demo-sidebar__quote footer {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--text-soft);
}

/* Direct email link */
.demo-sidebar__contact { padding: 16px 20px; }

.demo-sidebar__email {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--indigo);
  text-decoration: none;
  margin-top: 6px;
  transition: opacity 120ms ease;
}

.demo-sidebar__email:hover { opacity: 0.75; }

/* Metric anchor strip */
.demo-metric-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.demo-metric {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: center;
}

.demo-metric strong {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.demo-metric span {
  font-size: 0.78rem;
  color: var(--text-soft);
  font-weight: 600;
  line-height: 1.3;
}

/* Contact responsive */
@media (max-width: 960px) {
  .demo-layout { grid-template-columns: 1fr; }
  .demo-sidebar { position: static; }
}

@media (max-width: 700px) {
  .demo-metric-strip { grid-template-columns: repeat(2, 1fr); }
  .demo-form-wrap { padding: 22px 20px; }
  .trust-badges { grid-template-columns: 1fr; }
  .demo-steps { flex-direction: column; align-items: stretch; }
  .demo-step__arrow { display: none; }
}

/* ════════════════════════════════════════════════════════════════
   LEGAL PAGES  (Privacy Policy + Terms)
   ════════════════════════════════════════════════════════════════ */

/* Two-column layout — nav + body */
.legal-layout {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 52px;
  align-items: start;
}

/* Sticky side nav */
.legal-nav {
  position: sticky;
  top: 108px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.legal-nav a {
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-soft);
  text-decoration: none;
  transition: all 120ms ease;
  border: 1px solid transparent;
}

.legal-nav a:hover {
  background: rgba(79,70,229,0.06);
  color: var(--indigo);
  border-color: rgba(79,70,229,0.12);
}

.legal-nav a.is-active {
  background: rgba(79,70,229,0.08);
  color: var(--indigo);
  border-color: rgba(79,70,229,0.18);
}

/* Legal body typography */
.legal-body {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.legal-section h2 {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(79,70,229,0.1);
}

.legal-section h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin: 20px 0 8px;
}

.legal-section p,
.legal-section li {
  font-size: 0.9rem;
  color: var(--text-soft);
  line-height: 1.75;
  margin-bottom: 8px;
}

.legal-section ul {
  padding-left: 1.25rem;
  margin: 0 0 8px;
}

.legal-section ul li { margin-bottom: 4px; }

.legal-section address {
  font-style: normal;
  font-size: 0.9rem;
  color: var(--text-soft);
  line-height: 1.7;
  padding: 14px 18px;
  background: rgba(79,70,229,0.04);
  border-left: 3px solid var(--indigo);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.legal-section a { color: var(--indigo); }

/* Legal data tables */
.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid var(--line);
  margin: 12px 0;
}

.legal-table thead {
  background: var(--navy);
  color: #fff;
}

.legal-table thead th {
  padding: 10px 14px;
  text-align: left;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.legal-table tbody tr {
  border-bottom: 1px solid var(--line);
}

.legal-table tbody tr:last-child { border-bottom: none; }

.legal-table tbody tr:hover {
  background: rgba(79,70,229,0.03);
}

.legal-table td {
  padding: 10px 14px;
  color: var(--text-soft);
  vertical-align: top;
}

/* Cookie settings inline button */
.legal-cookie-btn {
  background: none;
  border: 1px solid var(--indigo);
  color: var(--indigo);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  cursor: pointer;
  font-family: inherit;
  transition: all 120ms ease;
}

.legal-cookie-btn:hover {
  background: rgba(79,70,229,0.08);
}

/* Legal responsive */
@media (max-width: 820px) {
  .legal-layout { grid-template-columns: 1fr; }
  .legal-nav {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px;
  }
  .legal-nav a { font-size: 0.76rem; padding: 5px 9px; }
}

/* ════════════════════════════════════════════════════════════════
   COMPLIANCE QUIZ PAGE
   ════════════════════════════════════════════════════════════════ */

/* Quiz option buttons — CSS polish over inline JS-applied styles */
.quiz-option {
  text-align: left;
  padding: 0.9rem 1.1rem;
  border: 1.5px solid var(--line);
  border-radius: 10px;
  background: transparent;
  color: var(--text-body);
  cursor: pointer;
  transition: border-color 150ms ease, background 150ms ease;
  font-size: 0.95rem;
  width: 100%;
  font-family: inherit;
  display: flex;
  align-items: center;
  gap: 12px;
}

.quiz-option:hover {
  border-color: var(--indigo);
  background: rgba(79,70,229,0.03);
}

.quiz-option.selected {
  border-color: var(--indigo) !important;
  background: rgba(79,70,229,0.07) !important;
}

/* Quiz slide transition */
.quiz-slide {
  animation: quizFadeIn 200ms ease;
}

@keyframes quizFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ════════════════════════════════════════════════════════════════
   FAQ PAGE — Active scroll highlight JS hook
   (The JS below is appended to page-faq.php separately)
   ════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════
   CLIENT LOGO STRIP — "Trusted by" social proof section
   ════════════════════════════════════════════════════════════════ */

.client-logo-strip {
  background: var(--surface);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.client-logo-strip__label {
  text-align: center;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-soft);
  margin-bottom: 1.5rem;
}

.client-logo-strip__grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1rem 2.5rem;
  margin-bottom: 2rem;
}

.client-logo {
  display: flex;
  align-items: center;
  opacity: 0.55;
  color: var(--text);
  transition: opacity 0.2s;
  filter: grayscale(1);
}

.client-logo:hover {
  opacity: 0.85;
  filter: grayscale(0);
}

/* ── Review trust bar (G2 + Trustpilot) ── */
.client-logo-strip__reviews {
  display: flex;
  justify-content: center;
}

.review-trust-bar {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem 1.5rem;
  background: var(--surface-strong);
  border: 1px solid var(--line);
  border-radius: 999px;
  flex-wrap: wrap;
  justify-content: center;
}

.review-trust-bar__item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.82rem;
}

.review-trust-bar__stars {
  display: flex;
  gap: 1px;
}

.review-trust-bar__score {
  font-weight: 700;
  color: var(--text);
  font-size: 0.85rem;
}

.review-trust-bar__source {
  color: var(--text-soft);
  font-size: 0.78rem;
}

.review-trust-bar__source em {
  font-style: italic;
  opacity: 0.7;
  font-size: 0.72rem;
}

.review-trust-bar__divider {
  width: 1px;
  height: 20px;
  background: var(--line);
}

.review-trust-bar__total {
  font-size: 0.78rem;
  color: var(--text-soft);
}

[data-theme="dark"] .client-logo-strip {
  background: rgba(255,255,255,0.03);
}

[data-theme="dark"] .review-trust-bar {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.08);
}

@media (max-width: 600px) {
  .review-trust-bar { border-radius: 12px; }
  .review-trust-bar__divider { display: none; }
}

/* ════════════════════════════════════════════════════════════════
   EXIT-INTENT POPUP — Lead capture modal (Annual Report)
   ════════════════════════════════════════════════════════════════ */

.exit-popup {
  position: fixed;
  inset: 0;
  z-index: 9800;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.exit-popup[hidden] { display: none; }

.exit-popup__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 12, 40, 0.72);
  backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity 0.3s;
}

.exit-popup.is-visible .exit-popup__backdrop { opacity: 1; }

.exit-popup__box {
  position: relative;
  z-index: 1;
  background: var(--surface-strong);
  border: 1px solid var(--line);
  border-radius: 20px;
  max-width: 860px;
  width: 100%;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(10,12,40,0.35), 0 0 0 1px rgba(79,70,229,0.12);
  transform: translateY(24px) scale(0.97);
  opacity: 0;
  transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1), opacity 0.3s;
}

.exit-popup.is-visible .exit-popup__box {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.exit-popup__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}

.exit-popup__close:hover {
  background: var(--indigo);
  color: #fff;
  border-color: var(--indigo);
}

.exit-popup__inner {
  display: grid;
  grid-template-columns: 1fr 280px;
  min-height: 400px;
}

.exit-popup__copy {
  padding: 2.5rem;
}

.exit-popup__title {
  font-size: clamp(1.35rem, 3vw, 1.75rem);
  font-weight: 800;
  color: var(--text);
  line-height: 1.2;
  margin: 0.5rem 0 0.75rem;
}

.exit-popup__lede {
  font-size: 0.92rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin-bottom: 1rem;
}

.exit-popup__bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.exit-popup__bullets li {
  font-size: 0.85rem;
  color: var(--text-soft);
}

.exit-popup__fields {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 0.75rem;
}

.exit-popup__input {
  width: 100%;
  padding: 0.65rem 0.9rem;
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  background: var(--bg);
  color: var(--text);
  font-size: 0.9rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  box-sizing: border-box;
}

.exit-popup__input:focus {
  border-color: var(--indigo);
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1);
}

.exit-popup__error {
  color: #e11d48;
  font-size: 0.82rem;
  margin: 0.25rem 0;
}

.exit-popup__privacy {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  font-size: 0.75rem;
  color: var(--text-soft);
  margin-top: 0.6rem;
  line-height: 1.5;
}

.exit-popup__privacy svg {
  flex-shrink: 0;
  margin-top: 2px;
}

/* Success state */
.exit-popup__success {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1rem 0;
}

.exit-popup__success-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #dcfce7;
  border: 2px solid #86efac;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #16a34a;
  margin-bottom: 1rem;
}

[data-theme="dark"] .exit-popup__success-icon {
  background: rgba(22,163,74,0.15);
  border-color: rgba(134,239,172,0.3);
}

.exit-popup__success h3 { margin: 0 0 0.5rem; font-size: 1.1rem; }
.exit-popup__success p  { font-size: 0.88rem; color: var(--text-soft); margin: 0; }

/* Right visual panel */
.exit-popup__visual {
  background: linear-gradient(160deg, #11183a 0%, #1e1b4b 40%, #2e1065 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  position: relative;
  overflow: hidden;
}

.exit-popup__report-cover {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  width: 100%;
}

.exit-popup__report-mock {
  width: 100%;
  aspect-ratio: 3/4;
  max-width: 200px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(199,210,254,0.2);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  position: relative;
  overflow: hidden;
  padding: 1.5rem 1rem;
}

.exit-popup__report-stripe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 6px;
  background: linear-gradient(90deg, #4F46E5, #7C3AED);
}

.exit-popup__report-stripe--2 {
  top: 10px;
  height: 3px;
  opacity: 0.4;
}

.exit-popup__report-year {
  font-size: 2.5rem;
  font-weight: 800;
  color: rgba(199,210,254,0.9);
  margin: 0;
  line-height: 1;
}

.exit-popup__report-sub {
  font-size: 0.68rem;
  color: rgba(199,210,254,0.55);
  text-align: center;
  line-height: 1.4;
  margin: 0;
}

.exit-popup__report-badge {
  display: inline-block;
  padding: 0.3rem 0.8rem;
  background: rgba(79,70,229,0.2);
  border: 1px solid rgba(79,70,229,0.4);
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  color: rgba(199,210,254,0.8);
}

/* Responsive */
@media (max-width: 640px) {
  .exit-popup__inner {
    grid-template-columns: 1fr;
  }
  .exit-popup__visual {
    display: none;
  }
  .exit-popup__copy {
    padding: 1.75rem 1.25rem;
  }
}

body.exit-popup-open {
  overflow: hidden;
}

[data-theme="dark"] .exit-popup__box {
  background: var(--surface-dark);
  border-color: rgba(255,255,255,0.08);
}

[data-theme="dark"] .exit-popup__input {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.12);
  color: #e2e8f0;
}

/* Already defined: .faq-nav__link.is-active — just note it's driven by IntersectionObserver */

/* ── Front page: What's New slider ───────────────────────── */
.whats-new-banner {
  padding-top: 1.5rem;
}

.whats-new-banner__shell {
  display: grid;
  gap: 1.4rem;
}

.whats-new-banner__intro {
  display: grid;
  gap: 0.75rem;
  max-width: 900px;
}

.whats-new-banner__intro h2 {
  margin: 0;
  font-size: clamp(1.7rem, 4vw, 2.65rem);
  line-height: 1.08;
  color: var(--text);
}

.whats-new-banner__lede {
  margin: 0;
  max-width: 720px;
  color: var(--text-soft);
  font-size: 1rem;
  line-height: 1.75;
}

.whats-new-slider {
  position: relative;
  border-radius: 28px;
  border: 1px solid rgba(79,70,229,0.18);
  background:
    radial-gradient(circle at top right, rgba(13,148,136,0.16), transparent 34%),
    radial-gradient(circle at left center, rgba(79,70,229,0.14), transparent 32%),
    linear-gradient(145deg, rgba(8,15,38,0.98), rgba(16,24,52,0.96));
  box-shadow: 0 34px 90px rgba(3, 7, 18, 0.24);
  overflow: hidden;
}

.whats-new-slider__viewport {
  position: relative;
  min-height: 420px;
}

.whats-new-slider__track {
  position: relative;
  min-height: inherit;
}

.whats-new-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transform: translateX(24px);
  transition: opacity 0.42s ease, transform 0.42s ease;
  padding: 2rem;
}

.whats-new-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  position: relative;
  transform: translateX(0);
}

.whats-new-slide__content {
  display: grid;
  gap: 1.2rem;
  min-height: 100%;
  align-content: center;
  max-width: 900px;
}

.whats-new-slide__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.8rem;
}

.whats-new-slide__eyebrow,
.whats-new-slide__meta,
.whats-new-slide__signal {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border-radius: 999px;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}

.whats-new-slide__eyebrow {
  padding: 0.45rem 0.9rem;
  background: rgba(79,70,229,0.14);
  border: 1px solid rgba(129,140,248,0.24);
  color: #a5b4fc;
  text-transform: uppercase;
  font-weight: 800;
}

.whats-new-slide__meta {
  padding: 0.45rem 0.9rem;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(226,232,240,0.85);
}

.whats-new-slide h3 {
  margin: 0;
  font-size: clamp(1.9rem, 4vw, 3.15rem);
  line-height: 1.04;
  color: #f8fafc;
  max-width: 16ch;
}

.whats-new-slide h3 a {
  color: inherit;
  text-decoration: none;
}

.whats-new-slide h3 a:hover {
  color: #c7d2fe;
}

.whats-new-slide p {
  margin: 0;
  max-width: 72ch;
  color: rgba(226,232,240,0.84);
  font-size: 1rem;
  line-height: 1.78;
}

.whats-new-slide__signals {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.whats-new-slide__signal {
  padding: 0.5rem 0.85rem;
  background: rgba(13,148,136,0.12);
  border: 1px solid rgba(45,212,191,0.2);
  color: #99f6e4;
  font-weight: 600;
}

.whats-new-slide__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-top: 0.2rem;
}

.whats-new-slider__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0 2rem 1.8rem;
}

.whats-new-slider__controls,
.whats-new-slider__dots {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.whats-new-slider__control,
.whats-new-slider__dot {
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  cursor: pointer;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.whats-new-slider__control {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  color: #e2e8f0;
  font-size: 1rem;
}

.whats-new-slider__control:hover,
.whats-new-slider__dot:hover,
.whats-new-slider__control:focus-visible,
.whats-new-slider__dot:focus-visible {
  border-color: rgba(129,140,248,0.55);
  background: rgba(79,70,229,0.18);
  transform: translateY(-1px);
  outline: none;
}

.whats-new-slider__dot {
  width: 11px;
  height: 11px;
  border-radius: 999px;
  padding: 0;
}

.whats-new-slider__dot.is-active {
  width: 34px;
  background: linear-gradient(90deg, #4f46e5, #14b8a6);
  border-color: transparent;
}

@media (max-width: 860px) {
  .whats-new-slide {
    padding: 1.5rem;
  }

  .whats-new-slider__viewport {
    min-height: 500px;
  }

  .whats-new-slider__footer {
    padding: 0 1.5rem 1.5rem;
  }
}

@media (max-width: 640px) {
  .whats-new-banner {
    padding-top: 1rem;
  }

  .whats-new-slider__viewport {
    min-height: 560px;
  }

  .whats-new-slide h3 {
    max-width: none;
  }

  .whats-new-slide__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .whats-new-slide__actions .button {
    width: 100%;
    justify-content: center;
  }

  .whats-new-slider__footer {
    flex-direction: column;
    align-items: stretch;
  }
}
