/* ══════════════════════════════════════════════════════════
   ACCELERAID — Design System
   Rebuilt to match Webflow template exactly
   April 2026
   ══════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════
   SECTION 1 — DESIGN TOKENS
   ═══════════════════════════════════════════════════════════ */

:root {
  /* ── Brand palette ──────────────────────────────────── */
  --blue:   #1D92FF;
  --navy:   #192B45;
  --dark:   #192B45;
  --fog:    #F4FAFF;
  --cloud:  #DDEFFF;

  /* ── Semantic tokens ────────────────────────────────── */
  --color-primary:       #1D92FF;
  --color-primary-hover: #0D7EF0;
  --color-primary-dark:  #0A5FD6;
  --color-primary-light: #EBF5FF;
  --color-primary-mid:   #BAE0FF;
  --color-secondary:     #5717EA;
  --color-secondary-hover: #4710C7;
  --color-secondary-light: #EDE9FF;
  --color-text:          #283149;
  --color-text-body:     #283149;
  --color-text-muted:    #6D7483;
  --color-text-faint:    #9BABBE;
  --color-text-inverse:  #FFFFFF;
  --color-bg:            #FFFFFF;
  --color-surface:       #F8FBFF;
  --color-surface-2:     #F4FAFF;
  --color-surface-offset: #EEF6FF;
  --color-divider:       rgba(29,146,255,0.12);
  --color-border:        #DDE6F0;
  --color-success:       #00B87A;
  --color-warning:       #FFD221;
  --green:               #00B87A;

  /* ── Product colors ─────────────────────────────────── */
  --color-product-cdp:        #5717EA;
  --color-product-prediction: #5717ea;
  --color-product-clm:        #fd8006;
  --color-product-experience: #1d92ff;
  --color-product-reporting:  #19add0;
  --color-product-genai:      #24C774;

  /* ── Hero background (measured from screenshot) ─────── */
  --hero-bg: linear-gradient(
    145deg,
    #EEF3F7 0%,
    #E8F2FE 20%,
    #EDF5FF 45%,
    #F5F9FF 70%,
    #FAFCFF 85%,
    #FFFFFF 100%
  );
  /* Legacy aliases */
  --hero-gradient: linear-gradient(180deg, #f7faff 0%, #ffffff 60%);
  --hero-radial: radial-gradient(ellipse at 10% 50%, rgba(29,146,255,0.06) 0%, transparent 60%),
                 radial-gradient(ellipse at 85% 15%, rgba(87,23,234,0.03) 0%, transparent 50%);

  /* ── Typography ─────────────────────────────────────── */
  --font-body:    'Geist', system-ui, 'Helvetica Neue', Arial, sans-serif;
  --font-display: 'Geist', system-ui, 'Helvetica Neue', Arial, sans-serif;

  /* ── Type scale (fluid) ─────────────────────────────── */
  --text-xs:   clamp(0.72rem,  0.68rem + 0.2vw,   0.82rem);
  --text-sm:   clamp(0.85rem,  0.80rem + 0.25vw,  0.95rem);
  --text-base: clamp(0.95rem,  0.90rem + 0.25vw,  1.05rem);
  --text-lg:   clamp(1.1rem,   1.0rem  + 0.5vw,   1.35rem);
  --text-xl:   clamp(1.35rem,  1.1rem  + 1.25vw,  1.9rem);
  --text-2xl:  clamp(1.75rem,  1.2rem  + 2.75vw,  3.25rem);
  --text-3xl:  clamp(2.4rem,   1.5rem  + 4.5vw,   5rem);
  --text-hero: clamp(2.8rem,   1.6rem  + 6vw,     5.5rem);

  /* ── Spacing (4px grid) ─────────────────────────────── */
  --s-1:  0.25rem;
  --s-2:  0.5rem;
  --s-3:  0.75rem;
  --s-4:  1rem;
  --s-5:  1.25rem;
  --s-6:  1.5rem;
  --s-8:  2rem;
  --s-10: 2.5rem;
  --s-12: 3rem;
  --s-16: 4rem;
  --s-20: 5rem;
  --s-24: 6rem;
  /* Legacy aliases */
  --space-1:  0.25rem; --space-2:  0.5rem;  --space-3:  0.75rem;
  --space-4:  1rem;    --space-5:  1.25rem; --space-6:  1.5rem;
  --space-7:  1.75rem; --space-8:  2rem;    --space-10: 2.5rem;
  --space-12: 3rem;    --space-16: 4rem;    --space-20: 5rem;
  --space-24: 6rem;    --space-32: 8rem;

  /* ── Radius ──────────────────────────────────────────── */
  --radius-sm:  6px;
  --radius-md:  10px;
  --radius-lg:  14px;
  --radius-xl:  20px;
  --radius-2xl: 28px;
  --radius-full: 9999px;

  /* ── Shadows ─────────────────────────────────────────── */
  --shadow-sm:   0 1px 3px rgba(25,43,69,0.06), 0 1px 2px rgba(25,43,69,0.04);
  --shadow-md:   0 4px 12px rgba(25,43,69,0.08), 0 2px 6px rgba(25,43,69,0.04);
  --shadow-lg:   0 12px 32px rgba(25,43,69,0.10), 0 4px 12px rgba(25,43,69,0.06);
  --shadow-xl:   0 20px 60px rgba(25,43,69,0.12), 0 8px 20px rgba(25,43,69,0.06);
  --shadow-blue: 0 4px 20px rgba(29,146,255,0.22);
  --shadow-blue-lg: 0 8px 40px rgba(29,146,255,0.28);
  --shadow-card: 0 2px 8px rgba(0,0,0,0.06), 0 0 0 1px rgba(0,0,0,0.04);
  --shadow-card-hover: 0 8px 24px rgba(29,146,255,0.14), 0 0 0 1px rgba(29,146,255,0.1);

  /* ── Easing ──────────────────────────────────────────── */
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --t-fast: 150ms;
  --t-base: 220ms;
  --t-slow: 380ms;
  --transition-interactive: 180ms cubic-bezier(0.16, 1, 0.3, 1);

  /* ── Layout ──────────────────────────────────────────── */
  --w-narrow:  680px;
  --w-default: 1000px;
  --w-wide:    1280px;
  --w-max:     1440px;
  --w-full:    100%;
  /* Legacy alias */
  --content-wide: 1280px;
}

/* ═══════════════════════════════════════════════════════════
   SECTION 2 — BASE RESET
   ═══════════════════════════════════════════════════════════ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
  hanging-punctuation: first last;
}
body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.65;
  min-height: 100dvh;
}
img, video, svg { display: block; max-width: 100%; height: auto; }
h1, h2, h3, h4, h5, h6 {
  line-height: 1.12;
  text-wrap: balance;
  font-family: var(--font-display);
  font-optical-sizing: auto;
  color: var(--color-text);
}
p, li { text-wrap: pretty; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; background: none; border: none; font: inherit; color: inherit; }
input, textarea, select { font: inherit; color: inherit; }
ul[role="list"], ol[role="list"] { list-style: none; padding: 0; }
::selection { background: rgba(29,146,255,0.18); color: var(--color-text); }
:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 3px; border-radius: var(--radius-sm); }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ═══════════════════════════════════════════════════════════
   SECTION 3 — LAYOUT
   ═══════════════════════════════════════════════════════════ */

.container {
  width: 100%;
  max-width: var(--w-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--s-5), 5vw, var(--s-16));
}
.container--narrow {
  width: 100%;
  max-width: var(--w-narrow);
  margin-inline: auto;
  padding-inline: clamp(var(--s-5), 5vw, var(--s-16));
}
.container--wide {
  width: 100%;
  max-width: var(--w-max);
  margin-inline: auto;
  padding-inline: clamp(var(--s-5), 5vw, var(--s-16));
}
.container--full   { max-width: none; }

.section { padding-block: clamp(var(--s-12), 7vw, var(--s-24)); }
.section--white   { background: #fff; }
.section--gray    { background: #f4f7fd; }
.section--fog     { background: var(--fog); }
.section--surface { background: var(--color-surface-2); }
.section--grid-bg {
  background-image:
    linear-gradient(rgba(29,146,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(29,146,255,0.04) 1px, transparent 1px);
  background-size: 48px 48px;
  background-color: var(--fog);
}

.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-8); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-6); }
.split-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(var(--space-10), 6vw, var(--space-20));
  align-items: center;
}
.split-2 .split-visual {
  font-size: 8rem;
  text-align: center;
  background: var(--color-surface-2);
  border-radius: var(--radius-2xl);
  aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
}
.split-2.reverse { direction: rtl; }
.split-2.reverse > * { direction: ltr; }
.text-center { text-align: center; }
.text-center p, .text-center li { margin-inline: auto; }

@media (max-width: 960px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .split-2 { grid-template-columns: 1fr; }
  .split-2 .split-visual { aspect-ratio: 2/1; }
  .grid-4 { grid-template-columns: 1fr 1fr; }
  .grid-3 { gap: 20px; }
}
@media (max-width: 600px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* Inline-grid mobile safety net.
   Inline style="grid-template-columns:..." bypasses .grid-N rules.
   For repeat(N,1fr): `1fr` is `minmax(auto, 1fr)`, so card content forces
   columns wider than viewport. For fixed-px columns (e.g. 220px 60px 1fr):
   the diagram exceeds viewport directly. Either way → page horizontal overflow.
   Override at the same breakpoints as .grid-3/.grid-4. */
@media (max-width: 1024px) {
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns: repeat(4"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(3"] {
    grid-template-columns: 1fr 1fr !important;
  }
}
@media (max-width: 768px) {
  [style*="grid-template-columns:220px"],
  [style*="grid-template-columns: 220px"] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  [style*="grid-template-columns:220px"] > :nth-child(2),
  [style*="grid-template-columns: 220px"] > :nth-child(2) {
    display: none !important;
  }
}
@media (max-width: 640px) {
  [style*="grid-template-columns:repeat"],
  [style*="grid-template-columns: repeat"] {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
}

/* Responsive utilities */
@media (max-width: 640px) {
  .hide-mobile { display: none !important; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn { width: 100%; justify-content: center; }
}
@media (min-width: 641px) {
  .show-mobile { display: none !important; }
}

/* ═══════════════════════════════════════════════════════════
   SECTION 4 — TYPOGRAPHY COMPONENTS
   ═══════════════════════════════════════════════════════════ */

.section-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--s-4);
  line-height: 1;
}
/* section-label dot removed per design feedback */
.section-label::before {
  display: none;
}
.section-header { margin-bottom: var(--s-10); }
.section-title {
  font-size: var(--text-2xl);
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: var(--s-4);
}
.section-subtitle {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.72;
  max-width: 58ch;
}
.text-center .section-subtitle { margin-inline: auto; }
.heading-accent {
  background: linear-gradient(135deg, #1D92FF 0%, #5717EA 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
}
.heading-muted { color: var(--color-text-muted); font-weight: 400; display: block; }
.heading-bold-line { display: block; font-weight: 800; }

/* Hero eyebrow */
.hero-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: -8px;
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  margin-bottom: var(--space-4);
}
.breadcrumb a { color: var(--color-primary); }
.breadcrumb-sep { color: var(--color-text-faint); }

/* Stat strip */
.stat-strip {
  background: var(--color-surface-2);
  border-top: 1px solid var(--color-divider);
  border-bottom: 1px solid var(--color-divider);
  padding-block: clamp(var(--space-8), 4vw, var(--space-12));
}
.stat-strip-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  text-align: center;
}
@media (max-width: 768px) { .stat-strip-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .stat-strip-grid { grid-template-columns: 1fr; } }
.stat-val {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xl);
  color: var(--color-primary);
  line-height: 1;
  margin-bottom: var(--space-2);
}
.stat-lbl { font-size: var(--text-sm); color: var(--color-text-muted); font-weight: 500; }

/* ═══════════════════════════════════════════════════════════
   SECTION 5 — NAVIGATION
   ═══════════════════════════════════════════════════════════ */

.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 500;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition:
    background var(--t-base) var(--ease),
    border-color var(--t-base) var(--ease),
    box-shadow var(--t-base) var(--ease);
}
.nav.scrolled {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border-bottom-color: rgba(29,146,255,0.10);
  box-shadow: 0 1px 0 rgba(0,0,0,0.04), 0 4px 16px rgba(25,43,69,0.06);
}
.nav-inner {
  display: flex;
  align-items: center;
  height: 72px;
  max-width: var(--w-max);
  margin-inline: auto;
  padding-inline: clamp(var(--s-5), 5vw, var(--s-12));
  gap: var(--s-6);
}
.nav-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  margin-right: auto;
  background: none;
  border: none;
  box-shadow: none;
}
.nav-logo * {
  background: none;
  box-shadow: none;
  border: none;
}
.nav-logo img {
  background: none;
  border: none;
  box-shadow: none;
  padding: 0;
}
.nav-logo-img,
#nav-logo-img {
  height: 52px !important;
  width: auto !important;
  display: block;
  object-fit: contain;
}
.nav-links {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0;
}
.nav-links > li {
  display: flex;
  align-items: center;
}
.nav-link,
.nav-link-has-dropdown {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: color var(--t-fast), background var(--t-fast);
  white-space: nowrap;
  cursor: pointer;
  background: none;
  border: none;
  font-family: var(--font-body);
  line-height: 1;
  z-index: 1;
}
.nav-link:hover,
.nav-link-has-dropdown:hover {
  color: var(--color-primary);
  background: rgba(29,146,255,0.06);
}
/* Underline on nav links (only when scrolled / visible) */
.nav-link:not(.nav-link-has-dropdown):not(.nav-link--no-href)::after {
  content: '';
  display: block;
  height: 2px;
  width: 0;
  background: var(--color-primary);
  border-radius: 2px;
  transition: width 0.25s cubic-bezier(0.16,1,0.3,1);
  margin-top: 2px;
  pointer-events: none;
}
.nav-link:not(.nav-link-has-dropdown):not(.nav-link--no-href):hover::after { width: 100%; }
.nav:not(.scrolled) .nav-link:not(.nav-link-has-dropdown):not(.nav-link--no-href)::after {
  background: rgba(255,255,255,0.7);
}
.nav-link--no-href { cursor: pointer; user-select: none; }
.nav-chevron {
  transition: transform var(--t-fast) var(--ease);
  flex-shrink: 0;
  stroke: currentColor;
  opacity: 0.6;
}
.nav-item-dropdown:hover .nav-chevron,
.nav-item-dropdown.open .nav-chevron {
  transform: rotate(180deg);
  opacity: 1;
}
.nav-item-dropdown {
  position: relative;
  display: flex;
  align-items: center;
  z-index: 300;
  padding-bottom: 8px;
  margin-bottom: -8px;
}
.nav-item-dropdown > .nav-link-has-dropdown,
.nav-item-dropdown > a.nav-link-has-dropdown {
  padding-bottom: 28px;
  margin-bottom: -20px;
}
.nav-link--why {
  position: relative;
  display: flex;
  align-items: center;
  height: 40px;
}
.nav-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: -16px;
  min-width: 600px;
  background: #fff;
  border: 1px solid rgba(29,146,255,0.15);
  border-radius: var(--radius-xl);
  box-shadow: 0 8px 40px rgba(25,43,69,0.14);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease), visibility var(--t-base);
  z-index: 501;
  padding: 14px;
  margin-top: -4px;
}
.nav-dropdown::before {
  content: '';
  position: absolute;
  top: -16px;
  left: 0; right: 0;
  height: 16px;
  pointer-events: all;
}
.nav-dropdown.open,
.nav-item-dropdown:hover .nav-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.nav-dropdown--narrow { min-width: 360px; }
.nav-dropdown-inner {
  display: flex;
  gap: var(--s-2);
}
.nav-dropdown-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.nav-dropdown-heading {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding: 8px 10px 6px;
}
.nav-dropdown-item {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
  padding: 10px 10px;
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background var(--t-fast);
  cursor: pointer;
}
.nav-dropdown-item:hover { background: var(--fog); }
.nav-dropdown-item strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
  margin-bottom: 3px;
}
.nav-dropdown-item > span > span {
  display: block;
  font-size: 0.78rem;
  color: #5A7A99;
  line-height: 1.4;
}
.nav-dropdown-icon {
  width: 32px; height: 32px;
  border-radius: var(--radius-md);
  background: rgba(29,146,255,0.08);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.nav-dropdown-item--cta strong { color: var(--color-primary); }

.nav-actions {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-shrink: 0;
}
.lang-switcher {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-muted);
  padding: 4px 9px;
  border: 1px solid var(--color-border);
  border-radius: 5px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.lang-switcher:hover { color: var(--color-primary); border-color: var(--color-primary); }

.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  border-radius: var(--radius-md);
  cursor: pointer;
  min-width: 44px; min-height: 44px;
  align-items: center;
  justify-content: center;
}
.nav-hamburger span {
  display: block;
  width: 20px; height: 2px;
  background: var(--color-text);
  border-radius: 2px;
  transition: transform var(--t-base) var(--ease), opacity var(--t-fast);
}
.nav-mobile {
  display: none;
  flex-direction: column;
  background: #fff;
  border-top: 1px solid var(--color-divider);
  padding: var(--s-4) var(--s-6);
  max-height: calc(100vh - 72px);
  overflow-y: auto;
}
.nav-mobile.open { display: flex; }
.nav-mobile-section { padding: var(--s-3) 0; border-bottom: 1px solid var(--color-divider); }
.nav-mobile-section:last-child { border-bottom: none; }
.nav-mobile-heading {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  padding: var(--s-2) 0 var(--s-3);
}
.nav-mobile a,
.nav-mobile .nav-link {
  display: block;
  padding: 10px var(--s-2);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  border-radius: var(--radius-md);
  transition: color var(--t-fast), background var(--t-fast);
  text-decoration: none;
}
.nav-mobile a:hover { color: var(--color-primary); background: var(--fog); }

