:root {
  --bg: #0a1a3a;
  --panel: rgba(15, 37, 71, 0.7);
  --panel-soft: rgba(15, 37, 71, 0.5);
  --panel-light: rgba(30, 58, 138, 0.4);
  --muted: #b8d4ff;
  --text: #ffffff;
  --text-subtle: rgba(255, 255, 255, 0.7);
  --accent: #2563eb;
  --accent-strong: #3b82f6;
  --accent-light: #60a5fa;
  --blue-1: #1e40af;
  --blue-2: #2563eb;
  --blue-3: #3b82f6;
  --blue-4: #60a5fa;
  --blue-5: #93c5fd;
  --blue-6: #dbeafe;
  --border: rgba(59, 130, 246, 0.2);
  --border-light: rgba(59, 130, 246, 0.3);
  --shadow: 0 24px 60px rgba(0, 0, 0, 0.4);
  --shadow-card: 0 8px 24px rgba(0, 0, 0, 0.3);
  --radius-lg: 16px;
  --radius-md: 12px;
  --radius-sm: 8px;
  --max-width: 95%;
  --container-max: 1200px;
  --page-pad: 48px;
}

* {
  box-sizing: border-box;
}

/* Performance optimizations */
.card,
.btn,
.feature {
  contain: layout style paint;
}

.cards--news {
  contain: layout;
}

html {
  font-family: 'Urbanist', system-ui, -apple-system, sans-serif;
}

html {
  overflow-x: hidden;
  width: 100%;
  max-width: 100%;
  overflow-y: scroll;
}

/* Reusable container class */
.container {
  width: min(var(--container-max, 1200px), calc(100% - var(--page-pad, 48px) * 2));
  margin-inline: auto;
}

html,
body {
  margin: 0;
  font-family: 'Urbanist', system-ui, -apple-system, sans-serif;
}

body {
  background: #06133B;
  color: var(--text);
  line-height: 1.6;
  position: relative;
  --gradient-1-x: 20%;
  --gradient-1-y: 30%;
  --gradient-2-x: 80%;
  --gradient-2-y: 20%;
}

body.page--home,
body.page--bp,
body.page--brand-protection,
body.page--eu-compliance,
body.page--customer-engagement,
body.page--business-panel,
body.page--data-carriers,
body.page--what-is-dpp {
  background: #f5f6f8;
  color: #1F2937;
}

body.page--home::before,
body.page--bp::before,
body.page--brand-protection::before,
body.page--eu-compliance::before,
body.page--customer-engagement::before,
body.page--business-panel::before,
body.page--data-carriers::before,
body.page--what-is-dpp::before,
body.page--home::after,
body.page--bp::after,
body.page--brand-protection::after,
body.page--eu-compliance::after,
body.page--customer-engagement::after,
body.page--business-panel::after,
body.page--data-carriers::after,
body.page--what-is-dpp::after {
  display: none;
}

body.page--business-panel main,
body.page--data-carriers main,
body.page--what-is-dpp main {
  background: #f5f6f8;
}


body::before {
  display: none !important;
}

body::after {
  display: none !important;
}

/* Global gradient scrim overlay - sits above background, below content */
html::before {
  display: none !important;
  content: '';
  position: fixed;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.6) 0%,
    rgba(0, 0, 0, 0.5) 15%,
    rgba(0, 0, 0, 0.4) 25%,
    rgba(0, 0, 0, 0.35) 35%,
    rgba(0, 0, 0, 0.25) 45%,
    rgba(0, 0, 0, 0.15) 55%,
    rgba(0, 0, 0, 0.08) 65%,
    rgba(0, 0, 0, 0) 75%
  );
  pointer-events: none;
  z-index: 0;
  transform: translateZ(0);
  transition: opacity 0.3s ease-in-out;
  will-change: opacity;
}

body > * {
  position: relative;
  z-index: 1;
}

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

a:hover {
  opacity: 0.85;
}

img {
  max-width: 100%;
  display: block;
  border-radius: var(--radius-md);
}

main {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: #f5f6f8;
  /* Remove top gap so the hero sits flush under the sticky nav */
  padding: 0 0 140px;
  width: 100%;
}

main > * {
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  padding-left: 2.5%;
  padding-right: 2.5%;
  box-sizing: border-box;
}

/* Brand Protection page: sections should use full available screen width */
.page--bp main > * {
  max-width: 100vw;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 0;
  padding-right: 0;
}

/* Brand Protection page: avoid the empty dark band at the bottom of main */
.page--bp main {
  padding-bottom: 0;
}

main > #solutions-2 {
  padding: 0 0 125px;
  background: #f5f6f8 !important;
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: -60px;
  position: relative;
  z-index: 1;
  isolation: isolate;
}

/* Book Demo CTA: full-bleed section (but keep inner content centered) */
main > #bookdemo.cta {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#solutions-2::before {
  display: none;
}

main > .business-platform {
  max-width: none;
  padding-left: 0;
  padding-right: 0;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: -125px; /* Remove gap from previous section */
}

/* Add breathing room between How It Works cards and the next section title */
main > #platform.business-platform {
  margin-top: 0;
}

main > .secure-network-hero {
  position: relative;
  z-index: 1;
  margin-top: 15px;
  margin-bottom: 34px;
}

main > .secure-network-hero + .band--no-frame {
  margin-top: 0 !important;
}

.secure-network-hero__content {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

.announcement {
  display: none;
  background: var(--accent);
  color: var(--text);
  border-bottom: none;
  overflow: hidden;
  padding: 0;
  height: 31px;
  align-items: center;
}

.announcement__container {
  overflow: hidden;
  width: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.announcement__scroll {
  display: flex;
  width: fit-content;
  animation: scroll-announcement 25s linear infinite;
}

.announcement__text {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 40px;
  flex-shrink: 0;
  white-space: nowrap;
  font-size: 14.3px;
  font-weight: 500;
  height: 31px;
}

.announcement a {
  font-weight: 700;
  color: var(--text);
  text-decoration: underline;
}

@keyframes scroll-announcement {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-33.333%);
  }
}

.nav {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 126px;
  min-height: 126px;
  padding: 0;
  background: #f5f6f8; /* Match hero background color */
  border-bottom: none;
  box-shadow: none;
}

.nav__container {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding-left: 12%;
  padding-right: 14%;
}

.nav__logo {
  display: flex;
  align-items: center;
  white-space: nowrap;
  text-decoration: none;
  color: #111827; /* Primary headings and logo wordmark */
  cursor: pointer;
  font-family: 'Urbanist', sans-serif;
  font-weight: 700;
  font-size: 32px;
  letter-spacing: 0.05em;
  position: relative;
  justify-self: start;
  margin-left: -32px;
  line-height: 1;
  align-self: center;
  height: 100%;
}

.nav__logo img {
  display: block !important;
  height: 252px !important;
  width: auto !important;
  max-width: 1260px !important;
  max-height: 252px !important;
  object-fit: contain;
  vertical-align: middle;
  margin: 0;
}

/* Two logos: desktop vs mobile – show only one per breakpoint */
.nav__logo .logo-img--mobile {
  display: none !important;
}
.nav__logo .logo-img--desktop {
  display: block !important;
}

.nav__logo::after {
  display: none; /* Hide underline for image logo */
}

.footer .nav__logo::after {
  display: none !important;
}

.footer .nav__logo-img {
  display: none !important;
}

.footer .nav__logo {
  margin-left: 0;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #ffffff;
}

.nav__logo:hover {
  opacity: 0.8;
}

.nav__logo-img {
  display: none; /* Hide old logo image */
}

.nav__menu-pill {
  background: rgba(0, 0, 0, 0.06); /* Increased intensity from 0.03 */
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(0, 0, 0, 0.08); /* Slightly more visible border */
  border-radius: 100px;
  padding: 10px 24px;
  display: flex;
  align-items: center;
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.12); /* Stronger shadow for depth */
  justify-self: center;
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 32px;
  position: relative;
}

.nav__links a:not(.btn) {
  font-weight: 500;
  color: #111827; /* Primary headings and logo wordmark */
  padding: 10px 20px;
  font-size: clamp(17px, 2vw, 22px);
  text-decoration: none;
  transition: all 0.2s ease;
  border-radius: 100px;
}

.nav__links a:not(.btn):hover {
  background: rgba(0, 0, 0, 0.05);
  color: #111827;
}

/* Remove the old underline effect */
.nav__links a:not(.btn)::after {
  display: none;
}

.nav__item--has-sub > a::after {
  display: inline-block !important;
}

.btn--header {
  background: #669DF6;
  color: #ffffff;
  font-weight: 700;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 18px;
  transition: all 0.3s ease;
  border: none;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 14px 30px rgba(102, 157, 246, 0.3);
  min-width: 200px;
}

.btn--header:hover {
  background: #5595F5;
  transform: translateY(-2px);
  box-shadow: 0 18px 35px rgba(102, 157, 246, 0.4);
}

.btn--header:active {
  background: #458DF4;
}

.nav__item {
  position: relative;
  display: flex;
  align-items: center;
}

.nav__item--has-sub {
  padding-bottom: 0;
}

.nav__item--has-sub > a {
  padding-bottom: 4px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  position: relative;
}

.nav__item--has-sub > a::after {
  content: '';
  width: 8px;
  height: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s ease, opacity 0.2s ease;
  opacity: 0.6;
  margin-top: -2px;
  display: inline-block;
}

.nav__item--has-sub:hover > a::after {
  transform: rotate(225deg);
  opacity: 1;
  margin-top: 2px;
}

.nav__item--has-sub .nav__sub {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: fit-content;
  min-width: 280px;
  background: rgba(255, 255, 255, 0.98); /* Light background for submenus */
  backdrop-filter: blur(20px);
  border: 1px solid rgba(0, 0, 0, 0.05);
  border-radius: 16px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
  padding: 16px;
  z-index: 30;
  margin-top: 12px;
}

.nav__item--has-sub .nav__sub::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 0;
  right: 0;
  height: 12px;
  background: transparent;
}

.nav__item--has-sub:hover .nav__sub,
.nav__item--has-sub:focus-within .nav__sub,
.nav__item--has-sub .nav__sub:hover {
  display: flex;
  flex-direction: column;
  gap: 8px;
  animation: fadeInDown 0.2s ease-out;
}

.nav__sub a {
  padding: 12px 20px;
  border-radius: 8px;
  color: #111827; /* Dark text for submenus */
  font-size: 18px !important;
  font-weight: 600;
  transition: all 0.2s ease;
  display: block;
  text-align: left;
  white-space: nowrap;
}

.nav__sub a:hover {
  color: #111827;
  background: rgba(0, 0, 0, 0.05);
}

.nav__item--has-sub > a {
  position: relative;
}

.nav__item--has-sub:hover > a {
  color: #fff;
}

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

.nav__toggle {
  display: none;
  background: transparent;
  border: none;
  cursor: pointer;
  flex-direction: column;
  gap: 4px;
}

.nav__toggle span {
  width: 22px;
  height: 2px;
  background: #06133B; /* Dark color for mobile toggle */
  display: block;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  align-items: center;
  gap: 80px;
  margin-top: 0; /* remove bar/gap between nav and hero */
  margin-bottom: 0;
  padding: 40px 0 20px; /* reduced top padding from 80px to 40px */
  min-height: 84vh; /* match brand-protection hero height */
  position: relative;
}

.hero::before {
  content: "";
  position: absolute;
  top: -1px; /* avoid any 1px seam between nav and hero */
  bottom: -40px; /* Adjusted for reduced gap */
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  /* Hero background: ultra-subtle single glow */
  background: 
    radial-gradient(ellipse 1000px 500px at 50% 50%, rgba(62, 49, 168, 0.04) 0%, transparent 40%),
    #06133B;
  z-index: -1;
  pointer-events: none;
}

/* Brand Protection page: taller hero so we can add more copy (homepage unchanged) */
.hero.hero--bp {
  min-height: 84vh;
  /* Match homepage hero padding */
  padding: 40px 0 20px;
}

/* Solutions pages hero: match homepage "Why it Matters" background */
.page--brand-protection .hero::before,
.page--eu-compliance .hero::before,
.page--customer-engagement .hero::before {
  background: #f5f6f8;
}

.page--home .hero::before {
  background: 
    radial-gradient(ellipse 600px 500px at 25% 50%, 
      rgba(102, 157, 246, 0.12) 0%, 
      rgba(127, 217, 168, 0.08) 40%, 
      transparent 70%),
    #f5f6f8;
}

.page--legal .hero::before {
  background: #f5f6f8;
}

/* Legal pages: shorter hero to reduce vertical space */
.page--legal .hero.hero--bp {
  min-height: 28vh;
  padding: 16px 0 12px;
}

/* Ensure hero surface matches navbar color */
.page--legal .hero {
  background: #f5f6f8;
}

.page--legal .hero__brand {
  color: #1F2937;
  font-weight: 700;
  margin-bottom: 24px;
}

.page--legal .hero__lead {
  color: #4B5563;
  margin-bottom: 32px;
  max-width: 800px;
}

.page--legal .hero__content {
  padding-left: 14%;
  max-width: 860px;
}

.page--legal .band--no-frame .page-content {
  max-width: none !important;
  width: 100vw !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  text-align: left !important;
  padding-left: 14% !important;
  padding-right: 14% !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  box-sizing: border-box !important;
}

.page--legal .band--no-frame {
  padding: 28px 0 70px !important; /* match homepage Foundation section */
  min-height: 0 !important;
}

.page--legal .band--no-frame__subtitle {
  margin: 0 0 18px !important;
  text-align: left !important;
  white-space: normal !important;
}

.page--legal .band--no-frame h2,
.page--legal .band--no-frame .page-content h2 {
  font-size: clamp(24px, 2.4vw, 34px) !important;
  line-height: 1.25 !important;
  letter-spacing: -0.01em !important;
  margin: 28px 0 12px !important;
  text-align: left !important;
  white-space: normal !important;
  width: 100% !important;
  align-self: flex-start !important;
}

.page--legal .band--no-frame p,
.page--legal .band--no-frame li {
  font-size: 16px !important;
  line-height: 1.75 !important;
}

.page--legal .band--no-frame ul {
  margin: 10px 0 18px !important;
  padding-left: 20px !important;
}

.page--brand-protection .hero__brand,
.page--eu-compliance .hero__brand,
.page--customer-engagement .hero__brand {
  color: #1F2937;
  font-weight: 700;
  margin-bottom: 24px;
}

.page--home .hero__brand {
  color: #1F2937;
  font-weight: 700;
  margin-bottom: 24px;
  line-height: 1.15;
  position: relative;
  z-index: 1;
}

.page--brand-protection .hero__lead,
.page--eu-compliance .hero__lead,
.page--customer-engagement .hero__lead {
  font-size: clamp(17px, 2vw, 22px);
  color: #4B5563;
  margin-bottom: 32px;
  max-width: 800px;
  line-height: 1.6;
}

.page--home .hero__lead {
  font-size: clamp(19px, 2.3vw, 26px);
  color: #4B5563;
  margin-bottom: 32px;
  max-width: 800px;
  line-height: 1.6;
}

/* Solutions hero layout (single column + bullet list) */
.page--brand-protection .hero,
.page--eu-compliance .hero,
.page--customer-engagement .hero,
.page--home .hero.hero--bp {
  grid-template-columns: 1fr 0.9fr;
  align-items: center;
  gap: 80px;
}

.page--brand-protection .hero__content,
.page--eu-compliance .hero__content,
.page--customer-engagement .hero__content,
.page--home .hero.hero--bp .hero__content {
  max-width: 860px;
}

.page--eu-compliance .hero__content {
  padding-left: 14%;
}

.page--home .hero.hero--bp .hero__content {
  padding-left: 14%;
}

.page--brand-protection .hero__content {
  padding-left: 14%;
}

.page--customer-engagement .hero__content {
  padding-left: 14%;
}

main > .hero {
  max-width: 100vw;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 0;
  padding-right: 0;
}

.page--brand-protection .hero__actions,
.page--eu-compliance .hero__actions,
.page--customer-engagement .hero__actions,
.page--home .hero.hero--bp .hero__actions {
  margin-top: 48px;
}

.page--eu-compliance .hero__image,
.page--home .hero.hero--bp .hero__image {
  width: 125%;
  max-width: none;
  transform: translateX(-10%);
}

.page--brand-protection .hero__image,
.page--customer-engagement .hero__image {
  width: 125%;
  max-width: none;
  transform: translateX(5%);
}

.bp-hero__bullets {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.bp-hero__bullet {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.bp-hero__icon {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}

.bp-hero__icon svg {
  width: 18px;
  height: 18px;
}

.bp-hero__icon--cyan {
  background: rgba(102, 157, 246, 0.16);
  color: #669DF6;
}

.bp-hero__icon--indigo {
  background: rgba(116, 207, 226, 0.16);
  color: #74CFE2;
}

.bp-hero__icon--slate {
  background: rgba(127, 217, 168, 0.16);
  color: #7FD9A8;
}

.bp-hero__bullet-title {
  font-weight: 700;
  color: #1F2937;
  font-size: clamp(17px, 2vw, 22px);
  line-height: 1.25;
  margin-bottom: 4px;
}

.bp-hero__bullet-desc {
  color: #4B5563;
  font-size: clamp(17px, 2vw, 22px);
  line-height: 1.55;
}

.homepage-bullet {
  display: flex;
  gap: 16px;
  align-items: center;
  margin-bottom: 20px;
}

.homepage-bullet__icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: rgba(102, 157, 246, 0.1);
  border: 1px solid rgba(102, 157, 246, 0.4);
  color: #669DF6;
}

.homepage-bullet__icon svg {
  width: 16px;
  height: 16px;
  stroke-width: 3;
}

.homepage-bullet__text {
  font-size: clamp(17px, 2vw, 22px);
  color: #4B5563;
  line-height: 1.6;
}

.hero__content,
.hero__visual {
  position: relative;
  z-index: 1;
}

.hero__content {
  max-width: 600px;
  padding-left: 6%;
}

.hero__brand {
  overflow-wrap: normal;
  word-wrap: normal;
}

.hero__brand {
  font-size: clamp(38px, 4.7vw, 56px);
  font-weight: 600;
  color: #ffffff;
  margin: 0 0 24px;
  line-height: 1.15;
  letter-spacing: -0.3px;
  word-break: keep-all;
}

.hero__brand-no-break {
  white-space: nowrap !important;
  display: inline;
}

.hero__tagline {
  font-size: 26px;
  color: #3E31A8;
  margin: 0 0 32px;
  font-weight: 400;
  letter-spacing: 0.2px;
  line-height: 1.4;
}

.hero__title {
  font-size: clamp(43px, 5.4vw, 65px);
  line-height: 1.1;
  margin: 0 0 30px;
  font-weight: 700;
  color: #ffffff;
}

.hero__lead {
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 21px);
  max-width: 700px;
  line-height: 1.6;
  margin-bottom: 56px;
}

.hero__actions {
  display: flex;
  gap: 12px;
  margin: 0 0 20px;
}

.hero__actions .btn:not(.btn--secondary) {
  padding: 14px 28px;
  font-size: 18px;
  border-radius: 10px;
  min-width: 200px;
  background: #669DF6;
  color: #ffffff;
  box-shadow: 0 14px 30px rgba(102, 157, 246, 0.3);
}

