:root {
  --navy-950: #07111f;
  --navy-900: #0a1628;
  --navy-800: #10233d;
  --navy-700: #15365d;
  --platinum-50: #f8fafc;
  --platinum-100: #edf1f6;
  --platinum-200: #d8dee8;
  --platinum-300: #b9c1cf;
  --slate-500: #64748b;
  --slate-600: #475569;
  --slate-700: #334155;
  --gold-300: #f4d37b;
  --gold-400: #d9ad4f;
  --gold-500: #b98a2e;
  --cyan-300: #77e5ff;
  --blue-400: #4f8cff;
  --violet-400: #9f7aea;
  --green-300: #82efac;
  --white: #ffffff;
  --shadow-sm: 0 10px 30px rgba(7, 17, 31, 0.08);
  --shadow-md: 0 24px 70px rgba(7, 17, 31, 0.16);
  --shadow-lg: 0 44px 120px rgba(7, 17, 31, 0.28);
  --radius-sm: 14px;
  --radius-md: 22px;
  --radius-lg: 34px;
  --container: 1180px;
  --ease: cubic-bezier(0.2, 0.8, 0.2, 1);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--navy-950);
  background: linear-gradient(180deg, #f9fbff 0%, #f4f7fb 42%, #ffffff 100%);
  line-height: 1.6;
}

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

img,
svg {
  max-width: 100%;
}

button,
input,
textarea,
select {
  font: inherit;
}

.site-shell {
  min-height: 100vh;
  overflow: hidden;
}

.container {
  width: min(100% - 40px, var(--container));
  margin-inline: auto;
}

.narrow {
  max-width: 860px;
}

.section-pad {
  padding: 108px 0;
}

.section-tight {
  padding: 56px 0;
}

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

.navbar {
  position: fixed;
  z-index: 50;
  top: 18px;
  left: 50%;
  width: min(calc(100% - 32px), 1180px);
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  padding: 13px 16px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(22px);
  box-shadow: 0 18px 60px rgba(7, 17, 31, 0.1);
  transition: background 240ms ease, box-shadow 240ms ease, border-color 240ms ease;
}

.navbar.is-scrolled {
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 24px 70px rgba(7, 17, 31, 0.14);
  border-color: rgba(216, 222, 232, 0.9);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  min-width: max-content;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 43px;
  height: 43px;
  border-radius: 14px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff7d7 0%, var(--gold-300) 48%, #a7b7cf 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), 0 12px 28px rgba(185, 138, 46, 0.22);
  font-size: 0.83rem;
}

.brand-text {
  font-size: 0.98rem;
}

.primary-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--slate-600);
  font-weight: 700;
  font-size: 0.93rem;
}

.primary-nav a {
  padding: 10px 14px;
  border-radius: 999px;
  transition: color 180ms ease, background 180ms ease;
}

.primary-nav a:hover,
.primary-nav a[aria-current="page"] {
  color: var(--navy-950);
  background: rgba(16, 35, 61, 0.07);
}

.nav-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: max-content;
  padding: 11px 16px;
  border-radius: 999px;
  color: white;
  background: linear-gradient(135deg, var(--navy-950), var(--navy-700));
  font-weight: 800;
  font-size: 0.92rem;
  box-shadow: 0 14px 34px rgba(10, 22, 40, 0.24);
}

.nav-toggle {
  display: none;
  border: 0;
  background: transparent;
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 999px;
}

.nav-toggle span:not(.sr-only) {
  display: block;
  width: 20px;
  height: 2px;
  margin: 4px auto;
  border-radius: 4px;
  background: var(--navy-950);
}

.hero {
  position: relative;
  min-height: 860px;
  padding-top: 184px;
  background:
    radial-gradient(circle at 10% 10%, rgba(79, 140, 255, 0.14), transparent 32%),
    radial-gradient(circle at 72% 14%, rgba(244, 211, 123, 0.26), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, #f4f7fc 100%);
}

.hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  gap: 56px;
  align-items: center;
}

.hero-copy h1,
.page-hero h1 {
  margin: 18px 0 22px;
  font-size: clamp(3.1rem, 7vw, 6.75rem);
  line-height: 0.91;
  letter-spacing: -0.075em;
  max-width: 820px;
}

.hero-lede,
.page-hero p {
  max-width: 660px;
  margin: 0;
  color: var(--slate-600);
  font-size: clamp(1.05rem, 1.6vw, 1.28rem);
  line-height: 1.62;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: var(--navy-700);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}

.pulse {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--green-300);
  box-shadow: 0 0 0 8px rgba(130, 239, 172, 0.18);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 34px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 850;
  transition: transform 180ms var(--ease), box-shadow 180ms var(--ease), background 180ms ease;
}

.button:hover {
  transform: translateY(-2px);
}

.button-primary {
  color: white;
  background: linear-gradient(135deg, var(--navy-950), #183e69 55%, #285c91);
  box-shadow: 0 20px 40px rgba(7, 17, 31, 0.25);
}

.button-primary:hover {
  box-shadow: 0 26px 60px rgba(7, 17, 31, 0.28);
}

.button-secondary {
  color: var(--navy-950);
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(185, 193, 207, 0.8);
  box-shadow: var(--shadow-sm);
}

.trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 42px;
}

.trust-strip span,
.pill-row span {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(185, 193, 207, 0.74);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--slate-600);
  padding: 8px 12px;
  font-size: 0.82rem;
  font-weight: 800;
}

.hero-visual {
  position: relative;
  min-height: 560px;
  perspective: 1200px;
}

.dashboard-card,
.floating-card,
.research-console,
.contact-form,
.package-card,
.case-card,
.testimonial-card,
.article-card {
  border: 1px solid rgba(255, 255, 255, 0.54);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.68));
  backdrop-filter: blur(22px);
  box-shadow: var(--shadow-md);
}

.main-card {
  position: absolute;
  inset: 56px 0 auto auto;
  width: min(100%, 500px);
  min-height: 420px;
  border-radius: 32px;
  overflow: hidden;
  transform: rotateX(8deg) rotateY(-12deg) rotateZ(2deg);
}

.card-toolbar,
.console-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 18px 20px;
  border-bottom: 1px solid rgba(185, 193, 207, 0.36);
}

.card-toolbar span,
.console-header span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--platinum-300);
}

.card-toolbar span:nth-child(1),
.console-header span:nth-child(1) {
  background: var(--gold-300);
}

.card-toolbar span:nth-child(2),
.console-header span:nth-child(2) {
  background: var(--blue-400);
}

.card-toolbar span:nth-child(3),
.console-header span:nth-child(3) {
  background: var(--green-300);
}

.card-toolbar strong,
.console-header strong {
  margin-left: auto;
  color: var(--slate-600);
  font-size: 0.82rem;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: 20px;
}

.metric-card,
.workflow-card {
  border: 1px solid rgba(216, 222, 232, 0.82);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
  padding: 20px;
  min-height: 158px;
}

.metric-card small,
.metric-card span,
.insight-card small,
.story-card span,
.article-card span,
.package-card span,
.case-kicker {
  color: var(--slate-500);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.11em;
}

.metric-card strong {
  display: block;
  margin: 8px 0 4px;
  font-size: 4.1rem;
  letter-spacing: -0.08em;
  line-height: 0.95;
}

.metric-card.accent {
  color: white;
  background: linear-gradient(135deg, var(--navy-900), var(--navy-700) 60%, #2d6ea5);
}

.metric-card.accent small,
.metric-card.accent span {
  color: rgba(255, 255, 255, 0.72);
}

.workflow-card {
  grid-column: 1 / -1;
  display: grid;
  gap: 13px;
  min-height: 170px;
}

.workflow-line {
  display: grid;
  grid-template-columns: 16px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: #f6f8fb;
}

.workflow-line span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--gold-400);
}

.workflow-line b {
  letter-spacing: -0.03em;
}

.workflow-line em {
  color: var(--slate-500);
  font-style: normal;
  font-size: 0.8rem;
  font-weight: 800;
}

.floating-card {
  position: absolute;
  border-radius: 24px;
  padding: 19px;
}

.code-card {
  left: 0;
  top: 0;
  width: 270px;
  color: white;
  background: linear-gradient(140deg, var(--navy-950), #193964 60%, #224d7f);
  transform: rotateX(10deg) rotateY(16deg) rotateZ(-7deg);
}

.code-line {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.code-line b {
  color: var(--green-300);
}

.code-card pre {
  margin: 18px 0 0;
  color: rgba(255, 255, 255, 0.86);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 0.9rem;
  line-height: 1.6;
  white-space: pre-wrap;
}

.insight-card {
  right: -12px;
  bottom: 8px;
  width: 310px;
  transform: rotateX(8deg) rotateY(-14deg) rotateZ(7deg);
}

.insight-card strong {
  display: block;
  margin: 7px 0;
  font-size: 1.2rem;
  letter-spacing: -0.04em;
}

.insight-card p {
  margin: 0;
  color: var(--slate-600);
  font-size: 0.92rem;
}

.orb,
.mesh {
  position: absolute;
  pointer-events: none;
  filter: blur(0.2px);
}

.orb-one {
  width: 420px;
  height: 420px;
  left: -120px;
  top: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79, 140, 255, 0.22), transparent 68%);
}

.orb-two {
  width: 540px;
  height: 540px;
  right: -130px;
  top: 70px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(244, 211, 123, 0.32), transparent 66%);
}

.mesh-one {
  left: 48%;
  top: 210px;
  width: 510px;
  height: 360px;
  background-image:
    linear-gradient(rgba(21, 54, 93, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(21, 54, 93, 0.08) 1px, transparent 1px);
  background-size: 32px 32px;
  transform: rotate(-10deg) skewX(-10deg);
  mask-image: radial-gradient(circle, black 18%, transparent 70%);
}

.logo-cloud {
  border-top: 1px solid rgba(216, 222, 232, 0.75);
  border-bottom: 1px solid rgba(216, 222, 232, 0.75);
  background: rgba(255, 255, 255, 0.64);
}

.logo-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  color: var(--slate-500);
  flex-wrap: wrap;
}

.logo-row span {
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.logo-row strong {
  color: var(--navy-800);
  font-size: 1rem;
  letter-spacing: -0.02em;
}

.split-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: 42px;
  align-items: end;
  margin-bottom: 42px;
}

.split-header h2,
.proof-copy h2,
.infra-copy h2,
.cta-card h2,
.package-card h2,
.case-card h2,
.ai-roadmap h2 {
  margin: 12px 0 0;
  color: var(--navy-950);
  font-size: clamp(2.25rem, 4vw, 4.3rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.split-header p,
.proof-copy p,
.infra-copy p,
.ai-roadmap p {
  margin: 0;
  color: var(--slate-600);
  font-size: 1.06rem;
}

.card-grid,
.service-grid,
.insight-grid,
.article-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.service-card,
.audience-card,
.insight-tile,
.process-step,
.detail-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(216, 222, 232, 0.82);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: var(--shadow-sm);
}

.service-card {
  min-height: 314px;
  padding: 26px;
  border-radius: 26px;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms ease;
}

.service-card::after {
  content: "";
  position: absolute;
  width: 190px;
  height: 190px;
  right: -80px;
  bottom: -90px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(244, 211, 123, 0.34), transparent 68%);
}

.service-card:hover,
.package-card:hover,
.article-card:hover,
.case-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
  border-color: rgba(185, 138, 46, 0.34);
}

.service-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding-inline: 12px;
  border-radius: 15px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff6dc, var(--gold-300));
  font-size: 0.83rem;
  font-weight: 950;
}

.service-card h3,
.audience-card h3,
.story-card h3,
.insight-tile h3,
.process-step h3,
.detail-card h2,
.article-card h3,
.testimonial-card p,
.research-console h3 {
  margin: 20px 0 10px;
  color: var(--navy-950);
  font-size: 1.34rem;
  line-height: 1.12;
  letter-spacing: -0.045em;
}

.service-card p,
.audience-card p,
.story-card p,
.insight-tile p,
.process-step p,
.detail-card p,
.article-card p,
.case-card p,
.testimonial-card footer,
.form-note {
  color: var(--slate-600);
  margin: 0;
}

.service-card a,
.text-link {
  position: relative;
  z-index: 2;
  display: inline-flex;
  margin-top: 20px;
  color: var(--navy-700);
  font-weight: 900;
}

.text-link::after,
.service-card a::after {
  content: "→";
  margin-left: 8px;
  transition: transform 180ms var(--ease);
}

.text-link:hover::after,
.service-card a:hover::after {
  transform: translateX(4px);
}

.dark-panel {
  position: relative;
  color: white;
  background:
    radial-gradient(circle at 16% 0%, rgba(79, 140, 255, 0.28), transparent 35%),
    radial-gradient(circle at 78% 16%, rgba(244, 211, 123, 0.18), transparent 30%),
    linear-gradient(135deg, var(--navy-950), var(--navy-900) 52%, #112844 100%);
}

.dark-panel h2,
.dark-panel .metric-block strong,
.dark-panel .eyebrow,
.dark-panel .ai-roadmap h2 {
  color: white;
}

.dark-panel p,
.dark-panel .metric-block span,
.dark-panel .split-header p,
.dark-panel .ai-roadmap p {
  color: rgba(255, 255, 255, 0.68);
}

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

.metric-block {
  padding: 28px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.055);
}

.metric-block strong {
  display: block;
  font-size: clamp(2.8rem, 5vw, 5.2rem);
  line-height: 0.95;
  letter-spacing: -0.08em;
}

.metric-block span {
  display: block;
  margin-top: 10px;
  font-weight: 700;
}

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

.audience-card {
  padding: 30px;
  border-radius: 30px;
}

.audience-card ul,
.package-card ul {
  padding: 0;
  margin: 24px 0 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.audience-card li,
.package-card li {
  position: relative;
  padding-left: 22px;
  color: var(--slate-600);
  font-weight: 700;
}

.audience-card li::before,
.package-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
}

.proof-section {
  background:
    linear-gradient(180deg, rgba(248, 250, 252, 0.1), rgba(237, 241, 246, 0.55)),
    radial-gradient(circle at 92% 12%, rgba(79, 140, 255, 0.13), transparent 32%);
}

.proof-layout {
  display: grid;
  grid-template-columns: 0.88fr 1.12fr;
  gap: 54px;
  align-items: center;
}

.proof-copy .button {
  margin-top: 28px;
}

.story-stack {
  display: grid;
  gap: 22px;
}

.story-card {
  padding: 28px;
  border: 1px solid rgba(216, 222, 232, 0.84);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-sm);
}

.story-card.offset {
  margin-left: 46px;
}

.story-meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid rgba(216, 222, 232, 0.8);
}

.story-meta strong {
  color: var(--navy-950);
}

.story-meta span {
  color: var(--slate-600);
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.95rem;
}

.infrastructure-section {
  background: #fff;
}

.infra-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 64px;
  align-items: center;
}

.infra-visual {
  min-height: 460px;
  display: grid;
  place-items: center;
}

.system-map {
  position: relative;
  width: min(100%, 460px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.84) 0 24%, transparent 24% 100%),
    repeating-radial-gradient(circle, rgba(21, 54, 93, 0.12) 0 1px, transparent 1px 70px),
    radial-gradient(circle at 50% 50%, rgba(79, 140, 255, 0.08), rgba(244, 211, 123, 0.08));
}

.node {
  position: absolute;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(216, 222, 232, 0.9);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: var(--shadow-sm);
  color: var(--navy-800);
  font-weight: 900;
}

.node.core {
  width: 116px;
  height: 116px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  font-size: 1.4rem;
}

.n1 { width: 108px; height: 56px; left: 8%; top: 20%; }
.n2 { width: 92px; height: 52px; right: 9%; top: 18%; }
.n3 { width: 80px; height: 80px; right: 4%; top: 54%; }
.n4 { width: 104px; height: 54px; left: 10%; bottom: 15%; }
.n5 { width: 116px; height: 56px; right: 24%; bottom: 4%; }

.check-list {
  display: grid;
  gap: 18px;
  margin-top: 30px;
}

.check-list div {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 14px;
  align-items: start;
}

.check-list span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff3c7, var(--gold-300));
  font-weight: 950;
}

.check-list p {
  margin: 3px 0 0;
}

.insights-section {
  background: linear-gradient(180deg, #f9fbff, #ffffff);
}

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

.insight-tile {
  min-height: 230px;
  padding: 28px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.72)),
    radial-gradient(circle at 100% 0%, rgba(79, 140, 255, 0.14), transparent 38%);
}

.insight-tile span {
  color: var(--gold-500);
  font-size: 0.76rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.cta-band {
  background: linear-gradient(180deg, #ffffff, #f4f7fb);
}

.cta-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding: clamp(30px, 5vw, 56px);
  border-radius: 36px;
  color: white;
  background:
    radial-gradient(circle at 12% 10%, rgba(119, 229, 255, 0.28), transparent 32%),
    radial-gradient(circle at 90% 10%, rgba(244, 211, 123, 0.24), transparent 32%),
    linear-gradient(135deg, var(--navy-950), var(--navy-800));
  box-shadow: var(--shadow-lg);
}

.cta-card h2 {
  color: white;
  max-width: 720px;
}

.cta-card .eyebrow {
  color: var(--gold-300);
}

.cta-card .button-primary {
  background: linear-gradient(135deg, #fff, #dfe7f2);
  color: var(--navy-950);
  box-shadow: 0 20px 44px rgba(0, 0, 0, 0.18);
}

.footer {
  background: var(--navy-950);
  color: rgba(255, 255, 255, 0.72);
  padding: 76px 0 30px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 34px;
}

.footer .brand-text,
.footer h4 {
  color: white;
}

.footer p {
  max-width: 370px;
  margin: 18px 0 0;
}

.footer h4 {
  margin: 0 0 14px;
  font-size: 0.88rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.footer a:not(.brand) {
  display: block;
  margin: 9px 0;
  color: rgba(255, 255, 255, 0.66);
  transition: color 180ms ease;
}

.footer a:hover {
  color: white;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-top: 52px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.11);
  font-size: 0.88rem;
}

.page-hero {
  padding-top: 178px;
  background:
    radial-gradient(circle at 82% 8%, rgba(244, 211, 123, 0.22), transparent 30%),
    radial-gradient(circle at 10% 12%, rgba(79, 140, 255, 0.12), transparent 32%),
    linear-gradient(180deg, #ffffff, #f5f8fc);
}

.compact-hero {
  padding-bottom: 78px;
}

.package-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.package-card {
  padding: 30px;
  border-radius: 32px;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
}

.package-card.featured {
  color: white;
  background:
    radial-gradient(circle at 100% 0%, rgba(244, 211, 123, 0.28), transparent 34%),
    linear-gradient(135deg, var(--navy-950), var(--navy-800));
}

.package-card.featured h2,
.package-card.featured p,
.package-card.featured li,
.package-card.featured span {
  color: white;
}

.package-card h2 {
  font-size: clamp(1.9rem, 3vw, 3rem);
}

.service-detail-grid {
  display: grid;
  gap: 20px;
}

.detail-card {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 28px;
  align-items: start;
  padding: 34px;
  border-radius: 30px;
}

.detail-number {
  display: grid;
  place-items: center;
  width: 70px;
  height: 70px;
  border-radius: 22px;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  font-weight: 950;
}

.detail-card h2 {
  margin: 0 0 10px;
  font-size: clamp(1.9rem, 3vw, 3rem);
}

.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}

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

.process-step {
  padding: 26px;
  border-radius: 28px;
}

.process-step span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  color: white;
  background: var(--navy-900);
  font-weight: 950;
}

.research-hero-grid,
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 0.82fr;
  gap: 54px;
  align-items: center;
}

.research-console {
  overflow: hidden;
  border-radius: 30px;
  color: white;
  background: linear-gradient(135deg, var(--navy-950), #15365d 74%, #2d6ea5);
}

.console-body {
  padding: 28px;
}

.console-body p {
  max-width: none;
  margin: 0 0 12px;
  color: rgba(255, 255, 255, 0.8);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 0.94rem;
}

.console-progress {
  height: 13px;
  margin-top: 24px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
}

.console-progress span {
  display: block;
  width: 72%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--gold-300), var(--green-300), var(--cyan-300));
}

.article-grid {
  grid-template-columns: 1.2fr repeat(3, 1fr);
}

.article-card {
  min-height: 300px;
  padding: 28px;
  border-radius: 30px;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
}

.feature-article {
  color: white;
  background:
    radial-gradient(circle at 90% 6%, rgba(244, 211, 123, 0.28), transparent 34%),
    linear-gradient(135deg, var(--navy-950), var(--navy-800));
}

.feature-article h3,
.feature-article p,
.feature-article span,
.feature-article a {
  color: white;
}

.ai-roadmap {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 44px;
  align-items: center;
}

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

.roadmap-lane div,
.checklist-grid div {
  padding: 22px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.06);
}

.roadmap-lane span,
.checklist-grid span {
  display: block;
  color: var(--gold-300);
  font-size: 0.76rem;
  font-weight: 950;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.roadmap-lane strong {
  display: block;
  margin: 12px 0 8px;
  color: white;
  font-size: 1.08rem;
}

.case-grid {
  display: grid;
  gap: 22px;
}

.case-card {
  padding: 34px;
  border-radius: 32px;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
}

.case-card h2 {
  max-width: 790px;
  font-size: clamp(2rem, 4vw, 3.65rem);
}

.case-summary {
  max-width: 770px;
  font-size: 1.08rem;
}

.case-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 30px;
}

.case-columns div {
  padding: 22px;
  border-radius: 22px;
  background: #f6f8fb;
}

.case-columns h3 {
  margin: 0 0 8px;
  color: var(--navy-950);
  letter-spacing: -0.03em;
}

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

.testimonial-card {
  margin: 0;
  padding: 30px;
  border-radius: 30px;
}

.testimonial-card p {
  margin: 0 0 20px;
  color: var(--navy-950);
  font-size: 1.24rem;
}

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

.contact-hero {
  min-height: 760px;
}

.contact-proof {
  display: grid;
  gap: 14px;
  margin-top: 32px;
  max-width: 640px;
}

.contact-proof div {
  padding: 18px 20px;
  border: 1px solid rgba(216, 222, 232, 0.82);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.72);
}

.contact-proof strong,
.contact-proof span {
  display: block;
}

.contact-proof span {
  color: var(--slate-600);
  margin-top: 4px;
}

.contact-form {
  display: grid;
  gap: 16px;
  padding: 28px;
  border-radius: 32px;
}

.contact-form label {
  display: grid;
  gap: 8px;
}

.contact-form label span {
  color: var(--navy-800);
  font-size: 0.88rem;
  font-weight: 850;
}

.contact-form input,
.contact-form textarea,
.contact-form select {
  width: 100%;
  border: 1px solid rgba(185, 193, 207, 0.9);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.84);
  padding: 14px 15px;
  color: var(--navy-950);
  outline: none;
  transition: border-color 180ms ease, box-shadow 180ms ease;
}

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
  border-color: var(--gold-400);
  box-shadow: 0 0 0 4px rgba(244, 211, 123, 0.2);
}

.contact-form textarea {
  resize: vertical;
}

.form-note {
  font-size: 0.86rem;
}

.toast {
  position: fixed;
  z-index: 100;
  right: 20px;
  bottom: 20px;
  max-width: min(420px, calc(100% - 40px));
  border-radius: 18px;
  padding: 16px 18px;
  color: white;
  background: var(--navy-950);
  box-shadow: var(--shadow-lg);
  transform: translateY(20px);
  opacity: 0;
  transition: opacity 220ms var(--ease), transform 220ms var(--ease);
}

.toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 650ms var(--ease), transform 650ms var(--ease);
}

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

.delay-1 { transition-delay: 90ms; }
.delay-2 { transition-delay: 180ms; }
.delay-3 { transition-delay: 270ms; }

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

@media (max-width: 1020px) {
  .navbar {
    border-radius: 26px;
    align-items: flex-start;
  }

  .brand-text {
    max-width: 180px;
    line-height: 1.1;
  }

  .nav-toggle {
    display: block;
    margin-left: auto;
  }

  .primary-nav,
  .nav-cta {
    display: none;
  }

  .navbar.is-open {
    flex-wrap: wrap;
  }

  .navbar.is-open .primary-nav {
    order: 5;
    display: grid;
    width: 100%;
    gap: 2px;
    padding-top: 10px;
  }

  .navbar.is-open .nav-cta {
    order: 6;
    display: flex;
    width: 100%;
  }

  .hero-grid,
  .proof-layout,
  .infra-grid,
  .research-hero-grid,
  .contact-grid,
  .ai-roadmap {
    grid-template-columns: 1fr;
  }

  .hero {
    padding-top: 150px;
    min-height: auto;
  }

  .hero-visual {
    min-height: 610px;
  }

  .main-card {
    right: 50%;
    transform: translateX(50%) rotateX(8deg) rotateY(-10deg) rotateZ(2deg);
  }

  .card-grid,
  .service-grid,
  .metrics-grid,
  .process-grid,
  .checklist-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .package-grid,
  .audience-grid,
  .insight-grid,
  .testimonial-grid,
  .footer-grid,
  .roadmap-lane {
    grid-template-columns: 1fr 1fr;
  }

  .split-header {
    grid-template-columns: 1fr;
  }

  .cta-card {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  .container {
    width: min(100% - 28px, var(--container));
  }

  .section-pad {
    padding: 78px 0;
  }

  .section-tight {
    padding: 42px 0;
  }

  .navbar {
    top: 10px;
    width: min(calc(100% - 18px), 1180px);
    padding: 10px;
  }

  .brand-mark {
    width: 39px;
    height: 39px;
    border-radius: 13px;
  }

  .brand-text {
    font-size: 0.9rem;
    max-width: 145px;
  }

  .hero-copy h1,
  .page-hero h1 {
    font-size: clamp(3rem, 15vw, 4.85rem);
  }

  .hero {
    padding-top: 132px;
  }

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

  .hero-actions,
  .trust-strip {
    width: 100%;
  }

  .button {
    width: 100%;
  }

  .hero-visual {
    min-height: 560px;
  }

  .main-card {
    inset: 80px auto auto 50%;
    width: 92%;
    transform: translateX(-50%);
  }

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

  .workflow-card {
    grid-column: auto;
  }

  .code-card {
    top: 0;
    left: 4px;
    width: 230px;
    transform: rotateZ(-4deg);
  }

  .insight-card {
    right: 4px;
    bottom: 0;
    width: 240px;
    transform: rotateZ(4deg);
  }

  .card-grid,
  .service-grid,
  .metrics-grid,
  .process-grid,
  .checklist-grid,
  .package-grid,
  .audience-grid,
  .insight-grid,
  .testimonial-grid,
  .article-grid,
  .footer-grid,
  .roadmap-lane {
    grid-template-columns: 1fr;
  }

  .proof-layout,
  .infra-grid {
    gap: 32px;
  }

  .story-card.offset {
    margin-left: 0;
  }

  .detail-card {
    grid-template-columns: 1fr;
    padding: 26px;
  }

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

  .footer-bottom {
    flex-direction: column;
  }

  .system-map {
    width: 330px;
  }

  .node.core {
    width: 94px;
    height: 94px;
  }

  .n1 { left: 0; top: 18%; }
  .n2 { right: 0; top: 16%; }
  .n3 { right: -4px; top: 54%; }
  .n4 { left: -4px; bottom: 14%; }
  .n5 { right: 18%; bottom: -2%; }
}

/* Homepage hero v2: cinematic PSG Operating System scene */
.hero.hero-command {
  min-height: 960px;
  padding-top: 172px;
  overflow: hidden;
  background:
    radial-gradient(circle at 6% 12%, rgba(79, 140, 255, 0.22), transparent 34%),
    radial-gradient(circle at 72% 4%, rgba(244, 211, 123, 0.28), transparent 29%),
    radial-gradient(circle at 96% 44%, rgba(119, 229, 255, 0.18), transparent 31%),
    linear-gradient(180deg, #ffffff 0%, #f5f8ff 49%, #eef4fb 100%);
}

.hero.hero-command::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(115deg, transparent 0 34%, rgba(255, 255, 255, 0.68) 43%, transparent 55% 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.56), transparent 62%);
  opacity: 0.62;
  mix-blend-mode: screen;
}