/* Safe-area insets for notched / rounded-corner devices (iOS, modern Android) */
@supports (padding: env(safe-area-inset-top)) {
  .nav-inner {
    padding-left: max(clamp(var(--s-5), 5vw, var(--s-12)), env(safe-area-inset-left));
    padding-right: max(clamp(var(--s-5), 5vw, var(--s-12)), env(safe-area-inset-right));
  }
  .nav-mobile {
    padding-bottom: calc(var(--s-4) + env(safe-area-inset-bottom));
  }
  #scroll-top-btn {
    bottom: calc(32px + env(safe-area-inset-bottom));
    right: calc(32px + env(safe-area-inset-right));
  }
  .footer-clean-inner,
  .footer-bottom {
    padding-bottom: calc(48px + env(safe-area-inset-bottom));
  }
}

/* Nav state on hero pages */
body:has(.hero--split) .nav:not(.scrolled),
body:has(.hero--blue) .nav:not(.scrolled) {
  background: transparent;
  border-bottom-color: transparent;
  box-shadow: none;
}
/* Full-bleed hero: nav gets semi-transparent dark background so it's readable */
body:has(.hero--fullbg) .nav:not(.scrolled) {
  background: rgba(12, 24, 44, 0.55);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom-color: rgba(255,255,255,0.08);
}
body:has(.hero--fullbg) .nav:not(.scrolled) .nav-link,
body:has(.hero--fullbg) .nav:not(.scrolled) .nav-link-has-dropdown {
  color: rgba(255,255,255,0.9);
}
body:has(.hero--fullbg) .nav:not(.scrolled) .nav-logo-text {
  color: #fff;
}
body:has(.hero--fullbg) .nav:not(.scrolled) .nav-logo-img {
  filter: drop-shadow(0 1px 4px rgba(0,0,0,0.6)) brightness(1.1);
}

body:has(.page-header) .nav:not(.scrolled) {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom-color: rgba(29,146,255,0.08);
  box-shadow: 0 1px 0 rgba(0,0,0,0.04);
}
/* Photo-Hero: Nav transparent mit weissen Links */
body:has(.page-header--photo) .nav:not(.scrolled),
body:has(.hero-split) .nav:not(.scrolled),
body:has(section.page-header--photo) .nav:not(.scrolled) {
  background: rgba(11,22,35,0.15);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom-color: rgba(255,255,255,0.08);
  box-shadow: none;
}
body:has(.page-header--photo) .nav:not(.scrolled) .nav-logo,
body:has(.page-header--photo) .nav:not(.scrolled) .nav-link,
body:has(.hero-split) .nav:not(.scrolled) .nav-logo,
body:has(.hero-split) .nav:not(.scrolled) .nav-link {
  color: #fff;
}
body:has(.page-header--photo) .nav:not(.scrolled) .nav-link:hover,
body:has(.hero-split) .nav:not(.scrolled) .nav-link:hover {
  color: rgba(255,255,255,0.75);
}
body:has(.page-header--photo) .nav:not(.scrolled) .btn-nav-contact,
body:has(.hero-split) .nav:not(.scrolled) .btn-nav-contact {
  color: #fff;
  border-color: rgba(255,255,255,0.35);
}
body:has(.page-header--photo) .nav:not(.scrolled) .lang-toggle,
body:has(.hero-split) .nav:not(.scrolled) .lang-toggle {
  color: rgba(255,255,255,0.75);
}

@media (max-width: 900px) {
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
  .nav-actions .btn-nav-contact { display: none; }
  .nav-dropdown { display: none !important; }
}
@media (max-width: 600px) {
  .nav-actions .btn-primary { display: none; }
}
@media (max-width: 480px) {
  /* .btn-nav-contact is already hidden below 900px, kept here for clarity */
  .nav-actions .btn-nav-contact { display: none; }
  .nav-actions .lang-switcher { display: none; }
}
@media (max-width: 640px) {
  .nav-dropdown { display: none !important; }
}

/* In-menu language toggle (surfaced when desktop .lang-switcher is hidden) */
.nav-mobile-lang {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: var(--s-4) var(--s-6);
  margin-top: var(--s-4);
  border-top: 1px solid var(--color-border);
}
.nav-mobile-lang .nav-mobile-lang-label {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-faint);
}
.nav-mobile-lang a.nav-mobile-lang-link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  padding: 6px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.nav-mobile-lang a.nav-mobile-lang-link:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background: transparent;
}

/* ═══════════════════════════════════════════════════════════
   SECTION 6 — BUTTONS
   ═══════════════════════════════════════════════════════════ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  font-size: var(--text-sm);
  font-weight: 600;
  font-family: var(--font-body);
  line-height: 1;
  padding: 11px 22px;
  border-radius: var(--radius-md);
  border: 1.5px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition:
    transform var(--t-base) var(--ease),
    box-shadow var(--t-base) var(--ease),
    background var(--t-fast) var(--ease),
    border-color var(--t-fast) var(--ease),
    color var(--t-fast) var(--ease);
}
.btn-sm  { padding: 12px 18px; font-size: var(--text-xs); border-radius: var(--radius-md); min-height: 44px; }
.btn-lg  { padding: 14px 28px; font-size: var(--text-base); border-radius: var(--radius-lg); }
.btn-xl  { padding: 16px 36px; font-size: var(--text-lg); border-radius: var(--radius-lg); }

.btn-primary {
  background: linear-gradient(135deg, #1D92FF 0%, #0A5FD6 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 16px rgba(29,146,255,0.30);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(29,146,255,0.45);
  background: linear-gradient(135deg, #2da0ff 0%, #1D92FF 100%);
}
.btn-primary:active { transform: translateY(0); }

.btn-secondary {
  background: transparent;
  border-color: var(--color-border);
  color: var(--color-text);
}
.btn-secondary:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: rgba(29,146,255,0.05);
}

.btn-white {
  background: #fff;
  color: var(--navy);
  border-color: rgba(255,255,255,0.25);
  box-shadow: var(--shadow-md);
}
.btn-white:hover { background: rgba(255,255,255,0.92); transform: translateY(-1px); }

.btn-ghost-white {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.35);
  color: #fff;
}
.btn-ghost-white:hover { background: rgba(255,255,255,0.24); }

.btn-nav-contact {
  background: transparent;
  border: 1.5px solid rgba(25,43,69,0.22);
  color: var(--color-text);
  padding: 8px 20px;
  font-weight: 600;
  border-radius: var(--radius-lg);
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.btn-nav-contact:hover {
  border-color: var(--color-text);
  background: var(--color-text);
  color: #fff;
  transform: none;
  box-shadow: none;
}

/* ═══════════════════════════════════════════════════════════
   SECTION 7 — TAGS & BADGES
   ═══════════════════════════════════════════════════════════ */

.tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 600;
  background: var(--fog);
  border: 1px solid var(--cloud);
  color: var(--color-text-muted);
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast), transform 0.2s;
}
.tag:hover {
  background: rgba(29,146,255,0.09);
  border-color: rgba(29,146,255,0.25);
  color: var(--color-primary);
  transform: translateY(-1px);
}
.tag--purple { background: var(--color-secondary-light); color: var(--color-secondary); }
.tag--gray   { background: var(--color-surface-2);       color: var(--color-text-muted); }

.section-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  background: rgba(29,146,255,0.08);
  border: 1px solid rgba(29,146,255,0.20);
  border-radius: var(--radius-full);
  padding: 5px 14px;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--s-5);
}

/* ── HERO BADGE — clean label, no oval pill shape ── */
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--s-3);
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  box-shadow: none;
}
.hero-badge::before {
  display: none;
}

.kpi-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-lg);
  box-shadow: 0 4px 20px rgba(29,146,255,0.3);
}

/* ═══════════════════════════════════════════════════════════
   SECTION 8 — HERO SECTIONS
   ═══════════════════════════════════════════════════════════ */

/* ── HERO SPLIT ─────────────────────────────────────────── */
.hero--split {
  position: relative;
  overflow: hidden;
  background: var(--hero-gradient);
  background-blend-mode: normal;
  padding: clamp(72px, 6vw, 90px) 0 0;
  min-height: 640px;
}
.hero-inner--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: flex-end;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 clamp(24px, 5vw, 72px) 0;
}
.hero-content--left {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding-bottom: clamp(60px, 8vw, 100px);
}
.hero-content--right {
  position: relative;
  align-self: stretch;
  overflow: hidden;
  margin-top: calc(-1 * clamp(100px, 10vw, 130px));
  margin-bottom: 0;
  min-height: 560px;
}
.hero-content--left .hero-title {
  font-size: clamp(2.6rem, 5.5vw, 5rem);
  line-height: 1.05;
  font-weight: 300;
  color: var(--color-text);
  margin: 0;
  text-wrap: balance;
}
.hero-content--left .hero-subtitle {
  font-size: clamp(1rem, 1.2vw, 1.2rem);
  color: var(--color-text-muted);
  line-height: 1.75;
  max-width: 560px;
  margin: 0;
}
/* Mini stats row in hero */
.hero-mini-stats {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px solid var(--color-divider);
}
.hero-mini-stat { display: flex; flex-direction: column; gap: 2px; }
.hero-mini-num {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}
.hero-mini-lbl {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.3;
}
/* Hero trust checks */
.hero-trust-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 4px;
}
.hero-trust-check {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-text-muted);
}
/* Screenshot column */
.hero-visual {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  overflow: visible;
}
.hero-screenshot-wrap {
  position: relative;
  width: 100%;
  max-width: 720px;
  border-radius: 16px 16px 0 0;
  overflow: visible;
  margin-left: 0;
  margin-top: 40px;
  margin-bottom: -4px;
  background: #fff;
  box-shadow: 0 8px 48px rgba(0,0,0,0.12), 0 2px 16px rgba(0,0,0,0.06);
  border: 1px solid rgba(0,0,0,0.06);
  border-bottom: none;
}
.hero-screenshot {
  width: 100%;
  border-radius: 12px 12px 0 0;
  box-shadow: 0 8px 40px rgba(0,0,0,0.10), 0 2px 12px rgba(0,0,0,0.06);
  display: block;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
  border-bottom: none;
}
/* Browser chrome bar */
.hero-browser-chrome {
  background: #f0f0f0;
  border-radius: 12px 12px 0 0;
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 6px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.chrome-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.chrome-dot--red    { background: #FF5F57; }
.chrome-dot--yellow { background: #FEBC2E; }
.chrome-dot--green  { background: #28C840; }
.chrome-address-bar {
  flex: 1;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.1);
  border-radius: 6px;
  padding: 4px 12px;
  font-size: 0.72rem;
  color: var(--color-text-muted);
  margin-left: 8px;
  font-family: var(--font-body);
}
.hero-browser-chrome + .hero-screenshot {
  border-radius: 0;
  border-top: none;
}
/* Floating badges on screenshot */
.hero-badge-float {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.95);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 10px;
  padding: 8px 14px;
  font-size: 0.77rem;
  font-weight: 600;
  color: var(--color-text);
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
  white-space: nowrap;
  animation: badge-float 4s ease-in-out infinite alternate;
}
.hero-badge-float--tl { top: 10%; left: -5%; animation-delay: 0s; }
.hero-badge-float--tr { top: 20%; right: -5%; animation-delay: 0.5s; }
.hero-badge-float--bl { bottom: 30%; left: -8%; animation-delay: 1s; }
.hero-badge-float--br { bottom: 20%; right: -8%; animation-delay: 1.5s; }

/* Blobs */
.hero-blob {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  filter: blur(60px);
}
.hero-blob--1 {
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(29,146,255,0.04) 0%, transparent 70%);
  top: -100px; right: 0;
  animation: blob-drift 9s ease-in-out infinite alternate;
}
.hero-blob--2 {
  width: 350px; height: 350px;
  background: radial-gradient(circle, rgba(87,23,234,0.03) 0%, transparent 70%);
  bottom: 0; left: 5%;
  animation: blob-drift 12s ease-in-out infinite alternate-reverse;
}
/* Hero background blobs */
.hero::before {
  content: '';
  position: absolute;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(29,146,255,0.18) 0%, transparent 70%);
  border-radius: 50%;
  top: -100px; right: -100px;
  pointer-events: none;
  animation: blob-drift 8s ease-in-out infinite alternate;
  z-index: 0;
}
.hero::after {
  content: '';
  position: absolute;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(87,23,234,0.03) 0%, transparent 70%);
  border-radius: 50%;
  bottom: -50px; left: 10%;
  pointer-events: none;
  animation: blob-drift 10s ease-in-out infinite alternate-reverse;
  z-index: 0;
}
.hero-inner, .hero-kpis, .hero-content { position: relative; z-index: 1; }

/* Decorative dots */
.hero-dots { position: relative; overflow: hidden; }
.hero-dots::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle, rgba(29,146,255,0.12) 2px, transparent 2px),
    radial-gradient(circle, rgba(87,23,234,0.08) 2px, transparent 2px),
    radial-gradient(circle, rgba(29,146,255,0.2) 1.5px, transparent 1.5px);
  background-size: 320px 320px, 240px 240px, 180px 180px;
  background-position: 30px 20px, 180px 80px, 60px 160px;
  pointer-events: none;
  z-index: 0;
  opacity: 0.6;
}
.hero-dots > * { position: relative; z-index: 1; }

/* Floating product pill */
.product-pill-float {
  display: none;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, rgba(29,146,255,0.12), rgba(87,23,234,0.08));
  border: 1px solid rgba(29,146,255,0.25);
  border-radius: 100px;
  padding: 8px 16px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-primary);
  position: absolute;
  white-space: nowrap;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 20px rgba(29,146,255,0.15);
  animation: badge-float 3s ease-in-out infinite alternate;
  z-index: 5;
}
.product-pill-float .pill-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-primary);
  animation: pulse-dot 1.5s ease-in-out infinite;
}

/* Avatar stack (social proof) */
.avatar-stack { display: flex; align-items: center; gap: 4px; }
.avatar-stack-imgs { display: flex; }
.avatar-img {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 2px solid #fff;
  margin-left: -10px;
  background: var(--cloud);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--color-primary);
  overflow: hidden;
  flex-shrink: 0;
}
.avatar-img:first-child { margin-left: 0; }
.avatar-stack-text {
  margin-left: 10px;
  font-size: 0.78rem;
  color: var(--color-text-muted);
  line-height: 1.3;
}
.avatar-stack-text strong { color: var(--color-text); font-weight: 600; }

/* Floating KPI cards in hero */
.hero-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  max-width: 800px;
  margin: var(--space-10) auto 0;
}
@media (max-width: 640px) { .hero-kpis { grid-template-columns: 1fr; } }
.hero-kpi-card {
  background: #fff;
  border: 1.5px solid #DDEFFF;
  border-radius: 16px;
  padding: var(--space-5) var(--space-6);
  text-align: center;
  box-shadow: 0 4px 20px rgba(29,146,255,0.10);
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.hero-kpi-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(29,146,255,0.18);
  border-color: #1D92FF;
}
.hero-kpi-val {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xl);
  color: var(--color-primary);
  line-height: 1;
  margin-bottom: var(--space-2);
}
.hero-kpi-lbl {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: 500;
}