.hero__actions .btn:not(.btn--secondary):hover {
  background: #5595F5;
  transform: translateY(-2px);
  box-shadow: 0 18px 35px rgba(102, 157, 246, 0.4);
}

.hero__actions .btn:not(.btn--secondary):active {
  background: #458DF4;
}

.hero__metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
  margin-top: 12px;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
}

.hero__metrics strong {
  display: block;
  color: var(--text);
  font-size: 19px;
}

.hero__visual {
  width: 100%;
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.hero__image {
  width: 140%;
  height: auto;
  display: block;
  transform: translateX(0);
}

.page--home .hero__image--main {
  width: 88%;
  max-width: 88%;
  max-height: 61.6vh;
  height: auto;
  object-fit: contain;
  /* Subtle edge fade to blend into page background */
  -webkit-mask-image:
    linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%),
    linear-gradient(to bottom, transparent 0%, #000 6%, #000 88%, transparent 100%);
  mask-image:
    linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%),
    linear-gradient(to bottom, transparent 0%, #000 6%, #000 88%, transparent 100%);
  -webkit-mask-composite: source-in;
  mask-composite: intersect;
}

.page--home .hero__visual {
  justify-content: flex-start;
  position: relative;
  background: #F5F6F8;
  padding-left: 20px;
}

.hero__visual img {
  border: none;
  box-shadow: none;
}

.band {
  background: rgba(59, 130, 246, 0.35);
  border: 1px solid rgba(96, 165, 250, 0.5);
  border-radius: var(--radius-lg);
  padding: 80px 3%;
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.3),
    0 0 0 1px rgba(59, 130, 246, 0.3),
    0 0 40px rgba(59, 130, 246, 0.15),
    0 0 80px rgba(37, 99, 235, 0.1);
  position: relative;
}

.divider-band {
  margin: 48px 0 48px;
  padding: 80px 0;
  background: #F4F5F7;
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  border: none;
  box-shadow: none;
  overflow: hidden;
}

.divider-band::before {
  content: none;
}

.divider-band__glow-bar {
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background: rgba(96, 165, 250, 0.5);
  z-index: 2;
}

.divider-band__glow-bar--top {
  top: 0;
}

.divider-band__glow-bar--bottom {
  bottom: 0;
}

@keyframes glow-pulse {
  0%, 100% {
    opacity: 1;
    box-shadow: 
      0 0 20px rgba(59, 130, 246, 0.8),
      0 0 40px rgba(96, 165, 250, 0.6),
      0 0 60px rgba(147, 197, 253, 0.4);
  }
  50% {
    opacity: 0.9;
    box-shadow: 
      0 0 30px rgba(59, 130, 246, 1),
      0 0 60px rgba(96, 165, 250, 0.8),
      0 0 90px rgba(147, 197, 253, 0.6);
  }
}

.divider-band__inner {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
  text-align: center;
  z-index: 1;
}

.divider-band__title {
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: normal;
  text-transform: none;
  color: #1F2937;
  margin: 0 0 40px;
}

.divider-band__subtitle {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: normal;
  text-transform: none;
  color: #1F2937;
  margin: 0 0 40px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.divider-band__actions {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 40px;
}

.divider-band__items {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 64px;
  flex-wrap: nowrap;
}

.divider-band__item {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
  flex: 0 0 auto;
  margin: 0;
  padding: 0;
}

.divider-band__number {
  position: relative;
  width: auto;
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  margin-right: -35px;
}

.divider-band__number-img {
  width: auto;
  height: 105px;
  object-fit: contain;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  margin: 0;
  padding: 0;
  display: block;
}

.divider-band__label {
  font-size: 50px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #1F2937;
  white-space: nowrap;
  margin: 0;
  padding: 0;
  margin-left: -35px;
}

@media (max-width: 768px) {
  .divider-band {
    padding: 28px 20px;
    margin: 32px 0;
  }
  .divider-band__title {
    font-size: clamp(16px, 1.8vw, 22px);
    letter-spacing: 0.16em;
  }
  .divider-band__subtitle {
    font-size: clamp(16px, 1.8vw, 22px);
    margin-bottom: 30px;
  }
  .divider-band__items {
    gap: 12px;
    flex-wrap: nowrap;
  }
  .divider-band__item {
    gap: 0;
  }
  
  .divider-band__number {
    margin-right: -12px;
  }
  
  .divider-band__label {
    margin-left: -12px;
  }
  .divider-band__number-img {
    height: 51px;
  }
  .divider-band__label {
    font-size: 12px;
  }
}

@media (max-width: 520px) {
  .footer__grid {
    grid-template-columns: 1fr;
  }

  .footer__card--cta {
    align-items: flex-start;
  }
}

#resources.band {
  background: #f5f6f8 !important;
  z-index: 1;
  isolation: isolate;
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  border: none !important;
  box-shadow: none !important;
  padding: 60px 2.5% !important;
  margin: 0 !important;
  overflow: visible;
  position: relative;
  z-index: 1;
}

#resources .band__header h2 {
  text-align: center;
  color: #1F2937 !important;
  font-size: clamp(30px, 3.7vw, 46px) !important;
  font-weight: 500 !important;
  margin: 8px auto 24px !important;
  max-width: 1600px;
  padding: 0 40px;
  line-height: 1.3 !important;
}

#resources .cards--news {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#resources .cards--news::before {
  content: '';
  flex-shrink: 0;
  width: 2.5vw;
  min-width: 2.5vw;
}

#resources .band__header {
  margin-left: 0 !important;
  margin-right: 0 !important;
  text-align: center;
}

#resources.band::before {
  display: none !important;
}

#resources.band::after {
  display: none !important;
}

.band::before {
  display: none;
}

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

.band--muted {
  background: rgba(37, 99, 235, 0.3);
}

.band--muted.cta,
.band.cta,
.cta.band {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  outline: none !important;
}

/* Unified DPP & Whitepaper Section */
/* DPP Section - New Design */
.dpp-section,
.band.dpp-section,
.band--muted.dpp-section {
  padding: 100px 2.5%;
  background: 
    radial-gradient(circle at 20% 30%, rgba(59, 130, 246, 0.03) 0%, transparent 70%),
    radial-gradient(circle at 80% 70%, rgba(37, 99, 235, 0.03) 0%, transparent 70%),
    #020819;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  position: relative;
  box-sizing: border-box;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.dpp-container {
  max-width: 1400px;
  margin: 0 auto;
}

.dpp-header {
  text-align: center;
  max-width: 900px;
  margin: 0 auto 80px;
}

.dpp-headline {
  font-size: clamp(40px, 5.5vw, 62px);
  font-weight: 700;
  line-height: 1.1;
  color: #ffffff;
  margin-bottom: 24px;
}

.dpp-description {
  font-size: 18px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.7);
  margin: 0 auto;
  max-width: 750px;
}

.dpp-icon-modules {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1300px;
  margin: 0 auto;
}

.dpp-icon-module {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01));
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  border: 1px solid rgba(62, 49, 168, 0.2);
  border-radius: 20px;
  padding: 60px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3);
}

.dpp-icon-module::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 50%;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.05), transparent);
  pointer-events: none;
}

.dpp-icon-module:hover {
  transform: translateY(-10px) scale(1.02);
  border-color: rgba(62, 49, 168, 0.6);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5), 0 0 30px rgba(62, 49, 168, 0.2);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
}

.dpp-icon-module__icon {
  width: 90px;
  height: 90px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
  border: 1px solid rgba(62, 49, 168, 0.4);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 35px;
  box-shadow: 0 0 25px rgba(62, 49, 168, 0.2);
  position: relative;
}

.dpp-icon-module__icon::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 18px;
  background: radial-gradient(circle at center, rgba(62, 49, 168, 0.2), transparent 70%);
  z-index: -1;
}

.dpp-icon-module__icon img {
  width: 55%;
  height: 55%;
  object-fit: contain;
  filter: drop-shadow(0 0 8px rgba(62, 49, 168, 0.6));
}

.dpp-icon-module__title {
  font-size: 20px;
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 12px;
  font-size: clamp(16px, 1.8vw, 22px);
}

.dpp-icon-module__text {
  font-size: clamp(16px, 1.8vw, 22px);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.6);
}

.dpp-footer {
  text-align: center;
  margin-top: 60px;
}

.btn--dpp {
  background: rgba(102, 157, 246, 0.1);
  color: #669DF6;
  padding: 14px 32px;
  font-size: 16px;
  font-weight: 700;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-decoration: none;
  transition: all 0.3s ease;
  border: 1px solid rgba(62, 49, 168, 0.4);
  cursor: pointer;
  box-shadow: 0 0 20px rgba(62, 49, 168, 0.1);
}

.btn--dpp:hover {
  background: #669DF6;
  color: #ffffff;
  box-shadow: 0 0 30px rgba(102, 157, 246, 0.3);
  transform: translateY(-2px);
}

/* Responsive styles for DPP section */
@media (max-width: 1024px) {
  .dpp-icon-modules {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}

@media (max-width: 768px) {
  .dpp-section {
    padding: 80px 5%;
  }
  
  .dpp-header {
    margin-bottom: 50px;
  }
  
  .dpp-headline {
    font-size: 36px;
  }
  
  .dpp-icon-modules {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .dpp-icon-module {
    padding: 40px 20px;
  }
}

/* Legacy unified-section styles (keeping for compatibility) */
.unified-section {
  padding: 80px 2.5%;
}

.unified-container {
  max-width: 1400px;
  margin: 0 auto;
}

.unified-content {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  align-items: start;
}

.unified-main {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.unified-header h2 {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  line-height: 1.1;
  margin: 0 0 20px;
  color: var(--text);
  letter-spacing: -0.02em;
}

.unified-lede {
  font-size: 18px;
  line-height: 1.7;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  margin: 0;
  max-width: 600px;
}

.unified-features {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.unified-feature {
  display: flex;
  gap: 20px;
  padding: 24px;
  background: rgba(59, 130, 246, 0.2);
  border: 1px solid rgba(96, 165, 250, 0.5);
  border-radius: var(--radius-md);
  transition: all 0.3s ease, transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 
    0 4px 12px rgba(0, 0, 0, 0.2),
    0 0 0 1px rgba(59, 130, 246, 0.2),
    0 0 20px rgba(59, 130, 246, 0.1);
}

.unified-feature:hover {
  background: rgba(96, 165, 250, 0.3);
  border-color: rgba(147, 197, 253, 0.7);
  transform: translateY(-4px);
  box-shadow: 
    0 16px 50px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(96, 165, 250, 0.5),
    0 0 40px rgba(96, 165, 250, 0.4);
}

.unified-feature__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(59, 130, 246, 0.1));
  border-radius: 12px;
  color: var(--accent-strong);
}

.unified-feature__content h3 {
  font-size: 20px;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--text);
}

.unified-feature__content p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  margin: 0;
}

/* Unified Whitepaper Card */
.unified-whitepaper {
  position: relative;
}

.unified-whitepaper__card {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.99));
  border-radius: var(--radius-lg);
  padding: 40px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  position: relative;
  z-index: 2;
}

.unified-whitepaper__badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(59, 130, 246, 0.1);
  padding: 6px 12px;
  border-radius: 6px;
  margin-bottom: 16px;
}

.unified-whitepaper__header h3 {
  font-size: 24px;
  font-weight: 700;
  color: #111827;
  margin: 0 0 16px;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.unified-whitepaper__description {
  font-size: 15px;
  line-height: 1.6;
  color: #4B5563;
  margin: 0 0 28px;
}

.unified-whitepaper__keypoints {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 32px;
  padding-bottom: 28px;
  border-bottom: 1px solid #e5e7eb;
}

.unified-keypoint {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 0;
}

.unified-keypoint__number {
  font-size: 20px;
  font-weight: 700;
  color: var(--accent);
  opacity: 0.4;
  min-width: 36px;
  font-variant-numeric: tabular-nums;
}

.unified-keypoint__text {
  font-size: 15px;
  font-weight: 600;
  color: #111827;
}

.btn--unified {
  width: 100%;
  background: var(--accent);
  color: #ffffff;
  padding: 16px 24px;
  font-size: 15px;
  font-weight: 600;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-decoration: none;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

.btn--unified:hover {
  background: var(--accent-strong);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(59, 130, 246, 0.4);
}

.btn--unified svg {
  width: 16px;
  height: 16px;
}

/* Unified Document Stack Visual */
.unified-whitepaper__visual {
  position: absolute;
  top: 0;
  right: -40px;
  width: 280px;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 1000px;
}

.unified-document-stack {
  position: relative;
  width: 100%;
  height: 400px;
  transform-style: preserve-3d;
}

.unified-document {
  position: absolute;
  width: 220px;
  height: 300px;
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(59, 130, 246, 0.25);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.unified-document--1 {
  z-index: 3;
  transform: rotateY(-10deg) rotateX(3deg) translateZ(0);
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

.unified-document--2 {
  z-index: 2;
  transform: rotateY(-14deg) rotateX(5deg) translateX(-25px) translateY(20px) translateZ(-40px);
  background: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);
  opacity: 0.85;
}

.unified-document--3 {
  z-index: 1;
  transform: rotateY(-18deg) rotateX(7deg) translateX(-50px) translateY(40px) translateZ(-80px);
  background: linear-gradient(135deg, #93c5fd 0%, #60a5fa 100%);
  opacity: 0.7;
}

.unified-whitepaper:hover .unified-document--1 {
  transform: rotateY(-8deg) rotateX(2deg) translateZ(20px);
}

.band__header {
  margin-bottom: 48px;
}

.band__header h2 {
  margin: 0 0 24px;
  font-size: clamp(32px, 3.5vw, 42px);
  line-height: 1.2;
  font-weight: 700;
  color: #ffffff;
}

#solutions-2 .band__header h2 {
  text-align: center;
}

.band__header .lede {
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  max-width: 1000px;
  font-size: 18px;
  line-height: 1.7;
  margin: 0 0 24px;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 12px;
  color: var(--accent-light);
  margin: 0;
  font-weight: 600;
}

.grid {
  display: grid;
  gap: 32px;
}

.features {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.cards {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.cards--news {
  display: flex !important;
  flex-direction: row !important;
  overflow-x: auto;
  overflow-y: visible;
  scroll-behavior: auto;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x;
  padding: 10px 0 20px 0 !important;
  margin: 0 !important;
  gap: 21px;
  width: 100%;
  max-width: 100%;
  grid-template-columns: none !important;
  scrollbar-width: none;
  -ms-overflow-style: none;
  cursor: grab;
  user-select: none;
  scroll-padding-left: 0;
}

.cards--news .card:first-child {
  margin-left: 0;
}

.cards--news .card:last-child {
  margin-right: 0;
}

.cards--news:active {
  cursor: grabbing;
}

.cards--news a,
.cards--news img {
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  draggable: false;
}

.cards--news::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
  background: transparent;
}

.card,
.feature,
.stat {
  background: rgba(59, 130, 246, 0.3);
  border: 1px solid rgba(96, 165, 250, 0.6);
  border-radius: var(--radius-md);
  padding: 28px;
  box-shadow: 
    0 8px 24px rgba(0, 0, 0, 0.3),
    0 0 0 1px rgba(59, 130, 246, 0.3);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
  position: relative;
  overflow: hidden;
}


.card:hover,
.feature:hover {
  background: rgba(96, 165, 250, 0.3);
  border-color: rgba(147, 197, 253, 0.8);
  transform: translateY(-4px) translateZ(0);
  box-shadow: 
    0 12px 40px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(147, 197, 253, 0.6),
}


.feature__tag {
  color: var(--accent-light);
  font-weight: 600;
  margin: 0 0 6px;
}

.card__label {
  color: var(--accent-light);
  font-weight: 600;
  letter-spacing: 0.3px;
  margin: 0 0 8px;
}

.card h3,
.feature h3,
.stat strong {
  margin: 0 0 12px;
  font-size: 20px;
  font-weight: 600;
  color: #ffffff;
}

.feature p {
  margin: 0;
  line-height: 1.7;
}

.card p,
.feature p,
.stat p,
.lede,
.band__header p {
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
}

.card ul {
  padding-left: 16px;
  margin: 12px 0 0;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  display: grid;
  gap: 6px;
}

.image-placeholder {
  width: 100%;
  height: 200px;
  background: rgba(59, 130, 246, 0.15);
  border: 1px dashed rgba(96, 165, 250, 0.5);
  border-radius: var(--radius-md);
  margin-top: 16px;
  box-shadow: 
    0 0 0 1px rgba(59, 130, 246, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  font-size: clamp(16px, 1.8vw, 22px);
}

.image-placeholder::before {
  content: "Image placeholder";
}

.card--inline {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  align-items: center;
  gap: 16px;
}

.integration-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 40px;
  align-items: center;
}

.integration-layout__copy {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.band__cta--left {
  margin-top: 8px;
  text-align: left;
}

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

.integration__item {
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  padding: 0;
  box-shadow: none;
  overflow: hidden;
}

.integration__item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-md);
}

@media (max-width: 900px) {
  .integration-layout {
    grid-template-columns: 1fr;
  }
}

.integration {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  align-items: start;
}

.integration__item {
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(96, 165, 250, 0.4);
  border-radius: var(--radius-md);
  padding: 18px;
  box-shadow: 
    0 2px 8px rgba(0, 0, 0, 0.2),
    0 0 0 1px rgba(59, 130, 246, 0.2);
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.15);
  color: var(--text);
  border: 1px solid rgba(59, 130, 246, 0.4);
  font-weight: 600;
  font-size: clamp(16px, 1.8vw, 22px);
  transition: background 0.2s ease, border-color 0.2s ease;
}

.chip:hover {
  background: rgba(59, 130, 246, 0.25);
  border-color: rgba(59, 130, 246, 0.6);
}

.cards--news .card,
.cards--news .card:hover,
.cards--news .card:active,
.cards--news .card:focus {
  display: flex;
  flex-direction: column;
  background: #ffffff !important;
  border: 1px solid #e6edf5;
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  padding: 0;
  flex: 0 0 380px;
  width: 380px;
  min-width: 380px;
  max-width: 380px;
  flex-shrink: 0;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
  transform: none !important;
}


.cards--news .card:hover,
.cards--news .card:focus,
.cards--news .card:active {
  transform: translateY(-6px) !important;
  background: #ffffff !important;
  border: 1px solid #e6edf5 !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08) !important;
  outline: none !important;
  opacity: 1 !important;
}

.cards--news .card::before {
  display: none !important;
}

.cards--news .card::after {
  display: none !important;
}

.cards--news .card:active::after,
.cards--news .card:hover::after,
.cards--news .card:focus::after {
  display: none !important;
}


.news-thumbnail {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
  background: #f5f6f8;
  border-radius: 0;
  margin: 0;
  border: none;
  outline: none;
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  draggable: false;
}

.news-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  background: transparent;
  color: #3E31A8;
  border: 1px solid rgba(62, 49, 168, 0.3);
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  width: fit-content;
  margin-bottom: 12px;
}

.cards--news .card > *:not(:first-child) {
  padding-left: 24px;
  padding-right: 24px;
}

.cards--news .card > div:nth-child(2) {
  padding-top: 20px;
  padding-bottom: 0;
  margin-bottom: 0;
  min-height: auto;
}

.cards--news .card > div:not(:first-child):not(:nth-child(2)) {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding-bottom: 24px;
}

.cards--news .card h3 {
  margin: 8px 0 12px;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.3;
  color: #1F2937;
}

.cards--news .card p {
  margin: 0 0 16px;
  color: #4B5563;
  font-size: 16px;
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-card__date {
  font-size: 14px;
  color: #3E31A8;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 1;
  margin: 0;
  padding: 0;
  text-align: left;
}

.cards--news .card .chip {
  display: none;
}

.loading {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  padding: 40px;
}

.trusted {
  text-align: center;
  padding: 50px 0 !important;
  max-width: 100vw !important;
  width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  background: #f5f6f8 !important;
  border: none !important;
  box-shadow: none !important;
  z-index: 1;
}

.trusted .band__header h2 {
  text-align: center !important;
  color: #1F2937 !important;
  font-size: clamp(30px, 3.7vw, 46px) !important;
  font-weight: 500 !important;
  margin: 8px auto 24px !important;
  max-width: 1600px;
  padding: 0 40px;
  line-height: 1.3 !important;
}

.trusted .band__header {
  position: relative;
  padding-bottom: 30px;
  margin-bottom: 0;
}

.trusted .band__header::after {
  display: none !important;
}

.trusted__container::after {
  display: none !important;
}

.trusted__scroll {
  display: flex;
  width: fit-content;
  animation: scroll-left 30s linear infinite;
}

.trusted__logos {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 60px;
  padding: 0 40px;
  flex-shrink: 0;
  min-width: max-content;
}

.trusted__logos img {
  height: 72px;
  max-width: 202px;
  width: auto;
  object-fit: contain;
  filter: none;
  opacity: 0.9;
  transition: all 0.3s ease;
  display: block !important;
  flex-shrink: 0;
  background: transparent;
  padding: 8px;
  visibility: visible !important;
}

.trusted__logos img:hover {
  filter: brightness(0) opacity(1);
  opacity: 1;
}

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

.platform-section {
  width: 100%;
  max-width: 100%;
  padding: 30px 3% 40px;
  margin: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

/* Fix: ensure the “HOW IT WORKS” accent above “Your Path to a Connected Product”
   isn’t hidden by the section overlap on desktop. */
@media (min-width: 769px) {
  #digital-twin.platform-section {
    margin-top: 0 !important;
    padding-top: 110px !important;
    position: relative;
    isolation: isolate;
    z-index: 5; /* keep How It Works cards above the next overlapped section */
  }

  /* Move the white→blue split UP so it sits behind the How It Works cards
     around the 3rd line of copy (desktop). */
  #digital-twin.platform-section::after {
    display: none !important;
  }

  #digital-twin.platform-section > * {
    position: relative;
    z-index: 1;
  }
}