.hero-command .hero-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}

.hero-command .hero-grid {
  grid-template-columns: minmax(0, 0.94fr) minmax(520px, 1.06fr);
  gap: 44px;
}

.hero-command .hero-copy {
  position: relative;
  z-index: 5;
}

.hero-command .hero-lede {
  color: rgba(51, 65, 85, 0.86);
}

.hero-proof-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 650px;
  margin-top: 30px;
}

.hero-proof-row div {
  min-height: 98px;
  padding: 17px 18px;
  border: 1px solid rgba(216, 222, 232, 0.72);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.56));
  box-shadow: 0 18px 46px rgba(7, 17, 31, 0.07);
  backdrop-filter: blur(18px);
}

.hero-proof-row strong {
  display: block;
  color: var(--navy-950);
  font-size: clamp(1.58rem, 2.2vw, 2.25rem);
  line-height: 0.95;
  letter-spacing: -0.07em;
}

.hero-proof-row span {
  display: block;
  margin-top: 8px;
  color: var(--slate-600);
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1.28;
}

.hero-command .trust-strip {
  margin-top: 20px;
}

.hero-command .orb-three {
  width: 360px;
  height: 360px;
  right: 20%;
  bottom: 0;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(159, 122, 234, 0.17), transparent 68%);
}

.gradient-slab {
  position: absolute;
  width: 520px;
  height: 210px;
  border-radius: 56px;
  filter: blur(0.1px);
  opacity: 0.64;
  transform: rotate(-12deg) skewX(-18deg);
}

.slab-one {
  right: -132px;
  top: 142px;
  background: linear-gradient(100deg, rgba(79, 140, 255, 0.18), rgba(119, 229, 255, 0.26), rgba(244, 211, 123, 0.2));
}

.slab-two {
  right: 220px;
  top: 344px;
  width: 360px;
  height: 120px;
  background: linear-gradient(100deg, rgba(244, 211, 123, 0.22), rgba(255, 255, 255, 0.02), rgba(79, 140, 255, 0.18));
}

.data-stream {
  position: absolute;
  height: 1px;
  width: 520px;
  background: linear-gradient(90deg, transparent, rgba(79, 140, 255, 0.4), rgba(244, 211, 123, 0.46), transparent);
  transform: rotate(-13deg);
  opacity: 0.78;
  animation: streamDrift 8s var(--ease) infinite;
}

.stream-one { right: 8%; top: 214px; animation-delay: 0s; }
.stream-two { right: 18%; top: 458px; width: 390px; animation-delay: -2.8s; }
.stream-three { right: -2%; top: 610px; width: 470px; animation-delay: -5.6s; }

.hero-operating-scene {
  min-height: 690px;
  isolation: isolate;
  transform-style: preserve-3d;
}

.scene-halo {
  position: absolute;
  z-index: 0;
  inset: 18px -42px 0 -18px;
  border-radius: 46px;
  background:
    radial-gradient(circle at 50% 30%, rgba(119, 229, 255, 0.24), transparent 38%),
    radial-gradient(circle at 60% 72%, rgba(244, 211, 123, 0.18), transparent 45%);
  filter: blur(18px);
}

.scene-grid-floor {
  position: absolute;
  z-index: 0;
  right: -110px;
  bottom: -72px;
  width: 690px;
  height: 330px;
  background-image:
    linear-gradient(rgba(21, 54, 93, 0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(21, 54, 93, 0.12) 1px, transparent 1px);
  background-size: 36px 36px;
  transform: rotateX(64deg) rotateZ(-18deg) skewX(-10deg);
  transform-origin: center;
  mask-image: radial-gradient(ellipse at center, black 18%, transparent 72%);
  opacity: 0.66;
}

.ops-console,
.os-float,
.system-status-chip {
  --parallax-x: 0px;
  --parallax-y: 0px;
  position: absolute;
  z-index: 2;
  will-change: transform;
  transition: transform 220ms var(--ease);
}

.ops-console {
  right: -12px;
  top: 54px;
  width: min(100%, 610px);
  min-height: 520px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 38px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(239, 245, 253, 0.76)),
    radial-gradient(circle at 90% 2%, rgba(119, 229, 255, 0.22), transparent 32%);
  box-shadow:
    0 34px 90px rgba(7, 17, 31, 0.22),
    0 2px 0 rgba(255, 255, 255, 0.86) inset;
  backdrop-filter: blur(28px);
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateX(7.5deg) rotateY(-13deg) rotateZ(2deg);
  transform-style: preserve-3d;
}

.ops-console::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 0 38%, rgba(255, 255, 255, 0.74) 48%, transparent 58% 100%);
  opacity: 0.42;
  transform: translateX(-62%);
  animation: consoleSheen 9s ease-in-out infinite;
  pointer-events: none;
}

.ops-console::after {
  content: "";
  position: absolute;
  inset: auto 22px 22px 22px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(79, 140, 255, 0.38), rgba(244, 211, 123, 0.42), transparent);
  opacity: 0.76;
}

.ops-toolbar {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(185, 193, 207, 0.32);
  background: rgba(255, 255, 255, 0.56);
}

.window-dots {
  display: inline-flex;
  gap: 7px;
}

.window-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--platinum-300);
}

.window-dots span:nth-child(1) { background: var(--gold-300); }
.window-dots span:nth-child(2) { background: var(--blue-400); }
.window-dots span:nth-child(3) { background: var(--green-300); }

.ops-toolbar strong {
  color: var(--navy-950);
  font-size: 0.86rem;
  letter-spacing: -0.02em;
  white-space: nowrap;
}

.ops-toolbar-tabs {
  display: inline-flex;
  gap: 5px;
  margin-left: auto;
  padding: 4px;
  border: 1px solid rgba(216, 222, 232, 0.72);
  border-radius: 999px;
  background: rgba(248, 250, 252, 0.8);
}

.ops-toolbar-tabs span {
  padding: 6px 10px;
  border-radius: 999px;
  color: var(--slate-500);
  font-size: 0.72rem;
  font-weight: 900;
}

.ops-toolbar-tabs .active {
  color: var(--navy-950);
  background: white;
  box-shadow: 0 8px 20px rgba(7, 17, 31, 0.08);
}

.ops-toolbar em {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--green-300);
  font-style: normal;
  font-size: 0.72rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.ops-toolbar em::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green-300);
  box-shadow: 0 0 0 7px rgba(130, 239, 172, 0.16);
}

.ops-console-body {
  position: relative;
  z-index: 1;
  padding: 22px;
}

.ops-hero-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}

.ops-label,
.ops-panel-header span,
.roadmap-header span,
.decision-panel span,
.os-float small {
  display: block;
  color: var(--slate-500);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.ops-hero-row h2 {
  margin: 7px 0 0;
  color: var(--navy-950);
  font-size: clamp(1.55rem, 2.4vw, 2.35rem);
  line-height: 0.95;
  letter-spacing: -0.065em;
}

.ops-score {
  min-width: 116px;
  padding: 13px 14px;
  border: 1px solid rgba(216, 222, 232, 0.84);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.7);
  text-align: right;
  box-shadow: 0 14px 28px rgba(7, 17, 31, 0.06);
}

.ops-score span {
  color: var(--slate-500);
  font-size: 0.72rem;
  font-weight: 850;
}

.ops-score strong {
  display: block;
  margin-top: 3px;
  color: var(--navy-950);
  font-size: 2rem;
  line-height: 0.95;
  letter-spacing: -0.08em;
}

.ops-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.32fr) minmax(170px, 0.68fr);
  gap: 14px;
}

.ops-panel {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(216, 222, 232, 0.74);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.68);
  box-shadow: 0 16px 34px rgba(7, 17, 31, 0.07);
}

.forecast-panel {
  padding: 18px;
}

.ops-panel-header,
.roadmap-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.ops-panel-header strong {
  display: block;
  margin-top: 5px;
  color: var(--navy-950);
  font-size: 2.25rem;
  line-height: 0.95;
  letter-spacing: -0.08em;
}

.ops-panel-header b,
.roadmap-header b {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 9px;
  border-radius: 999px;
  color: #0d5831;
  background: rgba(130, 239, 172, 0.22);
  font-size: 0.75rem;
  white-space: nowrap;
}

.trend-chart {
  display: block;
  width: 100%;
  height: 158px;
  margin-top: 4px;
}

.chart-grid-line {
  stroke: rgba(185, 193, 207, 0.45);
  stroke-width: 1;
  stroke-dasharray: 5 7;
}

.trend-fill {
  fill: url(#psgTrend);
  opacity: 0.14;
}

.trend-line {
  fill: none;
  stroke: url(#psgTrend);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-dasharray: 420;
  stroke-dashoffset: 420;
  animation: drawTrend 2.8s var(--ease) forwards 420ms;
}

.chart-dot {
  fill: var(--gold-300);
  stroke: white;
  stroke-width: 4;
  filter: drop-shadow(0 0 12px rgba(244, 211, 123, 0.65));
  animation: chartDotPulse 2.4s ease-in-out infinite 1.8s;
}

.decision-panel {
  padding: 18px;
  background:
    radial-gradient(circle at 100% 0%, rgba(79, 140, 255, 0.18), transparent 42%),
    linear-gradient(145deg, rgba(10, 22, 40, 0.96), rgba(21, 54, 93, 0.88));
  color: white;
}

.decision-panel span,
.decision-panel p {
  color: rgba(255, 255, 255, 0.68);
}

.decision-panel strong {
  display: block;
  margin: 12px 0 8px;
  color: white;
  font-size: 3.5rem;
  line-height: 0.9;
  letter-spacing: -0.08em;
}

.decision-panel p {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.45;
  font-weight: 650;
}

.decision-progress {
  height: 9px;
  margin-top: 18px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.13);
}

.decision-progress span {
  display: block;
  width: 74%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--gold-300), var(--green-300), var(--cyan-300));
  animation: progressPulse 3.4s ease-in-out infinite;
}

.roadmap-panel {
  grid-column: 1 / -1;
  padding: 18px;
}

.roadmap-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.roadmap-lane-card {
  display: grid;
  gap: 8px;
  min-height: 154px;
  padding: 12px;
  border: 1px solid rgba(216, 222, 232, 0.72);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.78);
}

.roadmap-lane-card.active {
  background:
    radial-gradient(circle at 100% 0%, rgba(244, 211, 123, 0.24), transparent 48%),
    rgba(255, 255, 255, 0.84);
  box-shadow: inset 0 0 0 1px rgba(244, 211, 123, 0.16);
}

.roadmap-lane-card > span {
  color: var(--navy-700);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.roadmap-lane-card article {
  position: relative;
  padding: 11px 10px 10px 12px;
  border: 1px solid rgba(216, 222, 232, 0.72);
  border-radius: 14px;
  background: white;
  box-shadow: 0 8px 22px rgba(7, 17, 31, 0.045);
}

.roadmap-lane-card article::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--blue-400), var(--gold-300));
}

.roadmap-lane-card b,
.roadmap-lane-card em {
  display: block;
}

.roadmap-lane-card b {
  color: var(--navy-950);
  font-size: 0.86rem;
  letter-spacing: -0.03em;
}

.roadmap-lane-card em {
  margin-top: 2px;
  color: var(--slate-500);
  font-style: normal;
  font-size: 0.73rem;
  font-weight: 850;
}

.system-status-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 999px;
  color: var(--navy-800);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 38px rgba(7, 17, 31, 0.1);
  backdrop-filter: blur(18px);
  font-size: 0.78rem;
  font-weight: 900;
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0);
  animation: heroFloat 6s ease-in-out infinite;
}

.system-status-chip span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green-300);
  box-shadow: 0 0 0 6px rgba(130, 239, 172, 0.16);
}

.chip-forecast { left: 74px; top: 30px; animation-delay: -1.1s; }
.chip-risk { right: 18px; top: 18px; animation-delay: -3.2s; }
.chip-risk span { background: var(--gold-300); box-shadow: 0 0 0 6px rgba(244, 211, 123, 0.18); }
.chip-ai { right: 44px; bottom: 98px; animation-delay: -4.4s; }
.chip-ai span { background: var(--cyan-300); box-shadow: 0 0 0 6px rgba(119, 229, 255, 0.18); }

.os-float {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.64));
  box-shadow: 0 24px 64px rgba(7, 17, 31, 0.16);
  backdrop-filter: blur(24px);
  transform-style: preserve-3d;
}

.os-float strong {
  display: block;
  color: var(--navy-950);
  letter-spacing: -0.045em;
  line-height: 1.04;
}

.os-float p {
  margin: 7px 0 0;
  color: var(--slate-600);
  font-size: 0.79rem;
  line-height: 1.38;
}

.board-pack-card {
  left: 0;
  top: 126px;
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 14px;
  width: 292px;
  padding: 16px;
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(-7deg);
  animation: heroFloat 7.2s ease-in-out infinite;
}

.mini-doc-stack {
  position: relative;
  min-height: 82px;
}

.mini-doc-stack span {
  position: absolute;
  width: 54px;
  height: 70px;
  border: 1px solid rgba(216, 222, 232, 0.82);
  border-radius: 12px;
  background:
    linear-gradient(90deg, rgba(21, 54, 93, 0.12) 0 30%, transparent 30% 100%) 12px 16px / 30px 5px no-repeat,
    linear-gradient(90deg, rgba(79, 140, 255, 0.18), rgba(244, 211, 123, 0.16)),
    white;
  box-shadow: 0 8px 18px rgba(7, 17, 31, 0.08);
}

.mini-doc-stack span:nth-child(1) { left: 0; top: 10px; transform: rotate(-8deg); }
.mini-doc-stack span:nth-child(2) { left: 12px; top: 4px; transform: rotate(4deg); }
.mini-doc-stack span:nth-child(3) { left: 24px; top: 0; transform: rotate(10deg); }

.ai-flow-card {
  right: 8px;
  top: 366px;
  width: 306px;
  padding: 18px;
  color: white;
  background:
    radial-gradient(circle at 100% 0%, rgba(119, 229, 255, 0.26), transparent 36%),
    linear-gradient(145deg, rgba(7, 17, 31, 0.95), rgba(21, 54, 93, 0.92));
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(5deg);
  animation: heroFloat 7.8s ease-in-out infinite -2.4s;
}

.ai-flow-card small,
.ai-flow-card p {
  color: rgba(255, 255, 255, 0.66);
}

.ai-flow-card strong {
  color: white;
  font-size: 1.14rem;
}

.ai-badge {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  margin-bottom: 13px;
  border-radius: 16px;
  color: var(--navy-950);
  background: linear-gradient(135deg, var(--cyan-300), var(--gold-300));
  font-size: 0.86rem;
  font-weight: 950;
  box-shadow: 0 18px 40px rgba(119, 229, 255, 0.18);
}

.mini-flow {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
}

.mini-flow span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.68rem;
  font-weight: 850;
}

.mini-flow i {
  flex: 1;
  height: 1px;
  min-width: 12px;
  background: linear-gradient(90deg, rgba(119, 229, 255, 0.1), rgba(119, 229, 255, 0.88));
}

.margin-bridge-card {
  left: 26px;
  bottom: 58px;
  width: 254px;
  padding: 18px;
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(6deg);
  animation: heroFloat 8.2s ease-in-out infinite -4s;
}

.margin-bridge-card strong {
  margin-top: 4px;
  font-size: 1.18rem;
}

.bridge-bars {
  display: flex;
  align-items: end;
  gap: 8px;
  height: 74px;
  margin-top: 14px;
  padding: 10px 12px;
  border-radius: 16px;
  background: #f6f8fb;
}

.bridge-bars span {
  flex: 1;
  height: var(--h);
  min-height: 18px;
  border-radius: 999px 999px 4px 4px;
  background: linear-gradient(180deg, var(--gold-300), var(--blue-400));
  transform-origin: bottom;
  animation: barGrow 1.8s var(--ease) both;
}

.bridge-bars span:nth-child(2) { animation-delay: 120ms; }
.bridge-bars span:nth-child(3) { animation-delay: 240ms; }
.bridge-bars span:nth-child(4) { animation-delay: 360ms; }
.bridge-bars span:nth-child(5) { animation-delay: 480ms; }

.roadmap-timeline-card {
  right: 76px;
  bottom: 0;
  width: 292px;
  padding: 18px;
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(-5deg);
  animation: heroFloat 7.6s ease-in-out infinite -1.8s;
}

.timeline-list {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.timeline-list div {
  display: grid;
  grid-template-columns: 12px 84px 1fr;
  gap: 9px;
  align-items: center;
}

.timeline-list span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--gold-300);
  box-shadow: 0 0 0 6px rgba(244, 211, 123, 0.14);
}

.timeline-list b {
  color: var(--navy-950);
  font-size: 0.82rem;
}

.timeline-list em {
  color: var(--slate-500);
  font-style: normal;
  font-size: 0.78rem;
  font-weight: 760;
}

@keyframes drawTrend {
  to { stroke-dashoffset: 0; }
}

@keyframes chartDotPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.42); opacity: 0.72; }
}

@keyframes progressPulse {
  0%, 100% { filter: saturate(1); transform: translateX(0); }
  50% { filter: saturate(1.35); transform: translateX(4%); }
}

@keyframes barGrow {
  from { transform: scaleY(0.18); opacity: 0.35; }
  to { transform: scaleY(1); opacity: 1; }
}

@keyframes heroFloat {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -10px; }
}

@keyframes consoleSheen {
  0%, 42% { transform: translateX(-70%); }
  62%, 100% { transform: translateX(70%); }
}

@keyframes streamDrift {
  0%, 100% { transform: translate3d(-18px, 0, 0) rotate(-13deg); opacity: 0.26; }
  48% { transform: translate3d(32px, -6px, 0) rotate(-13deg); opacity: 0.82; }
}

@media (max-width: 1180px) {
  .hero-command .hero-grid {
    grid-template-columns: minmax(0, 0.9fr) minmax(500px, 1.1fr);
    gap: 28px;
  }

  .ops-console {
    width: 570px;
  }

  .board-pack-card {
    left: -8px;
  }
}

@media (max-width: 1020px) {
  .hero.hero-command {
    min-height: auto;
    padding-top: 150px;
  }

  .hero-command .hero-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .hero-proof-row {
    max-width: none;
  }

  .hero-visual.hero-operating-scene {
    width: min(100%, 760px);
    min-height: 740px;
    margin-inline: auto;
  }

  .ops-console {
    left: 50%;
    right: auto;
    top: 82px;
    width: min(94%, 620px);
    transform: translate3d(calc(-50% + var(--parallax-x)), var(--parallax-y), 0) rotateX(7deg) rotateY(-7deg) rotateZ(1deg);
  }

  .board-pack-card { left: 16px; top: 20px; }
  .ai-flow-card { right: 18px; top: 392px; }
  .margin-bridge-card { left: 42px; bottom: 74px; }
  .roadmap-timeline-card { right: 46px; bottom: 0; }
  .chip-forecast { left: 156px; top: 44px; }
  .chip-risk { right: 92px; top: 34px; }
  .chip-ai { right: 30px; bottom: 126px; }
}

@media (max-width: 720px) {
  .hero.hero-command {
    padding-top: 132px;
  }

  .hero-proof-row {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .hero-proof-row div {
    min-height: auto;
    padding: 15px 16px;
  }

  .hero-visual.hero-operating-scene {
    min-height: 790px;
  }

  .scene-grid-floor {
    right: -190px;
    width: 620px;
  }

  .ops-console {
    top: 116px;
    width: min(100%, 520px);
    min-height: auto;
    border-radius: 30px;
    transform: translate3d(calc(-50% + var(--parallax-x)), var(--parallax-y), 0);
  }

  .ops-toolbar {
    padding: 13px 14px;
  }

  .ops-toolbar-tabs {
    display: none;
  }

  .ops-console-body {
    padding: 16px;
  }

  .ops-hero-row {
    align-items: stretch;
    flex-direction: column;
  }

  .ops-score {
    text-align: left;
  }

  .ops-layout,
  .roadmap-board {
    grid-template-columns: 1fr;
  }

  .roadmap-panel {
    grid-column: auto;
  }

  .trend-chart {
    height: 132px;
  }

  .decision-panel strong {
    font-size: 2.9rem;
  }

  .system-status-chip {
    font-size: 0.72rem;
    min-height: 31px;
  }

  .chip-forecast { left: 8px; top: 32px; }
  .chip-risk { right: 0; top: 74px; }
  .chip-ai { right: 12px; bottom: 74px; }

  .board-pack-card {
    left: 0;
    top: 0;
    width: 248px;
    grid-template-columns: 60px 1fr;
    transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(-4deg);
  }

  .ai-flow-card {
    top: auto;
    right: 0;
    bottom: 188px;
    width: 258px;
    transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(3deg);
  }

  .margin-bridge-card {
    left: 0;
    bottom: 52px;
    width: 226px;
    transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(4deg);
  }

  .roadmap-timeline-card {
    right: 0;
    bottom: 0;
    width: 252px;
    transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateZ(-3deg);
  }

  .timeline-list div {
    grid-template-columns: 12px 74px 1fr;
  }
}

@media (max-width: 520px) {
  .hero-visual.hero-operating-scene {
    min-height: 850px;
  }

  .ops-console {
    top: 132px;
    width: 100%;
  }

  .ops-toolbar strong {
    font-size: 0.78rem;
  }

  .window-dots {
    gap: 5px;
  }

  .window-dots span {
    width: 8px;
    height: 8px;
  }

  .roadmap-lane-card {
    min-height: auto;
  }

  .forecast-panel,
  .decision-panel,
  .roadmap-panel {
    padding: 14px;
  }

  .board-pack-card {
    width: 226px;
  }

  .ai-flow-card {
    bottom: 224px;
    width: 232px;
  }

  .margin-bridge-card {
    bottom: 88px;
    width: 210px;
  }

  .roadmap-timeline-card {
    width: 226px;
  }

  .chip-risk {
    display: none;
  }
}

/* Final hero balance pass */
.hero-command .hero-copy h1 {
  max-width: 680px;
  font-size: clamp(3.35rem, 5.85vw, 5.45rem);
  line-height: 0.94;
}

@media (max-width: 720px) {
  .hero-command .hero-copy h1 {
    font-size: clamp(3rem, 14.5vw, 4.85rem);
  }
}


/* Interactive bento services grid */
.bento-services {
  position: relative;
}

.bento-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-areas:
    "finance finance strategy"
    "finance finance ai"
    "people fractional fractional";
  gap: 18px;
}

.bento-card {
  --accent: rgba(79, 140, 255, 0.3);
  position: relative;
  overflow: hidden;
  min-height: 250px;
  padding: 24px;
  border-radius: 30px;
  border: 1px solid rgba(216, 222, 232, 0.86);
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.74), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(245, 248, 253, 0.92));
  box-shadow: 0 22px 64px rgba(7, 17, 31, 0.08);
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms ease;
  outline: none;
  cursor: pointer;
}

.bento-card::before {
  content: "";
  position: absolute;
  inset: auto -54px -68px auto;
  width: 190px;
  height: 190px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--accent), transparent 70%);
  pointer-events: none;
}

.bento-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
  pointer-events: none;
}

.bento-card:hover,
.bento-card:focus-visible,
.bento-card.is-active {
  transform: translateY(-6px);
  box-shadow: 0 28px 78px rgba(7, 17, 31, 0.13);
  border-color: rgba(79, 140, 255, 0.32);
}

.bento-card.is-active {
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.84), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(244, 248, 255, 0.96));
}

.bento-finance { grid-area: finance; --accent: rgba(79, 140, 255, 0.24); }
.bento-strategy { grid-area: strategy; --accent: rgba(244, 211, 123, 0.26); }
.bento-ai { grid-area: ai; --accent: rgba(119, 229, 255, 0.24); }
.bento-people { grid-area: people; --accent: rgba(130, 239, 172, 0.22); }
.bento-fractional { grid-area: fractional; --accent: rgba(165, 155, 255, 0.2); }

.bento-card-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.bento-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding-inline: 10px;
  border-radius: 14px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff7dd, #f4d37b);
  font-size: 0.83rem;
  font-weight: 950;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.bento-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(16, 35, 61, 0.06);
  color: var(--navy-800);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.bento-card h3 {
  position: relative;
  z-index: 1;
  margin: 18px 0 10px;
  color: var(--navy-950);
  font-size: clamp(1.32rem, 1.7vw, 1.9rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
  max-width: 16ch;
}

.bento-card p {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: 58ch;
  color: var(--slate-600);
}

.bento-surface {
  position: relative;
  z-index: 1;
  margin-top: 18px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.68);
  background: rgba(241, 246, 253, 0.88);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68);
}

.surface-header,
.surface-pills,
.signal-row,
.mini-status-row,
.flow-line,
.cadence-grid,
.strategy-lanes,
.surface-checklist {
  position: relative;
  z-index: 1;
}

.surface-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
  color: var(--slate-500);
  font-size: 0.78rem;
  font-weight: 800;
}

.surface-header strong {
  color: var(--navy-950);
  font-size: 0.88rem;
}

.surface-header.compact {
  margin-bottom: 12px;
}

.surface-pills,
.signal-row,
.mini-status-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.surface-pills span,
.signal-row span,
.mini-status-row small {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--navy-800);
  font-size: 0.72rem;
  font-weight: 800;
}

.close-bars,
.workforce-bars {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  align-items: end;
  height: 112px;
  margin: 14px 0;
}

.workforce-bars {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  height: 88px;
}