/* Responsive split hero */
@media (max-width: 900px) {
  .hero-inner--split { grid-template-columns: 1fr; }
  .hero-visual {
    display: block !important;
    height: 300px;
    overflow: hidden;
    border-radius: 16px;
    margin-top: var(--space-6);
    position: relative;
  }
  .hero-visual img {
    position: static !important;
    width: 100% !important;
    height: 300px !important;
    object-fit: cover;
    object-position: center top;
    border-radius: 16px;
  }
  .hero-content--left { padding-bottom: 40px; }
}

/* ── HERO BLUE VARIANT ──────────────────────────────────── */
.hero--blue {
  background: linear-gradient(135deg, #1d92ff 0%, #0e6fd4 50%, #192b45 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.hero--blue .section-label  { color: rgba(255,255,255,0.7); }
.hero--blue .section-title,
.hero--blue .hero-title      { color: #fff; }
.hero--blue .section-subtitle,
.hero--blue .hero-subtitle   { color: rgba(255,255,255,0.85); }
.hero--blue .hero-badge      { background: rgba(255,255,255,0.15); color: #fff; border-color: rgba(255,255,255,0.2); }
.hero--blue::before {
  content: '';
  position: absolute;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%);
  top: -50px; right: 10%;
  border-radius: 50%;
  pointer-events: none;
  animation: blob-drift 8s ease-in-out infinite alternate;
}
.hero--blue > * { position: relative; z-index: 1; }

/* ── HERO INNER (generic) ──────────────────────────────── */
.hero-inner {
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--space-6), 5vw, var(--space-16));
  display: grid;
  grid-template-columns: 47% 53%;
  align-items: flex-end;      /* text + image align to bottom like Taskopia */
  gap: 0;
  position: relative;
  z-index: 1;
  min-height: 80vh;           /* fill viewport like Taskopia */
  padding-top: clamp(80px, 9vw, 110px);
}
.hero-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding-bottom: clamp(60px, 7vw, 100px);
  padding-right: clamp(24px, 3vw, 48px);
}
.hero-visual {
  position: relative;
  align-self: stretch;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.hero-visual img {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  box-shadow: 0 -8px 40px rgba(29,146,255,0.06);
  object-fit: cover;
  object-position: top center;
}
.hero--centered .hero-inner {
  grid-template-columns: 1fr;
  text-align: center;
  max-width: 860px;
}

/* ── PAGE HEADER (inner pages, light) ──────────────────── */
.page-header {
  min-height: 82vh;
  display: flex;
  align-items: center;
  padding-top: clamp(48px, 5vw, 72px);
  padding-bottom: 0;
  background: linear-gradient(
    160deg,
    #f5f8ff 0%,
    #f8f9ff 40%,
    #fafaff 70%,
    #ffffff 100%
  );
  position: relative;
  overflow: hidden;
}
.page-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(29,146,255,0.025) 1px, transparent 1px);
  background-size: 36px 36px;
  pointer-events: none;
  z-index: 0;
}
.page-header::after { display: none; }
.page-header > * { position: relative; z-index: 1; }

/* ── 2-column split: text left, visual right ──────────────── */
.page-header-inner {
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--space-6), 5vw, var(--space-16));
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 50% 50%;
  gap: 0;
  align-items: center;
  width: 100%;
  min-height: clamp(480px, 56vh, 680px);
  box-sizing: border-box;
}

/* Left: text stack, vertically centered */
.page-header-content {
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  padding-bottom: clamp(60px, 7vw, 100px);
  padding-right: clamp(24px, 3vw, 48px);
}

/* Right: visual bleeds to bottom edge like Taskopia */
.page-header-visual {
  position: relative;
  align-self: stretch;
  display: flex;
  align-items: flex-end;   /* image sits at bottom */
  justify-content: flex-end;
  overflow: hidden;
  min-height: clamp(420px, 55vh, 660px);
}
.page-header-visual img {
  /* Fill column, crop bottom — shows face at top */
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center 15%;  /* show upper portion — face, not feet */
  margin-right: 0;
}

/* Full-width fallback when no visual */
.page-header-inner:not(:has(> .page-header-visual)) {
  grid-template-columns: 1fr;
  align-items: center;
  min-height: 72vh;
}
.page-header-inner:not(:has(> .page-header-visual)) .page-header-content {
  max-width: 68ch;
  padding-bottom: clamp(60px, 7vw, 90px);
  padding-right: 0;
}

@media (max-width: 1024px) {
  .page-header-inner { grid-template-columns: 1fr 45%; gap: var(--space-6); }
  .page-header-content { padding-right: 0; }
}
@media (max-width: 768px) {
  .page-header-inner { grid-template-columns: 1fr; }
  .page-header-visual {
    display: block !important;
    height: 320px;
    overflow: hidden;
    border-radius: 16px;
    margin-top: var(--space-6);
    position: relative;
  }
  .page-header-visual img {
    position: static !important;
    width: 100% !important;
    height: 320px !important;
    object-fit: cover;
    object-position: center top;
    border-radius: 16px;
  }
}
@media (max-width: 480px) {
  .page-header-visual { height: 260px; }
  .page-header-visual img { height: 260px !important; }
}


/* ── Platform pages: Dashboard/UI screenshots (landscape) ── */
.page-header-visual--dashboard {
  position: relative;
  align-self: center;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  min-height: 400px;
  padding: var(--space-8) 0 var(--space-8) var(--space-6);
}
.page-header-visual--dashboard img {
  position: relative;
  width: 100%;
  max-width: 620px;
  height: auto;
  display: block;
  border-radius: 16px;
  box-shadow: 0 16px 64px rgba(29,146,255,0.18), 0 4px 24px rgba(25,43,69,0.12);
  object-fit: contain;
}
@media (max-width: 768px) {
  .page-header-visual--dashboard {
    padding: var(--space-4) 0 0;
    min-height: auto;
  }
  .page-header-visual--dashboard img {
    max-width: 100%;
    border-radius: 12px;
  }
}

/* ── HERO PRODUCT IMAGE ──────────────────────────────────── */
.hero-img-wrap {
  width: 100%;
  display: flex;
  align-items: center;
}

/* ═══════════════════════════════════════════════════════════
   SECTION 9 — CARDS & FEATURES
   ═══════════════════════════════════════════════════════════ */

/* Feature card */
.feature-card {
  background: #FFFFFF;
  border-radius: 20px;
  border: 1.5px solid #DDEFFF;
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  box-shadow: 0 2px 12px rgba(29,146,255,0.06);
  transition: transform 0.25s cubic-bezier(0.16,1,0.3,1), box-shadow 0.25s cubic-bezier(0.16,1,0.3,1), border-color 0.25s;
  position: relative;
  overflow: hidden;
}
.feature-card::before {
  content: '';
  position: absolute;
  inset: -1.5px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(29,146,255,0.45), rgba(29,146,255,0.15), rgba(29,146,255,0.04));
  z-index: -1;
  opacity: 0;
  transition: opacity 0.3s;
}
.feature-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(29,146,255,0.14), 0 2px 8px rgba(0,0,0,0.06);
  border-color: rgba(29,146,255,0.4);
}
.feature-card:hover::before { opacity: 1; }
.feature-card-icon {
  width: 52px; height: 52px;
  background: #1D92FF;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  flex-shrink: 0;
  margin-bottom: 4px;
  transition: transform 0.3s, box-shadow 0.3s;
}
.feature-card:hover .feature-card-icon {
  transform: scale(1.12);
  box-shadow: 0 0 0 6px rgba(29,146,255,0.12);
}
.feature-card-icon--purple     { background: #5717EA; color: #fff; }
.feature-card-icon--raspberry  { background: #5717EA; color: #fff; }
.feature-card-icon--cornflower { background: #5717ea; color: #fff; }
.feature-card-icon--tangerine  { background: #fd8006; color: #fff; }
.feature-card-icon--sky        { background: #1d92ff; color: #fff; }
.feature-card-icon--ocean      { background: #19add0; color: #fff; }
.feature-card-icon--tree       { background: #24C774; color: #fff; }
.feature-card-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-text);
}
.feature-card-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.65;
  max-width: none;
}

/* KPI card */
.kpi-card {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-divider);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s cubic-bezier(0.16,1,0.3,1), box-shadow 0.25s;
}
.kpi-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--color-primary);
}
.kpi-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(29,146,255,0.12);
}
.kpi-number {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-2xl);
  background: linear-gradient(135deg, #1D92FF, #0A5FD6);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: var(--space-2);
}
.kpi-label {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-weight: 500;
  overflow-wrap: anywhere;
  hyphens: auto;
}
.kpi-section { background: var(--color-surface-2); }

/* Resource card */
.resource-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: #FFFFFF;
  border: 1.5px solid #DDEFFF;
  border-radius: 16px;
  padding: 28px 24px;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 180ms, border-color 180ms, transform 180ms;
}
.resource-card:hover {
  border-color: #1D92FF;
  box-shadow: 0 16px 48px rgba(29,146,255,0.12);
  transform: translateY(-5px);
}

/* ── CARD ICON ───────────────────────────────────────────────────────── */
/* Base icon box used in .card components across industry/platform pages  */
.card-icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: rgba(29,146,255,0.10);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-bottom: var(--s-4);
}
.card-icon--purple {
  background: rgba(87,23,234,0.10);
  color: var(--color-secondary);
}
.card-icon--sm {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  margin-bottom: 0;
}

.resource-card-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
  flex-shrink: 0;
}
.resource-card-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--color-text-faint);
}
.resource-card-title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--color-text);
  font-family: var(--font-display);
  line-height: 1.2;
}
.resource-card-desc {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  flex: 1;
  max-width: none;
}
.resource-card-link {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-top: 4px;
}
.resource-card:hover .resource-card-link { text-decoration: underline; }

/* Story card */
.story-card {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-divider);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition-interactive), transform var(--transition-interactive);
}
.story-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.story-card-tag {
  padding: var(--space-4) var(--space-6);
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  border-bottom: 1px solid var(--color-divider);
  background: var(--color-surface-2);
}
.story-card-kpi {
  padding: var(--space-6);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xl);
  color: var(--color-primary);
  line-height: 1.2;
  border-bottom: 1px solid var(--color-divider);
}
.story-card-body { padding: var(--space-6); flex: 1; display: flex; flex-direction: column; gap: var(--space-4); }
.story-card-body p { color: var(--color-text-muted); font-size: var(--text-sm); max-width: none; }

/* Platform card */
.platform-card {
  transition: transform 0.25s cubic-bezier(0.16,1,0.3,1), box-shadow 0.25s cubic-bezier(0.16,1,0.3,1), border-color 0.25s;
}
.platform-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(29,146,255,0.14), 0 2px 8px rgba(0,0,0,0.06);
  border-color: rgba(29,146,255,0.4);
}

/* Gradient border card */
.card--gradient-border {
  position: relative;
  background: #fff;
  border: none;
}
.card--gradient-border::before {
  content: '';
  position: absolute;
  inset: -1.5px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(29,146,255,0.45), rgba(29,146,255,0.15), rgba(29,146,255,0.04));
  z-index: -1;
  opacity: 0;
  transition: opacity 0.3s;
}
.card--gradient-border:hover::before { opacity: 1; }

/* Blog card */
.blog-card {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-divider);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition-interactive), transform var(--transition-interactive);
}
.blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.blog-card-thumb {
  background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-secondary-light) 100%);
  aspect-ratio: 16/9;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem;
}
.blog-card-body { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.blog-card-meta { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.blog-card-date { font-size: var(--text-xs); color: var(--color-text-faint); }
.blog-card-title { font-family: var(--font-display); font-weight: 700; font-size: var(--text-base); color: var(--color-text); line-height: 1.4; }
.blog-card-excerpt { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; max-width: none; flex: 1; }

/* About stat card */
.about-stat-card {
  display: flex; align-items: center; gap: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
  transition: box-shadow 0.2s, transform 0.2s;
}
.about-stat-card:hover { box-shadow: 0 4px 24px rgba(29,146,255,0.10); transform: translateX(4px); }
.about-stat-icon {
  width: 44px; height: 44px; border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.about-stat-val { font-family: var(--font-display); font-weight: 700; font-size: var(--text-base); color: var(--color-text); }
.about-stat-lbl { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: 2px; }
.about-visual-col { display: flex; align-items: center; justify-content: center; }
.about-stat-stack { display: flex; flex-direction: column; gap: var(--space-4); width: 100%; }

/* Timeline */
.timeline { display: flex; flex-direction: column; gap: 0; position: relative; }
.timeline::before {
  content: '';
  position: absolute;
  left: 80px; top: 0; bottom: 0; width: 2px;
  background: linear-gradient(180deg, var(--color-primary) 0%, #19add0 100%);
  opacity: 0.2;
}
.timeline-item {
  display: flex; gap: var(--space-8);
  padding: var(--space-6) 0;
  position: relative;
}
.timeline-item::before {
  content: '';
  position: absolute;
  left: 75px; top: calc(var(--space-6) + 8px);
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(29,146,255,0.15);
}
.timeline-year {
  width: 68px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-base);
  color: var(--color-primary);
  text-align: right;
  padding-top: 2px;
  flex-shrink: 0;
  white-space: nowrap;
}
.timeline-content { padding-left: var(--space-4); flex: 1; }
.timeline-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.timeline-text { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; }

/* Jobs list */
.jobs-list { display: flex; flex-direction: column; gap: var(--space-4); }
.job-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-7) var(--space-8);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-8);
  transition: box-shadow 0.2s, transform 0.2s, border-color 0.2s;
}
.job-card:hover {
  box-shadow: 0 8px 32px rgba(29,146,255,0.10);
  transform: translateX(4px);
  border-color: rgba(29,146,255,0.2);
}
.job-card--spontaneous { border-style: dashed; }
.job-card-left { flex: 1; }
.job-card-right { flex-shrink: 0; }
.job-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-text);
  margin-bottom: var(--space-3);
}
.job-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: var(--space-3); }
.job-description { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.6; max-width: 600px; }

/* Pipeline step */
.pipeline-step {
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.pipeline-step:hover {
  box-shadow: 0 4px 20px rgba(29,146,255,0.15);
  transform: translateY(-2px);
}

/* Numbered steps */
.steps { display: flex; flex-direction: column; gap: var(--space-6); }
.step  { display: flex; gap: var(--space-6); align-items: flex-start; }

/* Accordion */
.accordion { border-radius: var(--radius-xl); overflow: hidden; border: 1px solid var(--color-divider); }
.accordion-item { border-bottom: 1px solid var(--color-divider); }
.accordion-item:last-child { border-bottom: none; }
.accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-6);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-surface);
  text-align: left;
  gap: var(--space-4);
  cursor: pointer;
  transition: background var(--transition-interactive);
}
.accordion-trigger:hover { background: var(--color-surface-2); }
.accordion-icon {
  width: 24px; height: 24px;
  flex-shrink: 0;
  color: var(--color-primary);
  transition: transform var(--transition-interactive);
}
.accordion-item.open .accordion-icon { transform: rotate(45deg); }
.accordion-body {
  padding: 0 var(--space-6) var(--space-6);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
  display: none;
  background: var(--color-surface);
}
.accordion-item.open .accordion-body { display: block; }

@media (max-width: 640px) {
  .job-card { flex-direction: column; align-items: flex-start; }
  .timeline::before { left: 48px; }
  .timeline-item::before { left: 43px; }
  .timeline-year { width: 40px; font-size: var(--text-sm); }
}

/* ═══════════════════════════════════════════════════════════
   SECTION 10 — STATS ROW, CALLOUT STRIP, SECTION--DARK
   ═══════════════════════════════════════════════════════════ */

/* Logo strip — static client logo row used below platform/industry heroes.
   The EN platform page also has inline-style fallbacks; this rule lets DE
   (and any future page) use the class without re-declaring every property. */