.platform {
  display: grid;
  grid-template-columns: minmax(0, 0.5fr) minmax(0, 1.5fr);
  gap: 60px;
  align-items: center;
  max-width: var(--max-width);
  margin: 0 auto;
  position: relative;
}

.platform__copy {
  z-index: 2;
}

.platform__copy h2 {
  font-size: clamp(44px, 5.5vw, 62px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
  font-weight: 700;
  white-space: nowrap;
  margin-left: -2px;
}

.platform__subtitle {
  font-size: 20px;
  line-height: 1.7;
  margin: 0 0 20px;
  font-weight: 400;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  white-space: nowrap;
}

.platform2__subtitle {
  font-size: 24px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--accent-light);
  white-space: nowrap;
  margin-bottom: 42px !important;
}

#platform2 .platform__copy .list li {
  white-space: nowrap;
}

.platform2__closing {
  white-space: nowrap;
  line-height: 1.5;
}

/* Breakout for full-width Product Identity section */
#platform2.platform-section {
  background: #ffffff;
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: -125px;
  padding: 28px 0 70px; /* reduce empty space above FOUNDATION label */
  box-sizing: border-box;
  border: none;
  box-shadow: none;
  position: relative;
  z-index: 2;
}

.page--home #platform2 .dpp-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 0;
  gap: 0;
}

/* Legal pages: make the Foundation section match the hero grid for perfect alignment */
.page--legal #platform2 .dpp-content {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.page--legal #platform2 .dpp-content-left {
  padding-left: 14% !important;
  padding-right: 14% !important;
  width: 100% !important;
  max-width: none !important;
  text-align: left !important;
}

.page--home #platform2 .dpp-content-left {
  padding-left: 14%;
  box-sizing: border-box;
}

.page--home #platform2 .dpp-content-right {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}

.page--home #platform2 .dpp-content-right img {
  width: 90% !important;
  max-width: 90% !important;
  height: auto;
  display: block;
}

#foundation.platform-section {
  background: #ffffff !important;
  width: 100vw !important;
  max-width: none !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding: 100px 0 !important;
  box-sizing: border-box !important;
  border: none !important;
  box-shadow: none !important;
  position: relative !important;
  z-index: 2 !important;
}

#compliance.platform-section {
  background: #f5f6f8;
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: -125px;
  padding: 28px 0 100px !important;
  box-sizing: border-box;
  border: none;
  box-shadow: none;
  position: relative;
  z-index: 2;
}

#compliance .dpp-content {
  align-items: center !important;
}

#compliance .dpp-content-left {
  margin-top: 0 !important;
}

#compliance .dpp-content-right {
  align-self: center !important;
}

/* DPP Content Layout */
.dpp-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 2.5%;
  align-items: center;
  box-sizing: border-box;
}

.dpp-content-left {
  display: flex;
  flex-direction: column;
}

.dpp-content-title {
  font-size: clamp(32px, 4vw, 49px);
  font-weight: 700;
  color: #1F2937;
  margin: 0 0 24px;
  line-height: 1.2;
}

.dpp-content-subtitle {
  font-size: clamp(17px, 2vw, 22px) !important;
  color: #1F2937;
  line-height: 1.6;
  margin: 0 0 32px;
}

.dpp-content-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.dpp-content-list li {
  color: #1F2937;
  font-size: clamp(16px, 1.8vw, 20px);
  line-height: 1.6;
  padding-left: 28px;
  margin-bottom: 16px;
  position: relative;
}

.dpp-content-list li::before {
  content: '';
  width: 20px;
  height: 20px;
  position: absolute;
  left: 0;
  top: 2px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M20 6L9 17l-5-5' stroke='%2300E5FF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.dpp-content-right {
  position: relative;
  height: 500px;
  width: 100%;
}

.dpp-content-right .dpp-placeholder-image {
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

@media (max-width: 1024px) {
  .dpp-content {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  
  .dpp-content-right {
    height: 400px;
    order: -1;
  }
}

/* DPP Scroll Animation Container */
.dpp-scroll-container {
  position: relative;
  width: 100%;
  min-height: 300vh;
}

.dpp-scroll-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 100px 4.5%;
  position: sticky;
  top: 0;
  align-items: center;
}

.dpp-scroll-left {
  position: relative;
  min-height: 400px;
}

.dpp-scroll-step {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.6s ease, visibility 0.6s ease;
  transform: translateY(20px);
}

.dpp-scroll-step.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dpp-scroll-step.next {
  opacity: 0.3;
  visibility: visible;
  transform: translateY(10px);
}

.dpp-scroll-title {
  font-size: clamp(36px, 4.5vw, 56px);
  font-weight: 700;
  color: #1F2937;
  margin: 0 0 24px;
  line-height: 1.2;
}

.dpp-scroll-subtitle {
  font-size: clamp(18px, 2vw, 24px);
  color: #1F2937;
  line-height: 1.6;
  margin: 0 0 32px;
}

.dpp-scroll-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.dpp-scroll-list li {
  color: #1F2937;
  font-size: clamp(16px, 1.8vw, 20px);
  line-height: 1.6;
  padding-left: 28px;
  margin-bottom: 16px;
  position: relative;
}

.dpp-scroll-list li::before {
  content: '';
  width: 20px;
  height: 20px;
  position: absolute;
  left: 0;
  top: 2px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M20 6L9 17l-5-5' stroke='%2300E5FF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.dpp-scroll-right {
  position: relative;
  height: 500px;
  width: 100%;
}

.dpp-scroll-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.8s ease, visibility 0.8s ease;
  transform: scale(0.95);
}

.dpp-scroll-image.active {
  opacity: 1;
  visibility: visible;
  transform: scale(1);
}

.dpp-placeholder-image {
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.dpp-scroll-spacer {
  height: 200vh;
}

@media (max-width: 1024px) {
  .dpp-scroll-content {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  
  .dpp-scroll-right {
    height: 400px;
    order: -1;
  }
  
  .dpp-scroll-left {
    min-height: auto;
  }
  
  .dpp-scroll-step {
    position: relative;
    opacity: 1;
    visibility: visible;
    transform: none;
  }
  
  .dpp-scroll-step:not(:first-child) {
    margin-top: 60px;
  }
}

#platform2-duplicate.platform-section {
  background: #ffffff;
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: 0;
  padding: 100px 0;
  box-sizing: border-box;
  border: none;
  box-shadow: none;
  position: relative;
  z-index: 2;
}

#platform2 .platform,
#platform2-duplicate .platform {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 4.5%; /* Matches the hero alignment: main padding 2.5% + hero padding 2% */
  box-sizing: border-box;
}

#platform2 .platform__copy h2,
#platform2 .platform__copy .platform__subtitle,
#platform2 .platform__copy .platform2__subtitle,
#platform2 .platform__copy .platform__description,
#platform2 .platform__copy .list,
#platform2 .platform__copy .list li,
#platform2-duplicate .platform__copy h2,
#platform2-duplicate .platform__copy .platform__subtitle,
#platform2-duplicate .platform__copy .platform2__subtitle,
#platform2-duplicate .platform__copy .platform__description,
#platform2-duplicate .platform__copy .list,
#platform2-duplicate .platform__copy .list li {
  color: #2F3A4A !important;
}

#platform2 .platform__copy .list li::before,
#platform2-duplicate .platform__copy .list li::before {
  color: #2F3A4A !important;
}

#platform2 .btn--platform,
#platform2-duplicate .btn--platform {
  background: #2F3A4A !important;
  color: #F4F5F7 !important;
  border: none !important;
}

#platform2 .btn--platform:hover,
#platform2-duplicate .btn--platform:hover {
  background: #1a222c !important;
  color: #ffffff !important;
}

#platform2.platform-section,
#compliance.platform-section,
#platform2-duplicate.platform-section,
#platform3.platform-section,
#platform4.platform-section {
  margin-top: 0;
  margin-bottom: 0;
}

#compliance.platform-section {
  /* margin-top matches foundation section */
}

#platform3.platform-section,
#platform4.platform-section {
  padding-left: 0;
  padding-right: 3%;
  margin-left: -1.5%;
}

#platform4 .platform__visual {
  width: 100%;
  margin-left: 10%;
  margin-top: 80px;
  position: relative;
}

#platform4 .platform__visual img {
  width: 100%;
  height: auto;
  display: block;
}

#platform3 .platform {
  grid-template-columns: 1fr 1fr;
  justify-items: end;
  gap: 288px;
}

#platform3 .platform__visual {
  grid-column: 1;
  justify-self: start;
  width: 100%;
}

#platform3 .platform__visual img {
  width: 90%;
  height: auto;
  display: block;
}

#platform3 .platform__copy {
  grid-column: 2;
  max-width: 100%;
  margin-right: -12%;
}

.platform__description {
  font-size: 20px;
  line-height: 1.7;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  margin: 0 0 20px;
  max-width: 600px;
}

.platform__copy .list {
  padding-left: 0;
  margin: 0 0 40px;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  display: grid;
  gap: 16px;
  font-size: 18px;
  line-height: 1.7;
  list-style: none;
}

.platform__copy .list li {
  position: relative;
  padding-left: 32px;
}

.platform__copy .list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
  font-size: 20px;
  line-height: 1.6;
}

.platform__copy .cta__actions {
  display: flex;
  justify-content: flex-start;
  margin-top: 8px;
}

.platform__visual {
  width: 100%;
  margin: 0;
  padding: 0;
  position: relative;
  overflow: visible;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.platform__visual img {
  width: auto;
  max-width: none;
  height: auto;
  max-height: 650px;
  display: block;
  border-radius: 0;
  box-shadow: none;
  object-fit: contain;
  margin-left: auto;
  margin-right: 0;
  transform: translateX(20%);
}

.btn--platform {
  background: var(--accent) !important;
  color: #ffffff !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 10px;
  font-weight: 700;
  padding: 10px 24px !important;
  font-size: 24px !important;
  transition: background 0.2s ease;
  min-width: 320px;
}

.btn--platform:hover {
  background: var(--accent-strong) !important;
  color: #ffffff !important;
  transform: none !important;
  box-shadow: none !important;
}

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

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--accent);
  color: var(--text);
  padding: 12px 24px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 16px;
  border: none;
  cursor: pointer;
  transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.2s ease;
  box-shadow: 0 14px 30px rgba(59, 130, 246, 0.3);
}

.btn:hover {
  background: var(--accent-strong);
  transform: translateY(-1px);
}

.btn--outline {
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: none;
}

.btn--ghost {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: none;
  padding: 12px 24px;
  font-size: 16px;
}

.btn--header {
  background: #669DF6;
  color: #ffffff;
  border: none;
  box-shadow: 0 14px 30px rgba(102, 157, 246, 0.3);
  border-radius: 10px;
  font-weight: 700;
  padding: 14px 28px;
  font-size: 18px;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 200px;
}

.btn--header:hover {
  background: #5595F5;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 18px 35px rgba(102, 157, 246, 0.4);
}

.btn--header:active {
  background: #458DF4;
}

.btn--secondary {
  background: transparent;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: none;
}

.btn--secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.5);
  transform: translateY(-1px);
}

.back-to-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.5);
  background: rgba(15, 23, 42, 0.9);
  color: #cbd5f5;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.8);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
  z-index: 50;
}

.back-to-top svg {
  pointer-events: none;
}

.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  border-color: rgba(148, 163, 184, 0.9);
  background: rgba(15, 23, 42, 0.98);
  color: #e5e7eb;
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.9);
}

.back-to-top:active {
  transform: translateY(1px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.9);
}

@media (max-width: 768px) {
  .back-to-top {
    right: 16px;
    bottom: 16px;
    width: 36px;
    height: 36px;
  }
}

.cta {
  padding: 100px 3% !important;
  background: transparent !important;
  position: relative;
  overflow: hidden;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  outline: none !important;
}

.cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: 
    radial-gradient(ellipse 800px 600px at 50% 50%, rgba(59, 130, 246, 0.08) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.cta::after {
  display: none;
}

.cta__content {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 28px;
  position: relative;
  z-index: 1;
}

.cta__text {
  flex: 1;
  max-width: 100%;
}

.cta__text h2 {
  font-size: clamp(36px, 4.5vw, 52px);
  font-weight: 700;
  margin: 0 0 16px;
  line-height: 1.2;
  color: #ffffff;
  letter-spacing: -0.02em;
}

.cta__text p {
  font-size: clamp(18px, 2.2vw, 26px); /* match Use Cases subtitle */
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  font-weight: 400;
}

.btn--cta {
  background: var(--accent);
  color: #ffffff;
  border: none;
  box-shadow: none;
  border-radius: 10px;
  font-weight: 700;
  padding: 10px 24px;
  font-size: 18px;
  transition: background 0.2s ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  white-space: nowrap;
}

.btn--cta:hover {
  background: var(--accent-strong);
  color: #ffffff;
  transform: none;
}

.cta__actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}

.cta__actions .btn:not(.btn--secondary) {
  padding: 16px 32px;
  font-size: clamp(16px, 1.8vw, 22px);
  border-radius: 10px;
  min-width: 220px;
  background: #669DF6;
  color: #ffffff;
  box-shadow: 0 14px 30px rgba(102, 157, 246, 0.3);
}

.cta__actions .btn:not(.btn--secondary):hover {
  background: #5595F5;
  transform: translateY(-2px);
  box-shadow: 0 18px 35px rgba(62, 49, 168, 0.4);
}

.cta__actions .btn--secondary {
  padding: 16px 32px;
  font-size: clamp(16px, 1.8vw, 22px);
  border-radius: 10px;
  min-width: 220px;
}

/* Bottom CTA Banner */
.cta-banner {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 100px 2.5% 120px;
  background: linear-gradient(180deg, #020713 0%, #06133B 100%);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.cta-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 700px 500px at 50% 30%, rgba(62, 49, 168, 0.15), transparent 70%);
  z-index: 0;
  pointer-events: none;
}

.cta-banner__inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 20px;
  text-align: center;
  position: relative;
  z-index: 1;
}

.cta-banner__eyebrow {
  color: #3E31A8;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0;
  font-size: clamp(14px, 1.6vw, 16px);
}

.cta-banner__title {
  color: #ffffff;
  font-size: clamp(38px, 4.8vw, 58px);
  font-weight: 700;
  line-height: 1.1;
  margin: 0;
}

.cta-banner__subtitle {
  color: rgba(255, 255, 255, 0.82);
  font-size: clamp(18px, 2.2vw, 24px);
  line-height: 1.6;
  margin: 0 auto;
  max-width: 960px;
}

.cta-banner__actions {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.cta-banner .btn {
  min-width: 180px;
  padding: 16px 28px;
  font-size: clamp(16px, 1.8vw, 20px);
  border-radius: 14px;
}

.cta-banner .btn.btn--secondary {
  background: transparent;
  border: 2px solid #669DF6;
  color: #669DF6;
}

.cta-banner .btn.btn--secondary:hover {
  background: rgba(102, 157, 246, 0.08);
}

.card--link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.card--link:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 50px rgba(0, 0, 0, 0.4);
}

/* Secure Network Hero Section */
/* IMPORTANT: Adjust height to match your specific homepage hero height */
.secure-network-hero {
  position: relative;
  height: auto;
  min-height: 600px;
  background: transparent;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  overflow: hidden;
  box-shadow: none !important;
  border: none !important;
  border-radius: 0 !important;
  outline: none !important;
  padding: 40px 2% 0;
}


/* Layer 1 (z-0): Background Visuals */
.secure-network-hero__glow {
  display: none;
}

.secure-network-hero__network {
  display: none;
}