.close-bars i,
.workforce-bars i {
  display: block;
  height: var(--h);
  border-radius: 14px 14px 8px 8px;
  background: linear-gradient(180deg, rgba(79, 140, 255, 0.9), rgba(31, 88, 157, 0.82));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.workforce-bars i {
  background: linear-gradient(180deg, rgba(130, 239, 172, 0.98), rgba(58, 172, 107, 0.86));
}

.surface-checklist {
  display: grid;
  gap: 8px;
}

.surface-checklist div,
.timeline-list div {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 10px;
  align-items: center;
  color: var(--slate-600);
  font-size: 0.82rem;
  font-weight: 700;
}

.surface-checklist span {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, #77e5ff, #4f8cff);
  box-shadow: 0 0 0 4px rgba(79, 140, 255, 0.12);
}

.strategy-lanes {
  display: grid;
  gap: 8px;
}

.strategy-lanes div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.84);
  color: var(--navy-900);
  font-size: 0.8rem;
  font-weight: 850;
}

.strategy-lanes span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(244, 211, 123, 0.46);
  color: var(--navy-950);
}

.flow-line {
  display: grid;
  grid-template-columns: auto 1fr auto 1fr auto 1fr auto;
  gap: 8px;
  align-items: center;
}

.flow-line div {
  display: grid;
  place-items: center;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.84);
  color: var(--navy-950);
  font-size: 0.74rem;
  font-weight: 850;
}

.flow-line span {
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(79, 140, 255, 0.7), rgba(119, 229, 255, 0.92));
}

.mini-status-row {
  margin-top: 12px;
}

.mini-status-row.alerts small {
  background: rgba(255, 255, 255, 0.9);
}

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

.cadence-grid div {
  min-height: 68px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.84);
}

.cadence-grid b {
  display: block;
  color: var(--navy-950);
  font-size: 0.82rem;
  letter-spacing: -0.02em;
}

.cadence-grid span {
  color: var(--slate-600);
  font-size: 0.76rem;
  font-weight: 700;
}

.service-spotlight {
  margin-top: 18px;
  padding: 22px 24px;
  border-radius: 26px;
  border: 1px solid rgba(216, 222, 232, 0.84);
  background: linear-gradient(180deg, rgba(16, 35, 61, 0.02), rgba(255, 255, 255, 0.92));
  box-shadow: 0 18px 54px rgba(7, 17, 31, 0.07);
}

.spotlight-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.spotlight-note {
  color: var(--slate-500);
  font-size: 0.82rem;
  font-weight: 800;
}

.spotlight-body {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr auto;
  gap: 24px;
  align-items: center;
  margin-top: 16px;
}

.service-spotlight h3 {
  margin: 0 0 8px;
  color: var(--navy-950);
  font-size: clamp(1.55rem, 2.2vw, 2.2rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
}

.service-spotlight p {
  margin: 0;
  color: var(--slate-600);
}

.spotlight-list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.spotlight-list li {
  position: relative;
  padding-left: 18px;
  color: var(--navy-900);
  font-weight: 800;
}

.spotlight-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #77e5ff, #4f8cff);
  box-shadow: 0 0 0 4px rgba(79, 140, 255, 0.1);
}

.spotlight-cta-wrap {
  display: flex;
  justify-content: flex-end;
}

@media (max-width: 1020px) {
  .bento-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "finance finance"
      "strategy ai"
      "people fractional";
  }

  .spotlight-body {
    grid-template-columns: 1fr;
  }

  .spotlight-cta-wrap {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .bento-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "finance"
      "strategy"
      "ai"
      "people"
      "fractional";
  }

  .bento-card {
    min-height: auto;
    padding: 20px;
  }

  .flow-line {
    grid-template-columns: 1fr;
  }

  .flow-line span {
    height: 14px;
    width: 2px;
    margin-inline: auto;
  }

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

  .service-spotlight {
    padding: 20px;
  }
}


/* Premium proof / customer story section */
.premium-proof {
  position: relative;
}

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

.proof-spotlight,
.proof-story-card,
.proof-quote-card,
.proof-stat-band {
  border: 1px solid rgba(216, 222, 232, 0.86);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,253,0.94));
  box-shadow: 0 22px 64px rgba(7, 17, 31, 0.08);
}

.proof-spotlight {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  padding: 28px;
}

.proof-spotlight::before {
  content: "";
  position: absolute;
  right: -60px;
  top: -40px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79, 140, 255, 0.14), transparent 68%);
  pointer-events: none;
}

.proof-spotlight::after {
  content: "";
  position: absolute;
  left: -50px;
  bottom: -70px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(244, 211, 123, 0.16), transparent 68%);
  pointer-events: none;
}

.proof-spotlight-topline {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.proof-kicker,
.proof-company {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(16, 35, 61, 0.06);
  color: var(--navy-800);
  font-size: 0.78rem;
  font-weight: 850;
}

.proof-spotlight-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.9fr);
  gap: 22px;
  align-items: stretch;
}

.proof-spotlight-copy h3 {
  margin: 0 0 14px;
  color: var(--navy-950);
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 0.98;
  letter-spacing: -0.055em;
  max-width: 14ch;
}

.proof-spotlight-copy p {
  margin: 0;
  color: var(--slate-600);
  max-width: 58ch;
}

.proof-capability-block {
  margin-top: 22px;
}

.proof-capability-block > span {
  display: block;
  margin-bottom: 10px;
  color: var(--slate-500);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.proof-capability-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.proof-capability-pills span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(216, 222, 232, 0.9);
  color: var(--navy-900);
  font-size: 0.78rem;
  font-weight: 850;
}

.proof-actions {
  margin-top: 24px;
}

.proof-visual-card {
  position: relative;
  overflow: hidden;
  padding: 18px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(16, 35, 61, 0.98), rgba(25, 58, 94, 0.98));
  color: white;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 24px 64px rgba(7, 17, 31, 0.18);
}

.proof-visual-card::before {
  content: "";
  position: absolute;
  inset: auto -20% -28% auto;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(119, 229, 255, 0.24), transparent 70%);
}

.proof-visual-header {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 14px;
  color: rgba(255,255,255,0.72);
  font-size: 0.8rem;
  font-weight: 800;
}

.proof-visual-header strong {
  color: white;
}

.proof-metric-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.proof-metric-grid div {
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
}

.proof-metric-grid small {
  display: block;
  color: rgba(255,255,255,0.68);
  font-size: 0.72rem;
  font-weight: 800;
}

.proof-metric-grid strong {
  display: block;
  margin: 8px 0 4px;
  color: white;
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: -0.04em;
}

.proof-metric-grid span {
  color: rgba(255,255,255,0.76);
  font-size: 0.76rem;
  font-weight: 700;
}

.proof-visual-surface {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.proof-surface-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 14px;
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.82);
  font-size: 0.78rem;
  font-weight: 800;
}

.proof-surface-row b {
  color: white;
}

.proof-sidebar {
  display: grid;
  gap: 16px;
}

.proof-story-list {
  display: grid;
  gap: 14px;
}

.proof-story-card {
  text-align: left;
  padding: 18px;
  border-radius: 24px;
  cursor: pointer;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms ease, background 220ms ease;
}

.proof-story-card:hover,
.proof-story-card:focus-visible,
.proof-story-card.is-active {
  transform: translateY(-4px);
  border-color: rgba(79, 140, 255, 0.34);
  box-shadow: 0 24px 64px rgba(7, 17, 31, 0.11);
  outline: none;
}

.proof-story-tag {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(16, 35, 61, 0.06);
  color: var(--navy-800);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.proof-story-card strong {
  display: block;
  margin-top: 14px;
  color: var(--navy-950);
  font-size: 1.08rem;
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.proof-story-card p {
  margin: 8px 0 0;
  color: var(--slate-600);
  font-size: 0.92rem;
}

.proof-quote-card {
  position: relative;
  overflow: hidden;
  padding: 22px 20px 20px;
  border-radius: 26px;
}

.proof-quote-mark {
  position: absolute;
  top: 6px;
  right: 14px;
  color: rgba(79, 140, 255, 0.16);
  font-size: 5rem;
  line-height: 1;
  font-weight: 900;
}

.proof-quote-card p {
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--navy-900);
  font-size: 1.02rem;
  line-height: 1.6;
}

.proof-quote-card footer {
  position: relative;
  z-index: 1;
  margin-top: 12px;
  color: var(--slate-500);
  font-size: 0.82rem;
  font-weight: 800;
}

.proof-stat-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 18px;
  border-radius: 28px;
  overflow: hidden;
}

.proof-stat-block {
  padding: 22px 24px;
}

.proof-stat-block + .proof-stat-block {
  border-left: 1px solid rgba(216, 222, 232, 0.86);
}

.proof-stat-block small {
  display: block;
  color: var(--slate-500);
  font-size: 0.75rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.proof-stat-block strong {
  display: block;
  margin: 8px 0 6px;
  color: var(--navy-950);
  font-size: 1.4rem;
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.proof-stat-block span {
  color: var(--slate-600);
}

@media (max-width: 1020px) {
  .proof-showcase,
  .proof-spotlight-grid {
    grid-template-columns: 1fr;
  }

  .proof-spotlight-copy h3 {
    max-width: none;
  }

  .proof-stat-band {
    grid-template-columns: 1fr;
  }

  .proof-stat-block + .proof-stat-block {
    border-left: 0;
    border-top: 1px solid rgba(216, 222, 232, 0.86);
  }
}

@media (max-width: 720px) {
  .proof-spotlight {
    padding: 20px;
    border-radius: 28px;
  }

  .proof-metric-grid {
    grid-template-columns: 1fr 1fr;
  }

  .proof-story-card,
  .proof-quote-card,
  .proof-stat-block {
    padding: 18px;
  }
}

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


/* Simplified homepage pass: calmer hero, service cards, and combined proof */
.simplified-home-hero {
  min-height: 840px;
  background:
    radial-gradient(circle at 8% 12%, rgba(79, 140, 255, 0.16), transparent 32%),
    radial-gradient(circle at 76% 8%, rgba(244, 211, 123, 0.18), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f6f9fe 58%, #eef4fb 100%);
}

.simplified-home-hero::before {
  opacity: 0.38;
}

.simplified-home-hero .orb-three,
.simplified-home-hero .stream-two,
.simplified-home-hero .stream-three,
.simplified-home-hero .slab-two {
  display: none;
}

.simplified-home-hero .gradient-slab {
  opacity: 0.38;
}

.simplified-home-hero .trust-strip {
  margin-top: 30px;
}

.simplified-hero-scene {
  min-height: 560px;
}

.simplified-hero-scene .scene-halo {
  inset: 36px 12px 20px 0;
  filter: blur(22px);
  opacity: 0.72;
}

.simplified-hero-scene .scene-grid-floor {
  right: -72px;
  bottom: -96px;
  opacity: 0.34;
}

.calm-console,
.support-card,
.quiet-status-chip {
  --parallax-x: 0px;
  --parallax-y: 0px;
  position: absolute;
  z-index: 2;
  will-change: transform;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms ease;
}

.calm-console {
  right: 8px;
  top: 54px;
  width: min(100%, 590px);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.74);
  border-radius: 36px;
  background:
    radial-gradient(circle at 94% 0%, rgba(119, 229, 255, 0.13), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(243,247,253,0.86));
  box-shadow: 0 32px 86px rgba(7, 17, 31, 0.18), inset 0 1px 0 rgba(255,255,255,0.86);
  backdrop-filter: blur(24px);
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0) rotateX(6deg) rotateY(-9deg) rotateZ(1deg);
}

.calm-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(185, 193, 207, 0.32);
  background: rgba(255, 255, 255, 0.62);
}

.calm-toolbar strong {
  color: var(--navy-950);
  font-size: 0.92rem;
  letter-spacing: -0.025em;
}

.calm-toolbar em {
  margin-left: auto;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  color: var(--navy-800);
  background: rgba(16, 35, 61, 0.06);
  font-style: normal;
  font-size: 0.74rem;
  font-weight: 900;
}

.calm-console-body {
  padding: 22px;
}

.calm-console-header {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.calm-console-header h2 {
  margin: 6px 0 0;
  color: var(--navy-950);
  font-size: clamp(1.8rem, 3vw, 2.7rem);
  line-height: 0.96;
  letter-spacing: -0.055em;
}

.calm-score {
  min-width: 132px;
  padding: 14px;
  border-radius: 20px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(216,222,232,0.72);
  text-align: right;
}

.calm-score span,
.calm-panel-header span {
  display: block;
  color: var(--slate-500);
  font-size: 0.72rem;
  font-weight: 850;
}

.calm-score strong {
  display: block;
  margin-top: 6px;
  color: var(--navy-950);
  font-size: 1.75rem;
  line-height: 1;
  letter-spacing: -0.06em;
}

.calm-dashboard-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 14px;
}

.calm-panel {
  min-height: 250px;
  padding: 17px;
  border-radius: 24px;
  border: 1px solid rgba(216,222,232,0.72);
  background: rgba(255,255,255,0.68);
}

.calm-panel-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
}

.calm-panel-header strong {
  color: var(--navy-900);
  font-size: 0.82rem;
}

.calm-roadmap-list {
  display: grid;
  gap: 10px;
}

.calm-roadmap-list div {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  gap: 10px;
  align-items: center;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 15px;
  background: rgba(248,250,252,0.88);
}

.calm-roadmap-list span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: linear-gradient(135deg, #77e5ff, #4f8cff);
  box-shadow: 0 0 0 4px rgba(79, 140, 255, 0.1);
}

.calm-roadmap-list b {
  color: var(--navy-900);
  font-size: 0.78rem;
  letter-spacing: -0.02em;
}

.calm-roadmap-list em {
  color: var(--slate-500);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 800;
}

.calm-line-chart {
  width: 100%;
  height: 170px;
}

.calm-grid-line {
  fill: none;
  stroke: rgba(185,193,207,0.55);
  stroke-width: 1;
}

.calm-chart-fill {
  fill: rgba(79, 140, 255, 0.1);
}

.calm-chart-line {
  fill: none;
  stroke: url(#calmTrend);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-dasharray: 420;
  stroke-dashoffset: 420;
  animation: drawLine 1.4s ease forwards 0.45s;
}

.calm-chart-dot {
  fill: #f4d37b;
  filter: drop-shadow(0 8px 14px rgba(185,138,46,0.26));
}

.quiet-status-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 13px;
  border-radius: 999px;
  border: 1px solid rgba(216, 222, 232, 0.82);
  background: rgba(255,255,255,0.82);
  color: var(--navy-800);
  box-shadow: 0 14px 34px rgba(7,17,31,0.08);
  backdrop-filter: blur(18px);
  font-size: 0.78rem;
  font-weight: 900;
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0);
}

.quiet-status-chip span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green-300);
  box-shadow: 0 0 0 6px rgba(130,239,172,0.18);
}

.chip-board-ready { left: 26px; top: 74px; }
.chip-ai-live { right: 6px; bottom: 112px; }

.support-card {
  width: 230px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.72);
  background: rgba(255,255,255,0.82);
  box-shadow: 0 22px 54px rgba(7,17,31,0.1);
  backdrop-filter: blur(18px);
  transform: translate3d(var(--parallax-x), var(--parallax-y), 0);
}

.support-card small {
  display: block;
  color: var(--slate-500);
  font-size: 0.72rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.support-card strong {
  display: block;
  margin: 5px 0 5px;
  color: var(--navy-950);
  font-size: 1.05rem;
  line-height: 1.05;
  letter-spacing: -0.035em;
}

.support-card p {
  margin: 0;
  color: var(--slate-600);
  font-size: 0.82rem;
  line-height: 1.35;
}

.board-ready-card {
  left: 10px;
  bottom: 78px;
}

.ai-live-card {
  right: 54px;
  top: 0;
}

.support-flow {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
}

.support-flow span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(16,35,61,0.06);
  color: var(--navy-800);
  font-size: 0.68rem;
  font-weight: 850;
}

.support-flow i {
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #4f8cff, #77e5ff);
}

.simple-services {
  background: linear-gradient(180deg, #ffffff, #f8fbff);
}

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

.simple-service-card,
.embedded-support-strip,
.featured-proof-card,
.proof-metrics-panel,
.proof-metric-card,
.simple-quote-card {
  border: 1px solid rgba(216,222,232,0.86);
  background: rgba(255,255,255,0.88);
  box-shadow: 0 18px 52px rgba(7,17,31,0.065);
}

.simple-service-card {
  position: relative;
  overflow: hidden;
  min-height: 330px;
  padding: 26px;
  border-radius: 28px;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms ease;
}

.simple-service-card:hover {
  transform: translateY(-4px);
  border-color: rgba(79, 140, 255, 0.26);
  box-shadow: 0 24px 64px rgba(7,17,31,0.09);
}

.simple-service-topline {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: var(--navy-800);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.simple-service-icon {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff7dd, var(--gold-300));
  letter-spacing: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.52);
}

.simple-service-card h3 {
  margin: 0 0 10px;
  max-width: 16ch;
  color: var(--navy-950);
  font-size: clamp(1.55rem, 2.2vw, 2.25rem);
  line-height: 1;
  letter-spacing: -0.055em;
}

.simple-service-card p {
  max-width: 60ch;
  margin: 0;
  color: var(--slate-600);
}

.simple-service-card a {
  position: absolute;
  left: 26px;
  bottom: 24px;
  color: var(--navy-700);
  font-weight: 900;
}

.simple-service-card a::after {
  content: "→";
  margin-left: 8px;
  transition: transform 180ms var(--ease);
}

.simple-service-card a:hover::after {
  display: inline-block;
  transform: translateX(4px);
}

.simple-mini {
  margin-top: 22px;
  margin-bottom: 42px;
  padding: 16px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(248,250,252,0.94), rgba(241,246,253,0.78));
  border: 1px solid rgba(216,222,232,0.72);
}

.finance-mini {
  display: grid;
  gap: 10px;
}

.finance-mini i {
  display: block;
  width: var(--w);
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, #4f8cff, #77e5ff);
}

.roadmap-mini {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.roadmap-mini div {
  min-height: 64px;
  display: grid;
  align-content: center;
  gap: 8px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255,255,255,0.78);
}

.roadmap-mini span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--gold-300);
}

.roadmap-mini b {
  color: var(--navy-900);
  font-size: 0.76rem;
}

.ai-mini {
  display: grid;
  grid-template-columns: auto 1fr auto 1fr auto;
  gap: 8px;
  align-items: center;
}

.ai-mini span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.84);
  color: var(--navy-900);
  font-size: 0.74rem;
  font-weight: 850;
}

.ai-mini i {
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #4f8cff, #77e5ff);
}

.people-mini {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  align-items: end;
  height: 112px;
}

.people-mini i {
  display: block;
  height: var(--h);
  border-radius: 14px 14px 8px 8px;
  background: linear-gradient(180deg, rgba(130,239,172,0.95), rgba(58,172,107,0.82));
}

.embedded-support-strip {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  margin-top: 18px;
  padding: 24px 26px;
  border-radius: 28px;
}

.embedded-support-strip span {
  display: block;
  color: var(--slate-500);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.embedded-support-strip h3 {
  max-width: 760px;
  margin: 7px 0 0;
  color: var(--navy-950);
  font-size: clamp(1.2rem, 2vw, 1.8rem);
  line-height: 1.08;
  letter-spacing: -0.04em;
}

.simplified-proof {
  background:
    radial-gradient(circle at 10% 0%, rgba(79,140,255,0.08), transparent 32%),
    linear-gradient(180deg, #f8fbff, #ffffff);
}

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

.featured-proof-card {
  position: relative;
  overflow: hidden;
  min-height: 520px;
  padding: 32px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 100% 0%, rgba(79,140,255,0.12), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,253,0.94));
}

.featured-proof-topline {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.featured-proof-topline span,
.featured-proof-topline strong {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(16,35,61,0.06);
  color: var(--navy-800);
  font-size: 0.78rem;
  font-weight: 850;
}

.featured-proof-card h3 {
  max-width: 13ch;
  margin: 0 0 16px;
  color: var(--navy-950);
  font-size: clamp(2.2rem, 4.4vw, 4.25rem);
  line-height: 0.94;
  letter-spacing: -0.07em;
}

.featured-proof-card p {
  max-width: 650px;
  margin: 0;
  color: var(--slate-600);
  font-size: 1.05rem;
}

.proof-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.proof-pill-row span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(216,222,232,0.84);
  color: var(--navy-900);
  font-size: 0.78rem;
  font-weight: 850;
}

.proof-readout {
  position: absolute;
  right: 28px;
  bottom: 28px;
  width: min(360px, calc(100% - 56px));
  display: grid;
  gap: 10px;
}

.proof-readout div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 15px;
  background: rgba(255,255,255,0.76);
  border: 1px solid rgba(216,222,232,0.72);
}

.proof-readout span {
  color: var(--slate-600);
  font-size: 0.78rem;
  font-weight: 850;
}

.proof-readout b {
  color: var(--navy-950);
  font-size: 0.8rem;
}

.proof-metrics-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(16,35,61,0.98), rgba(25,58,94,0.98));
  color: white;
}

.proof-metric-card,
.simple-quote-card {
  padding: 20px;
  border-radius: 22px;
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.1);
  box-shadow: none;
}

.proof-metric-card small {
  display: block;
  color: rgba(255,255,255,0.68);
  font-size: 0.74rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.proof-metric-card strong {
  display: block;
  margin: 8px 0 4px;
  color: white;
  font-size: clamp(2.1rem, 4vw, 3.2rem);
  line-height: 0.95;
  letter-spacing: -0.07em;
}

.proof-metric-card span {
  color: rgba(255,255,255,0.78);
  font-size: 0.92rem;
  font-weight: 700;
}

.simple-quote-card p {
  margin: 0;
  color: rgba(255,255,255,0.9);
  font-size: 1rem;
  line-height: 1.6;
}

.simple-quote-card footer {
  margin-top: 12px;
  color: rgba(255,255,255,0.62);
  font-size: 0.82rem;
  font-weight: 850;
}

@media (max-width: 1180px) {
  .calm-console {
    width: 550px;
  }

  .chip-board-ready {
    left: 0;
  }
}

@media (max-width: 1020px) {
  .simplified-home-hero {
    min-height: auto;
  }

  .simplified-hero-scene {
    width: min(100%, 740px);
    min-height: 650px;
    margin-inline: auto;
  }

  .calm-console {
    left: 50%;
    right: auto;
    width: min(94%, 610px);
    transform: translate3d(calc(-50% + var(--parallax-x)), var(--parallax-y), 0) rotateX(5deg) rotateY(-5deg) rotateZ(1deg);
  }

  .simple-service-grid,
  .simplified-proof-grid {
    grid-template-columns: 1fr;
  }

  .embedded-support-strip {
    align-items: flex-start;
    flex-direction: column;
  }

  .featured-proof-card {
    min-height: 500px;
  }
}

@media (max-width: 720px) {
  .simplified-hero-scene {
    min-height: 720px;
  }

  .calm-console {
    top: 92px;
    width: 100%;
    border-radius: 28px;
    transform: translate3d(calc(-50% + var(--parallax-x)), var(--parallax-y), 0);
  }

  .calm-console-body,
  .simple-service-card,
  .featured-proof-card {
    padding: 20px;
  }

  .calm-console-header,
  .calm-dashboard-grid {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .calm-score {
    width: 100%;
    text-align: left;
  }

  .calm-dashboard-grid,
  .simple-service-grid {
    display: grid;
    grid-template-columns: 1fr;
  }

  .chip-board-ready {
    left: 0;
    top: 18px;
  }

  .chip-ai-live {
    right: 0;
    bottom: 94px;
  }

  .support-card {
    width: 220px;
  }

  .board-ready-card {
    left: 0;
    bottom: 38px;
  }

  .ai-live-card {
    right: 0;
    top: 34px;
  }

  .simple-service-card {
    min-height: auto;
  }

  .simple-service-card a {
    position: static;
    display: inline-flex;
    margin-top: 18px;
  }

  .simple-mini {
    margin-bottom: 0;
  }

  .roadmap-mini,
  .ai-mini {
    grid-template-columns: 1fr;
  }

  .ai-mini i {
    width: 2px;
    height: 14px;
    margin-inline: auto;
  }

  .featured-proof-card {
    min-height: auto;
  }

  .featured-proof-card h3 {
    max-width: none;
  }

  .proof-readout {
    position: relative;
    right: auto;
    bottom: auto;
    width: 100%;
    margin-top: 24px;
  }
}

@media (max-width: 520px) {
  .simplified-hero-scene {
    min-height: 760px;
  }

  .calm-toolbar em {
    display: none;
  }

  .support-card {
    width: 205px;
  }
}


/* Editorial chess hero replacement */
.editorial-chess-hero {
  min-height: 780px;
  padding: 154px 0 0;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.96) 36%, rgba(248, 250, 253, 0.54) 58%, rgba(241, 244, 248, 0.8) 100%),
    radial-gradient(circle at 14% 22%, rgba(255, 255, 255, 0.96), transparent 36%),
    linear-gradient(180deg, #ffffff 0%, #f5f7fa 100%);
}

.editorial-hero-atmosphere {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(7, 17, 31, 0.05) 0, transparent 1px) top/100% 1px no-repeat,
    radial-gradient(circle at 20% 34%, rgba(255, 255, 255, 0.86), transparent 28%),
    radial-gradient(circle at 76% 28%, rgba(16, 35, 61, 0.06), transparent 34%);
}

.editorial-hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(360px, 0.82fr) minmax(520px, 1.18fr);
  gap: 28px;
  align-items: stretch;
  min-height: 626px;
}

.editorial-hero-copy {
  position: relative;
  z-index: 4;
  align-self: center;
  max-width: 560px;
  padding-bottom: 40px;
}

.strategy-headline {
  margin: 0;
  color: var(--navy-950);
  font-family: "Cormorant Garamond", "Bodoni 72", Didot, Georgia, "Times New Roman", serif;
  font-size: clamp(4.8rem, 7.6vw, 7.35rem);
  font-weight: 400;
  line-height: 0.88;
  letter-spacing: 0.015em;
  text-transform: uppercase;
  text-wrap: balance;
}

.strategy-headline span {
  display: block;
}

.strategy-marker {
  display: grid;
  grid-template-columns: 16px minmax(120px, 1fr);
  align-items: center;
  gap: 18px;
  width: min(100%, 430px);
  margin: 30px 0 18px;
}

.strategy-marker span {
  display: block;
  width: 11px;
  height: 11px;
  margin-left: 2px;
  transform: rotate(45deg);
  background: linear-gradient(135deg, #fff5cf 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  box-shadow: 0 0 0 6px rgba(217, 173, 79, 0.10);
}

.strategy-marker::after {
  content: "";
  display: block;
  height: 1px;
  background: linear-gradient(90deg, rgba(7, 17, 31, 0.18), rgba(217, 173, 79, 0.55), rgba(7, 17, 31, 0.06));
}

.editorial-kicker {
  margin: 0 0 20px;
  color: var(--navy-700);
  font-size: 0.88rem;
  font-weight: 900;
  letter-spacing: 0.42em;
  line-height: 1.5;
  text-transform: uppercase;
}

.hero-rule {
  display: block;
  width: 120px;
  height: 1px;
  margin: 24px 0 24px;
  border: 0;
  background: var(--navy-950);
  opacity: 0.85;
}

.editorial-hero-lede {
  max-width: 500px;
  margin: 0;
  color: var(--slate-700);
  font-size: 1.02rem;
  line-height: 1.72;
}

.editorial-actions {
  margin-top: 26px;
}

.editorial-chess-hero .button {
  min-width: 174px;
  min-height: 50px;
  border-radius: 3px;
  box-shadow: none;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease), background 200ms ease, color 200ms ease, border-color 200ms ease;
}