.logo-strip {
  background: var(--fog, #F4FAFF);
  padding: 28px 0;
  border-top: 1px solid #E8F0FE;
  border-bottom: 1px solid #E8F0FE;
}
.logo-strip-label {
  font-size: var(--text-xs, 0.72rem);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-faint, #9aabb8);
  text-align: center;
  margin-bottom: 16px;
}
.logo-strip-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 28px;
  justify-content: center;
  align-items: center;
}
.logo-strip-logos > span {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-navy, #192B45);
  white-space: nowrap;
}

/* Stats row */
.stats-row {
  padding: 64px 0;
  background: #1D92FF;
  position: relative;
  overflow: hidden;
  clip-path: polygon(0 16px, 100% 0, 100% 100%, 0 100%);
  margin-top: -8px;
  padding-top: 48px;
}
.stats-row::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.stats-row-grid {
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--space-6), 5vw, var(--space-16));
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
  text-align: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 768px) { .stats-row-grid { grid-template-columns: repeat(2, 1fr); } }
.stats-row-item { position: relative; }
.stats-row-item:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  height: 50%;
  width: 1px;
  background: rgba(255,255,255,0.2);
}
@media (max-width: 768px) {
  .stats-row-item:not(:last-child)::after { display: none; }
}
.stats-row-number {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-3xl);
  background: linear-gradient(135deg, #fff 0%, rgba(255,255,255,0.85) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: 8px;
}
.stats-row-label { color: rgba(255,255,255,0.75); font-size: var(--text-sm); font-weight: 500; }
/* Reset the gradient-text clip when stats-row-number contains an emoji
   (e.g. the 🇩🇪 flag) — otherwise the emoji renders as a white silhouette. */
.stats-row-number.has-emoji {
  background: none;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: initial;
  background-clip: initial;
}
.stats-row .section-label,
.stats-row .section-title,
.stats-row .stat-val { color: #fff; }

/* Callout strip */
.callout-strip {
  background: #0B1623;
  color: #fff;
  padding-block: clamp(var(--space-12), 6vw, var(--space-20));
  text-align: center;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(29,146,255,0.15);
}
.callout-strip::before {
  content: '';
  position: absolute;
  width: 640px; height: 640px;
  background: radial-gradient(circle, rgba(29,146,255,0.08) 0%, transparent 65%);
  top: -240px; left: 50%;
  transform: translateX(-50%);
  border-radius: 50%;
  pointer-events: none;
}
.callout-strip::after { display: none; }
.callout-strip .section-title { color: #fff; margin-bottom: var(--space-4); }
.callout-strip .section-subtitle { color: rgba(255,255,255,0.85); margin-inline: auto; }

/* Section dark */
.section--dark {
  background: linear-gradient(135deg, #192B45 0%, #192B45 60%, #1a1040 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.section--dark::before {
  content: '';
  position: absolute;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(29,146,255,0.12) 0%, transparent 70%);
  top: -200px; right: -100px;
  border-radius: 50%;
  pointer-events: none;
}
.section--dark .section-label   { color: rgba(255,255,255,0.5); }
.section--dark .section-title   { color: #fff; }
.section--dark .section-subtitle { color: rgba(255,255,255,0.7); }
.section--dark .feature-card    { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }
.section--dark .feature-card-title { color: #fff; }
.section--dark .feature-card-text  { color: rgba(255,255,255,0.65); }
.section--dark .feature-card-icon  { background: rgba(29,146,255,0.2); color: #60b4ff; }
.section--dark .feature-card:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(29,146,255,0.4);
  box-shadow: 0 8px 32px rgba(29,146,255,0.18);
  transform: translateY(-4px);
}
.section--dark .kpi-card,
.section--dark .kpi-number,
.section--dark .kpi-label { color: #fff; }
.section--dark .kpi-card { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }

/* Section--navy */
.section--navy { background: #192B45; color: #fff; }

/* Subtle off-white — breaks monotony between pure white sections */
.section--offwhite { background: #f8f9fc; }

/* Feature card with icon LEFT of text — more modern than icon-above */
.card--horizontal {
  flex-direction: row;
  align-items: flex-start;
  gap: var(--space-5);
}
.card--horizontal .card-icon {
  margin-bottom: 0;
  margin-top: 2px;
}
.card--horizontal .card-body {
  flex: 1;
}

/* Numbered card — big number accent, modern process feel */
.card--numbered {
  position: relative;
  counter-increment: card-counter;
}
.card--numbered::before {
  content: counter(card-counter, decimal-leading-zero);
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1;
  color: rgba(29,146,255,0.08);
  letter-spacing: -0.04em;
  pointer-events: none;
}
.card-grid--numbered {
  counter-reset: card-counter;
}

/* Stat highlight inside card */
.card-stat {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 800;
  color: var(--color-primary);
  letter-spacing: -0.03em;
  line-height: 1;
  margin-bottom: var(--s-1);
}
.card-stat-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  font-weight: 600;
}

/* Use-case card — slightly richer than plain card */
.card--usecase {
  border-top: 3px solid transparent;
  background: linear-gradient(#fff, #fff) padding-box,
              linear-gradient(135deg, rgba(29,146,255,0.3), rgba(87,23,234,0.15)) border-box;
}
.card--usecase:hover {
  border-top-color: transparent;
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(29,146,255,0.14);
}
.section--navy .section-label   { color: rgba(255,255,255,0.6); }
.section--navy .section-title   { color: #fff; }
.section--navy .section-subtitle { color: rgba(255,255,255,0.75); }
.navy-feature-block {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
}
.navy-feature-block h3 { font-size: var(--text-lg); font-weight: 700; color: #fff; margin-bottom: var(--space-2); }
.navy-feature-block p  { font-size: var(--text-sm); color: rgba(255,255,255,0.7); line-height: 1.6; }
.navy-feature-block .navy-badge {
  display: inline-block;
  font-size: 0.68rem; font-weight: 700;
  padding: 3px 10px; border-radius: 20px;
  background: rgba(29,146,255,0.25); color: #7ec4ff;
  text-transform: uppercase; letter-spacing: .04em;
  margin-bottom: var(--space-3);
}

/* Section dividers */
.section-divider-wave { position: relative; margin-top: -2px; line-height: 0; overflow: hidden; }
.section-divider-wave svg { display: block; width: 100%; }
.alternating-features { position: relative; }
.alternating-features::before {
  content: '';
  display: block;
  height: 60px;
  background: linear-gradient(180deg, var(--fog) 0%, transparent 100%);
  margin-bottom: -1px;
}

/* ═══════════════════════════════════════════════════════════
   SECTION 11 — FORMS
   ═══════════════════════════════════════════════════════════ */

.form-group { display: flex; flex-direction: column; gap: var(--space-2); }
.form-label { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); }
.form-input, .form-select, .form-textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: var(--color-surface);
  transition: border-color var(--transition-interactive), box-shadow var(--transition-interactive);
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(29,146,255,0.15);
}
.form-textarea { resize: vertical; min-height: 120px; }

/* ═══════════════════════════════════════════════════════════
   SECTION 12 — ANIMATIONS & MICRO-INTERACTIONS
   ═══════════════════════════════════════════════════════════ */

/* Keyframes */
@keyframes fadeup {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes blob-drift {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(40px, 30px) scale(1.1); }
}
@keyframes badge-float {
  from { transform: translateY(0px); }
  to   { transform: translateY(-8px); }
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.5; transform: scale(0.75); }
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes marquee-reverse {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}

/* Animate classes */
.animate-fadeup { animation: fadeup 0.6s cubic-bezier(0.16,1,0.3,1) both; }
.anim-delay-1 { animation-delay: 0.1s; }
.anim-delay-2 { animation-delay: 0.2s; }
.anim-delay-3 { animation-delay: 0.3s; }
.anim-delay-4 { animation-delay: 0.4s; }

/* Scroll-triggered */
[data-animate] { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease, transform 0.6s ease; }
[data-animate].in-view, [data-animate].visible { opacity: 1; transform: translateY(0); }

.grid-3[data-animate] > *,
.grid-4[data-animate] > *,
.grid-2[data-animate] > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.grid-3[data-animate].in-view > *,
.grid-4[data-animate].in-view > *,
.grid-2[data-animate].in-view > * { opacity: 1; transform: translateY(0); }
.grid-3[data-animate].in-view > *:nth-child(1),
.grid-4[data-animate].in-view > *:nth-child(1),
.grid-2[data-animate].in-view > *:nth-child(1) { transition-delay: 0s; }
.grid-3[data-animate].in-view > *:nth-child(2),
.grid-4[data-animate].in-view > *:nth-child(2),
.grid-2[data-animate].in-view > *:nth-child(2) { transition-delay: 0.09s; }
.grid-3[data-animate].in-view > *:nth-child(3),
.grid-4[data-animate].in-view > *:nth-child(3),
.grid-2[data-animate].in-view > *:nth-child(3) { transition-delay: 0.18s; }
.grid-3[data-animate].in-view > *:nth-child(4),
.grid-4[data-animate].in-view > *:nth-child(4),
.grid-2[data-animate].in-view > *:nth-child(4) { transition-delay: 0.27s; }
.grid-3[data-animate].in-view > *:nth-child(5),
.grid-4[data-animate].in-view > *:nth-child(5) { transition-delay: 0.36s; }
.grid-3[data-animate].in-view > *:nth-child(6),
.grid-4[data-animate].in-view > *:nth-child(6) { transition-delay: 0.45s; }

.bento-grid[data-animate] > *:nth-child(1) { transition-delay: 0s; }
.bento-grid[data-animate] > *:nth-child(2) { transition-delay: 0.08s; }
.bento-grid[data-animate] > *:nth-child(3) { transition-delay: 0.16s; }
.bento-grid[data-animate] > *:nth-child(4) { transition-delay: 0.24s; }
.bento-grid[data-animate] > *:nth-child(5) { transition-delay: 0.32s; }
.bento-grid[data-animate] > *:nth-child(6) { transition-delay: 0.40s; }

/* Scroll progress bar */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, #1D92FF, #5717EA);
  z-index: 10000;
  transition: width 0.1s linear;
  pointer-events: none;
  border-radius: 0 2px 2px 0;
}

/* Tilt card */
.tilt-card {
  transform-style: preserve-3d;
  transition: transform 0.15s ease;
  will-change: transform;
}

/* Scroll to top */
#scroll-top-btn {
  position: fixed;
  bottom: 32px; right: 32px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1D92FF, #0A5FD6);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(29,146,255,0.4);
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.3s, transform 0.3s;
  z-index: 999;
  pointer-events: none;
}
#scroll-top-btn.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}
#scroll-top-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(29,146,255,0.5);
}

/* Marquee */
.marquee-section { overflow: hidden; }
.marquee-container {
  overflow: hidden;
  position: relative;
  padding-block: var(--space-10);
  background: var(--fog);
  border-top: 1px solid var(--color-divider);
  border-bottom: 1px solid var(--color-divider);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}
.marquee-container .section-label {
  text-align: center;
  display: block;
  margin-bottom: var(--space-6);
}
.marquee-track {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  animation: marquee 30s linear infinite;
  width: max-content;
  will-change: transform;
}
.marquee-track--reverse { animation: marquee-reverse 30s linear infinite; }
.marquee-item {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.1rem, 0.9rem + 1vw, 1.5rem);
  color: var(--color-text);
  white-space: nowrap;
  letter-spacing: 0.01em;
  opacity: 0.8;
  transition: opacity 0.2s, color 0.2s;
}
.marquee-item:hover { opacity: 1; color: var(--color-primary); }
.marquee-sep {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #1D92FF;
  opacity: 0.5;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   SECTION 13 — FOOTER
   ═══════════════════════════════════════════════════════════ */

.footer {
  background: var(--color-text);
  color: rgba(255,255,255,0.75);
  padding-block: clamp(var(--space-12), 6vw, var(--space-20));
}
.footer-inner {
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--space-6), 5vw, var(--space-16));
}
.footer-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: var(--space-12);
  padding-bottom: var(--space-12);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
@media (max-width: 900px) { .footer-top { grid-template-columns: 1fr 1fr; gap: var(--space-8); } }
@media (max-width: 480px) { .footer-top { grid-template-columns: 1fr; } }
.footer-brand { display: flex; flex-direction: column; gap: var(--space-4); }
.footer-logo {
  display: flex;
  align-items: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-lg);
  color: #fff;
  letter-spacing: -0.02em;
}
.footer-logo-img {
  height: 24px;
  width: auto;
  display: block;
  object-fit: contain;
}
.footer-desc { font-size: var(--text-sm); line-height: 1.65; max-width: 30ch; }
.footer-tagline { font-size: var(--text-sm); line-height: 1.65; max-width: 30ch; }
.footer-col-title,
.footer-link-heading {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  color: #fff;
  margin-bottom: var(--space-4);
  letter-spacing: 0.02em;
}
.footer-links { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); }
.footer-links a {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.6);
  transition: color var(--transition-interactive);
}
.footer-links a:hover { color: #fff; }
.footer-col a {
  transition: color 0.2s, transform 0.2s;
  display: inline-block;
}
.footer-col a:hover { color: #60b4ff; transform: translateX(3px); }
.footer-bottom {
  padding-top: var(--space-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.45);
}
.footer-legal-links { display: flex; gap: var(--space-4); flex-wrap: wrap; }
.footer-copy { font-size: var(--text-xs); color: rgba(255,255,255,0.45); }
.footer-bottom a { color: rgba(255,255,255,0.6); transition: color var(--transition-interactive); }
.footer-bottom a:hover { color: #fff; }

/* Notion-style footer variant */
.footer--notion .footer-notion-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-16) var(--space-8) var(--space-10);
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-16);
  align-items: start;
}
.footer--notion .footer-notion-nav {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
}
@media (max-width: 1100px) {
  .footer--notion .footer-notion-inner { grid-template-columns: 1fr; gap: var(--space-10); }
  .footer--notion .footer-notion-nav  { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .footer--notion .footer-notion-inner { padding: var(--space-10) var(--space-6); }
  .footer--notion .footer-notion-nav  { grid-template-columns: 1fr 1fr; gap: var(--space-6); }
}

/* ═══════════════════════════════════════════════════════════
   SECTION 14 — PRESERVED COMPONENT STYLES
   ═══════════════════════════════════════════════════════════ */

/* ── PLATFORM TABS ──────────────────────────────────────── */
.tabs-section {
  padding-block: clamp(var(--space-16), 7vw, var(--space-24));
  background: #fff;
}
.tabs-section .container {
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--space-6), 5vw, var(--space-16));
}
.tabs-layout {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--space-10);
  align-items: start;
}
@media (max-width: 1024px) and (min-width: 901px) {
  .tabs-layout { grid-template-columns: 260px 1fr; }
}
@media (max-width: 900px) { .tabs-layout { grid-template-columns: 1fr; } }
.tab-btn-label { min-width: 0; }
.tabs-nav { display: flex; flex-direction: column; gap: var(--space-2); }
.tab-btn {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border: 1.5px solid #DDEFFF;
  border-radius: 16px;
  background: #fff;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: left;
  width: 100%;
}
.tab-btn:hover {
  border-color: rgba(29,146,255,0.4);
  background: rgba(29,146,255,0.06);
  transform: translateX(3px);
}
.tab-btn.active {
  border-color: #1D92FF;
  background: #FFFFFF;
  box-shadow: 0 4px 20px rgba(29,146,255,0.15);
}
.tab-btn-icon {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: rgba(29,146,255,0.1);
  display: flex; align-items: center; justify-content: center;
  color: #1D92FF;
  flex-shrink: 0;
  transition: all 0.2s ease;
}
.tab-btn.active .tab-btn-icon { background: #1D92FF; color: #fff; }
.tab-btn-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--color-text);
}
.tab-btn-sublabel { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: 2px; }
.tabs-content { position: relative; min-height: 300px; }
.tab-panel {
  display: none;
  padding: var(--space-8);
  background: #FFFFFF;
  border-radius: 20px;
  border: 1.5px solid #DDEFFF;
  box-shadow: 0 2px 12px rgba(29,146,255,0.06);
  animation: fadeup 0.3s ease;
}
.tab-panel.active { display: block; }
.tab-panel h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xl);
  color: var(--color-text);
  margin-bottom: var(--space-4);
}
.tab-panel p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.7;
  margin-bottom: var(--space-4);
  max-width: none;
}
.tab-bullets {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: 0;
  margin: 0;
}
.tab-bullets li {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}
.tab-bullets li::before {
  content: '';
  width: 18px; height: 18px;
  min-width: 18px;
  background: rgba(29,146,255,0.12);
  border: 1.5px solid rgba(29,146,255,0.3);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpolyline points='2,6 5,9 10,3' fill='none' stroke='%231D92FF' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── ALTERNATING FEATURES ───────────────────────────────── */
.alt-features-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}
.alt-features-list::before {
  content: '';
  position: absolute;
  left: 50%; top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--color-primary) 0%, rgba(29,146,255,0.1) 100%);
  transform: translateX(-50%);
}
@media (max-width: 768px) { .alt-features-list::before { display: none; } }
.alt-feature-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(var(--space-8), 5vw, var(--space-16));
  align-items: center;
  padding-block: var(--space-12);
  position: relative;
}
.alt-feature-row::before {
  content: '';
  position: absolute;
  left: 50%; top: 50%;
  width: 16px; height: 16px;
  background: var(--color-primary);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  border: 3px solid #fff;
  box-shadow: 0 0 0 3px rgba(29,146,255,0.2);
  z-index: 2;
}
@media (max-width: 768px) {
  .alt-feature-row { grid-template-columns: 1fr; }
  .alt-feature-row::before { display: none; }
  .alt-feature-row.reverse .alt-feature-visual { order: -1; }
}
.alt-feature-row.reverse { direction: rtl; }
.alt-feature-row.reverse > * { direction: ltr; }
.alt-feature-text {}
.alt-feature-text .section-label { margin-bottom: var(--space-3); }
.alt-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  background: #1D92FF;
  color: #fff;
  border-radius: 50%;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
  box-shadow: 0 4px 16px rgba(29,146,255,0.25);
  flex-shrink: 0;
}
.alt-feature-text h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xl);
  color: var(--color-text);
  margin-bottom: var(--space-4);
  line-height: 1.2;
}
.alt-feature-text p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
  margin-bottom: var(--space-4);
  max-width: none;
}
.alt-feature-visual {
  background: transparent;
  border-radius: 20px;
  aspect-ratio: 4/3;
  display: flex; align-items: center; justify-content: center;
  border: none;
  overflow: visible;
  position: relative;
}
.alt-feature-visual-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  text-align: center;
  padding: var(--space-6);
}
.alt-feature-visual-icon {
  width: 64px; height: 64px;
  background: var(--color-primary);
  border-radius: var(--radius-xl);
  display: flex; align-items: center; justify-content: center;
  color: #fff;
}
.alt-feature-visual-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ── TESTIMONIAL MARQUEE & CARDS ────────────────────────── */
.testimonial-marquee {
  padding-block: clamp(var(--space-16), 7vw, var(--space-24));
  background: var(--fog);
  overflow: hidden;
  border-top: 1px solid var(--color-divider);
  border-bottom: 1px solid var(--color-divider);
}
.testimonial-marquee .section-header {
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--space-6), 5vw, var(--space-16));
  margin-bottom: var(--space-10);
  text-align: center;
}
.testimonial-marquee .section-header p { margin-inline: auto; }
.testimonial-row {
  display: flex;
  gap: var(--space-6);
  animation: marquee 45s linear infinite;
  width: max-content;
  will-change: transform;
  margin-bottom: var(--space-6);
}
.testimonial-row--reverse { animation: marquee-reverse 40s linear infinite; }
.testimonial-card {
  flex-shrink: 0;
  width: 380px;
  background: #fff;
  border: 1.5px solid #DDEFFF;
  border-radius: 20px;
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  box-shadow: 0 2px 12px rgba(29,146,255,0.06);
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}
.testimonial-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 36px rgba(29,146,255,0.12);
  border-color: rgba(29,146,255,0.3);
}
.testimonial-company {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--color-primary);
}
.testimonial-quote {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
  flex: 1;
  font-style: italic;
  max-width: none;
}
.testimonial-result {
  display: inline-block;
  background: linear-gradient(135deg, rgba(29,146,255,0.12), rgba(87,23,234,0.08));
  border: 1px solid rgba(29,146,255,0.2);
  border-radius: 100px;
  padding: 3px 12px;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-top: 8px;
  align-self: flex-start;
}