/* Layer 3 (z-10): Foreground Content */
.secure-network-hero__content {
  position: relative;
  z-index: 10;
  text-align: left;
  max-width: 50%;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.secure-network-hero .back-link {
  color: rgba(255, 255, 255, 0.9) !important;
  margin-bottom: 24px;
  display: inline-block;
  align-self: flex-start;
}

.secure-network-hero__label {
  position: absolute;
  top: -32px;
  color: #60a5fa;
  display: inline-block;
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.gradient-text {
  color: #111827; /* Fallback for browsers that don't support background-clip: text */
  background: linear-gradient(90deg, #669DF6 0%, #7FD9A8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline-block;
}

.secure-network-hero h1 {
  font-size: clamp(43px, 5.4vw, 65px);
  font-weight: 700;
  line-height: 1.2;
  color: #ffffff;
  margin: 0 0 48px;
  letter-spacing: -0.02em;
  text-align: left;
  width: 100%;
  white-space: normal;
}

.secure-network-hero h1 .gradient-text {
  white-space: nowrap;
}

.secure-network-hero__subheadline {
  font-size: clamp(16px, 1.8vw, 22px);
  line-height: 1.6;
  color: rgba(203, 213, 225, 1);
  margin: 0 0 40px;
  max-width: 100%;
  text-align: left;
}

.secure-network-hero__actions {
  display: flex;
  gap: 12px;
  justify-content: flex-start;
  flex-wrap: wrap;
}

.secure-network-hero .btn--primary {
  background: #2563eb;
  color: #ffffff;
  border: none;
  padding: 16px 32px;
  font-size: 18px;
  font-weight: 600;
  border-radius: 10px;
  min-width: 220px;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3);
}

.secure-network-hero .btn--primary:hover {
  background: #1d4ed8;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.5);
}

.secure-network-hero .btn--secondary {
  background: transparent;
  color: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(148, 163, 184, 0.5);
  padding: 16px 32px;
  font-size: 18px;
  font-weight: 600;
  border-radius: 10px;
  min-width: 220px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.secure-network-hero .btn--secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(148, 163, 184, 0.8);
  color: #ffffff;
}

.page-hero {
  padding: 120px 40px 80px;
  max-width: var(--max-width);
  margin: 0 auto;
  text-align: center;
}

.page-hero__content {
  max-width: 900px;
  margin: 0 auto;
}

.back-link {
  display: inline-block;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  margin-bottom: 32px;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.2s ease;
  font-size: clamp(16px, 1.8vw, 22px);
  font-size: clamp(16px, 1.8vw, 22px);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.back-link:hover {
  color: var(--text);
}

.page-hero h1 {
  font-size: clamp(48px, 6vw, 72px);
  line-height: 1.1;
  margin: 0 0 24px;
  color: #ffffff;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.page-hero__lead {
  font-size: clamp(20px, 2.5vw, 28px);
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  line-height: 1.5;
  max-width: 800px;
  margin: 0 auto;
  font-weight: 400;
}

.band--no-frame {
  background: #f8f9fa !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 120px 0 100px !important;
  color: #111827 !important;
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  min-height: 800px !important;
  position: relative;
  z-index: 2;
}

/* Force remove all spacing and borders between consecutive sections - remove blue divider */
.band--no-frame + .band--no-frame {
  margin-top: -125px !important;
  padding-top: 0 !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  border-top: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  outline: none !important;
  background: #f8f9fa !important;
  position: relative !important;
  z-index: 2 !important;
}


/* Override any band styling that might create blue dividers */
.band--no-frame {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

.band--no-frame .page-content {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  width: 100% !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Content split layout for title, subtitle, copy on left and image on right */
.content-split {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 60px !important;
  align-items: center !important;
  max-width: 1280px !important;
  width: 100% !important;
  padding: 80px 40px !important;
  box-sizing: border-box !important;
}

.content-split__copy {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
  align-items: flex-start !important;
  text-align: left !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.content-split__copy h2,
.content-split__copy .content-split__subtitle,
.content-split__copy .content-split__description {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  text-indent: 0 !important;
  box-sizing: border-box !important;
}

.content-split__copy h2 {
  font-size: clamp(44px, 5.5vw, 62px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
  padding: 0 !important;
  font-weight: 700 !important;
  color: #111827 !important;
  text-align: left !important;
  width: 100% !important;
}

.content-split__subtitle {
  font-size: clamp(24px, 2.5vw, 28px) !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  color: #60a5fa !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  width: 100% !important;
}

.content-split__description {
  font-size: clamp(16px, 1.8vw, 20px) !important;
  line-height: 1.6 !important;
  color: #4a5568 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  width: 100% !important;
}

.content-split__visual {
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.content-split__visual img {
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
  border-radius: 8px !important;
}

.band--no-frame::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.4'/%3E%3C/svg%3E");
  opacity: 0.15;
  pointer-events: none;
  z-index: 0;
}

.band--no-frame > * {
  position: relative;
  z-index: 1;
}


.features-section-title {
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: normal;
  margin: 80px 0 100px;
  color: #1F2937 !important;
  text-align: center;
}

.band--no-frame h2,
.band--no-frame .page-content h2 {
  font-size: clamp(39px, 4.86vw, 59px) !important;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 auto !important;
  font-weight: 700;
  color: #1F2937 !important;
  text-align: center !important;
  white-space: nowrap;
  width: auto;
  max-width: 100%;
  padding: 0 !important;
  box-sizing: border-box !important;
  align-self: center !important;
}

.band--no-frame__subtitle {
  font-size: clamp(16px, 1.8vw, 22px) !important;
  line-height: 1.6;
  color: rgba(45, 55, 72, 0.8) !important;
  margin: 24px auto 0 !important;
  text-align: center !important;
  white-space: nowrap;
  width: auto;
  max-width: 100%;
  padding: 0;
}

/* Legal pages: force left alignment after global band overrides */
.page--legal .band--no-frame__subtitle,
.page--legal .band--no-frame h2,
.page--legal .band--no-frame .page-content h2,
.page--legal .band--no-frame p,
.page--legal .band--no-frame li {
  text-align: left !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  align-self: flex-start !important;
}

.page--legal .band--no-frame__subtitle {
  margin: 0 0 18px !important;
  white-space: normal !important;
  width: 100% !important;
}

.band--no-frame h3,
.band--no-frame h4 {
  color: #1F2937 !important;
}

.band--no-frame p {
  color: #4a5568 !important;
}

.features-grid-2x2 {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 80px 180px !important;
  margin: 80px auto 0 !important;
  max-width: 95vw !important;
  width: 95vw !important;
  padding: 90px 20% !important;
  border: none !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  box-sizing: border-box !important;
  position: relative !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  justify-items: start !important;
}

/* Align left column icons (Security and Supply Chain) with section title left edge */
.features-grid-2x2 .feature-point:nth-child(1),
.features-grid-2x2 .feature-point:nth-child(3) {
  margin-left: calc(50vw - 47.5vw - 20%);
}

.feature-point {
  display: flex !important;
  align-items: flex-start !important;
  gap: 24px !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
}

.feature-point__icon {
  width: 53px !important;
  height: 53px !important;
  min-width: 53px !important;
  flex-shrink: 0 !important;
  background: transparent !important;
  border-radius: 4px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 3px !important;
  align-self: flex-start !important;
}

.feature-point__icon img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.feature-point__content {
  flex: 1 !important;
  max-width: 130% !important;
  width: 130% !important;
}

.feature-point__title {
  font-size: clamp(20px, 2.2vw, 24px) !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: #111827 !important;
  margin: 0 0 6px !important;
  padding: 0 !important;
  padding-top: 0 !important;
}

.feature-point__subtitle {
  font-size: clamp(15px, 1.7vw, 18px) !important;
  line-height: 1.6 !important;
  color: #111827 !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: normal !important;
  max-width: 130% !important;
  width: 130% !important;
}

.band--no-frame a {
  color: #111827 !important;
}

.features-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 64px 32px !important;
  margin: 0 auto !important;
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
}

.feature-item {
  text-align: left;
  display: flex;
  flex-direction: column;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

.feature-item h3 {
  margin-bottom: 12px;
  font-size: clamp(16px, 1.8vw, 22px);
  font-size: clamp(20px, 2.2vw, 26px);
  max-width: 80%;
}

.feature-item p {
  margin-bottom: 20px;
  font-size: clamp(15px, 1.7vw, 18px);
  line-height: 1.5;
  max-width: 80%;
}

.feature-box {
  width: 80%;
  aspect-ratio: 301 / 198;
  background: transparent;
  border: none;
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
  margin-top: auto;
  flex-shrink: 0;
}

.feature-item h3 {
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: normal;
  margin-bottom: 12px;
  font-size: clamp(16px, 1.8vw, 22px);
  color: #1F2937 !important;
}

.feature-item p {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: normal;
  color: #4a5568 !important;
  margin: 0;
}

@media (max-width: 768px) {
  .features-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

/* Book Demo Form */
.book-demo-container {
  max-width: 800px;
  margin: 0 auto;
}

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

.form-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.form-group--full {
  grid-column: 1 / -1;
}

.form-group label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  margin-bottom: 6px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  font-size: 11px;
}

.form-group .required {
  color: var(--accent-light);
  font-weight: 700;
  margin-left: 3px;
  font-size: clamp(16px, 1.8vw, 22px);
  display: inline-block;
}

.form-group input,
.form-group select,
.form-group textarea {
  padding: 14px 16px;
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(96, 165, 250, 0.5);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 15px;
  font-family: inherit;
  transition: all 0.3s ease;
  width: 100%;
  box-shadow: 
    0 2px 8px rgba(0, 0, 0, 0.2),
    0 0 0 1px rgba(59, 130, 246, 0.2);
}

.form-group input:hover,
.form-group select:hover,
.form-group textarea:hover {
  border-color: rgba(96, 165, 250, 0.7);
  background: rgba(59, 130, 246, 0.2);
  box-shadow: 
    0 2px 8px rgba(0, 0, 0, 0.2),
    0 0 0 1px rgba(96, 165, 250, 0.4),
    0 0 20px rgba(59, 130, 246, 0.2);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: rgba(147, 197, 253, 0.8);
  background: rgba(59, 130, 246, 0.25);
  box-shadow: 
    0 4px 12px rgba(0, 0, 0, 0.3),
    0 0 0 2px rgba(59, 130, 246, 0.4),
    0 0 30px rgba(96, 165, 250, 0.4);
}


/* Custom validation message */
.form-group__error {
  display: none;
  font-size: 12px;
  color: #f87171;
  margin-top: 6px;
  align-items: center;
  gap: 6px;
  animation: slideDown 0.2s ease;
  font-weight: 400;
}

.form-group__error svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  stroke: currentColor;
}

.form-group--error .form-group__error {
  display: flex;
}

.form-group--error input,
.form-group--error select,
.form-group--error textarea {
  border-color: rgba(239, 68, 68, 0.5);
  background: rgba(239, 68, 68, 0.06);
}

.form-group--error input:focus,
.form-group--error select:focus,
.form-group--error textarea:focus {
  border-color: rgba(239, 68, 68, 0.8);
  background: rgba(239, 68, 68, 0.08);
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.15);
}

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

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  opacity: 0.6;
}

.form-group textarea {
  resize: vertical;
  min-height: 100px;
  font-family: inherit;
}

.form-actions {
  margin-top: 8px;
  display: flex;
  justify-content: flex-start;
}

.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-size: 13px;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  line-height: 1.6;
  padding: 12px 0;
}

.checkbox-label input[type="checkbox"] {
  margin-top: 2px;
  width: 16px;
  height: 16px;
  min-width: 16px;
  cursor: pointer;
  accent-color: var(--accent);
  flex-shrink: 0;
}

/* Success Modal */
.success-modal,
.error-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  font-family: 'Urbanist', system-ui, -apple-system, sans-serif;
}

.success-modal.is-visible,
.error-modal.is-visible {
  opacity: 1;
  visibility: visible;
}

.success-modal__overlay,
.error-modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.85);
}

.success-modal__content,
.error-modal__content {
  position: relative;
  background: rgba(59, 130, 246, 0.3);
  border: 1px solid rgba(96, 165, 250, 0.7);
  box-shadow: 
    0 24px 60px rgba(0, 0, 0, 0.5),
    0 0 0 1px rgba(59, 130, 246, 0.4),
    0 0 50px rgba(59, 130, 246, 0.3),
    0 0 100px rgba(37, 99, 235, 0.2);
  border-radius: var(--radius-lg);
  padding: 48px;
  max-width: 500px;
  width: 90%;
  text-align: center;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
  transform: scale(0.9);
  transition: transform 0.3s ease;
}

.success-modal.is-visible .success-modal__content,
.error-modal.is-visible .error-modal__content {
  transform: scale(1);
}

.success-modal__icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 24px;
  color: #10b981;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(16, 185, 129, 0.1);
  border-radius: 50%;
  animation: scaleIn 0.4s ease;
}

.error-modal__icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 24px;
  color: #ef4444;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(239, 68, 68, 0.1);
  border-radius: 50%;
  animation: scaleIn 0.4s ease;
}