/* Primary: solid near-black fill with white text */
.editorial-chess-hero .button-primary {
  color: #ffffff;
  background: linear-gradient(135deg, var(--navy-950) 0%, #15213a 100%);
  box-shadow:
    0 14px 32px rgba(7, 17, 31, 0.30),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
}

.editorial-chess-hero .button-primary:hover {
  background: linear-gradient(135deg, #0d1929 0%, #1c2a47 100%);
  box-shadow:
    0 18px 42px rgba(7, 17, 31, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.10) inset;
}

/* Secondary: soft grey with grey border + dark text */
.editorial-chess-hero .button-secondary {
  color: var(--slate-700);
  background: rgba(237, 241, 246, 0.78);
  border: 1px solid var(--platinum-300);
  box-shadow: 0 6px 18px rgba(7, 17, 31, 0.06);
}

.editorial-chess-hero .button-secondary:hover {
  color: var(--navy-950);
  background: rgba(216, 222, 232, 0.86);
  border-color: var(--slate-500);
}

.hero-focus-line {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px;
  margin-top: 30px;
  color: var(--navy-950);
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
}

.hero-focus-line span {
  white-space: nowrap;
}

.hero-focus-line i {
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold-500);
  opacity: 0.7;
}

.editorial-chess-visual {
  position: relative;
  min-height: 626px;
  align-self: stretch;
}

.chess-photo-wrap {
  position: absolute;
  inset: -12px -16vw 0 -10vw;
  overflow: hidden;
}

.chess-photo-wrap::before,
.chess-photo-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.chess-photo-wrap::before {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.82) 10%, rgba(255, 255, 255, 0.08) 38%, rgba(255, 255, 255, 0) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.36) 0%, rgba(255, 255, 255, 0) 34%, rgba(255, 255, 255, 0.08) 100%);
}

.chess-photo-wrap::after {
  background: linear-gradient(180deg, transparent 80%, rgba(245, 247, 250, 0.94) 100%);
}

.chess-photo-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center bottom;
  filter: saturate(0.94) contrast(1.03);
  transform: scale(1.02);
}

@media (max-width: 1180px) {
  .editorial-hero-grid {
    grid-template-columns: minmax(330px, 0.9fr) minmax(430px, 1.1fr);
  }

  .strategy-headline {
    font-size: clamp(4.1rem, 7.4vw, 6.6rem);
  }

  .chess-photo-wrap {
    inset: 0 -20vw 0 -12vw;
  }
}

@media (max-width: 1020px) {
  .editorial-chess-hero {
    min-height: auto;
    padding-top: 142px;
  }

  .editorial-hero-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    min-height: 0;
  }

  .editorial-hero-copy {
    max-width: 720px;
    padding-bottom: 0;
  }

  .strategy-headline {
    font-size: clamp(4.2rem, 12vw, 7rem);
    max-width: 760px;
  }

  .editorial-chess-visual {
    min-height: 480px;
    margin-top: -10px;
  }

  .chess-photo-wrap {
    inset: 0 -16vw 0 -8vw;
  }

  .chess-photo-wrap::before {
    background:
      linear-gradient(90deg, rgba(255, 255, 255, 0.78) 0%, rgba(255, 255, 255, 0.16) 32%, rgba(255, 255, 255, 0) 100%),
      linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 42%, rgba(245, 247, 250, 0.42) 100%);
  }
}

@media (max-width: 720px) {
  .editorial-chess-hero {
    padding-top: 126px;
  }

  .strategy-headline {
    font-size: clamp(3.25rem, 16vw, 5rem);
    line-height: 0.92;
  }

  .strategy-marker {
    width: 100%;
    margin: 24px 0 16px;
  }

  .editorial-kicker {
    letter-spacing: 0.28em;
    font-size: 0.78rem;
  }

  .editorial-hero-lede {
    font-size: 0.98rem;
  }

  .editorial-actions {
    width: 100%;
  }

  .editorial-chess-hero .button {
    width: 100%;
  }

  /* Below 720px the hero column narrows further, so let the
     6-label focus row wrap onto multiple lines instead of
     forcing nowrap + overflow. */
  .hero-focus-line {
    flex-wrap: wrap;
    white-space: normal;
    gap: 8px;
    letter-spacing: 0.16em;
  }

  /* Mobile hero polish: trim the aggressive chess-image bleed
     (was -34/-20vw — pushed the knight ~75% of viewport off-screen)
     down to a mild bleed that keeps the piece visible. Shrink the
     visual block height and add some bottom breathing room. */
  .editorial-chess-hero {
    padding-bottom: 32px;
  }

  .editorial-chess-visual {
    min-height: 260px;
  }

  .chess-photo-wrap {
    inset: 0 -10vw 0 -8vw;
  }

  .chess-photo-wrap img {
    object-position: center center;
  }
}

@media (max-width: 520px) {
  .editorial-chess-visual {
    min-height: 220px;
  }

  .chess-photo-wrap {
    inset: 0 -8vw 0 -6vw;
  }

  .hero-focus-line {
    font-size: 0.64rem;
    letter-spacing: 0.14em;
  }
}


/* Headline update: Where Strategy Becomes Power
   Matches the Inter/700/-0.06em/0.98 treatment of the page's
   shared H2 ( .infra-copy h2, .split-header h2, .cta-card h2 )
   so the hero reads in the same Stripe-clean voice as
   "From board to roadmap." */
.strategy-headline-power {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-weight: 700;
  font-size: clamp(3rem, 5.5vw, 5.2rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
  text-transform: none;
  max-width: 760px;
  color: var(--navy-950);
}

.strategy-headline-power span {
  display: block;
}

@media (max-width: 1020px) {
  .strategy-headline-power {
    font-size: clamp(3.6rem, 10vw, 6.4rem);
    max-width: 820px;
  }
}

@media (max-width: 720px) {
  .strategy-headline-power {
    font-size: clamp(3rem, 14vw, 4.7rem);
    line-height: 0.96;
  }
}


/* Updated PSG corner logo */
.brand {
  gap: 12px;
  letter-spacing: 0;
}

.brand-logo-img {
  display: block;
  height: 40px;
  width: auto;
  max-width: 112px;
  object-fit: contain;
  filter: drop-shadow(0 7px 12px rgba(7, 17, 31, 0.10));
}

/* Invert the dark logo to white when it appears on the dark footer */
/* Footer sits on dark navy. We don't crush the logo into a flat
   silhouette — invert(1) flips the dark logo's polarity so the
   letters/knight read white while the chrome highlights become
   subtle darker hints, preserving the original sculpted detail. */
.footer .brand-logo-img {
  filter: invert(1) contrast(1.05) brightness(1.02) drop-shadow(0 4px 12px rgba(0, 0, 0, 0.4));
}

.navbar .brand-text {
  color: var(--navy-900);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  line-height: 1.15;
  text-transform: uppercase;
  white-space: nowrap;
}

.footer-brand .brand-logo-img {
  height: 42px;
  max-width: 118px;
}

.footer-brand .brand-text {
  font-family: Georgia, "Times New Roman", serif;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

@media (max-width: 720px) {
  .brand {
    gap: 9px;
  }

  .brand-logo-img {
    height: 34px;
    max-width: 96px;
  }

  .navbar .brand-text {
    font-size: 0.55rem;
    letter-spacing: 0.16em;
    max-width: 132px;
  }
}

@media (max-width: 520px) {
  .navbar .brand-text {
    display: none;
  }

  .brand-logo-img {
    height: 36px;
    max-width: 100px;
  }
}


/* Living strategy board hero */
.living-strategy-visual {
  min-height: 626px;
}

.living-board-wrap {
  position: absolute;
  inset: 26px -10vw 42px -1vw;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: 36px 0 0 36px;
  background: #07111f;
  box-shadow:
    0 36px 100px rgba(7, 17, 31, 0.24),
    0 18px 50px rgba(7, 17, 31, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transform: perspective(1200px) rotateX(1.5deg) rotateY(-3.5deg) translateZ(0);
  isolation: isolate;
}

.living-board-wrap::before,
.living-board-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}

.living-board-wrap::before {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 255, 255, 0.72) 10%, rgba(255, 255, 255, 0.1) 33%, rgba(255, 255, 255, 0) 68%),
    radial-gradient(circle at 42% 45%, rgba(244, 211, 123, 0.12), transparent 30%),
    radial-gradient(circle at 72% 35%, rgba(79, 140, 255, 0.13), transparent 26%);
}

.living-board-wrap::after {
  background:
    linear-gradient(180deg, rgba(7, 17, 31, 0.08) 0%, transparent 24%, transparent 72%, rgba(245, 247, 250, 0.84) 100%),
    radial-gradient(circle at 88% 16%, rgba(244, 211, 123, 0.2), transparent 16%);
  mix-blend-mode: screen;
  opacity: 0.78;
}

.living-board-wrap picture,
.living-board-wrap img {
  display: block;
  width: 100%;
  height: 100%;
}

.living-board-wrap picture {
  position: absolute;
  inset: 0;
}

.living-board-wrap img {
  object-fit: cover;
  object-position: center;
  filter: saturate(0.96) contrast(1.05) brightness(0.98);
  transform: scale(1.04);
  transform-origin: 55% 50%;
  animation: board-breathe 12s ease-in-out infinite;
}

.living-board-paths {
  position: absolute;
  inset: 0;
  z-index: 8;
  width: 100%;
  height: 100%;
  opacity: 0.9;
  filter: drop-shadow(0 0 10px rgba(244, 211, 123, 0.5));
}

.board-path {
  fill: none;
  stroke-width: 3.2;
  stroke-linecap: round;
  stroke-dasharray: 330;
  stroke-dashoffset: 330;
  animation: draw-board-path 7.2s ease-in-out infinite;
}

.path-one { animation-delay: 0.2s; }
.path-two { animation-delay: 1.6s; }
.path-three { animation-delay: 3s; }

.board-path-gold {
  stroke: url(#goldMovePath);
}

.board-path-blue {
  stroke: url(#blueMovePath);
  filter: drop-shadow(0 0 12px rgba(79, 140, 255, 0.72));
}

.path-signal {
  position: relative;
  fill: rgba(255, 255, 255, 0.92);
  stroke: rgba(244, 211, 123, 0.72);
  stroke-width: 2;
  opacity: 0;
  filter: drop-shadow(0 0 14px rgba(244, 211, 123, 0.78));
  animation: signal-pulse 7.2s ease-in-out infinite;
}

.signal-one { animation-delay: 0.2s; }
.signal-two {
  stroke: rgba(119, 229, 255, 0.74);
  filter: drop-shadow(0 0 16px rgba(79, 140, 255, 0.84));
  animation-delay: 1.6s;
}
.signal-three { animation-delay: 3s; }

.moving-token {
  position: absolute;
  z-index: 9;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  color: #07111f;
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.68) 56%, rgba(244, 211, 123, 0.38) 100%);
  border: 1px solid rgba(255, 255, 255, 0.76);
  box-shadow:
    0 0 0 8px rgba(244, 211, 123, 0.09),
    0 14px 34px rgba(7, 17, 31, 0.18),
    0 0 28px rgba(244, 211, 123, 0.32);
  font-size: 1.26rem;
  line-height: 1;
  opacity: 0;
  backdrop-filter: blur(6px);
}

.moving-token::after {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: inherit;
  border: 1px solid rgba(244, 211, 123, 0.26);
  opacity: 0.7;
}

.moving-knight {
  left: 36%;
  top: 58%;
  animation: knight-strategy-move 8.2s cubic-bezier(.32,.72,.25,1) infinite;
}

.moving-pawn {
  left: 74%;
  top: 62%;
  width: 32px;
  height: 32px;
  background:
    radial-gradient(circle at 38% 28%, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.58) 58%, rgba(119, 229, 255, 0.42) 100%);
  box-shadow:
    0 0 0 7px rgba(79, 140, 255, 0.1),
    0 14px 34px rgba(7, 17, 31, 0.18),
    0 0 28px rgba(79, 140, 255, 0.5);
  animation: pawn-position-move 7.6s cubic-bezier(.32,.72,.25,1) infinite;
  animation-delay: 1.4s;
}

.moving-pawn::before {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: rgba(6, 34, 77, 0.72);
  box-shadow: 0 9px 0 3px rgba(6, 34, 77, 0.44);
}

.moving-queen {
  left: 25%;
  top: 69%;
  color: #09234b;
  animation: queen-leverage-move 9.4s cubic-bezier(.32,.72,.25,1) infinite;
  animation-delay: 2.4s;
}

.living-board-glass {
  position: absolute;
  z-index: 10;
  left: 42px;
  right: 56px;
  bottom: 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  max-width: 680px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  background: rgba(7, 17, 31, 0.46);
  color: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 60px rgba(7, 17, 31, 0.18);
  font-size: 0.72rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.living-board-glass span {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  white-space: nowrap;
}

.living-board-glass i {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #f4d37b;
  box-shadow: 0 0 0 6px rgba(244, 211, 123, 0.16), 0 0 18px rgba(244, 211, 123, 0.72);
}

@keyframes board-breathe {
  0%, 100% { transform: scale(1.035) translate3d(0, 0, 0); }
  50% { transform: scale(1.07) translate3d(-1.4%, -0.6%, 0); }
}

@keyframes draw-board-path {
  0%, 16% { stroke-dashoffset: 330; opacity: 0; }
  28%, 56% { stroke-dashoffset: 0; opacity: 1; }
  76%, 100% { stroke-dashoffset: -330; opacity: 0; }
}

@keyframes signal-pulse {
  0%, 30% { opacity: 0; r: 5; }
  42% { opacity: 1; r: 12; }
  56% { opacity: 0.65; r: 24; }
  74%, 100% { opacity: 0; r: 8; }
}

@keyframes knight-strategy-move {
  0%, 16% { left: 36%; top: 58%; opacity: 0; transform: scale(0.74); }
  27% { opacity: 0.9; }
  48%, 58% { left: 58%; top: 33%; opacity: 0.95; transform: scale(1); }
  76%, 100% { left: 58%; top: 33%; opacity: 0; transform: scale(0.82); }
}

@keyframes pawn-position-move {
  0%, 16% { left: 74%; top: 64%; opacity: 0; transform: scale(0.72); }
  32% { opacity: 0.78; }
  54%, 64% { left: 75%; top: 42%; opacity: 0.82; transform: scale(1); }
  82%, 100% { left: 75%; top: 42%; opacity: 0; transform: scale(0.8); }
}

@keyframes queen-leverage-move {
  0%, 20% { left: 25%; top: 69%; opacity: 0; transform: scale(0.74); }
  34% { opacity: 0.75; }
  54%, 66% { left: 36%; top: 56%; opacity: 0.9; transform: scale(1); }
  84%, 100% { left: 36%; top: 56%; opacity: 0; transform: scale(0.8); }
}

@media (max-width: 1180px) {
  .living-board-wrap {
    inset: 38px -15vw 46px -2vw;
  }

  .living-board-glass {
    right: 38px;
  }
}

@media (max-width: 1020px) {
  .living-strategy-visual {
    min-height: 500px;
    margin-top: 18px;
  }

  .living-board-wrap {
    inset: 0;
    border-radius: 34px;
    transform: none;
  }

  .living-board-wrap::before {
    background:
      linear-gradient(90deg, rgba(255, 255, 255, 0.58) 0%, rgba(255, 255, 255, 0.04) 36%, rgba(255, 255, 255, 0) 100%),
      radial-gradient(circle at 42% 45%, rgba(244, 211, 123, 0.12), transparent 32%),
      radial-gradient(circle at 74% 34%, rgba(79, 140, 255, 0.14), transparent 28%);
  }
}

@media (max-width: 720px) {
  .living-strategy-visual {
    min-height: 360px;
  }

  .living-board-wrap {
    border-radius: 28px;
  }

  .living-board-wrap img {
    object-position: center;
    transform-origin: center;
  }

  .living-board-glass {
    left: 14px;
    right: 14px;
    bottom: 14px;
    align-items: flex-start;
    flex-direction: column;
    gap: 6px;
    border-radius: 18px;
    font-size: 0.62rem;
    letter-spacing: 0.06em;
  }

  .moving-token {
    width: 34px;
    height: 34px;
    font-size: 1rem;
  }

  .moving-pawn {
    width: 28px;
    height: 28px;
  }

  .board-path {
    stroke-width: 4;
  }
}

@media (max-width: 520px) {
  .living-strategy-visual {
    min-height: 300px;
  }

  .living-board-wrap img {
    object-position: 58% center;
  }

  .living-board-glass span:last-child {
    display: none;
  }
}




/* V17: Six-card flip strategic carousel */
.strategic-pieces-flip-section {
  background:
    radial-gradient(circle at 10% 12%, rgba(79, 140, 255, 0.08), transparent 24%),
    radial-gradient(circle at 88% 10%, rgba(244, 211, 123, 0.1), transparent 26%),
    linear-gradient(180deg, #ffffff, #f7fbff);
}

.flip-carousel-shell {
  --visible-slides: 3;
  --piece-gap: 18px;
}

.flip-carousel-shell .strategic-carousel-intro strong { font-size: 1rem; }

.flip-carousel-shell .strategic-carousel-viewport {
  overflow: hidden;
  padding: 4px 0;
}

.flip-carousel-shell .strategic-carousel-track {
  display: flex;
  gap: var(--piece-gap);
  transition: transform 420ms cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}

.piece-card-flip {
  position: relative;
  flex: 0 0 calc((100% - (var(--piece-gap) * (var(--visible-slides) - 1))) / var(--visible-slides));
  min-height: 550px;
  border-radius: 30px;
  perspective: 1600px;
  background: transparent;
  border: 0;
  box-shadow: none;
  isolation: isolate;
}

.piece-card-flip .piece-card-face {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  backface-visibility: hidden;
  border-radius: 30px;
  box-shadow: 0 28px 74px rgba(7,17,31,0.14);
  transition: transform 850ms cubic-bezier(.2,.65,.15,1), opacity 450ms ease;
}

.piece-card-flip .piece-card-front {
  justify-content: flex-end;
  border: 1px solid rgba(216, 222, 232, 0.82);
  background: linear-gradient(180deg, #f4f6fa, #eaeef4);
  transform: rotateY(0deg);
}

.piece-card-flip .piece-card-back {
  padding: 22px 22px 24px;
  border: 1px solid rgba(255,255,255,0.1);
  background:
    radial-gradient(circle at 84% 10%, rgba(244,211,123,0.16), transparent 24%),
    linear-gradient(180deg, #11161d 0%, #090d12 100%);
  color: white;
  transform: rotateY(180deg);
}

.piece-card-flip.is-flipped .piece-card-front,
.piece-card-flip:hover .piece-card-front,
.piece-card-flip:focus-within .piece-card-front {
  transform: rotateY(-180deg);
  opacity: 0;
}

.piece-card-flip.is-flipped .piece-card-back,
.piece-card-flip:hover .piece-card-back,
.piece-card-flip:focus-within .piece-card-back {
  transform: rotateY(0deg);
  opacity: 1;
}

.piece-card-front .piece-card-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 26%;
  transform: scale(1.015);
}

.piece-card-front .piece-card-bg.object-top {
  object-position: center 18%;
}

.piece-card-front-gradient {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0) 38%, rgba(6,10,17,0.18) 58%, rgba(6,10,17,0.92) 100%),
    radial-gradient(circle at 78% 16%, rgba(255,255,255,0.16), transparent 20%);
}

.piece-card-front-copy {
  position: relative;
  z-index: 2;
  padding: 22px;
  color: white;
}

.piece-front-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  color: rgba(255,255,255,0.88);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

.piece-card-front-copy h3 {
  margin: 16px 0 0;
  color: white;
  font-size: clamp(2rem, 2.9vw, 2.8rem);
  line-height: 0.95;
  letter-spacing: -0.06em;
}

.piece-card-back .piece-chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.07);
  color: rgba(255,255,255,0.9);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.piece-card-back h3 {
  margin: 14px 0 10px;
  color: white;
  font-size: 1.32rem;
  line-height: 1.08;
  letter-spacing: -0.035em;
}

.piece-card-back p {
  margin: 0;
  color: rgba(255,255,255,0.76);
  font-size: 0.88rem;
  line-height: 1.5;
}

/* Service-offering chips — 7 per card, wrap cleanly across the
   width. Compacted vs. the original 3-chip layout so seven items
   read as a tidy capability set rather than a wall. */
.piece-card-back .piece-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}

.piece-card-back .piece-card-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(255,243,206,0.07);
  border: 1px solid rgba(255,243,206,0.14);
  color: rgba(255,243,206,0.86);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.005em;
  white-space: nowrap;
}

.piece-card-back a {
  display: inline-flex;
  align-items: center;
  margin-top: auto;
  padding-top: 18px;
  color: #fff3ce;
  font-weight: 900;
}

.piece-card-back a::after {
  content: '→';
  margin-left: 8px;
  transition: transform 180ms var(--ease);
}

.piece-card-back a:hover::after { transform: translateX(4px); }

.flip-carousel-shell .carousel-arrow {
  width: 48px;
  height: 48px;
  border: 1px solid rgba(216,222,232,0.9);
  border-radius: 50%;
  background: rgba(255,255,255,0.92);
  box-shadow: 0 16px 38px rgba(7,17,31,0.08);
}

.flip-carousel-shell .carousel-dots { display: flex; gap: 8px; }
.flip-carousel-shell .carousel-dot {
  width: 10px; height: 10px; border: 0; border-radius: 999px;
  background: rgba(16,35,61,0.16); transition: width 180ms var(--ease), background 180ms ease;
}
.flip-carousel-shell .carousel-dot.is-active {
  width: 28px; background: linear-gradient(90deg, var(--gold-400), #4f8cff);
}

@media (max-width: 1100px) {
  .flip-carousel-shell { --visible-slides: 2; }
}

@media (max-width: 720px) {
  .flip-carousel-shell { --visible-slides: 1; }
  .piece-card-flip { min-height: 517px; }
}

/* V16: From board to roadmap operating infrastructure */
.board-roadmap-section {
  background:
    radial-gradient(circle at 12% 12%, rgba(79, 140, 255, 0.08), transparent 26%),
    radial-gradient(circle at 88% 18%, rgba(244, 211, 123, 0.12), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.board-roadmap-grid {
  grid-template-columns: 1.08fr 0.92fr;
  gap: 56px;
  align-items: center;
}

.board-roadmap-visual {
  width: 100%;
}

.board-roadmap-stage {
  position: relative;
  min-height: 520px;
  padding: 26px;
  border-radius: 34px;
  border: 1px solid rgba(216, 222, 232, 0.88);
  background:
    radial-gradient(circle at 82% 16%, rgba(244, 211, 123, 0.14), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 253, 0.94));
  box-shadow: 0 28px 84px rgba(7, 17, 31, 0.1);
  overflow: hidden;
}

.board-roadmap-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(45deg, rgba(7, 17, 31, 0.018) 25%, transparent 25% 75%, rgba(7, 17, 31, 0.018) 75%),
    linear-gradient(45deg, rgba(7, 17, 31, 0.014) 25%, transparent 25% 75%, rgba(7, 17, 31, 0.014) 75%);
  background-position: 0 0, 28px 28px;
  background-size: 56px 56px;
  opacity: 0.38;
  pointer-events: none;
}

.board-roadmap-stage {
  display: grid;
  grid-template-columns: minmax(220px, 0.92fr) 90px minmax(260px, 1.08fr);
  align-items: center;
  gap: 18px;
}

.strategy-board-panel,
.roadmap-panel {
  position: relative;
  z-index: 1;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 22px 70px rgba(7, 17, 31, 0.12);
}

.strategy-board-panel {
  min-height: 340px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background:
    radial-gradient(circle at 60% 40%, rgba(244, 211, 123, 0.12), transparent 36%),
    linear-gradient(180deg, #12243e 0%, #0b1729 100%);
}

.mini-board-grid {
  position: absolute;
  inset: 22px 22px 92px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(4, 1fr);
  gap: 6px;
}

.sq {
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
}

.sq.light {
  background: rgba(255, 255, 255, 0.12);
}

.sq.dark {
  background: rgba(255, 255, 255, 0.04);
}

.sq.active {
  box-shadow: inset 0 0 0 1px rgba(119, 229, 255, 0.4), 0 0 24px rgba(79, 140, 255, 0.28);
  background: rgba(79, 140, 255, 0.24);
}

.sq.active-gold {
  box-shadow: inset 0 0 0 1px rgba(244, 211, 123, 0.44), 0 0 28px rgba(244, 211, 123, 0.34);
  background: rgba(244, 211, 123, 0.3);
}

.board-piece {
  position: absolute;
  display: grid;
  place-items: center;
  border-radius: 18px;
  color: white;
  font-family: Georgia, 'Times New Roman', serif;
  line-height: 1;
}

.piece-knight {
  left: 88px;
  top: 102px;
  width: 72px;
  height: 72px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(79, 140, 255, 0.14));
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.18);
  font-size: 2.2rem;
}

.piece-rook {
  right: 70px;
  top: 184px;
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, rgba(255, 244, 204, 0.2), rgba(244, 211, 123, 0.18));
  border: 1px solid rgba(255, 244, 204, 0.24);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.18);
  font-size: 1.9rem;
  color: #fff3ce;
}

.board-panel-label {
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 22px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(16px);
}

.board-panel-label strong {
  display: block;
  color: white;
  font-size: 1.02rem;
  letter-spacing: -0.02em;
}

.board-panel-label small {
  display: block;
  margin-top: 6px;
  color: rgba(255, 255, 255, 0.64);
  font-size: 0.8rem;
}

.roadmap-flow {
  position: relative;
  z-index: 1;
  min-height: 220px;
}

.flow-line-main {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 4px;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(79, 140, 255, 0) 0%, rgba(79, 140, 255, 0.95) 34%, rgba(244, 211, 123, 0.95) 100%);
  box-shadow: 0 0 18px rgba(244, 211, 123, 0.32);
}

.flow-line-main::after {
  content: "";
  position: absolute;
  right: -2px;
  top: 50%;
  width: 14px;
  height: 14px;
  transform: translateY(-50%) rotate(45deg);
  border-radius: 3px;
  background: linear-gradient(135deg, #fff3ce, #f4d37b);
  box-shadow: 0 0 18px rgba(244, 211, 123, 0.46);
}

.flow-diamond {
  position: absolute;
  width: 14px;
  height: 14px;
  transform: rotate(45deg);
  border-radius: 3px;
  background: linear-gradient(135deg, #fff4cc, #f4d37b);
  box-shadow: 0 0 18px rgba(244, 211, 123, 0.46);
}

.flow-d1 { left: 10px; top: calc(50% - 7px); }
.flow-d2 { left: calc(50% - 7px); top: calc(50% - 7px); }
.flow-d3 { right: 10px; top: calc(50% - 7px); }

.roadmap-panel {
  min-height: 392px;
  padding: 22px;
  border: 1px solid rgba(216, 222, 232, 0.9);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.96));
}

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