/* ── FAQ ACCORDION ──────────────────────────────────────── */
.faq-list { display: flex; flex-direction: column; gap: var(--space-3); }
.faq-item {
  background: #fff;
  border: 1.5px solid #DDEFFF;
  border-radius: 16px;
  overflow: hidden;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.faq-item[open] {
  box-shadow: 0 4px 16px rgba(29,146,255,0.08);
  border-color: rgba(29,146,255,0.2);
}
.faq-question {
  padding: var(--space-5) var(--space-6);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-text);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  transition: color 0.2s;
}
.faq-question::-webkit-details-marker { display: none; }
.faq-question::after {
  content: '+';
  font-size: 1.5rem;
  color: var(--color-primary);
  font-weight: 300;
  flex-shrink: 0;
  transition: transform 0.2s;
}
.faq-item[open] .faq-question::after { transform: rotate(45deg); }
.faq-item:hover .faq-question { color: var(--color-primary); }
.faq-answer {
  padding: 0 var(--space-6) var(--space-6);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
  max-width: none;
}

/* ── FAQ SPLIT LAYOUT ───────────────────────────────────── */
.faq-split-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.faq-split-left { position: sticky; top: 100px; }
.faq-split-right {}
@media (max-width: 800px) {
  .faq-split-layout { grid-template-columns: 1fr; }
  .faq-split-left { position: static; }
}

/* ── STATS ROW (hero section) ───────────────────────────── */
.hero-kpi-card, .value-card, .story-card, .platform-card {
  transition: transform 0.25s cubic-bezier(0.16,1,0.3,1), box-shadow 0.25s cubic-bezier(0.16,1,0.3,1), border-color 0.25s;
}

/* ── BENTO GRID ─────────────────────────────────────────── */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: auto;
  gap: 20px;
  margin-top: var(--space-10);
}
.bento-card {
  border-radius: 20px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform 0.3s cubic-bezier(0.16,1,0.3,1), box-shadow 0.3s;
}
.bento-card:hover { transform: translateY(-4px); box-shadow: 0 20px 60px rgba(0,0,0,0.10); }
.bento-card--large  { grid-column: span 5; grid-row: span 2; }
.bento-card--medium { grid-column: span 4; grid-row: span 2; }
.bento-card--small  { grid-column: span 3; }
.bento-card--wide   { grid-column: span 12; }
.bento-card--blue   { background: linear-gradient(135deg, #1D92FF 0%, #0A5FD6 100%); color: #fff; }
.bento-card--dark   { background: linear-gradient(135deg, #192B45 0%, #192B45 100%); color: #fff; }
.bento-card--light  { background: var(--fog); border: 1px solid var(--cloud); color: var(--color-text); }
.bento-card--purple { background: linear-gradient(135deg, #5717EA 0%, #3B10A8 100%); color: #fff; }
.bento-card-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.65;
}
.bento-card--blue .bento-card-label,
.bento-card--dark .bento-card-label,
.bento-card--purple .bento-card-label { color: rgba(255,255,255,0.7); }
.bento-card-title {
  font-size: clamp(1.3rem, 2vw, 1.9rem);
  font-weight: 800;
  line-height: 1.15;
  margin: 0;
}
.bento-card--blue .bento-card-title,
.bento-card--dark .bento-card-title,
.bento-card--purple .bento-card-title { color: #fff; }
.bento-card-text {
  font-size: 0.9rem;
  line-height: 1.6;
  opacity: 0.75;
  margin: 0;
}
.bento-card--blue .bento-card-text,
.bento-card--dark .bento-card-text,
.bento-card--purple .bento-card-text { color: rgba(255,255,255,0.8); }
.bento-card-stat {
  margin-top: auto;
  font-size: 3rem;
  font-weight: 800;
  color: rgba(255,255,255,0.95);
  line-height: 1;
}
.bento-card-stat span { display: block; font-size: 0.85rem; font-weight: 500; opacity: 0.7; margin-top: 4px; }
.bento-card-icon { margin-bottom: 4px; }
.bento-pill-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: auto; }
.bento-pill {
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 100px;
  padding: 4px 12px;
  font-size: 0.78rem; font-weight: 600;
  color: rgba(255,255,255,0.9);
}
.bento-integration-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }
.bento-chip {
  background: #fff;
  border: 1px solid var(--cloud);
  border-radius: 8px;
  padding: 6px 14px;
  font-size: 0.82rem; font-weight: 600;
  color: var(--color-text);
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
@media (max-width: 900px) {
  .bento-card { padding: 22px 20px; }
  .bento-card--large, .bento-card--medium, .bento-card--wide { grid-column: span 12; }
  .bento-card--small { grid-column: span 6; }
}
@media (max-width: 640px) {
  .bento-card--small { grid-column: span 12; }
}
@media (max-width: 500px) {
  .bento-card--small { grid-column: span 12; }
}

/* ── INTEGRATION HUB SVG ────────────────────────────────── */
.hub-visual-svg {
  position: relative;
  width: 100%;
  max-width: 600px;
  margin: 48px auto 0;
  aspect-ratio: 1;
}
.hub-svg { width: 100%; height: 100%; }
.hub-nodes-overlay { position: absolute; inset: 0; }
.hub-node-o {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-text-muted);
  text-align: center;
  min-width: 70px;
}
.hub-node-o-icon {
  width: 40px; height: 40px;
  background: #fff;
  border: 1.5px solid var(--cloud);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  color: var(--color-primary);
  box-shadow: 0 4px 16px rgba(29,146,255,0.12);
  transition: transform 0.3s, box-shadow 0.3s;
}
.hub-node-o:hover .hub-node-o-icon {
  transform: scale(1.12);
  box-shadow: 0 8px 28px rgba(29,146,255,0.22);
}
.hub-center-label {
  display: none;
}
/* Integration hub (non-SVG variant) */
.integration-hub {
  padding-block: clamp(var(--space-16), 7vw, var(--space-24));
  background: #fff;
}
.hub-visual {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-6);
  max-width: 700px;
  margin: var(--space-10) auto 0;
  position: relative;
}
.hub-center {
  width: 100px; height: 100px;
  background: var(--color-primary);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xs);
  text-align: center;
  line-height: 1.2;
  box-shadow: 0 8px 32px rgba(29,146,255,0.25);
  z-index: 2;
  position: relative;
}
.hub-node {
  width: 120px;
  display: flex; flex-direction: column; align-items: center; gap: var(--space-2);
  text-align: center;
}
.hub-node-icon {
  width: 56px; height: 56px;
  background: #fff;
  border: 1.5px solid #DDEFFF;
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-xs);
}

/* ── BLOG CARD EXTRAS ───────────────────────────────────── */
.blog-card-eyebrow {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: 6px;
  margin-top: 2px;
}
.blog-card-author {
  font-size: 0.72rem;
  color: var(--color-text-faint);
  margin-left: 8px;
  padding-left: 8px;
  border-left: 1px solid var(--color-divider);
}
.blog-card:hover .blog-card-eyebrow { color: var(--color-secondary); }
.blog-card:first-child { grid-column: span 1; }

/* ── CLIENT COMPANY GRID ────────────────────────────────── */
.client-company-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  margin-top: var(--space-10);
}
.client-company-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--fog);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: 16px 20px;
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}
.client-company-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(29,146,255,0.10);
  border-color: rgba(29,146,255,0.25);
}
.client-company-initial {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800;
  font-size: 1rem;
  color: #fff;
  flex-shrink: 0;
}
.client-company-info { flex: 1; min-width: 0; }
.client-company-name {
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.client-role-badge {
  display: inline-block;
  background: rgba(29,146,255,0.10);
  color: var(--color-primary);
  border-radius: 100px;
  padding: 2px 10px;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-top: 3px;
}
.client-company-result {
  font-size: 0.72rem;
  font-weight: 700;
  color: #00B87A;
  white-space: nowrap;
  text-align: right;
  flex-shrink: 0;
}
@media (max-width: 600px) {
  .client-company-grid { grid-template-columns: 1fr; }
  .client-company-result { display: none; }
}

/* ── CONTACT GRADIENT SECTION ───────────────────────────── */
.contact-gradient-section {
  background: linear-gradient(135deg, #f4f0ff 0%, #e8f4ff 40%, #f0fff8 100%);
  position: relative;
  overflow: hidden;
}
.contact-gradient-section::before {
  content: '';
  position: absolute;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(87,23,234,0.07) 0%, transparent 70%);
  top: -100px; right: -50px;
  border-radius: 50%;
  pointer-events: none;
}
.contact-gradient-section::after {
  content: '';
  position: absolute;
  width: 350px; height: 350px;
  background: radial-gradient(circle, rgba(29,146,255,0.07) 0%, transparent 70%);
  bottom: -50px; left: 5%;
  border-radius: 50%;
  pointer-events: none;
}
.contact-gradient-section { }

/* ── BASE CARD ──────────────────────────────────────────── */
.card {
  background: #fff;
  border: 1px solid #dde8f5;
  border-radius: 16px;
  padding: var(--space-7) var(--space-7);
  display: flex;
  flex-direction: column;
  box-shadow: 0 1px 4px rgba(0,0,0,0.07), 0 6px 24px rgba(29,146,255,0.08);
  transition: transform 0.25s cubic-bezier(0.16,1,0.3,1), box-shadow 0.25s cubic-bezier(0.16,1,0.3,1);
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(29,146,255,0.13), 0 2px 8px rgba(0,0,0,0.06);
}

/* Problem/Challenge card variant */
.card--problem {
  border-left: 3px solid rgba(239,68,68,0.4);
  background: #fff9f9;
}
.card--problem .card-icon {
  background: rgba(239,68,68,0.08) !important;
  color: #ef4444 !important;
}
.card--problem:hover {
  border-left-color: #ef4444;
  box-shadow: 0 12px 40px rgba(239,68,68,0.10), 0 2px 8px rgba(0,0,0,0.04);
}
.card-title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: var(--s-2);
  color: var(--color-navy);
  line-height: 1.3;
}
.card-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.65;
  flex: 1;
}
.card-list {
  margin: var(--s-3) 0 0 0;
  padding-left: 1.1em;
  font-size: 0.82rem;
  color: var(--color-text-muted);
  line-height: 1.55;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.card-link {
  margin-top: var(--s-4);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: gap 0.2s;
}
.card-link:hover { gap: 8px; }
/* Card with colored top border — icon must sit inside padding, not straddle border */
.card[style*="border-top"] {
  padding-top: var(--space-6);
}

/* ── PRICING ────────────────────────────────────────────── */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: start;
}
.tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: start;
}
.pricing-card--featured {
  transform: translateY(-12px);
  border-color: var(--color-primary) !important;
  box-shadow: 0 24px 64px rgba(29,146,255,0.18), 0 4px 16px rgba(0,0,0,0.06) !important;
  position: relative;
  z-index: 2;
}
.pricing-card--featured:hover { transform: translateY(-16px) !important; }
.pricing-recommended-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg, #FFD221, #F5A623);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 100px;
  margin-bottom: 16px;
  box-shadow: 0 4px 12px rgba(253,128,6,0.3);
}
@media (max-width: 768px) {
  .pricing-grid { grid-template-columns: 1fr; }
  .tier-grid    { grid-template-columns: 1fr; }
  .pricing-card--featured { transform: none; }
}

/* ═══════════════════════════════════════════════════════════
   SECTION 15 — LEGAL PAGES
   ═══════════════════════════════════════════════════════════ */

.legal-content h2 {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 2.5rem 0 0.75rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-divider);
}
.legal-content h2:first-child { border-top: none; padding-top: 0; }
.legal-content h3 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-text);
  margin: 1.5rem 0 0.5rem;
}
.legal-content p {
  color: var(--color-text-muted);
  line-height: 1.75;
  margin-bottom: 1rem;
}
.legal-content ul, .legal-content ol {
  color: var(--color-text-muted);
  line-height: 1.75;
  margin: 0.5rem 0 1rem 1.5rem;
}
.legal-content li { margin-bottom: 0.4rem; }
.legal-content a { color: var(--color-primary); }
.legal-content a:hover { text-decoration: underline; }
.legal-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0;
  font-size: 0.9rem;
}
.legal-content th {
  background: var(--fog);
  padding: 10px 14px;
  text-align: left;
  font-weight: 600;
  border: 1px solid var(--color-divider);
}
.legal-content td {
  padding: 10px 14px;
  border: 1px solid var(--color-divider);
  color: var(--color-text-muted);
  vertical-align: top;
}
.legal-content strong { color: var(--color-text); font-weight: 600; }
.legal-content .legal-contact-box {
  background: var(--fog);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: 24px 28px;
  margin: 1.5rem 0;
}