@keyframes scaleIn {
  from {
    transform: scale(0);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

.success-modal__title,
.error-modal__title {
  font-size: 28px;
  font-weight: 600;
  margin: 0 0 16px;
  color: var(--text);
}

.success-modal__message,
.error-modal__message {
  font-size: 16px;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  line-height: 1.6;
  margin: 0 0 32px;
}

.success-modal__content .btn,
.error-modal__content .btn {
  min-width: 150px;
}

@media (max-width: 768px) {
  .form-row {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .success-modal__content,
  .error-modal__content {
    padding: 32px 24px;
  }
}

.page-content h2 {
  font-size: clamp(28px, 3.5vw, 40px);
  margin: 0 0 20px;
  line-height: 1.2;
}

.page-content h3 {
  font-size: clamp(22px, 2.5vw, 28px);
  margin: 32px 0 12px;
  line-height: 1.3;
}

.page-content p {
  margin: 0 0 20px;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  line-height: 1.7;
  font-size: 16px;
}

/* Whitepaper Section */
.whitepaper-section {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}

.whitepaper-card {
  background: #ffffff;
  border-radius: var(--radius-lg);
  padding: 48px 40px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.whitepaper-card h2 {
  font-size: 32px;
  font-weight: 700;
  color: #111827;
  margin: 0 0 20px;
  line-height: 1.2;
}

.whitepaper-description {
  font-size: 16px;
  line-height: 1.6;
  color: #4B5563;
  margin: 0 0 40px;
}

.whitepaper-keypoints {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 40px;
}

.keypoint {
  display: flex;
  gap: 20px;
  padding-bottom: 24px;
  border-bottom: 1px solid #e5e5e5;
  transition: transform 0.2s ease;
}

.keypoint:hover {
  transform: translateX(4px);
}

.keypoint:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.keypoint-number {
  font-size: 32px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
  flex-shrink: 0;
  opacity: 0.3;
  font-family: 'Urbanist', sans-serif;
}

.keypoint-content {
  flex: 1;
}

.keypoint h3 {
  font-size: 18px;
  font-weight: 600;
  color: #111827;
  margin: 0 0 8px;
}

.keypoint p {
  font-size: 15px;
  line-height: 1.6;
  color: #6B7280;
  margin: 0;
}

.btn--whitepaper {
  width: 100%;
  background: var(--accent);
  color: #ffffff;
  padding: 16px 32px;
  font-size: 16px;
  font-weight: 600;
  border-radius: var(--radius-sm);
  text-align: center;
  display: block;
  text-decoration: none;
  transition: background 0.2s ease, transform 0.1s ease;
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

.btn--whitepaper:hover {
  background: var(--accent-strong);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(59, 130, 246, 0.4);
}

/* Whitepaper Preview on Homepage */
.whitepaper-preview {
  max-width: 1200px;
  margin: 0 auto;
}

.whitepaper-preview__card {
  background: #ffffff;
  border-radius: var(--radius-lg);
  padding: 40px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  align-items: center;
}

.whitepaper-preview__content {
  display: flex;
  flex-direction: column;
}

.whitepaper-preview__content h2 {
  font-size: 28px;
  font-weight: 700;
  color: #111827;
  margin: 0 0 16px;
  line-height: 1.2;
}

.whitepaper-preview__description {
  font-size: 15px;
  line-height: 1.6;
  color: #4B5563;
  margin: 0 0 32px;
}

.whitepaper-preview__keypoints {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 32px;
}

.keypoint-preview {
  display: flex;
  gap: 16px;
  align-items: center;
}

.keypoint-preview__number {
  font-size: 24px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
  opacity: 0.3;
  flex-shrink: 0;
  min-width: 40px;
}

.keypoint-preview__content h4 {
  font-size: 16px;
  font-weight: 600;
  color: #111827;
  margin: 0;
}

.btn--whitepaper-preview {
  width: fit-content;
  background: var(--accent);
  color: #ffffff;
  padding: 14px 28px;
  font-size: 15px;
  font-weight: 600;
  border-radius: var(--radius-sm);
  text-align: center;
  display: inline-block;
  text-decoration: none;
  transition: background 0.2s ease, transform 0.1s ease;
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

.btn--whitepaper-preview:hover {
  background: var(--accent-strong);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(59, 130, 246, 0.4);
}

.document-preview {
  position: relative;
  height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 800px;
}

.document-preview__stack {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
}

.document-preview__item {
  position: absolute;
  width: 200px;
  height: 260px;
  border-radius: 10px;
  box-shadow: 0 15px 40px rgba(59, 130, 246, 0.3);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.document-preview__item--1 {
  z-index: 3;
  transform: rotateY(-8deg) rotateX(2deg) translateZ(0);
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

.document-preview__item--1:hover {
  transform: rotateY(-5deg) rotateX(0deg) translateZ(15px);
  box-shadow: 0 20px 50px rgba(59, 130, 246, 0.4);
}

.document-preview__item--2 {
  z-index: 2;
  transform: rotateY(-12deg) rotateX(4deg) translateX(-15px) translateY(10px) translateZ(-25px);
  background: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);
  opacity: 0.85;
}

.document-preview__item--3 {
  z-index: 1;
  transform: rotateY(-16deg) rotateX(6deg) translateX(-30px) translateY(20px) translateZ(-50px);
  background: linear-gradient(135deg, #93c5fd 0%, #60a5fa 100%);
  opacity: 0.7;
}

/* Whitepaper Visual - Document Stack */
.whitepaper-visual {
  position: relative;
  height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 1000px;
}

.document-stack {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
}

.document {
  position: absolute;
  width: 280px;
  height: 380px;
  border-radius: 12px;
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  box-shadow: 0 20px 60px rgba(59, 130, 246, 0.4);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.document--1 {
  z-index: 3;
  transform: rotateY(-8deg) rotateX(2deg) translateZ(0);
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  padding: 24px;
  color: #ffffff;
}

.document--1:hover {
  transform: rotateY(-5deg) rotateX(0deg) translateZ(20px);
  box-shadow: 0 25px 80px rgba(59, 130, 246, 0.5);
}

.document--2 {
  z-index: 2;
  transform: rotateY(-12deg) rotateX(4deg) translateX(-20px) translateY(15px) translateZ(-30px);
  background: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);
  opacity: 0.85;
}

.document--3 {
  z-index: 1;
  transform: rotateY(-16deg) rotateX(6deg) translateX(-40px) translateY(30px) translateZ(-60px);
  background: linear-gradient(135deg, #93c5fd 0%, #60a5fa 100%);
  opacity: 0.7;
}

.document-header {
  margin-bottom: 16px;
}

.document-label {
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 700;
  letter-spacing: 2px;
  opacity: 0.9;
}

.document-title {
  font-size: 12px;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 8px;
  letter-spacing: 0.5px;
}

.document-subtitle {
  font-size: 11px;
  opacity: 0.85;
  margin-bottom: 12px;
  font-size: clamp(16px, 1.8vw, 22px);
}

.document-tag {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1px;
  opacity: 0.7;
  margin-bottom: 24px;
}

.document-graphic {
  margin-top: 24px;
}

.document-icon-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 20px;
}

.icon-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  transition: background 0.2s ease;
}

.icon-item:hover {
  background: rgba(255, 255, 255, 0.15);
}

.icon-item svg {
  width: 20px;
  height: 20px;
  stroke: #ffffff;
}

.icon-item span {
  font-size: 9px;
  font-weight: 600;
  text-align: center;
  line-height: 1.2;
  letter-spacing: 0.5px;
}

/* Footer - Full width background */
.site-footer {
  width: 100%;
  background: rgba(62, 49, 168, 0.08);
  color: #1f2937;
  position: relative;
  z-index: 1;
  isolation: isolate;
}

/* Hide footer on non-homepage */
.page--home .site-footer {
  display: block;
}

/* Footer inner container - aligns with content above */
.footer-inner {
  padding-block: 48px;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.footer__top {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

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

.footer__logo {
  display: inline-block;
  text-decoration: none;
}

.footer__logo img {
  display: block;
  height: 252px;
  width: auto;
  max-width: 1260px;
  max-height: 252px;
  object-fit: contain;
}

.footer__payoff {
  font-size: 14px;
  font-weight: 700;
  color: #475569; /* Slate 600 - much better readability on grey */
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0;
}

.footer__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)) 1fr;
  gap: 24px;
  align-items: start;
  width: 100%;
}

.footer__card {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 24px;
  padding: 40px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 260px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.footer__card:hover {
  /* Hover effects disabled */
}

.footer__card-title {
  font-size: clamp(18px, 2.2vw, 24px);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #64748b;
  font-weight: 800;
  margin-bottom: 12px;
}

.footer__card a {
  color: #1F2937;
  font-size: clamp(17px, 2vw, 22px);
  font-weight: 500;
  line-height: 1.6;
  transition: all 0.2s ease;
  display: block;
  margin: 6px 0;
}

.footer__card a:hover {
  /* Hover effects disabled */
  color: #1F2937;
  padding-left: 4px;
}

.footer__card--cta {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
  justify-content: flex-start;
}

.footer__launch {
  display: none; /* Hidden temporarily - change to inline-flex to show again */
  align-items: center;
  justify-content: center;
  background: #669DF6;
  color: #ffffff;
  padding: 18px 36px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 18px;
  box-shadow: 0 10px 24px rgba(102, 157, 246, 0.3);
  transition: all 0.3s ease;
  text-decoration: none;
  align-self: flex-start;
}

.footer__launch:hover {
  /* Hover effects disabled */
}

.footer__social {
  display: flex;
  gap: 16px;
}

.footer__social a {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: #1e293b;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  transition: all 0.2s ease;
  position: relative;
}

.footer__social a:hover {
  /* Hover effects disabled */
}

.footer__bottom {
  border-top: 2px solid #cbd5e1;
  padding-top: 24px;
  font-size: 13px;
  color: #64748b;
  width: 100%;
}

.footer__bottom .footer__bottom-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  box-sizing: border-box;
}

.footer__bottom .footer__bottom-row p {
  margin: 0;
}

.footer__bottom .footer__bottom-links {
  display: inline-flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
}

.footer__bottom .footer__bottom-links a {
  color: #64748b;
  text-decoration: none;
  font-weight: 600;
  font-size: 15px !important;
}

.footer__bottom .footer__bottom-links a:hover {
  /* Hover effects disabled */
}

@media (max-width: 768px) {
  .footer-inner {
    padding-block: 32px;
    gap: 32px;
  }

  .footer__bottom .footer__bottom-row {
    padding-left: 0;
    padding-right: 0;
  }

  .footer__inner {
    padding: 0 6%;
    gap: 20px;
  }

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

  .footer__card {
    min-height: auto;
  }

  .whitepaper-section {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .whitepaper-card {
    padding: 32px 24px;
  }

  .whitepaper-card h2 {
    font-size: 24px;
  }

  .whitepaper-description {
    font-size: 15px;
  }

  .keypoint h3 {
    font-size: 16px;
  }

  .keypoint p {
    font-size: clamp(16px, 1.8vw, 22px);
  }

  .whitepaper-visual {
    height: 400px;
    order: -1;
  }

  .document {
    width: 240px;
    height: 320px;
  }

  .document--1 {
    transform: rotateY(-5deg) rotateX(2deg);
  }

  .document--2 {
    transform: rotateY(-8deg) rotateX(4deg) translateX(-15px) translateY(10px) translateZ(-20px);
  }

  .document--3 {
    transform: rotateY(-12deg) rotateX(6deg) translateX(-30px) translateY(20px) translateZ(-40px);
  }

  .whitepaper-preview__card {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 32px 24px;
  }

  .whitepaper-preview__content h2 {
    font-size: 24px;
  }

  .whitepaper-preview__description {
    font-size: clamp(16px, 1.8vw, 22px);
  }

  .document-preview {
    height: 250px;
    order: -1;
  }

  .document-preview__item {
    width: 160px;
    height: 200px;
  }

  .unified-content {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .unified-header h2 {
    font-size: 28px;
  }

  .unified-lede {
    font-size: 16px;
  }

  .unified-feature {
    padding: 20px;
  }

  .unified-feature__icon {
    width: 40px;
    height: 40px;
  }

  .unified-feature__content h3 {
    font-size: 18px;
  }

  .unified-whitepaper__visual {
    position: relative;
    right: auto;
    width: 100%;
    height: 300px;
    margin-top: 32px;
    order: -1;
  }

  .unified-document-stack {
    height: 300px;
  }

  .unified-document {
    width: 180px;
    height: 240px;
  }

  .unified-whitepaper__card {
    padding: 32px 24px;
  }

  .unified-whitepaper__header h3 {
    font-size: 20px;
  }
}

/* Lift logo + cyan subtitle so the subtitle aligns with first footer link row (desktop only) */
@media (min-width: 769px) {
  .footer__brand {
    margin-top: -48px;
    gap: 8px;
  }
}

/* Removed legacy footer styles */


.footer__social {
  display: flex;
  gap: 16px;
  margin-top: 12px;
}

/* Social cleanup */

.footer__social a svg {
  width: 32px;
  height: 32px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.footer__social a:first-child svg {
  fill: #ffffff;
  stroke: none;
}

.footer__social a:nth-child(2) svg {
  fill: #ffffff;
  stroke: none;
}

.footer__social a:last-child svg {
  fill: none;
  stroke: #ffffff;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.footer__social a:hover {
  /* Hover effects disabled */
}

/* Removed legacy footer styles causing conflicts */

.footer__newsletter {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
}

.footer__newsletter-title {
  font-size: 18px;
  font-weight: 800;
  color: #111827;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin: 0 0 8px;
}

.footer__newsletter-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}

.footer__newsletter-input {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid #e6edf5;
  border-radius: 8px;
  background: #ffffff;
  color: #1F2937;
  font-size: 16px;
  font-family: inherit;
  transition: all 0.2s ease;
  box-sizing: border-box;
}

.footer__newsletter-input:focus {
  outline: none;
  border-color: #669DF6;
  box-shadow: 0 0 0 3px rgba(102, 157, 246, 0.1);
}

.footer__newsletter-input::placeholder {
  color: #9CA3AF;
}

.footer__newsletter-submit {
  padding: 14px 28px;
  border: 1px solid #ffffff;
  border-radius: 8px;
  background: transparent;
  color: #1F2937;
  font-size: 16px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.2s ease;
  align-self: flex-start;
}

.footer__newsletter-submit:hover {
  background: rgba(0, 0, 0, 0.05);
  border-color: #e6edf5;
}

.footer__newsletter-disclaimer {
  font-size: 13px;
  color: #64748b;
  line-height: 1.6;
  margin: 0;
}

.footer__newsletter-disclaimer a {
  color: #3E31A8;
  text-decoration: underline;
}

.footer__newsletter-disclaimer a:hover {
  color: #352A95;
}

.footer__newsletter-desc {
  font-size: clamp(17px, 1.9vw, 22px);
  color: var(--text-subtle);
  margin-bottom: 12px;
  line-height: 1.5;
}

.footer__newsletter-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.footer__newsletter-input {
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
  font-size: clamp(16px, 1.8vw, 22px);
  font-family: inherit;
  transition: all 0.2s ease;
}

.footer__newsletter-input:focus {
  outline: none;
  border-color: var(--accent);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.footer__newsletter-input::placeholder {
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
}

/* Footer Copyright */
.footer__copyright {
  grid-column: 1 / -1;
  margin-top: 40px;
  padding-top: 24px;
  padding-left: 0;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.footer__copyright p {
  margin: 0;
  color: var(--text-subtle);
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 400;
  letter-spacing: 0.01em;
}

@media (max-width: 768px) {
  .footer__copyright {
    margin-top: 32px;
    padding-top: 20px;
    justify-content: center;
    text-align: center;
  }
}

/* Cookie Consent Banner */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #ffffff;
  border-top: 2px solid #cbd5e1;
  box-shadow: 
    0 -4px 24px rgba(0, 0, 0, 0.1),
    0 0 0 1px rgba(0, 0, 0, 0.05);
  z-index: 1000;
  padding: 24px;
  font-family: 'Urbanist', system-ui, -apple-system, sans-serif;
  transform: translateY(100%);
  transition: transform 0.3s ease;
}

.cookie-banner.is-visible {
  transform: translateY(0);
}

.cookie-banner__content {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.cookie-banner__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(102, 157, 246, 0.1);
  border-radius: 12px;
  color: #669DF6;
}

.cookie-banner__text {
  flex: 1;
  min-width: 250px;
}

.cookie-banner__title {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 8px 0;
  color: #1F2937;
}

.cookie-banner__description {
  font-size: clamp(15px, 1.6vw, 18px);
  margin: 0;
  color: #4B5563;
  line-height: 1.6;
}

.cookie-banner__description a {
  color: #3E31A8;
  text-decoration: underline;
  font-weight: 500;
  transition: color 0.2s ease;
}

.cookie-banner__description a:hover {
  color: #5595F5;
}

.cookie-banner__actions {
  display: flex;
  gap: 12px;
  flex-shrink: 0;
}

.btn--cookie-reject {
  background: transparent;
  border: 1.5px solid #e5e7eb;
  color: #4B5563;
  padding: 12px 20px;
  font-size: clamp(15px, 1.6vw, 17px);
  font-weight: 600;
  border-radius: 8px;
  transition: all 0.2s ease;
}

.btn--cookie-reject:hover {
  background: #f5f6f8;
  border-color: #e5e7eb;
  color: #1F2937;
}

.btn--cookie-secondary {
  background: transparent;
  border: 1.5px solid #e5e7eb;
  color: #4B5563;
  padding: 12px 24px;
  font-size: clamp(15px, 1.6vw, 17px);
  font-weight: 600;
  border-radius: 8px;
  transition: all 0.2s ease;
}

.btn--cookie-secondary:hover {
  background: #f5f6f8;
  border-color: #669DF6;
  color: #1F2937;
}

.btn--cookie-primary {
  background: #669DF6;
  border: 1.5px solid #669DF6;
  color: #ffffff;
  padding: 12px 24px;
  font-size: clamp(15px, 1.6vw, 17px);
  font-weight: 700;
  border-radius: 8px;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(62, 49, 168, 0.2);
}

.btn--cookie-primary:hover {
  background: #5595F5;
  border-color: #5595F5;
  box-shadow: 0 6px 16px rgba(102, 157, 246, 0.3);
  transform: translateY(-1px);
}

/* Cookie Modal */
.cookie-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  font-family: 'Urbanist', system-ui, -apple-system, sans-serif;
  padding: 20px;
}

.cookie-modal.is-visible {
  opacity: 1;
  visibility: visible;
}

.cookie-modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.75);
}

.cookie-modal__content {
  position: relative;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  box-shadow: 
    0 24px 60px rgba(0, 0, 0, 0.15),
    0 0 0 1px rgba(0, 0, 0, 0.05);
  max-width: 600px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  transform: scale(0.95) translateY(20px);
  transition: transform 0.3s ease;
}

.cookie-modal.is-visible .cookie-modal__content {
  transform: scale(1) translateY(0);
}

.cookie-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px;
  border-bottom: 2px solid #cbd5e1;
}

.cookie-modal__title {
  font-size: 24px;
  font-weight: 600;
  margin: 0;
  color: #1F2937;
}

.cookie-modal__close {
  background: transparent;
  border: none;
  color: #4B5563;
  cursor: pointer;
  padding: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: background 0.2s ease;
  width: 36px;
  height: 36px;
}

.cookie-modal__close:hover {
  background: #f5f6f8;
  color: #1F2937;
}

.cookie-modal__body {
  padding: 24px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.cookie-category {
  grid-column: span 1;
}

.cookie-category__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.cookie-category__info {
  display: flex;
  align-items: center;
  gap: 12px;
}

.cookie-category__title {
  font-size: 18px;
  font-weight: 600;
  margin: 0;
  color: #1F2937;
}

.cookie-category__badge {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  background: rgba(62, 49, 168, 0.1);
  color: #3E31A8;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.cookie-category__description {
  font-size: clamp(15px, 1.6vw, 17px);
  line-height: 1.6;
  margin: 0;
  color: #4B5563;
}

/* Cookie Toggle Switch */
.cookie-toggle {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  cursor: pointer;
}

.cookie-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.cookie-toggle__slider {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #e5e7eb;
  border-radius: 24px;
  transition: background 0.3s ease;
}

.cookie-toggle__slider::before {
  content: '';
  position: absolute;
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 3px;
  background: #ffffff;
  border-radius: 50%;
  transition: transform 0.3s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.cookie-toggle input:checked + .cookie-toggle__slider {
  background: #669DF6;
}

.cookie-toggle input:checked + .cookie-toggle__slider::before {
  transform: translateX(20px);
}

.cookie-toggle input:focus + .cookie-toggle__slider {
  box-shadow: 0 0 0 3px rgba(62, 49, 168, 0.2);
}

.cookie-modal__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px;
  border-top: 2px solid #cbd5e1;
  gap: 12px;
}

.btn--cookie-remove {
  background: transparent;
  border: 1.5px solid #e5e7eb;
  color: #4B5563;
  padding: 12px 24px;
  font-size: clamp(15px, 1.6vw, 17px);
  font-weight: 600;
  flex: 1;
  border-radius: 8px;
  transition: all 0.2s ease;
}

.btn--cookie-remove:hover {
  background: #f5f6f8;
  border-color: #669DF6;
  color: #1F2937;
}

.btn--cookie-save {
  background: #669DF6;
  border: 1.5px solid #669DF6;
  color: #ffffff;
  padding: 12px 24px;
  font-size: clamp(15px, 1.6vw, 17px);
  font-weight: 700;
  flex: 1;
  border-radius: 8px;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(62, 49, 168, 0.2);
}

.btn--cookie-save:hover {
  background: #5595F5;
  border-color: #5595F5;
  box-shadow: 0 6px 16px rgba(102, 157, 246, 0.3);
  transform: translateY(-1px);
}

/* Mobile responsive for cookie modal */
@media (max-width: 768px) {
  .cookie-banner__content {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .cookie-banner__actions {
    width: 100%;
    flex-direction: column;
  }
  
  .cookie-banner__actions .btn {
    width: 100%;
  }
  
  .cookie-modal__body {
    grid-template-columns: 1fr;
  }
  
  .cookie-modal__footer {
    flex-direction: column;
  }
  
  .cookie-modal__footer .btn {
    width: 100%;
  }
}

.btn--small {
  padding: 10px 20px;
  font-size: clamp(16px, 1.8vw, 22px);
  border-radius: 8px;
}


@media (max-width: 1100px) {
  :root {
    --max-width: 100%;
  }

  .nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: auto;
    min-height: 88px;
    align-items: center;
  }

  /* Mobile nav: left = logo, center = Book a Demo, right = hamburger. Use flex for reliable left/center/right. */
  .nav__container {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    padding-left: 20px;
    padding-right: 12px;
    gap: 8px;
    position: relative;
  }

  .nav__logo {
    order: 1;
    flex-shrink: 0;
    min-width: 0;
    margin-left: -10px;
    overflow: visible;
    align-self: center;
  }

  /* Menu-pill takes no space (dropdown links use position: absolute relative to .nav) */
  .nav__menu-pill {
    flex: 0 0 0;
    width: 0;
    min-width: 0;
    overflow: visible;
  }

  .btn--header {
    display: none !important;
  }

  .nav__toggle {
    order: 3;
    flex-shrink: 0;
    margin-left: auto;
    margin-right: 20px;
    padding: 12px;
    gap: 6px;
  }

  .nav__toggle span {
    width: 28px;
    height: 3px;
  }

  .nav__logo .logo-img--desktop {
    display: none !important;
  }
  .nav__logo .logo-img--mobile {
    display: block !important;
  }
  .nav__logo img {
    height: auto !important;
    max-height: 72px !important;
    width: auto !important;
    max-width: none !important;
  }

  .nav__menu-pill {
    background: none;
    backdrop-filter: none;
    border: none;
    padding: 0;
  }

  .nav__links {
    position: absolute;
    top: 88px;
    right: 16px;
    left: 16px;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.98); /* Light background for mobile menu */
    backdrop-filter: blur(20px);
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 20px;
    padding: 20px;
    display: none;
    gap: 10px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
  }

  .nav__links.is-open {
    display: flex;
    flex-direction: column;
  }

  /* Mobile: each nav item full width so sub-menus stack below, no overlap */
  .nav__links .nav__item {
    width: 100%;
  }

  .nav__item--has-sub {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .nav__item--has-sub > a {
    width: 100%;
    justify-content: space-between;
    padding: 12px 16px;
    border-radius: var(--radius-sm);
  }

  /* Accordion: sub-menus hidden by default, shown when parent has --open */
  .nav__item--has-sub .nav__sub {
    position: static;
    display: none;
    flex-direction: column;
    gap: 4px;
    width: 100%;
    margin-top: 6px;
    margin-left: 0;
    background: rgba(0, 0, 0, 0.04);
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: var(--radius-md);
    padding: 10px 12px;
    box-shadow: none;
  }

  .nav__item--has-sub.nav__item--open .nav__sub {
    display: flex;
  }

  .nav__item--has-sub.nav__item--open > a::after {
    transform: rotate(225deg);
  }

  .nav__sub a {
    padding: 10px 14px;
    font-size: 15px !important;
    white-space: normal;
    color: #111827;
  }

  .nav__toggle {
    display: flex;
  }

  .hero,
  .platform,
  .cta,
  .card--inline,
  .band,
  main {
    grid-template-columns: 1fr;
    max-width: 100%;
  }

  .page--home .hero.hero--bp {
    padding-top: 8px;
  }

  main {
    padding: 24px 14px 100px;
    padding-top: 88px;
  }

  .cta__content {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
    text-align: left;
  }

  .cta__text {
    width: 100%;
  }

  .cta__text p {
    max-width: 100%;
  }

  .btn--cta {
    width: 100%;
    justify-content: center;
  }

  .cta__actions .btn {
    width: 100%;
    min-width: 320px;
    justify-content: center;
  }

  .hero__actions {
    flex-direction: column;
  }

  .hero__actions .btn {
    width: 100%;
    min-width: 320px;
  }
}

/* Nav bar on small mobile - tall enough for larger logo */
@media (max-width: 768px) {
  .nav {
    height: auto;
    min-height: 72px;
    align-items: center;
  }

  main {
    padding-top: 72px;
  }

  .nav__container {
    gap: 6px;
    padding-left: 18px;
    padding-right: 10px;
    align-items: center;
  }

  .nav__logo {
    margin-left: -10px;
    align-self: center;
  }

  .nav__logo img {
    max-height: 56px !important;
  }

  .nav__toggle {
    margin-right: 16px;
    padding: 10px;
  }

  .nav__toggle span {
    width: 26px;
    height: 3px;
  }

  .btn--header {
    padding: 8px 14px;
    font-size: 13px;
  }

  .nav__links {
    top: 72px;
  }
}

/* Business Platform Section Redesign */
.business-platform {
  padding: 120px 0;
  background: #ffffff;
  color: #111827;
  overflow: visible;
  position: relative;
}

/* Applications section styling */
#applications.business-platform {
  display: flex;
  align-items: center;
  min-height: auto; /* Will be set by JS or content */
}

.use-cases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px; /* add breathing room between the three cards */
  margin-top: 60px;
}


.use-case-card {
  background: rgba(62, 49, 168, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.03);
  border-radius: 35px;
  padding: 42px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  text-decoration: none;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 100%;
  box-shadow: none;
  width: 100%;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  gap: 21px;
}

.use-case-card::before {
  display: none;
}

.use-case-card > * {
  position: relative;
  z-index: 1;
}

.use-case-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.08);
  border-color: rgba(0, 0, 0, 0.03);
}

.use-case-card__visual {
  width: 100%;
  height: 211px;
  background: rgba(0, 0, 0, 0.05);
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  margin-bottom: 0;
}

.use-case-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 18px;
}

.use-case-card__content {
  padding: 0 !important;
  background: transparent !important;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  min-height: auto !important;
  gap: 14px;
}

.use-case-card__content h3 {
  color: #111827 !important;
  font-size: 26px !important;
  font-weight: 600 !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}

.use-case-card__content p {
  color: #4B5563 !important;
  font-size: clamp(17px, 2vw, 22px) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

.use-case-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #3E31A8 !important;
  font-weight: 600;
  font-size: clamp(17px, 2vw, 22px);
  text-decoration: none;
  margin-top: auto;
  transition: gap 0.2s ease;
}

.use-case-card__link svg {
  transition: transform 0.2s ease;
}

.use-case-card__link:hover {
  gap: 12px;
}

.use-case-card__link:hover svg {
  transform: translateX(4px);
}


@media (max-width: 1024px) {
  .use-cases-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .use-cases-grid {
    grid-template-columns: 1fr;
  }
}

.business-platform__container {
  max-width: 1680px;
  margin: 0 auto;
  padding: 0 40px;
  position: relative;
  z-index: 2;
}

.business-platform__header {
  text-align: center;
  margin-bottom: 56px;
}

.business-platform__header h2 {
  text-align: center;
  color: #1F2937;
  font-size: clamp(30px, 3.7vw, 46px);
  font-weight: 500;
  margin: 8px auto 24px;
  max-width: 1600px;
  padding: 0 40px;
  line-height: 1.3;
}

/* Use Cases subtitle: match “Implementing a Digital Product Passport…” typography */
.business-platform__header .use-cases__subtitle {
  font-size: clamp(16px, 1.94vw, 23px);
  line-height: 1.5;
  font-weight: 400;
  color: #4B5563;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;
}

.business-platform__subtitle {
  font-size: 24px;
  color: rgba(255, 255, 255, 0.8);
  max-width: 800px;
  margin: 0 auto;
  font-weight: 500;
  line-height: 1.2;
}

.business-platform__content {
  display: flex;
  align-items: center; /* Vertically center columns relative to laptop */
  justify-content: center;
  gap: 55px;
  margin-bottom: 80px;
}

.business-platform__side {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 30px; /* Balanced gap between boxes */
  max-width: 450px;
  min-width: 380px;
}

.business-platform__side--left {
  align-items: flex-end;
}

.business-platform__side--right {
  align-items: flex-start;
}

.business-platform__visual {
  flex: 0 0 700px; /* Fixed width to prevent shrinking */
  min-width: 700px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: visible !important;
}

.business-platform__visual-inner {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  overflow: visible !important;
}

.business-platform__glow {
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 70%;
  background: radial-gradient(ellipse at center, rgba(62, 49, 168, 0.7) 0%, rgba(62, 49, 168, 0.2) 50%, transparent 80%);
  filter: blur(50px);
  z-index: 2;
  pointer-events: none;
}

.business-platform__visual::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 150%;
  height: 150%;
  background-image: url('./wovlabs_dump/images/background-laptop-Photoroom.png');
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 1;
  pointer-events: none;
  -webkit-mask-image: radial-gradient(circle, black 30%, transparent 70%);
  mask-image: radial-gradient(circle, black 30%, transparent 70%);
  filter: brightness(1.4);
}