.roadmap-header span {
  display: inline-block;
  color: var(--gold-500);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.roadmap-header strong {
  display: block;
  margin-top: 8px;
  color: var(--navy-950);
  font-size: 1.28rem;
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.roadmap-steps {
  display: grid;
  gap: 10px;
}

.roadmap-steps article {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px;
  border-radius: 16px;
  background: rgba(7, 17, 31, 0.03);
}

.roadmap-steps article span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  color: var(--navy-950);
  font-size: 0.75rem;
  font-weight: 950;
}

.roadmap-steps article strong {
  display: block;
  color: var(--navy-950);
  font-size: 0.94rem;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.roadmap-steps article small {
  display: block;
  margin-top: 5px;
  color: var(--slate-600);
  line-height: 1.35;
}

.floating-signal {
  position: absolute;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 12px 34px rgba(7, 17, 31, 0.08);
  color: var(--navy-800);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  backdrop-filter: blur(12px);
}

.signal-constraint { left: 18px; top: 18px; }
.signal-priority { left: 220px; top: 44px; }
.signal-owner { right: 170px; bottom: 24px; }
.signal-cadence { right: 24px; top: 18px; }

@media (max-width: 1180px) {
  .board-roadmap-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .board-roadmap-stage {
    min-height: 0;
  }
}

@media (max-width: 920px) {
  .board-roadmap-stage {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 20px;
  }

  .strategy-board-panel,
  .roadmap-panel {
    min-height: 0;
  }

  .strategy-board-panel {
    min-height: 320px;
  }

  .roadmap-flow {
    min-height: 54px;
  }

  .flow-line-main {
    width: 100%;
  }

  .floating-signal {
    display: none;
  }
}

@media (max-width: 720px) {
  .board-roadmap-stage {
    border-radius: 28px;
  }

  .mini-board-grid {
    inset: 18px 18px 86px;
  }

  .piece-knight {
    left: 64px;
    top: 92px;
    width: 60px;
    height: 60px;
    font-size: 1.9rem;
  }

  .piece-rook {
    right: 52px;
    top: 172px;
    width: 56px;
    height: 56px;
    font-size: 1.6rem;
  }
}


/* v20 carousel front-label refinement */
.piece-card-front-copy {
  padding: 26px;
}

.piece-card-front-copy h3 {
  max-width: 11ch;
  margin: 0;
  font-size: clamp(1.9rem, 2.45vw, 2.65rem);
  line-height: 0.98;
  text-wrap: balance;
}

.piece-card-front-copy h3::before {
  content: "";
  display: block;
  width: 58px;
  height: 2px;
  margin-bottom: 16px;
  border-radius: 999px;
  background: linear-gradient(90deg, #f4d37b, rgba(244, 211, 123, 0));
  box-shadow: 0 0 18px rgba(244, 211, 123, 0.32);
}

@media (max-width: 720px) {
  .piece-card-front-copy h3 {
    max-width: 13ch;
  }
}


/* v21 carousel cleanup: no intro text, side arrows */
.strategic-pieces-flip-section {
  padding-top: clamp(54px, 6vw, 82px);
}

.strategic-carousel-frame {
  position: relative;
}

.flip-carousel-shell .strategic-carousel-viewport {
  overflow: hidden;
  padding: 6px 0 10px;
}

.carousel-arrow-side {
  position: absolute;
  top: 50%;
  z-index: 8;
  transform: translateY(-50%);
  width: 54px;
  height: 54px;
  color: var(--navy-950);
  border-color: rgba(244, 211, 123, 0.42);
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.94), transparent 34%),
    linear-gradient(135deg, #fff8df, #f4d37b);
  box-shadow:
    0 18px 46px rgba(7, 17, 31, 0.14),
    0 0 0 8px rgba(244, 211, 123, 0.08);
}

.carousel-arrow-prev {
  left: -27px;
}

.carousel-arrow-next {
  right: -27px;
}

.carousel-arrow-side:hover:not(:disabled) {
  transform: translateY(-50%) scale(1.04);
}

.carousel-arrow-side:disabled {
  opacity: 0.38;
  cursor: not-allowed;
  box-shadow: 0 10px 24px rgba(7, 17, 31, 0.08);
}

.carousel-dots-bottom {
  justify-content: center;
  margin-top: 22px;
}

.flip-carousel-shell .carousel-dots-bottom {
  display: flex;
}

.strategic-carousel-toolbar,
.strategic-carousel-intro,
.strategic-carousel-controls {
  display: none;
}

@media (max-width: 900px) {
  .carousel-arrow-prev {
    left: 10px;
  }

  .carousel-arrow-next {
    right: 10px;
  }

  .carousel-arrow-side {
    width: 48px;
    height: 48px;
  }
}

@media (max-width: 720px) {
  .strategic-pieces-flip-section {
    padding-top: 44px;
  }

  .carousel-arrow-side {
    top: auto;
    bottom: -70px;
    transform: none;
  }

  .carousel-arrow-side:hover:not(:disabled) {
    transform: scale(1.04);
  }

  .carousel-arrow-prev {
    left: calc(50% - 66px);
  }

  .carousel-arrow-next {
    right: calc(50% - 66px);
  }

  .carousel-dots-bottom {
    margin-top: 86px;
  }
}


/* ---------------------------------------------------------------
   V21 homepage micro-enhancements
   Small, in-theme details to make the page feel alive without
   overpowering the editorial Stripe-style layout. All animations
   respect prefers-reduced-motion (see overrides at end).
   --------------------------------------------------------------- */

/* 1. Slim scroll-progress bar (navy → gold) */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  z-index: 100;
  pointer-events: none;
  background: rgba(216, 222, 232, 0.28);
}

.scroll-progress span {
  display: block;
  height: 100%;
  width: 100%;
  transform: scaleX(0);
  transform-origin: 0 50%;
  background: linear-gradient(90deg, var(--navy-700) 0%, var(--navy-700) 38%, var(--gold-400) 100%);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.45);
  transition: transform 90ms linear;
}

/* 2. (Removed) Hero headline now uses the page-shared sans
   treatment — no gold-italic accent or underline. */

/* 3. Slow gentle pulse on the strategy-marker diamond (gold halo) */
.strategy-marker span {
  animation: psg-marker-pulse 4.2s ease-in-out 1.2s infinite;
}

@keyframes psg-marker-pulse {
  0%, 100% {
    box-shadow: 0 0 0 6px rgba(217, 173, 79, 0.10);
  }
  50% {
    box-shadow: 0 0 0 9px rgba(217, 173, 79, 0.06), 0 0 18px rgba(217, 173, 79, 0.42);
  }
}

/* 4. Cascade pulse on the hero focus-line dots */
.hero-focus-line i {
  animation: psg-focus-dot 3.6s ease-in-out infinite;
}
.hero-focus-line i:nth-of-type(1) { animation-delay: 0s; }
.hero-focus-line i:nth-of-type(2) { animation-delay: 0.45s; }
.hero-focus-line i:nth-of-type(3) { animation-delay: 0.9s; }

@keyframes psg-focus-dot {
  0%, 100% { transform: scale(1);   opacity: 0.55; box-shadow: 0 0 0 0 rgba(217, 173, 79, 0);   }
  50%      { transform: scale(1.4); opacity: 1;    box-shadow: 0 0 8px 1px rgba(217, 173, 79, 0.55); }
}

/* 5. Subtle sheen sweep across the logo cloud row */
.logo-cloud {
  position: relative;
  overflow: hidden;
}

.logo-cloud::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 35%;
  pointer-events: none;
  background: linear-gradient(
    100deg,
    transparent 0%,
    rgba(255, 255, 255, 0.55) 45%,
    rgba(244, 211, 123, 0.18) 55%,
    transparent 100%
  );
  filter: blur(2px);
  transform: skewX(-14deg);
  animation: psg-logo-sheen 9s ease-in-out 2.6s infinite;
}

@keyframes psg-logo-sheen {
  0%   { left: -40%; opacity: 0; }
  8%   { opacity: 1; }
  60%  { left: 110%; opacity: 1; }
  100% { left: 110%; opacity: 0; }
}

/* 6. Gold underline reveal on nav links */
.primary-nav a {
  position: relative;
}

.primary-nav a::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 5px;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(217, 173, 79, 0), var(--gold-400), rgba(217, 173, 79, 0));
  transform: scaleX(0);
  transform-origin: 50% 50%;
  transition: transform 220ms var(--ease), opacity 220ms ease;
  opacity: 0;
}

.primary-nav a:hover::after,
.primary-nav a:focus-visible::after,
.primary-nav a[aria-current="page"]::after {
  transform: scaleX(1);
  opacity: 1;
}

/* 7. Gold corner-bracket accent on insight tile hover */
.insight-tile {
  transition: transform 240ms var(--ease), box-shadow 240ms var(--ease), border-color 240ms ease;
}

.insight-tile:hover {
  transform: translateY(-4px);
  border-color: rgba(217, 173, 79, 0.42);
  box-shadow: 0 24px 60px rgba(7, 17, 31, 0.12);
}

.insight-tile::before {
  content: "";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 0;
  height: 0;
  border-top: 2px solid var(--gold-400);
  border-right: 2px solid var(--gold-400);
  border-top-right-radius: 4px;
  opacity: 0;
  transition: width 280ms var(--ease), height 280ms var(--ease) 60ms, opacity 200ms ease;
  pointer-events: none;
}

.insight-tile:hover::before,
.insight-tile:focus-within::before {
  width: 22px;
  height: 22px;
  opacity: 1;
}

/* 8a. Slow glow pulse on the active mini-board squares */
.sq.active {
  animation: psg-sq-cyan 4.4s ease-in-out infinite;
}

.sq.active-gold {
  animation: psg-sq-gold 4.4s ease-in-out 1.2s infinite;
}

@keyframes psg-sq-cyan {
  0%, 100% { box-shadow: inset 0 0 0 1px rgba(119, 229, 255, 0.4),  0 0 18px rgba(79, 140, 255, 0.24); }
  50%      { box-shadow: inset 0 0 0 1px rgba(119, 229, 255, 0.62), 0 0 30px rgba(79, 140, 255, 0.42); }
}

@keyframes psg-sq-gold {
  0%, 100% { box-shadow: inset 0 0 0 1px rgba(244, 211, 123, 0.44), 0 0 22px rgba(244, 211, 123, 0.30); }
  50%      { box-shadow: inset 0 0 0 1px rgba(244, 211, 123, 0.68), 0 0 36px rgba(244, 211, 123, 0.46); }
}

/* 8b. Heartbeat pulse along the roadmap flow diamonds */
.flow-diamond {
  animation: psg-flow-beat 3.2s ease-in-out infinite;
}
.flow-d1 { animation-delay: 0s; }
.flow-d2 { animation-delay: 0.35s; }
.flow-d3 { animation-delay: 0.7s; }

@keyframes psg-flow-beat {
  0%, 100% { transform: rotate(45deg) scale(1);    box-shadow: 0 0 14px rgba(244, 211, 123, 0.40); }
  50%      { transform: rotate(45deg) scale(1.18); box-shadow: 0 0 22px rgba(244, 211, 123, 0.70); }
}

/* 8c. Gentle drift on the floating signals */
.floating-signal {
  animation: psg-signal-drift 6s ease-in-out infinite;
  transition: box-shadow 260ms ease, transform 260ms var(--ease), border-color 260ms ease;
}
.signal-constraint { animation-delay: 0s;   }
.signal-priority   { animation-delay: 1.2s; }
.signal-owner      { animation-delay: 2.4s; }
.signal-cadence    { animation-delay: 3.6s; }

.floating-signal:hover {
  transform: translateY(-3px);
  border-color: rgba(217, 173, 79, 0.55);
  box-shadow: 0 18px 44px rgba(7, 17, 31, 0.12), 0 0 0 3px rgba(244, 211, 123, 0.14);
}

@keyframes psg-signal-drift {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); }
}

/* 9. Embedded-support strip — gold edge glow + arrow nudge */
.embedded-support-strip {
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 251, 255, 0.86));
  transition: border-color 240ms ease, box-shadow 240ms var(--ease), transform 240ms var(--ease);
}

.embedded-support-strip:hover {
  border-color: rgba(217, 173, 79, 0.45);
  box-shadow: 0 22px 56px rgba(7, 17, 31, 0.10), 0 0 0 1px rgba(217, 173, 79, 0.18) inset;
}

.embedded-support-strip .text-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--navy-900);
  font-weight: 800;
  transition: color 180ms ease;
}

.embedded-support-strip .text-link::after {
  content: "→";
  display: inline-block;
  color: var(--gold-500);
  transition: transform 220ms var(--ease);
}

.embedded-support-strip:hover .text-link {
  color: var(--navy-950);
}

.embedded-support-strip:hover .text-link::after {
  transform: translateX(4px);
}

/* 10. Sheen sweep on the primary CTA on hover (only outside the dark hero) */
.button-primary {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.button-primary::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(
    100deg,
    transparent 0%,
    rgba(255, 255, 255, 0.42) 50%,
    transparent 100%
  );
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.button-primary:hover::after {
  left: 110%;
}

/* 11. Pulsing gold dot for the "Your next move" eyebrow indicator */
.next-move-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--gold-500);
  font-size: 0.76rem;
  font-weight: 950;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.next-move-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 0 0 rgba(217, 173, 79, 0.45);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

@keyframes psg-eyebrow-pulse {
  0%   { box-shadow: 0 0 0 0   rgba(217, 173, 79, 0.55); transform: scale(1);    }
  70%  { box-shadow: 0 0 0 12px rgba(217, 173, 79, 0);   transform: scale(1.08); }
  100% { box-shadow: 0 0 0 0   rgba(217, 173, 79, 0);    transform: scale(1);    }
}

/* ---------------------------------------------------------------
   V21 board-roadmap dark overhaul
   Full-bleed cinematic chess image fills the entire section; the
   copy floats over the dark ambient half of the photograph on the
   right. Top + bottom edges blend into adjacent light sections.
   --------------------------------------------------------------- */

.board-roadmap-dark {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  /* Solid backstop in case the image fails to load */
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  min-height: 558px;
  padding: 119px 0;
}

/* Full-bleed background photograph */
.board-roadmap-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 22% center;
  filter: saturate(1.04) contrast(1.05) brightness(0.96);
  z-index: 0;
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.board-roadmap-dark.is-revealed .board-roadmap-bg,
.board-roadmap-dark .infra-copy.is-visible ~ .board-roadmap-bg,
.board-roadmap-dark:has(.is-visible) .board-roadmap-bg {
  transform: scale(1);
}

/* Dark gradient overlay — keeps the chess piece readable on the
   left, deepens to nearly-opaque on the right behind the copy.
   Also adds soft top + bottom blend bands so the section meets
   adjacent light sections without a hard horizontal seam. */
.board-roadmap-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5, 11, 22, 0.45) 0%, rgba(5, 11, 22, 0.08) 28%, rgba(5, 11, 22, 0.18) 45%, rgba(5, 11, 22, 0.72) 70%, rgba(7, 17, 31, 0.92) 100%),
    linear-gradient(180deg, rgba(248, 251, 255, 0.55) 0%, rgba(248, 251, 255, 0) 6%, rgba(248, 251, 255, 0) 94%, rgba(248, 251, 255, 0.45) 100%);
}

/* Single gold scan-line along the bottom edge, drawn once on reveal */
.board-roadmap-scanline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  z-index: 2;
  background: linear-gradient(90deg, rgba(244, 211, 123, 0) 0%, rgba(244, 211, 123, 0.85) 50%, rgba(244, 211, 123, 0) 100%);
  transform: scaleX(0);
  transform-origin: 0 50%;
  opacity: 0;
  pointer-events: none;
}

.board-roadmap-dark:has(.is-visible) .board-roadmap-scanline {
  animation: psg-scanline 2400ms var(--ease) 240ms forwards;
}

@keyframes psg-scanline {
  0%   { transform: scaleX(0); opacity: 0; }
  18%  { opacity: 1; }
  100% { transform: scaleX(1); opacity: 0.7; }
}

.board-roadmap-dark .container {
  position: relative;
  z-index: 3;
}

/* Copy column floats on the right side, over the dark ambient half */
.board-roadmap-dark .board-roadmap-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-items: end;
}

.board-roadmap-dark .infra-copy {
  width: min(100%, 520px);
}

/* --- Copy styling --- */
.board-roadmap-dark .infra-copy .eyebrow {
  color: var(--gold-300);
  letter-spacing: 0.22em;
  font-size: 0.68rem;
}

.board-roadmap-dark .infra-copy .eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
}

.board-roadmap-dark .infra-copy h2 {
  color: white;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.25);
  font-size: clamp(1.97rem, 3.5vw, 3.76rem);
}

.board-roadmap-dark .infra-copy p {
  color: rgba(214, 222, 234, 0.78);
}

/* Subtle gold rule between headline and lede */
.board-roadmap-dark .infra-copy h2::after {
  content: "";
  display: block;
  width: 56px;
  height: 2px;
  margin: 22px 0 0;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--gold-400), rgba(217, 173, 79, 0));
  opacity: 0.9;
}

/* --- Dark check list --- */
.board-roadmap-dark .check-list {
  margin-top: 32px;
  gap: 14px;
}

.board-roadmap-dark .check-list > div {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015));
  transition: border-color 240ms ease, background 240ms ease, transform 240ms var(--ease);
}

.board-roadmap-dark .check-list > div:hover {
  border-color: rgba(217, 173, 79, 0.34);
  background: linear-gradient(180deg, rgba(217, 173, 79, 0.06), rgba(255, 255, 255, 0.015));
  transform: translateY(-1px);
}

.board-roadmap-dark .check-list span {
  width: 30px;
  height: 30px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff6d0, var(--gold-300));
  box-shadow: 0 6px 16px rgba(217, 173, 79, 0.28);
  font-size: 0.85rem;
}

.board-roadmap-dark .check-list p {
  color: rgba(220, 226, 236, 0.86);
  line-height: 1.55;
}

/* --- Responsive --- */
@media (max-width: 980px) {
  .board-roadmap-dark {
    min-height: 486px;
    padding: 90px 0;
  }

  /* On narrower viewports, pull the image more to the left so the
     chess piece doesn't sit behind the copy text */
  .board-roadmap-bg {
    object-position: 18% center;
  }

  /* Strengthen the right-side darkening to compensate for the
     copy column being wider relative to the image */
  .board-roadmap-shade {
    background:
      linear-gradient(90deg, rgba(5, 11, 22, 0.35) 0%, rgba(5, 11, 22, 0.08) 22%, rgba(5, 11, 22, 0.55) 50%, rgba(7, 17, 31, 0.94) 100%),
      linear-gradient(180deg, rgba(248, 251, 255, 0.55) 0%, rgba(248, 251, 255, 0) 6%, rgba(248, 251, 255, 0) 94%, rgba(248, 251, 255, 0.45) 100%);
  }
}

@media (max-width: 720px) {
  .board-roadmap-dark {
    min-height: 0;
    padding: 79px 0;
  }

  .board-roadmap-bg {
    object-position: 28% center;
  }

  /* On mobile, the copy column drops to the bottom of the section
     and the image fills the upper half. */
  .board-roadmap-shade {
    background:
      linear-gradient(180deg, rgba(5, 11, 22, 0.35) 0%, rgba(5, 11, 22, 0.05) 18%, rgba(7, 17, 31, 0.7) 55%, rgba(7, 17, 31, 0.96) 100%),
      linear-gradient(180deg, rgba(248, 251, 255, 0.55) 0%, rgba(248, 251, 255, 0) 6%, rgba(248, 251, 255, 0) 94%, rgba(248, 251, 255, 0.45) 100%);
  }

  .board-roadmap-dark .board-roadmap-grid {
    justify-items: start;
    padding-top: 220px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .board-roadmap-bg,
  .board-roadmap-scanline {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}


/* ---------------------------------------------------------------
   V21 final CTA — dark cinematic conversion section
   Page climaxes here and flows directly into the dark footer.
   One focal action (gold button), risk-reversal trust row, kept
   process strip + coverage chips for brand continuity.
   --------------------------------------------------------------- */

.cta-final {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(96px, 11vw, 148px) 0 clamp(88px, 9vw, 124px);
  background: #07111f;
  color: rgba(232, 238, 248, 0.92);
}

.cta-final-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  background: #050b16; /* fallback while the photo loads */
}

/* Backdrop photograph — full bleed, slightly desaturated + dimmed
   so the navy + gold palette stays in control. The composition's
   warm light on the left harmonizes with the brand gold; the dark
   silhouettes on the right hold copy contrast naturally. */
.cta-final-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 55%;
  filter: brightness(0.52) saturate(0.72) contrast(1.06);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
  z-index: 0;
}

.cta-final:has(.is-visible) .cta-final-photo {
  transform: scale(1);
}

/* Heavy central vignette + horizontal sunset-tamer so the headline
   and CTA stay rock-solid legible while the lower process strip
   lets the imagery peek through. */
.cta-final-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    /* central focal vignette — strongest behind headline/CTA */
    radial-gradient(ellipse 75% 55% at 50% 32%, rgba(5, 11, 22, 0.78) 0%, rgba(5, 11, 22, 0.30) 60%, rgba(5, 11, 22, 0.08) 100%),
    /* horizontal: extra darkening on the bright sunset side */
    linear-gradient(90deg, rgba(7, 17, 31, 0.48) 0%, rgba(7, 17, 31, 0.18) 50%, rgba(7, 17, 31, 0.30) 100%),
    /* vertical base: heavy top, lighter mid (image breathes), dark again for footer seam */
    linear-gradient(180deg, rgba(5, 11, 22, 0.55) 0%, rgba(5, 11, 22, 0.40) 40%, rgba(5, 11, 22, 0.32) 75%, rgba(5, 11, 22, 0.78) 100%);
}

/* Brand accent glows + soft top blend so the dark section meets
   the light insights section above without a hard horizontal seam. */
.cta-final-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(60, 130, 230, 0.16), transparent 36%),
    radial-gradient(ellipse at 50% 100%, rgba(244, 211, 123, 0.08), transparent 42%),
    linear-gradient(180deg, rgba(248, 251, 255, 0.55) 0%, rgba(248, 251, 255, 0) 6%);
  mix-blend-mode: screen;
}

.cta-final-shell {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  text-align: center;
  max-width: 820px;
  margin: 0 auto;
}

/* Eyebrow */
.cta-final-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.cta-final-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

/* Editorial headline — "power." in gold-gradient italic */
/* Matches the homepage hero + every other H1/H2 on the site:
   Inter / 700 / -0.06em / line-height 0.98 — the Stripe-clean sans
   treatment used as the page's headline system. */
.cta-final-headline {
  margin: 22px 0 24px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(2.4rem, 4.8vw, 4rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

/* Gold accent on the signature word — same treatment used across
   the site's gold-accented em (capabilities, system, easiest, etc.) */
.cta-final-headline em {
  font-style: normal;
  font-weight: inherit;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400);
}

.cta-final-lede {
  max-width: 620px;
  margin: 0 auto 36px;
  color: rgba(214, 222, 234, 0.82);
  font-size: clamp(1.02rem, 1.4vw, 1.16rem);
  line-height: 1.65;
}

/* Actions row */
.cta-final-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 22px;
  margin-bottom: 18px;
}

.cta-final-primary {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  min-height: 60px;
  padding: 0 32px;
  border: 0;
  border-radius: 999px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff5cf 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  box-shadow:
    0 18px 44px rgba(217, 173, 79, 0.28),
    0 0 0 1px rgba(255, 247, 215, 0.42) inset;
  font-weight: 900;
  font-size: 1.02rem;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease);
}

.cta-final-primary::after {
  /* Sheen sweep on hover */
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.55) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.cta-final-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 24px 56px rgba(217, 173, 79, 0.36),
    0 0 0 1px rgba(255, 247, 215, 0.6) inset;
}

.cta-final-primary:hover::after {
  left: 110%;
}

.cta-final-arrow {
  display: inline-block;
  transition: transform 220ms var(--ease);
}

.cta-final-primary:hover .cta-final-arrow {
  transform: translateX(4px);
}

.cta-final-secondary {
  color: rgba(232, 238, 248, 0.7);
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: underline;
  text-decoration-color: rgba(232, 238, 248, 0.22);
  text-underline-offset: 4px;
  transition: color 180ms ease, text-decoration-color 180ms ease;
}

.cta-final-secondary:hover {
  color: white;
  text-decoration-color: var(--gold-400);
}

/* Trust row */
.cta-final-trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px 28px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
  color: rgba(214, 222, 234, 0.7);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: -0.005em;
}

.cta-final-trust li {
  display: inline-flex;
  align-items: center;
  gap: 9px;
}

.cta-final-trust li > span {
  display: inline-grid;
  place-items: center;
  width: 19px;
  height: 19px;
  border-radius: 50%;
  background: rgba(217, 173, 79, 0.18);
  color: var(--gold-300);
  font-size: 0.7rem;
  font-weight: 950;
}

.cta-final-rule {
  width: 84px;
  height: 1px;
  margin: 54px 0 40px;
  border: 0;
  background: linear-gradient(90deg, transparent, rgba(217, 173, 79, 0.46), transparent);
}

/* Process strip */
.cta-final-process {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  width: 100%;
  max-width: 720px;
  margin-bottom: 36px;
}

.cta-final-process article {
  padding: 22px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01));
  text-align: center;
  transition: border-color 240ms ease, background 240ms ease, transform 240ms var(--ease);
}

.cta-final-process article:hover {
  border-color: rgba(217, 173, 79, 0.36);
  background: linear-gradient(180deg, rgba(217, 173, 79, 0.06), rgba(255, 255, 255, 0.01));
  transform: translateY(-2px);
}

.cta-final-glyph {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--gold-300);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.65rem;
  line-height: 1;
}

.cta-final-process strong {
  display: block;
  color: white;
  font-size: 0.96rem;
  letter-spacing: -0.01em;
}

.cta-final-process small {
  display: block;
  margin-top: 5px;
  color: rgba(214, 222, 234, 0.66);
  font-size: 0.84rem;
  line-height: 1.45;
}

/* Coverage row */
.cta-final-coverage {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 10px 14px;
  color: rgba(214, 222, 234, 0.78);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.20em;
  text-transform: uppercase;
}

.cta-final-coverage-label {
  color: rgba(214, 222, 234, 0.42);
  letter-spacing: 0.26em;
}

.cta-final-coverage i {
  display: inline-block;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--gold-400);
  opacity: 0.6;
}

