@import url("https://api.fontshare.com/v2/css?f[]=greycliff-cf@400,500,600,700,800,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,700&family=Space+Grotesk:wght@300;400;500;600;700&display=swap");

:root {
  --navy: #213258;
  --cream: #f6f3dc;
  --yellow: #f0d293;
  --pink: #e8998c;
  --purple: #494f7e;
  --ink: #10162a;
  /* Light surfaces derived from brand cream (less stark than pure white) */
  --surface-warm: color-mix(in srgb, var(--cream) 92%, white 8%);
  --surface-gold-wash: color-mix(in srgb, var(--yellow) 16%, var(--cream) 84%);
  --surface-slate-wash: color-mix(in srgb, var(--purple) 16%, var(--cream) 84%);
  --mist: rgba(246, 243, 220, 0.12);
  --glow: rgba(240, 210, 147, 0.45);
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --shadow-soft: 0 24px 80px rgba(16, 22, 42, 0.35);
  --shadow-mid: 0 16px 40px rgba(16, 22, 42, 0.4);
  --space-1: 8px;
  --space-2: 12px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 32px;
  --space-6: 48px;
  --space-7: 72px;
  --space-8: 96px;
  --space-9: 128px;
  /* Horizontal gutter: header + primary content + footer (single alignment) */
  --layout-gutter: clamp(1rem, 4vw, 2rem);
  --header-pad: 10px;
  /* Tighter vertical padding so a taller logo still fits the same nav row height */
  --header-nav-pad-block: 0px;
  /* One-third larger than 124×66; nav row height unchanged */
  --header-logo-w: 165px;
  /* Wordmark: target height; width capped so the link row does not crowd nav text */
  --header-logo-h: 88px;
  --header-nav-max-depth: 100px;
  /* Match .site-header for case-study hero bands */
  --header-surface: rgba(26, 39, 70, 0.78);
}

/* Animated primary-button border (conic sweep) — used with layered background-clip */
@property --btn-mb-angle {
  syntax: "<angle>";
  inherits: false;
  initial-value: 0deg;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Greycliff CF", "Space Grotesk", system-ui, sans-serif;
  color: var(--cream);
  background: #030711;
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
}

.page-transition {
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at 20% 20%, rgba(240, 210, 147, 0.25), transparent 45%),
    radial-gradient(circle at 80% 20%, rgba(232, 153, 140, 0.25), transparent 40%),
    linear-gradient(135deg, rgba(16, 22, 42, 0.9), rgba(33, 50, 88, 0.95));
  z-index: 40;
  opacity: 0;
  transform: translateY(-12px);
  transition: opacity 0.7s ease, transform 0.7s ease;
  pointer-events: none;
}

.page-transition.is-ready {
  opacity: 0;
  transform: translateY(-12px);
}

.page-transition.is-active {
  opacity: 1;
  transform: translateY(0);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image: linear-gradient(rgba(246, 243, 220, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(246, 243, 220, 0.06) 1px, transparent 1px);
  background-size: 140px 140px;
  opacity: 0.09;
  pointer-events: none;
  z-index: -1;
  animation: grid-shift 26s linear infinite;
}

body::after {
  content: "";
  position: fixed;
  inset: -20% 0 0 -20%;
  background: radial-gradient(circle at 20% 20%, rgba(240, 210, 147, 0.25), transparent 45%),
    radial-gradient(circle at 80% 30%, rgba(232, 153, 140, 0.22), transparent 40%),
    radial-gradient(circle at 60% 80%, rgba(73, 79, 126, 0.5), transparent 55%);
  filter: blur(20px);
  opacity: 0.32;
  pointer-events: none;
  z-index: -2;
  animation: ambient-drift 32s ease-in-out infinite;
}

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

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

main {
  padding-top: calc(var(--header-nav-max-depth) + 12px);
}

.container {
  width: 100%;
  max-width: none;
  padding-inline: var(--layout-gutter);
  margin: 0 auto;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.24em;
  font-size: 0.75rem;
  color: rgba(246, 243, 220, 0.7);
}

.eyebrow + h1,
.eyebrow + h2,
.eyebrow + h3 {
  margin-top: var(--space-4);
}

.section {
  padding: var(--space-8) 0;
}

.section-tight {
  padding: var(--space-6) 0;
}

h1,
h2,
h3,
h4 {
  font-family: "Greycliff CF", "Space Grotesk", system-ui, sans-serif;
  margin: 0 0 var(--space-3);
  color: var(--cream);
}

h1 {
  font-size: clamp(2.8rem, 4vw, 4.4rem);
  line-height: 1.05;
}

h2 {
  font-size: clamp(2rem, 3.2vw, 3rem);
  line-height: 1.1;
}

h3 {
  font-size: 1.4rem;
}

p {
  color: rgba(246, 243, 220, 0.86);
  line-height: 1.6;
  margin: 0 0 var(--space-4);
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
  backdrop-filter: blur(12px);
  background: var(--header-surface);
  border-bottom: 1px solid rgba(246, 243, 220, 0.12);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: none;
  min-height: var(--header-nav-max-depth);
  margin: 0;
  padding: var(--header-nav-pad-block) var(--layout-gutter);
  box-sizing: border-box;
}

.site-logo {
  display: inline-flex;
  align-items: center;
  align-self: center;
  gap: 12px;
  line-height: 0;
  padding: 0;
}

.site-logo img {
  height: var(--header-logo-h);
  width: auto;
  max-width: var(--header-logo-w);
  object-fit: contain;
  display: block;
}

.nav-links {
  display: flex;
  gap: 20px;
  align-items: center;
  align-self: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.nav-links > a {
  padding: 8px 10px;
  border-radius: 999px;
  transition: none;
  position: relative;
}

.nav-links > a:hover {
  background: transparent;
}

.nav-links > a::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: -6px;
  height: 2px;
  background: rgba(240, 210, 147, 0.95);
  transform: scaleX(0);
  transform-origin: center;
  transition: none;
}

.nav-links > a:hover::after {
  transform: scaleX(1);
}

.nav-dropdown {
  position: relative;
  align-self: center;
}

.nav-dropdown__trigger {
  font: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  cursor: pointer;
  border: none;
  background: transparent;
  padding: 8px 10px;
  border-radius: 999px;
  color: inherit;
  text-transform: uppercase;
  transition: none;
  position: relative;
}

.nav-dropdown__trigger:hover {
  background: transparent;
}

.nav-dropdown__trigger::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: -6px;
  height: 2px;
  background: rgba(240, 210, 147, 0.95);
  transform: scaleX(0);
  transform-origin: center;
  transition: none;
}

.nav-dropdown__trigger:hover::after,
.nav-dropdown.is-open .nav-dropdown__trigger::after {
  transform: scaleX(1);
}

.nav-dropdown__panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: min(260px, calc(100vw - 32px));
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: #fff;
  border: 1px solid rgba(33, 50, 88, 0.1);
  border-radius: var(--radius-md);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.6) inset,
    0 4px 12px rgba(16, 22, 42, 0.06),
    0 18px 40px -12px rgba(16, 22, 42, 0.14);
  z-index: 30;
}

.nav-dropdown__panel[hidden] {
  display: none !important;
}

.nav-dropdown__item {
  display: block;
  padding: 10px 14px;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(33, 50, 88, 0.92);
  text-decoration: none;
  border-radius: var(--radius-sm);
  line-height: 1.25;
  transition: background 0.15s ease, color 0.15s ease;
}

.nav-dropdown__item:hover {
  background: rgba(33, 50, 88, 0.06);
  color: var(--navy);
}

.nav-dropdown__item:focus-visible {
  outline: 2px solid rgba(33, 50, 88, 0.35);
  outline-offset: 2px;
}

.nav-dropdown__item:first-child {
  margin-bottom: 4px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(33, 50, 88, 0.08);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--navy);
}

.nav-dropdown__item:first-child:hover {
  background: rgba(33, 50, 88, 0.06);
}

.cta {
  background: transparent;
  color: inherit;
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 600;
  box-shadow: none;
}

.hero {
  padding: var(--space-9) 0 var(--space-7);
  position: relative;
  overflow: hidden;
}

/* ----- Contact: white page canvas ----- */
body.page-contact {
  background: #fff;
  color: var(--ink);
}

body.page-contact h1,
body.page-contact h2,
body.page-contact h3,
body.page-contact h4 {
  color: var(--navy);
}

body.page-contact p {
  color: rgba(16, 22, 42, 0.82);
}

body.page-contact .eyebrow {
  color: rgba(33, 50, 88, 0.62);
}

body.page-contact .site-header {
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(33, 50, 88, 0.1);
  backdrop-filter: blur(12px);
}

body.page-contact .nav-links,
body.page-contact .nav-dropdown__trigger {
  color: var(--navy);
}

body.page-contact .nav-links > a::after,
body.page-contact .nav-dropdown__trigger::after {
  background: var(--navy);
}

body.page-contact .hero-card {
  background: linear-gradient(
    152deg,
    color-mix(in srgb, var(--navy) 82%, white 18%) 0%,
    var(--navy) 38%,
    color-mix(in srgb, var(--navy) 72%, var(--ink) 28%) 70%,
    color-mix(in srgb, var(--navy) 48%, var(--ink) 52%) 100%
  );
  border: 1px solid rgba(246, 243, 220, 0.18);
  box-shadow:
    0 24px 60px rgba(16, 22, 42, 0.35),
    0 1px 0 rgba(255, 255, 255, 0.08) inset;
  animation: none;
}

body.page-contact .hero-card::after {
  background:
    radial-gradient(ellipse 95% 75% at 88% 8%, rgba(240, 210, 147, 0.16), transparent 58%),
    radial-gradient(ellipse 72% 58% at 10% 88%, rgba(73, 79, 126, 0.22), transparent 52%),
    radial-gradient(ellipse 70% 55% at 6% 92%, rgba(232, 153, 140, 0.08), transparent 52%);
  opacity: 1;
}

body.page-about .hero-card {
  background: linear-gradient(
    152deg,
    color-mix(in srgb, var(--navy) 82%, white 18%) 0%,
    var(--navy) 38%,
    color-mix(in srgb, var(--navy) 72%, var(--ink) 28%) 70%,
    color-mix(in srgb, var(--navy) 48%, var(--ink) 52%) 100%
  );
  border: 1px solid rgba(246, 243, 220, 0.18);
  box-shadow:
    0 24px 60px rgba(16, 22, 42, 0.35),
    0 1px 0 rgba(255, 255, 255, 0.08) inset;
  animation: none;
  transition:
    transform 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease;
}

body.page-about .hero-card:hover {
  transform: translateY(-5px);
  border-color: rgba(246, 243, 220, 0.28);
  box-shadow:
    0 32px 74px rgba(16, 22, 42, 0.38),
    0 1px 0 rgba(255, 255, 255, 0.12) inset;
}

body.page-about .hero-card::after {
  background:
    radial-gradient(ellipse 95% 75% at 88% 8%, rgba(240, 210, 147, 0.16), transparent 58%),
    radial-gradient(ellipse 72% 58% at 10% 88%, rgba(73, 79, 126, 0.22), transparent 52%),
    radial-gradient(ellipse 70% 55% at 6% 92%, rgba(232, 153, 140, 0.08), transparent 52%);
  opacity: 1;
}

body.page-contact .hero-card label {
  color: rgba(246, 243, 220, 0.92);
}

body.page-contact .hero-card input,
body.page-contact .hero-card textarea {
  border: 1px solid rgba(33, 50, 88, 0.18);
  background: #fff;
  color: var(--ink);
}

body.page-contact .hero-card input::placeholder,
body.page-contact .hero-card textarea::placeholder {
  color: rgba(16, 22, 42, 0.42);
}

body.page-contact .hero-card input:focus-visible,
body.page-contact .hero-card textarea:focus-visible {
  outline: 2px solid rgba(33, 50, 88, 0.35);
  outline-offset: 2px;
}

body.page-contact .hero-actions .btn-ghost {
  color: rgba(246, 243, 220, 0.95);
  border-color: rgba(246, 243, 220, 0.38);
}

body.page-contact .hero-actions .btn-ghost:hover,
body.page-contact .hero-actions .btn-ghost:focus-visible {
  color: var(--navy);
}

/* Contact hero: fixed two columns (copy | form), not auto-fit single-column collapse */
body.page-contact .hero-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: start;
  gap: clamp(2rem, 5vw, 3.5rem);
}

body.page-contact .form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 900px) {
  body.page-contact .hero-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  body.page-contact .form-grid {
    grid-template-columns: 1fr;
  }
}

/* ----- About: white page + navy gradient panels (cards, hero-cards) + warm CTA ----- */
body.page-about {
  background: #fff;
  color: var(--ink);
}

body.page-about h1,
body.page-about h2,
body.page-about h3,
body.page-about h4 {
  color: var(--navy);
}

body.page-about p {
  color: rgba(16, 22, 42, 0.82);
}

body.page-about .section > .container > .eyebrow {
  color: rgba(33, 50, 88, 0.62);
}

body.page-about .about-profile-label {
  color: rgba(33, 50, 88, 0.55);
}

body.page-about .about-page-heading-sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

/* About: compact section rhythm */
body.page-about .about-section--compact {
  padding-top: var(--space-5);
  padding-bottom: var(--space-5);
}

body.page-about .about-section--compact .about-section__prose h2 {
  margin-top: 0;
  margin-bottom: var(--space-3);
}

body.page-about .about-section--compact .about-section__prose p {
  margin-bottom: var(--space-3);
}

body.page-about .about-section--compact .about-section__prose p:last-child {
  margin-bottom: 0;
}

body.page-about .about-section--intro-perspective {
  background:
    radial-gradient(ellipse 90% 80% at 50% -20%, rgba(240, 210, 147, 0.14), transparent 55%),
    #fff;
  border-bottom: 1px solid rgba(33, 50, 88, 0.08);
}

/* About — Perspective band: marquee row + breathable editorial copy */
body.page-about .about-perspective {
  max-width: min(62rem, 100%);
  margin-inline: auto;
  text-align: center;
}

body.page-about .about-perspective-marquee {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: clamp(0.5rem, 2.2vw, 1.15rem)
    clamp(0.65rem, 3vw, 1.85rem);
  margin: 0 0 clamp(1.5rem, 4vw, 2.65rem);
  padding: clamp(1.1rem, 3vw, 1.9rem)
    clamp(1rem, 4vw, 2rem)
    clamp(0.55rem, 2vw, 1.1rem);
  border-radius: 999px;
  background: color-mix(in srgb, var(--cream) 38%, white 62%);
  border: 1px solid rgba(33, 50, 88, 0.07);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

body.page-about .about-perspective-marquee__keyword {
  font-family: "Greycliff CF", "Space Grotesk", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.85rem, 5.2vw, 3rem);
  line-height: 1.03;
  letter-spacing: -0.03em;
  color: var(--navy);
}

body.page-about .about-perspective-marquee__roundel {
  display: grid;
  place-items: center;
  width: clamp(60px, 13.5vw, 96px);
  height: clamp(60px, 13.5vw, 96px);
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid rgba(33, 50, 88, 0.12);
  background: radial-gradient(circle at 30% 30%, rgba(240, 210, 147, 0.35), rgba(255, 255, 255, 0.95));
  box-shadow:
    0 2px 0 rgba(255, 255, 255, 0.9) inset,
    0 14px 36px rgba(16, 22, 42, 0.1);
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}

body.page-about .about-perspective-marquee__roundel:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow:
    0 2px 0 rgba(255, 255, 255, 0.9) inset,
    0 20px 44px rgba(16, 22, 42, 0.14);
}

@media (prefers-reduced-motion: reduce) {
  body.page-about .about-perspective-marquee__roundel {
    transition: none;
  }

  body.page-about .about-perspective-marquee__roundel:hover {
    transform: none;
  }
}

body.page-about .about-perspective-marquee__roundel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

body.page-about .about-perspective-heading {
  margin: 0;
}

body.page-about .about-perspective-heading h2 {
  margin: 0;
  font-size: clamp(1.5rem, 4vw, 2.05rem);
  font-weight: 700;
  color: var(--navy);
  letter-spacing: -0.02em;
}

body.page-about .about-perspective-copy {
  margin-top: clamp(1rem, 2.8vw, 1.85rem);
  max-width: min(42rem, 100%);
  margin-inline: auto;
  text-align: left;
}

body.page-about .about-perspective-copy p {
  margin: 0;
  font-size: clamp(1rem, 1.62vw, 1.085rem);
  line-height: 1.74;
  color: rgba(16, 22, 42, 0.78);
}

body.page-about .about-perspective-copy p + p {
  margin-top: clamp(1rem, 3vw, 1.35rem);
}

body.page-about .about-perspective-accent {
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  text-decoration-line: underline;
  text-decoration-style: wavy;
  text-decoration-color: rgba(240, 210, 147, 0.95);
  text-decoration-thickness: 2px;
  text-underline-offset: 6px;
  font-weight: 600;
  color: var(--navy);
}

body.page-about .about-perspective-tagline {
  display: flex;
  justify-content: center;
  margin: clamp(1.85rem, 4.5vw, 2.75rem) 0 0;
  padding-top: clamp(1.5rem, 3.8vw, 2.15rem);
  border-top: 1px solid rgba(33, 50, 88, 0.08);
}

body.page-about .about-perspective-tagline__pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  max-width: min(100%, 28rem);
  padding: clamp(0.85rem, 2.2vw, 1.15rem) clamp(1.6rem, 4.5vw, 2.35rem);
  font-size: clamp(1.05rem, 2.2vw, 1.28rem);
  font-weight: 650;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: var(--navy);
  border-radius: 999px;
  border: 2px solid rgba(33, 50, 88, 0.14);
  background: linear-gradient(
    165deg,
    rgba(255, 255, 255, 0.98) 0%,
    color-mix(in srgb, var(--cream) 55%, white 45%) 100%
  );
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 1) inset,
    0 12px 40px rgba(16, 22, 42, 0.08),
    0 0 0 1px rgba(240, 210, 147, 0.35);
}

@media (max-width: 520px) {
  body.page-about .about-perspective-tagline {
    padding-inline: 0.5rem;
  }

  body.page-about .about-perspective-tagline__pill {
    padding-inline: clamp(1.1rem, 5vw, 1.5rem);
  }
}

@media (max-width: 640px) {
  body.page-about .about-perspective-marquee {
    border-radius: 22px;
  }
}

/* About — Approach: navy band + light cards (readability on dark field) */
body.page-about .about-section--approach {
  background:
    radial-gradient(ellipse 95% 70% at 50% -8%, rgba(33, 50, 88, 0.55), transparent 58%),
    radial-gradient(ellipse 52% 45% at 100% 8%, rgba(240, 210, 147, 0.1), transparent 52%),
    radial-gradient(ellipse 55% 50% at 0% 45%, rgba(73, 79, 126, 0.24), transparent 58%),
    linear-gradient(180deg, #040815 0%, #08122d 42%, #030711 100%);
  color: var(--cream);
  border-bottom: 1px solid rgba(246, 243, 220, 0.08);
}

body.page-about .about-section--approach .about-approach__title {
  margin: 0 0 clamp(1rem, 2.8vw, 1.65rem);
  font-family: "Greycliff CF", "Space Grotesk", system-ui, sans-serif;
  font-size: clamp(1.95rem, 5vw, 2.85rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: rgba(246, 243, 220, 0.98);
}

body.page-about .about-approach__intro {
  text-align: center;
  margin-bottom: clamp(1.6rem, 4vw, 2.85rem);
  max-width: min(52rem, 100%);
  margin-inline: auto;
}

body.page-about .about-section--approach .about-approach__title-em {
  color: rgba(246, 243, 220, 0.98);
  background: linear-gradient(
    to bottom right,
    transparent 52%,
    rgba(240, 210, 147, 0.32) 52%
  );
}

body.page-about .about-approach__title-em {
  font-weight: 800;
  color: var(--navy);
  background: linear-gradient(
    to bottom right,
    transparent 55%,
    color-mix(in srgb, var(--yellow) 42%, transparent) 55%
  );
  padding-inline: 0.06em;
  border-radius: 0.12em;
}

body.page-about .about-section--approach .about-approach__lede {
  margin: 0 auto;
  max-width: min(40rem, 100%);
  font-size: clamp(0.95rem, 1.55vw, 1.065rem);
  line-height: 1.72;
  color: rgba(246, 243, 220, 0.74);
}

body.page-about .about-approach__lede {
  margin: 0 auto;
  max-width: min(40rem, 100%);
  font-size: clamp(0.95rem, 1.55vw, 1.065rem);
  line-height: 1.72;
  color: rgba(16, 22, 42, 0.66);
}

body.page-about .about-approach__split {
  display: grid;
  grid-template-columns: minmax(0, min(44%, 440px)) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 3.75rem);
  align-items: stretch;
}

body.page-about .about-section--approach .about-approach__figure {
  margin: 0;
  align-self: stretch;
  height: auto;
  min-height: 0;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(246, 243, 220, 0.16);
  box-shadow:
    0 1px 0 rgba(246, 243, 220, 0.12) inset,
    0 28px 64px rgba(0, 0, 0, 0.45);
}

body.page-about .about-approach__figure {
  margin: 0;
  align-self: stretch;
  height: auto;
  min-height: 0;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(33, 50, 88, 0.1);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.65) inset,
    0 28px 64px rgba(16, 22, 42, 0.12);
}

body.page-about .about-approach__figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

body.page-about .about-approach__grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: start;
  gap: clamp(1.05rem, 2.85vw, 1.65rem);
}

body.page-about .about-approach-card {
  position: relative;
  margin: 0;
  padding: clamp(1.35rem, 3.2vw, 1.75rem);
  padding-top: clamp(3.55rem, 6vw, 4.35rem);
  border-radius: 16px;
  background: linear-gradient(
    155deg,
    rgba(255, 255, 255, 1) 0%,
    color-mix(in srgb, white 94%, rgba(246, 243, 220, 0.35)) 100%
  );
  border: 1px solid rgba(33, 50, 88, 0.08);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 1) inset,
    0 18px 40px rgba(16, 22, 42, 0.075);
  transition:
    transform 0.22s ease,
    border-color 0.22s ease,
    box-shadow 0.22s ease;
}