.business-platform__laptop {
  width: 100%;
  max-width: 1122px;
  min-width: 700px;
  height: auto;
  position: relative;
  z-index: 3;
  display: block;
  filter: drop-shadow(0 0 20px rgba(62, 49, 168, 0.5)) drop-shadow(0 0 50px rgba(62, 49, 168, 0.3));
  transform: scale(1.155); /* Increase laptop size by 15.5% (5% increase from previous 1.1) */
}

.business-feature {
  background: #081021;
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 32px;
  padding: 50px 40px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  text-decoration: none;
  transition: all 0.3s ease;
  width: 440px; /* Force same width as Smart Tagging */
  height: 320px; /* Force same height as Smart Tagging */
  flex-shrink: 0;
  box-shadow: 0 20px 80px rgba(0, 0, 0, 0.15);
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  z-index: 4;
}

.business-feature::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at 20% 20%, rgba(62, 49, 168, 0.07), transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.business-feature:hover {
  background: #0a152d;
  transform: translateY(-8px);
  box-shadow: 0 30px 100px rgba(0, 0, 0, 0.2);
}

.business-feature__icon {
  width: 86px;
  height: 86px;
  background: #0f1d35;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 45px;
  box-shadow: 
    0 10px 30px rgba(0, 0, 0, 0.45),
    inset 0 0 15px rgba(255, 255, 255, 0.05);
  transition: all 0.3s ease;
  position: relative;
  z-index: 1;
  overflow: visible;
  flex-shrink: 0;
}

.business-feature__icon::after {
  content: '';
  position: absolute;
  inset: -15px;
  background: radial-gradient(circle at center, rgba(62, 49, 168, 0.3) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  filter: blur(10px);
  opacity: 0.8;
}

.business-feature:hover .business-feature__icon {
  transform: scale(1.05) translateY(-2px);
  background: #152749;
  border-color: rgba(62, 49, 168, 0.4);
}

.business-feature__icon img {
  width: 38px;
  height: 38px;
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(78%) sepia(100%) saturate(1352%) hue-rotate(142deg) brightness(105%) contrast(105%);
  position: relative;
  z-index: 1;
}

.business-feature__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  width: 100%;
  position: relative;
  z-index: 1;
}

.business-feature h3 {
  font-size: 30px !important;
  font-weight: 700 !important;
  margin: 0 0 18px !important;
  color: #fff !important;
  text-align: left !important;
  line-height: 1.2 !important;
}

.business-feature p {
  font-size: clamp(17px, 2vw, 22px) !important;
  color: rgba(255, 255, 255, 0.65) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  text-align: left !important;
}

.business-platform__footer {
  text-align: center;
  margin-top: 60px;
}

.business-platform__footer .btn {
  background-color: #669DF6;
  color: #111827;
  padding: 18px 45px;
  font-size: 20px;
  border-radius: 12px;
  font-weight: 600;
  transition: all 0.3s ease;
}

.business-platform__footer .btn:hover {
  background-color: #5595F5;
  transform: translateY(-2px);
  box-shadow: 0 10px 25px rgba(62, 49, 168, 0.4);
}

/* SaaS Solutions Section */
#solutions-2 {
  padding: 20px 0 60px;
  background: #f5f6f8 !important;
  width: 100%;
  margin-bottom: -60px;
  position: relative;
  z-index: 1;
  isolation: isolate;
}

#solutions-2::before {
  display: none;
}

/* How It Works cards (match reference layout) */
#digital-twin .how-steps {
  max-width: 1600px;
  margin: 0 auto;
  padding: 0 4.5%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 64px;
  position: relative;
}

#digital-twin .how-steps::before {
  content: '';
  position: absolute;
  /* Slightly extended beyond the container */
  left: -5%;
  right: -5%;
  /* position it behind the center of the cards */
  top: 34%;
  transform: translateY(-50%);
  border-top: 5px dashed rgba(148, 163, 184, 0.6); /* light grey */
  z-index: 0;
  pointer-events: none;
  /* fade the line into the background at both ends */
  -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
  mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}

#digital-twin .how-card {
  background: #ffffff;
  border: 1px solid #e6edf5;
  border-radius: 22px;
  padding: 32px 44px 34px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 1;
}

#digital-twin .how-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

#digital-twin .how-step-label {
  display: flex;
  align-items: center;
  gap: 16px;
  color: #6B7280;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 11px;
  margin-bottom: -10px;
}

#digital-twin .how-icon-wrap {
  display: flex;
  justify-content: center;
  padding: 26px 0 18px;
}

#digital-twin .how-icon {
  position: relative;
  width: 128px;
  height: 128px;
  display: grid;
  place-items: center;
}

#digital-twin .how-icon svg {
  width: 112px;
  height: 112px;
}

#digital-twin .how-icon-badge {
  position: absolute;
  right: 12px;
  bottom: 10px;
  width: 14px;
  height: 14px;
  background: #7FD9A8;
  border-radius: 999px;
  border: 2px solid #ffffff;
  box-shadow: 0 10px 22px rgba(127, 217, 168, 0.35);
}

#digital-twin .how-card-title {
  margin: 0 auto 10px;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: #111827;
  text-align: center;
  line-height: 1.3;
  /* keep titles aligned even if some wrap to 2 lines */
  min-height: 82px;
}

#digital-twin .how-card-desc {
  margin: 0;
  font-size: clamp(17px, 2vw, 22px);
  line-height: 1.7;
  color: #6b7280;
  text-align: center;
  /* fill vertical space so dividers + system lines align across cards */
  flex: 1;
}

#digital-twin .how-card-divider {
  border: none;
  height: 1px;
  background: #e6edf5;
  margin: 30px 0 18px;
}

#digital-twin .how-card-system {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: #6b7280;
  text-align: center;
  /* align system lines across cards by giving them a consistent height */
  min-height: 52px;
}

#digital-twin .how-card-system strong {
  font-weight: 600;
  color: #1F2937;
}

@media (max-width: 1024px) {
  #digital-twin .how-steps::before {
    display: none;
  }
  #digital-twin .how-steps {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  #digital-twin .how-card {
    padding: 26px 22px 20px;
  }
}

.solutions-2__header {
  text-align: center;
  max-width: var(--max-width);
  margin: 40px auto 60px;
  padding: 0 2.5%;
}

.solutions-2__title {
  text-align: center;
  color: #1F2937;
  font-size: clamp(28px, 3.5vw, 42px);
  font-weight: 700;
  margin: 0 0 16px;
  padding: 0;
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.solutions-2__subtitle {
  text-align: center;
  color: #4B5563;
  font-size: clamp(17px, 2vw, 22px);
  font-weight: 400;
  margin: 0;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
}

.cards--saas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 60px;
  margin: 0 auto;
  width: 100%;
  max-width: var(--max-width);
  padding: 0 2.5%;
  box-sizing: border-box;
}

.card--saas {
  background: rgba(62, 49, 168, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.03);
  border-radius: 35px;
  padding: 56px 42px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  text-decoration: none;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 100%;
  box-shadow: none;
  width: 100%;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  gap: 21px;
}

.card--saas::before {
  display: none;
}

.card--saas:hover {
  transform: translateY(-8px);
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.08);
}

.card--saas__icon {
  width: 70px;
  height: 70px;
  background: rgba(62, 49, 168, 0.15);
  border: none;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 4px;
  box-shadow: none;
  transition: all 0.3s ease;
  position: relative;
  z-index: 1;
  overflow: visible;
}

.card--saas__icon::after {
  display: none;
}

.card--saas:hover .card--saas__icon {
  transform: none;
}

.card--saas__icon svg {
  width: 35px;
  height: 35px;
  color: #3E31A8;
  position: relative;
  z-index: 1;
  filter: none;
  stroke-width: 2;
}

.card--saas .card--saas__title {
  color: #111827 !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  margin: 0 !important;
  line-height: 1.2 !important;
  position: relative;
  z-index: 1;
}

.card--saas__desc {
  color: #4B5563 !important;
  font-size: clamp(17px, 2vw, 22px) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  position: relative;
  z-index: 1;
}

/* Color Variations */
.card--saas--cyan {
  background-color: #E3EEFF;
}
.card--saas--cyan .card--saas__icon {
  background-color: rgba(130, 182, 243, 0.2);
  color: #82B6F3;
}
.card--saas--cyan .card--saas__icon svg {
  color: #82B6F3;
}

.card--saas--indigo {
  background-color: #E0F4FA;
}
.card--saas--indigo .card--saas__icon {
  background-color: rgba(140, 202, 240, 0.2);
  color: #8CCAF0;
}
.card--saas--indigo .card--saas__icon svg {
  color: #8CCAF0;
}

.card--saas--blue {
  background-color: #E3F8F0;
}
.card--saas--blue .card--saas__icon {
  background-color: rgba(143, 219, 226, 0.2);
  color: #8FDBE2;
}
.card--saas--blue .card--saas__icon svg {
  color: #8FDBE2;
}