/* Responsive */
@media (max-width: 720px) {
  .cta-final-headline br {
    display: none;
  }
  .cta-final-process {
    grid-template-columns: 1fr;
  }
  .cta-final-actions {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: 16px;
  }
  .cta-final-primary {
    width: 100%;
    justify-content: center;
  }
  .cta-final-secondary {
    align-self: center;
  }
  .cta-final-trust {
    gap: 10px 18px;
  }
  .cta-final-coverage {
    font-size: 0.7rem;
    letter-spacing: 0.18em;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cta-final-primary,
  .cta-final-primary::after,
  .cta-final-arrow,
  .cta-final-process article,
  .cta-final-eyebrow i {
    transition: none !important;
    animation: none !important;
  }
}


/* 12. Reduced-motion overrides — calm everything down for users who opt out */
@media (prefers-reduced-motion: reduce) {
  .scroll-progress span,
  .strategy-marker span,
  .hero-focus-line i,
  .logo-cloud::after,
  .primary-nav a::after,
  .insight-tile::before,
  .button-primary::after,
  .next-move-eyebrow i {
    animation: none !important;
    transition: none !important;
  }
}


/* ---------------------------------------------------------------
   Hero rotating word — typewriter cycle through:
   Execution, Advantage, Leverage, Momentum, Results
   --------------------------------------------------------------- */
/* NOTE: .strategy-headline span { display: block } stacks the
   H1 onto two lines. That rule also matches our nested spans
   (.rotating-word and friends), forcing them to block and
   breaking the line. The selectors below add a class to the
   specificity so the rotating word + caret stay inline. */
.strategy-headline .rotating-word {
  display: inline-block;
  white-space: nowrap;
  /* No min-width — let the period flow with the word, true typewriter feel.
     Adding a width-reservation would push the period to a new line in
     the constrained hero-copy column. */
}

/* Gold gradient fill on the rotating word — matches the gold
   accent treatment used on the closing CTA "power." so the hero
   and final CTA visually bookend the same signature gold beat. */
.strategy-headline .rotating-word-text {
  display: inline;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400); /* fallback for browsers without background-clip */
}

.strategy-headline .rotating-word-caret {
  display: inline-block;
  width: 0.055em;
  height: 0.78em;
  margin-left: 0.05em;
  background: var(--gold-400);
  vertical-align: -0.08em;
  border-radius: 1px;
  opacity: 0.9;
  box-shadow: 0 0 6px rgba(217, 173, 79, 0.35);
  animation: psg-caret-blink 1.05s steps(2, end) infinite;
}

@keyframes psg-caret-blink {
  0%, 50%       { opacity: 0.85; }
  50.01%, 100%  { opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .strategy-headline .rotating-word-caret {
    animation: none;
    opacity: 0;
  }
}


/* ---------------------------------------------------------------
   Logo cloud / experience strip
   Replaces the old "Built for ..." inline row with a centered
   eyebrow + a horizontal strip of company logos at consistent
   visual weight (full color, ~78% opacity for restraint, full
   color on hover).
   --------------------------------------------------------------- */
.logo-cloud-shell {
  display: grid;
  grid-template-columns: minmax(0, 240px) minmax(0, 1fr);
  gap: 38px;
  align-items: center;
}

.logo-cloud-eyebrow {
  margin: 0;
  text-align: left;
  color: var(--slate-500);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  line-height: 1.45;
}

/* Marquee viewport — clips the track and fades both edges so logos
   appear to drift in/out of view instead of popping at a hard edge. */
.logo-strip-viewport {
  position: relative;
  width: 100%;
  overflow: hidden;
  --logo-slot: 220px; /* JS overrides this based on viewport width */
  --logo-marquee-duration: 32s;
  mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
}

.logo-strip {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  width: max-content;
  margin: 0;
  padding: 0;
  list-style: none;
  animation: psg-logo-marquee var(--logo-marquee-duration) linear infinite;
  will-change: transform;
}

.logo-strip-viewport:hover .logo-strip,
.logo-strip-viewport:focus-within .logo-strip {
  animation-play-state: paused;
}

.logo-strip li {
  flex: 0 0 var(--logo-slot);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 18px;
  box-sizing: border-box;
}

/* Single uniform grayscale tone for all logos. Color + lift on hover. */
.logo-strip img {
  max-height: 100%;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  filter: grayscale(1) brightness(0.45) contrast(1.1);
  opacity: 0.82;
  transition: filter 280ms ease, opacity 220ms ease, transform 220ms var(--ease);
}

/* Square-ish logos (Merrill, Sears) bumped slightly to match optical weight */
.logo-strip img.logo-strip-img-tall {
  max-height: 120%;
  margin-top: -2px;
}

.logo-strip li:hover img,
.logo-strip li:focus-within img {
  filter: grayscale(0) brightness(1) contrast(1);
  opacity: 1;
  transform: translateY(-1px);
}

/* Text fallback — matched to the same gray tone as the logos.
   Swap each <li class="logo-strip-text"> for an <img> once
   real logos for 360 Remodeling and Cliq land in assets/img/logos/. */
.logo-strip-text {
  color: var(--slate-600);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.02rem;
  font-weight: 700;
  font-style: italic;
  letter-spacing: -0.005em;
  opacity: 0.82;
  transition: color 220ms ease, opacity 220ms ease, transform 220ms var(--ease);
  white-space: nowrap;
}

.logo-strip-text:hover {
  color: var(--navy-800);
  opacity: 1;
  transform: translateY(-1px);
}

@keyframes psg-logo-marquee {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}

@media (max-width: 720px) {
  .logo-cloud-shell {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .logo-cloud-eyebrow {
    font-size: 0.72rem;
    letter-spacing: 0.12em;
  }
  .logo-strip li {
    height: 30px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .logo-strip {
    animation: none;
  }
  /* Without animation, the duplicates would just sit there awkwardly —
     hide them so reduced-motion users see the 7 originals once. */
  .logo-strip > li[data-logo-clone] {
    display: none;
  }
}


/* ===============================================================
   Services page — mirrors the homepage's editorial + cinematic
   visual system, scoped to .services-* classes so it doesn't
   leak into other pages.
   =============================================================== */

/* --- Hero (sunset backdrop, dark gradient overlay, gold scan-line) --- */
.services-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  min-height: 620px;
  padding: 168px 0 96px;
}

.services-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 55%;
  filter: saturate(1.05) contrast(1.05) brightness(0.85);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.services-hero:has(.is-visible) .services-hero-bg {
  transform: scale(1);
}

.services-hero-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 80% at 22% 55%, rgba(5, 11, 22, 0.74) 0%, rgba(5, 11, 22, 0.32) 55%, rgba(5, 11, 22, 0.08) 100%),
    linear-gradient(90deg, rgba(5, 11, 22, 0.58) 0%, rgba(5, 11, 22, 0.18) 50%, rgba(5, 11, 22, 0.10) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.45) 0%, rgba(5, 11, 22, 0.10) 22%, rgba(5, 11, 22, 0.10) 78%, rgba(5, 11, 22, 0.62) 100%);
}

.services-hero-scanline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  z-index: 2;
  background: linear-gradient(90deg, rgba(244, 211, 123, 0) 0%, rgba(244, 211, 123, 0.85) 50%, rgba(244, 211, 123, 0) 100%);
  transform: scaleX(0);
  transform-origin: 0 50%;
  opacity: 0;
  pointer-events: none;
}

.services-hero:has(.is-visible) .services-hero-scanline {
  animation: psg-scanline 2200ms var(--ease) 280ms forwards;
}

.services-hero-shell {
  position: relative;
  z-index: 3;
  max-width: 720px;
}

.services-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.services-hero-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

/* Matches the homepage hero's typographic treatment:
   Inter / 700 / -0.06em / line-height 0.98 — the same Stripe-clean
   sans treatment used across the page's H1 + H2 headlines. */
.services-hero-title {
  margin: 22px 0 22px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(2.4rem, 4.8vw, 4.2rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

/* Gold accent on the two signature words — "capabilities" and "system" */
.services-hero-title em {
  font-style: normal;
  font-weight: inherit;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400); /* fallback */
}

.services-hero-lede {
  max-width: 580px;
  margin: 0 0 32px;
  color: rgba(214, 222, 234, 0.82);
  font-size: 1.06rem;
  line-height: 1.65;
}

.services-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 22px;
  margin-bottom: 32px;
}

.services-cta-gold {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 54px;
  padding: 0 26px;
  border: 0;
  border-radius: 3px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff5cf 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  box-shadow:
    0 16px 36px rgba(217, 173, 79, 0.28),
    0 0 0 1px rgba(255, 247, 215, 0.42) inset;
  font-weight: 900;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease);
}

.services-cta-gold::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.45) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.services-cta-gold:hover {
  transform: translateY(-2px);
  box-shadow:
    0 20px 46px rgba(217, 173, 79, 0.36),
    0 0 0 1px rgba(255, 247, 215, 0.6) inset;
}

.services-cta-gold:hover::after {
  left: 110%;
}

.services-arrow {
  display: inline-block;
  transition: transform 220ms var(--ease);
}

.services-cta-gold:hover .services-arrow {
  transform: translateX(4px);
}

.services-cta-secondary {
  color: rgba(232, 238, 248, 0.78);
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: underline;
  text-decoration-color: rgba(232, 238, 248, 0.22);
  text-underline-offset: 4px;
  transition: color 180ms ease, text-decoration-color 180ms ease;
}

.services-cta-secondary:hover {
  color: white;
  text-decoration-color: var(--gold-400);
}

/* ---- Hero-only button overrides: black + grey to match homepage hero ---- */
.services-hero .services-cta-gold {
  color: #ffffff;
  background: linear-gradient(135deg, var(--navy-950) 0%, #15213a 100%);
  box-shadow:
    0 14px 32px rgba(7, 17, 31, 0.30),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
}

.services-hero .services-cta-gold::after {
  /* White sheen sweep on the dark button (instead of warm gold) */
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.28) 50%, transparent 100%);
}

.services-hero .services-cta-gold:hover {
  background: linear-gradient(135deg, #0d1929 0%, #1c2a47 100%);
  box-shadow:
    0 18px 42px rgba(7, 17, 31, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.10) inset;
}

/* Hero secondary becomes a grey-pill button to match the homepage pair */
.services-hero .services-cta-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 24px;
  border: 1px solid var(--platinum-300);
  border-radius: 3px;
  background: rgba(237, 241, 246, 0.86);
  color: var(--slate-700);
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: none;
  box-shadow: 0 6px 18px rgba(7, 17, 31, 0.06);
  transition: color 180ms ease, background 180ms ease, border-color 180ms ease;
}

.services-hero .services-cta-secondary:hover {
  color: var(--navy-950);
  background: rgba(216, 222, 232, 0.94);
  border-color: var(--slate-500);
}

.services-hero-focus {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  color: rgba(232, 238, 248, 0.86);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.32em;
  text-transform: uppercase;
}

.services-hero-focus i {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold-400);
  opacity: 0.75;
}

/* --- Service areas grid (6 cards, 2-up) --- */
.services-areas {
  background:
    radial-gradient(ellipse at 80% 0%, rgba(79, 140, 255, 0.08), transparent 36%),
    linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.services-areas-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-top: 12px;
}

.service-area-card {
  display: grid;
  grid-template-columns: 168px minmax(0, 1fr);
  gap: 22px;
  padding: 28px;
  border-radius: 28px;
  border: 1px solid rgba(216, 222, 232, 0.82);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
  box-shadow: 0 18px 52px rgba(7, 17, 31, 0.08);
  transition: transform 240ms var(--ease), box-shadow 240ms var(--ease), border-color 240ms ease;
}

.service-area-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 26px 70px rgba(7, 17, 31, 0.12);
  border-color: rgba(217, 173, 79, 0.36);
}

.service-area-visual {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  background: linear-gradient(180deg, #f4f6fa, #eaeef4);
  border: 1px solid rgba(216, 222, 232, 0.7);
}

.service-area-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 28%;
  transform: scale(1.02);
  transition: transform 600ms var(--ease);
}

.service-area-card:hover .service-area-visual img {
  transform: scale(1.06);
}

.service-area-glyph {
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-grid;
  place-items: center;
  min-width: 30px;
  height: 30px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(7, 17, 31, 0.78);
  color: var(--gold-300);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.05rem;
  line-height: 1;
  backdrop-filter: blur(8px);
}

.service-area-body {
  display: flex;
  flex-direction: column;
}

.service-area-chip {
  display: inline-block;
  align-self: flex-start;
  color: var(--gold-500);
  font-size: 0.7rem;
  font-weight: 950;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.service-area-body h3 {
  margin: 10px 0 10px;
  color: var(--navy-950);
  font-size: 1.32rem;
  line-height: 1.18;
  letter-spacing: -0.025em;
}

.service-area-body > p {
  margin: 0;
  color: var(--slate-600);
  font-size: 0.95rem;
  line-height: 1.55;
}

.service-area-capabilities {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 14px 0 16px;
  padding: 0;
  list-style: none;
}

.service-area-capabilities li {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(244, 211, 123, 0.12);
  border: 1px solid rgba(217, 173, 79, 0.30);
  color: var(--navy-800);
  font-size: 0.7rem;
  font-weight: 800;
  white-space: nowrap;
}

.service-area-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  color: var(--navy-900);
  font-weight: 800;
  font-size: 0.92rem;
  transition: color 200ms ease;
}

.service-area-link span {
  color: var(--gold-500);
  transition: transform 220ms var(--ease);
}

.service-area-link:hover {
  color: var(--navy-950);
}

.service-area-link:hover span {
  transform: translateX(4px);
}

/* --- Methodology section (dark cinematic) --- */
.services-methodology {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.services-methodology-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 78% center;
  filter: saturate(1.08) contrast(1.06) brightness(0.78);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.services-methodology:has(.is-visible) .services-methodology-bg {
  transform: scale(1);
}

.services-methodology-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5, 11, 22, 0.85) 0%, rgba(5, 11, 22, 0.45) 45%, rgba(5, 11, 22, 0.20) 75%, rgba(5, 11, 22, 0.18) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.40) 0%, rgba(5, 11, 22, 0.10) 18%, rgba(5, 11, 22, 0.10) 82%, rgba(5, 11, 22, 0.55) 100%);
}

.services-methodology-shell {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
}

.services-methodology-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.services-methodology-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.services-methodology-copy h2 {
  margin: 18px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1.85rem, 3vw, 2.6rem);
  line-height: 1.1;
  letter-spacing: -0.045em;
}

.services-methodology-copy p {
  color: rgba(214, 222, 234, 0.82);
  font-size: 1rem;
  line-height: 1.62;
}

.services-methodology-steps {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.services-methodology-steps li {
  position: relative;
  padding: 18px 22px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01));
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: start;
  gap: 14px;
  transition: border-color 240ms ease, background 240ms ease;
}

.services-methodology-steps li:hover {
  border-color: rgba(217, 173, 79, 0.38);
  background: linear-gradient(180deg, rgba(217, 173, 79, 0.06), rgba(255, 255, 255, 0.015));
}

.services-methodology-step-num {
  grid-row: 1 / span 2;
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  color: var(--navy-950);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.04em;
}

.services-methodology-steps strong {
  color: white;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.32rem;
  font-weight: 500;
  font-style: italic;
  letter-spacing: 0;
}

.services-methodology-steps small {
  display: block;
  margin-top: 4px;
  color: rgba(214, 222, 234, 0.75);
  font-size: 0.92rem;
  line-height: 1.5;
}

/* --- AI spotlight section --- */
.services-ai-spotlight {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #060f1c;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.services-ai-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  filter: saturate(1.05) contrast(1.04) brightness(0.75);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.services-ai-spotlight:has(.is-visible) .services-ai-bg {
  transform: scale(1);
}

.services-ai-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(70, 140, 240, 0.12), transparent 60%),
    linear-gradient(180deg, rgba(6, 15, 28, 0.78) 0%, rgba(6, 15, 28, 0.55) 35%, rgba(6, 15, 28, 0.45) 65%, rgba(6, 15, 28, 0.85) 100%);
}

.services-ai-shell {
  position: relative;
  z-index: 2;
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.services-ai-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: rgba(119, 229, 255, 0.92);
  font-size: 0.74rem;
  font-weight: 950;
  letter-spacing: 0.32em;
  text-transform: uppercase;
}

.services-ai-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(119, 229, 255, 0.92);
  box-shadow: 0 0 14px rgba(79, 140, 255, 0.65);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.services-ai-spotlight h2 {
  margin: 22px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.05em;
  text-wrap: balance;
}

.services-ai-lede {
  max-width: 680px;
  margin: 0 0 40px;
  color: rgba(214, 222, 234, 0.82);
  font-size: 1.04rem;
  line-height: 1.65;
}

.services-ai-capabilities {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  width: 100%;
  margin-bottom: 36px;
  text-align: left;
}

.services-ai-capabilities article {
  padding: 20px 22px;
  border-radius: 16px;
  border: 1px solid rgba(119, 229, 255, 0.18);
  background: linear-gradient(180deg, rgba(79, 140, 255, 0.06), rgba(255, 255, 255, 0.01));
  transition: border-color 240ms ease, transform 240ms var(--ease);
}

.services-ai-capabilities article:hover {
  border-color: rgba(119, 229, 255, 0.42);
  transform: translateY(-2px);
}

.services-ai-cap-num {
  display: inline-block;
  margin-bottom: 8px;
  color: rgba(119, 229, 255, 0.62);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.2em;
}

.services-ai-capabilities strong {
  display: block;
  color: white;
  font-size: 1.02rem;
  letter-spacing: -0.01em;
}

.services-ai-capabilities small {
  display: block;
  margin-top: 6px;
  color: rgba(214, 222, 234, 0.7);
  font-size: 0.86rem;
  line-height: 1.5;
}

.services-ai-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(119, 229, 255, 0.92);
  font-weight: 800;
  font-size: 0.96rem;
  transition: color 200ms ease;
}

.services-ai-link span {
  transition: transform 220ms var(--ease);
}

.services-ai-link:hover {
  color: white;
}

.services-ai-link:hover span {
  transform: translateX(4px);
}

/* --- Packages section --- */
.services-packages {
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.services-packages-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 16px;
}

.services-package-card {
  display: flex;
  flex-direction: column;
  padding: 30px 28px 28px;
  border-radius: 24px;
  border: 1px solid rgba(216, 222, 232, 0.82);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 16px 44px rgba(7, 17, 31, 0.08);
  transition: transform 240ms var(--ease), box-shadow 240ms var(--ease), border-color 240ms ease;
}

.services-package-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 60px rgba(7, 17, 31, 0.12);
  border-color: rgba(217, 173, 79, 0.36);
}

.services-package-featured {
  border-color: rgba(217, 173, 79, 0.46);
  background:
    radial-gradient(circle at 100% 0%, rgba(244, 211, 123, 0.14), transparent 50%),
    linear-gradient(180deg, #ffffff, #fffdf3);
  box-shadow: 0 24px 56px rgba(217, 173, 79, 0.16);
}

.services-package-tag {
  display: inline-block;
  align-self: flex-start;
  color: var(--gold-500);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.services-package-card h3 {
  margin: 12px 0 12px;
  color: var(--navy-950);
  font-size: 1.45rem;
  line-height: 1.12;
  letter-spacing: -0.03em;
}

.services-package-card > p {
  margin: 0 0 18px;
  color: var(--slate-600);
  font-size: 0.95rem;
  line-height: 1.55;
}

.services-package-card ul {
  margin: 0 0 22px;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.services-package-card li {
  position: relative;
  padding-left: 22px;
  color: var(--slate-700);
  font-size: 0.92rem;
  line-height: 1.45;
}

.services-package-card li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--gold-500);
  font-weight: 900;
}

.services-package-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  color: var(--navy-900);
  font-weight: 800;
  font-size: 0.94rem;
  transition: color 200ms ease;
}

.services-package-link span {
  color: var(--gold-500);
  transition: transform 220ms var(--ease);
}

.services-package-link:hover span {
  transform: translateX(4px);
}

.services-package-featured .services-cta-gold {
  margin-top: auto;
}

/* --- Eyebrow dot helper for light sections --- */
.eyebrow-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  vertical-align: 1px;
  animation: psg-eyebrow-pulse 2.6s ease-out infinite;
}

/* --- Responsive --- */
@media (max-width: 1020px) {
  .services-methodology-shell {
    grid-template-columns: 1fr;
    gap: 36px;
  }
}

@media (max-width: 880px) {
  .services-areas-grid {
    grid-template-columns: 1fr;
  }
  .services-packages-grid {
    grid-template-columns: 1fr;
  }
  .services-ai-capabilities {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .services-hero {
    padding: 138px 0 84px;
    min-height: 540px;
  }
  .services-hero-shade {
    background:
      linear-gradient(180deg, rgba(5, 11, 22, 0.78) 0%, rgba(5, 11, 22, 0.62) 60%, rgba(5, 11, 22, 0.82) 100%);
  }
  .services-hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .services-cta-gold {
    justify-content: center;
  }
  .service-area-card {
    grid-template-columns: 1fr;
    padding: 22px;
  }
  .service-area-visual {
    min-height: 160px;
  }
  .services-hero-focus {
    gap: 8px;
    font-size: 0.66rem;
    letter-spacing: 0.22em;
  }
}

@media (prefers-reduced-motion: reduce) {
  .services-hero-bg,
  .services-methodology-bg,
  .services-ai-bg,
  .services-hero-scanline,
  .services-cta-gold,
  .services-cta-gold::after,
  .services-arrow,
  .service-area-card,
  .service-area-visual img,
  .services-methodology-steps li,
  .services-ai-capabilities article,
  .services-package-card,
  .services-hero-eyebrow i,
  .services-methodology-eyebrow i,
  .services-ai-eyebrow i,
  .eyebrow-dot {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}


/* ===============================================================
   AI Research page — mirrors the homepage's editorial + cinematic
   system. Same dark cinematic hero, gold accent words, black/grey
   buttons, card grids, and a closing CTA that matches the home CTA.
   Scoped to .ai-* classes so it doesn't leak into other pages.
   =============================================================== */

/* ---- Hero (gold-path cityscape backdrop) ---- */
.ai-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  min-height: 660px;
  padding: 168px 0 96px;
}

.ai-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 70% 55%;
  filter: saturate(1.06) contrast(1.06) brightness(0.86);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.ai-hero:has(.is-visible) .ai-hero-bg {
  transform: scale(1);
}

.ai-hero-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 78% 80% at 18% 55%, rgba(5, 11, 22, 0.78) 0%, rgba(5, 11, 22, 0.35) 55%, rgba(5, 11, 22, 0.05) 100%),
    linear-gradient(90deg, rgba(5, 11, 22, 0.62) 0%, rgba(5, 11, 22, 0.18) 55%, rgba(5, 11, 22, 0.06) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.45) 0%, rgba(5, 11, 22, 0.10) 22%, rgba(5, 11, 22, 0.10) 78%, rgba(5, 11, 22, 0.66) 100%);
}

.ai-hero-scanline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  z-index: 2;
  background: linear-gradient(90deg, rgba(244, 211, 123, 0) 0%, rgba(244, 211, 123, 0.85) 50%, rgba(244, 211, 123, 0) 100%);
  transform: scaleX(0);
  transform-origin: 0 50%;
  opacity: 0;
  pointer-events: none;
}

.ai-hero:has(.is-visible) .ai-hero-scanline {
  animation: psg-scanline 2200ms var(--ease) 280ms forwards;
}

.ai-hero-shell {
  position: relative;
  z-index: 3;
  max-width: 760px;
}

.ai-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.ai-hero-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.ai-hero-title {
  margin: 22px 0 22px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(2.4rem, 4.8vw, 4.2rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

.ai-hero-title em {
  font-style: normal;
  font-weight: inherit;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400);
}

.ai-hero-rule {
  display: block;
  width: 120px;
  height: 1px;
  margin: 4px 0 22px;
  border: 0;
  background: rgba(244, 211, 123, 0.7);
}

.ai-hero-lede {
  max-width: 620px;
  margin: 0 0 32px;
  color: rgba(214, 222, 234, 0.84);
  font-size: 1.06rem;
  line-height: 1.65;
}

.ai-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 22px;
  margin-bottom: 34px;
}

.ai-hero-primary {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 54px;
  padding: 0 26px;
  border: 0;
  border-radius: 3px;
  color: #ffffff;
  background: linear-gradient(135deg, var(--navy-950) 0%, #15213a 100%);
  box-shadow:
    0 14px 32px rgba(7, 17, 31, 0.30),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  font-weight: 900;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease), background 200ms ease;
}

.ai-hero-primary::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.28) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.ai-hero-primary:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #0d1929 0%, #1c2a47 100%);
  box-shadow:
    0 18px 42px rgba(7, 17, 31, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.10) inset;
}

.ai-hero-primary:hover::after {
  left: 110%;
}

.ai-hero-arrow {
  display: inline-block;
  transition: transform 220ms var(--ease);
}

.ai-hero-primary:hover .ai-hero-arrow {
  transform: translateX(4px);
}

.ai-hero-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 24px;
  border: 1px solid var(--platinum-300);
  border-radius: 3px;
  background: rgba(237, 241, 246, 0.86);
  color: var(--slate-700);
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: none;
  box-shadow: 0 6px 18px rgba(7, 17, 31, 0.06);
  transition: color 180ms ease, background 180ms ease, border-color 180ms ease;
}

.ai-hero-secondary:hover {
  color: var(--navy-950);
  background: rgba(216, 222, 232, 0.94);
  border-color: var(--slate-500);
}

.ai-hero-pillars {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  color: rgba(232, 238, 248, 0.86);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  white-space: nowrap;
}

.ai-hero-pillars i {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold-400);
  opacity: 0.75;
}

/* ---- Capabilities grid (3 x 2) ---- */
.ai-capabilities {
  background:
    radial-gradient(ellipse at 12% 0%, rgba(79, 140, 255, 0.08), transparent 30%),
    radial-gradient(ellipse at 92% 100%, rgba(244, 211, 123, 0.08), transparent 36%),
    linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.ai-capabilities-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.ai-capability-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 28px 26px 26px;
  border-radius: 22px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
  box-shadow: 0 16px 44px rgba(7, 17, 31, 0.07);
  transition: transform 240ms var(--ease), box-shadow 240ms var(--ease), border-color 240ms ease;
}

.ai-capability-card:hover {
  transform: translateY(-3px);
  border-color: rgba(217, 173, 79, 0.36);
  box-shadow: 0 24px 60px rgba(7, 17, 31, 0.10);
}

.ai-capability-num {
  display: inline-block;
  color: var(--gold-500);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.22em;
  margin-bottom: 10px;
}

.ai-capability-card h3 {
  margin: 0 0 12px;
  color: var(--navy-950);
  font-size: 1.22rem;
  line-height: 1.18;
  letter-spacing: -0.025em;
}

.ai-capability-card > p {
  margin: 0 0 16px;
  color: var(--slate-600);
  font-size: 0.92rem;
  line-height: 1.55;
}

.ai-capability-points {
  margin: auto 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-top: 1px solid rgba(217, 173, 79, 0.22);
  padding-top: 14px;
}

.ai-capability-points li {
  position: relative;
  padding-left: 16px;
  color: var(--slate-700);
  font-size: 0.86rem;
  line-height: 1.45;
}

.ai-capability-points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold-400);
  opacity: 0.7;
}