body.page-about .about-approach-card:hover {
  transform: translateY(-3px);
  border-color: rgba(33, 50, 88, 0.14);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 1) inset,
    0 26px 56px rgba(16, 22, 42, 0.11);
}

body.page-about .about-approach-card__title {
  margin: 0.45rem 0 var(--space-3);
  font-size: clamp(1.02rem, 1.42vw, 1.125rem);
  font-weight: 700;
  color: var(--navy);
}

body.page-about .about-approach-card p {
  margin: 0;
  font-size: clamp(0.86rem, 1.35vw, 0.935rem);
  line-height: 1.62;
  color: rgba(16, 22, 42, 0.72);
}

body.page-about .about-approach-card__num {
  position: absolute;
  top: 1.05rem;
  left: 1.05rem;
  width: 2.4rem;
  height: 2.4rem;
  display: grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  font-family: "Greycliff CF", "Space Grotesk", system-ui, sans-serif;
  font-size: 0.9375rem;
  font-style: normal;
  font-variant-numeric: tabular-nums;
  font-weight: 800;
  color: var(--navy);
  background: radial-gradient(circle at 35% 30%, rgba(255, 255, 255, 0.95), #e8eefc);
  border: 2px solid rgba(33, 50, 88, 0.12);
  box-shadow:
    0 1px 2px rgba(16, 22, 42, 0.06),
    0 0 0 1px rgba(240, 210, 147, 0.28) inset;
}

@media (prefers-reduced-motion: reduce) {
  body.page-about .about-approach-card {
    transition: none;
  }

  body.page-about .about-approach-card:hover {
    transform: none;
  }
}

@media (max-width: 840px) {
  body.page-about .about-approach__split {
    grid-template-columns: minmax(0, 340px);
    justify-items: stretch;
    max-width: 28rem;
    margin-inline: auto;
  }

  body.page-about .about-approach__figure {
    align-self: stretch;
    aspect-ratio: 16 / 10;
    min-height: 0;
    width: 100%;
  }

  body.page-about .about-approach__figure img {
    min-height: 0;
  }

  body.page-about .about-approach__grid {
    grid-template-columns: 1fr;
  }
}

/* Capabilities — simplified chips on navy */
body.page-about .about-section--capabilities-simple {
  background:
    radial-gradient(ellipse 92% 60% at 50% -12%, rgba(240, 210, 147, 0.12), transparent 55%),
    linear-gradient(
      180deg,
      #030711 0%,
      color-mix(in srgb, var(--navy) 88%, #0a1430 12%) 48%,
      #040815 100%
    );
  color: var(--cream);
  border-top: none;
  border-bottom: 1px solid rgba(246, 243, 220, 0.08);
}

body.page-about .about-section--capabilities-simple .about-capabilities__heading {
  margin-bottom: var(--space-3);
  color: rgba(246, 243, 220, 0.98);
}

body.page-about .about-section--capabilities-simple .about-capabilities-simple__lede {
  color: rgba(246, 243, 220, 0.68);
}

body.page-about .about-capabilities-simple {
  max-width: min(52rem, 100%);
  margin-inline: auto;
  text-align: center;
}

body.page-about .about-capabilities-simple__lede {
  margin: 0 auto var(--space-5);
  max-width: min(38rem, 100%);
  font-size: clamp(0.93rem, 1.42vw, 1.035rem);
  line-height: 1.62;
  color: rgba(16, 22, 42, 0.62);
}

body.page-about .about-capability-chips {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px clamp(14px, 2.8vw, 18px);
}

body.page-about .about-capability-chip {
  display: inline-block;
  margin: 0;
  padding: 0.6rem 1.15rem;
  font-size: clamp(0.84rem, 1.38vw, 0.935rem);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--navy);
  border-radius: 999px;
  border: 1px solid rgba(33, 50, 88, 0.12);
  background: rgba(246, 243, 220, 0.28);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 1) inset,
    0 10px 28px rgba(16, 22, 42, 0.05);
  transition:
    transform 0.52s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.52s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.4s ease,
    background-color 0.4s ease;
}

body.page-about .about-capability-chip:hover {
  transform: translateY(-3px);
  border-color: rgba(232, 153, 140, 0.45);
  background: rgba(246, 243, 220, 0.55);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 1) inset,
    0 16px 40px rgba(16, 22, 42, 0.1);
}

body.page-about .about-section--capabilities-simple .about-capability-chip {
  color: rgba(246, 243, 220, 0.94);
  border: 1px solid rgba(246, 243, 220, 0.24);
  background: rgba(255, 255, 255, 0.075);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.08) inset,
    0 12px 36px rgba(0, 0, 0, 0.28);
}

body.page-about .about-section--capabilities-simple .about-capability-chip:hover {
  border-color: rgba(240, 210, 147, 0.5);
  background: rgba(255, 255, 255, 0.11);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.1) inset,
    0 18px 44px rgba(0, 0, 0, 0.38);
}

@media (prefers-reduced-motion: reduce) {
  body.page-about .about-capability-chip {
    transition-duration: 0.01ms;
  }

  body.page-about .about-capability-chip:hover {
    transform: none;
  }

  body.page-about .hero-card {
    transition: none;
  }

  body.page-about .hero-card:hover {
    transform: none;
  }
}

body.page-about section.section:has(.container.hero-grid) {
  padding-block: clamp(2rem, 5vw, 3.5rem);
  background:
    radial-gradient(ellipse 88% 75% at 50% -12%, rgba(73, 79, 126, 0.07), transparent 58%),
    #fff;
}

body.page-about .site-header {
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(33, 50, 88, 0.1);
  backdrop-filter: blur(12px);
}

body.page-about .nav-links,
body.page-about .nav-dropdown__trigger {
  color: var(--navy);
}

body.page-about .nav-links > a::after,
body.page-about .nav-dropdown__trigger::after {
  background: var(--navy);
}

body.page-about .hero-card .eyebrow {
  color: rgba(246, 243, 220, 0.72);
}

body.page-about .hero-card h2 {
  color: rgba(255, 255, 255, 0.98);
}

body.page-about .hero-card p,
body.page-about .card p {
  color: rgba(246, 243, 220, 0.9);
}

body.page-about .cta-panel p {
  color: rgba(33, 50, 88, 0.8);
}

body.page-about .card {
  background: linear-gradient(
    152deg,
    color-mix(in srgb, var(--navy) 82%, white 18%) 0%,
    var(--navy) 38%,
    color-mix(in srgb, var(--navy) 72%, var(--ink) 28%) 70%,
    color-mix(in srgb, var(--navy) 48%, var(--ink) 52%) 100%
  );
  border: 1px solid rgba(246, 243, 220, 0.18);
  box-shadow:
    0 24px 60px rgba(16, 22, 42, 0.3),
    0 1px 0 rgba(255, 255, 255, 0.08) inset;
}

body.page-about .card::before {
  background:
    radial-gradient(ellipse 95% 75% at 88% 8%, rgba(240, 210, 147, 0.14), transparent 58%),
    radial-gradient(ellipse 72% 58% at 10% 88%, rgba(73, 79, 126, 0.2), transparent 52%),
    radial-gradient(ellipse 70% 55% at 6% 92%, rgba(232, 153, 140, 0.07), transparent 52%);
  opacity: 1;
}

body.page-about .card h3 {
  color: rgba(255, 255, 255, 0.98);
}

body.page-about .card p,
body.page-about .card li,
body.page-about .about-tools-copy {
  color: rgba(246, 243, 220, 0.9);
}

/* Match homepage .section--cta-dark .cta-panel (warm wash + inset highlight) */
body.page-about .cta-panel {
  background: linear-gradient(
    152deg,
    color-mix(in srgb, var(--cream) 78%, var(--yellow) 22%) 0%,
    color-mix(in srgb, var(--cream) 72%, var(--pink) 28%) 48%,
    color-mix(in srgb, var(--pink) 18%, var(--cream) 82%) 100%
  );
  border: 1px solid color-mix(in srgb, var(--yellow) 45%, rgba(33, 50, 88, 0.2) 55%);
  box-shadow:
    0 4px 0 rgba(240, 210, 147, 0.35) inset,
    0 28px 64px rgba(0, 0, 0, 0.35);
}

body.page-about .cta-panel .eyebrow {
  color: var(--navy);
}

body.page-about .cta-panel h2 {
  color: var(--navy);
}

body.page-about .cta-panel .hero-actions .btn-ghost {
  border-color: rgba(33, 50, 88, 0.35);
  color: var(--navy);
}

body.page-about .cta-panel .hero-actions .btn-ghost:hover {
  color: var(--ink);
}

/* Match homepage CTA primary: white pill at rest; transparent on hover for gradient fill */
body.page-about .cta-panel .btn-primary {
  color: var(--navy);
  background-color: #fff;
  border-color: rgba(33, 50, 88, 0.22);
}

body.page-about .cta-panel .btn-primary:hover {
  background-color: transparent;
  color: var(--ink);
}

/* ----- Portfolio (Featured Projects): white canvas ----- */
body.page-portfolio {
  background: #fff;
  color: var(--ink);
}

body.page-portfolio::before,
body.page-portfolio::after {
  opacity: 0;
}

body.page-portfolio main .section {
  background: #fff;
  position: relative;
}

body.page-portfolio main {
  background: #fff;
}

body.page-portfolio .site-header {
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(33, 50, 88, 0.1);
  backdrop-filter: blur(12px);
}

body.page-portfolio .nav-links,
body.page-portfolio .nav-dropdown__trigger {
  color: var(--navy);
}

body.page-portfolio .nav-links > a::after,
body.page-portfolio .nav-dropdown__trigger::after {
  background: var(--navy);
}

/* ----- Home: Figma export — starfield, scroll-driven dark→light (CSS vars + RAF) ----- */
body.page-home {
  /* Deeper blue on home only; :root --navy stays #213258 for other pages */
  --navy: #152644;
  /* Driven by main.js: --home-scroll-progress, --home-bg-blend-smooth, --home-fg-blend-smooth (0–1) */
  --home-scroll-progress: 0;
  --home-bg-blend-smooth: 0;
  --home-fg-blend-smooth: 0;
  /* Page chrome + vision reveal (starfield + radial animation unchanged) */
  --home-bg-deep: var(--navy);
  --home-bg-mid: var(--navy);
  --home-bg-light: var(--navy);
  --home-bg-light-soft: var(--navy);
  --home-text-on-dark-strong: rgba(255, 255, 255, 0.88);
  --home-text-on-dark: rgba(255, 255, 255, 0.78);
  --home-text-on-dark-muted: rgba(255, 255, 255, 0.55);
  --home-text-on-light-strong: rgba(33, 50, 88, 0.92);
  --home-text-on-light: rgba(33, 50, 88, 0.82);
  --home-text-on-light-muted: rgba(33, 50, 88, 0.55);
  background: color-mix(
    in srgb,
    var(--home-bg-deep) calc((1 - var(--home-bg-blend-smooth)) * 100%),
    var(--home-bg-light) calc(var(--home-bg-blend-smooth) * 100%)
  );
}

body.page-home::before,
body.page-home::after {
  opacity: 0;
}

.home-atmosphere {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.home-atmosphere::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(
    ellipse 85% 75% at 50% 42%,
    transparent 22%,
    rgba(0, 0, 0, 0.38) 100%
  );
  opacity: calc((1 - var(--home-bg-blend-smooth)) * 0.62);
}

.home-bg-white {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 135% 95% at 50% -8%,
    #ffffff 0%,
    #fafcfe 38%,
    var(--home-bg-light-soft) 100%
  );
  opacity: var(--home-bg-blend-smooth);
}

.home-bg-dark {
  position: absolute;
  inset: 0;
  background: var(--navy);
  opacity: calc(1 - var(--home-bg-blend-smooth));
}

body.page-home .home-bg-white {
  opacity: 0 !important;
}

body.page-home main {
  position: relative;
  z-index: 2;
  background: var(--navy);
}

/* Home: work showcase, process row, final CTA — solid brand navy #213258 (spotlight stays white) */
body.page-home .section--light.home-portfolio-white,
body.page-home section.section--spotlight + section.section--light,
body.page-home .section--cta-dark {
  background: #213258;
}

/* ── Layered card scroll: each section lifts over the previous one ──────────
   Same language as the portfolio→quote transition (rounded top + upward shadow).
   z-index steps up so every section correctly covers the one behind it.
   Scoped to page-home so other pages are unaffected.
   ────────────────────────────────────────────────────────────────────────── */

/* ① Quote → Spotlight  (white card over navy) */
body.page-home .section--light.section--spotlight {
  position: relative;
  z-index: 3;
  border-radius: 24px 24px 0 0;
  box-shadow:
    0 -32px 72px rgba(8, 12, 28, 0.52),
    0 -2px 0 rgba(255, 255, 255, 0.06);
}

/* ② Spotlight → Process  (navy card over white) */
body.page-home section.section--spotlight + section.section--light {
  position: relative;
  z-index: 4;
  border-radius: 24px 24px 0 0;
  box-shadow:
    0 -28px 64px rgba(8, 12, 28, 0.42),
    0 -2px 0 rgba(246, 243, 220, 0.06);
}

/* ③ Process → Testimonials  (warm card over navy) */
body.page-home .section--light.section--testimonials {
  position: relative;
  z-index: 5;
  border-radius: 24px 24px 0 0;
  box-shadow:
    0 -32px 72px rgba(8, 12, 28, 0.48),
    0 -2px 0 rgba(246, 243, 220, 0.06);
}

/* ④ Testimonials → CTA  (final dark card) */
body.page-home .section--cta-dark {
  position: relative;
  z-index: 6;
  border-radius: 24px 24px 0 0;
  box-shadow:
    0 -28px 64px rgba(8, 12, 28, 0.36),
    0 -2px 0 rgba(246, 243, 220, 0.05);
}

/* Reduce to smaller radius on narrow screens */
@media (max-width: 720px) {
  body.page-home .section--light.section--spotlight,
  body.page-home section.section--spotlight + section.section--light,
  body.page-home .section--light.section--testimonials,
  body.page-home .section--cta-dark {
    border-radius: 16px 16px 0 0;
  }
}

/* Reduced-motion: keep the radius (it's static) but kill any shadow transition */
@media (prefers-reduced-motion: reduce) {
  body.page-home .section--light.section--spotlight,
  body.page-home section.section--spotlight + section.section--light,
  body.page-home .section--light.section--testimonials,
  body.page-home .section--cta-dark {
    transition: none;
  }
}