@media (max-width: 992px) {
  .cards--saas {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .cards--saas {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .card--saas {
    padding: 28px;
  }
}

/* DPP Intro Section */
.dpp-intro {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 4.5%;
  box-sizing: border-box;
}

.dpp-intro__title {
  text-align: center;
  color: #1F2937;
  font-size: clamp(36px, 4.5vw, 56px);
  font-weight: 700;
  margin: 0 0 24px;
  line-height: 1.2;
}

.dpp-intro__description {
  text-align: center;
  color: #1F2937;
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.6;
  margin: 0 auto 80px;
  max-width: 800px;
}

.dpp-intro__content {
  display: grid;
  grid-template-columns: 1fr 1.5fr 1fr;
  gap: 60px;
  align-items: center;
  margin-top: 60px;
}

.dpp-intro__left,
.dpp-intro__right {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.dpp-intro__section-title {
  color: #1F2937;
  font-size: clamp(20px, 2.2vw, 28px);
  font-weight: 700;
  margin: 0;
  line-height: 1.2;
}

.dpp-intro__section-text {
  color: #1F2937;
  font-size: clamp(16px, 1.8vw, 20px);
  line-height: 1.6;
  margin: 0;
}

.dpp-intro__features {
  list-style: none;
  padding: 0;
  margin: 32px 0 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.dpp-intro__feature {
  color: #1F2937;
  font-size: clamp(15px, 1.6vw, 18px);
  line-height: 1.6;
  padding-left: 24px;
  position: relative;
}

.dpp-intro__feature::before {
  content: '';
  width: 20px;
  height: 20px;
  position: absolute;
  left: 0;
  top: 2px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M20 6L9 17l-5-5' stroke='%2300E5FF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.dpp-intro__center {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
}

.dpp-intro__visual {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dpp-intro__phone {
  position: relative;
  width: 200px;
  height: 360px;
  background: #1a1a1a;
  border-radius: 24px;
  padding: 12px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  z-index: 2;
}

.dpp-intro__phone-screen {
  width: 100%;
  height: 100%;
  background: #ffffff;
  border-radius: 16px;
  padding: 24px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.dpp-intro__phone-logo {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #3E31A8;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  font-size: 32px;
  font-weight: 700;
  margin-top: 20px;
}

.dpp-intro__phone-label {
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 600;
  color: #1F2937;
  text-align: center;
}

.dpp-intro__phone-data {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}

.dpp-intro__data-row {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: #1F2937;
}

.dpp-intro__data-row span:first-child {
  font-weight: 600;
}

.dpp-intro__qr-code {
  width: 80px;
  height: 80px;
  background: repeating-linear-gradient(
    0deg,
    #000 0px,
    #000 4px,
    #fff 4px,
    #fff 8px
  ),
  repeating-linear-gradient(
    90deg,
    #000 0px,
    #000 4px,
    #fff 4px,
    #fff 8px
  );
  border: 2px solid #000;
  margin-top: auto;
  margin-bottom: 20px;
}


@media (max-width: 1024px) {
  .dpp-intro__content {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  
  .dpp-intro__center {
    order: 2;
    min-height: 300px;
  }
  
  .dpp-intro__left {
    order: 1;
  }
  
  .dpp-intro__right {
    order: 3;
  }
}

/* Benefit Cards (Light Crayon Style) */
.benefit-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 60px;
  margin: 0 auto;
  width: 100%;
  max-width: 1680px; /* Reduced by 20% from 2100px */
}

/* Allow page-content in Brand Protection to expand for wider cards */
.page--bp .band--no-frame .page-content {
  max-width: 1680px !important;
}

.benefit-card {
  padding: 64px 48px;
  border-radius: 40px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  text-align: left;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  border: 1px solid rgba(0, 0, 0, 0.03);
  height: 100%;
}

.benefit-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.08);
}

.benefit-card__icon-box {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 4px;
}

.benefit-card__icon-box svg {
  width: 40px;
  height: 40px;
}

.benefit-card h3 {
  font-size: 30px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}

.benefit-card p {
  font-size: clamp(17px, 2vw, 22px) !important;
  line-height: 1.6 !important;
  color: #4B5563 !important;
  margin: 0 !important;
}

/* Color Variations */
.benefit-card--cyan {
  background-color: #E3EEFF;
}
.benefit-card--cyan .benefit-card__icon-box {
  background-color: rgba(130, 182, 243, 0.2);
  color: #82B6F3;
}

.benefit-card--indigo {
  background-color: #E0F4FA;
}
.benefit-card--indigo .benefit-card__icon-box {
  background-color: rgba(140, 202, 240, 0.2);
  color: #8CCAF0;
}

.benefit-card--blue {
  background-color: #E3F8F0;
}
.benefit-card--blue .benefit-card__icon-box {
  background-color: rgba(143, 219, 226, 0.2);
  color: #8FDBE2;
}

@media (max-width: 992px) {
  .benefit-cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .benefit-cards-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .benefit-card {
    padding: 32px;
  }
  /* Disable hover lift/shadow on mobile – no dynamic interaction on touch */
  .benefit-card:hover {
    transform: none;
    box-shadow: none;
  }
}

/* Global Accent Eyebrow Consistency */
.accent-eyebrow {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}

.accent-eyebrow--center {
  justify-content: center;
}

.accent-eyebrow__bar {
  display: inline-block;
  width: 2px;
  height: 1.1em;
  background: #7FD9A8;
  border-radius: 2px;
  flex-shrink: 0;
}

.accent-eyebrow__text {
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  line-height: 1;
}

/* CTA Card Components (Shared) */
.home-cta-section {
  padding: 120px 0 10px 0;
  margin-bottom: 64px;
  background-color: #f5f6f8;
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  display: block;
}

.home-cta-card {
  max-width: 1200px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid #e6edf5;
  border-radius: 24px;
  padding: 60px;
  display: flex;
  flex-direction: column;
  text-align: center;
  justify-content: center;
  align-items: center;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
  position: relative;
  z-index: 2;
  gap: 32px;
  left: auto;
  transform: none;
}

.home-cta-card__text {
  max-width: 800px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.home-cta-card__title {
  font-size: clamp(30px, 3.7vw, 46px);
  font-weight: 500;
  color: #1F2937;
  margin: 8px 0 12px;
  line-height: 1.3;
}

.home-cta-card__description {
  font-size: clamp(16px, 1.94vw, 23px);
  color: #4B5563;
  max-width: 1100px;
  margin: 0 auto;
  line-height: 1.5;
}

.home-cta-card__actions {
  display: flex;
  gap: 16px;
  flex-shrink: 0;
  justify-content: center;
}

.btn--primary-cyan {
  background: #669DF6;
  color: #ffffff;
  padding: 14px 32px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 18px;
  transition: all 0.3s ease;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 14px 30px rgba(102, 157, 246, 0.3);
}

.btn--primary-cyan:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 35px rgba(102, 157, 246, 0.4);
  background: #5595F5;
}

.btn--primary-cyan:active {
  background: #458DF4;
}

.btn--outline {
  background: transparent;
  color: #1F2937;
  border: 1px solid #2F3A4A;
  padding: 14px 32px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 18px;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn--outline:hover {
  border-color: #669DF6;
  color: #669DF6;
  background: rgba(102, 157, 246, 0.05);
  transform: translateY(-1px);
}

.btn--outline:active {
  border-color: #458DF4;
  color: #458DF4;
}

/* Footer mockup override */
/* Remove old footer overrides - using new structure */

.footer__top, .footer__grid {
  padding-left: 0 !important;
  box-sizing: border-box !important;
}

.footer__top {
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px !important;
}

.footer__brand {
  gap: 6px !important;
}

.footer__logo {
  display: inline-block !important;
  text-decoration: none !important;
}

.footer__logo img {
  display: block !important;
  height: 252px !important;
  width: auto !important;
  max-width: 1260px !important;
  max-height: 252px !important;
  object-fit: contain !important;
}

.footer__payoff {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #374151 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  opacity: 0.9 !important;
}

.footer__grid {
  grid-template-columns: 1fr 1fr 1fr 2fr !important;
  gap: 40px !important;
  justify-items: start !important;
  text-align: left !important;
  width: 100% !important;
}

.footer__card {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  gap: 12px !important;
  box-shadow: none !important;
  align-items: flex-start !important;
}

.footer__card-title {
  font-size: clamp(18px, 2.2vw, 24px) !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  color: #111827 !important;
}

.footer__card a {
  color: #1f2937 !important;
  font-size: clamp(17px, 2vw, 22px) !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  text-decoration: none !important;
  opacity: 0.9 !important;
}

.footer__card a:hover {
  /* Hover effects disabled */
}

.footer__card--cta {
  grid-column: span 1 !important;
  width: 100% !important;
  min-width: 0 !important;
  align-items: center !important;
  gap: 32px !important;
}
.footer__card--cta .footer__launch,
.footer__card--cta .footer__social {
  align-self: center !important;
}

.footer__launch {
  display: none !important; /* Hidden temporarily */
  padding: 16px 48px !important;
  border-radius: 100px !important;
  font-size: 19px !important;
  text-decoration: none !important;
  box-shadow: 0 0 20px rgba(62, 49, 168, 0.4) !important;
}

.footer__launch:hover {
  /* Hover effects disabled */
}

.footer__social {
  gap: 20px !important;
}

.footer__social a {
  border-radius: 50% !important;
  border: 1px solid rgba(0, 0, 0, 0.15) !important;
  background: rgba(255, 255, 255, 0.35) !important;
  color: #1f2937 !important;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08) !important;
}

.footer__social a:hover {
  /* Hover effects disabled */
}

.footer__social a svg {
  width: 24px !important;
  height: 24px !important;
}

.footer__social a:first-child svg,
.footer__social a:nth-child(2) svg {
  fill: #1f2937 !important;
  stroke: none !important;
}

.footer__social a:last-child svg {
  stroke: #1f2937 !important;
}

.footer__bottom {
  border-top: 2px solid #cbd5e1;
  padding-top: 24px;
  margin-top: 0;
  font-size: 15px;
  color: #64748b;
}

.footer__bottom .footer__bottom-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.footer__bottom .footer__bottom-links {
  display: inline-flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
}

.footer__bottom-right {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
}

.footer__back-to-top {
  background: rgba(255, 255, 255, 0.6) !important;
  color: #1f2937 !important;
  text-decoration: none !important;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08) !important;
}

.footer__back-to-top:hover {
  /* Hover effects disabled */
}

.footer__star {
  color: #1f2937 !important;
  opacity: 0.8 !important;
}

@media (max-width: 1024px) {
  .footer__grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 40px !important;
  }
  .footer__card--cta {
    grid-column: span 2 !important;
    align-items: center !important;
  }

  /* Stack the bottom row but keep it LEFT-aligned with the CTA content */
  .footer__bottom .footer__bottom-row {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    justify-items: start !important;
  }

  .footer__bottom .footer__bottom-row > p {
    grid-column: 1 / -1 !important;
    justify-self: start !important;
    text-align: left !important;
  }

  .footer__bottom .footer__bottom-links {
    grid-column: 1 / -1 !important;
    justify-self: start !important;
    justify-content: flex-start !important;
  }
}

@media (max-width: 768px) {
  .footer-inner {
    padding-block: 32px;
    gap: 32px;
  }
  .footer__logo img {
    height: auto !important;
    max-height: 200px !important;
    max-width: 100% !important;
  }
  .footer__grid {
    grid-template-columns: 1fr !important;
    text-align: left !important;
  }
  .footer__card {
    align-items: flex-start !important;
  }
  .footer__card--cta {
    grid-column: span 1 !important;
    align-items: flex-start !important;
  }
  .footer__bottom {
    flex-direction: column !important;
    gap: 24px !important;
    text-align: left !important;
  }

  .footer__bottom .footer__bottom-row {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    justify-items: start !important;
  }

  .footer__bottom .footer__bottom-row > p {
    grid-column: 1 / -1 !important;
  }

  .footer__bottom .footer__bottom-links {
    grid-column: 1 / -1 !important;
    justify-self: start !important;
    justify-content: flex-start !important;
  }
}

@media (max-width: 968px) {
  .home-cta-card {
    flex-direction: column;
    text-align: center;
    padding: 40px;
    gap: 32px;
  }
  .home-cta-card__text {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .home-cta-card__actions {
    width: 100%;
    flex-direction: column;
  }
  .btn--primary-cyan, .btn--outline {
    width: 100%;
  }
}

/* --- Alignment Source of Truth (Matched to Footer) --- */
.page-container {
  width: 100% !important;
  max-width: 1680px !important;
  margin: 0 auto !important;
  padding-left: 40px !important;
  padding-right: 40px !important;
  box-sizing: border-box !important;
}

/* Reset hero and body parts so they don't fight the container */
.page--legal .hero {
  display: block !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

.page--legal .hero__content {
  padding-left: 0 !important;
  margin: 0 !important;
  max-width: none !important;
  width: 100% !important;
}

.page--legal .hero__lead {
  max-width: none !important;
  width: 100% !important;
}

.page--legal #platform2.platform-section {
  display: block !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  background: #ffffff !important;
}

.page--legal .legal-body-content {
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
}

.page--legal .legal-body-title {
  font-size: 30px !important;
  font-weight: 700 !important;
  color: #2F3A4A !important;
  margin: 0 0 32px 0 !important;
  line-height: 1.2 !important;
  text-align: left !important;
}

.page--legal .legal-body-text {
  font-size: clamp(17px, 2vw, 22px) !important;
  color: #4a4a4a !important;
  margin: 0 !important;
  line-height: 1.6 !important;
  text-align: left !important;
  width: 100% !important;
}

/* Force match to solution card description text */
.page--legal .legal-body-content .legal-body-text,
.page--legal #platform2 .legal-body-text,
.page--legal .legal-body-text {
  font-size: clamp(17px, 2vw, 22px) !important;
  color: #4B5563 !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  text-align: left !important;
  width: 100% !important;
  position: relative !important;
  z-index: 1 !important;
}

/* ========== HOMEPAGE MOBILE OPTIMIZATION ========== */
@media (max-width: 768px) {
  body.page--home {
    overflow-x: hidden;
  }

  .page--home main {
    padding: 16px 16px 32px;
    padding-top: 72px;
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
    padding-bottom: max(32px, env(safe-area-inset-bottom));
  }

  /* Hero intro on mobile: headline → subheadline → image → Book a Demo button */
  .page--home .hero.hero--bp {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-auto-rows: auto;
    padding: 6px 0 40px;
    min-height: auto;
    gap: 28px;
    align-items: stretch;
  }

  .page--home .hero__content {
    display: contents;
  }

  .page--home .hero__content > * {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box;
    text-align: center;
  }

  .page--home .hero__brand {
    order: 1;
  }

  .page--home .hero__lead {
    order: 2;
  }

  .page--home .hero__visual {
    order: 3;
    padding: 0 !important;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
  }

  .page--home .hero__actions {
    order: 4;
  }

  .page--home .hero__brand {
    font-size: clamp(26px, 6.5vw, 34px) !important;
    line-height: 1.25 !important;
    margin: 0 0 12px !important;
    text-align: center;
  }

  .page--home .hero__lead {
    font-size: 15px !important;
    line-height: 1.55 !important;
    margin: 0 0 20px !important;
    max-width: 100% !important;
    text-align: center;
  }

  .page--home .hero__actions {
    width: 100%;
    max-width: 280px;
    margin-top: 4px;
    justify-content: center;
  }

  .page--home .hero__actions .btn {
    width: 100%;
    min-width: 0;
    min-height: 48px;
    padding: 14px 24px;
    font-size: 16px;
  }

  .page--home .hero__visual {
    width: 100vw !important;
    max-width: 100vw !important;
    padding: 0 !important;
    justify-content: center !important;
    background: transparent !important;
    box-sizing: border-box;
    border-radius: 0 !important;
    overflow: hidden;
  }

  .page--home .hero__image,
  .page--home .hero__image--main {
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    transform: none !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
    object-fit: contain;
    object-position: center center;
    border-radius: 0 !important;
  }

  /* Solutions section */
  .page--home #solutions-2 {
    padding: 24px 16px 48px;
    margin-bottom: -40px;
  }

  .page--home #solutions-2 .solutions-2__header {
    margin-bottom: 40px;
    padding: 0 8px;
  }
  .page--home #solutions-2 .solutions-2__title {
    font-size: clamp(22px, 5.5vw, 28px);
    font-weight: 700;
    margin: 0 0 12px;
  }
  .page--home #solutions-2 .solutions-2__subtitle {
    font-size: clamp(15px, 3.8vw, 18px);
  }

  .page--home .cards--saas {
    padding: 0 4%;
    gap: 16px;
  }

  .page--home .card--saas {
    padding: 24px 20px;
    border-radius: 24px;
  }

  .page--home .card--saas__icon {
    width: 56px;
    height: 56px;
  }

  .page--home .card--saas__icon svg {
    width: 28px;
    height: 28px;
  }

  .page--home .card--saas .card--saas__title {
    font-size: 20px !important;
  }

  .page--home .card--saas__desc {
    font-size: 15px !important;
  }

  /* Platform sections (Foundation, Why it matters) – full width, no side margin */
  .page--home .platform-section {
    padding: 48px 0 40px !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  .page--home #platform2 .dpp-content,
  .page--home #compliance .dpp-content {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto;
    margin-top: 24px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 20px;
    gap: 32px;
    width: 100%;
    max-width: 540px;
    box-sizing: border-box;
  }

  /* Foundation: image on top, then text + bullets */
  .page--home #platform2 .dpp-content-left {
    order: 2;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }

  .page--home #platform2 .dpp-content-right {
    order: 1;
    height: auto !important;
    min-height: 0 !important;
    width: 100% !important;
    padding: 0 !important;
    overflow: visible !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  .page--home #platform2 .dpp-content-right img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    border-radius: 16px;
  }

  /* Compliance: image on top, then text + bullets */
  .page--home #compliance .dpp-content-left {
    order: 1;
    width: 100% !important;
    margin-top: 0 !important;
    padding: 0 !important;
  }

  .page--home #compliance .dpp-content-right {
    order: 2;
    height: auto !important;
    min-height: 0 !important;
    width: 100% !important;
    padding: 0 !important;
  }

  .page--home #compliance .dpp-content-left img {
    width: 100% !important;
    max-width: 280px !important;
    margin: 0 auto;
    display: block;
    border-radius: 16px;
  }

  /* Why it matters (#compliance) – reduce empty space at bottom */
  .page--home #compliance.platform-section {
    padding-bottom: 32px !important;
  }

  .page--home .dpp-content-title {
    font-size: clamp(22px, 5.5vw, 28px) !important;
    margin: 8px 0 20px !important;
    text-align: left;
  }

  .page--home .dpp-content-subtitle {
    font-size: 15px !important;
    margin: 0 0 24px !important;
    text-align: left;
  }

  /* Bullet list: allow text to wrap (fix truncation) */
  .page--home .homepage-bullets {
    width: 100%;
    min-width: 0;
  }

  .page--home .homepage-bullet {
    gap: 12px;
    align-items: flex-start;
    min-width: 0;
  }

  .page--home .homepage-bullet__icon {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
  }

  .page--home .homepage-bullet__icon svg {
    width: 14px;
    height: 14px;
  }

  .page--home .homepage-bullet__text {
    font-size: 15px !important;
    min-width: 0;
    flex: 1;
    overflow-wrap: break-word;
    word-wrap: break-word;
    word-break: normal;
  }

  /* How it works (#digital-twin) – no negative margin; minimal bottom gap */
  .page--home #digital-twin.platform-section {
    padding: 48px 0 40px !important;
    margin-top: 0 !important;
  }

  .page--home #digital-twin > div:first-child {
    padding: 0 4% 32px;
    margin-bottom: 24px;
  }

  .page--home #digital-twin h2 {
    font-size: clamp(22px, 5.5vw, 28px) !important;
    margin: 8px 0 12px !important;
  }

  .page--home #digital-twin > div:first-child p {
    font-size: 15px !important;
  }

  .page--home #digital-twin .how-steps {
    padding: 0 4%;
    gap: 20px;
  }

  .page--home #digital-twin .how-card {
    padding: 22px 20px 24px;
    border-radius: 18px;
  }

  .page--home #digital-twin .how-icon {
    width: 88px;
    height: 88px;
  }

  .page--home #digital-twin .how-icon svg {
    width: 72px;
    height: 72px;
  }

  .page--home #digital-twin .how-card-title {
    font-size: 20px !important;
    min-height: auto;
  }

  .page--home #digital-twin .how-card-desc {
    font-size: 15px !important;
  }

  /* Use cases (green) – sit below purple section, no negative margin */
  .page--home main > .business-platform,
  .page--home .business-platform {
    margin-top: 0 !important;
    padding: 48px 0 56px;
  }

  .page--home .business-platform__container {
    padding: 0 4%;
  }

  .page--home .business-platform__header h2 {
    font-size: clamp(24px, 6vw, 30px) !important;
  }

  .page--home .use-cases__subtitle {
    font-size: 15px;
  }

  .page--home .use-cases-grid {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-top: 32px;
  }

  .page--home .use-case-card {
    padding: 24px 20px;
    border-radius: 24px;
  }

  .page--home .use-case-card__visual {
    height: 180px;
  }

  .page--home .use-case-card__content h3 {
    font-size: 20px !important;
  }

  .page--home .use-case-card__content p {
    font-size: 15px !important;
  }

  .page--home .use-case-card__link {
    min-height: 44px;
    align-items: center;
  }

  /* News / Resources band */
  .page--home #resources.band {
    padding: 48px 0 40px;
  }

  .page--home #resources .band__header h2 {
    font-size: clamp(22px, 5.5vw, 28px);
  }

  .page--home #resources .grid.cards--news {
    padding: 0 4%;
    gap: 20px;
  }

  /* Trusted by */
  .page--home #trusted.band {
    padding: 32px 0 48px;
  }

  .page--home .trusted__container {
    padding: 0 8px;
  }

  /* Home CTA */
  .page--home .home-cta-section {
    padding: 48px 16px 32px;
    margin-bottom: 24px;
  }

  .page--home .home-cta-card {
    padding: 32px 20px;
    border-radius: 20px;
    margin: 0 4%;
  }

  .page--home .home-cta-card__title {
    font-size: clamp(24px, 6vw, 28px);
  }

  .page--home .home-cta-card__description {
    font-size: 15px;
  }

  .page--home .home-cta-card__actions {
    flex-direction: column;
    width: 100%;
    gap: 12px;
  }

  .page--home .home-cta-card__actions .btn {
    width: 100%;
    min-height: 48px;
    justify-content: center;
    font-size: 16px;
  }

  /* Back to top - touch target */
  .page--home .back-to-top {
    bottom: max(20px, env(safe-area-inset-bottom));
    right: max(16px, env(safe-area-inset-right));
    width: 48px;
    height: 48px;
    min-width: 48px;
    min-height: 48px;
  }
}