/* ---- Boardroom metrics section (dark cinematic) ---- */
.ai-boardroom {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.ai-boardroom-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 65% center;
  filter: saturate(1.06) contrast(1.04) brightness(0.78);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.ai-boardroom:has(.is-visible) .ai-boardroom-bg {
  transform: scale(1);
}

.ai-boardroom-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5, 11, 22, 0.84) 0%, rgba(5, 11, 22, 0.45) 50%, rgba(5, 11, 22, 0.20) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.40) 0%, rgba(5, 11, 22, 0.08) 22%, rgba(5, 11, 22, 0.08) 78%, rgba(5, 11, 22, 0.55) 100%);
}

.ai-boardroom-shell {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
}

.ai-boardroom-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.ai-boardroom-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.ai-boardroom-copy h2 {
  margin: 18px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1.85rem, 3vw, 2.6rem);
  line-height: 1.1;
  letter-spacing: -0.045em;
}

.ai-boardroom-copy p {
  color: rgba(214, 222, 234, 0.82);
  font-size: 1rem;
  line-height: 1.62;
}

.ai-boardroom-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.ai-boardroom-metrics article {
  padding: 22px 22px 20px;
  border-radius: 16px;
  border: 1px solid rgba(244, 211, 123, 0.22);
  background: linear-gradient(180deg, rgba(244, 211, 123, 0.06), rgba(255, 255, 255, 0.015));
  transition: border-color 240ms ease, transform 240ms var(--ease);
}

.ai-boardroom-metrics article:hover {
  border-color: rgba(244, 211, 123, 0.45);
  transform: translateY(-2px);
}

.ai-metric-label {
  display: block;
  color: rgba(214, 222, 234, 0.72);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.ai-metric-value {
  display: block;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(2rem, 2.6vw, 2.6rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400);
  margin-bottom: 10px;
}

.ai-boardroom-metrics small {
  display: block;
  color: rgba(214, 222, 234, 0.7);
  font-size: 0.82rem;
  line-height: 1.45;
}

/* ---- Operating-system view (dark cinematic with map + chess piece) ---- */
.ai-operating-system {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #04080f;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.ai-operating-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  filter: saturate(1.08) contrast(1.06) brightness(0.7);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.ai-operating-system:has(.is-visible) .ai-operating-bg {
  transform: scale(1);
}

.ai-operating-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 90% 60% at 30% 40%, rgba(4, 8, 15, 0.55) 0%, rgba(4, 8, 15, 0.25) 60%, rgba(4, 8, 15, 0.10) 100%),
    linear-gradient(180deg, rgba(4, 8, 15, 0.45) 0%, rgba(4, 8, 15, 0.15) 22%, rgba(4, 8, 15, 0.20) 78%, rgba(4, 8, 15, 0.65) 100%);
}

.ai-operating-shell {
  position: relative;
  z-index: 2;
  max-width: 920px;
}

.ai-operating-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.ai-operating-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.ai-operating-system h2 {
  margin: 18px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 3.4vw, 2.8rem);
  line-height: 1.08;
  letter-spacing: -0.05em;
  text-wrap: balance;
}

.ai-operating-lede {
  max-width: 720px;
  margin: 0 0 36px;
  color: rgba(214, 222, 234, 0.82);
  font-size: 1.02rem;
  line-height: 1.65;
}

.ai-operating-pillars {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.ai-operating-pillars article {
  padding: 18px 18px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
  transition: border-color 240ms ease, transform 240ms var(--ease);
}

.ai-operating-pillars article:hover {
  border-color: rgba(217, 173, 79, 0.42);
  transform: translateY(-2px);
}

.ai-operating-num {
  display: inline-block;
  color: rgba(244, 211, 123, 0.6);
  font-size: 0.66rem;
  font-weight: 950;
  letter-spacing: 0.2em;
  margin-bottom: 6px;
}

.ai-operating-pillars strong {
  display: block;
  color: white;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.42rem;
  font-weight: 500;
  font-style: italic;
  letter-spacing: 0;
}

.ai-operating-pillars small {
  display: block;
  margin-top: 4px;
  color: rgba(214, 222, 234, 0.7);
  font-size: 0.85rem;
  line-height: 1.4;
}

/* ---- Field notes (3 x 2 grid, light section) ---- */
.ai-field-notes {
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.ai-field-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 12px;
}

.ai-field-card {
  display: flex;
  flex-direction: column;
  padding: 28px 26px 26px;
  border-radius: 22px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
  box-shadow: 0 14px 40px rgba(7, 17, 31, 0.06);
  transition: transform 240ms var(--ease), border-color 240ms ease, box-shadow 240ms var(--ease);
}

.ai-field-card:hover {
  transform: translateY(-3px);
  border-color: rgba(217, 173, 79, 0.36);
  box-shadow: 0 22px 56px rgba(7, 17, 31, 0.10);
}

.ai-field-cat {
  display: inline-block;
  color: var(--gold-500);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.ai-field-card h3 {
  margin: 10px 0 10px;
  color: var(--navy-950);
  font-size: 1.18rem;
  line-height: 1.2;
  letter-spacing: -0.025em;
}

.ai-field-card > p {
  margin: 0 0 16px;
  color: var(--slate-600);
  font-size: 0.92rem;
  line-height: 1.55;
}

.ai-field-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  color: var(--navy-900);
  font-weight: 800;
  font-size: 0.92rem;
  transition: color 200ms ease;
}

.ai-field-link span {
  color: var(--gold-500);
  transition: transform 220ms var(--ease);
}

.ai-field-link:hover span {
  transform: translateX(4px);
}

/* ---- Responsive ---- */
@media (max-width: 1100px) {
  .ai-capabilities-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ai-field-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ai-operating-pillars {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 880px) {
  .ai-boardroom-shell {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .ai-operating-pillars {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .ai-hero {
    padding: 138px 0 84px;
    min-height: 560px;
  }
  .ai-hero-shade {
    background:
      linear-gradient(180deg, rgba(5, 11, 22, 0.78) 0%, rgba(5, 11, 22, 0.62) 60%, rgba(5, 11, 22, 0.82) 100%);
  }
  .ai-hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .ai-hero-primary,
  .ai-hero-secondary {
    justify-content: center;
  }
  .ai-capabilities-grid,
  .ai-field-grid {
    grid-template-columns: 1fr;
  }
  .ai-boardroom-metrics,
  .ai-operating-pillars {
    grid-template-columns: 1fr;
  }
  .ai-hero-pillars {
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    gap: 8px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ai-hero-bg,
  .ai-boardroom-bg,
  .ai-operating-bg,
  .ai-hero-scanline,
  .ai-hero-primary,
  .ai-hero-primary::after,
  .ai-hero-arrow,
  .ai-capability-card,
  .ai-field-card,
  .ai-boardroom-metrics article,
  .ai-operating-pillars article,
  .ai-hero-eyebrow i,
  .ai-boardroom-eyebrow i,
  .ai-operating-eyebrow i {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}


/* ===============================================================
   Contact page — mirrors the homepage's editorial + cinematic
   system. Dark cinematic hero, light premium form section,
   dark cinematic four-step path. Scoped to .contact-* classes.
   =============================================================== */

/* ---- Hero (handshake backdrop) ---- */
.contact-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  min-height: 620px;
  padding: 168px 0 96px;
}

.contact-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 72% center;
  filter: saturate(1.04) contrast(1.04) brightness(0.86);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.contact-hero:has(.is-visible) .contact-hero-bg {
  transform: scale(1);
}

.contact-hero-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 78% 80% at 18% 55%, rgba(5, 11, 22, 0.80) 0%, rgba(5, 11, 22, 0.40) 55%, rgba(5, 11, 22, 0.08) 100%),
    linear-gradient(90deg, rgba(5, 11, 22, 0.68) 0%, rgba(5, 11, 22, 0.22) 55%, rgba(5, 11, 22, 0.08) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.45) 0%, rgba(5, 11, 22, 0.10) 22%, rgba(5, 11, 22, 0.10) 78%, rgba(5, 11, 22, 0.66) 100%);
}

.contact-hero-scanline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  z-index: 2;
  background: linear-gradient(90deg, rgba(244, 211, 123, 0) 0%, rgba(244, 211, 123, 0.85) 50%, rgba(244, 211, 123, 0) 100%);
  transform: scaleX(0);
  transform-origin: 0 50%;
  opacity: 0;
  pointer-events: none;
}

.contact-hero:has(.is-visible) .contact-hero-scanline {
  animation: psg-scanline 2200ms var(--ease) 280ms forwards;
}

.contact-hero-shell {
  position: relative;
  z-index: 3;
  max-width: 720px;
}

.contact-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.contact-hero-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.contact-hero-title {
  margin: 22px 0 22px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(2.4rem, 4.8vw, 4.2rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

.contact-hero-title em {
  font-style: normal;
  font-weight: inherit;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400);
}

.contact-hero-rule {
  display: block;
  width: 120px;
  height: 1px;
  margin: 4px 0 22px;
  border: 0;
  background: rgba(244, 211, 123, 0.7);
}

.contact-hero-lede {
  max-width: 620px;
  margin: 0 0 32px;
  color: rgba(214, 222, 234, 0.84);
  font-size: 1.06rem;
  line-height: 1.65;
}

.contact-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 22px;
  margin-bottom: 34px;
}

.contact-hero-primary {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 54px;
  padding: 0 26px;
  border: 0;
  border-radius: 3px;
  color: #ffffff;
  background: linear-gradient(135deg, var(--navy-950) 0%, #15213a 100%);
  box-shadow:
    0 14px 32px rgba(7, 17, 31, 0.30),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  font-weight: 900;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease), background 200ms ease;
}

.contact-hero-primary::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.28) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.contact-hero-primary:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #0d1929 0%, #1c2a47 100%);
  box-shadow:
    0 18px 42px rgba(7, 17, 31, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.10) inset;
}

.contact-hero-primary:hover::after {
  left: 110%;
}

.contact-hero-arrow {
  display: inline-block;
  transition: transform 220ms var(--ease);
}

.contact-hero-primary:hover .contact-hero-arrow {
  transform: translateY(3px);
}

.contact-hero-secondary {
  color: rgba(232, 238, 248, 0.78);
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: underline;
  text-decoration-color: rgba(232, 238, 248, 0.22);
  text-underline-offset: 4px;
  transition: color 180ms ease, text-decoration-color 180ms ease;
}

.contact-hero-secondary:hover {
  color: white;
  text-decoration-color: var(--gold-400);
}

.contact-hero-pillars {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
  color: rgba(232, 238, 248, 0.86);
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
}

.contact-hero-pillars i {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold-400);
  opacity: 0.75;
}

/* ---- Contact form section (light) ---- */
.contact-form-section {
  background:
    radial-gradient(ellipse at 12% 0%, rgba(79, 140, 255, 0.08), transparent 36%),
    linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.contact-form-shell {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 48px;
  align-items: start;
}

.contact-form-intro h2 {
  margin: 14px 0 16px;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(1.7rem, 2.6vw, 2.2rem);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -0.05em;
}

.contact-form-intro > p {
  color: var(--slate-600);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0 0 28px;
}

.contact-form-trust {
  margin: 0 0 28px;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.contact-form-trust li {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 12px;
  align-items: start;
}

.contact-trust-check {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  color: var(--navy-950);
  font-size: 0.74rem;
  font-weight: 950;
  margin-top: 2px;
}

.contact-form-trust strong {
  display: block;
  color: var(--navy-950);
  font-size: 0.96rem;
  letter-spacing: -0.01em;
}

.contact-form-trust small {
  display: block;
  margin-top: 2px;
  color: var(--slate-600);
  font-size: 0.86rem;
  line-height: 1.45;
}

.contact-direct {
  padding: 18px 20px;
  border-radius: 14px;
  border: 1px dashed rgba(217, 173, 79, 0.38);
  background: rgba(244, 211, 123, 0.06);
}

.contact-direct span {
  display: block;
  color: var(--slate-600);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.contact-direct a {
  color: var(--navy-950);
  font-weight: 800;
  font-size: 1.02rem;
  letter-spacing: -0.01em;
  transition: color 180ms ease;
}

.contact-direct a:hover {
  color: var(--gold-500);
}

/* ---- Form card ---- */
.contact-form-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 32px 30px 28px;
  border-radius: 24px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 22px 60px rgba(7, 17, 31, 0.10);
}

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

.contact-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contact-field > span {
  color: var(--navy-900);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.contact-field input,
.contact-field select,
.contact-field textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--platinum-200);
  background: #ffffff;
  color: var(--navy-950);
  font-family: inherit;
  font-size: 0.96rem;
  line-height: 1.4;
  transition: border-color 180ms ease, box-shadow 180ms ease;
}

.contact-field input::placeholder,
.contact-field textarea::placeholder {
  color: var(--slate-500);
}

.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus {
  outline: none;
  border-color: var(--gold-400);
  box-shadow: 0 0 0 3px rgba(244, 211, 123, 0.22);
}

.contact-field textarea {
  resize: vertical;
  min-height: 110px;
}

.contact-submit {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 54px;
  padding: 0 28px;
  margin-top: 6px;
  border: 0;
  border-radius: 999px;
  color: var(--navy-950);
  background: linear-gradient(135deg, #fff5cf 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  box-shadow:
    0 16px 40px rgba(217, 173, 79, 0.28),
    0 0 0 1px rgba(255, 247, 215, 0.42) inset;
  font-weight: 900;
  font-size: 1rem;
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease);
}

.contact-submit::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.45) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.contact-submit:hover {
  transform: translateY(-2px);
  box-shadow:
    0 20px 48px rgba(217, 173, 79, 0.36),
    0 0 0 1px rgba(255, 247, 215, 0.6) inset;
}

.contact-submit:hover::after {
  left: 110%;
}

.contact-submit-arrow {
  display: inline-block;
  transition: transform 220ms var(--ease);
}

.contact-submit:hover .contact-submit-arrow {
  transform: translateX(4px);
}

.contact-form-note {
  margin: 4px 0 0;
  color: var(--slate-500);
  font-size: 0.78rem;
  line-height: 1.45;
}

/* ---- "What happens next" four-step path (dark cinematic) ---- */
.contact-path {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.contact-path-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 78% center;
  filter: saturate(1.06) contrast(1.05) brightness(0.74);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.contact-path:has(.is-visible) .contact-path-bg {
  transform: scale(1);
}

.contact-path-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5, 11, 22, 0.84) 0%, rgba(5, 11, 22, 0.45) 50%, rgba(5, 11, 22, 0.20) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.42) 0%, rgba(5, 11, 22, 0.08) 22%, rgba(5, 11, 22, 0.08) 78%, rgba(5, 11, 22, 0.55) 100%);
}

.contact-path-shell {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
}

.contact-path-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.contact-path-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.contact-path-copy h2 {
  margin: 18px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1.85rem, 3vw, 2.6rem);
  line-height: 1.1;
  letter-spacing: -0.045em;
}

.contact-path-copy p {
  color: rgba(214, 222, 234, 0.82);
  font-size: 1rem;
  line-height: 1.62;
}

.contact-path-steps {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.contact-path-steps li {
  position: relative;
  padding: 18px 22px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01));
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: start;
  gap: 14px;
  transition: border-color 240ms ease, background 240ms ease;
}

.contact-path-steps li:hover {
  border-color: rgba(217, 173, 79, 0.38);
  background: linear-gradient(180deg, rgba(217, 173, 79, 0.06), rgba(255, 255, 255, 0.015));
}

.contact-path-step-num {
  grid-row: 1 / span 2;
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  color: var(--navy-950);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.04em;
}

.contact-path-steps strong {
  color: white;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.32rem;
  font-weight: 500;
  font-style: italic;
  letter-spacing: 0;
}

.contact-path-steps small {
  display: block;
  margin-top: 4px;
  color: rgba(214, 222, 234, 0.75);
  font-size: 0.92rem;
  line-height: 1.5;
}

/* ---- Responsive ---- */
@media (max-width: 980px) {
  .contact-form-shell {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .contact-path-shell {
    grid-template-columns: 1fr;
    gap: 36px;
  }
}

@media (max-width: 720px) {
  .contact-hero {
    padding: 138px 0 84px;
    min-height: 540px;
  }
  .contact-hero-shade {
    background:
      linear-gradient(180deg, rgba(5, 11, 22, 0.80) 0%, rgba(5, 11, 22, 0.62) 60%, rgba(5, 11, 22, 0.85) 100%);
  }
  .contact-hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .contact-hero-primary {
    justify-content: center;
  }
  .contact-hero-pillars {
    flex-wrap: wrap;
    white-space: normal;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    gap: 8px;
  }
  .contact-form-row {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .contact-form-card {
    padding: 24px 22px 22px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .contact-hero-bg,
  .contact-path-bg,
  .contact-hero-scanline,
  .contact-hero-primary,
  .contact-hero-primary::after,
  .contact-hero-arrow,
  .contact-submit,
  .contact-submit::after,
  .contact-submit-arrow,
  .contact-path-steps li,
  .contact-hero-eyebrow i,
  .contact-path-eyebrow i {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}


/* ===============================================================
   Proof page — mirrors the homepage's editorial + cinematic
   system. Hero (intimate consult), metrics strip, 3 case studies,
   engagement-in-motion dark band, voices, and a closing dark
   leave-behind section. Scoped to .proof-* classes.
   =============================================================== */

/* ---- Hero (intimate conversation backdrop) ---- */
.proof-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  min-height: 620px;
  padding: 168px 0 96px;
}

.proof-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 72% center;
  filter: saturate(1.04) contrast(1.05) brightness(0.86);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.proof-hero:has(.is-visible) .proof-hero-bg {
  transform: scale(1);
}

.proof-hero-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 78% 80% at 18% 55%, rgba(5, 11, 22, 0.80) 0%, rgba(5, 11, 22, 0.42) 55%, rgba(5, 11, 22, 0.08) 100%),
    linear-gradient(90deg, rgba(5, 11, 22, 0.68) 0%, rgba(5, 11, 22, 0.22) 55%, rgba(5, 11, 22, 0.08) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.45) 0%, rgba(5, 11, 22, 0.10) 22%, rgba(5, 11, 22, 0.10) 78%, rgba(5, 11, 22, 0.66) 100%);
}

.proof-hero-scanline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  z-index: 2;
  background: linear-gradient(90deg, rgba(244, 211, 123, 0) 0%, rgba(244, 211, 123, 0.85) 50%, rgba(244, 211, 123, 0) 100%);
  transform: scaleX(0);
  transform-origin: 0 50%;
  opacity: 0;
  pointer-events: none;
}

.proof-hero:has(.is-visible) .proof-hero-scanline {
  animation: psg-scanline 2200ms var(--ease) 280ms forwards;
}

.proof-hero-shell {
  position: relative;
  z-index: 3;
  max-width: 720px;
}

.proof-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.proof-hero-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.proof-hero-title {
  margin: 22px 0 22px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(2.4rem, 4.8vw, 4.2rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

.proof-hero-title em {
  font-style: normal;
  font-weight: inherit;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400);
}

.proof-hero-rule {
  display: block;
  width: 120px;
  height: 1px;
  margin: 4px 0 22px;
  border: 0;
  background: rgba(244, 211, 123, 0.7);
}

.proof-hero-lede {
  max-width: 620px;
  margin: 0 0 32px;
  color: rgba(214, 222, 234, 0.84);
  font-size: 1.06rem;
  line-height: 1.65;
}

.proof-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 22px;
  margin-bottom: 34px;
}

.proof-hero-primary {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 54px;
  padding: 0 26px;
  border: 0;
  border-radius: 3px;
  color: #ffffff;
  background: linear-gradient(135deg, var(--navy-950) 0%, #15213a 100%);
  box-shadow:
    0 14px 32px rgba(7, 17, 31, 0.30),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  font-weight: 900;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease), background 200ms ease;
}

.proof-hero-primary::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.28) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.proof-hero-primary:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #0d1929 0%, #1c2a47 100%);
  box-shadow:
    0 18px 42px rgba(7, 17, 31, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.10) inset;
}

.proof-hero-primary:hover::after {
  left: 110%;
}

.proof-hero-arrow {
  display: inline-block;
  transition: transform 220ms var(--ease);
}

.proof-hero-primary:hover .proof-hero-arrow {
  transform: translateY(3px);
}

.proof-hero-secondary {
  color: rgba(232, 238, 248, 0.78);
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: underline;
  text-decoration-color: rgba(232, 238, 248, 0.22);
  text-underline-offset: 4px;
  transition: color 180ms ease, text-decoration-color 180ms ease;
}

.proof-hero-secondary:hover {
  color: white;
  text-decoration-color: var(--gold-400);
}

.proof-hero-pillars {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
  color: rgba(232, 238, 248, 0.86);
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
}

.proof-hero-pillars i {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold-400);
  opacity: 0.75;
}

/* ---- Representative outcomes strip (light) ---- */
.proof-metrics-strip {
  background:
    radial-gradient(ellipse at 88% 0%, rgba(244, 211, 123, 0.08), transparent 36%),
    linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.proof-metrics-shell {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 48px;
  align-items: center;
}

.proof-metrics-intro h2 {
  margin: 14px 0 16px;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(1.7rem, 2.6vw, 2.2rem);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -0.05em;
}

.proof-metrics-intro p {
  color: var(--slate-600);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0;
}

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

.proof-metrics-grid article {
  padding: 22px 22px 20px;
  border-radius: 18px;
  border: 1px solid rgba(217, 173, 79, 0.30);
  background: linear-gradient(180deg, rgba(244, 211, 123, 0.08), rgba(255, 255, 255, 0.5));
  transition: border-color 240ms ease, transform 240ms var(--ease);
}

.proof-metrics-grid article:hover {
  border-color: rgba(217, 173, 79, 0.55);
  transform: translateY(-2px);
}

.proof-metric-label {
  display: block;
  color: var(--slate-600);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.proof-metric-value {
  display: block;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(2rem, 2.6vw, 2.6rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  background: linear-gradient(180deg, #c98b1b 0%, var(--gold-500) 60%, #9a721c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-500);
  margin-bottom: 10px;
}

.proof-metrics-grid small {
  display: block;
  color: var(--slate-600);
  font-size: 0.84rem;
  line-height: 1.45;
}

/* ---- Case studies (3 cards, vertical stack on desktop) ---- */
.proof-cases {
  background:
    radial-gradient(ellipse at 12% 0%, rgba(79, 140, 255, 0.06), transparent 30%),
    linear-gradient(180deg, #f7faff 0%, #ffffff 100%);
}

.proof-cases-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  margin-top: 14px;
}

.proof-case-card {
  position: relative;
  padding: 32px 32px 28px;
  border-radius: 26px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
  box-shadow: 0 18px 50px rgba(7, 17, 31, 0.08);
  transition: border-color 240ms ease, box-shadow 240ms var(--ease), transform 240ms var(--ease);
}

.proof-case-card:hover {
  border-color: rgba(217, 173, 79, 0.36);
  box-shadow: 0 26px 64px rgba(7, 17, 31, 0.12);
  transform: translateY(-2px);
}

.proof-case-head {
  margin-bottom: 22px;
}

.proof-case-tag {
  display: inline-block;
  color: var(--gold-500);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.proof-case-head h3 {
  margin: 0;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(1.32rem, 2vw, 1.66rem);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.035em;
  text-wrap: balance;
}

.proof-case-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 18px;
}

.proof-case-block {
  padding: 18px 18px;
  border-radius: 14px;
  background: rgba(248, 251, 255, 0.6);
  border: 1px solid rgba(216, 222, 232, 0.6);
}

.proof-case-block-result {
  background: linear-gradient(180deg, rgba(244, 211, 123, 0.10), rgba(255, 250, 232, 0.4));
  border-color: rgba(217, 173, 79, 0.34);
}

.proof-case-label {
  display: block;
  color: var(--slate-600);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.proof-case-block-result .proof-case-label {
  color: var(--gold-500);
}

.proof-case-block p {
  margin: 0;
  color: var(--slate-700);
  font-size: 0.94rem;
  line-height: 1.55;
}

.proof-case-block p strong {
  color: var(--navy-950);
  font-weight: 800;
}

.proof-case-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.proof-case-pills li {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(7, 17, 31, 0.06);
  border: 1px solid rgba(216, 222, 232, 0.85);
  color: var(--navy-800);
  font-size: 0.72rem;
  font-weight: 800;
  white-space: nowrap;
}

/* ---- Engagement-in-motion (dark cinematic, group image) ---- */
.proof-engagement {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.proof-engagement-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 60% center;
  filter: saturate(1.06) contrast(1.05) brightness(0.78);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.proof-engagement:has(.is-visible) .proof-engagement-bg {
  transform: scale(1);
}

.proof-engagement-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5, 11, 22, 0.84) 0%, rgba(5, 11, 22, 0.45) 50%, rgba(5, 11, 22, 0.18) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.42) 0%, rgba(5, 11, 22, 0.08) 22%, rgba(5, 11, 22, 0.08) 78%, rgba(5, 11, 22, 0.55) 100%);
}

.proof-engagement-shell {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
}

.proof-engagement-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.proof-engagement-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.proof-engagement-copy h2 {
  margin: 18px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1.85rem, 3vw, 2.6rem);
  line-height: 1.1;
  letter-spacing: -0.045em;
}

.proof-engagement-copy p {
  color: rgba(214, 222, 234, 0.82);
  font-size: 1rem;
  line-height: 1.62;
}

.proof-engagement-modes {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.proof-engagement-modes li {
  position: relative;
  padding: 18px 22px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01));
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: start;
  gap: 14px;
  transition: border-color 240ms ease, background 240ms ease;
}

.proof-engagement-modes li:hover {
  border-color: rgba(217, 173, 79, 0.38);
  background: linear-gradient(180deg, rgba(217, 173, 79, 0.06), rgba(255, 255, 255, 0.015));
}

.proof-engagement-num {
  grid-row: 1 / span 2;
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  color: var(--navy-950);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.04em;
}

.proof-engagement-modes strong {
  color: white;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.32rem;
  font-weight: 500;
  font-style: italic;
  letter-spacing: 0;
}

.proof-engagement-modes small {
  display: block;
  margin-top: 4px;
  color: rgba(214, 222, 234, 0.75);
  font-size: 0.92rem;
  line-height: 1.5;
}

/* ---- Voices (testimonial cards, light section) ---- */
.proof-voices {
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.proof-voices-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 12px;
}

.proof-voice-card {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 28px 26px 26px;
  border-radius: 22px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
  box-shadow: 0 14px 40px rgba(7, 17, 31, 0.06);
  transition: transform 240ms var(--ease), border-color 240ms ease, box-shadow 240ms var(--ease);
}

.proof-voice-card:hover {
  transform: translateY(-3px);
  border-color: rgba(217, 173, 79, 0.36);
  box-shadow: 0 22px 56px rgba(7, 17, 31, 0.10);
}

.proof-voice-card p {
  margin: 0 0 22px;
  color: var(--navy-900);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-style: italic;
  font-size: 1.16rem;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -0.005em;
}

.proof-voice-card footer {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid rgba(217, 173, 79, 0.28);
}

.proof-voice-card strong {
  color: var(--navy-950);
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: -0.01em;
}