body.page-home .site-header {
  /* Transparent over dark hero; solid light bar as page lightens (logo crossfade matches) */
  background: color-mix(
    in srgb,
    transparent calc((1 - var(--home-fg-blend-smooth)) * 100%),
    rgba(255, 255, 255, 0.94) calc(var(--home-fg-blend-smooth) * 100%)
  );
  backdrop-filter: blur(calc(14px * var(--home-fg-blend-smooth)));
  -webkit-backdrop-filter: blur(calc(14px * var(--home-fg-blend-smooth)));
  border-bottom: 1px solid
    color-mix(
      in srgb,
      transparent calc((1 - var(--home-fg-blend-smooth)) * 100%),
      rgba(33, 50, 88, 0.1) calc(var(--home-fg-blend-smooth) * 100%)
    );
  box-shadow: 0 1px 0
    color-mix(
      in srgb,
      transparent calc((1 - var(--home-fg-blend-smooth)) * 100%),
      rgba(255, 255, 255, 0.85) calc(var(--home-fg-blend-smooth) * 100%)
    );
  transition: background 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

body.page-home .nav {
  padding: var(--header-nav-pad-block) var(--layout-gutter);
}

body.page-home .site-logo {
  position: relative;
}

/* Home: cream/light mark on dark scroll, navy/dark mark on light scroll */
body.page-home .site-logo img.site-logo__mark--light {
  display: block;
  position: relative;
  z-index: 0;
  opacity: calc(1 - var(--home-fg-blend-smooth));
  transition: opacity 0.15s ease-out;
}

body.page-home .site-logo img.site-logo__mark--dark {
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  height: var(--header-logo-h);
  width: auto;
  max-width: var(--header-logo-w);
  object-fit: contain;
  opacity: var(--home-fg-blend-smooth);
  pointer-events: none;
  transition: opacity 0.2s ease-out;
}

body.page-home .nav-links > a {
  padding: 8px 6px;
  border-radius: 0;
  font-size: inherit;
  font-weight: 600;
  color: color-mix(
    in srgb,
    var(--home-text-on-dark-strong) calc((1 - var(--home-fg-blend-smooth)) * 100%),
    var(--home-text-on-light-strong) calc(var(--home-fg-blend-smooth) * 100%)
  );
  transition: none;
}

body.page-home .nav-links > a:hover {
  background: transparent;
  color: color-mix(
    in srgb,
    var(--home-text-on-dark-strong) calc((1 - var(--home-fg-blend-smooth)) * 100%),
    var(--home-text-on-light-strong) calc(var(--home-fg-blend-smooth) * 100%)
  );
}

body.page-home .nav-dropdown__trigger {
  padding: 8px 6px;
  border-radius: 0;
  font-size: inherit;
  font-weight: 600;
  color: color-mix(
    in srgb,
    var(--home-text-on-dark-strong) calc((1 - var(--home-fg-blend-smooth)) * 100%),
    var(--home-text-on-light-strong) calc(var(--home-fg-blend-smooth) * 100%)
  );
  transition: none;
}

body.page-home .nav-dropdown__trigger:hover {
  background: transparent;
  color: color-mix(
    in srgb,
    var(--home-text-on-dark-strong) calc((1 - var(--home-fg-blend-smooth)) * 100%),
    var(--home-text-on-light-strong) calc(var(--home-fg-blend-smooth) * 100%)
  );
}

body.page-home .nav-links > a::after,
body.page-home .nav-dropdown__trigger::after {
  background: color-mix(
    in srgb,
    rgba(240, 210, 147, 0.95) calc((1 - var(--home-fg-blend-smooth)) * 100%),
    rgba(33, 50, 88, 0.88) calc(var(--home-fg-blend-smooth) * 100%)
  );
}

.mouse-glow {
  position: fixed;
  left: 0;
  top: 0;
  width: 400px;
  height: 400px;
  margin: 0;
  pointer-events: none;
  z-index: 1;
  transform: translate(-50%, -50%);
  background: radial-gradient(
    circle,
    rgba(147, 51, 234, 0.15) 0%,
    rgba(168, 85, 247, 0.08) 25%,
    transparent 70%
  );
  filter: blur(40px);
  will-change: transform;
}

body.page-home .mouse-glow {
  opacity: clamp(0, calc(1 - var(--home-bg-blend-smooth) * 1.12), 1);
  transition: opacity 0.4s ease;
}

@media (hover: none), (pointer: coarse) {
  .mouse-glow {
    display: none;
  }
}

.home-starfield {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
  opacity: clamp(0, calc(1 - var(--home-bg-blend-smooth) * 1.02), 1);
}

/* After #vision leaves the viewport, kill the fixed layer so lower sections scroll normally */
body.page-home.home-past-vision .home-starfield {
  opacity: 0 !important;
  visibility: hidden !important;
}

.home-starfield::before {
  content: "";
  position: absolute;
  inset: -10%;
  background:
    radial-gradient(ellipse 85% 55% at 72% 28%, rgba(120, 145, 210, 0.14), transparent 58%),
    radial-gradient(ellipse 70% 50% at 18% 62%, rgba(90, 110, 175, 0.1), transparent 52%),
    radial-gradient(ellipse 55% 40% at 48% 48%, rgba(255, 255, 255, 0.04), transparent 45%);
  opacity: 0.85;
  pointer-events: none;
}

.home-starfield__canvas {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
}

.site-starfield {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  transition: opacity 0.2s linear;
}

.site-starfield__layer {
  position: absolute;
  inset: -5%;
  background-repeat: repeat;
  background-size: 100% 100%;
}

.site-starfield__layer--deep {
  background-image: radial-gradient(1px 1px at 2% 8%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1.2px 1.2px at 9% 31%, rgba(255, 255, 255, 0.35), transparent),
    radial-gradient(1px 1px at 16% 76%, rgba(255, 255, 255, 0.45), transparent),
    radial-gradient(0.8px 0.8px at 23% 14%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1.1px 1.1px at 31% 52%, rgba(255, 255, 255, 0.55), transparent),
    radial-gradient(1px 1px at 38% 91%, rgba(255, 255, 255, 0.38), transparent),
    radial-gradient(1.2px 1.2px at 44% 22%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1px 1px at 51% 68%, rgba(255, 255, 255, 0.42), transparent),
    radial-gradient(0.9px 0.9px at 58% 5%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 65% 41%, rgba(255, 255, 255, 0.36), transparent),
    radial-gradient(1.1px 1.1px at 72% 84%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(1px 1px at 79% 19%, rgba(255, 255, 255, 0.44), transparent),
    radial-gradient(1.2px 1.2px at 86% 57%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1px 1px at 93% 93%, rgba(255, 255, 255, 0.46), transparent),
    radial-gradient(0.8px 0.8px at 6% 62%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 13% 44%, rgba(255, 255, 255, 0.34), transparent),
    radial-gradient(1.1px 1.1px at 27% 88%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1px 1px at 35% 2%, rgba(255, 255, 255, 0.55), transparent),
    radial-gradient(1px 1px at 48% 37%, rgba(255, 255, 255, 0.38), transparent),
    radial-gradient(0.9px 0.9px at 56% 71%, rgba(255, 255, 255, 0.45), transparent),
    radial-gradient(1.2px 1.2px at 63% 11%, rgba(255, 255, 255, 0.42), transparent),
    radial-gradient(1px 1px at 74% 48%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 81% 26%, rgba(255, 255, 255, 0.36), transparent),
    radial-gradient(1.1px 1.1px at 89% 64%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(0.8px 0.8px at 96% 17%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1px 1px at 4% 95%, rgba(255, 255, 255, 0.46), transparent),
    radial-gradient(1px 1px at 19% 59%, rgba(255, 255, 255, 0.44), transparent),
    radial-gradient(1.2px 1.2px at 41% 79%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 53% 16%, rgba(255, 255, 255, 0.35), transparent),
    radial-gradient(0.9px 0.9px at 68% 33%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1px 1px at 77% 96%, rgba(255, 255, 255, 0.42), transparent),
    radial-gradient(1.1px 1.1px at 91% 41%, rgba(255, 255, 255, 0.5), transparent);
  opacity: 0.26;
  animation: home-starfield-twinkle-a 18s ease-in-out infinite,
    home-starfield-drift 130s ease-in-out infinite alternate;
}

.site-starfield__layer--mid {
  background-image: radial-gradient(1.2px 1.2px at 7% 18%, rgba(246, 243, 220, 0.55), transparent),
    radial-gradient(1px 1px at 14% 66%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(0.9px 0.9px at 21% 39%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1.1px 1.1px at 28% 91%, rgba(255, 255, 255, 0.36), transparent),
    radial-gradient(1px 1px at 36% 7%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(1.2px 1.2px at 43% 54%, rgba(246, 243, 220, 0.44), transparent),
    radial-gradient(1px 1px at 50% 82%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(0.8px 0.8px at 57% 28%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 64% 61%, rgba(255, 255, 255, 0.38), transparent),
    radial-gradient(1.1px 1.1px at 71% 3%, rgba(255, 255, 255, 0.46), transparent),
    radial-gradient(1px 1px at 78% 47%, rgba(255, 255, 255, 0.42), transparent),
    radial-gradient(1.2px 1.2px at 85% 88%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 92% 24%, rgba(255, 255, 255, 0.34), transparent),
    radial-gradient(0.9px 0.9px at 3% 51%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1px 1px at 11% 73%, rgba(255, 255, 255, 0.44), transparent),
    radial-gradient(1.1px 1.1px at 25% 12%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(1px 1px at 33% 58%, rgba(255, 255, 255, 0.36), transparent),
    radial-gradient(1px 1px at 46% 86%, rgba(246, 243, 220, 0.45), transparent),
    radial-gradient(1.2px 1.2px at 54% 21%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(0.8px 0.8px at 61% 69%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1px 1px at 69% 35%, rgba(255, 255, 255, 0.46), transparent),
    radial-gradient(1.1px 1.1px at 76% 98%, rgba(255, 255, 255, 0.38), transparent),
    radial-gradient(1px 1px at 83% 15%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 90% 52%, rgba(255, 255, 255, 0.42), transparent),
    radial-gradient(0.9px 0.9px at 97% 77%, rgba(255, 255, 255, 0.45), transparent),
    radial-gradient(1.2px 1.2px at 17% 8%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1px 1px at 39% 44%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1px 1px at 59% 9%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(1.1px 1.1px at 73% 63%, rgba(255, 255, 255, 0.36), transparent),
    radial-gradient(1px 1px at 88% 31%, rgba(255, 255, 255, 0.5), transparent);
  opacity: 0.18;
  animation: home-starfield-twinkle-b 22s ease-in-out infinite 0.8s,
    home-starfield-drift 150s ease-in-out infinite alternate-reverse;
}

.site-starfield__layer--near {
  background-image: radial-gradient(1.4px 1.4px at 5% 42%, rgba(255, 255, 255, 0.65), transparent),
    radial-gradient(1.2px 1.2px at 12% 11%, rgba(255, 255, 255, 0.45), transparent),
    radial-gradient(1px 1px at 20% 78%, rgba(240, 210, 147, 0.5), transparent),
    radial-gradient(1.3px 1.3px at 29% 33%, rgba(255, 255, 255, 0.55), transparent),
    radial-gradient(1.1px 1.1px at 37% 91%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1.2px 1.2px at 45% 19%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(1px 1px at 52% 62%, rgba(255, 255, 255, 0.38), transparent),
    radial-gradient(1.4px 1.4px at 60% 4%, rgba(246, 243, 220, 0.58), transparent),
    radial-gradient(1px 1px at 67% 49%, rgba(255, 255, 255, 0.46), transparent),
    radial-gradient(1.2px 1.2px at 75% 85%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1.1px 1.1px at 82% 27%, rgba(255, 255, 255, 0.42), transparent),
    radial-gradient(1.3px 1.3px at 90% 71%, rgba(255, 255, 255, 0.55), transparent),
    radial-gradient(1px 1px at 96% 14%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1.2px 1.2px at 8% 67%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1px 1px at 18% 24%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(1.4px 1.4px at 34% 56%, rgba(240, 210, 147, 0.48), transparent),
    radial-gradient(1px 1px at 48% 3%, rgba(255, 255, 255, 0.44), transparent),
    radial-gradient(1.1px 1.1px at 55% 88%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1.2px 1.2px at 63% 41%, rgba(255, 255, 255, 0.36), transparent),
    radial-gradient(1px 1px at 71% 16%, rgba(255, 255, 255, 0.54), transparent),
    radial-gradient(1.3px 1.3px at 79% 59%, rgba(255, 255, 255, 0.42), transparent),
    radial-gradient(1px 1px at 87% 96%, rgba(255, 255, 255, 0.46), transparent),
    radial-gradient(1.2px 1.2px at 94% 38%, rgba(255, 255, 255, 0.5), transparent),
    radial-gradient(1px 1px at 2% 29%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1.4px 1.4px at 24% 81%, rgba(255, 255, 255, 0.55), transparent),
    radial-gradient(1px 1px at 41% 48%, rgba(255, 255, 255, 0.45), transparent),
    radial-gradient(1.1px 1.1px at 58% 12%, rgba(255, 255, 255, 0.48), transparent),
    radial-gradient(1.2px 1.2px at 72% 74%, rgba(255, 255, 255, 0.4), transparent),
    radial-gradient(1px 1px at 84% 22%, rgba(255, 255, 255, 0.52), transparent),
    radial-gradient(1.3px 1.3px at 91% 65%, rgba(255, 255, 255, 0.46), transparent);
  opacity: 0.13;
  animation: home-starfield-twinkle-c 16s ease-in-out infinite 1.2s,
    home-starfield-drift 110s ease-in-out infinite alternate;
}

.hero--home {
  position: relative;
  isolation: isolate;
  padding: clamp(4.5rem, 12vh, 7.5rem) 0 var(--space-8);
  min-height: min(92vh, 880px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}

.hero-home__atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.hero-home__navy {
  position: absolute;
  inset: 0;
  background: var(--navy);
}

.hero-home__starfield-canvas {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  vertical-align: top;
}

.hero--home .hero-home-inner,
.hero--home .scroll-hint {
  position: relative;
  z-index: 1;
}

@media (prefers-reduced-motion: reduce) {
  .hero-home__starfield-canvas {
    opacity: 0.92;
  }
}

.hero-home-inner {
  text-align: center;
  max-width: 52rem;
  margin: 0 auto;
}

.hero-kicker {
  margin: 0 0 var(--space-3);
  font-size: clamp(1.35rem, 3.8vw, 2.35rem);
  font-weight: 500;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.35;
}

body.page-home .hero--home .hero-kicker {
  color: rgba(255, 255, 255, 0.82);
}

.hero-title-home {
  margin: 0 0 var(--space-4);
  line-height: 1.02;
}

.hero-cosmic {
  display: inline-block;
  font-family: "Greycliff CF", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(3.75rem, 14vw, 8.5rem);
  letter-spacing: -0.04em;
  text-transform: none;
  color: transparent;
  -webkit-text-fill-color: transparent;
  background-color: #070214;
  background-image: radial-gradient(ellipse 115% 135% at 30% 50%,
      rgba(60, 255, 210, 0.98) 0%,
      rgba(90, 155, 255, 0.78) 24%,
      rgba(75, 255, 200, 0.58) 42%,
      rgba(15, 70, 190, 0.45) 65%,
      transparent 88%),
    radial-gradient(ellipse 75% 95% at 72% 36%,
      rgba(170, 255, 220, 0.9) 0%,
      rgba(80, 165, 255, 0.38) 38%,
      transparent 62%),
    radial-gradient(ellipse 55% 70% at 46% 72%,
      rgba(120, 255, 235, 0.46) 0%,
      transparent 58%),
    url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22260%22%20height%3D%22260%22%3E%3Ccircle%20cx%3D%2218%22%20cy%3D%2222%22%20r%3D%220.7%22%20fill%3D%22%23fff%22%20opacity%3D%220.85%22%2F%3E%3Ccircle%20cx%3D%2242%22%20cy%3D%2288%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.6%22%2F%3E%3Ccircle%20cx%3D%2271%22%20cy%3D%2241%22%20r%3D%220.6%22%20fill%3D%22%23e8f4ff%22%20opacity%3D%220.75%22%2F%3E%3Ccircle%20cx%3D%2295%22%20cy%3D%22112%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.7%22%2F%3E%3Ccircle%20cx%3D%22124%22%20cy%3D%2218%22%20r%3D%220.65%22%20fill%3D%22%23fff%22%20opacity%3D%220.9%22%2F%3E%3Ccircle%20cx%3D%22148%22%20cy%3D%2276%22%20r%3D%220.45%22%20fill%3D%22%23ffd4f5%22%20opacity%3D%220.65%22%2F%3E%3Ccircle%20cx%3D%22172%22%20cy%3D%22138%22%20r%3D%220.7%22%20fill%3D%22%23fff%22%20opacity%3D%220.55%22%2F%3E%3Ccircle%20cx%3D%22198%22%20cy%3D%2254%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.8%22%2F%3E%3Ccircle%20cx%3D%22228%22%20cy%3D%2296%22%20r%3D%220.6%22%20fill%3D%22%23c8e6ff%22%20opacity%3D%220.7%22%2F%3E%3Ccircle%20cx%3D%2234%22%20cy%3D%22148%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.5%22%2F%3E%3Ccircle%20cx%3D%2256%22%20cy%3D%22178%22%20r%3D%220.4%22%20fill%3D%22%23fff%22%20opacity%3D%220.65%22%2F%3E%3Ccircle%20cx%3D%2288%22%20cy%3D%22196%22%20r%3D%220.65%22%20fill%3D%22%23fff%22%20opacity%3D%220.45%22%2F%3E%3Ccircle%20cx%3D%22112%22%20cy%3D%22162%22%20r%3D%220.5%22%20fill%3D%22%23ffe8f0%22%20opacity%3D%220.72%22%2F%3E%3Ccircle%20cx%3D%22138%22%20cy%3D%22220%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.58%22%2F%3E%3Ccircle%20cx%3D%22162%22%20cy%3D%22186%22%20r%3D%220.45%22%20fill%3D%22%23fff%22%20opacity%3D%220.68%22%2F%3E%3Ccircle%20cx%3D%22190%22%20cy%3D%22208%22%20r%3D%220.7%22%20fill%3D%22%23d4e8ff%22%20opacity%3D%220.52%22%2F%3E%3Ccircle%20cx%3D%22220%22%20cy%3D%22162%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.78%22%2F%3E%3Ccircle%20cx%3D%22242%22%20cy%3D%22234%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.48%22%2F%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%22118%22%20r%3D%220.45%22%20fill%3D%22%23fff%22%20opacity%3D%220.62%22%2F%3E%3Ccircle%20cx%3D%2252%22%20cy%3D%2256%22%20r%3D%220.6%22%20fill%3D%22%23fff%22%20opacity%3D%220.55%22%2F%3E%3Ccircle%20cx%3D%2282%22%20cy%3D%22132%22%20r%3D%220.5%22%20fill%3D%22%23ffc8e8%22%20opacity%3D%220.68%22%2F%3E%3Ccircle%20cx%3D%22106%22%20cy%3D%22228%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.5%22%2F%3E%3Ccircle%20cx%3D%22154%22%20cy%3D%22102%22%20r%3D%220.65%22%20fill%3D%22%23fff%22%20opacity%3D%220.72%22%2F%3E%3Ccircle%20cx%3D%22178%22%20cy%3D%2212%22%20r%3D%220.45%22%20fill%3D%22%23fff%22%20opacity%3D%220.58%22%2F%3E%3Ccircle%20cx%3D%22204%22%20cy%3D%22124%22%20r%3D%220.55%22%20fill%3D%22%23e0f0ff%22%20opacity%3D%220.65%22%2F%3E%3Ccircle%20cx%3D%22236%22%20cy%3D%2218%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.82%22%2F%3E%3Ccircle%20cx%3D%22130%22%20cy%3D%22130%22%20r%3D%221.2%22%20fill%3D%22%23fff4e0%22%20opacity%3D%220.35%22%2F%3E%3C%2Fsvg%3E");
  background-size: 210% 210%, 195% 195%, 175% 175%, 260px 260px;
  background-position: 0% 50%, 100% 38%, 52% 78%, 0 0;
  background-repeat: no-repeat, no-repeat, no-repeat, repeat;
  -webkit-background-clip: text;
  background-clip: text;
  filter: drop-shadow(0 0 32px rgba(90, 255, 210, 0.24));
}

.hero-cosmic.hero-cosmic--video {
  position: relative;
  display: inline-block;
  isolation: isolate;
  overflow: hidden;
  transform: translateZ(0);
  background: none;
  background-image: none;
  background-color: transparent;
  background-size: auto;
  background-position: 0 0;
  background-repeat: repeat;
  color: inherit;
  -webkit-text-fill-color: inherit;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  filter: none;
}

.hero-cosmic__video {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
  pointer-events: none;
  display: block;
  border: 0;
  outline: none;
  -webkit-mask-origin: border-box;
  mask-origin: border-box;
  -webkit-mask-clip: border-box;
  mask-clip: border-box;
  backface-visibility: hidden;
  /* Opacity alone can still flicker edges on some GPUs; visibility removes the painted layer entirely. */
  visibility: hidden;
  opacity: 0;
  /* Instant reveal: a crossfade can read as fringed “scan lines” while the mask composites. */
  transition: none;
  transform: translateZ(0);
}

/* Visible after mask PNG is bound (sizes set inline in JS for first paint consistency). */
.hero-cosmic.hero-cosmic--video.is-mask-ready .hero-cosmic__video {
  visibility: visible;
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .hero-cosmic.hero-cosmic--video .hero-cosmic__video {
    transition: none;
  }
}

.hero-cosmic__sizer {
  position: relative;
  z-index: 1;
  display: inline-block;
  margin: 0;
  padding: 0;
  font: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  line-height: inherit;
  color: transparent;
  opacity: 0;
  pointer-events: none;
  user-select: none;
}

.hero-title-home .hero-cosmic:not(.hero-cosmic--video) {
  animation: hero-cosmic-drift 48s ease-in-out infinite alternate,
    hero-cosmic-shimmer 32s ease-in-out infinite alternate;
}

.hero-title-home .hero-cosmic--video {
  animation: none;
  filter: none;
}

.hero-title-home .hero-cosmic__video {
  /* Freeze object-position — drift + masked H.264 often reads as vertical banding inside stems. */
  animation: none;
  object-position: 50% 50%;
  /* Slight zoom hides rare ½px gaps between GPU mask tiling and rounded mask samples (esp. Safari). */
  transform: translateZ(0) scale(1.022);
  transform-origin: center center;
}

.hero-sub-home {
  margin: 0 auto var(--space-6);
  max-width: 42rem;
  font-size: clamp(1.15rem, 2.6vw, 1.85rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.88);
  font-weight: 500;
}

body.page-home .hero--home .hero-sub-home {
  color: rgba(255, 255, 255, 0.9);
}

body.page-home .hero--home .hero-actions .btn {
  transition: border-color 0.45s ease, background 0.35s ease, background-size 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    color 0.35s ease, box-shadow 0.35s ease;
}

body.page-home .hero--home .hero-actions .btn-ghost {
  border-color: rgba(246, 243, 220, 0.45);
  color: var(--cream);
}

body.page-home .hero--home .hero-actions .btn-ghost:hover {
  color: var(--ink);
  border-color: var(--pink);
}

body.page-home .hero--home .hero-actions .btn-primary {
  --btn-primary-border-hover: rgba(16, 22, 42, 0.2);
}

.hero-cosmic--tight {
  text-transform: uppercase;
  letter-spacing: -0.02em;
}

.vision-title .hero-cosmic.hero-cosmic--tight {
  text-transform: none;
}

/* Vision block — purple / blue nebula inside letters (matches light landing reference) */
.vision-title .hero-cosmic.hero-cosmic--vision:not(.hero-cosmic--video) {
  background-color: #0f0828;
  background-image: radial-gradient(
      ellipse 110% 140% at 38% 48%,
      rgba(190, 140, 255, 0.98) 0%,
      rgba(95, 65, 210, 0.72) 28%,
      rgba(45, 35, 120, 0.55) 55%,
      transparent 78%
    ),
    radial-gradient(
      ellipse 95% 110% at 78% 52%,
      rgba(110, 195, 255, 0.62) 0%,
      rgba(55, 95, 220, 0.45) 42%,
      transparent 68%
    ),
    radial-gradient(ellipse 70% 90% at 22% 72%, rgba(230, 210, 255, 0.42) 0%, transparent 58%),
    radial-gradient(ellipse 50% 60% at 55% 28%, rgba(255, 255, 255, 0.12) 0%, transparent 55%),
    url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22260%22%20height%3D%22260%22%3E%3Ccircle%20cx%3D%2218%22%20cy%3D%2222%22%20r%3D%220.7%22%20fill%3D%22%23fff%22%20opacity%3D%220.85%22%2F%3E%3Ccircle%20cx%3D%2242%22%20cy%3D%2288%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.6%22%2F%3E%3Ccircle%20cx%3D%2271%22%20cy%3D%2241%22%20r%3D%220.6%22%20fill%3D%22%23e8f4ff%22%20opacity%3D%220.75%22%2F%3E%3Ccircle%20cx%3D%2295%22%20cy%3D%22112%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.7%22%2F%3E%3Ccircle%20cx%3D%22124%22%20cy%3D%2218%22%20r%3D%220.65%22%20fill%3D%22%23fff%22%20opacity%3D%220.9%22%2F%3E%3Ccircle%20cx%3D%22148%22%20cy%3D%2276%22%20r%3D%220.45%22%20fill%3D%22%23ffd4f5%22%20opacity%3D%220.65%22%2F%3E%3Ccircle%20cx%3D%22172%22%20cy%3D%22138%22%20r%3D%220.7%22%20fill%3D%22%23fff%22%20opacity%3D%220.55%22%2F%3E%3Ccircle%20cx%3D%22198%22%20cy%3D%2254%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.8%22%2F%3E%3Ccircle%20cx%3D%22228%22%20cy%3D%2296%22%20r%3D%220.6%22%20fill%3D%22%23c8e6ff%22%20opacity%3D%220.7%22%2F%3E%3Ccircle%20cx%3D%2234%22%20cy%3D%22148%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.5%22%2F%3E%3Ccircle%20cx%3D%2256%22%20cy%3D%22178%22%20r%3D%220.4%22%20fill%3D%22%23fff%22%20opacity%3D%220.65%22%2F%3E%3Ccircle%20cx%3D%2288%22%20cy%3D%22196%22%20r%3D%220.65%22%20fill%3D%22%23fff%22%20opacity%3D%220.45%22%2F%3E%3Ccircle%20cx%3D%22112%22%20cy%3D%22162%22%20r%3D%220.5%22%20fill%3D%22%23ffe8f0%22%20opacity%3D%220.72%22%2F%3E%3Ccircle%20cx%3D%22138%22%20cy%3D%22220%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.58%22%2F%3E%3Ccircle%20cx%3D%22162%22%20cy%3D%22186%22%20r%3D%220.45%22%20fill%3D%22%23fff%22%20opacity%3D%220.68%22%2F%3E%3Ccircle%20cx%3D%22190%22%20cy%3D%22208%22%20r%3D%220.7%22%20fill%3D%22%23d4e8ff%22%20opacity%3D%220.52%22%2F%3E%3Ccircle%20cx%3D%22220%22%20cy%3D%22162%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.78%22%2F%3E%3Ccircle%20cx%3D%22242%22%20cy%3D%22234%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.48%22%2F%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%22118%22%20r%3D%220.45%22%20fill%3D%22%23fff%22%20opacity%3D%220.62%22%2F%3E%3Ccircle%20cx%3D%2252%22%20cy%3D%2256%22%20r%3D%220.6%22%20fill%3D%22%23fff%22%20opacity%3D%220.55%22%2F%3E%3Ccircle%20cx%3D%2282%22%20cy%3D%22132%22%20r%3D%220.5%22%20fill%3D%22%23ffc8e8%22%20opacity%3D%220.68%22%2F%3E%3Ccircle%20cx%3D%22106%22%20cy%3D%22228%22%20r%3D%220.55%22%20fill%3D%22%23fff%22%20opacity%3D%220.5%22%2F%3E%3Ccircle%20cx%3D%22154%22%20cy%3D%22102%22%20r%3D%220.65%22%20fill%3D%22%23fff%22%20opacity%3D%220.72%22%2F%3E%3Ccircle%20cx%3D%22178%22%20cy%3D%2212%22%20r%3D%220.45%22%20fill%3D%22%23fff%22%20opacity%3D%220.58%22%2F%3E%3Ccircle%20cx%3D%22204%22%20cy%3D%22124%22%20r%3D%220.55%22%20fill%3D%22%23e0f0ff%22%20opacity%3D%220.65%22%2F%3E%3Ccircle%20cx%3D%22236%22%20cy%3D%2218%22%20r%3D%220.5%22%20fill%3D%22%23fff%22%20opacity%3D%220.82%22%2F%3E%3Ccircle%20cx%3D%22130%22%20cy%3D%22130%22%20r%3D%221.2%22%20fill%3D%22%23fff4e0%22%20opacity%3D%220.35%22%2F%3E%3C%2Fsvg%3E");
  background-size: 220% 220%, 200% 200%, 185% 185%, 160% 160%, 240px 240px;
  background-position: 0% 50%, 100% 42%, 48% 78%, 50% 50%, 0 0;
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat;
  filter: drop-shadow(0 0 20px rgba(140, 110, 255, 0.35));
  font-size: clamp(3.85rem, 12.5vw, 7.75rem);
  letter-spacing: -0.03em;
  animation: hero-vision-swirl 44s ease-in-out infinite,
    hero-vision-nebula-shimmer 28s ease-in-out infinite alternate,
    hero-vision-twinkle 5.5s ease-in-out infinite;
}

.vision-title .hero-cosmic.hero-cosmic--vision.hero-cosmic--video {
  font-size: clamp(3.85rem, 12.5vw, 7.75rem);
  letter-spacing: -0.03em;
  animation: none;
  filter: none;
}

.vision-title .hero-cosmic.hero-cosmic--vision.hero-cosmic--video .hero-cosmic__video {
  animation: hero-cosmic-video-drift 40s ease-in-out infinite alternate;
}

body.page-home .vision-title .hero-cosmic.hero-cosmic--vision:not(.hero-cosmic--video) {
  background-color: #0a1428;
}

.scroll-hint {
  position: absolute;
  left: 50%;
  bottom: clamp(2rem, 6vh, 3.5rem);
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  color: rgba(255, 255, 255, 0.55);
  z-index: 1;
}

.scroll-hint__label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  font-weight: 600;
}

.scroll-hint__mouse {
  width: 26px;
  height: 42px;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-radius: 999px;
  display: flex;
  justify-content: center;
  padding-top: 8px;
}

.scroll-hint__wheel {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.55);
  animation: scroll-hint-wheel 1.5s ease-in-out infinite;
}

body.page-home .hero--home .scroll-hint {
  color: rgba(255, 255, 255, 0.58);
  opacity: calc(1 - var(--home-bg-blend-smooth) * 0.85);
}

body.page-home .hero--home .scroll-hint__mouse {
  border-color: rgba(255, 255, 255, 0.38);
}

body.page-home .hero--home .scroll-hint__wheel {
  background: rgba(255, 255, 255, 0.55);
}

@keyframes scroll-hint-wheel {
  0%,
  100% {
    transform: translateY(0);
    opacity: 1;
  }
  50% {
    transform: translateY(10px);
    opacity: 0.35;
  }
}

.vision-section {
  min-height: min(100vh, 960px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) 0;
}

/* Home vision: scroll-driven radial reveal (GSAP ScrollTrigger → --vision-r, --vision-at-*) */
.vision-section.vision-section--scroll-reveal {
  --vision-r: 64px;
  --vision-at-x: 50%;
  --vision-at-y: 50%;
  background: transparent;
  position: relative;
  /* Allow the radial mask to extend past the section box (overflow: clip was slicing the circle). */
  overflow: visible;
  isolation: isolate;
  /* Tighter than .vision-section so Projects sits slightly higher */
  min-height: min(94vh, 900px);
  padding: var(--space-7) 0;
}

.vision-section.section--light.vision-section--scroll-reveal {
  background: transparent;
}

.vision-section--scroll-reveal .vision-section__light {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: #fff;
  pointer-events: none;
  will-change: clip-path;
  transform: translateZ(0);
  clip-path: circle(var(--vision-r) at var(--vision-at-x) var(--vision-at-y));
}

/* Canvas stars only outside the white reveal (same center/radius as __light) — blends with hero starfield */
.vision-section--scroll-reveal .vision-section__stars {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  transform: translateZ(0);
  -webkit-mask-image: radial-gradient(
    circle var(--vision-r) at var(--vision-at-x) var(--vision-at-y),
    transparent calc(var(--vision-r) - 1px),
    #000 calc(var(--vision-r) + 0.5px)
  );
  mask-image: radial-gradient(
    circle var(--vision-r) at var(--vision-at-x) var(--vision-at-y),
    transparent calc(var(--vision-r) - 1px),
    #000 calc(var(--vision-r) + 0.5px)
  );
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.vision-section--scroll-reveal .vision-section__stars-canvas {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
}

@media (prefers-reduced-motion: reduce) {
  .vision-section--scroll-reveal .vision-section__light {
    clip-path: circle(200vmax at var(--vision-at-x) var(--vision-at-y));
  }

  .vision-section--scroll-reveal .vision-section__stars {
    display: none;
  }
}

.vision-section--scroll-reveal .vision-inner {
  position: relative;
  z-index: 1;
}

/* ── Scan-line breach: Vision → Projects ─────────────────────────────────── */
.section-breach {
  position: relative;
  height: 0;
  z-index: 20;
  pointer-events: none;
  overflow: visible;
}

.section-breach__line {
  position: absolute;
  left: 0;
  right: 0;
  top: -1px;
  height: 2px;
  transform-origin: center center;
  transform: scaleX(0);
  opacity: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(160, 200, 255, 0.5) 12%,
    rgba(220, 238, 255, 1)   50%,
    rgba(160, 200, 255, 0.5) 88%,
    transparent 100%
  );
  box-shadow:
    0 0 5px 1px rgba(190, 220, 255, 0.55),
    0 0 18px 4px rgba(110, 160, 255, 0.22);
}

.section-breach__bloom {
  position: absolute;
  left: 0;
  right: 0;
  top: -48px;
  height: 98px;
  background: radial-gradient(
    ellipse 55% 50% at 50% 50%,
    rgba(130, 185, 255, 0.14) 0%,
    transparent 72%
  );
  opacity: 0;
  pointer-events: none;
}

.section-breach__streak {
  position: absolute;
  top: -14px;
  width: 1px;
  height: 28px;
  background: linear-gradient(180deg, transparent, rgba(200, 230, 255, 0.7), transparent);
  opacity: 0;
  transform: scaleY(0);
  transform-origin: center center;
}

.section-breach__streak--a { left: 44%; }
.section-breach__streak--b { left: 56%; }

.section-breach.is-firing .section-breach__line {
  animation: breach-scan 0.58s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.section-breach.is-firing .section-breach__bloom {
  animation: breach-bloom 0.7s ease-out forwards;
}

.section-breach.is-firing .section-breach__streak--a,
.section-breach.is-firing .section-breach__streak--b {
  animation: breach-streak 0.4s 0.08s ease-out forwards;
}

@keyframes breach-scan {
  0%   { transform: scaleX(0); opacity: 1; }
  55%  { transform: scaleX(1); opacity: 1; }
  100% { transform: scaleX(1); opacity: 0; }
}

@keyframes breach-bloom {
  0%   { opacity: 0; transform: scaleY(0.4); }
  22%  { opacity: 1; transform: scaleY(1); }
  100% { opacity: 0; transform: scaleY(1.1); }
}

@keyframes breach-streak {
  0%   { opacity: 0; transform: scaleY(0); }
  30%  { opacity: 1; transform: scaleY(1); }
  100% { opacity: 0; transform: scaleY(1.2); }
}

@media (prefers-reduced-motion: reduce) {
  .section-breach { display: none; }
}

/* Quote band → spotlight: warmer scan (ember) vs vision→projects (cool) */
.section-breach--ember .section-breach__line {
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 190, 150, 0.42) 14%,
    rgba(255, 248, 235, 0.98) 50%,
    rgba(255, 190, 150, 0.42) 86%,
    transparent 100%
  );
  box-shadow:
    0 0 6px 1px rgba(255, 210, 170, 0.5),
    0 0 22px 5px rgba(255, 160, 110, 0.18);
}

.section-breach--ember .section-breach__bloom {
  background: radial-gradient(
    ellipse 58% 52% at 50% 50%,
    rgba(255, 200, 150, 0.16) 0%,
    transparent 72%
  );
}

.section-breach--ember .section-breach__streak {
  background: linear-gradient(180deg, transparent, rgba(255, 230, 200, 0.75), transparent);
}

/* Home: staggered scroll-in after portfolio (headings, cards, CTA) */
.reveal-stagger .reveal-stagger-item {
  opacity: 0;
  transform: translate3d(0, 34px, 0) scale(0.97);
  transition:
    opacity 0.95s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.95s cubic-bezier(0.2, 1, 0.35, 1);
  transition-delay: calc(var(--reveal-order, 0) * 0.078s);
}

.reveal-stagger .reveal-stagger-item[data-reveal="left"] {
  transform: translate3d(-52px, 22px, 0) scale(0.98);
}

.reveal-stagger .reveal-stagger-item[data-reveal="right"] {
  transform: translate3d(52px, 22px, 0) scale(0.98);
}

.reveal-stagger .reveal-stagger-item[data-reveal="rise"] {
  transform: translate3d(0, 40px, 0) scale(0.96);
}

.reveal-stagger.is-visible .reveal-stagger-item {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.vision-inner {
  text-align: center;
  max-width: 56rem;
  margin: 0 auto;
}

.vision-kicker {
  margin: 0 0 0.5rem;
  font-size: clamp(1.5rem, 4.2vw, 3rem);
  font-weight: 500;
  color: var(--navy);
  line-height: 1.2;
}

.vision-kicker--after {
  margin: 0.45rem 0 0;
  text-transform: none;
  letter-spacing: 0.01em;
  font-size: clamp(1.5rem, 4.2vw, 3rem);
  font-weight: 500;
  color: var(--navy);
}

.vision-title {
  margin: clamp(0.5rem, 1.5vw, 1rem) 0 0;
  line-height: 0.95;
  color: transparent;
}

.vision-body {
  margin: clamp(1.1rem, 3.25vw, 2rem) auto 0;
  font-size: clamp(0.98rem, 1.85vw, 1.22rem);
  line-height: 1.65;
  color: rgba(33, 50, 88, 0.88);
  max-width: min(44rem, 94vw);
}

/* Tool roundels: center-weighted scale, soft discs, spotlight glow (home #vision) */
.vision-tools {
  position: relative;
  margin: clamp(2.6rem, 6.8vw, 4.25rem) calc(50% - 50vw) 0;
  width: 100vw;
  max-width: 100vw;
  padding: 0 max(2rem, env(safe-area-inset-left)) 0 max(2rem, env(safe-area-inset-right));
  box-sizing: border-box;
  isolation: isolate;
  overflow: visible;
}

.vision-tools__title {
  margin: 0 0 clamp(0.8rem, 2vw, 1.15rem);
  text-align: center;
  font-size: clamp(0.8rem, 1.6vw, 0.95rem);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(33, 50, 88, 0.68);
}

.vision-tools__glow {
  position: absolute;
  left: 50%;
  top: 58%;
  transform: translate(-50%, -50%);
  width: min(28rem, 88vw);
  height: min(14rem, 40vw);
  background: radial-gradient(
    ellipse 52% 48% at 50% 50%,
    rgba(255, 255, 255, 0.92) 0%,
    rgba(245, 248, 252, 0.45) 45%,
    transparent 72%
  );
  pointer-events: none;
  z-index: 0;
}

.vision-tools__list {
  position: relative;
  z-index: 1;
  list-style: none;
  margin: 0;
  padding: 0.35rem 0 0.5rem;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: flex-end;
  gap: clamp(0.35rem, 1.5vw, 0.85rem);
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
}

.vision-tools__list--marquee {
  width: max-content;
  min-width: 100%;
  overflow: visible;
  padding: 0.95rem 1.75rem 1.15rem;
  border-radius: 999px;
  animation: vision-tools-marquee 36s linear infinite;
}

.vision-tools__list--marquee:hover {
  animation-play-state: paused;
}

.vision-tools__item {
  flex: 0 0 auto;
  scroll-snap-align: center;
  transform: scale(var(--roundel-scale, 1));
  opacity: var(--roundel-opacity, 1);
  filter: blur(var(--roundel-blur, 0));
  transition:
    transform 0.35s ease,
    opacity 0.35s ease,
    filter 0.35s ease;
}

.vision-tools__roundel {
  --roundel-size: clamp(2.9rem, 8.2vw, 4.7rem);
  width: var(--roundel-size);
  height: var(--roundel-size);
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(165deg, #fff 0%, #f3f5f8 100%);
  box-shadow:
    0 10px 22px rgba(33, 50, 88, 0.1),
    0 2px 6px rgba(33, 50, 88, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.85);
  padding: 18%;
  box-sizing: border-box;
}

.vision-tools__roundel--hero {
  box-shadow:
    0 14px 32px rgba(33, 50, 88, 0.14),
    0 3px 10px rgba(33, 50, 88, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.vision-tools__roundel img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  filter: saturate(1.1) contrast(1.02);
}

.vision-tools__custom {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

.vision-tools__custom svg {
  width: 100%;
  height: 100%;
  display: block;
  filter: saturate(1.12) contrast(1.04);
}

@media (prefers-reduced-motion: reduce) {
  .vision-tools__list--marquee {
    animation: none;
  }

  .vision-tools__item {
    filter: none;
    transform: none;
    opacity: 1;
  }
}

@keyframes vision-tools-marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

.vision-pillars {
  list-style: none;
  margin: clamp(2.75rem, 7vw, 4.75rem) auto 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
  gap: clamp(1.5rem, 3.2vw, 2.4rem);
  width: min(100%, 78rem);
  max-width: min(78rem, 100%);
  text-align: center;
}

.vision-pillar {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.vision-pillar__icon {
  width: min(100%, 14rem);
  max-width: 14rem;
  /* Same footprint for each pillar — images scale inside so titles align on top edge */
  height: clamp(8.75rem, 14.5vw, 10.5rem);
  max-height: 10.75rem;
  margin: 0 auto var(--space-3);
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
  box-sizing: border-box;
}

.vision-pillar__icon img {
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 100%;
  display: block;
  object-fit: contain;
}

.vision-section.section--light .vision-pillar__icon {
  background: #fff;
  border-radius: 16px;
  padding: 0.45rem;
}

.vision-section.section--light .vision-pillar__icon img {
  background: #fff;
  border-radius: 12px;
}

.vision-pillar__title {
  margin: 0 0 0.4rem;
  font-size: clamp(0.95rem, 1.35vw, 1.05rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.25;
  color: var(--navy);
}

.vision-pillar__copy {
  margin: 0;
  font-size: clamp(0.82rem, 1.2vw, 0.92rem);
  line-height: 1.55;
  color: rgba(33, 50, 88, 0.72);
}

@media (max-width: 700px) {
  .vision-pillars {
    grid-template-columns: 1fr;
    max-width: min(22rem, 100%);
  }
}

.section--light {
  background: var(--surface-warm);
  color: var(--navy);
  position: relative;
  z-index: 2;
}

/* Eyebrow: navy on light surfaces; overridden on dark bands below */
.section--light .eyebrow {
  color: var(--navy);
}

.section--light h1,
.section--light h2,
.section--light h3 {
  color: var(--navy);
}

.section--light h2.vision-title {
  color: transparent;
}

.section--light p {
  color: rgba(33, 50, 88, 0.78);
}

.vision-section.section--light .vision-kicker,
.vision-section.section--light .vision-kicker--after {
  color: var(--navy);
}

.vision-section.section--light .vision-body {
  color: rgba(33, 50, 88, 0.88);
}

.section--light a:not(.btn):not(.cta) {
  color: var(--navy);
}

.section--light a:not(.btn):not(.cta):hover {
  color: rgba(33, 50, 88, 0.65);
}

.section--light .card {
  background: color-mix(in srgb, var(--cream) 45%, white 55%);
  border: 1px solid rgba(33, 50, 88, 0.12);
  box-shadow: none;
}

.section--light .card::before {
  display: none;
}

.section--light .work-card {
  background: color-mix(in srgb, var(--cream) 45%, white 55%);
  border: 1px solid rgba(33, 50, 88, 0.12);
  color: inherit;
}

.section--light .work-card:hover {
  border-color: rgba(33, 50, 88, 0.22);
  box-shadow: 0 20px 40px rgba(33, 50, 88, 0.08);
}

.section--light .work-meta {
  color: rgba(33, 50, 88, 0.55);
}

.section--light .process-step {
  background: color-mix(in srgb, var(--cream) 45%, white 55%);
  border: 1px solid rgba(33, 50, 88, 0.12);
}

.section--light .process-number {
  color: var(--navy);
  border-color: rgba(33, 50, 88, 0.35);
  background: rgba(33, 50, 88, 0.06);
}

.section--light .cta-panel {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--cream) 88%, white 12%),
    color-mix(in srgb, var(--cream) 78%, var(--yellow) 22%)
  );
  border: 1px solid rgba(33, 50, 88, 0.14);
  box-shadow: 0 24px 60px rgba(16, 22, 42, 0.08);
}

.section--light .btn-ghost {
  border-color: rgba(33, 50, 88, 0.35);
  color: var(--navy);
}

.section--light .btn-ghost:hover {
  color: var(--ink);
}

.section--light .btn-primary {
  --btn-primary-border-hover: rgba(33, 50, 88, 0.26);
  color: var(--navy);
}

.home-portfolio-white .btn-primary,
.section--cta-dark .btn-primary {
  color: var(--navy);
}

.section--cta-dark {
  background: var(--navy);
  color: var(--cream);
  position: relative;
  z-index: 2;
  border-bottom: 1px solid rgba(246, 243, 220, 0.1);
}

.section--cta-dark .eyebrow {
  color: var(--navy);
}

.section--cta-dark h2 {
  color: var(--navy);
}

.section--cta-dark .cta-panel p {
  color: rgba(33, 50, 88, 0.8);
}

.section--cta-dark .cta-panel {
  background: linear-gradient(
    152deg,
    color-mix(in srgb, var(--cream) 78%, var(--yellow) 22%) 0%,
    color-mix(in srgb, var(--cream) 72%, var(--pink) 28%) 48%,
    color-mix(in srgb, var(--pink) 18%, var(--cream) 82%) 100%
  );
  border: 1px solid color-mix(in srgb, var(--yellow) 45%, rgba(33, 50, 88, 0.2) 55%);
  box-shadow:
    0 4px 0 rgba(240, 210, 147, 0.35) inset,
    0 28px 64px rgba(0, 0, 0, 0.35);
}

.section--cta-dark .cta-panel--split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, min(50%, 520px));
  gap: clamp(var(--space-5), 4vw, var(--space-7));
  align-items: center;
  overflow: visible;
}

.section--cta-dark .cta-panel__copy {
  min-width: 0;
}

.section--cta-dark .cta-panel__banner {
  margin: 0;
  min-width: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: visible;
  background: none;
  box-shadow: none;
}

/* Flat-lay PNG (alpha); no extra layer — transparent areas show .cta-panel gradient */
.section--cta-dark .cta-panel__banner-img {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 0;
  background: none;
  box-shadow: none;
}

@media (max-width: 768px) {
  .section--cta-dark .cta-panel--split {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .section--cta-dark .cta-panel--split .hero-actions {
    justify-content: center;
  }

  .section--cta-dark .cta-panel__banner {
    max-width: min(100%, 400px);
    margin-inline: auto;
  }
}

.section--cta-dark .btn-ghost {
  border-color: rgba(33, 50, 88, 0.35);
  color: var(--navy);
}

.section--cta-dark .btn-ghost:hover {
  color: var(--ink);
}

.section--cta-dark .btn-primary {
  --btn-primary-border-hover: rgba(33, 50, 88, 0.26);
}

/* CTA card: solid white pill at rest; transparent on hover so ::after flood reads */
.section--cta-dark .cta-panel .btn-primary {
  background-color: #fff;
  border-color: rgba(33, 50, 88, 0.22);
}

.section--cta-dark .cta-panel .btn-primary:hover {
  background-color: transparent;
}

/* Home: process & testimonials rows — capped width aligns with guttered .container */
body.page-home section.section--light.home-flow-section:not(.section--spotlight) > .container {
  width: min(1200px, 94vw);
  margin-inline: auto;
  box-sizing: border-box;
}

/* Home: process (directly under spotlight) — navy band, white intro type + white cards */
section.section--spotlight + section.section--light {
  background: var(--navy);
  color: #fff;
}

section.section--spotlight + section.section--light .eyebrow {
  color: rgba(255, 255, 255, 0.92);
}

section.section--spotlight + section.section--light > .container > h2 {
  color: #fff;
  margin-bottom: clamp(var(--space-5), 4vw, var(--space-6));
}

section.section--spotlight + section.section--light .process-list {
  gap: clamp(1.5rem, 3.5vw, 2.5rem);
}

section.section--spotlight + section.section--light .process-step {
  background: #fff;
  border: 1px solid rgba(33, 50, 88, 0.14);
  box-shadow: 0 14px 40px rgba(16, 22, 42, 0.12);
}

section.section--spotlight + section.section--light .process-step__heading {
  margin-top: 0;
  color: var(--navy);
}

/* Process band — same star sprites as portfolio quote strip; ring layout keeps glyphs clear */
body.page-home section.section--spotlight + section.section--light.home-process-band {
  position: relative;
  isolation: isolate;
}

body.page-home section.section--spotlight + section.section--light.home-process-band > .home-portfolio-quote-stars {
  position: absolute;
  left: 0;
  right: 0;
  top: clamp(0.5rem, 2.8vh, 2rem);
  bottom: clamp(1rem, 5vh, 3rem);
  width: auto;
  min-height: 0;
  pointer-events: none;
  z-index: 0;
}

body.page-home section.section--spotlight + section.section--light.home-process-band > .container {
  position: relative;
  z-index: 1;
}

/* Home: testimonials — white field; light purple cards (brand slate) */
.section--light.section--testimonials {
  background: #fff;
}

.section--light.section--testimonials .testimonial-card {
  background: color-mix(in srgb, var(--purple) 14%, white 86%);
  border: 1px solid rgba(73, 79, 126, 0.22);
  box-shadow:
    0 1px 0 rgba(73, 79, 126, 0.08),
    0 20px 48px rgba(16, 22, 42, 0.1);
}

.section--light.section--testimonials .testimonial-card:hover {
  border-color: rgba(73, 79, 126, 0.38);
  box-shadow:
    0 1px 0 rgba(73, 79, 126, 0.1),
    0 28px 64px rgba(16, 22, 42, 0.14);
}

.section--light.section--testimonials .testimonial-card__attrib {
  border-top-color: rgba(73, 79, 126, 0.22);
}

/* Home: testimonials (placeholder copy) */
.section--testimonials h2 {
  margin-bottom: var(--space-5);
}

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  align-items: stretch;
}

.testimonials-grid:has(> :only-child) {
  grid-template-columns: 1fr;
  max-width: min(38rem, 100%);
  margin-inline: auto;
}

.testimonial-card {
  margin: 0;
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid #e5e7eb;
  background: #f9fafb;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.35s ease, border-color 0.35s ease;
}

.testimonial-card:hover {
  border-color: rgba(33, 50, 88, 0.18);
  box-shadow: 0 16px 40px rgba(33, 50, 88, 0.08);
}

.testimonial-card__quote {
  margin: 0;
  padding: 0;
  border: none;
  quotes: none;
  flex: 1;
}

.testimonial-card__quote p {
  margin: 0;
  font-size: clamp(0.98rem, 1.5vw, 1.05rem);
  line-height: 1.6;
  color: rgba(33, 50, 88, 0.88);
  font-style: italic;
  font-weight: 500;
}

.testimonial-card__attrib {
  margin: var(--space-4) 0 0;
  padding-top: var(--space-4);
  border-top: 1px solid rgba(33, 50, 88, 0.1);
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.testimonial-card__name {
  font-style: normal;
  font-weight: 700;
  font-size: 0.92rem;
  color: var(--navy);
}

.testimonial-card__role {
  font-style: normal;
  font-weight: 500;
  font-size: 0.8rem;
  letter-spacing: 0.02em;
  color: rgba(33, 50, 88, 0.62);
}

@media (max-width: 960px) {
  .testimonials-grid {
    grid-template-columns: 1fr;
    max-width: 32rem;
    margin: 0 auto;
  }
}

.section--spotlight {
  padding-top: var(--space-9);
  padding-bottom: var(--space-9);
}

/* Strategic spotlight: white field + subtle drifting aurora (Motion-style wash) */
.section--light.section--spotlight {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background-color: #fff;
  background-image: linear-gradient(
    165deg,
    #ffffff 0%,
    color-mix(in srgb, var(--cream) 12%, #fff 88%) 45%,
    #fafcfe 100%
  );
}

.section--light.section--spotlight::before {
  content: "";
  position: absolute;
  inset: -30% -18% -25% -18%;
  background:
    radial-gradient(ellipse 58% 44% at 16% 28%, rgba(240, 210, 147, 0.38), transparent 62%),
    radial-gradient(ellipse 52% 46% at 90% 16%, rgba(232, 153, 140, 0.3), transparent 58%),
    radial-gradient(ellipse 48% 40% at 74% 82%, rgba(73, 79, 126, 0.16), transparent 56%),
    radial-gradient(ellipse 42% 38% at 38% 90%, rgba(240, 210, 147, 0.22), transparent 60%);
  filter: blur(52px);
  opacity: 0.72;
  pointer-events: none;
  z-index: 0;
  transform: translateZ(0);
  animation: section-spotlight-aurora 26s ease-in-out infinite alternate;
}

.section--spotlight > .container {
  position: relative;
  z-index: 1;
}

@keyframes section-spotlight-aurora {
  0% {
    transform: translate(-5%, -4%) scale(1) rotate(0deg);
  }
  35% {
    transform: translate(6%, 3%) scale(1.06) rotate(4deg);
  }
  70% {
    transform: translate(-3%, 6%) scale(1.02) rotate(-3deg);
  }
  100% {
    transform: translate(4%, -5%) scale(1.08) rotate(2deg);
  }
}

.section--spotlight .spotlight-inner {
  max-width: 62rem;
}

.spotlight-inner {
  text-align: center;
  max-width: 52rem;
  margin: 0 auto;
}

.spotlight-heading {
  font-size: clamp(2rem, 5vw, 3.75rem);
  font-weight: 700;
  margin-bottom: var(--space-4);
  line-height: 1.1;
  color: var(--navy);
}

.spotlight-lede {
  font-size: clamp(1.05rem, 2.2vw, 1.35rem);
  line-height: 1.65;
  color: rgba(33, 50, 88, 0.78);
  margin: 0 auto var(--space-7);
  max-width: min(44rem, 94vw);
}

.section--spotlight .spotlight-grid {
  grid-template-columns: repeat(auto-fit, minmax(268px, 1fr));
}

.spotlight-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-5);
  text-align: left;
  margin-top: var(--space-6);
}

.spotlight-card {
  --spot-x: 50%;
  --spot-y: 36%;
  position: relative;
  container-type: inline-size;
  padding: var(--space-5);
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background-color: var(--navy);
  color: #fff;
  overflow: hidden;
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

/* Star field behind copy — ref: dense top/right constellation, mixed sizes + opacity;3 layouts */
.spotlight-card:nth-child(1) {
  background-image:
    radial-gradient(circle 2.4px at 90% 7%, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.48) 42%, transparent 72%),
    radial-gradient(circle 1.35px at 96% 14%, rgba(255, 255, 255, 0.78) 0%, transparent 2px),
    radial-gradient(circle 0.55px at 82% 5%, rgba(255, 255, 255, 0.52) 0%, transparent 1px),
    radial-gradient(circle 0.9px at 76% 12%, rgba(255, 255, 255, 0.66) 0%, transparent 1.6px),
    radial-gradient(circle 0.45px at 88% 18%, rgba(255, 255, 255, 0.4) 0%, transparent 1px),
    radial-gradient(circle 1.1px at 72% 20%, rgba(255, 255, 255, 0.58) 0%, transparent 1.8px),
    radial-gradient(circle 0.5px at 94% 22%, rgba(255, 255, 255, 0.45) 0%, transparent 1px),
    radial-gradient(circle 1.6px at 86% 26%, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.55) 45%, transparent 78%),
    radial-gradient(circle 0.48px at 68% 8%, rgba(255, 255, 255, 0.38) 0%, transparent 1px),
    radial-gradient(circle 0.85px at 58% 11%, rgba(255, 255, 255, 0.5) 0%, transparent 1.5px),
    radial-gradient(circle 0.4px at 52% 6%, rgba(255, 255, 255, 0.35) 0%, transparent 1px),
    radial-gradient(circle 1.2px at 62% 18%, rgba(255, 255, 255, 0.62) 0%, transparent 2px),
    radial-gradient(circle 0.52px at 48% 14%, rgba(255, 255, 255, 0.42) 0%, transparent 1px),
    radial-gradient(circle 0.42px at 42% 9%, rgba(255, 255, 255, 0.32) 0%, transparent 1px),
    radial-gradient(circle 0.95px at 78% 32%, rgba(255, 255, 255, 0.54) 0%, transparent 1.6px),
    radial-gradient(circle 0.48px at 92% 30%, rgba(255, 255, 255, 0.36) 0%, transparent 1px),
    radial-gradient(circle 1.4px at 98% 34%, rgba(255, 255, 255, 0.68) 0%, transparent 2.2px),
    radial-gradient(circle 0.55px at 84% 38%, rgba(255, 255, 255, 0.48) 0%, transparent 1px),
    radial-gradient(circle 0.38px at 70% 36%, rgba(255, 255, 255, 0.3) 0%, transparent 1px),
    radial-gradient(circle 2px at 88% 42%, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0.42) 50%, transparent 76%),
    radial-gradient(circle 0.72px at 74% 44%, rgba(255, 255, 255, 0.56) 0%, transparent 1.4px),
    radial-gradient(circle 0.44px at 96% 46%, rgba(255, 255, 255, 0.34) 0%, transparent 1px),
    radial-gradient(circle 0.88px at 56% 24%, rgba(255, 255, 255, 0.46) 0%, transparent 1.5px),
    radial-gradient(circle 0.5px at 36% 16%, rgba(255, 255, 255, 0.28) 0%, transparent 1px),
    radial-gradient(circle 0.62px at 32% 22%, rgba(255, 255, 255, 0.4) 0%, transparent 1.2px),
    radial-gradient(circle 1.15px at 66% 48%, rgba(255, 255, 255, 0.5) 0%, transparent 1.9px),
    radial-gradient(circle 0.46px at 90% 52%, rgba(255, 255, 255, 0.33) 0%, transparent 1px),
    radial-gradient(circle 0.58px at 82% 50%, rgba(255, 255, 255, 0.44) 0%, transparent 1.1px);
}

.spotlight-card:nth-child(2) {
  background-image:
    radial-gradient(circle 1.25px at 93% 9%, rgba(255, 255, 255, 0.72) 0%, transparent 2px),
    radial-gradient(circle 2.2px at 86% 5%, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.44) 48%, transparent 74%),
    radial-gradient(circle 0.5px at 98% 18%, rgba(255, 255, 255, 0.46) 0%, transparent 1px),
    radial-gradient(circle 0.82px at 80% 14%, rgba(255, 255, 255, 0.6) 0%, transparent 1.5px),
    radial-gradient(circle 0.44px at 74% 6%, rgba(255, 255, 255, 0.36) 0%, transparent 1px),
    radial-gradient(circle 1.5px at 90% 22%, rgba(255, 255, 255, 0.64) 0%, transparent 2.1px),
    radial-gradient(circle 0.48px at 70% 16%, rgba(255, 255, 255, 0.4) 0%, transparent 1px),
    radial-gradient(circle 0.92px at 64% 10%, rgba(255, 255, 255, 0.52) 0%, transparent 1.6px),
    radial-gradient(circle 0.4px at 54% 8%, rgba(255, 255, 255, 0.3) 0%, transparent 1px),
    radial-gradient(circle 1.1px at 60% 20%, rgba(255, 255, 255, 0.58) 0%, transparent 1.8px),
    radial-gradient(circle 0.55px at 46% 12%, rgba(255, 255, 255, 0.42) 0%, transparent 1px),
    radial-gradient(circle 0.38px at 40% 18%, rgba(255, 255, 255, 0.26) 0%, transparent 1px),
    radial-gradient(circle 1.35px at 84% 30%, rgba(255, 255, 255, 0.7) 0%, transparent 2px),
    radial-gradient(circle 0.58px at 76% 28%, rgba(255, 255, 255, 0.46) 0%, transparent 1.1px),
    radial-gradient(circle 0.46px at 94% 36%, rgba(255, 255, 255, 0.34) 0%, transparent 1px),
    radial-gradient(circle 2.1px at 88% 38%, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.4) 46%, transparent 72%),
    radial-gradient(circle 0.72px at 72% 38%, rgba(255, 255, 255, 0.54) 0%, transparent 1.4px),
    radial-gradient(circle 0.5px at 96% 44%, rgba(255, 255, 255, 0.38) 0%, transparent 1px),
    radial-gradient(circle 0.88px at 82% 46%, rgba(255, 255, 255, 0.5) 0%, transparent 1.5px),
    radial-gradient(circle 0.42px at 68% 42%, rgba(255, 255, 255, 0.32) 0%, transparent 1px),
    radial-gradient(circle 1.05px at 58% 28%, rgba(255, 255, 255, 0.48) 0%, transparent 1.7px),
    radial-gradient(circle 0.52px at 34% 14%, rgba(255, 255, 255, 0.34) 0%, transparent 1px),
    radial-gradient(circle 0.65px at 28% 20%, rgba(255, 255, 255, 0.4) 0%, transparent 1.2px),
    radial-gradient(circle 0.45px at 50% 22%, rgba(255, 255, 255, 0.36) 0%, transparent 1px),
    radial-gradient(circle 1.2px at 78% 50%, rgba(255, 255, 255, 0.56) 0%, transparent 2px),
    radial-gradient(circle 0.48px at 92% 54%, rgba(255, 255, 255, 0.32) 0%, transparent 1px),
    radial-gradient(circle 0.6px at 64% 46%, rgba(255, 255, 255, 0.44) 0%, transparent 1.1px);
}

.spotlight-card:nth-child(3) {
  background-image:
    radial-gradient(circle 2.3px at 94% 6%, rgba(255, 255, 255, 0.15) 0%, rgba(255, 255, 255, 0.46) 44%, transparent 73%),
    radial-gradient(circle 0.52px at 88% 11%, rgba(255, 255, 255, 0.44) 0%, transparent 1px),
    radial-gradient(circle 1.3px at 78% 8%, rgba(255, 255, 255, 0.74) 0%, transparent 2px),
    radial-gradient(circle 0.46px at 84% 16%, rgba(255, 255, 255, 0.38) 0%, transparent 1px),
    radial-gradient(circle 0.95px at 70% 14%, rgba(255, 255, 255, 0.6) 0%, transparent 1.6px),
    radial-gradient(circle 0.42px at 92% 20%, rgba(255, 255, 255, 0.34) 0%, transparent 1px),
    radial-gradient(circle 1.45px at 96% 26%, rgba(255, 255, 255, 0.66) 0%, transparent 2.1px),
    radial-gradient(circle 0.55px at 74% 24%, rgba(255, 255, 255, 0.48) 0%, transparent 1px),
    radial-gradient(circle 0.88px at 66% 18%, rgba(255, 255, 255, 0.52) 0%, transparent 1.5px),
    radial-gradient(circle 0.4px at 56% 12%, rgba(255, 255, 255, 0.28) 0%, transparent 1px),
    radial-gradient(circle 0.72px at 50% 18%, rgba(255, 255, 255, 0.46) 0%, transparent 1.3px),
    radial-gradient(circle 0.5px at 44% 7%, rgba(255, 255, 255, 0.36) 0%, transparent 1px),
    radial-gradient(circle 1.15px at 62% 26%, rgba(255, 255, 255, 0.56) 0%, transparent 1.9px),
    radial-gradient(circle 0.48px at 86% 32%, rgba(255, 255, 255, 0.4) 0%, transparent 1px),
    radial-gradient(circle 1.6px at 90% 36%, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.52) 48%, transparent 76%),
    radial-gradient(circle 0.58px at 76% 34%, rgba(255, 255, 255, 0.46) 0%, transparent 1.1px),
    radial-gradient(circle 0.44px at 98% 40%, rgba(255, 255, 255, 0.32) 0%, transparent 1px),
    radial-gradient(circle 0.92px at 82% 44%, rgba(255, 255, 255, 0.54) 0%, transparent 1.6px),
    radial-gradient(circle 0.38px at 72% 40%, rgba(255, 255, 255, 0.28) 0%, transparent 1px),
    radial-gradient(circle 1.05px at 68% 32%, rgba(255, 255, 255, 0.5) 0%, transparent 1.7px),
    radial-gradient(circle 0.54px at 38% 15%, rgba(255, 255, 255, 0.36) 0%, transparent 1px),
    radial-gradient(circle 0.62px at 32% 10%, rgba(255, 255, 255, 0.32) 0%, transparent 1.2px),
    radial-gradient(circle 0.45px at 48% 24%, rgba(255, 255, 255, 0.34) 0%, transparent 1px),
    radial-gradient(circle 1.25px at 58% 38%, rgba(255, 255, 255, 0.58) 0%, transparent 2px),
    radial-gradient(circle 0.5px at 94% 48%, rgba(255, 255, 255, 0.36) 0%, transparent 1px),
    radial-gradient(circle 0.68px at 86% 50%, rgba(255, 255, 255, 0.48) 0%, transparent 1.2px),
    radial-gradient(circle 0.46px at 70% 48%, rgba(255, 255, 255, 0.34) 0%, transparent 1px);
}

/* Pointer-follow spotlight + extra stars revealed inside the cone (home spotlight cards) */
.spotlight-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.35s ease;
  background: radial-gradient(
    circle 150px at var(--spot-x) var(--spot-y),
    rgba(255, 255, 255, 0.2) 0%,
    rgba(255, 255, 255, 0.06) 42%,
    transparent 68%
  );
}

.spotlight-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.35s ease;
  -webkit-mask-image: radial-gradient(
    circle 118px at var(--spot-x) var(--spot-y),
    #000 0%,
    transparent 70%
  );
  mask-image: radial-gradient(
    circle 118px at var(--spot-x) var(--spot-y),
    #000 0%,
    transparent 70%
  );
  background-image:
    radial-gradient(circle 1.1px at 12% 18%, rgba(255, 255, 255, 0.72) 0%, transparent 2px),
    radial-gradient(circle 0.5px at 22% 28%, rgba(255, 255, 255, 0.45) 0%, transparent 1px),
    radial-gradient(circle 0.85px at 18% 42%, rgba(255, 255, 255, 0.58) 0%, transparent 1.6px),
    radial-gradient(circle 0.4px at 28% 52%, rgba(255, 255, 255, 0.34) 0%, transparent 1px),
    radial-gradient(circle 1.35px at 38% 22%, rgba(255, 255, 255, 0.68) 0%, transparent 2px),
    radial-gradient(circle 0.48px at 48% 38%, rgba(255, 255, 255, 0.42) 0%, transparent 1px),
    radial-gradient(circle 0.95px at 42% 58%, rgba(255, 255, 255, 0.55) 0%, transparent 1.8px),
    radial-gradient(circle 0.42px at 52% 48%, rgba(255, 255, 255, 0.36) 0%, transparent 1px),
    radial-gradient(circle 1.2px at 58% 28%, rgba(255, 255, 255, 0.62) 0%, transparent 2px),
    radial-gradient(circle 0.55px at 68% 18%, rgba(255, 255, 255, 0.48) 0%, transparent 1px),
    radial-gradient(circle 0.38px at 72% 42%, rgba(255, 255, 255, 0.32) 0%, transparent 1px),
    radial-gradient(circle 0.88px at 62% 62%, rgba(255, 255, 255, 0.52) 0%, transparent 1.5px),
    radial-gradient(circle 0.5px at 78% 52%, rgba(255, 255, 255, 0.4) 0%, transparent 1px),
    radial-gradient(circle 1.5px at 88% 32%, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.55) 48%, transparent 76%),
    radial-gradient(circle 0.46px at 32% 68%, rgba(255, 255, 255, 0.35) 0%, transparent 1px),
    radial-gradient(circle 0.72px at 82% 68%, rgba(255, 255, 255, 0.5) 0%, transparent 1.3px),
    radial-gradient(circle 0.44px at 92% 58%, rgba(255, 255, 255, 0.33) 0%, transparent 1px),
    radial-gradient(circle 1.05px at 8% 72%, rgba(255, 255, 255, 0.48) 0%, transparent 1.7px),
    radial-gradient(circle 0.52px at 55% 78%, rgba(255, 255, 255, 0.42) 0%, transparent 1px),
    radial-gradient(circle 0.65px at 25% 82%, rgba(255, 255, 255, 0.38) 0%, transparent 1.2px);
}

.spotlight-card:hover::before,
.spotlight-card:focus-within::before {
  opacity: 1;
}

.spotlight-card:hover::after,
.spotlight-card:focus-within::after {
  opacity: 1;
}

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

@media (prefers-reduced-motion: reduce) {
  .spotlight-card::before,
  .spotlight-card::after {
    opacity: 0;
    transition: none;
  }

  .spotlight-card:hover::before,
  .spotlight-card:hover::after,
  .spotlight-card:focus-within::before,
  .spotlight-card:focus-within::after {
    opacity: 0;
  }
}

.spotlight-card__icon {
  margin: 0 0 var(--space-4);
  color: #fff;
  width: 3.1rem;
  height: 3.1rem;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: linear-gradient(
    150deg,
    rgba(240, 210, 147, 0.26) 0%,
    rgba(232, 153, 140, 0.22) 44%,
    rgba(73, 79, 126, 0.36) 100%
  );
  border: 1px solid rgba(246, 243, 220, 0.24);
  box-shadow:
    0 10px 22px rgba(16, 22, 42, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.spotlight-card__icon-svg {
  width: 1.8rem;
  height: 1.8rem;
  display: block;
  filter: drop-shadow(0 2px 5px rgba(16, 22, 42, 0.24));
}

.spotlight-card:hover .spotlight-card__icon,
.spotlight-card:focus-within .spotlight-card__icon {
  transform: translateY(-2px) scale(1.03);
  border-color: rgba(246, 243, 220, 0.36);
  box-shadow:
    0 14px 28px rgba(16, 22, 42, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.spotlight-card:hover {
  border-color: rgba(255, 255, 255, 0.4);
  box-shadow: 0 20px 48px rgba(16, 22, 42, 0.32);
}

.spotlight-card h3 {
  font-size: 1.35rem;
  margin-top: 0;
  margin-bottom: var(--space-2);
  color: #fff;
}

.spotlight-card p {
  margin: 0;
  font-size: 0.98rem;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.55;
}

/* ----- Home: portfolio showcase (dark band only; following sections stay .section--light) ----- */
.section--light.home-portfolio-white {
  background: var(--navy);
  color: var(--cream);
}

.section--light.home-portfolio-white .eyebrow {
  color: rgba(246, 243, 220, 0.75);
}

.home-portfolio-white {
  position: relative;
  margin-top: -1px;
  padding: calc(clamp(3.25rem, 9vw, 6.5rem) + 1px) 0 clamp(3.5rem, 10vw, 7rem);
  border-bottom: none;
}

.home-portfolio-white .container.home-portfolio-white__inner {
  width: min(1200px, 94vw);
}

.home-portfolio-white .home-work-showcase__intro .spotlight-heading {
  margin-bottom: var(--space-4);
  color: var(--cream);
}

.home-portfolio-white .home-work-showcase__intro-lede {
  margin-bottom: clamp(2rem, 5vw, 3.5rem);
  max-width: min(56rem, 94vw);
  text-wrap: balance;
  color: var(--cream);
}

.home-portfolio-white .spotlight-lede {
  color: var(--cream);
}

.home-portfolio-white .home-portfolio-white__cta {
  position: relative;
  isolation: isolate;
  margin-top: clamp(2.5rem, 7vw, 4.25rem);
  padding-top: clamp(1.5rem, 4vw, 2.5rem);
  border-top: 1px solid rgba(246, 243, 220, 0.12);
}

/* Match home starfield canvas: small discs, white / cool blue-white (main.js drawStars) */
.home-portfolio-quote-stars {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  min-height: 12rem;
  pointer-events: none;
  z-index: 0;
}

.home-portfolio-quote-stars__star {
  position: absolute;
  left: var(--star-x);
  top: var(--star-y);
  width: 2px;
  height: 2px;
  margin-left: -1px;
  margin-top: -1px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 0 4px rgba(255, 255, 255, 0.35);
}

.home-portfolio-quote-stars__star--cool {
  background: rgba(210, 228, 255, 0.78);
  box-shadow: 0 0 4px rgba(210, 228, 255, 0.32);
}

.home-portfolio-white .home-portfolio-white__cta > :not(.home-portfolio-quote-stars) {
  position: relative;
  z-index: 1;
}

@media (prefers-reduced-motion: reduce) {
  .home-portfolio-quote-stars__star {
    box-shadow: none;
  }
}

.home-portfolio-white .home-work-showcase__headline,
.home-portfolio-white .home-work-showcase__quote,
.home-portfolio-white .home-work-showcase__quote p {
  color: rgba(246, 243, 220, 0.95);
}

.home-portfolio-white .home-work-showcase__quote-attrib {
  color: rgba(246, 243, 220, 0.95);
}

.home-work-showcase__intro {
  margin-left: auto;
  margin-right: auto;
}

.home-work-showcase__grid {
  --showcase-tile-radius: 4px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(14px, 2vw, 22px);
  margin-bottom: 0;
  background: transparent;
}

.home-portfolio-white .home-work-showcase__tile {
  position: relative;
  display: block;
  text-decoration: none;
  color: inherit;
  border-radius: var(--showcase-tile-radius);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(246, 243, 220, 0.1);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
  transition: box-shadow 0.4s ease, border-color 0.35s ease, transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.home-portfolio-white .home-work-showcase__tile:focus-visible {
  outline: 2px solid rgba(246, 243, 220, 0.65);
  outline-offset: 3px;
}

.home-portfolio-white .home-work-showcase__tile:hover {
  border-color: rgba(246, 243, 220, 0.18);
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.45);
  transform: translateY(-2px);
}

.home-portfolio-white .home-work-showcase__media {
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: rgba(12, 18, 36, 0.9);
}

.home-work-showcase__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.home-work-showcase__img--primary {
  opacity: 1;
  z-index: 1;
}

.home-work-showcase__img--alt {
  opacity: 0;
  z-index: 2;
}

.home-work-showcase__tile:hover .home-work-showcase__img--primary,
.home-work-showcase__tile:focus-visible .home-work-showcase__img--primary {
  opacity: 0;
}

.home-work-showcase__tile:hover .home-work-showcase__img--alt,
.home-work-showcase__tile:focus-visible .home-work-showcase__img--alt {
  opacity: 1;
}

.home-work-showcase__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 48rem;
  margin: 0 auto;
  gap: var(--space-5);
}

.home-work-showcase .spotlight-heading,
.home-work-showcase .spotlight-lede,
.home-work-showcase__intro-lede {
  color: var(--cream);
}

.home-work-showcase .spotlight-lede,
.home-work-showcase__intro-lede {
  color: var(--cream);
}

.home-work-showcase__headline {
  font-family: "Greycliff CF", "Space Grotesk", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.85rem, 5vw, 3.35rem);
  line-height: 1.08;
  letter-spacing: -0.032em;
  color: var(--cream);
  margin: 0 0 var(--space-4);
  text-wrap: balance;
}

.home-work-showcase__quote {
  padding: 0;
  border: none;
  quotes: none;
  font-style: italic;
  font-weight: 700;
  line-height: 1.02;
  color: rgba(246, 243, 220, 0.92);
}

.home-work-showcase__quote p {
  margin: 0;
  color: rgba(246, 243, 220, 0.92);
  line-height: 1.02;
}

.home-work-showcase__quote-attrib {
  margin: var(--space-4) 0 0;
  font-style: normal;
  font-weight: 600;
  font-size: clamp(1rem, 2.5vw, 1.35rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: rgba(246, 243, 220, 0.92);
}

.home-work-showcase__cta .home-work-showcase__headline {
  margin: 0;
}

.home-work-showcase .btn-ghost {
  border-color: rgba(246, 243, 220, 0.35);
  color: var(--cream);
}

.home-work-showcase .btn-ghost:hover {
  color: #fff;
}

.home-work-showcase .btn-primary {
  --btn-primary-border-hover: rgba(33, 50, 88, 0.26);
  box-shadow: 0 10px 28px rgba(16, 22, 42, 0.14);
}

.home-work-showcase .btn-primary:hover {
  box-shadow: 0 14px 36px rgba(232, 153, 140, 0.32);
}

@media (max-width: 900px) {
  .home-work-showcase__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

@media (prefers-reduced-motion: reduce) {
  .home-work-showcase__tile {
    transition: none;
  }

  .home-work-showcase__tile:hover {
    transform: none;
  }

  .home-work-showcase__img {
    transition: opacity 0.01s linear;
  }
}

/* ── Projects intro section (white band above parallax image) ── */
.home-work-showcase__intro-section {
  background: #fff;
  text-align: center;
  padding-top: clamp(3rem, 8vw, 5.5rem);
  padding-bottom: clamp(2.5rem, 7vw, 4.5rem);
  border-top: 1px solid rgba(33, 50, 88, 0.12);
}

.home-work-showcase__header-inner {
  max-width: min(52rem, 94vw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.home-work-showcase__header-inner .spotlight-heading {
  color: var(--navy);
  margin-bottom: 0;
}

.home-work-showcase__header-inner .home-work-showcase__intro-lede {
  color: rgba(33, 50, 88, 0.72);
  margin: 0;
}

/* ── Portfolio marquee band — sticky so quote band can slide over it on scroll ── */
.home-work-showcase__mosaic-band {
  display: block;
  position: sticky;
  top: 0;
  z-index: 1;
}

.home-work-showcase__mosaic--marquee {
  position: relative;
  display: block;
  width: 100%;
  min-height: clamp(420px, 52vw, 720px);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  background: radial-gradient(ellipse 120% 80% at 50% 100%, rgba(232, 153, 140, 0.12), transparent 55%),
    linear-gradient(180deg, #070a12 0%, #12192a 42%, #0a0e18 100%);
}

.home-work-showcase__mosaic--marquee:focus-visible {
  outline: 2px solid var(--cream);
  outline-offset: 3px;
}

/* Warm tint on hover — keeps imagery visible (not a white wash) */
.home-work-showcase__mosaic--marquee::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    125deg,
    rgba(232, 153, 140, 0.14),
    rgba(240, 210, 147, 0.1),
    rgba(73, 79, 126, 0.12)
  );
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.home-work-showcase__mosaic--marquee:hover::after,
.home-work-showcase__mosaic--marquee:focus-visible::after {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .home-work-showcase__mosaic--marquee::after {
    transition: none;
  }
}

.home-work-showcase__marquee {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: clamp(10px, 2vw, 14px);
  padding: clamp(14px, 3vw, 22px) 0;
  z-index: 1;
  perspective: 1100px;
  perspective-origin: 50% 40%;
}

.home-work-showcase__marquee-row {
  position: relative;
  overflow: hidden;
  flex: 1;
  min-height: 0;
  display: flex;
  align-items: center;
  mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
}

.home-work-showcase__marquee-row--tilt-a {
  transform: rotateX(5deg);
  transform-origin: center center;
}

.home-work-showcase__marquee-row--tilt-b {
  transform: rotateX(0deg);
  transform-origin: center center;
}

.home-work-showcase__marquee-row--tilt-c {
  transform: rotateX(-5deg);
  transform-origin: center center;
}

.home-work-showcase__marquee-track {
  display: flex;
  width: max-content;
  will-change: transform;
  animation: home-marquee-scroll 55s linear infinite;
}

.home-work-showcase__marquee-track--reverse {
  animation-direction: reverse;
  animation-duration: 62s;
}

.home-work-showcase__marquee-track--slow {
  animation-duration: 72s;
}

@keyframes home-marquee-scroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

.home-work-showcase__marquee-strip {
  display: flex;
  align-items: stretch;
  gap: clamp(10px, 1.6vw, 14px);
  padding-right: clamp(10px, 1.6vw, 14px);
}

.home-work-showcase__marquee-img {
  flex: 0 0 auto;
  width: clamp(160px, 22vw, 240px);
  height: clamp(100px, 14vw, 150px);
  object-fit: cover;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(246, 243, 220, 0.14);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

@media (prefers-reduced-motion: reduce) {
  .home-work-showcase__marquee-track {
    animation: none;
    transform: translateX(0);
  }

  .home-work-showcase__marquee-row--tilt-a,
  .home-work-showcase__marquee-row--tilt-b,
  .home-work-showcase__marquee-row--tilt-c {
    transform: none;
  }
}

/* ── Dark quote band — slides up over the sticky image (layered scroll effect) ── */
.home-work-showcase__quote-band {
  position: relative;
  z-index: 2;
  /* Rounded top corners + shadow give the "card lifting over" depth */
  border-radius: 20px 20px 0 0;
  box-shadow:
    0 -28px 64px rgba(8, 12, 28, 0.55),
    0 -2px 0 rgba(246, 243, 220, 0.07);
  /* Pull up by 1px so no gap forms between image and quote band */
  margin-top: -1px;
  padding: clamp(3.25rem, 9vw, 6.5rem) 0;
}

.home-work-showcase__quote-band .home-portfolio-white__cta {
  padding-top: 0;
  border-top: none;
}

.home-work-showcase__quote-band .home-work-showcase__cta {
  /* Wider canvas so decorative stars live in side margins, not under the quote copy */
  max-width: min(72rem, 94vw);
  gap: var(--space-6);
}

.home-work-showcase__quote-band .home-work-showcase__quote {
  margin-inline: auto;
  width: fit-content;
  max-width: min(36rem, 88vw);
  box-sizing: border-box;
}

.home-work-showcase__quote-band .home-portfolio-quote-stars {
  /* Keeps sprites in horizontal margins and above/below the copy block */
  top: clamp(0.75rem, 3%, 2rem);
  bottom: clamp(0.75rem, 8%, 2.75rem);
  left: 0;
  right: 0;
  min-height: 0;
}

@media (max-width: 720px) {
  .home-work-showcase__quote-band {
    border-radius: 14px 14px 0 0;
  }
}

.footer-logo {
  height: 56px;
  width: auto;
  margin-bottom: var(--space-3);
}

/* Must beat `.site-logo img { display: block }` (img + class > class alone) */
.site-logo img.site-logo__mark--dark {
  display: none;
}

.hero-actions--center {
  justify-content: center;
}

.hero-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
  align-items: center;
}

.hero-grid .eyebrow {
  margin-bottom: var(--space-3);
}

.hero-card {
  background: rgba(16, 22, 42, 0.45);
  border: 1px solid rgba(246, 243, 220, 0.12);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
  animation: float-slow 10s ease-in-out infinite;
}

.hero-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(240, 210, 147, 0.2), transparent 45%);
  opacity: 0.8;
  pointer-events: none;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.btn {
  padding: 9px 18px;
  border-radius: 999px;
  border: 1px solid rgba(246, 243, 220, 0.45);
  font-weight: 600;
  font-size: 0.6875rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  background: transparent;
  color: var(--cream);
  text-decoration: none;
  transition: background 0.35s ease, border-color 0.35s ease, color 0.35s ease, box-shadow 0.35s ease,
    filter 0.35s ease;
}

.btn:hover:not(.btn-primary):not(.btn-ghost) {
  background: var(--pink);
  border-color: var(--pink);
  color: var(--ink);
  box-shadow: none;
}

.btn-primary {
  --btn-primary-flood: linear-gradient(
    125deg,
    color-mix(in srgb, var(--pink) 88%, var(--yellow) 12%),
    color-mix(in srgb, var(--yellow) 62%, var(--cream) 38%) 52%,
    color-mix(in srgb, var(--pink) 35%, var(--yellow) 65%)
  );
  --btn-primary-border-hover: rgba(16, 22, 42, 0.2);
  position: relative;
  z-index: 0;
  isolation: isolate;
  background-color: transparent;
  border: 2px solid rgba(246, 243, 220, 0.26);
  border-radius: 999px;
  color: var(--cream);
  box-shadow: 0 10px 28px rgba(16, 22, 42, 0.12);
  overflow: hidden;
  transition: color 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.btn-primary::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 2px;
  background: conic-gradient(
    from var(--btn-mb-angle),
    rgba(232, 153, 140, 0.95),
    rgba(240, 210, 147, 0.92),
    rgba(246, 243, 220, 0.78),
    rgba(73, 79, 126, 0.6),
    rgba(232, 153, 140, 0.95)
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  animation: btn-primary-border-spin 3.2s linear infinite;
}

.btn-primary::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--btn-primary-flood);
  transform: scaleY(0);
  transform-origin: center bottom;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
  z-index: -1;
}

@keyframes btn-primary-border-spin {
  to {
    --btn-mb-angle: 360deg;
  }
}

.btn-primary:hover {
  border-color: var(--btn-primary-border-hover);
  color: var(--ink);
  box-shadow: 0 14px 36px rgba(232, 153, 140, 0.35);
}

.btn-primary:hover::after {
  transform: scaleY(1);
}

.btn-primary:hover::before {
  animation: none;
}

.btn-primary:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--pink) 55%, var(--navy) 45%);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .btn-primary::before {
    animation: none;
  }

  .section--light.section--spotlight::before {
    animation: none;
    transform: none;
    opacity: 0.48;
  }
}

.btn-ghost {
  --btn-ghost-fill: #ffffff;
  background-color: transparent;
  background-image: linear-gradient(to top, var(--btn-ghost-fill), var(--btn-ghost-fill));
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 100% 0;
  transition: background-size 0.45s cubic-bezier(0.22, 1, 0.36, 1), color 0.35s ease,
    border-color 0.35s ease;
}

.btn-ghost:hover {
  background-size: 100% 100%;
  border-color: var(--pink);
  color: var(--ink);
}

.proof-bar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.proof-pill {
  padding: 12px 16px;
  border-radius: 999px;
  background: rgba(246, 243, 220, 0.08);
  border: 1px solid rgba(246, 243, 220, 0.12);
  font-size: 0.85rem;
  text-align: center;
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
}

.service-stack {
  display: grid;
  gap: var(--space-5);
}

.service-block {
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid rgba(246, 243, 220, 0.14);
  background: rgba(16, 22, 42, 0.4);
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
}

.service-block::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(240, 210, 147, 0.18), transparent 45%);
  opacity: 0.7;
  pointer-events: none;
}

.service-header {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-4);
  align-items: start;
  margin-bottom: var(--space-4);
}