/* ═══════════════════════════════════════════════════════════
   SECTION 16 — PAGE-SPECIFIC EXTRACTED STYLES
   ═══════════════════════════════════════════════════════════ */

/* ── Extracted from regulatory-reporting.html ─────────── */
.reg-category {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-7);
  margin-bottom: var(--space-6);
}
.reg-category-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-divider);
}
.reg-category-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.reg-category-title { font-size: var(--text-xl); font-weight: 700; color: var(--color-text); margin-bottom: 4px; }
.reg-category-subtitle { font-size: var(--text-sm); color: var(--color-text-muted); }
.reg-use-cases {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}
.reg-uc-item {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  border-left: 3px solid transparent;
}
.reg-uc-item--primary      { border-left-color: var(--color-primary); }
.reg-uc-item--cornflower   { border-left-color: #5717ea; }
.reg-uc-item--tangerine    { border-left-color: #fd8006; }
.reg-uc-item--raspberry    { border-left-color: #5717EA; }
.reg-uc-item--tree         { border-left-color: #24C774; }
.reg-uc-item--ocean        { border-left-color: #19add0; }
.reg-uc-title { font-size: var(--text-sm); font-weight: 700; color: var(--color-text); margin-bottom: 6px; }
.reg-uc-desc  { font-size: var(--text-xs); color: var(--color-text-muted); line-height: 1.6; }
.reg-uc-badge {
  display: inline-block;
  font-size: 0.68rem; font-weight: 700;
  padding: 2px 8px; border-radius: 20px;
  margin-bottom: 8px;
  text-transform: uppercase; letter-spacing: .04em;
}
.reg-uc-badge--blue   { background: rgba(29,146,255,0.12);  color: #1d92ff; }
.reg-uc-badge--purple { background: rgba(87,23,234,0.10);   color: #5717ea; }
.reg-uc-badge--orange { background: rgba(212,148,10,0.12);    color: #FFD221; }
.reg-uc-badge--pink   { background: rgba(87,23,234,0.10);    color: #5717EA; }
.reg-uc-badge--green  { background: rgba(29,189,142,0.12);   color: #24C774; }
.reg-uc-badge--teal   { background: rgba(25,173,208,0.12);  color: #19add0; }
.framework-tag {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.72rem; font-weight: 600;
  padding: 3px 10px; border-radius: 20px;
  background: rgba(29,146,255,0.08); color: var(--color-primary);
  border: 1px solid rgba(29,146,255,0.2);
  margin: 3px;
}
.how-it-works-step {
  display: flex; gap: var(--space-5); align-items: flex-start;
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
}
.step-number {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--color-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-lg); font-weight: 800;
  flex-shrink: 0;
}
@media (max-width: 768px) {
  .reg-use-cases { grid-template-columns: 1fr; }
  .reg-category-header { flex-direction: column; }
  .reg-category-header > div:last-child { margin-left: 0; }
}

/* ── Extracted from industries/public-sector.html ────── */
.before-after-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--color-border);
  margin-top: 32px;
}
.ba-header {
  padding: 18px 24px;
  font-weight: 700; font-size: 0.95rem;
  letter-spacing: 0.03em; text-transform: uppercase;
  display: flex; align-items: center; gap: 8px;
}
.ba-header--before { background: #fef2f2; color: #dc2626; border-bottom: 1px solid #fecaca; }
.ba-header--after  { background: #f0fdf4; color: #16a34a; border-bottom: 1px solid #bbf7d0; border-left: 1px solid #bbf7d0; }
.ba-row {
  padding: 16px 24px; font-size: 0.92rem; line-height: 1.55;
  display: flex; align-items: flex-start; gap: 10px;
  color: var(--color-text-muted);
}
.ba-row--before { background: #fff; border-bottom: 1px solid #fee2e2; }
.ba-row--after  { background: #f9fffe; border-bottom: 1px solid #dcfce7; border-left: 1px solid #dcfce7; }
.ba-row:last-child { border-bottom: none; }
.ba-icon { flex-shrink: 0; margin-top: 2px; font-size: 1rem; }
.objection-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 28px;
  position: relative;
}
.objection-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: #f0fdf4; color: #16a34a;
  border: 1px solid #bbf7d0; border-radius: 20px;
  padding: 4px 12px; font-size: 0.78rem; font-weight: 600; margin-bottom: 12px;
}
.objection-quote { font-size: 0.88rem; font-style: italic; color: var(--color-text-muted); margin-bottom: 10px; line-height: 1.5; }
.objection-body  { font-size: 0.9rem; color: var(--color-text); line-height: 1.6; }
.expansion-steps { display: flex; flex-direction: column; gap: 0; margin-top: 32px; }
.expansion-step { display: grid; grid-template-columns: 64px 1fr; gap: 0; position: relative; }
.expansion-step:not(:last-child) .step-line {
  position: absolute; left: 31px; top: 52px; bottom: 0; width: 2px;
  background: var(--color-border);
}
.step-num-col { display: flex; flex-direction: column; align-items: center; padding-top: 4px; }
.step-num {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--color-primary-light); color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1rem;
  flex-shrink: 0; z-index: 1; position: relative;
}
.step-num--advanced { background: var(--color-secondary-light); color: var(--color-secondary); }
.step-content { padding: 4px 0 32px 20px; }
.step-title { font-weight: 700; font-size: 1rem; color: var(--color-text); margin-bottom: 4px; }
.step-time {
  display: inline-block;
  background: var(--color-primary-light); color: var(--color-primary);
  border-radius: 20px; padding: 2px 10px; font-size: 0.75rem; font-weight: 600; margin-bottom: 8px;
}
.step-desc { font-size: 0.9rem; color: var(--color-text-muted); line-height: 1.55; }
.arch-layer {
  background: #fff; border: 1px solid var(--color-border);
  border-radius: 12px; padding: 28px; margin-bottom: 16px;
}
.arch-layer-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--color-primary-light); color: var(--color-primary);
  font-weight: 800; font-size: 0.9rem; margin-bottom: 12px;
}
.arch-layer-title { font-weight: 700; font-size: 1.05rem; color: var(--color-text); margin-bottom: 8px; }
.arch-layer-desc  { font-size: 0.9rem; color: var(--color-text-muted); line-height: 1.6; margin-bottom: 16px; }
.arch-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.arch-tag {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: 6px; padding: 4px 10px;
  font-size: 0.78rem; font-weight: 500; color: var(--color-text);
}
.hosting-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px; margin-top: 32px;
}
.hosting-card {
  background: #fff; border: 1px solid var(--color-border);
  border-radius: 12px; padding: 24px;
}
.hosting-card-logo   { font-weight: 700; font-size: 1rem; color: var(--color-text); margin-bottom: 6px; }
.hosting-card-region { font-size: 0.8rem; color: var(--color-primary); font-weight: 600; margin-bottom: 10px; }
.hosting-card-desc   { font-size: 0.88rem; color: var(--color-text-muted); line-height: 1.55; }
.dept-card {
  background: #fff; border: 1px solid var(--color-border);
  border-radius: 12px; padding: 24px;
}
.dept-card-title {
  font-weight: 700; font-size: 0.98rem; color: var(--color-text);
  margin-bottom: 10px; display: flex; align-items: center; gap: 10px;
}
.dept-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--color-primary-light); color: var(--color-primary);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.dept-list { list-style: none; padding: 0; margin: 0; }
.dept-list li {
  font-size: 0.87rem; color: var(--color-text-muted);
  padding: 4px 0; display: flex; align-items: flex-start; gap: 8px; line-height: 1.4;
}
.dept-list li::before { content: "›"; color: var(--color-primary); font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.why-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px; margin-top: 32px;
}
.why-card {
  background: #fff; border: 1px solid var(--color-border);
  border-radius: 12px; padding: 28px;
}
.why-card-num {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--color-primary-light); color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 0.9rem; margin-bottom: 14px;
}
.why-card-title { font-weight: 700; font-size: 1rem; color: var(--color-text); margin-bottom: 8px; }
.why-card-desc  { font-size: 0.9rem; color: var(--color-text-muted); line-height: 1.6; }
@media (max-width: 640px) {
  .before-after-grid { grid-template-columns: 1fr; }
  .ba-header--after, .ba-row--after { border-left: none; border-top: 1px solid #bbf7d0; }
}

/* ── Careers page ───────────────────────────────────────── */
.careers-hero {
  background: var(--hero-gradient);
}
.value-card {
  transition: transform 0.25s cubic-bezier(0.16,1,0.3,1), box-shadow 0.25s cubic-bezier(0.16,1,0.3,1), border-color 0.25s;
}
.value-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(29,146,255,0.14), 0 2px 8px rgba(0,0,0,0.06);
  border-color: rgba(29,146,255,0.4);
}
.application-form {
  background: #fff;
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
}
.file-upload-area {
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.file-upload-area:hover {
  border-color: var(--color-primary);
  background: var(--fog);
}
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-6);
}


/* ── ADDITIONAL PAGE FIXES ───────────────────────────── */

/* Contact page: warm gradient section */
.contact-gradient-section {
  background: linear-gradient(135deg, #f0eeff 0%, #e8f3ff 40%, #edfff7 100%) !important;
}

/* Hero--centered for pages that use it */
.hero--centered {
  background: var(--hero-bg);
  position: relative;
  overflow: hidden;
  text-align: center;
  padding-block: clamp(100px, 10vw, 140px) clamp(var(--s-12), 6vw, var(--s-20));
}
.hero--centered .container { max-width: var(--w-narrow); }
.hero--centered .hero-title { font-size: var(--text-3xl); }
.hero--centered .section-subtitle { margin-inline: auto; }

/* Hero visual mobile — show as card below text */
@media (max-width: 900px) {
  .hero-inner--split { grid-template-columns: 1fr; }
  .hero-content--left { padding-bottom: var(--s-12); }
  .hero-screenshot-wrap { width: 100%; margin-left: 0; }
}

/* Ensure product-pill-float is contained */
.page-header { position: relative; }
.hero--blue { position: relative; }

/* ── KEY VISUAL 2026 (homepage hero image) ─────────────────────────── */
/* hero-keyvisual — clean card display in split hero */
.hero-keyvisual {
  display: block;
  width: 100%;
  height: auto;
  max-height: 560px;
  object-fit: cover;
  object-position: center 22%;
}

/* ═══════════════════════════════════════════════════════════
   QA FIXES — April 11 2026
   ═══════════════════════════════════════════════════════════ */

/* FIX 1: hero-dots — needs padding-top to clear fixed nav */
.hero-dots {
  padding-top: clamp(100px, 10vw, 130px);
  padding-bottom: clamp(60px, 6vw, 100px);
  background: linear-gradient(160deg, #dde8f5 0%, #e8f1fb 30%, #eef5ff 60%, #f5f9ff 80%, #ffffff 100%);
}

/* FIX 2: recurring-tasks-section — no CSS existed at all */
.recurring-tasks-section {
  padding-block: clamp(60px, 7vw, 100px);
  background: linear-gradient(135deg, #192B45 0%, #192B45 60%, #0A1628 100%);
  color: #fff;
}
.recurring-tasks-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  max-width: var(--w-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--s-5), 5vw, var(--s-16));
}
.recurring-tasks-text h2 {
  color: #fff;
  font-size: clamp(1.7rem, 2.8vw, 2.4rem);
  font-weight: 700;
  margin-bottom: var(--s-4);
}
.recurring-tasks-text p {
  color: rgba(255,255,255,0.75);
  line-height: 1.7;
  margin-bottom: var(--s-5);
}
@media (max-width: 768px) {
  .recurring-tasks-layout { grid-template-columns: 1fr; }
}

/* hero-keyvisual final override — removed, base rule above is canonical */

/* ═══════════════════════════════════════════════════════════
   AWARD CARDS (About page)
   ═══════════════════════════════════════════════════════════ */

.awards-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
}
@media (max-width: 1024px) { .awards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .awards-grid { grid-template-columns: 1fr; } }

.award-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.2s, transform 0.2s;
}
.award-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.award-logo-wrap {
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--s-2);
}

.award-logo {
  max-width: 100%;
  max-height: 96px;
  width: auto;
  height: auto;
  object-fit: contain;
}
.award-logo--wef      { max-height: 72px; max-width: 85%; }
.award-logo--focus    { max-height: 80px; max-width: 80%; }
.award-logo--ki       { max-height: 56px; max-width: 95%; }
.award-logo--deloitte { max-height: 72px; max-width: 90%; }

/* Deloitte text badge (no official logo available) */
.award-logo-wrap--text {
  background: #f8f8f8;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.award-text-badge {
  display: flex;
  align-items: center;
  gap: 10px;
}
.award-text-badge-num {
  font-size: 2.4rem;
  font-weight: 800;
  color: #86BC25; /* Deloitte green */
  line-height: 1;
}
.award-text-badge-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.award-text-badge-name {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.2;
}
.award-text-badge-sub {
  font-size: 0.78rem;
  font-weight: 700;
  color: #86BC25;
  line-height: 1;
}

.award-card-body { display: flex; flex-direction: column; gap: 4px; }
.award-card-title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.3;
}
.award-card-year {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-primary);
  letter-spacing: 0.02em;
}
.award-card-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.65;
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════
   PLATFORM PAGE LAYOUT FIXES — April 13 2026
   ═══════════════════════════════════════════════════════════ */

/* ── Hero inner split (platform pages hero--blue) ────────── */
.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  max-width: var(--w-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--s-5), 5vw, var(--s-16));
  padding-top: clamp(80px, 8vw, 110px);
  padding-bottom: clamp(40px, 5vw, 64px);
}
.hero-content { display: flex; flex-direction: column; gap: var(--s-5); }
.hero-img-wrap { position: relative; }
.hero-product-img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  display: block;
}
@media (max-width: 900px) {
  .hero-inner {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 96px;
    padding-bottom: 32px;
  }
  .hero-img-wrap { display: none; }
}

/* ── Features list VC (2-column: rows left, image right) ─── */
.features-list-vc {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  margin-top: var(--s-12);
}
.features-list-vc-rows {
  display: flex;
  flex-direction: column;
  gap: 0;
  /* dividers between rows */
}
.features-list-vc-row {
  display: flex;
  gap: var(--s-5);
  align-items: flex-start;
  padding-block: var(--s-6);
  border-bottom: 1px solid var(--color-border);
}
.features-list-vc-row:first-child { border-top: 1px solid var(--color-border); }
.features-list-vc-icon {
  width: 48px;
  height: 48px;
  min-width: 48px;
  background: var(--color-primary-light);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  border: 1px solid rgba(29,146,255,0.12);
  margin-top: 2px;
}
.features-list-vc-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--s-2);
  line-height: 1.3;
  letter-spacing: -0.01em;
}
.features-list-vc-body {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.75;
  margin: 0;
}
.features-list-vc-visual img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  display: block;
}
@media (max-width: 900px) {
  .features-list-vc { grid-template-columns: 1fr; }
  .features-list-vc-visual { order: -1; }
}

/* ── Analytics section (split layout, no bg = white) ─────── */
.analytics-section {
  padding-block: clamp(var(--s-12), 7vw, var(--s-24));
  background: var(--color-surface);
}
.analytics-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  max-width: var(--w-wide);
  margin-inline: auto;
  padding-inline: clamp(var(--s-5), 5vw, var(--s-16));
}
.analytics-text { display: flex; flex-direction: column; gap: var(--s-5); }
.analytics-text h2 {
  font-size: clamp(1.75rem, 2.8vw, 2.5rem);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.15;
  letter-spacing: -0.02em;
}
.analytics-text p {
  color: var(--color-text-muted);
  line-height: 1.75;
  font-size: var(--text-base);
}
.analytics-feature {
  display: flex;
  gap: var(--s-4);
  align-items: flex-start;
  padding-block: var(--s-4);
  border-bottom: 1px solid var(--color-border);
}
.analytics-feature:first-of-type { border-top: 1px solid var(--color-border); }
.analytics-feature-icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  background: var(--color-primary-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  border: 1px solid rgba(29,146,255,0.12);
  flex-shrink: 0;
  margin-top: 2px;
}
.analytics-feature-title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 4px;
  line-height: 1.3;
  letter-spacing: -0.01em;
}
.analytics-feature-body {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.72;
  margin: 0;
}
.analytics-visual img,
.analytics-img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  display: block;
}
@media (max-width: 900px) {
  .analytics-layout { grid-template-columns: 1fr; }
  .analytics-visual { order: -1; }
}