/* Small phones */
@media (max-width: 480px) {
  .page--home .hero__brand {
    font-size: 26px !important;
  }

  .page--home #solutions-2 .solutions-2__title {
    font-size: 20px;
  }
  .page--home #solutions-2 .solutions-2__subtitle {
    font-size: 15px;
  }

  .page--home .card--saas {
    padding: 20px 16px;
  }

  .page--home .home-cta-card {
    padding: 24px 16px;
  }

  /* ========== BRAND PROTECTION, CUSTOMER ENGAGEMENT & EU COMPLIANCE MOBILE (same structure) ========== */
  /* Use overflow-x: clip to avoid iOS scroll lock (overflow-x: hidden can block scroll until reflow) */
  body.page--bp,
  body.page--brand-protection,
  body.page--eu-compliance,
  body.page--customer-engagement {
    overflow-x: clip;
  }

  .page--bp main,
  .page--brand-protection main,
  .page--eu-compliance main {
    padding: 16px 16px 32px;
    padding-top: 72px;
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
    padding-bottom: max(32px, env(safe-area-inset-bottom));
  }

  /* Platform sections: riduci spazi vuoti – meno padding verticale */
  .page--bp .platform-section,
  .page--brand-protection .platform-section,
  .page--eu-compliance .platform-section {
    padding: 16px 0 24px !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  /* Centered content containers (foundation, compliance) */
  .page--bp #foundation .dpp-content,
  .page--bp #compliance .dpp-content,
  .page--brand-protection #foundation .dpp-content,
  .page--brand-protection #compliance .dpp-content,
  .page--eu-compliance #foundation .dpp-content,
  .page--eu-compliance #compliance .dpp-content {
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 540px;
    padding: 0 20px;
    width: 100%;
    box-sizing: border-box;
  }

  /* DPP, IN PRACTICE (#foundation): stack text first (kicker, headline, paragraphs), then image; text left-aligned */
  .page--bp #foundation .dpp-content,
  .page--brand-protection #foundation .dpp-content,
  .page--eu-compliance #foundation .dpp-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px;
  }

  /* EU Compliance mobile: reduce space between image and text in foundation & compliance sections */
  body.page--eu-compliance #foundation .dpp-content,
  body.page--eu-compliance #compliance .dpp-content {
    gap: 12px !important;
    padding-top: 4px !important;
  }

  /* EU Compliance mobile: balanced margin in #compliance cyan container (overrides inline styles) */
  body.page--eu-compliance #compliance.platform-section {
    padding-top: 0 !important;
    padding-bottom: 28px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  body.page--eu-compliance #compliance .dpp-content {
    padding: 12px 14px 20px !important;
  }

  /* Slight gap between image and text (was 64px inline, then 0; now a bit in between) */
  body.page--eu-compliance #compliance .dpp-content-right {
    margin-top: 12px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Spacing inside text block (OPERATIONAL IMPACT / Reduce Risk) */
  body.page--eu-compliance #compliance .dpp-content-right .dpp-content-title,
  body.page--eu-compliance #compliance .dpp-content-subtitle {
    margin-top: 0 !important;
    margin-bottom: 20px !important;
  }

  body.page--eu-compliance #compliance .dpp-content-right > div:first-child {
    margin-bottom: 14px !important;
  }

  .page--bp #foundation .dpp-content-left,
  .page--brand-protection #foundation .dpp-content-left,
  .page--eu-compliance #foundation .dpp-content-left {
    order: 1;
    text-align: left !important;
  }

  .page--bp #foundation .dpp-content-right,
  .page--brand-protection #foundation .dpp-content-right,
  .page--eu-compliance #foundation .dpp-content-right {
    order: 2;
    height: auto !important;
    min-height: 0 !important;
  }

  .page--bp #foundation .dpp-content-title,
  .page--bp #foundation .dpp-content-subtitle,
  .page--brand-protection #foundation .dpp-content-title,
  .page--brand-protection #foundation .dpp-content-subtitle,
  .page--eu-compliance #foundation .dpp-content-title,
  .page--eu-compliance #foundation .dpp-content-subtitle {
    text-align: left !important;
  }

  /* DPP in practice (#foundation): meno spazio sopra/sotto */
  .page--bp #foundation.platform-section,
  .page--brand-protection #foundation.platform-section,
  .page--eu-compliance #foundation.platform-section {
    padding-top: 16px !important;
    padding-bottom: 12px !important;
  }

  /* #compliance (WHO IT SERVES): meno spazio vuoto */
  .page--bp #compliance.platform-section,
  .page--brand-protection #compliance.platform-section,
  .page--eu-compliance #compliance.platform-section {
    margin-top: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 32px !important;
  }

  /* WHO IT SERVES (#compliance): cyan box – padding ridotto */
  .page--bp #compliance .dpp-content,
  .page--brand-protection #compliance .dpp-content,
  .page--eu-compliance #compliance .dpp-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px;
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 8px 20px 28px !important;
    box-sizing: border-box !important;
  }

  .page--bp #compliance .dpp-content-left,
  .page--brand-protection #compliance .dpp-content-left,
  .page--eu-compliance #compliance .dpp-content-left {
    order: 2;
    margin-top: 0 !important;
  }

  .page--bp #compliance .dpp-content-right,
  .page--brand-protection #compliance .dpp-content-right,
  .page--eu-compliance #compliance .dpp-content-right {
    order: 1;
    text-align: left !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .page--bp #compliance .dpp-content-title,
  .page--bp #compliance .dpp-content-subtitle,
  .page--brand-protection #compliance .dpp-content-title,
  .page--brand-protection #compliance .dpp-content-subtitle,
  .page--eu-compliance #compliance .dpp-content-title,
  .page--eu-compliance #compliance .dpp-content-subtitle {
    text-align: left !important;
  }

  /* band--no-frame: meno spazio dopo WHO IT SERVES */
  .page--bp #compliance + .band--no-frame,
  .page--brand-protection #compliance + .band--no-frame,
  .page--eu-compliance #compliance + .band--no-frame {
    margin-top: 12px !important;
  }

  .page--bp .band--no-frame,
  .page--brand-protection .band--no-frame,
  .page--eu-compliance .band--no-frame {
    margin-top: 0 !important;
    padding-top: 24px !important;
    padding-bottom: 28px !important;
  }

  /* DPP section: keep headline and text inside the box on mobile – wrap and constrain */
  .page--bp .band--no-frame .page-content,
  .page--brand-protection .band--no-frame .page-content,
  .page--eu-compliance .band--no-frame .page-content {
    overflow-x: hidden !important;
    box-sizing: border-box !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  .page--bp .band--no-frame .page-content > div:first-child,
  .page--brand-protection .band--no-frame .page-content > div:first-child,
  .page--eu-compliance .band--no-frame .page-content > div:first-child {
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  /* Allow headline to wrap: global .band--no-frame h2 has white-space: nowrap, which was clipping the text */
  .page--bp .band--no-frame .page-content h2,
  .page--brand-protection .band--no-frame .page-content h2,
  .page--eu-compliance .band--no-frame .page-content h2 {
    white-space: normal !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-wrap: break-word !important;
    word-wrap: break-word !important;
    word-break: break-word !important;
    box-sizing: border-box !important;
    font-size: clamp(22px, 5.5vw, 28px) !important;
    line-height: 1.25 !important;
  }

  .page--bp .band--no-frame .page-content > div:first-child p,
  .page--brand-protection .band--no-frame .page-content > div:first-child p,
  .page--eu-compliance .band--no-frame .page-content > div:first-child p {
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow-wrap: break-word !important;
    word-wrap: break-word !important;
    box-sizing: border-box !important;
  }

  .page--bp .band--no-frame + .band--no-frame,
  .page--brand-protection .band--no-frame + .band--no-frame,
  .page--eu-compliance .band--no-frame + .band--no-frame {
    margin-top: 0 !important;
  }

  /* CTA section before footer – less gap */
  .page--bp .home-cta-section,
  .page--brand-protection .home-cta-section,
  .page--eu-compliance .home-cta-section {
    padding: 48px 16px 32px;
    margin-bottom: 24px;
  }

  /* Solutions pages hero: reorder on mobile – headline, subheadline, button, visual, bullets */
  .page--bp .hero.hero--bp,
  .page--brand-protection .hero.hero--bp,
  .page--eu-compliance .hero.hero--bp {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px;
    padding: 24px 20px 12px !important;
    min-height: auto !important;
    box-sizing: border-box;
  }

  .page--bp .hero__content,
  .page--brand-protection .hero__content,
  .page--eu-compliance .hero__content {
    display: contents !important;
  }

  .page--bp .hero__brand,
  .page--brand-protection .hero__brand,
  .page--eu-compliance .hero__brand {
    order: 1;
    margin-bottom: 0 !important;
  }

  .page--bp .hero__lead,
  .page--brand-protection .hero__lead,
  .page--eu-compliance .hero__lead {
    order: 2;
    margin-bottom: 0 !important;
  }

  /* EU Compliance hero: headline and subheadline centered */
  .page--eu-compliance .hero__brand,
  .page--eu-compliance .hero__lead {
    text-align: center !important;
  }

  /* Customer Engagement hero: headline and subheadline centered */
  .page--customer-engagement .hero__brand,
  .page--customer-engagement .hero__lead {
    text-align: center !important;
  }

  .page--bp .hero__actions,
  .page--brand-protection .hero__actions,
  .page--eu-compliance .hero__actions {
    order: 3;
    margin-top: 0 !important;
  }

  .page--bp .hero__visual,
  .page--brand-protection .hero__visual,
  .page--eu-compliance .hero__visual {
    order: 4;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .page--bp .hero.hero--bp,
  .page--brand-protection .hero.hero--bp,
  .page--eu-compliance .hero.hero--bp {
    overflow-x: hidden;
  }

  .page--bp .bp-hero__bullets,
  .page--brand-protection .bp-hero__bullets,
  .page--eu-compliance .bp-hero__bullets {
    order: 5;
  }

  /* Hero image square corners on mobile */
  .page--bp .hero__visual,
  .page--brand-protection .hero__visual,
  .page--eu-compliance .hero__visual {
    border-radius: 0 !important;
    overflow: hidden;
  }

  .page--bp .hero__image,
  .page--brand-protection .hero__image,
  .page--eu-compliance .hero__image {
    border-radius: 0 !important;
  }

  /* EU Compliance & Customer Engagement mobile: center hero image */
  body.page--eu-compliance .hero__visual,
  body.page--customer-engagement .hero__visual {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  body.page--eu-compliance .hero__image {
    transform: scale(0.88) !important;
    width: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
    object-position: 58% 50% !important; /* center image content in frame (nudge right if asset has left padding) */
  }

  body.page--customer-engagement .hero__image {
    transform: scale(0.88) !important;
    width: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
    object-position: 58% 50% !important;
  }

  /* EU Compliance mobile: center section images (Compliance/Care, mockups) – same as hero */
  body.page--eu-compliance #foundation .dpp-content-right,
  body.page--eu-compliance #compliance .dpp-content-left {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  body.page--eu-compliance #foundation .dpp-content-right img,
  body.page--eu-compliance #compliance .dpp-content-left img {
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    object-fit: contain !important;
    object-position: 58% 50% !important; /* center image content in frame (nudge right if asset has left padding) */
  }

  /* Legal / Privacy Policy hero on mobile – stacked and centered */
  .page--legal .hero.hero--bp {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    min-height: 0 !important;
    padding: 20px 0 28px !important;
    gap: 0 !important;
  }

  .page--legal .hero .page-container {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    padding-left: max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
    min-height: 0 !important;
    flex: 1 0 auto !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .page--legal .hero .hero__content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    width: 100% !important;
    max-width: 520px !important;
  }

  .page--legal .hero__visual {
    display: none !important;
  }

  .page--legal .hero__brand,
  .page--legal .hero__lead {
    text-align: center !important;
  }

  .page--legal .hero__brand {
    font-size: clamp(28px, 6vw, 42px) !important;
    margin-bottom: 12px !important;
    margin-top: 0 !important;
  }

  .page--legal .hero__lead {
    font-size: clamp(16px, 2vw, 18px) !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    line-height: 1.5 !important;
  }

  .page--legal .hero__lead[style] {
    margin-top: 0 !important;
  }

  /* Business Panel mobile: center all elements (remove scale so content is properly centered) */
  body.page--business-panel main {
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Reduce gap between navbar and first eyebrow on Data Carriers, What is DPP, Business Panel */
  .page--business-panel .data-carriers-hero,
  .page--data-carriers .data-carriers-hero,
  .page--what-is-dpp .data-carriers-hero {
    padding-top: 24px !important;
  }

  body.page--business-panel main > * {
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  .page--business-panel .data-carriers-hero__content {
    text-align: center !important;
    align-items: center !important;
    padding-left: max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }

  .page--business-panel .data-carriers-hero__title,
  .page--business-panel .data-carriers-hero__subtitle {
    text-align: center !important;
  }

  .page--business-panel .data-carriers-hero__actions {
    justify-content: center !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__container {
    padding-left: max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
    text-align: center !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__content {
    width: 100% !important;
    margin-left: 0 !important;
    text-align: center !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__title,
  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__description {
    text-align: center !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__visual {
    justify-content: center !important;
  }

  .page--business-panel .data-carriers-features-grid {
    justify-content: center !important;
  }

  .page--business-panel .accent-eyebrow {
    justify-content: center !important;
  }

  /* Business Panel mobile: refactor content below hero for a clean mobile layout */
  .page--business-panel .data-carriers-deepdive {
    padding: 40px 0 48px !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__container {
    display: flex !important;
    flex-direction: column !important;
    gap: 40px !important;
    padding: 0 max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    min-height: 0 !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__visual {
    order: 1;
    width: 100%;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__content {
    order: 2;
    padding: 0 !important;
    margin-right: 0 !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__img {
    width: 100% !important;
    max-width: 100% !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__title {
    font-size: clamp(26px, 5.5vw, 34px) !important;
    margin-bottom: 20px !important;
  }

  .page--business-panel .data-carriers-deepdive .data-carriers-deepdive__description {
    font-size: clamp(16px, 2vw, 18px) !important;
    margin-bottom: 28px !important;
    line-height: 1.6 !important;
  }

  .page--business-panel .data-carriers-features-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    justify-items: stretch !important;
  }

  .page--business-panel .feature-item {
    padding: 14px 12px !important;
    min-height: 0 !important;
  }

  .page--business-panel .feature-item__icon {
    width: 40px !important;
    height: 40px !important;
    flex-shrink: 0 !important;
  }

  .page--business-panel .feature-item__icon svg {
    width: 20px !important;
    height: 20px !important;
  }

  .page--business-panel .feature-item span {
    font-size: clamp(14px, 2vw, 16px) !important;
  }

  .page--business-panel .feature-item:hover .feature-item__icon {
    transform: none !important;
  }

  /* Catalog section */
  .page--business-panel .data-carriers-catalog {
    padding: 48px max(20px, env(safe-area-inset-left)) 56px !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }

  .page--business-panel .data-carriers-catalog__header {
    margin-bottom: 32px !important;
    padding: 0 !important;
  }

  .page--business-panel .data-carriers-catalog__header h2 {
    font-size: clamp(24px, 5vw, 32px) !important;
    margin-bottom: 16px !important;
  }

  .page--business-panel .data-carriers-catalog__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }

  .page--business-panel .data-carriers-card {
    padding: 28px 24px !important;
  }

  .page--business-panel .data-carriers-card:hover {
    transform: none !important;
  }

  .page--business-panel .data-carriers-card h3 {
    font-size: clamp(18px, 2vw, 20px) !important;
    margin-bottom: 12px !important;
  }

  .page--business-panel .data-carriers-card p {
    font-size: clamp(15px, 2vw, 17px) !important;
    line-height: 1.55 !important;
  }

  /* CTA section */
  .page--business-panel .data-carriers-cta {
    padding: 0 max(20px, env(safe-area-inset-left)) 40px !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }

  .page--business-panel .data-carriers-cta__container {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    padding: 28px 24px !important;
    gap: 24px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .page--business-panel .data-carriers-cta .accent-eyebrow--left {
    justify-content: center !important;
  }

  .page--business-panel .data-carriers-cta__title {
    font-size: clamp(20px, 4.5vw, 26px) !important;
    margin: 0 !important;
    line-height: 1.3 !important;
  }

  .page--business-panel .data-carriers-cta .btn {
    width: 100% !important;
    max-width: 280px !important;
    justify-content: center !important;
  }

  /* ========== Data Carriers page mobile (hero intact, refactor rest) ========== */
  body.page--data-carriers main {
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-bottom: 0 !important;
  }

  body.page--data-carriers main > * {
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  .page--data-carriers .data-carriers-hero__content {
    text-align: center !important;
    align-items: center !important;
    padding-left: max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }

  .page--data-carriers .data-carriers-hero__title,
  .page--data-carriers .data-carriers-hero__subtitle {
    text-align: center !important;
  }

  .page--data-carriers .data-carriers-hero__actions {
    justify-content: center !important;
  }

  .page--data-carriers .data-carriers-deepdive {
    padding: 40px 0 48px !important;
  }

  .page--data-carriers .data-carriers-deepdive .data-carriers-deepdive__container {
    display: flex !important;
    flex-direction: column !important;
    gap: 40px !important;
    padding: 0 max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
    min-height: 0 !important;
  }

  .page--data-carriers .data-carriers-deepdive .data-carriers-deepdive__visual {
    order: 1;
    width: 100%;
    justify-content: center !important;
  }

  .page--data-carriers .data-carriers-deepdive .data-carriers-deepdive__content {
    order: 2;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    text-align: center !important;
  }

  .page--data-carriers .data-carriers-deepdive .data-carriers-deepdive__img {
    width: 100% !important;
    max-width: 100% !important;
  }

  .page--data-carriers .data-carriers-deepdive .data-carriers-deepdive__title {
    font-size: clamp(26px, 5.5vw, 34px) !important;
    margin-bottom: 20px !important;
    text-align: center !important;
  }

  .page--data-carriers .data-carriers-deepdive .data-carriers-deepdive__description {
    font-size: clamp(16px, 2vw, 18px) !important;
    margin-bottom: 28px !important;
    line-height: 1.6 !important;
    text-align: center !important;
  }

  .page--data-carriers .data-carriers-features-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    justify-content: center !important;
    justify-items: stretch !important;
  }

  .page--data-carriers .feature-item {
    padding: 14px 12px !important;
  }

  .page--data-carriers .feature-item__icon {
    width: 40px !important;
    height: 40px !important;
    flex-shrink: 0 !important;
  }

  .page--data-carriers .feature-item__icon svg {
    width: 20px !important;
    height: 20px !important;
  }

  .page--data-carriers .feature-item span {
    font-size: clamp(14px, 2vw, 16px) !important;
  }

  .page--data-carriers .feature-item:hover .feature-item__icon {
    transform: none !important;
  }

  .page--data-carriers .accent-eyebrow {
    justify-content: center !important;
  }

  .page--data-carriers .data-carriers-catalog {
    padding: 48px max(20px, env(safe-area-inset-left)) 56px !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }

  .page--data-carriers .data-carriers-catalog__header {
    margin-bottom: 32px !important;
    padding: 0 !important;
    text-align: center !important;
  }

  .page--data-carriers .data-carriers-catalog__header h2 {
    font-size: clamp(24px, 5vw, 32px) !important;
    margin-bottom: 12px !important;
  }

  .page--data-carriers .data-carriers-catalog__subtitle {
    font-size: clamp(15px, 2vw, 17px) !important;
    margin-bottom: 24px !important;
  }

  .page--data-carriers .data-carriers-catalog__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }

  .page--data-carriers .data-carriers-card {
    border-radius: 20px 20px 0 0 !important;
  }

  .page--data-carriers .data-carriers-card:hover {
    transform: none !important;
  }

  .page--data-carriers .data-carriers-card__body {
    padding: 24px 24px 32px !important;
  }

  .page--data-carriers .data-carriers-card__body h3 {
    font-size: clamp(20px, 2vw, 24px) !important;
    margin-bottom: 10px !important;
  }

  .page--data-carriers .data-carriers-card__body p {
    font-size: clamp(15px, 2vw, 17px) !important;
    line-height: 1.55 !important;
  }

  .page--data-carriers .data-carriers-cta {
    padding: 0 max(20px, env(safe-area-inset-left)) 40px !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }

  .page--data-carriers .data-carriers-cta__container {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    padding: 28px 24px !important;
    gap: 24px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .page--data-carriers .data-carriers-cta .accent-eyebrow--left {
    justify-content: center !important;
  }

  .page--data-carriers .data-carriers-cta__title {
    font-size: clamp(20px, 4.5vw, 26px) !important;
    margin: 0 !important;
    line-height: 1.3 !important;
  }

  .page--data-carriers .data-carriers-cta .btn {
    width: 100% !important;
    max-width: 280px !important;
    justify-content: center !important;
  }
}

/* Mobile: More top padding for homepage hero */
@media (max-width: 768px) {
  .page--home .hero {
    padding-top: 40px !important;
  }
  
  .page--home .hero .hero__content {
    padding-top: 20px;
  }
}

/* ===== Language Switcher Styles ===== */
.nav__item--lang .nav__sub {
  min-width: 140px;
}

.lang-option--active {
  color: var(--accent, #2563eb) !important;
  font-weight: 600;
}

.lang-option--active::before {
  content: '✓ ';
}