.service-index {
  font-size: 1.1rem;
  letter-spacing: 0.4em;
  color: var(--yellow);
  font-weight: 600;
  border: 1px solid rgba(240, 210, 147, 0.4);
  border-radius: 999px;
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
  background: rgba(240, 210, 147, 0.08);
}

.service-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px 20px;
  color: rgba(246, 243, 220, 0.8);
  position: relative;
}

.service-list span {
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(246, 243, 220, 0.16);
  background: rgba(16, 22, 42, 0.5);
  font-size: 0.85rem;
  text-align: center;
}

.card {
  background: rgba(16, 22, 42, 0.45);
  border: 1px solid rgba(246, 243, 220, 0.12);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  position: relative;
  overflow: hidden;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 20%, rgba(73, 79, 126, 0.45), transparent 45%);
  opacity: 0.7;
}

.card > * {
  position: relative;
}

.card h3 {
  margin-bottom: var(--space-2);
}

.about-profile-label {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  font-weight: 600;
  color: rgba(246, 243, 220, 0.55);
  margin-bottom: var(--space-2);
}

.about-detail-list {
  margin: 0;
  padding-left: 1.15rem;
  line-height: 1.65;
}

.about-detail-list li {
  margin-bottom: 0.35rem;
}

.about-detail-list li:last-child {
  margin-bottom: 0;
}