/* ── Remove data-animate from layout containers ──────────── */
/* The recurring-tasks-layout had data-animate which made the
   entire block opacity:0. Fix: only animate children. */
.recurring-tasks-layout {
  opacity: 1 !important;
  transform: none !important;
}

/* ── Hero dots sizing cleanup ─────────────────────────────── */
/* Override the too-large padding from QA-fixes if hero has hero-inner */
.hero.hero--blue.hero-dots {
  padding-top: 0;
  padding-bottom: 0;
}


/* ── DATA-FLOW VISUAL (recurring-tasks right column) ─────── */
.data-flow-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--s-6);
}
.data-flow-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-xl);
  padding: var(--s-6);
  width: 100%;
  max-width: 400px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.data-flow-step {
  display: flex;
  gap: var(--s-4);
  align-items: center;
  padding-block: var(--s-4);
}
.data-flow-step-icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  background: rgba(29,146,255,0.15);
  border: 1px solid rgba(29,146,255,0.3);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #60b4ff;
}
.data-flow-step-icon--mid {
  background: rgba(87,23,234,0.15);
  border-color: rgba(87,23,234,0.3);
  color: #a78bfa;
}
.data-flow-step-icon--end {
  background: rgba(0,184,122,0.15);
  border-color: rgba(0,184,122,0.3);
  color: #34d399;
}
.data-flow-step-title {
  font-size: var(--text-sm);
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  margin-bottom: 2px;
}
.data-flow-step-sub {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.4;
}
.data-flow-arrow {
  text-align: center;
  color: rgba(29,146,255,0.4);
  font-size: 1.2rem;
  line-height: 1;
  padding-block: 2px;
  padding-left: 14px;
}

/* ── PAGE HEADER: full-width when no visual column ───────── */
/* When page-header-inner only has one child (page-header-content),
   collapse to single column. Works without :has() support. */
.page-header-inner > .page-header-content:only-child {
  grid-column: 1 / -1;
}
/* Also explicitly: if no .page-header-visual sibling, go full width */
.page-header-inner:not(:has(> .page-header-visual)) {
  grid-template-columns: 1fr;
}
.page-header-inner:not(:has(> .page-header-visual)) .page-header-content {
  max-width: 72ch;
}


/* ═══════════════════════════════════════════════════════════
   VISUAL REFRESH — April 15 2026
   Lighter headlines, cleaner hero background
   ═══════════════════════════════════════════════════════════ */

/* Thin hero headlines — modern, ElevenLabs-style */
.hero-content--left .hero-title,
.hero-content .hero-title {
  font-weight: 300;
  letter-spacing: -0.02em;
}

/* page-header (industry pages) — thin headline */
.page-header-content h1 {
  font-weight: 300;
  letter-spacing: -0.015em;
  line-height: 1.08;
}

/* why-acceleraid hero */
.hero-inner .hero-content h1,
.hero-inner .hero-content .hero-title {
  font-weight: 300;
  letter-spacing: -0.02em;
}

/* Slightly sharpen nav font */
.nav-link { font-weight: 400; }


/* ═══════════════════════════════════════════════════════════════
   MOBILE HERO — images visible below text on all screen sizes
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* Homepage split hero */
  .hero--split .hero-inner {
    grid-template-columns: 1fr;
  }
  .hero--split .hero-content--right {
    display: flex;
    justify-content: center;
    padding-top: var(--space-6);
  }
  .hero-keyvisual {
    max-width: 260px;
    max-height: 350px;
    object-fit: cover;
    object-position: top center;
    border-radius: 20px;
    mix-blend-mode: normal !important;
    filter: none !important;
    box-shadow: 0 8px 40px rgba(29,146,255,0.18);
    position: static !important;
  }
}
@media (max-width: 480px) {
  .hero-keyvisual {
    max-width: 200px;
    max-height: 280px;
  }
}




/* ╔═══════════════════════════════════════════════════════════════════════╗
   ║  MOBILE HERO — definitive responsive fix                            ║
   ║  All hero/industry images visible below text on mobile              ║
   ╚═══════════════════════════════════════════════════════════════════════╝ */

@media (max-width: 900px) {
  /* Homepage split: stack column */
  .hero--split .hero-inner,
  .hero-inner--split {
    grid-template-columns: 1fr !important;
    display: grid !important;
  }

  /* Homepage iPhone image */
  .hero-keyvisual {
    position: static !important;
    display: block;
    max-width: 220px !important;
    width: auto !important;
    height: auto !important;
    max-height: 300px !important;
    border-radius: 20px;
    box-shadow: 0 8px 40px rgba(29,146,255,0.2);
    mix-blend-mode: normal !important;
    filter: none !important;
    margin: 0 auto;
  }
  .hero--split .hero-content--right {
    display: flex !important;
    justify-content: center;
    padding: 20px 0 8px;
  }

  /* hero-visual (Why Acceleraid, About, platform pages) */
  .hero-visual {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    height: 260px !important;
    min-height: 0 !important;
    overflow: hidden;
    border-radius: 16px;
    margin-top: 20px;
  }
  .hero-visual img {
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: auto !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center 15% !important;
    border-radius: 16px !important;
    box-shadow: none !important;
  }

  /* page-header-visual (industry pages) */
  .page-header-inner {
    grid-template-columns: 1fr !important;
    display: grid !important;
  }
  .page-header-visual {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    height: 280px !important;
    min-height: 0 !important;
    align-self: auto !important;
    overflow: hidden;
    border-radius: 16px;
    margin-top: 20px;
  }
  .page-header-visual img {
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: auto !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center 20% !important;
    border-radius: 16px !important;
    box-shadow: none !important;
  }
}

@media (max-width: 480px) {
  .page-header-visual { height: 220px !important; }
  .hero-visual { height: 200px !important; }
  .hero-keyvisual { max-width: 180px !important; max-height: 240px !important; }
}

/* Force page-header-visual image full width on mobile — kill desktop flex alignment */
@media (max-width: 900px) {
  .page-header-visual {
    justify-content: flex-start !important;
    align-items: flex-start !important;
  }
}

/* Mobile: page-header-inner full width fix */
@media (max-width: 900px) {
  .page-header-inner {
    padding-inline: 16px !important;
    max-width: 100% !important;
    width: 100% !important;
    box-sizing: border-box;
    grid-template-columns: 1fr !important;
  }
  .page-header {
    padding-inline: 0 !important;
  }
}

/* CRITICAL: Mobile page-header-inner full width */
@media (max-width: 900px) {
  .page-header-inner {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
    min-height: auto !important;
    box-sizing: border-box !important;
    grid-template-columns: 1fr !important;
  }
}

/* MOBILE IMAGE BREAKOUT — full-width regardless of container constraints */
@media (max-width: 900px) {
  .page-header-visual {
    /* Break out of container: use viewport width */
    position: relative;
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    height: 280px !important;
    max-height: 280px;
    border-radius: 0 !important;
    margin-top: 24px;
    overflow: hidden;
  }
  .page-header-visual img {
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: auto !important;
    width: 100% !important; height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center 20% !important;
    border-radius: 0 !important;
  }
  
  /* Hero-visual same breakout */
  .hero-visual {
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    height: 260px !important;
    border-radius: 0 !important;
    margin-top: 24px;
    overflow: hidden;
    position: relative;
  }
  .hero-visual img {
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: auto !important;
    width: 100% !important; height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center 15% !important;
    border-radius: 0 !important;
  }
}

@media (max-width: 480px) {
  .page-header-visual { height: 220px !important; }
  .hero-visual { height: 200px !important; }
}

/* MOBILE FULL-WIDTH IMAGE — absolute breakout from page-header */
@media (max-width: 900px) {
  /* Make page-header itself the positioning context */
  .page-header {
    overflow: visible;
  }
  .page-header-visual {
    position: static !important;
    width: calc(100% + 0px) !important;
    margin-left: 0 !important;
    left: auto !important;
    right: auto !important;
    display: block !important;
    height: 280px !important;
    overflow: hidden;
    border-radius: 12px;
    margin-top: 20px;
    box-sizing: border-box;
  }
  .page-header-visual img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: auto !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center 20% !important;
    border-radius: 12px !important;
    box-shadow: none !important;
  }
}

/* ROOT FIX: page-header flex → column on mobile so inner gets full width */
@media (max-width: 900px) {
  .page-header {
    display: block !important;
    min-height: auto !important;
    padding-bottom: 32px;
  }
  .page-header-inner {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding-inline: 20px !important;
    box-sizing: border-box;
    grid-template-columns: 1fr !important;
    min-height: auto !important;
  }
  .product-pill-float {
    position: absolute;
    top: 20px;
    right: 20px;
  }
}