.proof-voice-card span {
  color: var(--slate-600);
  font-size: 0.84rem;
  font-weight: 600;
  letter-spacing: 0.005em;
}

/* ---- Leave-behind closing section (dark cinematic, laptop image) ---- */
.proof-leavebehind {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #04080f;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.proof-leavebehind-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 70% center;
  filter: saturate(1.06) contrast(1.04) brightness(0.74);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.proof-leavebehind:has(.is-visible) .proof-leavebehind-bg {
  transform: scale(1);
}

.proof-leavebehind-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 80% 70% at 22% 50%, rgba(4, 8, 15, 0.65) 0%, rgba(4, 8, 15, 0.28) 60%, rgba(4, 8, 15, 0.08) 100%),
    linear-gradient(180deg, rgba(4, 8, 15, 0.45) 0%, rgba(4, 8, 15, 0.12) 22%, rgba(4, 8, 15, 0.18) 78%, rgba(4, 8, 15, 0.66) 100%);
}

.proof-leavebehind-shell {
  position: relative;
  z-index: 2;
  max-width: 920px;
}

.proof-leavebehind-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.proof-leavebehind-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.proof-leavebehind h2 {
  margin: 18px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 3.4vw, 2.8rem);
  line-height: 1.08;
  letter-spacing: -0.05em;
  text-wrap: balance;
}

.proof-leavebehind-lede {
  max-width: 720px;
  margin: 0 0 36px;
  color: rgba(214, 222, 234, 0.82);
  font-size: 1.02rem;
  line-height: 1.65;
}

.proof-leavebehind-pillars {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.proof-leavebehind-pillars article {
  padding: 18px 18px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
  transition: border-color 240ms ease, transform 240ms var(--ease);
}

.proof-leavebehind-pillars article:hover {
  border-color: rgba(217, 173, 79, 0.42);
  transform: translateY(-2px);
}

.proof-leavebehind-num {
  display: inline-block;
  color: rgba(244, 211, 123, 0.6);
  font-size: 0.66rem;
  font-weight: 950;
  letter-spacing: 0.2em;
  margin-bottom: 6px;
}

.proof-leavebehind-pillars strong {
  display: block;
  color: white;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.36rem;
  font-weight: 500;
  font-style: italic;
  letter-spacing: 0;
}

.proof-leavebehind-pillars small {
  display: block;
  margin-top: 4px;
  color: rgba(214, 222, 234, 0.7);
  font-size: 0.85rem;
  line-height: 1.4;
}

/* ---- Responsive ---- */
@media (max-width: 1020px) {
  .proof-metrics-shell {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .proof-engagement-shell {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .proof-leavebehind-pillars {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 880px) {
  .proof-case-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .proof-voices-grid {
    grid-template-columns: 1fr;
  }
  .proof-leavebehind-pillars {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .proof-hero {
    padding: 138px 0 84px;
    min-height: 540px;
  }
  .proof-hero-shade {
    background:
      linear-gradient(180deg, rgba(5, 11, 22, 0.80) 0%, rgba(5, 11, 22, 0.62) 60%, rgba(5, 11, 22, 0.85) 100%);
  }
  .proof-hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .proof-hero-primary {
    justify-content: center;
  }
  .proof-hero-pillars {
    flex-wrap: wrap;
    white-space: normal;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    gap: 8px;
  }
  .proof-metrics-grid {
    grid-template-columns: 1fr;
  }
  .proof-case-card {
    padding: 26px 22px 24px;
  }
  .proof-leavebehind-pillars {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .proof-hero-bg,
  .proof-engagement-bg,
  .proof-leavebehind-bg,
  .proof-hero-scanline,
  .proof-hero-primary,
  .proof-hero-primary::after,
  .proof-hero-arrow,
  .proof-case-card,
  .proof-metrics-grid article,
  .proof-engagement-modes li,
  .proof-voice-card,
  .proof-leavebehind-pillars article,
  .proof-hero-eyebrow i,
  .proof-engagement-eyebrow i,
  .proof-leavebehind-eyebrow i {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}


/* ===============================================================
   Service detail pages (6 pages share this template)
   Hero → Why → Challenges → How PSG helps → Deliverables (dark)
   → Engagement options → Related experience → Final CTA + FAQ
   All scoped to .svc-* classes so other pages aren't affected.
   =============================================================== */

/* ---- Hero (dark cinematic — backdrop image varies per page) ---- */
.svc-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  min-height: 620px;
  padding: 168px 0 96px;
}

.svc-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 68% center;
  filter: saturate(1.05) contrast(1.05) brightness(0.85);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.svc-hero:has(.is-visible) .svc-hero-bg {
  transform: scale(1);
}

.svc-hero-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 78% 80% at 18% 55%, rgba(5, 11, 22, 0.80) 0%, rgba(5, 11, 22, 0.42) 55%, rgba(5, 11, 22, 0.08) 100%),
    linear-gradient(90deg, rgba(5, 11, 22, 0.66) 0%, rgba(5, 11, 22, 0.22) 55%, rgba(5, 11, 22, 0.08) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.45) 0%, rgba(5, 11, 22, 0.10) 22%, rgba(5, 11, 22, 0.10) 78%, rgba(5, 11, 22, 0.66) 100%);
}

.svc-hero-scanline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  z-index: 2;
  background: linear-gradient(90deg, rgba(244, 211, 123, 0) 0%, rgba(244, 211, 123, 0.85) 50%, rgba(244, 211, 123, 0) 100%);
  transform: scaleX(0);
  transform-origin: 0 50%;
  opacity: 0;
  pointer-events: none;
}

.svc-hero:has(.is-visible) .svc-hero-scanline {
  animation: psg-scanline 2200ms var(--ease) 280ms forwards;
}

.svc-hero-shell {
  position: relative;
  z-index: 3;
  max-width: 760px;
}

.svc-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.svc-hero-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.svc-hero-title {
  margin: 22px 0 22px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(2.3rem, 4.6vw, 4rem);
  font-weight: 700;
  line-height: 0.99;
  letter-spacing: -0.055em;
  text-wrap: balance;
}

.svc-hero-title em {
  font-style: normal;
  font-weight: inherit;
  background: linear-gradient(180deg, #fbe7a8 0%, var(--gold-300) 50%, var(--gold-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--gold-400);
}

.svc-hero-rule {
  display: block;
  width: 120px;
  height: 1px;
  margin: 4px 0 22px;
  border: 0;
  background: rgba(244, 211, 123, 0.7);
}

.svc-hero-lede {
  max-width: 620px;
  margin: 0 0 32px;
  color: rgba(214, 222, 234, 0.84);
  font-size: 1.04rem;
  line-height: 1.65;
}

.svc-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 22px;
  margin-bottom: 34px;
}

.svc-hero-primary {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 54px;
  padding: 0 26px;
  border: 0;
  border-radius: 3px;
  color: #ffffff;
  background: linear-gradient(135deg, var(--navy-950) 0%, #15213a 100%);
  box-shadow:
    0 14px 32px rgba(7, 17, 31, 0.30),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  font-weight: 900;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease), background 200ms ease;
}

.svc-hero-primary::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -40%;
  width: 38%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.28) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left 620ms var(--ease);
  pointer-events: none;
  z-index: -1;
}

.svc-hero-primary:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #0d1929 0%, #1c2a47 100%);
  box-shadow:
    0 18px 42px rgba(7, 17, 31, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.10) inset;
}

.svc-hero-primary:hover::after {
  left: 110%;
}

.svc-hero-arrow {
  display: inline-block;
  transition: transform 220ms var(--ease);
}

.svc-hero-primary:hover .svc-hero-arrow {
  transform: translateX(4px);
}

.svc-hero-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 22px;
  border: 1px solid var(--platinum-300);
  border-radius: 3px;
  background: rgba(237, 241, 246, 0.86);
  color: var(--slate-700);
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: none;
  transition: color 180ms ease, background 180ms ease, border-color 180ms ease;
}

.svc-hero-secondary:hover {
  color: var(--navy-950);
  background: rgba(216, 222, 232, 0.94);
  border-color: var(--slate-500);
}

.svc-hero-pillars {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  color: rgba(232, 238, 248, 0.86);
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.svc-hero-pillars i {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold-400);
  opacity: 0.75;
}

/* ---- Why it matters (light, narrow centered block) ---- */
.svc-why {
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.svc-why-shell {
  max-width: 760px;
  margin: 0 auto;
}

.svc-why-shell h2 {
  margin: 14px 0 18px;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(1.8rem, 2.8vw, 2.4rem);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -0.045em;
  text-wrap: balance;
}

.svc-why-shell p {
  color: var(--slate-700);
  font-size: 1.04rem;
  line-height: 1.65;
  margin: 0 0 18px;
}

.svc-why-shell p:last-child {
  margin-bottom: 0;
}

/* ---- Common challenges (light, 2-col layout) ---- */
.svc-challenges {
  background: linear-gradient(180deg, #f7faff 0%, #ffffff 100%);
}

.svc-challenges-shell {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 48px;
  align-items: start;
}

.svc-challenges-copy h2 {
  margin: 14px 0 16px;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(1.6rem, 2.4vw, 2.05rem);
  font-weight: 700;
  line-height: 1.14;
  letter-spacing: -0.04em;
}

.svc-challenges-copy p {
  color: var(--slate-600);
  font-size: 0.98rem;
  line-height: 1.6;
  margin: 0;
}

.svc-challenges-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.svc-challenges-list li {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 12px;
  padding: 14px 18px;
  border-radius: 12px;
  border: 1px solid rgba(216, 222, 232, 0.82);
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  color: var(--navy-900);
  font-size: 0.96rem;
  line-height: 1.5;
  transition: border-color 200ms ease, transform 200ms var(--ease);
}

.svc-challenges-list li:hover {
  border-color: rgba(217, 173, 79, 0.40);
  transform: translateY(-1px);
}

.svc-challenges-list li > span {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  color: var(--navy-950);
  font-size: 0.72rem;
  font-weight: 950;
  margin-top: 2px;
}

/* ---- How PSG helps (light, 3-col card grid) ---- */
.svc-help {
  background:
    radial-gradient(ellipse at 12% 0%, rgba(79, 140, 255, 0.06), transparent 32%),
    linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.svc-help-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 12px;
}

.svc-help-card {
  position: relative;
  padding: 26px 24px 24px;
  border-radius: 22px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
  box-shadow: 0 14px 38px rgba(7, 17, 31, 0.06);
  transition: transform 240ms var(--ease), border-color 240ms ease, box-shadow 240ms var(--ease);
}

.svc-help-card:hover {
  transform: translateY(-3px);
  border-color: rgba(217, 173, 79, 0.36);
  box-shadow: 0 22px 56px rgba(7, 17, 31, 0.10);
}

.svc-help-num {
  display: inline-block;
  color: var(--gold-500);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.20em;
  margin-bottom: 10px;
}

.svc-help-card h3 {
  margin: 0 0 10px;
  color: var(--navy-950);
  font-size: 1.16rem;
  line-height: 1.2;
  letter-spacing: -0.028em;
}

.svc-help-card p {
  margin: 0;
  color: var(--slate-600);
  font-size: 0.92rem;
  line-height: 1.55;
}

/* ---- Deliverables (dark cinematic, what-you-get) ---- */
.svc-deliverables {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #050b16;
  color: rgba(232, 238, 248, 0.92);
  padding: clamp(96px, 11vw, 138px) 0;
}

.svc-deliverables-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 60% center;
  filter: saturate(1.06) contrast(1.04) brightness(0.78);
  transform: scale(1.02);
  transition: transform 1400ms var(--ease);
}

.svc-deliverables:has(.is-visible) .svc-deliverables-bg {
  transform: scale(1);
}

.svc-deliverables-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5, 11, 22, 0.82) 0%, rgba(5, 11, 22, 0.45) 50%, rgba(5, 11, 22, 0.20) 100%),
    linear-gradient(180deg, rgba(5, 11, 22, 0.40) 0%, rgba(5, 11, 22, 0.08) 22%, rgba(5, 11, 22, 0.08) 78%, rgba(5, 11, 22, 0.55) 100%);
}

.svc-deliverables-shell {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 48px;
  align-items: start;
}

.svc-deliverables-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  color: var(--gold-300);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.svc-deliverables-eyebrow i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 12px rgba(217, 173, 79, 0.55);
  animation: psg-eyebrow-pulse 2.4s ease-out infinite;
}

.svc-deliverables-copy h2 {
  margin: 18px 0 18px;
  color: white;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1.7rem, 2.6vw, 2.3rem);
  line-height: 1.12;
  letter-spacing: -0.045em;
}

.svc-deliverables-copy p {
  color: rgba(214, 222, 234, 0.82);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0;
}

.svc-deliverables-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 12px;
}

.svc-deliverables-list li {
  position: relative;
  padding: 12px 14px 12px 32px;
  border-radius: 10px;
  border: 1px solid rgba(244, 211, 123, 0.18);
  background: linear-gradient(180deg, rgba(244, 211, 123, 0.05), rgba(255, 255, 255, 0.01));
  color: rgba(232, 238, 248, 0.92);
  font-size: 0.88rem;
  line-height: 1.45;
  transition: border-color 200ms ease, transform 200ms var(--ease);
}

.svc-deliverables-list li:hover {
  border-color: rgba(244, 211, 123, 0.42);
  transform: translateY(-1px);
}

.svc-deliverables-list li::before {
  content: "✓";
  position: absolute;
  left: 12px;
  top: 11px;
  color: var(--gold-300);
  font-weight: 950;
  font-size: 0.86rem;
}

/* ---- Engagement options (light, 3-col) ---- */
.svc-engagements {
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.svc-engagements-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 14px;
}

.svc-engagement-card {
  display: flex;
  flex-direction: column;
  padding: 28px 26px 26px;
  border-radius: 22px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 14px 40px rgba(7, 17, 31, 0.07);
  transition: transform 240ms var(--ease), border-color 240ms ease, box-shadow 240ms var(--ease);
}

.svc-engagement-card:hover {
  transform: translateY(-3px);
  border-color: rgba(217, 173, 79, 0.36);
  box-shadow: 0 22px 56px rgba(7, 17, 31, 0.10);
}

.svc-engagement-featured {
  border-color: rgba(217, 173, 79, 0.46);
  background:
    radial-gradient(circle at 100% 0%, rgba(244, 211, 123, 0.12), transparent 50%),
    linear-gradient(180deg, #ffffff, #fffdf3);
  box-shadow: 0 18px 48px rgba(217, 173, 79, 0.14);
}

.svc-engagement-tag {
  display: inline-block;
  color: var(--gold-500);
  font-size: 0.7rem;
  font-weight: 950;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.svc-engagement-card h3 {
  margin: 12px 0 10px;
  color: var(--navy-950);
  font-size: 1.18rem;
  line-height: 1.22;
  letter-spacing: -0.025em;
}

.svc-engagement-card p {
  margin: 0 0 18px;
  color: var(--slate-600);
  font-size: 0.94rem;
  line-height: 1.55;
}

.svc-engagement-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  color: var(--navy-900);
  font-weight: 800;
  font-size: 0.94rem;
  transition: color 200ms ease;
}

.svc-engagement-link span {
  color: var(--gold-500);
  transition: transform 220ms var(--ease);
}

.svc-engagement-link:hover span {
  transform: translateX(4px);
}

.svc-engagement-link-gold {
  color: var(--gold-600, #a8741e);
  font-weight: 900;
}

/* ---- Related experience (light, narrow centered) ---- */
.svc-related {
  background: linear-gradient(180deg, #f7faff 0%, #ffffff 100%);
}

.svc-related-shell {
  max-width: 820px;
  margin: 0 auto;
  padding: 30px 32px;
  border-radius: 24px;
  border: 1px solid rgba(216, 222, 232, 0.85);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.94));
  box-shadow: 0 16px 44px rgba(7, 17, 31, 0.06);
}

.svc-related-shell h2 {
  margin: 14px 0 14px;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(1.5rem, 2.2vw, 1.9rem);
  font-weight: 700;
  line-height: 1.14;
  letter-spacing: -0.04em;
}

.svc-related-shell > p {
  color: var(--slate-700);
  font-size: 0.98rem;
  line-height: 1.6;
  margin: 0 0 22px;
}

.svc-related-impact {
  padding: 18px 20px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(244, 211, 123, 0.08), rgba(255, 250, 232, 0.4));
  border: 1px solid rgba(217, 173, 79, 0.30);
  margin: 0 0 22px;
}

.svc-related-impact-label {
  display: block;
  color: var(--gold-500);
  font-size: 0.7rem;
  font-weight: 950;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.svc-related-impact ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
}

.svc-related-impact li {
  position: relative;
  padding-left: 14px;
  color: var(--navy-800);
  font-size: 0.92rem;
  line-height: 1.45;
}

.svc-related-impact li::before {
  content: "·";
  position: absolute;
  left: 4px;
  color: var(--gold-500);
  font-weight: 900;
}

.svc-related-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--navy-900);
  font-weight: 800;
  font-size: 0.96rem;
  transition: color 200ms ease;
}

.svc-related-link span {
  color: var(--gold-500);
  transition: transform 220ms var(--ease);
}

.svc-related-link:hover span {
  transform: translateX(4px);
}

/* ---- Final CTA + FAQ (light, 2-col) ---- */
.svc-finalcta {
  background:
    radial-gradient(ellipse at 88% 100%, rgba(244, 211, 123, 0.08), transparent 36%),
    linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.svc-finalcta-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: start;
}

.svc-finalcta-copy h2 {
  margin: 0 0 16px;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: clamp(1.7rem, 2.6vw, 2.3rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.045em;
  text-wrap: balance;
}

.svc-finalcta-copy p {
  color: var(--slate-700);
  font-size: 1.02rem;
  line-height: 1.62;
  margin: 0 0 28px;
}

.svc-finalcta-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 18px;
}

.svc-faq-title {
  margin: 0 0 18px;
  color: var(--navy-950);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: 1.16rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.svc-faq-item {
  border: 1px solid rgba(216, 222, 232, 0.85);
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  margin-bottom: 10px;
  transition: border-color 200ms ease;
}

.svc-faq-item:hover {
  border-color: rgba(217, 173, 79, 0.36);
}

.svc-faq-item[open] {
  border-color: rgba(217, 173, 79, 0.46);
  box-shadow: 0 10px 30px rgba(7, 17, 31, 0.06);
}

.svc-faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 44px 14px 18px;
  position: relative;
  color: var(--navy-950);
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.svc-faq-item summary::-webkit-details-marker { display: none; }

.svc-faq-item summary::after {
  content: "+";
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--gold-500);
  font-size: 1.18rem;
  font-weight: 900;
  line-height: 1;
  transition: transform 200ms var(--ease);
}

.svc-faq-item[open] summary::after {
  content: "−";
}

.svc-faq-item p {
  margin: 0;
  padding: 0 18px 16px;
  color: var(--slate-700);
  font-size: 0.92rem;
  line-height: 1.55;
}

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

@media (max-width: 880px) {
  .svc-challenges-shell {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .svc-deliverables-shell {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .svc-deliverables-list {
    grid-template-columns: 1fr;
  }
  .svc-finalcta-shell {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .svc-help-grid {
    grid-template-columns: 1fr;
  }
  .svc-engagements-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .svc-hero {
    padding: 138px 0 84px;
    min-height: 540px;
  }
  .svc-hero-shade {
    background:
      linear-gradient(180deg, rgba(5, 11, 22, 0.80) 0%, rgba(5, 11, 22, 0.62) 60%, rgba(5, 11, 22, 0.85) 100%);
  }
  .svc-hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .svc-hero-primary,
  .svc-hero-secondary {
    justify-content: center;
  }
  .svc-related-shell {
    padding: 24px 22px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .svc-hero-bg,
  .svc-deliverables-bg,
  .svc-hero-scanline,
  .svc-hero-primary,
  .svc-hero-primary::after,
  .svc-hero-arrow,
  .svc-help-card,
  .svc-challenges-list li,
  .svc-deliverables-list li,
  .svc-engagement-card,
  .svc-faq-item summary::after,
  .svc-hero-eyebrow i,
  .svc-deliverables-eyebrow i {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}


/* ===============================================================
   Services dropdown (top nav)
   Hover/focus reveals a panel under the Services link listing all
   6 service detail pages with chess-piece glyphs + short blurbs.
   Mobile: collapses to a static inline list inside the open nav.
   =============================================================== */

.primary-nav .nav-item-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
}

/* Match the pill treatment of other top-nav links */
.primary-nav .nav-item-dropdown > a {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 10px 14px;
  border-radius: 999px;
  transition: color 180ms ease, background 180ms ease;
}

.primary-nav .nav-item-dropdown > a:hover,
.primary-nav .nav-item-dropdown > a[aria-current="page"],
.primary-nav .nav-item-dropdown:focus-within > a {
  color: var(--navy-950);
  background: rgba(16, 35, 61, 0.07);
}

.nav-caret {
  display: inline-block;
  font-size: 0.62em;
  opacity: 0.6;
  transition: transform 220ms var(--ease);
  margin-left: 1px;
}

.primary-nav .nav-item-dropdown:hover .nav-caret,
.primary-nav .nav-item-dropdown:focus-within .nav-caret {
  transform: rotate(180deg);
  opacity: 0.95;
}

/* Invisible hover-bridge so the cursor can travel from the
   trigger to the panel without the panel collapsing */
.primary-nav .nav-item-dropdown::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 14px;
  pointer-events: none;
}

.primary-nav .nav-item-dropdown:hover::after,
.primary-nav .nav-item-dropdown:focus-within::after {
  pointer-events: auto;
}

.nav-dropdown {
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  width: 360px;
  padding: 10px;
  border-radius: 20px;
  border: 1px solid rgba(216, 222, 232, 0.88);
  /* Solid white + no backdrop-filter. Backdrop-filter combined with
     transform forces text through a blur shader, which softens
     rasterization. Solid white keeps the panel crisp + readable. */
  background: #ffffff;
  box-shadow: 0 24px 64px rgba(7, 17, 31, 0.18);
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity 220ms ease, transform 220ms var(--ease), visibility 0s linear 240ms;
  z-index: 60;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.primary-nav .nav-item-dropdown:hover .nav-dropdown,
.primary-nav .nav-item-dropdown:focus-within .nav-dropdown {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  transition: opacity 220ms ease, transform 220ms var(--ease), visibility 0s;
}

/* Soft gold rule + small label at the top of the panel */
.nav-dropdown-header {
  padding: 6px 14px 4px;
  color: var(--gold-500);
  font-size: 0.66rem;
  font-weight: 950;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.nav-dropdown > a {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 12px;
  color: var(--navy-900);
  font-weight: 700;
  text-decoration: none;
  transition: background 180ms ease, transform 180ms ease;
}

.nav-dropdown > a:hover,
.nav-dropdown > a:focus-visible,
.nav-dropdown > a[aria-current="page"] {
  background: rgba(244, 211, 123, 0.12);
  outline: none;
}

.nav-dropdown-glyph {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: linear-gradient(135deg, #fff8df, var(--gold-300));
  color: var(--navy-950);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.05rem;
  line-height: 1;
  box-shadow: 0 4px 12px rgba(217, 173, 79, 0.20);
}

.nav-dropdown-text strong {
  display: block;
  color: var(--navy-950);
  font-size: 0.92rem;
  letter-spacing: -0.015em;
}

.nav-dropdown-text small {
  display: block;
  margin-top: 2px;
  color: var(--slate-600);
  font-size: 0.76rem;
  line-height: 1.35;
  font-weight: 500;
}

/* Optional footer link in the panel — points at the full Services page */
.nav-dropdown-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 4px;
  padding: 10px 14px;
  border-top: 1px solid rgba(216, 222, 232, 0.85);
  color: var(--navy-900);
  font-size: 0.82rem;
  font-weight: 800;
  transition: color 180ms ease;
}

.nav-dropdown-footer:hover {
  color: var(--gold-500);
}

.nav-dropdown-footer span {
  transition: transform 220ms var(--ease);
}

.nav-dropdown-footer:hover span {
  transform: translateX(3px);
}

/* ---- Mobile: hamburger panel. Services dropdown is collapsed
   by default; tapping the caret pill on the right toggles it open.
   The text "Services" still links to the Services page directly. */
@media (max-width: 900px) {
  .primary-nav .nav-item-dropdown {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .primary-nav .nav-item-dropdown::after {
    display: none;
  }

  /* Trigger row: leave room on the right for the caret toggle pill */
  .primary-nav .nav-item-dropdown > a {
    position: relative;
    padding-right: 48px;
  }

  .nav-caret {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: rgba(16, 35, 61, 0.06);
    color: var(--navy-800);
    font-size: 0.92em;
    opacity: 1;
    cursor: pointer;
    transition: transform 220ms var(--ease), background 180ms ease;
    pointer-events: auto;
  }

  .primary-nav .nav-item-dropdown.is-open .nav-caret {
    transform: translateY(-50%) rotate(180deg);
    background: rgba(244, 211, 123, 0.18);
  }

  /* Collapsed by default on mobile */
  .nav-dropdown {
    position: static;
    transform: none;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    width: 100%;
    max-height: 0;
    overflow: hidden;
    padding: 0 0 0 16px;
    margin-top: 0;
    border: 0;
    border-left: 1px solid rgba(216, 222, 232, 0.7);
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
    border-radius: 0;
    transition: max-height 260ms var(--ease), opacity 200ms ease, padding 200ms ease, margin 200ms ease, visibility 0s linear 280ms;
  }

  /* Expanded state on mobile (via JS toggle) */
  .primary-nav .nav-item-dropdown.is-open .nav-dropdown {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    max-height: 600px;
    padding: 6px 0 10px 16px;
    margin-top: 6px;
    transition: max-height 320ms var(--ease), opacity 200ms ease, padding 200ms ease, margin 200ms ease, visibility 0s;
  }

  /* Neutralize desktop hover/focus reveal on mobile so only the
     .is-open class controls visibility (avoids tap-and-it-stays-open). */
  .primary-nav .nav-item-dropdown:hover .nav-dropdown,
  .primary-nav .nav-item-dropdown:focus-within .nav-dropdown {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    max-height: 0;
    padding: 0 0 0 16px;
    margin-top: 0;
  }

  .primary-nav .nav-item-dropdown.is-open:hover .nav-dropdown,
  .primary-nav .nav-item-dropdown.is-open:focus-within .nav-dropdown {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    max-height: 600px;
    padding: 6px 0 10px 16px;
    margin-top: 6px;
  }

  .nav-dropdown-header,
  .nav-dropdown-footer {
    display: none;
  }

  .nav-dropdown > a {
    padding: 8px 10px;
    grid-template-columns: 26px minmax(0, 1fr);
    gap: 10px;
  }

  .nav-dropdown-glyph {
    width: 26px;
    height: 26px;
    font-size: 0.92rem;
    box-shadow: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .nav-dropdown,
  .nav-caret,
  .nav-dropdown > a,
  .nav-dropdown-footer span {
    transition: none !important;
    transform: none !important;
  }
}