.about-tools-copy {
  margin: 0;
  line-height: 1.65;
}

.work-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-4);
}

.work-card {
  background: rgba(16, 22, 42, 0.45);
  border: 1px solid rgba(246, 243, 220, 0.12);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  transition: transform 0.3s ease, border 0.3s ease;
}

.work-card:hover {
  transform: translateY(-6px);
  border-color: rgba(240, 210, 147, 0.5);
}

.work-meta {
  font-size: 0.8rem;
  color: rgba(246, 243, 220, 0.6);
  margin-bottom: var(--space-2);
}

.process-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
}

.process-step {
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid rgba(246, 243, 220, 0.12);
  background: rgba(16, 22, 42, 0.5);
}

.process-step__icon {
  margin: 0 0 var(--space-4);
  color: rgba(246, 243, 220, 0.92);
  width: 3rem;
  height: 3rem;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: linear-gradient(
    155deg,
    rgba(240, 210, 147, 0.2) 0%,
    rgba(232, 153, 140, 0.18) 48%,
    rgba(73, 79, 126, 0.3) 100%
  );
  border: 1px solid rgba(246, 243, 220, 0.2);
  box-shadow:
    0 10px 24px rgba(16, 22, 42, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.process-step__icon-svg {
  width: 1.72rem;
  height: 1.72rem;
  display: block;
  filter: drop-shadow(0 2px 4px rgba(16, 22, 42, 0.2));
}

.section--light .process-step .process-step__icon,
section.section--spotlight + section.section--light .process-step .process-step__icon {
  color: var(--navy);
  border-color: rgba(33, 50, 88, 0.22);
  box-shadow:
    0 10px 24px rgba(33, 50, 88, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.process-step:hover .process-step__icon,
.process-step:focus-within .process-step__icon {
  transform: translateY(-2px) scale(1.03);
  border-color: rgba(33, 50, 88, 0.34);
  box-shadow:
    0 14px 30px rgba(33, 50, 88, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.process-step__heading {
  margin: 0 0 var(--space-3);
  font-size: clamp(1.05rem, 1.85vw, 1.3rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.3;
}

.process-number {
  font-size: 0.75rem;
  letter-spacing: 0.3em;
  color: var(--yellow);
}

.cta-panel {
  background: linear-gradient(130deg, rgba(240, 210, 147, 0.25), rgba(232, 153, 140, 0.25));
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  border: 1px solid rgba(246, 243, 220, 0.18);
  box-shadow: var(--shadow-mid);
}

/* Site-wide: navy footer; canvas starfield injected by main.js (same logic as home hero) */
.footer {
  position: relative;
  z-index: 5;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(1rem, 2.4vw, 1.35rem) 0;
  background: var(--navy);
  color: var(--cream);
}

.footer-starfield {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.footer-starfield__canvas {
  display: block;
  width: 100%;
  height: 100%;
  vertical-align: top;
}

.footer > .container {
  position: relative;
  z-index: 1;
}

/* Tight column: width follows logo / nav / bottom row, capped like other .container */
.footer > .container.footer-stack {
  width: fit-content;
  max-width: min(1200px, 94vw);
  margin-inline: auto;
}

/* Beats body.page-* p / .eyebrow so light pages keep the same footer palette as About */
body .footer p {
  color: rgba(246, 243, 220, 0.92);
}

body .footer .eyebrow {
  color: rgba(246, 243, 220, 0.72);
}

@media (prefers-reduced-motion: reduce) {
  .footer-starfield__canvas {
    opacity: 0.92;
  }
}

.footer a {
  color: rgba(246, 243, 220, 0.95);
}

.footer a:hover {
  color: #fff;
}

.footer-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.6rem, 1.6vw, 0.95rem);
  text-align: center;
}

.footer-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}

.footer-brand__logo {
  height: 42px;
  width: auto;
  display: block;
  margin-bottom: 0.8rem;
}

.footer-brand__tagline {
  margin: 0;
  padding: 0;
  max-width: 26rem;
  line-height: 1.5;
}

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-3) clamp(var(--space-4), 4vw, var(--space-6));
}

.footer-nav a {
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: rgba(246, 243, 220, 0.88);
  text-decoration: none;
}

.footer-nav a:hover {
  color: #fff;
}

.footer-rule {
  width: 100%;
  height: 0;
  margin: 0.1rem 0 0;
  border: none;
  border-top: 1px dotted rgba(246, 243, 220, 0.28);
}

.footer-bottom {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2) var(--space-4);
  padding-top: 0.05rem;
}

.footer-copyright {
  margin: 0;
  padding: 0;
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  color: rgba(246, 243, 220, 0.58);
  text-align: left;
}

body .footer p.footer-copyright {
  color: rgba(246, 243, 220, 0.58);
}

.footer-social {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-left: auto;
}

.footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(246, 243, 220, 0.88);
  line-height: 0;
  border-radius: 6px;
  padding: 0.2rem;
}

.footer-social__link:hover {
  color: #fff;
}

.footer-social__icon {
  width: 1.35rem;
  height: 1.35rem;
  display: block;
}

@media (max-width: 520px) {
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }

  .footer-social {
    margin-left: 0;
  }
}