/* MOBILE ORDER FIX: text first, image second */
@media (max-width: 900px) {
  .page-header-inner {
    display: flex !important;
    flex-direction: column !important;
  }
  .page-header-content {
    order: 1;
    padding-bottom: 0;
    padding-right: 0;
  }
  .page-header-visual {
    order: 2;
    /* Full width image below text */
    width: calc(100% + 40px) !important;
    margin-left: -20px !important;
    margin-right: -20px !important;
    height: 280px !important;
    border-radius: 0 !important;
    overflow: hidden;
    position: relative;
    flex-shrink: 0;
    display: block !important;
  }
  .page-header-visual img {
    position: absolute !important;
    top: 0 !important; left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center 20% !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════
   ║  NUCLEAR MOBILE FIX — complete hero/page-header override
   ║  Priority: this MUST be the LAST CSS in the file
   ╚══════════════════════════════════════════════════════════════ */
@media screen and (max-width: 900px) {

  /* 1. page-header: switch to block so inner can be full width */
  section.page-header,
  .page-header {
    display: block !important;
    min-height: auto !important;
    overflow: hidden !important;
  }

  /* 2. page-header-inner: full width, column flex */
  .page-header-inner {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box !important;
    gap: 20px !important;
    align-items: stretch !important;
  }

  /* 3. Text content: first, normal flow */
  .page-header-content {
    order: 1 !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* 4. Visual container: second, full-width image card */
  .page-header-visual {
    order: 2 !important;
    display: block !important;
    position: relative !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 260px !important;
    min-height: 0 !important;
    overflow: hidden !important;
    border-radius: 16px !important;
    align-self: stretch !important;
    flex-shrink: 0 !important;
    justify-content: unset !important;
    align-items: unset !important;
  }

  /* 5. Image inside visual: fill container completely */
  .page-header-visual > img,
  .page-header-visual img {
    position: absolute !important;
    inset: 0 !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    object-fit: cover !important;
    object-position: center 20% !important;
    border-radius: 16px !important;
    box-shadow: none !important;
  }

  /* 6. Floating pill: absolutely positioned, not in flow */
  .product-pill-float {
    position: fixed !important;
    top: 80px !important;
    right: 12px !important;
    z-index: 50;
  }
}

@media screen and (max-width: 480px) {
  .page-header-visual { height: 200px !important; }
}

/* FINAL CLEANUP */
@media screen and (max-width: 900px) {
  /* Hide the floating pill badge — too disruptive on mobile */
  .product-pill-float {
    display: none !important;
    position: static !important;
  }
  /* Make image edge-to-edge (no side padding) */
  .page-header-visual {
    margin-left: -20px !important;
    margin-right: -20px !important;
    width: calc(100% + 40px) !important;
    border-radius: 0 !important;
  }
  .page-header-visual img {
    border-radius: 0 !important;
  }
}


/* ╔══════════════════════════════════════════════════════════
   ║  RIVERSIDE-STYLE FEATURE IMAGES
   ║  Floating cards, no hard borders, soft shadow + fade
   ╚══════════════════════════════════════════════════════════ */

/* Alt-feature (How it Works) images — floating, no hard box */
.alt-feature-visual.img-float {
  overflow: hidden;
  border-radius: 16px;
  box-shadow:
    0 2px 8px rgba(0,0,0,0.06),
    0 12px 40px rgba(29,146,255,0.10),
    0 0 0 1px rgba(29,146,255,0.07);
  background: #fff;
  transform: translateY(0);
  transition: transform 0.4s cubic-bezier(0.16,1,0.3,1), box-shadow 0.4s cubic-bezier(0.16,1,0.3,1);
}
.alt-feature-visual.img-float:hover {
  transform: translateY(-6px);
  box-shadow:
    0 4px 12px rgba(0,0,0,0.08),
    0 24px 60px rgba(29,146,255,0.14),
    0 0 0 1px rgba(29,146,255,0.08);
}
.alt-feature-visual.img-float img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  border-radius: 16px;
}

/* Full-bleed image — no border, fades at bottom like Riverside */
.alt-feature-visual.img-bleed {
  overflow: hidden;
  border-radius: 16px 16px 0 0;
  background: linear-gradient(180deg, #f7f9ff 0%, #fff 100%);
}
.alt-feature-visual.img-bleed img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  border-radius: 16px 16px 0 0;
  -webkit-mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
  mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
}

/* Dashboard/infographic images — show full, light shadow, rounded */
.alt-feature-visual.img-dashboard {
  overflow: hidden;
  border-radius: 16px;
  background: #f8faff;
  box-shadow:
    0 1px 3px rgba(0,0,0,0.05),
    0 8px 32px rgba(29,146,255,0.09),
    0 0 0 1px rgba(29,146,255,0.08);
}
.alt-feature-visual.img-dashboard img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  padding: 8px;
}

/* ══ PAGE HEADER LAYOUT FIX — proper vertical alignment ══════════════ */
@media (min-width: 901px) {

  /* Inner: content aligned to top */
  .page-header-inner {
    align-items: start !important;
    min-height: 75vh !important;
    padding-top: 36px;
  }

  /* Content: tight, no extra padding */
  .page-header-content {
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    justify-content: flex-start;
  }

  /* Visual: fill full column height, image from top */
  .page-header-visual {
    align-self: stretch !important;
    min-height: 75vh !important;
  }

  .page-header-visual img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center top !important;
    border-radius: 0 !important;
    max-height: none !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════════
   ║  SMART CROP — per-page hero image positioning
   ║  Ensures faces + key content are always visible
   ╚══════════════════════════════════════════════════════════════════ */

/* Global: all page-header-visual images default to center top
   (shows face in portrait photos) */
.page-header-visual img {
  object-position: center 15% !important;
}

/* Why Acceleraid — team at monitor: show monitor in lower half */
[data-page="why-acceleraid"] .hero-visual img,
.hero-visual img[src*="why-acceleraid"] {
  object-position: center 60% !important;
}

/* Platform pages — show person + screen together */
.page-header-visual img[src*="platform"],
.hero-visual img[src*="platform"] {
  object-position: center 30% !important;
}

/* Industry hero images — person faces at top, device at bottom */
.page-header-visual img[src*="hero-banking"],
.page-header-visual img[src*="hero-insurance"],
.page-header-visual img[src*="hero-credit-cards"],
.page-header-visual img[src*="hero-public-sector"],
.page-header-visual img[src*="hero-financial-services"],
.page-header-visual img[src*="hero-private-banking"],
.page-header-visual img[src*="hero-fintech"],
.page-header-visual img[src*="hero-telco"],
.page-header-visual img[src*="hero-retail"],
.page-header-visual img[src*="hero-travel"],
.page-header-visual img[src*="hero-automotive"],
.page-header-visual img[src*="hero-energy"],
.page-header-visual img[src*="hero-loyalty"] {
  object-position: center 20% !important;
}

/* Advisor/meeting photos — show both people and screen */
.page-header-visual img[src*="hero-banking"],
.page-header-visual img[src*="hero-insurance"] {
  object-position: center 25% !important;
}

/* Laptop/MacBook photos — show screen + person together */
.page-header-visual img[src*="macbook"],
.page-header-visual img[src*="laptop"],
.page-header-visual img[src*="prediction"],
.page-header-visual img[src*="platform-index"],
.page-header-visual img[src*="journey"] {
  object-position: center 35% !important;
}

/* Platform module pages — ensure text readable on light hero bg */
section.page-header .page-header-content .hero-badge,
section.page-header .page-header-content h1,
section.page-header .page-header-content .page-header-subtitle {
  color: var(--color-navy) !important;
}

/* Contact page form section — ensure visible */
.contact-gradient-section .form-input,
.contact-gradient-section .form-select,
.contact-gradient-section .form-label {
  display: block;
}

/* ── Scroll entrance animations (will-animate / did-animate) ── */





/* Staggered children inside a parent */









/* ══════════════════════════════════════════════════════════════
   PHOTO HERO — vollflächiges Bild mit dark overlay
   ══════════════════════════════════════════════════════════════ */
.page-header--photo {
  background: #0B1623;
  min-height: clamp(520px, 75vh, 780px);
}
.page-header--photo::before { display: none; }
.page-header--photo .ph-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.page-header--photo .ph-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
}
.page-header--photo .ph-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    110deg,
    rgba(11,22,35,0.82) 0%,
    rgba(11,22,35,0.65) 50%,
    rgba(11,22,35,0.25) 100%
  );
}
.page-header--photo .hero-badge { background: rgba(29,146,255,0.2); color: #7FC8FF; border-color: rgba(29,146,255,0.3); }
.page-header--photo .hero-title { color: #fff; }
.page-header--photo .hero-subtitle { color: rgba(255,255,255,0.78); }
.page-header--photo .breadcrumb a { color: rgba(255,255,255,0.55); }
.page-header--photo .breadcrumb span { color: rgba(255,255,255,0.35); }
.page-header--photo .breadcrumb > span:last-child { color: rgba(255,255,255,0.75); }
.page-header--photo .btn-secondary { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.3); color: #fff; }
.page-header--photo .btn-secondary:hover { background: rgba(255,255,255,0.18); }

/* ══════════════════════════════════════════════════════════════
   HERO EDITORIAL — globaler Stil (Homepage + alle Hauptseiten)
   Vollflächiges Foto, weißer Verlauf links, Text dunkel
   ══════════════════════════════════════════════════════════════ */
.hero-editorial {
  position: relative;
  overflow: hidden;
  min-height: clamp(540px, 88vh, 860px);
  display: flex;
  align-items: center;
}
.hero-editorial__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-editorial__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 25%;
  display: block;
}
.hero-editorial__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    rgba(255,255,255,0.76) 0%,
    rgba(255,255,255,0.50) 35%,
    rgba(255,255,255,0.10) 62%,
    rgba(255,255,255,0.00) 100%
  );
}
.hero-editorial__content {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin-left: max(
    clamp(var(--s-5), 5vw, var(--s-12)),
    calc((100vw - var(--w-max)) / 2 + clamp(var(--s-5), 5vw, var(--s-12)))
  );
  padding-top: clamp(120px, 11vw, 160px);
  padding-right: clamp(32px, 6vw, 88px);
  padding-bottom: clamp(80px, 7vw, 120px);
}
.hero-editorial__eyebrow {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #1D92FF;
  margin-bottom: 14px;
}
.hero-editorial__title {
  font-size: clamp(2.2rem, 3.8vw, 3.6rem);
  font-weight: 500;
  color: #0D1532;
  line-height: 1.1;
  font-optical-sizing: auto;
  font-variation-settings: "wght" 500;
  margin: 0 0 18px;
}
.hero-editorial__sub {
  font-size: clamp(0.9rem, 1.05vw, 1rem);
  color: #374151;
  line-height: 1.75;
  max-width: 480px;
  margin: 0 0 28px;
}
.hero-editorial__checks {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 28px;
  font-size: 0.8rem;
  font-weight: 600;
  color: #374151;
}
.hero-editorial__btns {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.hero-editorial__btn-ghost {
  background: rgba(255,255,255,0.65) !important;
  border: 1.5px solid rgba(13,21,50,0.2) !important;
  color: #0D1532 !important;
  backdrop-filter: blur(8px);
}
.hero-editorial__btn-ghost:hover {
  background: rgba(255,255,255,0.9) !important;
}
.hero-editorial__stats {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  padding-top: 24px;
  border-top: 1px solid rgba(13,21,50,0.12);
  margin-top: 32px;
}
.hero-editorial__stats > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hero-editorial__stat-num {
  font-size: 1.4rem;
  font-weight: 900;
  color: #1D92FF;
  letter-spacing: -0.03em;
  line-height: 1;
}
.hero-editorial__stat-lbl {
  font-size: 0.68rem;
  color: #6B7280;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}
/* Nav transparency handled by JS in components.js */
@media (max-width: 768px) {
  .hero-editorial { min-height: clamp(480px, 75vh, 640px); }
  .hero-editorial__content { padding: 90px 24px 56px; max-width: 100%; margin-left: 0; }
  .hero-editorial__title { font-size: clamp(1.75rem, 6vw, 2.4rem); }
  .hero-editorial__sub { font-size: 0.9rem; max-width: 100%; }
  .hero-editorial__bg::after {
    background: linear-gradient(
      160deg,
      rgba(255,255,255,0.88) 0%,
      rgba(255,255,255,0.72) 50%,
      rgba(255,255,255,0.30) 100%
    ) !important;
  }
}
@media (max-width: 480px) {
  .hero-editorial { min-height: clamp(420px, 70vh, 580px); overflow: hidden; }
  .hero-editorial__content { padding: 80px 20px 48px; margin-left: 0; }
  .hero-editorial__title { font-size: clamp(1.6rem, 7vw, 2rem); }
  .hero-editorial__btns { flex-direction: column; gap: 10px; }
  .hero-editorial__btns .btn { width: 100%; justify-content: center; text-align: center; }
  .hero-editorial__stats { gap: 16px; }
  .hero-editorial__stat-num { font-size: 1.1rem; }
  .hide-mobile-br { display: none; }
}

/* ══════════════════════════════════════════════════════════════
   FOOTER CLEAN — Taskopia-inspired
   ══════════════════════════════════════════════════════════════ */
.footer--clean {
  background: #0B1623;
  color: rgba(255,255,255,0.75);
  border-top: 1px solid rgba(255,255,255,0.06);
}
.footer-clean-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 56px 40px 48px;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 900px) {
  .footer-clean-inner { grid-template-columns: 1fr; gap: 32px; padding: 40px 24px; }
}
.footer-brand-col .footer-tagline {
  font-size: .825rem;
  line-height: 1.6;
  color: rgba(255,255,255,0.5);
  margin-top: 14px;
  max-width: 220px;
}
.footer-social { display: flex; gap: 10px; margin-top: 16px; }
.footer-social-link {
  width: 44px; height: 44px;
  min-width: 44px; min-height: 44px;
  border-radius: 8px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.6);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .18s, color .18s;
}
.footer-social-link:hover { background: #1D92FF; color: #fff; border-color: #1D92FF; }
.footer-nav-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
@media (max-width: 768px) { .footer-nav-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .footer-nav-grid { grid-template-columns: 1fr; } }
.footer-col-title {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.35);
  margin-bottom: 14px;
}
.footer-links {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.footer-links a {
  font-size: .85rem;
  color: rgba(255,255,255,0.6);
  text-decoration: none;
  transition: color .15s;
}
.footer-links a:hover { color: #fff; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 18px 40px;
}
.footer-bottom-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  font-size: .78rem;
  color: rgba(255,255,255,0.35);
}
.footer-bottom-links { display: flex; gap: 20px; align-items: center; }
.footer-bottom-links a { color: rgba(255,255,255,0.45); text-decoration: none; }
.footer-bottom-links a:hover { color: #fff; }
.footer-lang-toggle { color: rgba(255,255,255,0.35); }


/* Pipedrive Web Forms — ensure full height rendering */
.pipedriveWebForms { min-height: 800px; width: 100%; display: block; }
.pipedriveWebForms iframe { min-height: 800px !important; width: 100% !important; border: none !important; }

/* ─── TRANSPARENT NAV (hero pages) ────────────────────────── */
.nav--transparent {
  background: transparent !important;
  box-shadow: none !important;
  border-bottom: none !important;
}
.nav--transparent .nav-link,
.nav--transparent .nav-link-has-dropdown {
  color: rgba(255,255,255,0.92) !important;
}
.nav--transparent .nav-link:hover,
.nav--transparent .nav-link-has-dropdown:hover {
  color: #fff !important;
}
.nav--transparent .nav-chevron path {
  stroke: rgba(255,255,255,0.92) !important;
}
.nav--transparent .nav-logo-img {
  content: none; /* handled via JS swap */
}
.nav--transparent .btn-secondary {
  color: #fff !important;
  border-color: rgba(255,255,255,0.55) !important;
  background: transparent !important;
}
.nav--transparent .btn-secondary:hover {
  background: rgba(255,255,255,0.12) !important;
  border-color: rgba(255,255,255,0.8) !important;
}
/* Language toggle on transparent nav */
.nav--transparent .lang-toggle {
  color: #fff !important;
  border-color: rgba(255,255,255,0.45) !important;
}
.nav--transparent .lang-toggle:hover {
  background: rgba(255,255,255,0.12) !important;
}

/* Smooth transition */
.nav {
  transition: background 0.25s ease, box-shadow 0.25s ease;
}


/* ── PHASE CARDS ─────────────────────────────────────────────────────────── */
.phase-card { background:#fff; border-radius:16px; padding:28px 24px; border:1px solid rgba(25,43,69,0.10); box-shadow:0 2px 12px rgba(25,43,69,0.06); display:flex; flex-direction:column; gap:10px; }
.phase-card--acquire  { border-top:3px solid #192B45; }
.phase-card--activate { border-top:3px solid #24C774; }
.phase-card--grow     { border-top:3px solid #5717EA; }
.phase-card--retain   { border-top:3px solid #1D92FF; }
.phase-card--winback  { border-top:3px solid #FFD221; }
.phase-card-num { font-size:var(--text-xs); font-weight:700; letter-spacing:.06em; text-transform:uppercase; }
.phase-card-title { font-size:var(--text-base); font-weight:800; color:var(--midnight); line-height:1.3; }
.phase-card-body { font-size:var(--text-sm); color:rgba(25,43,69,0.68); line-height:1.65; }

/* ── PIPELINE ────────────────────────────────────────────────────────────── */
.pipeline { display:flex; align-items:center; gap:4px; }
.pipeline-step { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:10px; background:#fff; border:1px solid rgba(25,43,69,0.10); font-size:var(--text-sm); color:var(--midnight); flex:1; min-width:0; }
.pipeline-step-icon { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:#fff; }
.pipeline-step-label { font-size:var(--text-xs); line-height:1.4; color:var(--midnight); }
.pipeline-step-label strong { display:block; font-weight:700; }
.pipeline-arrow { font-size:16px; color:rgba(25,43,69,0.3); flex-shrink:0; padding:0 2px; }

/* ── WPP CHAPTERS ────────────────────────────────────────────────────────── */
.wpp-chapter { display:flex; align-items:flex-start; gap:16px; padding:14px 0; border-bottom:1px solid rgba(25,43,69,0.08); }
.wpp-chapter:last-child { border-bottom:none; }
.wpp-chapter-num { width:32px; height:32px; border-radius:50%; background:#1D92FF; color:#fff; font-size:14px; font-weight:800; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px; }
.wpp-chapter-title { font-size:var(--text-base); font-weight:700; color:var(--midnight); line-height:1.4; margin-bottom:3px; }
.wpp-chapter-sub { font-size:var(--text-sm); color:rgba(25,43,69,0.6); line-height:1.5; }

/* ── COMPARISON TABLE ────────────────────────────────────────────────────── */
.comparison-table { width:100%; border-collapse:collapse; background:#fff; font-size:var(--text-sm); }
.comparison-table thead tr { background:var(--midnight); }
.comparison-table thead th { padding:14px 20px; text-align:left; color:#fff; font-weight:700; }
.comparison-table thead th:last-child { background:#1D92FF; border-radius:0 12px 0 0; }
.comparison-table thead th:first-child { border-radius:12px 0 0 0; width:130px; }
.comparison-table tbody td { padding:13px 20px; border-bottom:1px solid rgba(25,43,69,0.07); vertical-align:top; line-height:1.55; }
.comparison-table tbody td:first-child { font-weight:700; font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:rgba(25,43,69,0.5); background:var(--fog); width:130px; }
.comparison-table tbody td:nth-child(2) { color:rgba(25,43,69,0.5); }
.comparison-table tbody td:nth-child(3) { color:var(--midnight); font-weight:500; }
.comparison-table tbody tr:last-child td { border-bottom:none; }

/* Generic responsive base for content tables (excludes .cmp-table which has its own .cmp-table-wrap) */
.legal-content table,
table.comparison-table {
  display: block;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ── TESTIMONIAL MARQUEE overflow ────────────────────────────────────────── */
.testimonial-marquee { overflow:hidden !important; width:100%; max-width:100vw; }
.testimonial-marquee .marquee-track { overflow:hidden !important; width:100%; }

/* ── NAV LINK COLORS ─────────────────────────────────────────────────────── */
.nav-link, .nav-link-has-dropdown { color:var(--midnight) !important; }

/* ── PLATFORM INDEX: hero image position ─────────────────────────────────── */
body:has(.page-platform-index) .hero-editorial__bg img { object-position:left 30%; }

/* ── FEATURE CARD ICON CI VARIANTS ──────────────────────────────────────── */
.feature-card-icon--sky        { background:rgba(29,146,255,0.10); color:#1D92FF; }
.feature-card-icon--midnight   { background:rgba(25,43,69,0.08);   color:#192B45; }
.feature-card-icon--tree       { background:rgba(36,199,116,0.10); color:#24C774; }
.feature-card-icon--raspberry  { background:rgba(29,146,255,0.10); color:#1D92FF; }
.feature-card-icon--tangerine  { background:rgba(36,199,116,0.10); color:#24C774; }
.feature-card-icon--ocean      { background:rgba(25,43,69,0.08);   color:#192B45; }

/* ── SAFARI / WEBKIT CROSS-BROWSER FIXES ─────────────────────────────────── */

/* Fix: Safari gap in grid/flex */
@supports (-webkit-touch-callout: none) {
  .grid-3, .grid-4, .bento-grid { gap: 24px; }
  .hero-editorial { min-height: 100svh; }
}

/* Fix: Safari doesn't support gap in older versions — use margin fallback */
.marquee-inner > * + * { margin-left: 0; }

/* Fix: Safari hero-editorial background cover */
.hero-editorial__bg img {
  -webkit-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0; left: 0;
}

/* Fix: Safari smooth scrolling */
html {
  -webkit-overflow-scrolling: touch;
}

/* Fix: Safari button rendering */
.btn, button {
  -webkit-appearance: none;
  cursor: pointer;
}

/* Fix: Safari backdrop-filter */
.nav.scrolled {
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
}

/* Fix: Safari flexbox gap fallback */
.nav-inner { gap: 24px; }
.footer-clean-inner { gap: 48px; }

/* Fix: Safari position sticky */
.nav {
  position: -webkit-sticky;
  position: sticky;
}

/* Fix: Testimonial marquee Safari. Previously referenced the non-existent
   `marquee-scroll` keyframe, which silently killed the animation. Use the
   real `marquee` keyframe defined above. */
.marquee-track {
  -webkit-animation: marquee 40s linear infinite;
  animation: marquee 40s linear infinite;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
}

/* ── Certification Badges Row ─────────────────────────────────────── */
.cert-badges-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px 20px;
  margin-top: var(--space-8);
  padding: 18px 24px;
  background: var(--color-fog);
  border-radius: var(--radius-xl);
  border: 1px solid rgba(29,146,255,0.12);
}
.cert-badge {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-midnight);
  white-space: nowrap;
}
.cert-badge svg { flex-shrink: 0; }
.cert-badge--link {
  color: var(--color-sky);
  text-decoration: none;
  transition: opacity .2s;
}
.cert-badge--link:hover { opacity: .75; }
@media (max-width: 640px) {
  .cert-badges-row { justify-content: flex-start; gap: 10px 16px; }
  .cert-badge { font-size: .75rem; }
}

/* ── Bento pill green variant ────────────────────────────────────── */
/* Used on .bento-card--blue / --dark / --purple backgrounds; needs high
   contrast — solid green with white text reads against the deep card bg. */
.bento-pill--green {
  background: #1a9e5c;
  border-color: #1a9e5c;
  color: #fff;
  font-weight: 600;
}