.intro-overlay {
  position: fixed;
  inset: 0;
  background: var(--navy);
  z-index: 50;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.intro-overlay.is-hidden {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.6s ease;
}

.intro-logo {
  width: min(980px, 92vw);
  animation: intro-float 5s ease-in-out infinite;
}

.intro-stars {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.intro-star {
  position: absolute;
  width: 8px;
  height: 8px;
  background: var(--yellow);
  border-radius: 50%;
  box-shadow: 0 0 12px var(--glow);
  animation: twinkle 3.4s ease-in-out infinite;
}

.intro-star:nth-child(1) { top: 20%; left: 30%; animation-delay: 0s; }
.intro-star:nth-child(2) { top: 30%; left: 60%; animation-delay: 0.6s; }
.intro-star:nth-child(3) { top: 50%; left: 45%; animation-delay: 1.2s; }
.intro-star:nth-child(4) { top: 65%; left: 28%; animation-delay: 1.8s; }
.intro-star:nth-child(5) { top: 55%; left: 70%; animation-delay: 2.4s; }

.intro-skip {
  position: absolute;
  bottom: 32px;
  right: 32px;
  padding: 8px 16px;
  border: 1px solid rgba(246, 243, 220, 0.3);
  border-radius: 999px;
  background: rgba(16, 22, 42, 0.5);
  color: var(--cream);
  cursor: pointer;
}

.intro-lock {
  overflow: hidden;
}

.portfolio-embed {
  border: 1px solid rgba(246, 243, 220, 0.16);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.portfolio-embed object {
  width: 100%;
  height: 70vh;
  background: rgba(16, 22, 42, 0.6);
}

/* Portfolio page — light canvas grid (hover alternates stacked cover art) */
body.page-portfolio .portfolio-page-title {
  font-size: clamp(2.5rem, 6vw, 4.25rem);
  font-weight: 700;
  line-height: 1.15;
  margin: 0 0 var(--space-6);
  text-align: center;
  color: var(--navy);
}

body.page-portfolio .portfolio-cover-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(14px, 2.5vw, 22px);
  max-width: 1100px;
  margin: 0 auto;
}

body.page-portfolio .portfolio-cover-grid__link {
  display: block;
  position: relative;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid rgba(33, 50, 88, 0.12);
  background: #fff;
  box-shadow: 0 6px 20px rgba(16, 22, 42, 0.07);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.4s ease,
    border-color 0.35s ease;
}

body.page-portfolio .portfolio-cover-grid__link[id] {
  scroll-margin-top: calc(var(--header-nav-max-depth) + 16px);
}

body.page-portfolio .portfolio-cover-grid__link:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 44px rgba(16, 22, 42, 0.12);
  border-color: rgba(33, 50, 88, 0.22);
}

body.page-portfolio .portfolio-cover-grid__img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  transition: opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Alt / hover image — stacked on top, hidden until hover */
body.page-portfolio .portfolio-cover-grid__img--alt {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left top;
  opacity: 0;
}

body.page-portfolio #lk-arts .portfolio-cover-grid__img--alt {
  object-position: center center;
}

body.page-portfolio #the-pro-co .portfolio-cover-grid__img--alt {
  object-position: center center;
}

body.page-portfolio #gatineau-paris .portfolio-cover-grid__img,
body.page-portfolio #gatineau-paris .portfolio-cover-grid__img--alt {
  object-position: center center;
}

body.page-portfolio .portfolio-cover-grid__link[href$="#freelance-lila"] .portfolio-cover-grid__img,
body.page-portfolio .portfolio-cover-grid__link[href$="#freelance-lila"] .portfolio-cover-grid__img--alt {
  object-position: center center;
}

body.page-portfolio .portfolio-cover-grid__link[href$="#freelance-craig"] .portfolio-cover-grid__img--alt {
  object-position: center center;
}

body.page-portfolio .portfolio-cover-grid__link:hover .portfolio-cover-grid__img--alt,
body.page-portfolio .portfolio-cover-grid__link:focus-visible .portfolio-cover-grid__img--alt {
  opacity: 1;
}

body.page-portfolio .portfolio-cover-grid__link:hover .portfolio-cover-grid__img:not(.portfolio-cover-grid__img--alt),
body.page-portfolio .portfolio-cover-grid__link:focus-visible .portfolio-cover-grid__img:not(.portfolio-cover-grid__img--alt) {
  opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
  body.page-portfolio .portfolio-cover-grid__img {
    transition: none;
  }
}

body.page-portfolio .portfolio-paper-copy {
  text-align: center;
}

body.page-portfolio .portfolio-paper-copy__title {
  font-size: clamp(1.65rem, 3.5vw, 2.5rem);
  font-weight: 700;
  margin: 0 0 var(--space-4);
  line-height: 1.15;
  color: var(--navy);
}

body.page-portfolio .portfolio-paper-copy .btn-primary {
  color: var(--navy);
}

@media (max-width: 860px) {
  body.page-portfolio .portfolio-cover-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 520px) {
  body.page-portfolio .portfolio-cover-grid {
    grid-template-columns: 1fr;
  }
}

/* Case study (project) detail pages */
main > article > section.section:first-of-type {
  position: relative;
  isolation: isolate;
  background: #213258;
  border-bottom: 1px solid rgba(246, 243, 220, 0.12);
  margin-top: calc(-1 * (var(--header-nav-max-depth) + 12px));
  padding-top: calc(var(--header-nav-max-depth) + 12px + var(--space-8));
}

main > article > section.section:first-of-type:has(.case-study__hero) {
  overflow: hidden;
}

.case-study__hero-starfield {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(58%, 680px);
  pointer-events: none;
  z-index: 0;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 32%);
  mask-image: linear-gradient(to right, transparent, #000 32%);
}

.case-study__hero-starfield__canvas {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  vertical-align: top;
}

main > article > section.section:first-of-type:has(.case-study__hero) > .container {
  position: relative;
  z-index: 1;
}

@media (prefers-reduced-motion: reduce) {
  .case-study__hero-starfield__canvas {
    opacity: 0.92;
  }
}

/* Case study: bottom “All projects / Start a project” band */
main > article > section.section-tight:has(.hero-actions.hero-actions--center) {
  background: #213258;
  border-top: 1px solid rgba(246, 243, 220, 0.12);
  border-bottom: 1px solid rgba(246, 243, 220, 0.12);
}

.case-study__hero {
  max-width: 52rem;
}

.case-study__lede {
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  line-height: 1.55;
  color: rgba(246, 243, 220, 0.88);
}

.case-study__section {
  border-top: 1px solid rgba(246, 243, 220, 0.1);
}

/* Same frosted band as hero / site header (not the white “light” blocks) */
main > article > section.case-study__section:not(.case-study__section--light) {
  background: #213258;
  border-top-color: rgba(246, 243, 220, 0.12);
  border-bottom: 1px solid rgba(246, 243, 220, 0.12);
}

/* One continuous navy band: hero tint → first dark case band (same background) without a stacked hairline */
main > article > section.section:first-of-type:has(.case-study__hero)
  + section.case-study__section:not(.case-study__section--light) {
  border-top: none;
}

.case-study__section--light {
  background: #fff;
  color: var(--navy);
  border-color: rgba(33, 50, 88, 0.08);
}

.case-study__section--light .eyebrow {
  color: rgba(33, 50, 88, 0.62);
}

.case-study__section--light h2 {
  color: var(--navy);
}

.case-study__section--light h3 {
  color: var(--navy);
  font-size: clamp(1.35rem, 2.4vw, 1.75rem);
  line-height: 1.15;
  margin: 0 0 var(--space-4);
}

main > article > section.case-study__section:not(.case-study__section--light) h3 {
  color: rgba(246, 243, 220, 0.95);
  font-size: clamp(1.35rem, 2.4vw, 1.75rem);
  line-height: 1.15;
  margin: 0 0 var(--space-4);
}

.case-study__section--light p {
  color: rgba(33, 50, 88, 0.82);
}

/* LK Arts case study — structured gallery (hero, stacked duo, resin wide, poster + skeleton split, remnant row) */
body.page-lk-arts .case-study__grid--lk-arts-gallery {
  display: flex;
  flex-direction: column;
  gap: clamp(1.25rem, 3vw, 2rem);
}

body.page-lk-arts .case-study__grid--lk-arts-gallery > .case-study__lk-arts-row,
body.page-lk-arts .case-study__grid--lk-arts-gallery > .case-study__lk-arts-split,
body.page-lk-arts .case-study__lk-arts-split-top,
body.page-lk-arts .case-study__lk-arts-remnant-row {
  min-width: 0;
}

body.page-lk-arts .case-study__figure--lk-home-hero {
  margin-bottom: 0;
}

body.page-lk-arts .case-study__lk-arts-row--duo {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.75rem, 2vw, var(--space-4));
}

body.page-lk-arts .case-study__lk-arts-row--duo.case-study__lk-arts-row--stack {
  grid-template-columns: 1fr;
}

body.page-lk-arts .case-study__lk-arts-row--duo .case-study__figure,
body.page-lk-arts .case-study__grid--lk-arts-gallery > .case-study__figure--lk-gallery-tile {
  margin-bottom: 0;
}

/* Full container width inside padded .container — two-column top band + wide remnant row */
body.page-lk-arts .case-study__lk-arts-split {
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, var(--space-4));
  width: 100%;
}

body.page-lk-arts .case-study__lk-arts-split-top {
  display: grid;
  /* Resin column >50% width; skeleton narrower; row spans full padded .container */
  grid-template-columns: minmax(0, 1.9fr) minmax(min(240px, 32vw), 1fr);
  gap: clamp(0.75rem, 2vw, var(--space-4));
  align-items: stretch;
  width: 100%;
}

body.page-lk-arts .case-study__lk-arts-split-top .case-study__figure {
  margin-bottom: 0;
  min-width: 0;
  min-height: 0;
}

body.page-lk-arts .case-study__lk-arts-remnant-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.75rem, 2vw, var(--space-4));
  width: 100%;
}

body.page-lk-arts .case-study__lk-arts-remnant-row .case-study__figure {
  margin-bottom: 0;
  min-width: 0;
}

body.page-lk-arts .case-study__lk-arts-remnant-row .case-study__figure img {
  width: 100%;
  height: auto;
}

/* Match resin + skeleton tile height in the top row */
body.page-lk-arts {
  --lk-arts-resin-skeleton-h: clamp(320px, min(58vw, 72vh), 720px);
}

body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-split-primary,
body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-skeleton-rail {
  display: flex;
  align-items: center;
  align-self: stretch;
  min-height: var(--lk-arts-resin-skeleton-h);
  height: var(--lk-arts-resin-skeleton-h);
  max-height: var(--lk-arts-resin-skeleton-h);
  box-sizing: border-box;
}

body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-split-primary {
  justify-content: flex-start;
  overflow: hidden;
  border-radius: var(--radius-sm);
}

body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-skeleton-rail {
  justify-content: flex-end;
  overflow: hidden;
  border-radius: var(--radius-sm);
}

body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-split-primary img,
body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-skeleton-rail img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-split-primary img {
  object-position: left center;
}

body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-skeleton-rail img {
  object-position: right center;
}

@media (max-width: 520px) {
  body.page-lk-arts .case-study__lk-arts-remnant-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  body.page-lk-arts .case-study__lk-arts-row--duo {
    grid-template-columns: 1fr;
  }

  body.page-lk-arts .case-study__lk-arts-split-top {
    grid-template-columns: 1fr;
  }

  body.page-lk-arts .case-study__lk-arts-split-top .case-study__figure--lk-skeleton-rail {
    max-width: min(420px, 100%);
    margin-inline: auto;
  }

  body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-split-primary img,
  body.page-lk-arts .case-study__lk-arts-split-top > .case-study__figure--lk-skeleton-rail img {
    object-position: center center;
  }
}

body.page-lk-arts .case-study__lk-arts-cta {
  margin-top: clamp(2rem, 5vw, 3rem);
  margin-bottom: 0;
}

/* First white case-study band (usually packaging): subtle navy speckles on the right */
.case-study__section--light.case-study__section--starfield-light {
  position: relative;
  isolation: isolate;
  overflow-x: hidden;
}

.case-study__light-starfield {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(58%, 680px);
  pointer-events: none;
  z-index: 0;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 36%);
  mask-image: linear-gradient(to right, transparent 0%, #000 36%);
}

.case-study__light-starfield__canvas {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  vertical-align: top;
}

.case-study__section--light.case-study__section--starfield-light > .container {
  position: relative;
  z-index: 1;
}

@media (prefers-reduced-motion: reduce) {
  .case-study__light-starfield__canvas {
    opacity: 0.9;
  }
}

.case-study__figure {
  margin: 0 0 var(--space-5);
}

.case-study__figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(246, 243, 220, 0.12);
}

.case-study__section--light .case-study__figure img {
  border-color: rgba(33, 50, 88, 0.1);
}

.case-study__figure--site-hero .case-study__site-hero {
  max-width: min(920px, 100%);
  margin-inline: auto;
}

/* Nurture digital section: composite mockup replaces faux laptop bezel + scroll strip */
.case-study__figure--site-hero.case-study__figure--nurture-responsive-mockup .case-study__site-hero img {
  filter: drop-shadow(0 20px 48px rgba(16, 22, 42, 0.16));
}

.case-study__laptop {
  filter: drop-shadow(0 20px 48px rgba(16, 22, 42, 0.2));
}

.case-study__laptop__bezel {
  position: relative;
  padding: clamp(10px, 2vw, 14px);
  padding-top: clamp(26px, 4.5vw, 34px);
  border-radius: 16px 16px 6px 6px;
  background:
    linear-gradient(158deg, rgba(255, 255, 255, 0.14) 0%, transparent 42%),
    linear-gradient(180deg, #4b5362 0%, #292e38 52%, #1f232d 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    inset 0 -1px 0 rgba(0, 0, 0, 0.35);
}

.case-study__laptop__camera {
  position: absolute;
  top: clamp(9px, 1.9vw, 12px);
  left: 50%;
  transform: translateX(-50%);
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 32%, rgba(94, 102, 116, 0.95), #14161c);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.12),
    0 0 0 3px rgba(12, 14, 18, 0.55);
}

.case-study__laptop__viewport {
  position: relative;
  container-type: inline-size;
  container-name: sn-laptop-view;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-radius: 6px;
  background:
    radial-gradient(ellipse 120% 80% at 50% -20%, rgba(255, 255, 255, 0.07), transparent 55%),
    #0c0e12;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.07),
    inset 0 -18px 32px rgba(0, 0, 0, 0.42);
}

.case-study__laptop__viewport .case-study__site-hero__still {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  border: none;
  border-radius: 0;
}

/* Homepage hero overlay (approximates live satinnaturel.com storefront hero) */
.case-study__sn-hero-overlay {
  pointer-events: none;
  position: absolute;
  z-index: 2;
  inset: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
  align-items: stretch;
  padding: clamp(0.35em, 3cqw, 0.95em) clamp(0.45em, 3.2cqw, 1em) clamp(0.5em, 3.5cqw, 1.1em);
  font-family: system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: clamp(6.5px, 1.65cqw, 11px);
  color: rgba(255, 255, 255, 0.97);
}

.case-study__sn-hero-overlay__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  min-height: 1.8em;
  text-shadow: none;
}

.case-study__sn-hero-overlay__toolbar-left {
  display: flex;
  align-items: center;
  gap: 0.45em;
  min-width: 0;
}

.case-study__sn-hero-overlay__burger {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.case-study__sn-hero-overlay__burger-svg {
  display: block;
  width: 1.85em;
  height: 1.85em;
}

.case-study__sn-hero-overlay__links {
  display: flex;
  flex-wrap: nowrap;
  gap: clamp(0.25em, 2cqw, 0.75em);
  min-width: 0;
}

.case-study__sn-hero-overlay__link {
  white-space: nowrap;
  letter-spacing: 0.1em;
  font-size: clamp(5px, 1.2cqw, 7px);
  font-weight: 500;
  opacity: 0.94;
  text-transform: uppercase;
  text-shadow: none;
}

.case-study__sn-hero-overlay__utilities {
  display: flex;
  align-items: center;
  gap: clamp(0.35em, 2.8cqw, 0.9em);
  flex-shrink: 0;
}

.case-study__sn-hero-overlay__uti {
  width: 1.9em;
  height: 1.9em;
  display: flex;
  align-items: center;
  justify-content: center;
}

.case-study__sn-hero-overlay__uti-svg {
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.93;
}

.case-study__sn-hero-overlay__middle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.15em;
}

.case-study__sn-hero-overlay__logo {
  display: block;
  width: clamp(112px, 30cqw, 220px);
  height: auto;
  mix-blend-mode: lighten;
  filter: brightness(1.06);
}

.case-study__sn-hero-overlay__bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45em;
  padding-bottom: 0.15em;
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.4),
    0 0 12px rgba(0, 0, 0, 0.2);
}

.case-study__sn-hero-overlay__cta {
  display: inline-block;
  padding: 0.45em 1.25em;
  border-radius: 999px;
  font-size: clamp(6.5px, 1.38cqw, 8.5px);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(252, 250, 245, 0.98);
  background: rgba(28, 32, 38, 0.88);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
}

.case-study__sn-hero-overlay__micro {
  margin: 0;
  font-size: clamp(6px, 1.32cqw, 8px);
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.38;
  text-align: center;
  max-width: 28em;
}

.case-study__sn-hero-overlay__scroll {
  display: block;
  width: 1.25em;
  height: 1.25em;
  margin-top: -0.08em;
  opacity: 0.88;
}

@container sn-laptop-view (max-width: 320px) {
  .case-study__sn-hero-overlay__links .case-study__sn-hero-overlay__link:last-child {
    display: none;
  }
}

.case-study__laptop__hinge {
  height: 7px;
  margin: -1px clamp(48px, 12%, 112px) 0;
  border-radius: 0 0 3px 3px;
  background: linear-gradient(90deg, #3d4450 0%, #697286 46%, #3d4450 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.case-study__laptop__base {
  margin-top: 0;
  margin-inline: clamp(-28px, -3.8vw, -12px);
  height: clamp(15px, 2.9vw, 22px);
  border-radius: 0 0 12px 12px;
  background:
    linear-gradient(
      175deg,
      #e4e9f1 0%,
      #c7cedc 38%,
      #9eabbc 92%,
      #7f8a9e 100%
    );
  box-shadow:
    0 3px 0 rgba(255, 255, 255, 0.45) inset,
    0 12px 24px rgba(16, 22, 42, 0.18);
}

/* Stacked storefront frames inside laptop (auto-scroll demo; replaces blocked iframes) */
.case-study__laptop__viewport .case-study__site-scroll-rail {
  position: absolute;
  inset: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  scroll-behavior: auto;
}

.case-study__site-scroll-rail::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}

.case-study__site-scroll-rail img {
  width: 100%;
  height: auto;
  display: block;
  border: none;
  border-radius: 0;
  vertical-align: top;
}

.case-study__grid {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  margin-bottom: var(--space-5);
}

.case-study__grid--thumbs {
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-3);
}

.case-study__grid--thumbs .case-study__figure {
  margin-bottom: 0;
}

.case-study__grid--nested {
  margin-bottom: 0;
}

/* Salon Privé: 2×3 grid; square tiles, image fills via cover */
.case-study__grid--salon-event-mosaic {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(3, auto);
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.case-study__grid--salon-event-mosaic .case-study__figure {
  margin-bottom: 0;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: var(--radius-sm);
}

.case-study__grid--salon-event-mosaic .case-study__figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

@media (max-width: 640px) {
  .case-study__grid--salon-event-mosaic {
    grid-template-columns: 1fr;
    grid-template-rows: none;
  }
}

.case-study__grid--freelance-decree-quad {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

.case-study__grid--freelance-lila-split {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: auto auto;
  align-items: start;
  gap: var(--space-3);
}

.case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-top-trio {
  grid-column: 1 / -1;
  grid-row: 1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

.case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-side-thumbs {
  grid-column: 1;
  grid-row: 2;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-3);
  min-width: 0;
}

.case-study__grid--freelance-lila-split .case-study__figure--freelance-lila-ebc {
  grid-column: 2 / -1;
  grid-row: 2;
  margin-bottom: 0;
  min-width: 0;
  width: 100%;
  max-width: 94%;
  justify-self: start;
}

.case-study__grid--freelance-lila-split .case-study__figure--freelance-lila-ebc img {
  width: 100%;
  height: auto;
}

.case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-top-trio .case-study__figure,
.case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-side-thumbs .case-study__figure {
  margin-bottom: 0;
  aspect-ratio: 1;
}

.case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-top-trio .case-study__figure img,
.case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-side-thumbs .case-study__figure img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.case-study__grid--freelance-craig-trio {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
}

@media (max-width: 900px) {
  .case-study__grid--freelance-lila-split {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-top-trio {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  .case-study__grid--freelance-lila-split .case-study__grid--freelance-lila-side-thumbs {
    grid-column: 1 / -1;
    grid-row: auto;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-2);
    order: 1;
  }

  .case-study__grid--freelance-lila-split .case-study__figure--freelance-lila-ebc {
    grid-column: 1 / -1;
    grid-row: auto;
    max-width: 100%;
    justify-self: stretch;
    order: 2;
  }
}

@media (max-width: 720px) {
  .case-study__grid--freelance-decree-quad {
    grid-template-columns: 1fr;
  }

  .case-study__grid--freelance-craig-trio {
    grid-template-columns: 1fr;
  }
}

.case-study__grid--gatineau-dtc-gifs {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-5);
  margin-bottom: 0;
}

.case-study__grid--gatineau-dtc-gifs .case-study__figure {
  margin-bottom: 0;
}

.case-study__grid--gatineau-dtc-gifs .case-study__figure img {
  width: 100%;
  height: auto;
}

@media (max-width: 560px) {
  .case-study__grid--gatineau-dtc-gifs {
    grid-template-columns: 1fr;
  }
}

.case-study__grid--gatineau-events-trio {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.case-study__grid--gatineau-events-trio .case-study__figure {
  margin-bottom: 0;
}

@media (max-width: 768px) {
  .case-study__grid--gatineau-events-trio {
    grid-template-columns: 1fr;
  }
}

.case-study__stack--proco-trio {
  margin-bottom: var(--space-5);
}

.case-study__grid--proco-ebc-row {
  grid-template-columns: minmax(0, min(100%, 400px)) minmax(0, 1fr);
  align-items: start;
  gap: var(--space-5);
}

.case-study__figure--proco-ebc {
  margin-bottom: 0;
}

.case-study__figure--proco-ebc img {
  width: 100%;
  max-width: min(100%, 380px);
  margin-inline: auto;
  display: block;
}

.case-study__grid--proco-tiles {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

.case-study__grid--proco-tiles .case-study__figure {
  margin-bottom: 0;
}

@media (min-width: 700px) {
  .case-study__grid--proco-tiles {
    gap: var(--space-5);
  }

  .case-study__grid--proco-tiles .case-study__figure img {
    border-radius: var(--radius-sm);
  }
}

@media (max-width: 900px) {
  .case-study__grid--proco-ebc-row {
    grid-template-columns: 1fr;
  }

  .case-study__figure--proco-ebc img {
    max-width: min(420px, 100%);
  }
}

.case-study__stack--digital-amazon {
  margin-bottom: var(--space-5);
}

.case-study__stack--digital-amazon .case-study__grid--digital-pdp {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

/* Alpha Foods: full-width PDP trio, then vertical thumbs left + overview */
body.page-alpha-foods .case-study__stack--alpha-pdp-overview-split.case-study__stack--digital-amazon {
  margin-bottom: var(--space-5);
}

body.page-alpha-foods .case-study__alpha-pdp-mosaic {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

body.page-alpha-foods .case-study__alpha-pdp-body {
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2.8vw, 1.75rem);
  align-items: stretch;
  min-width: 0;
}

body.page-alpha-foods .case-study__alpha-pdp-top-products {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  width: 100%;
}

body.page-alpha-foods .case-study__alpha-pdp-top-products .case-study__figure--alpha-pdp-top-products-item {
  margin: 0;
  width: 100%;
  aspect-ratio: 1;
}

body.page-alpha-foods .case-study__alpha-pdp-top-products .case-study__figure--alpha-pdp-top-products-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body.page-alpha-foods .case-study__alpha-pdp-overview-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
  align-items: start;
  min-width: 0;
}

body.page-alpha-foods .case-study__figure--alpha-overview-main {
  grid-column: 2 / -1;
  margin: 0;
  min-width: 0;
  width: 100%;
  max-width: 94%;
  justify-self: start;
}

body.page-alpha-foods .case-study__figure--alpha-overview-main img {
  width: 100%;
  height: auto;
}

body.page-alpha-foods .case-study__alpha-pdp-overview-row .case-study__alpha-pdp-overview-thumbs {
  display: grid;
  grid-column: 1;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  align-items: stretch;
  align-self: start;
  min-width: 0;
}

body.page-alpha-foods .case-study__alpha-pdp-overview-row .case-study__alpha-pdp-overview-thumbs .case-study__figure--alpha-pdp-overview-thumb {
  margin: 0;
  width: 100%;
  aspect-ratio: 1;
}

body.page-alpha-foods .case-study__alpha-pdp-overview-row .case-study__alpha-pdp-overview-thumbs .case-study__figure--alpha-pdp-overview-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

@media (max-width: 680px) {
  body.page-alpha-foods .case-study__alpha-pdp-overview-row {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  body.page-alpha-foods .case-study__alpha-pdp-overview-row .case-study__alpha-pdp-overview-thumbs {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-2);
  }

  body.page-alpha-foods .case-study__figure--alpha-overview-main {
    grid-column: 1 / -1;
    max-width: 100%;
    justify-self: stretch;
  }
}

@media (max-width: 520px) {
  body.page-alpha-foods .case-study__alpha-pdp-top-products {
    gap: var(--space-2);
  }

  .case-study__stack--digital-amazon .case-study__grid--digital-pdp {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Satin Naturel Amazon: PDP thumbnails 1 column (~1/3) + tall A+ art (~2/3); extra PDP tiles under A+ strip */
.case-study__amazon-a-plus-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
  gap: var(--space-4);
  align-items: start;
}

.case-study__amazon-a-plus-split__aplus-column {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 0;
}

.case-study__amazon-a-plus-split .case-study__figure--amazon-a-desktop {
  margin-bottom: 0;
  isolation: isolate;
  filter: none;
}

.case-study__amazon-pdp-under-aplus {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
  align-items: start;
}

.case-study__amazon-pdp-under-aplus > .case-study__figure:only-child {
  grid-column: 1 / -1;
}

.case-study__amazon-pdp-under-aplus .case-study__figure {
  margin-bottom: 0;
}

.case-study__amazon-a-plus-split .case-study__grid--digital-pdp {
  grid-template-columns: minmax(0, 1fr);
  margin-bottom: 0;
}

.case-study__amazon-a-plus-split .case-study__figure--amazon-a-desktop .case-study__aplus-base-stack {
  width: 100%;
}

/* Nurture: PDP tiles continue under PT05; opaque white behind stitched A+ header (PNG transparency) */
.nurture-amazon-split .case-study__pdp-tail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
  width: 100%;
}

.nurture-amazon-split .case-study__pdp-tail-grid > .case-study__figure {
  margin-bottom: 0;
}

.nurture-amazon-split .case-study__pdp-tail-grid > .case-study__figure:nth-child(3) {
  grid-column: 1 / -1;
}

.nurture-amazon-split .case-study__pdp-tail-grid > .case-study__figure:only-child {
  grid-column: 1 / -1;
}

@media (max-width: 520px) {
  .nurture-amazon-split .case-study__pdp-tail-grid {
    grid-template-columns: 1fr;
  }

  .nurture-amazon-split .case-study__pdp-tail-grid > .case-study__figure:nth-child(3) {
    grid-column: 1;
  }
}

.nurture-amazon-split .case-study__figure--amazon-a-desktop,
.nurture-amazon-split .case-study__aplus-carousel-host,
.nurture-amazon-split .case-study__aplus-base-stack {
  background-color: #ffffff;
}

.nurture-amazon-split .case-study__aplus-header-sheet {
  background-color: #ffffff;
}

.nurture-amazon-split .case-study__aplus-header-sheet .case-study__aplus-slice {
  background-color: #ffffff;
}

.nurture-amazon-split .case-study__aplus-base-stack .case-study__amazon-pdp-under-aplus--nurture-below-reviews {
  margin-top: var(--space-4);
  width: 100%;
}

/* Stitched desktop A+: equal-width slices; only the carousel slot crossfades (JS + .is-active) */
.case-study__aplus-base-stack {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 0;
  line-height: 0;
  filter: none;
}

.case-study__aplus-base-stack > .case-study__aplus-slice {
  display: block;
  width: 100%;
  height: auto;
}

/* Optional white sheet behind stitched A+ header halves (transparency / export letterboxing) */
.case-study__aplus-header-sheet {
  display: flex;
  flex-direction: column;
  gap: 0;
  line-height: 0;
  background-color: #ffffff;
}

.case-study__aplus-header-sheet .case-study__aplus-slice {
  display: block;
  width: 100%;
  height: auto;
}

.case-study__grid--nurture-leadgen {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-5);
  margin-bottom: 0;
}

@media (max-width: 900px) {
  .case-study__grid--nurture-leadgen {
    grid-template-columns: 1fr;
  }
}

/* Nurture case study: single composite Instagram / feed mock */
.case-study__figure--nurture-social-hero {
  max-width: min(1024px, 100%);
  margin-inline: auto;
}

.case-study__section--light .case-study__figure--nurture-social-hero img {
  box-shadow:
    0 14px 44px rgba(33, 50, 88, 0.1),
    0 4px 12px rgba(33, 50, 88, 0.05);
}

/* Nurture: PDP+A+ listing alongside Brand Store capture */
.case-study__nurture-listing-store-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(248px, min(36vw, 400px));
  gap: var(--space-5);
  align-items: start;
}

.case-study__nurture-listing-store-row__listing {
  min-width: 0;
}

.case-study__nurture-listing-store-row__store h3:first-of-type {
  margin-top: 0;
}

.case-study__nurture-listing-store-row__store .case-study__figure--nurture-amazon-brand-store {
  max-width: 100%;
  margin-inline: 0;
  margin-bottom: 0;
}

@media (max-width: 960px) {
  .case-study__nurture-listing-store-row {
    grid-template-columns: 1fr;
  }

  .case-study__nurture-listing-store-row__store {
    max-width: min(400px, 100%);
    margin-inline: auto;
  }
}

/* Nurture: tall Amazon Brand Store capture, capped like a device frame */
.case-study__figure--nurture-amazon-brand-store {
  max-width: min(380px, 100%);
  margin-inline: auto;
  margin-bottom: var(--space-5);
}

.case-study__figure--nurture-amazon-brand-store img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
}

/* Nurture: Brand Store story — wide frames, minimal chrome so swipe feels like the live carousel */
.case-study__slideshow--nurture-brand-story .case-study__slideshow-slide {
  padding: var(--space-2) var(--space-3);
}

.case-study__slideshow--nurture-brand-story .case-study__slideshow-viewport {
  border-radius: var(--radius-sm);
  cursor: grab;
}

.case-study__slideshow--nurture-brand-story .case-study__slideshow-viewport:active {
  cursor: grabbing;
}

.case-study__figure--ocg-brand-wide {
  margin: 0 0 clamp(1rem, 2.6vw, 1.65rem);
}

.case-study__figure--ocg-brand-wide:last-child {
  margin-bottom: 0;
}

.case-study__figure--ocg-brand-wide:not(:has(.case-study__ocg-brand-flip-slot)) img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  display: block;
}

.case-study__ocg-brand-flip-slot {
  position: relative;
  width: 100%;
  aspect-ratio: 1024 / 436;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: rgba(246, 243, 220, 0.05);
  border: 1px solid rgba(246, 243, 220, 0.12);
  box-sizing: border-box;
  perspective: 1180px;
  transform-style: preserve-3d;
}

.case-study__ocg-brand-variant {
  border: none;
  pointer-events: none;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center top;
  opacity: 0;
  visibility: hidden;
  backface-visibility: hidden;
  transform: rotateY(-22deg) scale(0.98);
  transition:
    opacity 0.5s ease-in-out,
    visibility 0.5s ease-in-out,
    transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.case-study__ocg-brand-variant.is-active {
  opacity: 1;
  visibility: visible;
  transform: rotateY(0deg) scale(1);
}

@media (prefers-reduced-motion: reduce) {
  .case-study__ocg-brand-variant {
    transition: none;
    transform: none;
  }

  .case-study__ocg-brand-variant.is-active {
    transform: none;
  }
}

.case-study__grid--ocg-hero-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.65rem, 2vw, 1.25rem);
  margin: clamp(1.25rem, 3.2vw, 2rem) 0 clamp(1.5rem, 3.8vw, 2.75rem);
  align-items: end;
}

.case-study__grid--ocg-hero-row .case-study__figure {
  margin: 0;
}

.case-study__grid--ocg-hero-row img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  display: block;
}

@media (max-width: 760px) {
  .case-study__grid--ocg-hero-row {
    grid-template-columns: 1fr;
  }
}

.case-study__aplus-carousel-slot {
  position: relative;
  width: 100%;
  aspect-ratio: 2048 / 838;
  flex-shrink: 0;
  background-color: #e9dcdf;
}

.case-study__aplus-carousel-slot .case-study__aplus-variant {
  pointer-events: none;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center top;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.45s ease-in-out;
}

.case-study__aplus-carousel-slot .case-study__aplus-variant.is-active {
  opacity: 1;
  visibility: visible;
}

@media (prefers-reduced-motion: reduce) {
  .case-study__aplus-carousel-slot .case-study__aplus-variant {
    transition: none;
  }
}

.case-study__aplus-carousel-host {
  position: relative;
  display: block;
  filter: none;
}

/* Pixel-faithful A+ art: no filters/masks/blend stacks on images (incl. range slice); carousel keeps opacity tween */
.case-study__figure--amazon-a-desktop .case-study__aplus-slice,
.case-study__figure--amazon-a-desktop .case-study__aplus-carousel-slot .case-study__aplus-variant {
  border: none;
  border-radius: 0;
  box-shadow: none;
  filter: none;
  -webkit-filter: none;
  mix-blend-mode: normal;
}

.case-study__figure--amazon-a-desktop .case-study__aplus-slice {
  opacity: 1;
}

@media (max-width: 900px) {
  .case-study__amazon-a-plus-split {
    grid-template-columns: 1fr;
  }

  .case-study__amazon-a-plus-split .case-study__grid--digital-pdp {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .case-study__amazon-a-plus-split .case-study__grid--digital-pdp {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.case-study__grid--digital-split {
  grid-template-columns: minmax(0, 1fr) minmax(260px, 0.9fr);
  align-items: start;
}

.case-study__grid--digital-split .case-study__grid--nested.case-study__grid--thumbs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 900px) {
  .case-study__grid--digital-split {
    grid-template-columns: 1fr;
  }

  .case-study__grid--digital-split .case-study__grid--nested.case-study__grid--thumbs {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  }
}

.case-study__stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.case-study__stack .case-study__figure {
  margin-bottom: 0;
}

.case-study__credit {
  font-style: italic;
  font-size: 0.95rem;
  color: rgba(246, 243, 220, 0.65);
  margin-top: var(--space-3);
}

.case-study__section--light .case-study__credit {
  color: rgba(33, 50, 88, 0.6);
}

.case-study__divider {
  border: none;
  border-top: 1px solid rgba(246, 243, 220, 0.12);
  margin: var(--space-6) 0;
}

.case-study__section--light .case-study__divider {
  border-top-color: rgba(33, 50, 88, 0.12);
}

.case-study__embed {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  max-height: min(70vh, 520px);
  margin: 0 0 var(--space-4);
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid rgba(246, 243, 220, 0.12);
  background: rgba(3, 7, 17, 0.5);
}

.case-study__section--light .case-study__embed {
  border-color: rgba(33, 50, 88, 0.12);
}

.case-study__embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.case-study__figcaption {
  font-size: 0.9rem;
  line-height: 1.45;
  color: rgba(246, 243, 220, 0.72);
  margin-top: var(--space-2);
}

.case-study__section--light .case-study__figcaption {
  color: rgba(33, 50, 88, 0.72);
}

.case-study__figure--flush {
  margin-bottom: var(--space-4);
}

.case-study__figure--gallery {
  cursor: zoom-in;
}

.case-study__figure--gallery:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 3px;
}

.case-study__section--light .case-study__figure--gallery:focus-visible {
  outline-color: rgba(33, 50, 88, 0.85);
}

/* Case study: lightbox for PDP / thumbnail grids */
.case-study-lightbox {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  box-sizing: border-box;
}

.case-study-lightbox[hidden] {
  display: none !important;
}

.case-study-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 14, 28, 0.9);
  cursor: pointer;
}

.case-study-lightbox__panel {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  width: min(96vw, 1100px);
  max-height: min(92vh, 900px);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: rgba(21, 38, 68, 0.96);
  border: 1px solid rgba(246, 243, 220, 0.14);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
  color: var(--cream);
}

.case-study-lightbox__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-shrink: 0;
}

.case-study-lightbox__counter {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(246, 243, 220, 0.75);
}

.case-study-lightbox__close {
  flex-shrink: 0;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(246, 243, 220, 0.35);
  background: transparent;
  color: var(--cream);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
}

.case-study-lightbox__close:hover {
  background: rgba(246, 243, 220, 0.08);
}

.case-study-lightbox__close:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 2px;
}

.case-study-lightbox__stage {
  display: flex;
  align-items: stretch;
  gap: var(--space-2);
  min-height: 0;
  flex: 1;
}

.case-study-lightbox__nav {
  flex: 0 0 auto;
  align-self: center;
  width: 2.5rem;
  min-height: 3rem;
  padding: 0;
  border: 1px solid rgba(246, 243, 220, 0.28);
  border-radius: var(--radius-sm);
  background: rgba(3, 7, 17, 0.45);
  color: var(--cream);
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
}

.case-study-lightbox__nav:hover {
  background: rgba(246, 243, 220, 0.1);
}

.case-study-lightbox__nav:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 2px;
}

.case-study-lightbox__viewport {
  flex: 1;
  min-width: 0;
  min-height: 0;
  max-height: min(72vh, 720px);
  overflow: auto;
  border-radius: var(--radius-sm);
  background: rgba(3, 7, 17, 0.35);
  -webkit-overflow-scrolling: touch;
}

.case-study-lightbox__viewport:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 2px;
}

.case-study-lightbox__viewport img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
}

.case-study-lightbox__hint {
  margin: 0;
  flex-shrink: 0;
  font-size: 0.8rem;
  line-height: 1.4;
  color: rgba(246, 243, 220, 0.55);
  text-align: center;
}

@media (max-width: 640px) {
  .case-study-lightbox__viewport {
    max-height: min(62vh, 560px);
  }

  .case-study-lightbox__nav {
    width: 2rem;
    min-height: 2.5rem;
    font-size: 1.45rem;
  }

  .case-study-lightbox__hint {
    display: none;
  }
}

/* Case study: horizontal scroll-snap slideshow */
.case-study__slideshow {
  margin: 0 0 var(--space-5);
}

.case-study__slideshow-viewport {
  display: flex;
  align-items: flex-start;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  gap: 0;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(33, 50, 88, 0.12);
  background: rgba(33, 50, 88, 0.04);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(33, 50, 88, 0.35) transparent;
}

.case-study__section:not(.case-study__section--light) .case-study__slideshow-viewport {
  border-color: rgba(246, 243, 220, 0.12);
  background: rgba(3, 7, 17, 0.35);
  scrollbar-color: rgba(246, 243, 220, 0.35) transparent;
}

.case-study__slideshow-viewport:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 2px;
}

.case-study__slideshow-slide {
  flex: 0 0 100%;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  min-width: 0;
  box-sizing: border-box;
  padding: var(--space-4);
  margin: 0;
}

.case-study__slideshow-slide img {
  width: 100%;
  height: auto;
  display: block;
}

/* Portrait / tall assets: cap height so one slide does not balloon the whole carousel */
.case-study__slideshow-slide--iconography {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.case-study__slideshow-slide--iconography img {
  width: auto;
  max-width: 100%;
  max-height: min(42vw, 440px);
  height: auto;
  object-fit: contain;
}

.case-study__slideshow-slide.case-study__figure--flush {
  margin-bottom: 0;
}

.case-study__slideshow-hint {
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(33, 50, 88, 0.55);
  margin: 0 0 var(--space-3);
}

.case-study__section:not(.case-study__section--light) .case-study__slideshow-hint {
  color: rgba(246, 243, 220, 0.55);
}

.case-study__slideshow-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.case-study__slideshow-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(33, 50, 88, 0.2);
  background: rgba(255, 255, 255, 0.85);
  color: var(--navy);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.case-study__slideshow-btn:hover {
  background: #fff;
  border-color: rgba(33, 50, 88, 0.35);
}

.case-study__section:not(.case-study__section--light) .case-study__slideshow-btn {
  border-color: rgba(246, 243, 220, 0.25);
  background: rgba(26, 39, 70, 0.65);
  color: var(--cream);
}

.case-study__section:not(.case-study__section--light) .case-study__slideshow-btn:hover {
  background: rgba(26, 39, 70, 0.9);
  border-color: rgba(246, 243, 220, 0.4);
}

@media (prefers-reduced-motion: reduce) {
  .case-study__slideshow-viewport {
    scroll-behavior: auto;
  }
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
  row-gap: var(--space-5);
}

.hero-card form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.hero-card form > .form-grid + div {
  margin-top: var(--space-4);
}

label {
  display: block;
  font-size: 0.85rem;
  margin-bottom: var(--space-2);
}

label[for="details"] {
  margin-bottom: var(--space-4);
}

input,
textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(246, 243, 220, 0.2);
  background: rgba(16, 22, 42, 0.6);
  color: var(--cream);
  font-family: inherit;
}

textarea {
  min-height: 140px;
  resize: vertical;
}

@keyframes hero-cosmic-video-drift {
  0% {
    object-position: 44% 42%;
  }
  50% {
    object-position: 56% 54%;
  }
  100% {
    object-position: 42% 48%;
  }
}

@keyframes hero-cosmic-drift {
  0% {
    background-position: 0% 50%, 100% 38%, 52% 78%, 0 0;
  }
  25% {
    background-position: 28% 44%, 88% 46%, 48% 72%, 70px 55px;
  }
  50% {
    background-position: 52% 58%, 72% 34%, 58% 64%, 140px 90px;
  }
  75% {
    background-position: 78% 42%, 18% 54%, 38% 32%, 190px 35px;
  }
  100% {
    background-position: 100% 44%, 0% 52%, 46% 26%, 160px 100px;
  }
}

@keyframes hero-cosmic-shimmer {
  0%,
  100% {
    filter: drop-shadow(0 0 26px rgba(72, 220, 255, 0.22)) hue-rotate(-10deg) saturate(1.02)
      brightness(1.02);
  }
  33% {
    filter: drop-shadow(0 0 34px rgba(100, 255, 215, 0.3)) hue-rotate(8deg) saturate(1.08)
      brightness(1.04);
  }
  66% {
    filter: drop-shadow(0 0 30px rgba(130, 190, 255, 0.26)) hue-rotate(14deg) saturate(1.05)
      brightness(1.03);
  }
}

@keyframes hero-cosmic-shimmer-tight {
  0%,
  100% {
    filter: drop-shadow(0 0 22px rgba(90, 170, 255, 0.2)) hue-rotate(-8deg) saturate(1.02);
  }
  50% {
    filter: drop-shadow(0 0 28px rgba(70, 240, 210, 0.28)) hue-rotate(10deg) saturate(1.06);
  }
}

@keyframes hero-vision-swirl {
  0% {
    background-position: 0% 50%, 100% 42%, 48% 78%, 50% 50%, 0 0;
  }
  25% {
    background-position: 82% 32%, 18% 58%, 64% 48%, 44% 62%, 55px 45px;
  }
  50% {
    background-position: 42% 70%, 68% 24%, 26% 86%, 55% 38%, 130px 95px;
  }
  75% {
    background-position: 15% 46%, 90% 64%, 72% 30%, 32% 68%, 195px 28px;
  }
  100% {
    background-position: 0% 50%, 100% 42%, 48% 78%, 50% 50%, 0 0;
  }
}

@keyframes hero-vision-nebula-shimmer {
  0%,
  100% {
    filter: drop-shadow(0 0 18px rgba(150, 120, 255, 0.38)) hue-rotate(-14deg) saturate(1.06)
      brightness(1.02);
  }
  33% {
    filter: drop-shadow(0 0 26px rgba(120, 190, 255, 0.42)) hue-rotate(12deg) saturate(1.12)
      brightness(1.05);
  }
  66% {
    filter: drop-shadow(0 0 22px rgba(200, 140, 255, 0.36)) hue-rotate(22deg) saturate(1.08)
      brightness(1.04);
  }
}

@keyframes hero-vision-twinkle {
  0%,
  100% {
    opacity: 1;
  }
  22% {
    opacity: 0.96;
  }
  38% {
    opacity: 1;
  }
  51% {
    opacity: 0.93;
  }
  68% {
    opacity: 1;
  }
  84% {
    opacity: 0.97;
  }
}

@keyframes home-starfield-twinkle-a {
  0%,
  100% {
    opacity: 0.2;
  }
  50% {
    opacity: 0.26;
  }
}

@keyframes home-starfield-twinkle-b {
  0%,
  100% {
    opacity: 0.13;
  }
  50% {
    opacity: 0.19;
  }
}

@keyframes home-starfield-twinkle-c {
  0%,
  100% {
    opacity: 0.085;
  }
  50% {
    opacity: 0.13;
  }
}

@keyframes home-starfield-drift {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-1.2%, -0.8%, 0);
  }
}

@keyframes intro-float {
  0% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
  100% { transform: translateY(0px); }
}

@keyframes float-slow {
  0% { transform: translateY(0px); }
  50% { transform: translateY(-12px); }
  100% { transform: translateY(0px); }
}

@keyframes grid-shift {
  0% { background-position: 0 0; }
  100% { background-position: 160px 160px; }
}

@keyframes ambient-drift {
  0% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(4%, -3%, 0); }
  100% { transform: translate3d(0, 0, 0); }
}

.reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 0.9s ease, transform 0.9s ease;
}

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

@keyframes twinkle {
  0%, 100% { opacity: 0.2; transform: scale(0.8); }
  50% { opacity: 1; transform: scale(1.2); }
}

@media (max-width: 860px) {
  .nav {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    max-height: none;
  }

  .nav-links {
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
    justify-content: flex-start;
  }

  .nav-links > a,
  .nav-dropdown__trigger {
    font-size: 0.8125rem;
  }

  .nav-dropdown__panel {
    right: auto;
    left: 0;
  }

  main {
    padding-top: calc(var(--header-pad) * 3 + var(--header-logo-h) + 40px);
  }

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

  .service-index {
    width: 54px;
    height: 54px;
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    scroll-behavior: auto !important;
    animation: none !important;
    transition: none !important;
  }

  .scroll-hint {
    display: none !important;
  }
}
