:root {
  --deep-teal: #18280e;
  --mid-teal: #3f7308;
  --warm-peach: #b2eb76;
  --peach-light: #f2dfac;
  --sky-blue: #f4faed;
  --sky-blue-dark: #d8e5ca;
  --sage-green: #baebc2;
  --sage-dark: #4a5b38;
  --warm-cream: #ffffff;
  --rich-brown: #090f05;
  --cream: var(--warm-cream);
  --cream-soft: #f4faed;
  --tint: #f0fae6;
  --green: var(--deep-teal);
  --green-dark: #090f05;
  --terracotta: var(--warm-peach);
  --terracotta-dark: #9dd861;
  --gold: #ebe46a;
  --ink: var(--rich-brown);
  --muted: #4a5b38;
  --soil: #331b09;
  --earth: #c9753d;
  --soft-line: rgba(9, 15, 5, 0.12);
  --white-line: rgba(255, 255, 255, 0.16);
  --shadow: 0 18px 40px rgba(9, 15, 5, 0.08);
  --display: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --serif: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Fluid type scale — clamp(mobile, viewport-fluid, desktop), spade.com style.
     Each token scales smoothly between a 375px and a 1440px viewport. */
  --fs-11: clamp(10px, calc(9.65px + 0.094vw), 11px);
  --fs-12: clamp(11px, calc(10.65px + 0.094vw), 12px);
  --fs-13: clamp(12px, calc(11.65px + 0.094vw), 13px);
  --fs-135: clamp(12.5px, calc(12.15px + 0.094vw), 13.5px);
  --fs-14: clamp(13px, calc(12.65px + 0.094vw), 14px);
  --fs-145: clamp(13px, calc(12.47px + 0.141vw), 14.5px);
  --fs-15: clamp(13.5px, calc(12.97px + 0.141vw), 15px);
  --fs-155: clamp(14px, calc(13.47px + 0.141vw), 15.5px);
  --fs-16: clamp(14.5px, calc(13.97px + 0.141vw), 16px);
  --fs-165: clamp(15px, calc(14.47px + 0.141vw), 16.5px);
  --fs-17: clamp(15.5px, calc(14.97px + 0.141vw), 17px);
  --fs-18: clamp(16px, calc(15.3px + 0.188vw), 18px);
  --fs-20: clamp(17px, calc(15.94px + 0.282vw), 20px);
  --fs-22: clamp(19px, calc(17.94px + 0.282vw), 22px);
  --fs-24: clamp(20px, calc(18.59px + 0.376vw), 24px);
  --fs-25: clamp(21px, calc(19.59px + 0.376vw), 25px);
  --fs-27: clamp(23px, calc(21.59px + 0.376vw), 27px);
  --fs-28: clamp(24px, calc(22.59px + 0.376vw), 28px);
  --fs-90: clamp(50px, calc(35.92px + 3.756vw), 90px);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  overflow-wrap: break-word;
}

body.menu-open {
  overflow: hidden;
}

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

[hidden] {
  display: none !important;
}

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

button,
a {
  -webkit-tap-highlight-color: transparent;
}

::selection {
  background: var(--terracotta);
  color: var(--ink);
}

.skip-link {
  background: var(--ink);
  color: #fff;
  left: 16px;
  padding: 10px 14px;
  position: fixed;
  top: 12px;
  transform: translateY(-140%);
  z-index: 999;
}

.skip-link:focus {
  transform: translateY(0);
}

.site-header {
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(9, 15, 5, 0.08);
  color: var(--ink);
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  transition: background 220ms ease, box-shadow 220ms ease, color 220ms ease;
  z-index: 100;
}

.site-header.is-scrolled,
.site-header.is-open {
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 8px 24px rgba(9, 15, 5, 0.04);
  color: var(--ink);
}

.nav {
  align-items: center;
  display: flex;
  gap: 24px;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 1320px;
  padding: 10px 32px;
}

.brand,
.footer-logo {
  align-items: center;
  display: inline-flex;
}

.brand {
  flex: none;
}

.brand-logo {
  border-radius: 50%;
  display: block;
  height: clamp(40px, 3vw, 46px);
  object-fit: cover;
  width: clamp(40px, 3vw, 46px);
}

.footer-brand-logo {
  border-radius: 50%;
  height: 46px;
  width: 46px;
}

.nav-links {
  align-items: center;
  display: flex;
  gap: 34px;
}

.nav-links > a:not(.button) {
  font-family: var(--mono);
  font-size: var(--fs-14);
  font-weight: 600;
}

.nav-links .button-primary {
  background: rgba(9, 15, 5, 0.06);
  color: var(--ink);
}

.nav-links .button-primary:hover {
  background: rgba(9, 15, 5, 0.1);
}

.nav-links > a:hover,
.mobile-menu a:hover {
  opacity: 0.72;
}

.menu-toggle {
  align-items: center;
  background: transparent;
  border: 0;
  color: currentColor;
  cursor: pointer;
  display: none;
  flex-direction: column;
  gap: 5px;
  height: 44px;
  justify-content: center;
  padding: 0;
  width: 44px;
}

.menu-toggle span {
  background: currentColor;
  display: block;
  height: 2px;
  transition: transform 180ms ease, opacity 180ms ease;
  width: 24px;
}

.menu-toggle[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}

.menu-toggle[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.mobile-menu {
  background: #fff;
  border-top: 1px solid var(--soft-line);
  color: var(--ink);
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 24px 22px;
}

.mobile-menu a:not(.button) {
  border-bottom: 1px solid rgba(9, 15, 5, 0.07);
  font-size: var(--fs-17);
  font-weight: 600;
  padding: 12px 4px;
}

.button {
  align-items: center;
  border-radius: 6px;
  display: inline-flex;
  font-family: var(--mono);
  font-size: var(--fs-15);
  font-weight: 600;
  letter-spacing: 0;
  justify-content: center;
  line-height: 1;
  min-height: 44px;
  padding: 13px 20px;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.button:hover {
  transform: scale(0.98);
}

.button-primary {
  background: var(--terracotta);
  color: var(--ink);
}

.button-primary:hover {
  background: var(--terracotta-dark);
}

.button-small {
  font-size: var(--fs-14);
  min-height: 34px;
  padding: 8px 14px;
}

.button-ghost,
.button-outline {
  background: rgba(255, 255, 255, 0.66);
  border: 1px solid rgba(9, 15, 5, 0.18);
  color: var(--ink);
}

.button-ghost:hover,
.button-outline:hover {
  background: rgba(9, 15, 5, 0.06);
}

.section-green .button-outline,
.final-cta .button-outline {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.28);
  color: #fff;
}

.section-green .button-outline:hover,
.final-cta .button-outline:hover {
  background: rgba(255, 255, 255, 0.12);
}

.section {
  border-top: 1px solid rgba(9, 15, 5, 0.08);
  padding: clamp(88px, 10vw, 148px) 0;
  position: relative;
}

.section-inner {
  margin: 0 auto;
  max-width: 1320px;
  padding: 0 32px;
  width: 100%;
}

.section-inner-narrow {
  max-width: 980px;
  text-align: center;
}

.section-cream {
  background: #fff;
}

.section-tint {
  background: var(--tint);
}

.section-green {
  background: var(--green-dark);
  color: #fff;
}

.hero {
  align-items: center;
  background: var(--green-dark);
  border-radius: 12px 12px 0 0;
  display: flex;
  margin: 66px clamp(18px, 1.85vw, 36px) 0;
  min-height: calc(100svh - 86px);
  overflow: hidden;
  position: relative;
}

.hero-bg-photo {
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: center;
  opacity: 0.72;
  position: absolute;
  width: 100%;
  z-index: 0;
}

.hero::before,
.hero::after {
  background: repeating-linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.42) 0,
    rgba(255, 255, 255, 0.42) 1px,
    transparent 1px,
    transparent 28px
  );
  bottom: 32px;
  content: "";
  opacity: 0.24;
  pointer-events: none;
  position: absolute;
  top: 96px;
  width: 18px;
  z-index: 2;
}

.hero::before {
  left: 0;
}

.hero::after {
  right: 0;
}

.hero-shade,
.hero-vignette {
  position: absolute;
}

.hero-shade {
  background:
    radial-gradient(circle at 72% 38%, rgba(178, 235, 118, 0.18), transparent 28%),
    linear-gradient(180deg, rgba(9, 15, 5, 0.56), rgba(9, 15, 5, 0.76));
  height: 100%;
  inset: 0;
  width: 100%;
  z-index: 1;
}

.hero-vignette {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px) 0 0 / 72px 72px,
    linear-gradient(0deg, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px) 0 0 / 72px 72px;
  height: 100%;
  inset: 0;
  opacity: 0.42;
  width: 100%;
  z-index: 1;
}

.hero-inner {
  padding-bottom: clamp(84px, 9vw, 138px);
  padding-top: clamp(84px, 8vw, 126px);
  position: relative;
  z-index: 3;
}

.hero-copy {
  color: #fff;
  margin: 0 auto;
  max-width: min(960px, 86vw);
  text-align: center;
}

.eyebrow {
  align-items: center;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: 8px;
  display: inline-flex;
  font-size: var(--fs-135);
  font-weight: 600;
  gap: 10px;
  line-height: 1;
  margin: 0 0 26px;
  padding: 9px 16px;
  text-transform: uppercase;
}

.eyebrow span {
  background: var(--gold);
  border-radius: 50%;
  height: 7px;
  width: 7px;
}

h1,
h2,
h3 {
  font-family: var(--display);
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0;
}

h1 {
  font-family: var(--display);
  font-size: clamp(44px, 4.4vw, 84px);
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.05;
}

.hero-lede {
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.45;
  margin: 34px auto 28px;
  max-width: 560px;
}

.hero .button-primary {
  background: var(--terracotta);
  color: var(--ink);
}

.hero .button-primary:hover {
  background: var(--terracotta-dark);
}

.hero .button-ghost {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.32);
  color: #fff;
}

.hero .button-ghost:hover {
  background: rgba(255, 255, 255, 0.18);
}

.hero-actions,
.cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}

.hero-note {
  color: rgba(255, 255, 255, 0.72);
  font-size: var(--fs-145);
  margin: 38px 0 0;
}

.section-heading {
  margin-bottom: clamp(44px, 5vw, 68px);
  margin-left: auto;
  margin-right: auto;
  max-width: 760px;
  text-align: center;
}

.section-kicker {
  color: var(--mid-teal);
  font-family: var(--mono);
  font-size: var(--fs-16);
  font-weight: 600;
  letter-spacing: 0;
  margin: 0 0 18px;
  text-transform: none;
}

.section-kicker::before {
  content: "[";
}

.section-kicker::after {
  content: "]";
}

.section-heading h2,
.split-heading h2,
.impact-grid h2,
.about-copy h2,
.final-cta h2 {
  font-family: var(--display);
  font-size: clamp(30px, 3vw, 44px);
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.section-heading p,
.split-heading > p,
.impact-grid p,
.about-copy p,
.final-cta p {
  color: var(--muted);
  font-size: clamp(17px, 1.6vw, 20px);
  line-height: 1.6;
  margin: 22px 0 0;
}

#challenge {
  background: #fcfff8;
  border-top-color: rgba(9, 15, 5, 0.08);
  padding: 160px 0 76px;
}

#challenge .section-inner {
  max-width: 1360px;
}

#challenge .section-heading {
  margin: 0 auto 128px;
  max-width: 1145px;
  text-align: center;
}

#challenge .section-kicker {
  color: var(--mid-teal);
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
  margin: 0 0 23px;
}

#challenge .section-heading h2 {
  color: var(--ink);
  font-family: var(--display);
  font-size: 44px;
  font-weight: 500;
  letter-spacing: -0.44px;
  line-height: 1.1;
}

#challenge .section-heading p {
  color: var(--muted);
  font-size: 20px;
  line-height: 1.6;
  margin: 16px auto 0;
  max-width: 1145px;
}

.stats-grid {
  align-items: stretch;
  background: transparent;
  border: 0;
  border-radius: 0;
  display: grid;
  gap: 34px;
  grid-auto-rows: minmax(262px, auto);
  grid-template-columns: repeat(12, minmax(0, 1fr));
  overflow: visible;
}

.stat-card {
  background: transparent;
  border: 0;
  border-radius: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  grid-column: span 3;
  justify-content: flex-start;
  min-height: 262px;
  padding: 42px;
  position: relative;
}

.stat-card::before,
.stat-card::after {
  content: "";
  height: 0;
  pointer-events: none;
  position: absolute;
  width: 0;
}

.stat-card::before {
  border-right: 13px solid transparent;
  border-top: 13px solid var(--ink);
  left: 0;
  top: 0;
}

.stat-card::after {
  border-bottom: 13px solid var(--ink);
  border-left: 13px solid transparent;
  bottom: 0;
  right: 0;
}

.stat-card-dark {
  background: var(--green);
  clip-path: polygon(18px 0, calc(100% - 18px) 0, 100% 18px, 100% calc(100% - 18px), calc(100% - 18px) 100%, 18px 100%, 0 calc(100% - 18px), 0 18px);
  color: #fff;
  gap: 79px;
  grid-column: span 6;
  grid-row: span 2;
  justify-content: center;
  min-height: 562px;
  padding: 58px;
}

.stat-card-dark::before,
.stat-card-dark::after {
  display: none;
}

.stat-card-accent {
  background: transparent;
  color: var(--ink);
  gap: 33px;
  grid-column: span 6;
  justify-content: center;
}

.stat-card-top {
  align-items: center;
  display: flex;
  gap: 14px;
}

.stat-label {
  color: inherit;
  font-family: var(--mono);
  font-size: var(--fs-11);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.2;
  margin: 0;
  opacity: 0.86;
  text-transform: uppercase;
}

.stat-stack {
  display: grid;
  gap: 48px;
}

.stat-stack p,
.stat-card p {
  margin: 0;
}

.stat-stack p {
  display: grid;
  gap: 16px;
}

.stat-stack strong,
.stat-value {
  color: var(--ink);
  display: block;
  font-family: var(--display);
  font-size: 56px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 0.9;
  white-space: nowrap;
}

.stat-card-dark .stat-stack strong {
  color: #fff;
  font-size: 96px;
  line-height: 1;
}

.stat-card-accent .stat-value {
  color: var(--ink);
  font-size: 60px;
  line-height: 0.9;
}

.stat-card-dark .stat-stack p:first-child strong {
  color: var(--terracotta);
}

.stat-stack span,
.stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  color: var(--muted);
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.5;
  max-width: 28ch;
  text-transform: uppercase;
}

.stat-stack span {
  margin-top: 0;
}

.stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  margin-top: 18px;
}

.stat-card > .icon-badge {
  margin-bottom: 36px;
}

.stat-card-dark .stat-stack span {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.88);
}

.stat-card-dark .stat-card-top .icon-badge {
  color: #fff;
}

.stat-card-dark .stat-label {
  font-size: 16px;
  line-height: 0.825;
}

.stat-card-dark .stat-stack p:last-child span {
  max-width: none;
  white-space: nowrap;
}

.stat-card-accent > div:not(.stat-card-top):not(.stat-stack):not(.stat-accent-copy) > p {
  color: var(--muted);
  max-width: 60ch;
}

.stat-card b {
  font-weight: 600;
}

.stats-grid .icon-badge {
  align-items: center;
  background: transparent;
  border: 0;
  color: currentColor;
  flex: 0 0 24px;
  height: 24px;
  justify-content: flex-start;
  width: 24px;
}

.stats-grid .icon-badge i {
  font-size: var(--fs-22);
}

.icon-badge,
.info-icon {
  align-items: center;
  background: var(--sky-blue);
  border: 1px solid rgba(9, 15, 5, 0.08);
  border-radius: 6px;
  color: var(--deep-teal);
  display: inline-flex;
  height: 44px;
  justify-content: center;
  width: 44px;
}

.icon-badge i,
.info-icon i {
  display: block;
  font-size: var(--fs-24);
  line-height: 1;
}

.icon-badge-on-dark {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.18);
  color: var(--terracotta);
}

.icon-badge-on-accent {
  background: rgba(9, 15, 5, 0.1);
  color: var(--deep-teal);
}

.approach-grid,
.workshop-grid {
  display: grid;
  gap: 16px;
}

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

.info-card {
  background: #fff;
  border: 1px solid var(--soft-line);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  padding: 36px 30px;
}

.info-card h3,
.workshop-card h3 {
  font-size: var(--fs-25);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.08;
}

.info-card p,
.workshop-card p {
  color: var(--muted);
  font-size: var(--fs-165);
  line-height: 1.6;
  margin: 0;
}

.info-icon {
  background: #093328;
  border-color: var(--green);
  border-radius: 6px;
  color: var(--terracotta);
  height: 52px;
  width: 52px;
}

.info-icon i {
  font-size: var(--fs-28);
}

#approach {
  background: #fff;
  border-top-color: rgba(9, 15, 5, 0.08);
  padding: 128px 0;
}

#approach .section-inner {
  max-width: 1320px;
}

#approach .section-heading {
  margin: 0 auto 64px;
  max-width: 1096px;
  text-align: center;
}

#approach .section-kicker {
  color: var(--mid-teal);
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
  margin: 0 0 16px;
}

#approach .section-heading h2 {
  color: var(--ink);
  font-size: 44px;
  font-weight: 500;
  letter-spacing: -0.48px;
  line-height: 1.2;
  margin: 0 auto;
  max-width: 1096px;
}

#approach .approach-grid {
  gap: 16px;
  grid-template-columns: repeat(3, minmax(0, 408px));
  justify-content: center;
}

#approach .info-card {
  background: #fff;
  border-color: rgba(9, 15, 5, 0.12);
  border-radius: 8px;
  box-shadow: none;
  gap: 0;
  min-height: 303px;
  padding: 36px 30px 30px;
}

#approach .info-icon {
  background: #093328;
  border-color: #18280e;
  border-radius: 6px;
  color: var(--terracotta);
  height: 52px;
  margin-bottom: 30px;
  width: 52px;
}

#approach .info-icon i {
  font-size: 28px;
}

#approach .info-card h3 {
  color: var(--ink);
  font-size: 25px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.08;
  margin: 0 0 20px;
}

#approach .info-card p {
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.6;
  margin: 0;
}

.split-heading {
  align-items: center;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 24px;
  margin-bottom: clamp(40px, 5vw, 60px);
  text-align: center;
}

.split-heading > div {
  margin-left: auto;
  margin-right: auto;
  max-width: 640px;
}

.split-heading > p {
  margin-left: auto;
  margin-right: auto;
}

.impact-grid > .reveal:first-child {
  text-align: center;
}

#partners .section-kicker {
  text-align: center;
}

.split-heading > p {
  max-width: 330px;
}

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

.workshop-card {
  background: #fff;
  border: 1px solid var(--soft-line);
  border-radius: 8px;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: border-color 220ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.workshop-card:hover,
.workshop-card.is-open {
  border-color: rgba(9, 15, 5, 0.32);
  box-shadow: var(--shadow);
  transform: translateY(-1px);
}

.workshop-card > img,
.image-placeholder {
  aspect-ratio: 1.58;
  border-bottom: 1px solid var(--soft-line);
  height: 210px;
  object-fit: cover;
  width: 100%;
}

.image-placeholder {
  align-items: center;
  background: linear-gradient(135deg, var(--sky-blue), var(--terracotta));
  color: var(--green);
  display: flex;
  font-family: var(--serif);
  font-size: var(--fs-22);
  font-weight: 600;
  justify-content: center;
  padding: 20px;
  text-align: center;
}

.image-placeholder-dark {
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  color: var(--terracotta);
}

.image-placeholder-writing {
  background: linear-gradient(135deg, var(--sky-blue), var(--sage-green));
  color: var(--deep-teal);
}

.workshop-body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 14px;
  padding: 26px;
}

.card-title-row {
  align-items: flex-start;
  display: flex;
  gap: 14px;
  justify-content: space-between;
}

.card-title-row span {
  color: rgba(9, 15, 5, 0.42);
  flex: none;
  font-family: var(--mono);
  font-size: var(--fs-12);
  font-weight: 600;
}

.accordion-trigger {
  align-items: center;
  background: transparent;
  border: 0;
  border-top: 1px solid var(--soft-line);
  color: var(--mid-teal);
  cursor: pointer;
  display: flex;
  font: inherit;
  font-size: var(--fs-145);
  font-weight: 600;
  gap: 8px;
  justify-content: space-between;
  margin-top: auto;
  padding: 14px 0 0;
  text-align: left;
}

.accordion-trigger span:last-child {
  font-size: var(--fs-20);
  line-height: 1;
  transition: transform 220ms ease;
}

.accordion-trigger[aria-expanded="true"] span:last-child {
  transform: rotate(45deg);
}

.accordion-panel {
  display: grid;
  grid-template-rows: 0fr;
  overflow: hidden;
  transition: grid-template-rows 260ms ease;
}

.accordion-panel > p {
  background: var(--sky-blue);
  border: 1px solid rgba(9, 15, 5, 0.08);
  border-radius: 6px;
  color: var(--deep-teal);
  font-size: var(--fs-15);
  line-height: 1.55;
  margin-top: 10px;
  min-height: 0;
  overflow: hidden;
  padding: 0 16px;
  transition: padding 260ms ease;
}

.workshop-card.is-open .accordion-panel {
  grid-template-rows: 1fr;
}

.workshop-card.is-open .accordion-panel > p {
  padding: 14px 16px;
}

.section-green .section-kicker {
  color: var(--terracotta);
}

.impact-grid {
  align-items: center;
  display: grid;
  gap: clamp(40px, 5vw, 72px);
  grid-template-columns: minmax(0, 1fr) minmax(320px, 1fr);
}

.impact-grid p,
.final-cta p {
  color: rgba(255, 255, 255, 0.82);
}

.impact-image {
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  height: 280px;
  margin-top: 28px;
  object-fit: cover;
  width: 100%;
}

.outcome-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  overflow: hidden;
}

.outcome-list div {
  align-items: center;
  background: rgba(255, 255, 255, 0.04);
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 0;
  display: flex;
  font-size: clamp(17px, 1.7vw, 20px);
  font-weight: 600;
  gap: 18px;
  padding: 20px 24px;
}

.outcome-list div:last-child {
  border-bottom: 0;
}

.outcome-list span {
  align-items: center;
  border: 1px solid var(--terracotta);
  border-radius: 6px;
  color: var(--terracotta);
  display: inline-flex;
  flex: none;
  font-family: var(--serif);
  font-size: var(--fs-18);
  font-weight: 600;
  height: 46px;
  justify-content: center;
  width: 46px;
}

.testimonials .section-kicker {
  margin-bottom: 34px;
}

.testimonial-card {
  min-height: 300px;
}

.quote-mark {
  color: rgba(9, 15, 5, 0.12);
  font-family: var(--serif);
  font-size: var(--fs-90);
  height: 46px;
  line-height: 0.6;
}

blockquote {
  margin: 0;
}

blockquote p {
  color: var(--ink);
  font-family: var(--serif);
  font-size: clamp(20px, 2.4vw, 30px);
  font-style: normal;
  font-weight: 520;
  line-height: 1.32;
  margin: 0 0 32px;
}

blockquote footer {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

blockquote footer strong {
  color: var(--ink);
  font-size: var(--fs-17);
}

blockquote footer span {
  color: var(--muted);
  font-size: var(--fs-15);
}

blockquote footer span:last-child {
  color: var(--mid-teal);
  font-weight: 600;
}

.testimonial-controls {
  align-items: center;
  display: flex;
  gap: 22px;
  justify-content: center;
  margin-top: 42px;
}

.testimonial-controls > button {
  align-items: center;
  background: #fff;
  border: 1px solid var(--soft-line);
  border-radius: 6px;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  font-size: var(--fs-18);
  height: 46px;
  justify-content: center;
  width: 46px;
}

.testimonial-controls > button:hover {
  background: var(--sky-blue);
}

.testimonial-dots {
  display: flex;
  gap: 9px;
}

.testimonial-dots button {
  background: rgba(9, 15, 5, 0.18);
  border: 0;
  border-radius: 3px;
  cursor: pointer;
  height: 9px;
  padding: 0;
  transition: background 180ms ease, width 180ms ease;
  width: 9px;
}

.testimonial-dots button.is-active {
  background: var(--green);
  width: 28px;
}

#about {
  background: #fcfff8;
  border-top-color: rgba(9, 15, 5, 0.08);
}

#about .section-inner {
  max-width: 1320px;
}

.about-grid {
  align-items: center;
  display: grid;
  gap: clamp(48px, 5.5vw, 78px);
  grid-template-columns: minmax(0, 610px) minmax(0, 581px);
  justify-content: center;
}

.portrait-wrap {
  max-width: 610px;
  padding-bottom: 18px;
  padding-left: 18px;
  position: relative;
  width: 100%;
}

.portrait-wrap img {
  border: 1px solid var(--soft-line);
  border-radius: 8px;
  height: 540px;
  object-fit: cover;
  object-position: center;
  width: 100%;
}

.portrait-label {
  align-items: flex-start;
  background: #093328;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  bottom: 0;
  box-shadow: 0 20px 20px rgba(9, 15, 5, 0.2);
  color: #fff;
  display: flex;
  flex-direction: column;
  height: 83px;
  justify-content: center;
  left: 0;
  max-width: none;
  padding: 0 24px;
  position: absolute;
  width: 282px;
}

.portrait-label strong {
  display: block;
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 600;
  line-height: 1.1;
}

.portrait-label span {
  display: block;
  font-size: 14px;
  line-height: 1.2;
  margin-top: 5px;
  opacity: 0.9;
  white-space: nowrap;
}

.about-copy {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  max-width: 581px;
}

.about-copy .section-kicker {
  color: var(--mid-teal);
  font-size: 16px;
  line-height: 2;
  margin: 0 0 13px;
}

.about-copy h2 {
  font-family: var(--display);
  font-size: 48px;
  font-weight: 500;
  letter-spacing: -0.48px;
  line-height: 1.1;
}

.about-copy p:not(.section-kicker) {
  color: var(--muted);
  font-size: 20px;
  line-height: 1.6;
  margin: 18px 0 0;
}

.about-copy p:not(.section-kicker) + p:not(.section-kicker) {
  margin-top: 32px;
}

.role-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 31px;
  max-width: 466px;
}

.role-tags span {
  align-items: center;
  background: #fff;
  border: 1px solid var(--soft-line);
  border-radius: 6px;
  color: var(--ink);
  display: inline-flex;
  font-size: 15px;
  font-weight: 600;
  height: 41px;
  justify-content: center;
  line-height: 1;
  padding: 0 18px;
}

.partners {
  border-top: 1px solid var(--soft-line);
  padding-bottom: clamp(64px, 7vw, 96px);
  padding-top: clamp(64px, 7vw, 96px);
  text-align: center;
}

.partners .section-kicker {
  color: var(--muted);
}

.organisation-strip {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin: 34px auto 0;
}

.organisation-logo {
  align-items: center;
  background: #fff;
  border: 1px solid var(--soft-line);
  border-radius: 8px;
  color: var(--deep-teal);
  display: flex;
  flex-direction: column;
  font-size: var(--fs-15);
  font-weight: 600;
  gap: 12px;
  justify-content: center;
  min-height: 136px;
  padding: 22px 16px;
  text-align: center;
}

.organisation-icon {
  align-items: center;
  background: var(--sky-blue);
  border: 1px solid rgba(9, 15, 5, 0.08);
  border-radius: 6px;
  color: var(--deep-teal);
  display: inline-flex;
  height: 48px;
  justify-content: center;
  width: 48px;
}

.organisation-icon i {
  display: block;
  font-size: var(--fs-27);
  line-height: 1;
}

.final-cta {
  background: var(--cream);
  overflow: hidden;
  padding: clamp(72px, 9vw, 130px) 0;
  text-align: left;
}

.final-cta::before,
.final-cta::after {
  display: none;
}

.final-cta::before {
  background:
    repeating-radial-gradient(ellipse at center, transparent 0 12px, rgba(178, 235, 118, 0.55) 13px 15px, transparent 16px 26px);
  left: 22%;
  top: -68px;
  transform: rotate(9deg);
}

.final-cta::after {
  background:
    repeating-radial-gradient(ellipse at center, transparent 0 11px, rgba(178, 235, 118, 0.5) 12px 14px, transparent 15px 24px);
  right: 17%;
  top: 42%;
  transform: rotate(-17deg);
}

.final-cta .section-inner {
  position: relative;
  z-index: 2;
}

.final-cta .section-kicker {
  color: rgba(255, 255, 255, 0.62);
  font-family: var(--mono);
  font-size: var(--fs-12);
  margin-bottom: 28px;
  text-transform: uppercase;
}

.final-cta .section-kicker::before,
.final-cta .section-kicker::after {
  content: "";
}

/* Spade-style chamfered card */
.cta-card {
  --ch: clamp(20px, 3vw, 34px);
  background: rgba(178, 235, 118, 0.26);
  clip-path: polygon(
    var(--ch) 0, calc(100% - var(--ch)) 0, 100% var(--ch),
    100% calc(100% - var(--ch)), calc(100% - var(--ch)) 100%, var(--ch) 100%,
    0 calc(100% - var(--ch)), 0 var(--ch)
  );
  padding: 1px;
}

.cta-card-inner {
  --ch: clamp(20px, 3vw, 34px);
  background: var(--green);
  clip-path: polygon(
    var(--ch) 0, calc(100% - var(--ch)) 0, 100% var(--ch),
    100% calc(100% - var(--ch)), calc(100% - var(--ch)) 100%, var(--ch) 100%,
    0 calc(100% - var(--ch)), 0 var(--ch)
  );
  padding: clamp(40px, 6vw, 88px) clamp(34px, 5vw, 76px);
  text-align: center;
}

.cta-card-head {
  align-items: center;
  display: flex;
  gap: 14px;
  justify-content: center;
  margin-bottom: clamp(24px, 3.5vw, 40px);
}

.cta-chip {
  border: 1px solid rgba(178, 235, 118, 0.5);
  border-radius: 10px;
  flex: none;
  height: 46px;
  object-fit: cover;
  width: 46px;
}

.cta-kicker {
  color: rgba(255, 255, 255, 0.66);
  font-family: var(--mono);
  font-size: var(--fs-12);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.final-cta h2 {
  color: #fff;
  font-family: var(--display);
  font-size: clamp(36px, 4.4vw, 64px);
  font-weight: 500;
  letter-spacing: -0.012em;
  line-height: 1.2;
  margin: 0 auto;
  max-width: 16ch;
}

.final-cta h2 span {
  color: var(--terracotta);
}

.final-cta p {
  color: rgba(255, 255, 255, 0.7);
  margin: 22px auto 0;
  max-width: 52ch;
}

.cta-actions {
  justify-content: center;
  margin-top: clamp(30px, 4vw, 44px);
}

.final-cta .button-primary {
  background: var(--terracotta);
  color: var(--ink);
}

.final-cta .button-primary:hover {
  background: var(--terracotta-dark);
}

.final-cta .button-outline {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.34);
  color: #fff;
}

.contact-links {
  display: flex;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: var(--fs-13);
  gap: 24px;
  justify-content: center;
  margin-top: clamp(32px, 4vw, 48px);
}

.contact-links a {
  align-items: center;
  color: rgba(255, 255, 255, 0.76);
  display: inline-flex;
  gap: 10px;
}

.contact-links a::before {
  background: var(--terracotta);
  border-radius: 0;
  content: "";
  height: 8px;
  transform: rotate(45deg);
  width: 8px;
}

.contact-links a:hover {
  color: var(--terracotta);
}

.site-footer {
  background: var(--green);
  border-top: 1px solid rgba(178, 235, 118, 0.22);
  color: rgba(255, 255, 255, 0.82);
  padding: clamp(58px, 6vw, 84px) 0 38px;
}

.footer-top {
  align-items: start;
  display: grid;
  gap: clamp(42px, 6vw, 96px);
  grid-template-columns: minmax(240px, 0.85fr) minmax(360px, 1fr);
}

.footer-brand {
  max-width: 360px;
}

.footer-brand-logo {
  opacity: 1;
}

.footer-brand p {
  color: rgba(255, 255, 255, 0.62);
  font-size: var(--fs-15);
  line-height: 1.6;
  margin: 22px 0 0;
}

.footer-links {
  display: grid;
  gap: clamp(28px, 4vw, 72px);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.footer-links div {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.footer-links strong {
  color: rgba(255, 255, 255, 0.5);
  font-family: var(--mono);
  font-size: var(--fs-11);
  font-weight: 600;
  text-transform: uppercase;
}

.footer-links a,
.footer-bottom a {
  color: rgba(255, 255, 255, 0.86);
}

.footer-links a {
  font-size: var(--fs-16);
}

.footer-links a:hover,
.footer-bottom a:hover {
  color: var(--terracotta);
}

.footer-bottom {
  border-top: 1px solid rgba(178, 235, 118, 0.16);
  color: rgba(255, 255, 255, 0.52);
  display: flex;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: var(--fs-12);
  gap: 14px;
  justify-content: space-between;
  margin-top: clamp(52px, 7vw, 88px);
  padding-top: 24px;
}

.reveal,
.hero-reveal {
  opacity: 1;
  transform: none;
}

.js .reveal,
.js .hero-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms cubic-bezier(0.22, 0.61, 0.36, 1), transform 700ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.js .hero-reveal {
  transform: translateY(22px);
  transition-duration: 820ms;
}

.js .reveal.is-visible,
.js .hero-reveal.is-visible {
  opacity: 1;
  transform: none;
}

.hero-reveal:nth-child(1) {
  transition-delay: 40ms;
}

.hero-reveal:nth-child(2) {
  transition-delay: 120ms;
}

.hero-reveal:nth-child(3) {
  transition-delay: 200ms;
}

.hero-reveal:nth-child(4) {
  transition-delay: 280ms;
}

.hero-reveal:nth-child(5) {
  transition-delay: 360ms;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
    animation-duration: 1ms !important;
  }

  .js .reveal,
  .js .hero-reveal {
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 1080px) {
  .workshop-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .stats-grid {
    gap: 24px;
    grid-auto-rows: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .stat-card {
    border-bottom: 0;
    grid-column: auto;
    grid-row: auto;
  }

  .stat-card-dark,
  .stat-card-accent {
    grid-column: 1 / -1;
  }

  .stat-card-dark {
    min-height: 420px;
  }

  #challenge {
    padding: 112px 0 88px;
  }

  #challenge .section-heading {
    margin-bottom: 72px;
  }

  #challenge .section-heading h2 {
    font-size: clamp(34px, 4.6vw, 44px);
  }

  #challenge .stat-card-dark {
    gap: 48px;
  }

  #challenge .stat-card-dark .stat-stack strong {
    font-size: clamp(72px, 9vw, 96px);
  }

  .approach-grid,
  .impact-grid,
  .about-grid {
    grid-template-columns: 1fr;
  }

  #approach {
    padding: 96px 0;
  }

  #approach .approach-grid {
    grid-template-columns: repeat(2, minmax(0, 408px));
  }

  .about-grid {
    justify-items: center;
  }

  .about-copy {
    max-width: 610px;
  }

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

  .footer-top {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  body.menu-open {
    overflow: hidden;
  }

  .nav-links {
    display: none;
  }

  .menu-toggle {
    display: inline-flex;
  }

  .mobile-menu {
    max-height: calc(100vh - 72px);
    overflow-y: auto;
  }

  .hero {
    align-items: center;
    margin-left: 18px;
    margin-right: 18px;
    min-height: auto;
  }

  .hero-shade {
    background:
      radial-gradient(circle at 72% 38%, rgba(178, 235, 118, 0.16), transparent 28%),
      linear-gradient(180deg, rgba(9, 15, 5, 0.62), rgba(9, 15, 5, 0.82));
  }

  .hero-inner {
    padding-bottom: 54px;
    padding-top: clamp(64px, 10vh, 92px);
  }

  .hero-copy {
    margin: 0 auto;
    max-width: 720px;
    text-align: center;
  }

  .section {
    padding: 72px 0;
  }

  .final-cta {
    min-height: auto;
    padding-bottom: 82px;
    padding-top: 96px;
  }

  .final-cta::before {
    left: 4%;
    top: -82px;
  }

  .final-cta::after {
    right: -10%;
    top: 54%;
  }

  .impact-image {
    height: 240px;
  }

  .portrait-wrap img {
    height: clamp(380px, 62vw, 540px);
  }

  .portrait-label {
    bottom: 0;
    left: 0;
  }
}

@media (max-width: 680px) {
  .nav {
    padding: 8px 18px;
  }

  .section-inner {
    padding: 0 18px;
  }

  .brand-logo {
    width: 44px;
  }

  .hero-copy {
    max-width: 100%;
  }

  .hero-lede {
    font-size: var(--fs-17);
    max-width: 33ch;
  }

  .hero-note {
    max-width: 34ch;
  }

  .hero-actions,
  .cta-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .hero-actions .button,
  .cta-actions .button,
  .mobile-menu .button {
    width: 100%;
  }

  .final-cta .button-outline {
    font-size: var(--fs-15);
    padding-left: 14px;
    padding-right: 14px;
    white-space: normal;
  }

  .footer-links {
    grid-template-columns: 1fr;
  }

  .portrait-wrap {
    padding-bottom: 14px;
    padding-left: 14px;
  }

  .portrait-wrap img {
    height: clamp(340px, 86vw, 460px);
  }

  .portrait-label {
    height: 76px;
    width: min(282px, calc(100% - 22px));
  }

  .about-copy h2 {
    font-size: clamp(34px, 10vw, 44px);
  }

  .about-copy p:not(.section-kicker) {
    font-size: 17px;
    line-height: 1.55;
  }

  .approach-grid,
  .workshop-grid {
    grid-template-columns: 1fr;
  }

  #approach {
    padding: 72px 0;
  }

  #approach .section-heading {
    margin-bottom: 40px;
  }

  #approach .section-heading h2 {
    font-size: clamp(30px, 8vw, 38px);
  }

  #approach .approach-grid {
    grid-template-columns: 1fr;
  }

  #approach .info-card {
    min-height: auto;
    padding: 30px 24px;
  }

  .stats-grid {
    gap: 24px;
    grid-template-columns: 1fr;
  }

  .stat-card,
  .stat-card:nth-child(2n) {
    border-right: 0;
  }

  .stat-card:nth-last-child(-n + 2) {
    border-bottom: 0;
  }

  .stat-card:last-child {
    border-bottom: 0;
  }

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

  .organisation-logo {
    min-height: 124px;
    padding: 20px 14px;
  }

  .stat-card,
  .info-card {
    min-height: auto;
  }

  .stat-card {
    gap: 22px;
    justify-content: flex-start;
    padding: 26px 24px;
  }

  .stat-card-dark {
    min-height: auto;
    padding: 34px 28px;
  }

  #challenge {
    padding: 72px 0;
  }

  #challenge .section-heading {
    margin-bottom: 48px;
  }

  #challenge .section-kicker {
    margin-bottom: 18px;
  }

  #challenge .section-heading h2 {
    font-size: clamp(30px, 8vw, 38px);
    letter-spacing: -0.32px;
  }

  #challenge .section-heading p {
    font-size: 17px;
    line-height: 1.55;
  }

  #challenge .stat-card {
    min-height: auto;
    padding: 28px 24px;
  }

  #challenge .stat-card > .icon-badge {
    margin-bottom: 28px;
  }

  #challenge .stat-card-dark {
    gap: 32px;
    padding: 34px 28px;
  }

  #challenge .stat-stack {
    gap: 28px;
  }

  #challenge .stat-card-dark .stat-stack strong {
    font-size: clamp(56px, 18vw, 76px);
  }

  #challenge .stat-value,
  #challenge .stat-card-accent .stat-value {
    font-size: clamp(42px, 13vw, 52px);
  }

  #challenge .stat-card-dark .stat-stack span {
    font-size: 12px;
  }

  #challenge .stat-card-dark .stat-stack p:last-child span {
    white-space: normal;
  }

  #challenge .stat-card-accent {
    gap: 24px;
  }

  .stat-card-top {
    gap: 12px;
  }

  .stat-label {
    font-size: var(--fs-13);
    line-height: 1.2;
  }

  .stat-stack {
    gap: 18px;
  }

  .stat-stack p {
    align-items: flex-start;
    column-gap: 10px;
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 4px;
  }

  .stat-stack strong,
  .stat-value {
    font-size: clamp(40px, 13vw, 52px);
  }

  .stat-stack span,
  .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
    font-size: var(--fs-155);
    line-height: 1.55;
  }

  .split-heading {
    align-items: flex-start;
  }

  .outcome-list div {
    align-items: flex-start;
  }

  .contact-links {
    flex-direction: column;
    align-items: center;
  }

  .footer-bottom {
    flex-direction: column;
    align-items: center;
  }
}

@media (max-width: 420px) {
  .eyebrow {
    align-items: flex-start;
    border-radius: 8px;
    line-height: 1.25;
  }

  h1 {
    font-size: 40px;
  }

  .section-heading h2,
  .split-heading h2,
  .impact-grid h2,
  .about-copy h2,
  .final-cta h2 {
    font-size: 31px;
  }

  .stat-card,
  .info-card,
  .workshop-body {
    padding: 24px;
  }

}

/* Unified section typography */
.section-kicker,
#challenge .section-kicker,
#approach .section-kicker,
.about-copy .section-kicker,
.partners .section-kicker,
.testimonials .section-kicker {
  color: var(--mid-teal);
  font-family: var(--mono);
  font-size: var(--fs-16);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.2;
  margin-bottom: 18px;
  text-transform: none;
}

.section-heading h2,
#challenge .section-heading h2,
#approach .section-heading h2,
.split-heading h2,
.about-copy h2,
.impact-grid h2 {
  color: var(--ink);
  font-family: var(--display);
  font-size: clamp(31px, 3vw, 44px);
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.section-heading p,
#challenge .section-heading p,
.split-heading > p,
.about-copy p:not(.section-kicker),
.impact-grid p {
  color: var(--muted);
  font-size: clamp(17px, 1.6vw, 20px);
  line-height: 1.6;
}

.final-cta .cta-kicker {
  font-size: var(--fs-16);
  line-height: 1.2;
}

.final-cta h2 {
  font-size: clamp(31px, 3vw, 44px);
  line-height: 1.2;
}

.final-cta p {
  font-size: clamp(17px, 1.6vw, 20px);
  line-height: 1.6;
}

/* Section heading width parity */
#challenge .section-heading,
#approach .section-heading,
.split-heading {
  margin-left: auto;
  margin-right: auto;
  max-width: 1145px;
  text-align: center;
}

#challenge .section-heading .section-kicker,
#approach .section-heading .section-kicker,
.split-heading .section-kicker {
  color: var(--mid-teal);
  display: block;
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.2;
  margin: 0 0 18px;
  text-align: center;
  text-transform: none;
}

#challenge .section-heading h2,
#approach .section-heading h2,
.split-heading h2 {
  color: var(--ink);
  font-family: var(--display);
  font-size: clamp(31px, 3vw, 44px);
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
  margin-left: auto;
  margin-right: auto;
  max-width: 1145px;
  text-align: center;
}

#challenge .section-heading p,
.split-heading > p {
  color: var(--muted);
  font-size: clamp(17px, 1.6vw, 20px);
  line-height: 1.6;
  margin-left: auto;
  margin-right: auto;
  max-width: 1145px;
  text-align: center;
}

.split-heading > div {
  max-width: 1145px;
  width: 100%;
}

/* Mobile hero: keep all content inside the rounded panel */
@media (max-width: 680px) {
  .hero {
    align-items: stretch;
    display: block;
    min-height: calc(100svh - 86px);
  }

  .hero-bg-photo {
    object-position: center top;
  }

  .hero-inner {
    align-items: center;
    display: flex;
    min-height: calc(100svh - 86px);
    padding-bottom: clamp(72px, 12vh, 104px);
    padding-top: clamp(52px, 9vh, 76px);
  }

  .hero-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 100%;
  }

  .hero-lede {
    margin-bottom: 28px;
    margin-top: 24px;
  }

  .hero-actions {
    gap: 12px;
    padding-bottom: 2px;
  }
}

@media (max-width: 420px) {
  .hero-inner {
    padding-bottom: 84px;
    padding-top: 48px;
  }

  .hero-lede {
    margin-top: 22px;
  }
}

/* Crescendo theme: bold, kinetic, dark and blue, while preserving the existing page structure. */
:root {
  --cres-bg: #0b1020;
  --cres-bg-2: #121a30;
  --cres-panel: #151d38;
  --cres-panel-2: #1d2848;
  --cres-line: rgba(139, 160, 226, 0.2);
  --cres-line-strong: rgba(139, 160, 226, 0.4);
  --cres-cream: #e9edf8;
  --cres-cream-60: rgba(233, 237, 248, 0.64);
  --cres-cream-40: rgba(233, 237, 248, 0.4);
  --cres-lime: #8ba0e2;
  --cres-lime-hot: #aec0ff;
  --cres-accent-rgb: 139, 160, 226;
  --cres-bg-rgb: 11, 16, 32;
  --deep-teal: var(--cres-panel);
  --mid-teal: var(--cres-lime);
  --warm-peach: var(--cres-lime);
  --peach-light: #dce4ff;
  --sky-blue: var(--cres-panel);
  --sky-blue-dark: var(--cres-bg-2);
  --sage-green: #344267;
  --sage-dark: var(--cres-cream-60);
  --warm-cream: var(--cres-bg);
  --rich-brown: var(--cres-cream);
  --cream: var(--cres-bg);
  --cream-soft: var(--cres-bg-2);
  --tint: var(--cres-bg-2);
  --green: var(--cres-panel);
  --green-dark: var(--cres-bg);
  --terracotta: var(--cres-lime);
  --terracotta-dark: var(--cres-lime-hot);
  --gold: var(--cres-lime);
  --ink: var(--cres-cream);
  --muted: var(--cres-cream-60);
  --soil: var(--cres-bg);
  --earth: var(--cres-lime);
  --soft-line: var(--cres-line);
  --white-line: var(--cres-line);
  --shadow: 0 30px 70px -42px rgba(0, 0, 0, 0.72);
  --display: "Anton", Impact, sans-serif;
  --serif: "Anton", Impact, sans-serif;
  --sans: "Archivo", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "Space Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

body {
  background:
    radial-gradient(circle at 15% 0, rgba(var(--cres-accent-rgb), 0.1), transparent 24rem),
    linear-gradient(180deg, var(--cres-bg), #070b18 58%, var(--cres-bg));
  color: var(--cres-cream);
  font-family: var(--sans);
  overflow-x: hidden;
}

::selection {
  background: var(--cres-lime);
  color: var(--cres-bg);
}

.skip-link {
  background: var(--cres-lime);
  border-radius: 6px;
  color: var(--cres-bg);
  font-family: var(--mono);
  font-size: var(--fs-12);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.site-header,
.site-header.is-scrolled,
.site-header.is-open {
  background: rgba(var(--cres-bg-rgb), 0.82);
  border-bottom: 1px solid var(--cres-line);
  box-shadow: none;
  color: var(--cres-cream);
  backdrop-filter: blur(14px);
}

.site-header.is-scrolled {
  background: rgba(var(--cres-bg-rgb), 0.9);
}

.nav {
  max-width: 1440px;
  padding: 14px clamp(20px, 4vw, 56px);
}

.brand {
  gap: 0;
}

.brand::before {
  content: none;
}

.brand::after {
  content: none;
}

.brand-logo {
  border: 1px solid var(--cres-line-strong);
  height: 42px;
  order: 1;
  width: 42px;
}

@keyframes crescendoPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(var(--cres-accent-rgb), 0.56);
  }

  70% {
    box-shadow: 0 0 0 12px rgba(var(--cres-accent-rgb), 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(var(--cres-accent-rgb), 0);
  }
}

.nav-links {
  gap: clamp(18px, 2.4vw, 34px);
}

.nav-links > a:not(.button),
.mobile-menu a:not(.button) {
  color: var(--cres-cream);
  font-family: var(--sans);
  font-size: 12.5px;
  font-weight: 800;
  letter-spacing: 0.08em;
  opacity: 0.72;
  text-transform: uppercase;
}

.nav-links > a:hover,
.mobile-menu a:hover {
  color: var(--cres-lime);
  opacity: 1;
}

.nav-links .button-primary,
.mobile-menu .button-primary {
  background: var(--cres-lime);
  color: var(--cres-bg);
}

.mobile-menu {
  background: rgba(var(--cres-bg-rgb), 0.98);
  border-top: 1px solid var(--cres-line);
  color: var(--cres-cream);
}

.mobile-menu a:not(.button) {
  border-bottom-color: var(--cres-line);
}

.menu-toggle span {
  background: var(--cres-cream);
}

.button {
  border-radius: 8px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.05em;
  min-height: 48px;
  padding: 15px 24px;
  text-transform: uppercase;
}

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

.button-primary {
  background: var(--cres-lime);
  color: var(--cres-bg);
}

.button-primary:hover {
  background: var(--cres-lime-hot);
}

.button-ghost,
.button-outline {
  background: transparent;
  border: 2px solid var(--cres-line-strong);
  color: var(--cres-cream);
}

.button-ghost:hover,
.button-outline:hover {
  background: rgba(var(--cres-accent-rgb), 0.08);
  border-color: var(--cres-lime);
}

.section,
.section-cream,
.section-tint,
#challenge,
#approach,
#about,
.partners,
.testimonials {
  background: var(--cres-bg);
  border-top: 1px solid var(--cres-line);
}

.section-tint,
#approach,
#about,
.gallery,
.partners {
  background: var(--cres-bg-2);
}

.section {
  padding: clamp(86px, 11vh, 144px) 0;
}

.section-inner {
  max-width: 1320px;
  padding: 0 clamp(20px, 4vw, 56px);
}

.hero {
  background: var(--cres-bg);
  border: 0;
  border-radius: 0;
  margin: 0;
  min-height: 100svh;
  padding-top: 70px;
}

.hero-bg-photo {
  filter: brightness(1.12) saturate(0.96) contrast(1.04);
  opacity: 0.62;
}

.hero::before,
.hero::after {
  content: none;
  display: none;
}

.hero::before {
  bottom: clamp(34px, 6vw, 76px);
  left: clamp(20px, 4vw, 56px);
}

.hero::after {
  right: clamp(20px, 4vw, 56px);
  top: clamp(104px, 12vw, 180px);
}

.hero-shade {
  background:
    radial-gradient(circle at 74% 28%, rgba(var(--cres-accent-rgb), 0.12), transparent 24%),
    linear-gradient(180deg, rgba(var(--cres-bg-rgb), 0.34), rgba(var(--cres-bg-rgb), 0.68) 58%, rgba(var(--cres-bg-rgb), 0.84));
}

.hero-vignette {
  background:
    linear-gradient(90deg, rgba(var(--cres-accent-rgb), 0.06) 0 1px, transparent 1px) 0 0 / 80px 80px,
    linear-gradient(0deg, rgba(var(--cres-accent-rgb), 0.05) 0 1px, transparent 1px) 0 0 / 80px 80px;
  opacity: 0.24;
}

.hero-inner {
  padding-bottom: clamp(52px, 8vh, 86px);
  padding-top: clamp(74px, 11vh, 128px);
}

.hero-copy {
  max-width: min(1220px, 92vw);
  text-shadow: 0 3px 24px rgba(0, 0, 0, 0.42);
}

h1,
h2,
h3 {
  font-family: var(--display);
  font-weight: 400;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1 {
  color: var(--cres-cream);
  font-size: clamp(54px, 9.4vw, 132px);
  line-height: 0.85;
  max-width: none;
}

.hero-lede {
  color: var(--cres-cream-60);
  font-size: clamp(16px, 1.45vw, 20px);
  line-height: 1.5;
  margin: 44px auto 30px;
  max-width: 46ch;
}

.hero .button-primary {
  background: var(--cres-lime);
  color: var(--cres-bg);
}

.hero .button-ghost {
  background: transparent;
  border-color: var(--cres-line-strong);
  color: var(--cres-cream);
}

.hero-actions {
  gap: 13px;
}

.section-kicker,
#challenge .section-kicker,
#approach .section-kicker,
.about-copy .section-kicker,
.partners .section-kicker,
.testimonials .section-kicker,
.final-cta .cta-kicker {
  align-items: center;
  color: var(--cres-lime);
  display: inline-flex;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 800;
  gap: 12px;
  letter-spacing: 0.18em;
  line-height: 1.2;
  margin-bottom: 20px;
  text-transform: uppercase;
}

.section-kicker::before,
#challenge .section-kicker::before,
#approach .section-kicker::before,
.about-copy .section-kicker::before,
.partners .section-kicker::before,
.testimonials .section-kicker::before {
  background: var(--cres-lime);
  content: "";
  display: inline-block;
  height: 2px;
  width: 28px;
}

.section-kicker::after,
#challenge .section-kicker::after,
#approach .section-kicker::after,
.about-copy .section-kicker::after,
.partners .section-kicker::after,
.testimonials .section-kicker::after,
.final-cta .section-kicker::before,
.final-cta .section-kicker::after {
  content: none;
}

.section-heading,
#challenge .section-heading,
#approach .section-heading,
.split-heading {
  margin-bottom: clamp(42px, 5vw, 64px);
  max-width: 1140px;
  text-align: left;
}

.section-heading h2,
#challenge .section-heading h2,
#approach .section-heading h2,
.split-heading h2,
.about-copy h2,
.impact-grid h2,
.final-cta h2 {
  color: var(--cres-cream);
  font-family: var(--display);
  font-size: clamp(38px, 5.6vw, 78px);
  font-weight: 400;
  letter-spacing: 0;
  line-height: 0.92;
  text-transform: uppercase;
}

.section-heading p,
#challenge .section-heading p,
.split-heading > p,
.about-copy p:not(.section-kicker),
.impact-grid p,
.final-cta p {
  color: var(--cres-cream-60);
  font-size: clamp(16px, 1.45vw, 20px);
  line-height: 1.55;
}

#challenge {
  padding: clamp(86px, 11vh, 140px) 0;
}

#challenge .section-heading {
  align-items: end;
  display: grid;
  gap: 34px;
  grid-template-columns: 1fr minmax(320px, 0.85fr);
  margin-left: auto;
  margin-right: auto;
  text-align: left;
}

#challenge .section-heading .section-kicker {
  grid-column: 1 / -1;
  margin-bottom: -4px;
}

#challenge .section-heading h2 {
  max-width: 11ch;
  text-align: left;
}

#challenge .section-heading p {
  margin: 0;
  max-width: 50ch;
  text-align: left;
}

.stats-grid {
  gap: 18px;
  grid-auto-rows: minmax(244px, auto);
}

.stat-card,
.info-card,
.workshop-card,
.organisation-logo,
.testimonial-card {
  background: var(--cres-panel);
  border: 1px solid var(--cres-line);
  border-radius: 18px;
  box-shadow: none;
  color: var(--cres-cream);
}

.stat-card {
  gap: 0;
  min-height: 244px;
  padding: 34px;
  transition: border-color 260ms ease, transform 260ms ease;
}

.stat-card:hover,
.info-card:hover,
.workshop-card:hover,
.organisation-logo:hover {
  border-color: var(--cres-lime);
  transform: translateY(-4px);
}

.stat-card::before,
.stat-card::after {
  display: none;
}

.stat-card-dark {
  background: var(--cres-panel);
  clip-path: none;
  gap: 36px;
  min-height: 526px;
  padding: 42px;
}

.stat-card-accent {
  background: var(--cres-lime);
  border-color: var(--cres-lime);
  color: var(--cres-bg);
  gap: 28px;
}

.stat-label,
.stat-card-accent .stat-label,
.stat-card-dark .stat-label {
  color: var(--cres-lime);
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 0.16em;
  line-height: 1.25;
  opacity: 1;
}

.stat-card-accent .stat-label {
  color: rgba(var(--cres-bg-rgb), 0.68);
}

.stat-stack strong,
.stat-value,
.stat-card-dark .stat-stack strong,
.stat-card-accent .stat-value {
  color: var(--cres-cream);
  font-family: var(--display);
  font-size: clamp(56px, 8vw, 116px);
  font-weight: 400;
  letter-spacing: 0;
  line-height: 0.86;
}

.stat-card-dark .stat-stack p:first-child strong {
  color: var(--cres-lime);
}

.stat-card-accent .stat-value {
  color: var(--cres-bg);
  white-space: normal;
}

.stat-stack span,
.stat-card > div:not(.stat-card-top):not(.stat-stack) > p,
.stat-card-dark .stat-stack span,
.stat-card-accent > div:not(.stat-card-top):not(.stat-stack) > p {
  color: var(--cres-cream-60);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
  max-width: 42ch;
  text-transform: none;
  white-space: normal;
}

.stat-card-accent > div:not(.stat-card-top):not(.stat-stack):not(.stat-accent-copy) > p {
  color: rgba(var(--cres-bg-rgb), 0.78);
}

.stats-grid .icon-badge,
.icon-badge,
.info-icon,
.organisation-icon {
  background: rgba(var(--cres-accent-rgb), 0.08);
  border: 1px solid var(--cres-line-strong);
  border-radius: 10px;
  color: var(--cres-lime);
}

.stat-card-accent .icon-badge {
  background: rgba(var(--cres-bg-rgb), 0.1);
  border-color: rgba(var(--cres-bg-rgb), 0.18);
  color: var(--cres-bg);
}

#approach {
  padding: clamp(80px, 10vh, 128px) 0;
}

#approach .section-heading {
  margin-bottom: 54px;
  text-align: left;
}

#approach .section-heading h2 {
  margin-left: 0;
  max-width: 13ch;
  text-align: left;
}

#approach .approach-grid {
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.info-card,
#approach .info-card {
  gap: 0;
  min-height: 320px;
  padding: 34px 30px;
  transition: border-color 260ms ease, transform 260ms ease;
}

.info-icon,
#approach .info-icon {
  background: rgba(var(--cres-accent-rgb), 0.09);
  border-color: var(--cres-line-strong);
  color: var(--cres-lime);
  height: 52px;
  margin-bottom: 30px;
  width: 52px;
}

.info-card h3,
#approach .info-card h3,
.workshop-card h3,
.organisation-logo > span:last-child {
  color: var(--cres-cream);
  font-family: var(--display);
  font-size: clamp(28px, 3.2vw, 46px);
  font-weight: 400;
  letter-spacing: 0;
  line-height: 0.95;
  text-transform: uppercase;
}

.info-card p,
#approach .info-card p,
.workshop-card p {
  color: var(--cres-cream-60);
  font-size: var(--fs-16);
  line-height: 1.55;
}

.workshop-grid {
  gap: 18px;
}

.workshop-card {
  background: var(--cres-panel);
  overflow: hidden;
}

.workshop-card > img,
.image-placeholder {
  border-bottom: 1px solid var(--cres-line);
  filter: saturate(0.9) contrast(1.06);
  height: clamp(210px, 22vw, 300px);
}

.image-placeholder {
  background:
    linear-gradient(135deg, rgba(var(--cres-accent-rgb), 0.16), rgba(var(--cres-accent-rgb), 0.02)),
    var(--cres-panel-2);
  color: var(--cres-lime);
  font-family: var(--display);
  font-size: clamp(30px, 4vw, 54px);
  letter-spacing: 0;
  line-height: 0.92;
  text-transform: uppercase;
}

.image-placeholder-dark,
.image-placeholder-writing {
  background:
    linear-gradient(135deg, rgba(var(--cres-accent-rgb), 0.2), rgba(var(--cres-bg-rgb), 0.4)),
    var(--cres-bg);
  color: var(--cres-lime);
}

.workshop-body {
  gap: 18px;
  padding: 28px;
}

.card-title-row span {
  color: var(--cres-lime);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
}

.workshop-card:hover .card-title-row h3 {
  color: var(--cres-lime);
}

.testimonials {
  background: var(--cres-bg);
}

.testimonial-card {
  padding: clamp(28px, 5vw, 56px);
}

.quote-mark {
  color: var(--cres-lime);
  font-family: var(--display);
  opacity: 0.6;
}

blockquote p {
  color: var(--cres-cream);
  font-family: var(--display);
  font-size: clamp(28px, 4vw, 58px);
  font-weight: 400;
  line-height: 0.98;
  text-transform: uppercase;
}

blockquote footer strong {
  color: var(--cres-cream);
}

blockquote footer span {
  color: var(--cres-cream-60);
}

blockquote footer span:last-child {
  color: var(--cres-lime);
}

.testimonial-controls > button {
  background: transparent;
  border: 1px solid var(--cres-line-strong);
  color: var(--cres-cream);
}

.testimonial-controls > button:hover {
  background: rgba(var(--cres-accent-rgb), 0.08);
  color: var(--cres-lime);
}

.testimonial-dots button {
  background: var(--cres-line-strong);
}

.testimonial-dots button.is-active {
  background: var(--cres-lime);
}

.about-grid {
  gap: clamp(42px, 6vw, 82px);
}

.portrait-wrap {
  padding-bottom: 18px;
  padding-left: 18px;
}

.portrait-wrap img {
  border: 1px solid var(--cres-line);
  border-radius: 20px;
  filter: saturate(0.95) contrast(1.06);
}

.portrait-label {
  background: var(--cres-lime);
  border: 0;
  border-radius: 12px;
  box-shadow: 0 24px 45px -28px rgba(0, 0, 0, 0.8);
  color: var(--cres-bg);
  height: auto;
  min-height: 86px;
  padding: 16px 24px;
  width: min(360px, calc(100% - 22px));
}

.portrait-label strong {
  font-family: var(--display);
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.portrait-label span {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
  line-height: 1.25;
  opacity: 0.72;
  text-transform: uppercase;
  white-space: normal;
}

.about-copy h2 {
  font-size: clamp(44px, 6vw, 96px);
  line-height: 0.88;
}

.role-tags span,
.tags span {
  background: transparent;
  border: 1px solid var(--cres-line-strong);
  border-radius: 6px;
  color: var(--cres-cream);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.organisation-strip {
  gap: 18px;
}

.organisation-logo {
  color: var(--cres-cream);
  gap: 16px;
  min-height: 150px;
  transition: border-color 260ms ease, transform 260ms ease;
}

.organisation-logo > span:last-child {
  font-size: clamp(20px, 2vw, 28px);
}

.organisation-icon {
  height: 52px;
  width: 52px;
}

.final-cta {
  background: var(--cres-lime);
  color: var(--cres-bg);
  padding: clamp(78px, 10vw, 138px) 0;
}

.cta-card,
.cta-card-inner {
  background: transparent;
  clip-path: none;
  padding: 0;
}

.cta-card-inner {
  color: var(--cres-bg);
}

.cta-kicker,
.final-cta .cta-kicker {
  color: rgba(var(--cres-bg-rgb), 0.68);
  justify-content: center;
}

.final-cta h2 {
  color: var(--cres-bg);
  font-size: clamp(52px, 10vw, 150px);
  line-height: 0.84;
  max-width: 12ch;
}

.final-cta h2 span {
  color: var(--cres-bg);
}

.final-cta p {
  color: rgba(var(--cres-bg-rgb), 0.74);
  font-weight: 600;
}

.final-cta .button-primary {
  background: var(--cres-bg);
  color: var(--cres-lime);
}

.final-cta .button-primary:hover {
  background: #050816;
}

.final-cta .button-outline {
  border-color: rgba(var(--cres-bg-rgb), 0.36);
  color: var(--cres-bg);
}

.final-cta .button-outline:hover {
  background: rgba(var(--cres-bg-rgb), 0.08);
  border-color: var(--cres-bg);
}

.contact-links {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contact-links a {
  color: rgba(var(--cres-bg-rgb), 0.76);
}

.contact-links a::before {
  background: var(--cres-bg);
  border-radius: 50%;
}

.contact-links a:hover {
  color: var(--cres-bg);
}

.js .reveal,
.js .hero-reveal {
  transform: translateY(40px);
  transition: opacity 800ms cubic-bezier(0.2, 0.7, 0.2, 1), transform 800ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

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

@media (max-width: 1080px) {
  #challenge .section-heading {
    align-items: start;
    grid-template-columns: 1fr;
  }

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

@media (max-width: 860px) {
  .site-header,
  .site-header.is-scrolled,
  .site-header.is-open {
    background: rgba(var(--cres-bg-rgb), 0.96);
  }

  .hero {
    margin: 0;
    min-height: calc(100svh - 1px);
  }

  .hero-inner {
    min-height: calc(100svh - 1px);
  }

  h1 {
    font-size: clamp(46px, 13vw, 86px);
  }

  .section-heading,
  #challenge .section-heading,
  #approach .section-heading,
  .split-heading {
    text-align: left;
  }

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

@media (max-width: 680px) {
  .brand::after {
    font-size: 21px;
  }

  .brand-logo {
    height: 38px;
    width: 38px;
  }

  .button {
    min-height: 48px;
  }

  .hero {
    padding-top: 62px;
  }

  .hero-copy {
    text-align: left;
  }

  h1 {
    font-size: clamp(40px, 12vw, 68px);
  }

  .hero-lede {
    margin-left: 0;
    max-width: 31ch;
  }

  .hero-actions,
  .cta-actions {
    align-items: stretch;
  }

  .section-heading h2,
  #challenge .section-heading h2,
  #approach .section-heading h2,
  .split-heading h2,
  .about-copy h2,
  .impact-grid h2 {
    font-size: clamp(36px, 12vw, 56px);
  }

  .stats-grid,
  #approach .approach-grid,
  .workshop-grid {
    grid-template-columns: 1fr;
  }

  .stat-card,
  #challenge .stat-card,
  .info-card,
  #approach .info-card,
  .workshop-body,
  .testimonial-card {
    padding: 28px 24px;
  }

  .stat-card-dark {
    gap: 32px;
  }

  .stat-stack strong,
  .stat-value,
  .stat-card-dark .stat-stack strong,
  .stat-card-accent .stat-value {
    font-size: clamp(54px, 18vw, 82px);
  }

  .stat-stack span,
  .stat-card > div:not(.stat-card-top):not(.stat-stack) > p,
  .stat-card-dark .stat-stack span {
    font-size: 14px;
  }

  .split-heading {
    align-items: flex-start;
  }

  .organisation-strip {
    grid-template-columns: 1fr;
  }

  .final-cta h2 {
    font-size: clamp(48px, 17vw, 88px);
  }
}

/* Crescendo readability pass: keep the bold voice without clipping or cramped lines. */
h1,
.section-heading h2,
#challenge .section-heading h2,
#approach .section-heading h2,
.split-heading h2,
.about-copy h2,
.impact-grid h2,
.final-cta h2,
.info-card h3,
#approach .info-card h3,
.workshop-card h3,
.organisation-logo > span:last-child,
blockquote p,
.image-placeholder {
  max-width: 100%;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

h1 {
  font-size: clamp(46px, 7.6vw, 112px);
  line-height: 0.98;
}

.section-heading h2,
#challenge .section-heading h2,
#approach .section-heading h2,
.split-heading h2,
.impact-grid h2 {
  font-size: clamp(32px, 4.2vw, 64px);
  line-height: 1.06;
}

#challenge .section-heading h2,
#approach .section-heading h2 {
  max-width: min(850px, 100%);
}

.about-copy h2 {
  font-size: clamp(36px, 5vw, 76px);
  line-height: 1.04;
}

.info-card h3,
#approach .info-card h3,
.workshop-card h3,
.organisation-logo > span:last-child {
  font-size: clamp(24px, 2.45vw, 36px);
  line-height: 1.08;
}

.image-placeholder {
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.08;
}

.stat-stack strong,
.stat-value,
.stat-card-dark .stat-stack strong,
.stat-card-accent .stat-value {
  font-size: clamp(46px, 6.4vw, 92px);
  line-height: 1;
  overflow-wrap: anywhere;
}

blockquote p {
  font-size: clamp(24px, 3.2vw, 44px);
  line-height: 1.08;
}

.final-cta h2 {
  font-size: clamp(42px, 7.4vw, 104px);
  line-height: 0.98;
  max-width: min(920px, 100%);
}

@media (max-width: 860px) {
  h1 {
    font-size: clamp(40px, 9.6vw, 74px);
    line-height: 1.02;
  }

  .section-heading h2,
  #challenge .section-heading h2,
  #approach .section-heading h2,
  .split-heading h2,
  .about-copy h2,
  .impact-grid h2 {
    font-size: clamp(30px, 7vw, 48px);
    line-height: 1.08;
  }
}

@media (max-width: 680px) {
  h1 {
    font-size: clamp(34px, 10.2vw, 54px);
    line-height: 1.04;
  }

  .hero-lede {
    max-width: 100%;
  }

  .section-heading h2,
  #challenge .section-heading h2,
  #approach .section-heading h2,
  .split-heading h2,
  .about-copy h2,
  .impact-grid h2 {
    font-size: clamp(28px, 8.8vw, 42px);
  }

  .stat-stack strong,
  .stat-value,
  .stat-card-dark .stat-stack strong,
  .stat-card-accent .stat-value {
    font-size: clamp(42px, 13vw, 64px);
  }

  .final-cta h2 {
    font-size: clamp(38px, 11.5vw, 62px);
    line-height: 1.02;
  }

  .portrait-label {
    padding: 14px 18px;
    width: min(340px, calc(100% - 18px));
  }
}

/* Fix high-specificity legacy approach card styles that made light text sit on white cards. */
#approach .info-card {
  background: var(--cres-panel);
  border-color: var(--cres-line);
  border-radius: 18px;
  color: var(--cres-cream);
}

#approach .info-card h3 {
  color: var(--cres-cream);
}

#approach .info-card p {
  color: var(--cres-cream-60);
}

#approach .info-icon {
  background: rgba(var(--cres-accent-rgb), 0.09);
  border-color: var(--cres-line-strong);
  color: var(--cres-lime);
}

/* Partner labels stay on one line while scaling down on narrower cards. */
.organisation-logo {
  min-height: 176px;
  padding: 28px 18px;
}

.organisation-logo > span:last-child {
  font-size: clamp(16px, 1.05vw, 22px);
  line-height: 1.12;
  max-width: 100%;
  overflow-wrap: normal;
  text-wrap: nowrap;
  white-space: nowrap;
  word-break: normal;
}

@media (max-width: 860px) {
  .organisation-logo > span:last-child {
    font-size: clamp(12px, 3vw, 18px);
    max-width: 100%;
  }
}

/* Unified subheading style: no decorative line, consistent typography everywhere. */
.section-kicker,
#challenge .section-kicker,
#approach .section-kicker,
.split-heading .section-kicker,
.about-copy .section-kicker,
.partners .section-kicker,
.testimonials .section-kicker,
.final-cta .cta-kicker,
.cta-kicker {
  color: var(--cres-lime);
  display: block;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.18em;
  line-height: 1.3;
  margin: 0 0 20px;
  text-transform: uppercase;
}

.section-kicker::before,
.section-kicker::after,
#challenge .section-kicker::before,
#challenge .section-kicker::after,
#approach .section-kicker::before,
#approach .section-kicker::after,
.split-heading .section-kicker::before,
.split-heading .section-kicker::after,
.about-copy .section-kicker::before,
.about-copy .section-kicker::after,
.partners .section-kicker::before,
.partners .section-kicker::after,
.testimonials .section-kicker::before,
.testimonials .section-kicker::after,
.final-cta .cta-kicker::before,
.final-cta .cta-kicker::after,
.cta-kicker::before,
.cta-kicker::after {
  content: none;
  display: none;
}

.final-cta .cta-kicker,
.cta-kicker {
  color: rgba(var(--cres-bg-rgb), 0.72);
}

/* High-specificity kicker reset for older section-specific rules. */
#challenge .section-heading .section-kicker,
#approach .section-heading .section-kicker,
.split-heading .section-kicker,
.about-copy .section-kicker,
.partners .section-kicker,
.testimonials .section-kicker,
.final-cta .cta-kicker,
.cta-kicker {
  color: var(--cres-lime);
  display: block;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.18em;
  line-height: 1.3;
  margin: 0 0 20px;
  text-align: inherit;
  text-transform: uppercase;
}

#challenge .section-heading .section-kicker::before,
#challenge .section-heading .section-kicker::after,
#approach .section-heading .section-kicker::before,
#approach .section-heading .section-kicker::after,
.split-heading .section-kicker::before,
.split-heading .section-kicker::after,
.about-copy .section-kicker::before,
.about-copy .section-kicker::after,
.partners .section-kicker::before,
.partners .section-kicker::after,
.testimonials .section-kicker::before,
.testimonials .section-kicker::after,
.final-cta .cta-kicker::before,
.final-cta .cta-kicker::after,
.cta-kicker::before,
.cta-kicker::after {
  content: none;
  display: none;
}

.final-cta .cta-kicker,
.cta-kicker {
  color: rgba(var(--cres-bg-rgb), 0.72);
}

/* Final section label lock: keep every kicker on the same Crescendo style. */
main .section-kicker,
main .section-heading .section-kicker,
main .split-heading .section-kicker,
main .about-copy .section-kicker,
main .partners .section-kicker,
main .testimonials .section-kicker,
main .final-cta .section-kicker,
main .final-cta .cta-kicker {
  align-items: initial !important;
  color: var(--cres-lime) !important;
  display: block !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  gap: 0 !important;
  letter-spacing: 0.18em !important;
  line-height: 1.3 !important;
  margin: 0 0 20px !important;
  text-align: inherit !important;
  text-transform: uppercase !important;
  width: 100% !important;
}

main .section-kicker::before,
main .section-kicker::after,
main .section-heading .section-kicker::before,
main .section-heading .section-kicker::after,
main .split-heading .section-kicker::before,
main .split-heading .section-kicker::after,
main .about-copy .section-kicker::before,
main .about-copy .section-kicker::after,
main .partners .section-kicker::before,
main .partners .section-kicker::after,
main .testimonials .section-kicker::before,
main .testimonials .section-kicker::after,
main .final-cta .section-kicker::before,
main .final-cta .section-kicker::after,
main .final-cta .cta-kicker::before,
main .final-cta .cta-kicker::after {
  content: none !important;
  display: none !important;
}

main .final-cta .cta-kicker {
  color: rgba(var(--cres-bg-rgb), 0.72) !important;
}

/* Stat label badges should read as clear icons, not tiny inline marks. */
.stats-grid .stat-card-top .icon-badge {
  align-items: center;
  background: rgba(var(--cres-accent-rgb), 0.1);
  border: 1px solid var(--cres-line-strong);
  border-radius: 50%;
  color: var(--cres-lime);
  display: inline-flex;
  flex: 0 0 34px;
  height: 34px;
  justify-content: center;
  width: 34px;
}

.stats-grid .stat-card-top .icon-badge i {
  font-size: 19px;
}

.stats-grid .stat-card-accent .stat-card-top .icon-badge {
  background: rgba(var(--cres-bg-rgb), 0.1);
  border-color: rgba(var(--cres-bg-rgb), 0.22);
  color: var(--cres-bg);
}

/* Container alignment lock: headings and grids share the same section edges. */
:root {
  --site-container: 1320px;
}

.nav,
.section-inner,
#challenge .section-inner,
#approach .section-inner,
#about .section-inner,
.final-cta .section-inner {
  margin-left: auto;
  margin-right: auto;
  max-width: var(--site-container);
  width: 100%;
}

main .section-heading,
main #challenge .section-heading,
main #approach .section-heading,
main .split-heading {
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: none !important;
  width: 100% !important;
}

main .section-heading h2,
main #challenge .section-heading h2,
main #approach .section-heading h2,
main .split-heading h2,
main #challenge .section-heading p,
main .split-heading > p {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Direct icon rendering: remove badge/circle containers from all inline icons. */
main .icon-badge,
main .info-icon,
main .organisation-icon,
main .stats-grid .icon-badge,
main .stats-grid .stat-card-top .icon-badge,
main #approach .info-icon {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  color: var(--cres-lime) !important;
  flex: 0 0 auto !important;
  height: auto !important;
  justify-content: flex-start !important;
  min-height: 0 !important;
  padding: 0 !important;
  width: auto !important;
}

main .stat-card-accent .icon-badge,
main .stats-grid .stat-card-accent .stat-card-top .icon-badge {
  color: var(--cres-bg) !important;
}

main .icon-badge i,
main .info-icon i,
main .organisation-icon i,
main .stats-grid .icon-badge i,
main .stats-grid .stat-card-top .icon-badge i,
main #approach .info-icon i {
  display: block !important;
  font-size: 30px !important;
  line-height: 1 !important;
}

main .testimonials blockquote p {
  font-family: var(--sans) !important;
  font-size: clamp(18px, 1.55vw, 24px) !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1.45 !important;
  margin: 0 auto 32px !important;
  max-width: 900px;
  text-align: center !important;
  text-transform: none !important;
}

main .testimonials blockquote {
  text-align: center !important;
}

main #partners-title {
  display: inline-block !important;
  max-width: none !important;
  white-space: nowrap !important;
  width: auto !important;
}

/* Spacing rhythm lock: visible layout spacing follows a 4px grid. */
:root {
  --space-2: 2px;
  --space-4: 4px;
  --space-8: 8px;
  --space-12: 12px;
  --space-16: 16px;
  --space-20: 20px;
  --space-24: 24px;
  --space-28: 28px;
  --space-32: 32px;
  --space-36: 36px;
  --space-40: 40px;
  --space-44: 44px;
  --space-48: 48px;
  --space-56: 56px;
  --space-64: 64px;
  --space-72: 72px;
  --space-80: 80px;
  --space-88: 88px;
}

.nav {
  gap: var(--space-32);
  padding: var(--space-12) clamp(var(--space-20), 4vw, var(--space-56));
}

.nav-links {
  gap: clamp(var(--space-24), 2.5vw, var(--space-40));
}

.menu-toggle {
  gap: var(--space-4);
}

.button {
  padding: var(--space-12) var(--space-20);
}

.mobile-menu {
  gap: var(--space-4);
  padding: var(--space-12) var(--space-24) var(--space-24);
}

main .section {
  padding: clamp(var(--space-88), 11vh, 144px) 0;
}

main .section-inner {
  padding-left: clamp(var(--space-20), 4vw, var(--space-56));
  padding-right: clamp(var(--space-20), 4vw, var(--space-56));
}

main .section-heading,
main #challenge .section-heading,
main #approach .section-heading,
main .split-heading {
  margin-bottom: clamp(var(--space-48), 5vw, var(--space-64));
}

main #challenge .section-heading {
  gap: var(--space-32);
}

main .section-kicker,
main .section-heading .section-kicker,
main .split-heading .section-kicker,
main .about-copy .section-kicker,
main .partners .section-kicker,
main .testimonials .section-kicker,
main .final-cta .section-kicker,
main .final-cta .cta-kicker {
  margin-bottom: var(--space-20) !important;
}

main .hero-inner {
  padding-bottom: clamp(var(--space-56), 8vh, var(--space-88));
  padding-top: clamp(var(--space-72), 11vh, 128px);
}

main .hero-lede {
  margin-bottom: var(--space-32);
  margin-top: var(--space-44, 44px);
}

main .hero-actions {
  gap: var(--space-12);
}

main .stats-grid,
main #approach .approach-grid,
main .approach-grid,
main .workshop-grid,
main .organisation-strip {
  gap: var(--space-24);
}

main .stat-card {
  min-height: 244px;
  padding: var(--space-32);
}

main .stat-card-dark {
  gap: var(--space-36);
  min-height: 528px;
  padding: var(--space-40);
}

main .stat-card-accent {
  gap: var(--space-28);
}

main .stat-card-top {
  gap: var(--space-12);
}

main .stat-stack {
  gap: var(--space-48);
}

main .stat-stack p {
  gap: var(--space-16);
}

main .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  margin-top: var(--space-20);
}

main .info-card,
main #approach .info-card {
  min-height: 320px;
  padding: var(--space-32);
}

main .info-icon,
main #approach .info-icon {
  margin-bottom: var(--space-28);
}

main .workshop-body {
  padding: var(--space-28);
}

main .card-title-row {
  gap: var(--space-16);
}

main .about-grid {
  gap: clamp(var(--space-48), 6vw, var(--space-80));
}

main .portrait-wrap {
  padding-bottom: var(--space-16);
  padding-left: var(--space-16);
}

main .portrait-label {
  min-height: var(--space-88);
  padding: var(--space-16) var(--space-24);
}

main .role-tags {
  gap: var(--space-8);
  margin-top: var(--space-32);
}

main .organisation-strip {
  margin-top: var(--space-32);
}

main .organisation-logo {
  gap: var(--space-16);
  min-height: 176px;
  padding: var(--space-28) var(--space-20);
}

main .cta-card-inner {
  padding: clamp(var(--space-40), 6vw, var(--space-88)) clamp(var(--space-32), 5vw, 76px);
}

main .cta-card-head,
main .cta-actions,
main .contact-links,
main .footer-bottom,
main .footer-social,
main .footer-links {
  gap: var(--space-24);
}

main .contact-links {
  margin-top: var(--space-32);
}

@media (max-width: 680px) {
  .nav {
    padding: var(--space-8) var(--space-20);
  }

  main .section-inner {
    padding-left: var(--space-20);
    padding-right: var(--space-20);
  }

  main .stats-grid,
  main #approach .approach-grid,
  main .approach-grid,
  main .workshop-grid,
  main .organisation-strip {
    gap: var(--space-24);
  }

  main .stat-card,
  main #approach .info-card,
  main .testimonial-card {
    padding: var(--space-28) var(--space-24);
  }

  main .organisation-logo {
    min-height: 128px;
    padding: var(--space-20) var(--space-16);
  }
}

/* Stats typography lock: use body font and a quieter value scale. */
main #challenge .stat-card,
main #challenge .stat-card *,
main #challenge .stat-label,
main #challenge .stat-stack span,
main #challenge .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  font-family: var(--sans) !important;
}

main #challenge .stat-stack strong,
main #challenge .stat-value,
main #challenge .stat-card-dark .stat-stack strong,
main #challenge .stat-card-accent .stat-value {
  font-family: var(--sans) !important;
  font-size: clamp(28px, 3vw, 42px) !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  line-height: 1.05 !important;
}

main #challenge .stat-card-accent .stat-value {
  font-size: clamp(26px, 2.7vw, 38px) !important;
}

main #challenge .stat-label,
main #challenge .stat-stack span,
main #challenge .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  font-size: 15px !important;
  letter-spacing: 0 !important;
  line-height: 1.5 !important;
  text-transform: none !important;
}

@media (max-width: 680px) {
  main #challenge .stat-stack strong,
  main #challenge .stat-value,
  main #challenge .stat-card-dark .stat-stack strong,
  main #challenge .stat-card-accent .stat-value {
    font-size: clamp(26px, 8vw, 36px) !important;
  }
}

/*
 * Icon-font guard — MUST stay last.
 * The `* { font-family: var(--sans) !important }` typography locks above (e.g.
 * `main #challenge .stat-card *`) otherwise win over `.ph { font-family:"Phosphor" }`
 * and force the Phosphor PUA glyphs into the body font, rendering icons as empty boxes.
 * Keep these selectors specific enough (id + class chain) to beat those locks.
 */
main #challenge .stat-card i.ph,
main #challenge .stat-card .icon-badge i.ph,
main .stat-card i.ph,
main .icon-badge i.ph,
main .info-icon i.ph,
main .organisation-icon i.ph,
i.ph,
.ph {
  font-family: "Phosphor" !important;
}

/*
 * Workshops section only: centre the "WORKSHOP EXPERIENCES" eyebrow label.
 * The kicker uses `text-align: inherit`, and `.split-heading` resolves to
 * `text-align: left`, so the eyebrow sits left while the heading/description
 * (which set their own `text-align: center`) are centred. Force centre here,
 * id-scoped so it beats `main .split-heading .section-kicker` and stays local.
 */
#workshops .split-heading .section-kicker {
  text-align: center !important;
}

/* Cinematic handoff implementation: dark film palette, parallax layers, Ken Burns images, and pinned workshop reel. */
:root {
  --cine-bg: #04060f;
  --cine-bg-rgb: 4, 6, 15;
  --cine-panel: rgba(20, 26, 54, 0.68);
  --cine-panel-solid: #141a36;
  --cine-panel-2: #1d2547;
  --cine-line: rgba(255, 255, 255, 0.08);
  --cine-line-strong: rgba(151, 164, 247, 0.38);
  --cine-cream: #eceefb;
  --cine-muted: #aab0d4;
  --cine-muted-2: #8b91b8;
  --cine-accent: #97a4f7;
  --cine-accent-soft: #c3c9fb;
  --cine-warm: #f1c982;
  --cine-shadow: 0 34px 80px rgba(0, 0, 0, 0.38);
  --cres-bg: var(--cine-bg);
  --cres-bg-rgb: var(--cine-bg-rgb);
  --cres-bg-2: #080d1d;
  --cres-panel: var(--cine-panel-solid);
  --cres-panel-2: var(--cine-panel-2);
  --cres-line: var(--cine-line);
  --cres-line-strong: var(--cine-line-strong);
  --cres-cream: var(--cine-cream);
  --cres-cream-60: var(--cine-muted);
  --cres-cream-40: rgba(170, 176, 212, 0.5);
  --cres-lime: var(--cine-accent);
  --cres-lime-hot: var(--cine-accent-soft);
  --cres-accent-rgb: 151, 164, 247;
}

@keyframes cineKenBurns {
  0% {
    transform: scale(1.06) translate3d(0, 0, 0);
  }

  100% {
    transform: scale(1.2) translate3d(-2.5%, -3%, 0);
  }
}

@keyframes cineKenBurnsAlt {
  0% {
    transform: scale(1.08) translate3d(1%, 0, 0);
  }

  100% {
    transform: scale(1.19) translate3d(-1.5%, -2%, 0);
  }
}

body {
  background:
    radial-gradient(circle at 72% 0, rgba(151, 164, 247, 0.13), transparent 30rem),
    linear-gradient(180deg, #050814 0%, var(--cine-bg) 48%, #060a18 100%);
  color: var(--cine-cream);
}

.cinematic-vignette {
  box-shadow: inset 0 0 240px 60px rgba(0, 0, 0, 0.7);
  inset: 0;
  pointer-events: none;
  position: fixed;
  z-index: 120;
}

.scroll-progress {
  background: rgba(255, 255, 255, 0.04);
  height: 3px;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 220;
}

.scroll-progress > div {
  background: linear-gradient(90deg, var(--cine-accent), var(--cine-accent-soft));
  height: 100%;
  width: 0%;
}

.site-header,
.site-header.is-scrolled,
.site-header.is-open {
  background: rgba(var(--cine-bg-rgb), 0.78);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--cine-line);
  top: 3px;
}

.site-header.is-scrolled,
.site-header.is-open {
  background: rgba(var(--cine-bg-rgb), 0.9);
}

.brand-logo {
  border-color: var(--cine-line-strong);
  box-shadow: 0 0 0 1px rgba(151, 164, 247, 0.08);
}

.nav-links > a:not(.button),
.mobile-menu a:not(.button) {
  color: var(--cine-cream);
  opacity: 0.74;
}

.nav-links > a:hover,
.mobile-menu a:hover {
  color: var(--cine-accent-soft);
  opacity: 1;
}

.button {
  border-radius: 6px;
  letter-spacing: 0.08em;
}

.button-primary,
.nav-links .button-primary,
.mobile-menu .button-primary {
  background: var(--cine-accent);
  color: var(--cine-bg);
}

.button-primary:hover,
.nav-links .button-primary:hover,
.mobile-menu .button-primary:hover {
  background: var(--cine-accent-soft);
}

.button-ghost,
.button-outline {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.34);
  color: #fff;
}

.button-ghost:hover,
.button-outline:hover {
  background: rgba(151, 164, 247, 0.1);
  border-color: var(--cine-accent);
}

.hero {
  background: var(--cine-bg);
  min-height: 100svh;
  padding-top: 70px;
}

.hero-bg-photo {
  height: 118%;
  inset: -9% 0;
  max-width: none;
  opacity: 0.68;
  transform-origin: center;
  width: 100%;
  animation: cineKenBurns 24s ease-in-out infinite alternate;
  filter: brightness(0.92) saturate(0.95) contrast(1.08);
}

.hero-shade {
  background:
    radial-gradient(circle at 68% 30%, rgba(151, 164, 247, 0.16), transparent 26%),
    linear-gradient(180deg, rgba(var(--cine-bg-rgb), 0.38), rgba(var(--cine-bg-rgb), 0.58) 54%, var(--cine-bg));
}

.hero-vignette {
  background:
    linear-gradient(90deg, rgba(151, 164, 247, 0.06) 0 1px, transparent 1px) 0 0 / 80px 80px,
    linear-gradient(0deg, rgba(151, 164, 247, 0.05) 0 1px, transparent 1px) 0 0 / 80px 80px;
  opacity: 0.26;
}

.hero-copy {
  max-width: min(1180px, 92vw);
  text-shadow: 0 18px 52px rgba(0, 0, 0, 0.55);
  transform: translate3d(0, var(--parallax-y, 0px), 0);
  will-change: transform;
}

h1 {
  color: var(--cine-cream);
  font-size: 112px;
  line-height: 1;
  text-transform: uppercase;
}

.hero-lede {
  color: #d3d6ee;
  font-size: 18px;
  line-height: 1.6;
  margin: 28px auto 0;
  max-width: 540px;
}

.hero-actions {
  margin-top: 38px;
}

.section,
.section-cream,
.section-tint,
#challenge,
#approach,
#about,
.partners,
.testimonials {
  background: var(--cine-bg);
  border-top: 1px solid var(--cine-line);
}

.section-tint,
#approach,
#about,
.partners {
  background: #080d1d;
}

main .section-kicker,
main .section-heading .section-kicker,
main .split-heading .section-kicker,
main .about-copy .section-kicker,
main .partners .section-kicker,
main .testimonials .section-kicker,
main .final-cta .cta-kicker {
  color: var(--cine-accent) !important;
  font-size: 12px !important;
  letter-spacing: 0.28em !important;
}

main .section-heading h2,
main #challenge .section-heading h2,
main #approach .section-heading h2,
main .split-heading h2,
main .about-copy h2,
main .impact-grid h2,
main .final-cta h2 {
  color: var(--cine-cream);
  font-family: var(--display);
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1.05;
  text-transform: uppercase;
}

main .section-heading h2,
main #challenge .section-heading h2,
main #approach .section-heading h2,
main .split-heading h2 {
  font-size: 64px;
}

main .section-heading p,
main #challenge .section-heading p,
main .split-heading > p,
main .about-copy p:not(.section-kicker),
main .impact-grid p,
main .final-cta p {
  color: var(--cine-muted);
}

#challenge .section-heading,
#approach .section-heading {
  align-items: end;
  display: grid;
  gap: 32px;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.84fr);
  text-align: left;
}

#challenge .section-heading .section-kicker,
#approach .section-heading .section-kicker {
  grid-column: 1 / -1;
}

#challenge .section-heading h2,
#approach .section-heading h2 {
  max-width: 12ch !important;
  text-align: left !important;
}

#challenge .section-heading p {
  margin: 0 !important;
  max-width: 52ch !important;
  text-align: left !important;
}

.stats-grid {
  gap: 20px;
}

body main #challenge .stat-card,
body main .info-card,
body main .workshop-card,
body main .organisation-logo,
body main .testimonial-card {
  background: var(--cine-panel);
  border: 1px solid var(--cine-line);
  border-radius: 22px;
  box-shadow: none;
  backdrop-filter: blur(6px);
}

body main #challenge .stat-card {
  padding: 38px;
}

body main #challenge .stat-card:hover,
body main .info-card:hover,
body main .workshop-card:hover,
body main .organisation-logo:hover {
  border-color: var(--cine-line-strong);
  box-shadow: var(--cine-shadow);
  transform: translateY(-6px);
}

body main #challenge .stat-card-accent {
  background: linear-gradient(120deg, #3a44a0, #6470d8);
  border-color: transparent;
  color: #fff;
}

body main #challenge .stat-card,
body main #challenge .stat-card *,
body main #challenge .stat-label,
body main #challenge .stat-stack span,
body main #challenge .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  font-family: var(--sans) !important;
}

body main #challenge .stat-stack strong,
body main #challenge .stat-value,
body main #challenge .stat-card-dark .stat-stack strong,
body main #challenge .stat-card-accent .stat-value {
  color: var(--cine-cream);
  font-family: var(--display) !important;
  font-size: 86px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.95 !important;
}

body main #challenge .stat-card-dark .stat-stack p:first-child strong {
  color: var(--cine-accent);
}

body main #challenge .stat-card-accent .stat-value {
  color: #fff;
  font-size: 58px !important;
}

body main #challenge .stat-label {
  color: var(--cine-accent) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  line-height: 1.25 !important;
  text-transform: uppercase !important;
}

body main #challenge .stat-card-accent .stat-label,
body main #challenge .stat-card-accent .stat-accent-description {
  color: rgba(255, 255, 255, 0.86) !important;
}

body main #challenge .stat-stack span,
body main #challenge .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  color: var(--cine-muted) !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  text-transform: none !important;
}

body main #challenge .stat-card-accent > div:not(.stat-card-top):not(.stat-stack):not(.stat-accent-copy) > p {
  color: rgba(255, 255, 255, 0.82) !important;
}

body main #challenge .icon-badge {
  color: var(--cine-accent) !important;
}

body main #challenge .stat-card-accent .icon-badge {
  color: #fff !important;
}

#approach .approach-grid {
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body main .info-card,
body main #approach .info-card {
  gap: 0;
  min-height: 0;
  overflow: hidden;
  padding: 0;
}

.info-media {
  aspect-ratio: 1.55;
  border-bottom: 1px solid var(--cine-line);
  overflow: hidden;
}

.info-media img {
  height: 100%;
  object-fit: cover;
  transform: scale(1.03);
  transition: transform 900ms cubic-bezier(0.16, 1, 0.3, 1);
  width: 100%;
}

.info-card:hover .info-media img {
  transform: scale(1.11);
}

body main .info-icon,
body main #approach .info-icon {
  margin: 30px 30px 0;
}

body main .info-card h3,
body main #approach .info-card h3,
body main .info-card p,
body main #approach .info-card p {
  margin-left: 30px;
  margin-right: 30px;
}

body main .info-card h3,
body main #approach .info-card h3 {
  margin-top: 24px;
}

body main .info-card p,
body main #approach .info-card p {
  margin-bottom: 32px;
}

.workshop-card {
  border-radius: 18px;
}

.workshop-card > img,
.image-placeholder {
  height: 230px;
  object-fit: cover;
}

.workshop-card > img {
  transform: scale(1.01);
  transition: transform 900ms cubic-bezier(0.16, 1, 0.3, 1);
}

.workshop-card:hover > img {
  transform: scale(1.08);
}

.card-title-row span {
  background: var(--cine-accent);
  border-radius: 6px;
  color: var(--cine-bg);
  padding: 5px 9px;
}

.testimonial-card {
  background:
    linear-gradient(rgba(var(--cine-bg-rgb), 0.7), rgba(var(--cine-bg-rgb), 0.7)),
    url("images/open-mic-session.jpg") center / cover;
  overflow: hidden;
}

.portrait-wrap img {
  animation: cineKenBurnsAlt 28s ease-in-out infinite alternate;
  transform-origin: center;
}

.portrait-label {
  background: rgba(var(--cine-bg-rgb), 0.86);
  border: 1px solid var(--cine-line-strong);
  color: var(--cine-cream);
}

.portrait-label strong {
  color: var(--cine-accent);
}

.role-tags span {
  border-color: var(--cine-line-strong);
  border-radius: 30px;
  color: var(--cine-accent-soft);
}

.organisation-logo {
  background: var(--cine-panel);
}

.final-cta {
  align-items: center;
  background: var(--cine-bg);
  color: var(--cine-cream);
  display: flex;
  min-height: 100svh;
  overflow: hidden;
  padding: 110px 0;
  position: relative;
  text-align: center;
}

.cta-bg-wrap {
  inset: -12% 0;
  position: absolute;
  transform: translate3d(0, var(--parallax-y, 0px), 0);
  will-change: transform;
  z-index: 0;
}

.cta-bg-wrap::after {
  background: linear-gradient(180deg, rgba(var(--cine-bg-rgb), 0.58), rgba(var(--cine-bg-rgb), 0.88));
  content: "";
  inset: 0;
  position: absolute;
}

.cta-bg-photo {
  height: 100%;
  max-width: none;
  object-fit: cover;
  opacity: 0.76;
  width: 100%;
  animation: cineKenBurns 30s ease-in-out infinite alternate;
}

.final-cta .section-inner {
  position: relative;
  z-index: 1;
}

.cta-card,
.cta-card-inner {
  background: transparent;
  color: var(--cine-cream);
}

main .final-cta .cta-kicker {
  color: var(--cine-accent-soft) !important;
}

.final-cta h2,
main .final-cta h2 {
  color: var(--cine-cream);
  font-size: 104px;
  line-height: 1;
  max-width: 930px;
}

.final-cta h2 span {
  color: var(--cine-cream);
}

.final-cta p {
  color: #d3d6ee;
}

.final-cta .button-primary {
  background: var(--cine-accent);
  color: var(--cine-bg);
}

.final-cta .button-outline {
  border-color: rgba(255, 255, 255, 0.4);
  color: #fff;
}

.contact-links a {
  color: var(--cine-accent-soft);
}

.contact-links a::before {
  background: var(--cine-accent);
}

.js .reveal,
.js .hero-reveal {
  filter: blur(10px);
  transform: translateY(40px);
  transition:
    opacity 1100ms cubic-bezier(0.16, 1, 0.3, 1),
    transform 1100ms cubic-bezier(0.16, 1, 0.3, 1),
    filter 1100ms cubic-bezier(0.16, 1, 0.3, 1);
}

.js .reveal.is-visible,
.js .hero-reveal.is-visible {
  filter: blur(0);
  transform: none;
}

.hero-reveal:nth-child(1) {
  transition-delay: 120ms;
}

.hero-reveal:nth-child(2) {
  transition-delay: 360ms;
}

.hero-reveal:nth-child(3) {
  transition-delay: 620ms;
}

@media (min-width: 900px) {
  #workshops[data-hscroll] {
    height: 420vh;
    overflow: clip;
    padding: 0;
  }

  #workshops[data-hscroll] [data-hsticky] {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    height: 100svh;
    justify-content: center;
    max-width: none;
    overflow: hidden;
    padding: 92px 0 64px;
    position: sticky;
    top: 0;
  }

  #workshops[data-hscroll] .split-heading {
    flex: 0 0 auto;
    margin: 0 0 36px;
    max-width: 1140px !important;
    padding: 0 clamp(32px, 4vw, 56px);
    text-align: left;
  }

  #workshops[data-hscroll] .split-heading > div,
  #workshops[data-hscroll] .split-heading > p,
  #workshops[data-hscroll] .split-heading h2 {
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: 760px !important;
    text-align: left !important;
  }

  #workshops .split-heading .section-kicker {
    text-align: left !important;
  }

  #workshops[data-hscroll] [data-htrack] {
    display: flex;
    gap: 22px;
    grid-template-columns: none;
    padding: 0 clamp(32px, 4vw, 56px) 8px;
    transform: translate3d(var(--hscroll-x, 0px), 0, 0);
    transition: transform 80ms linear;
    width: max-content;
    will-change: transform;
  }

  #workshops[data-hscroll] .workshop-card {
    flex: 0 0 360px;
    min-height: 0;
  }
}

@media (max-width: 1180px) {
  h1 {
    font-size: 88px;
  }

  main .section-heading h2,
  main #challenge .section-heading h2,
  main #approach .section-heading h2,
  main .split-heading h2 {
    font-size: 54px;
  }

  .final-cta h2,
  main .final-cta h2 {
    font-size: 82px;
  }
}

@media (max-width: 1080px) {
  #challenge .section-heading,
  #approach .section-heading {
    align-items: start;
    grid-template-columns: 1fr;
  }

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

  body main #challenge .stat-stack strong,
  body main #challenge .stat-value,
  body main #challenge .stat-card-dark .stat-stack strong,
  body main #challenge .stat-card-accent .stat-value {
    font-size: 72px !important;
  }
}

@media (max-width: 860px) {
  .cinematic-vignette {
    box-shadow: inset 0 0 160px 30px rgba(0, 0, 0, 0.62);
  }

  .hero {
    padding-top: 62px;
  }

  h1 {
    font-size: 66px;
  }

  main .section-heading h2,
  main #challenge .section-heading h2,
  main #approach .section-heading h2,
  main .split-heading h2,
  main .about-copy h2,
  main .impact-grid h2 {
    font-size: 46px;
  }

  #approach .approach-grid {
    grid-template-columns: 1fr;
  }

  .final-cta h2,
  main .final-cta h2 {
    font-size: 66px;
  }
}

@media (max-width: 680px) {
  .hero-copy {
    text-align: left;
  }

  h1 {
    font-size: 46px;
    line-height: 1.04;
  }

  .hero-lede {
    font-size: 17px;
    margin-left: 0;
  }

  main .section-heading h2,
  main #challenge .section-heading h2,
  main #approach .section-heading h2,
  main .split-heading h2,
  main .about-copy h2,
  main .impact-grid h2 {
    font-size: 38px;
    line-height: 1.08;
  }

  body main #challenge .stat-card {
    padding: 28px 24px;
  }

  body main #challenge .stat-stack strong,
  body main #challenge .stat-value,
  body main #challenge .stat-card-dark .stat-stack strong,
  body main #challenge .stat-card-accent .stat-value {
    font-size: 54px !important;
  }

  body main .info-icon,
  body main #approach .info-icon,
  body main .info-card h3,
  body main #approach .info-card h3,
  body main .info-card p,
  body main #approach .info-card p {
    margin-left: 24px;
    margin-right: 24px;
  }

  .final-cta {
    min-height: auto;
    padding: 96px 0;
  }

  .final-cta h2,
  main .final-cta h2 {
    font-size: 48px;
    line-height: 1.04;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-bg-photo,
  .cta-bg-photo,
  .portrait-wrap img {
    animation: none !important;
  }

  [data-parallax] {
    transform: none !important;
  }

  #workshops[data-hscroll] {
    height: auto;
  }

  #workshops[data-hscroll] [data-hsticky] {
    height: auto;
    position: static;
  }

  #workshops[data-hscroll] [data-htrack] {
    transform: none !important;
    width: auto;
  }
}

/* Cinematic hero lock: match the shared 02 Cinematic hero while keeping the chosen logo and background image. */
main .hero {
  align-items: center !important;
  display: flex !important;
  justify-content: center !important;
  min-height: 100svh !important;
  overflow: hidden !important;
  padding-top: 0 !important;
}

main .hero-inner {
  align-items: center !important;
  display: flex !important;
  justify-content: center !important;
  min-height: 100svh !important;
  padding: 104px 40px 92px !important;
}

main .hero-copy {
  max-width: min(1180px, 100%) !important;
  padding: 0 !important;
  text-align: center !important;
}

main .hero-kicker {
  color: var(--cine-accent-soft);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.48em;
  line-height: 1.25;
  margin: 0 0 28px;
  text-transform: uppercase;
}

main #hero-title {
  color: var(--cine-cream);
  font-family: var(--display);
  font-size: clamp(46px, 10vw, 150px) !important;
  font-weight: 400;
  letter-spacing: 1px;
  line-height: 1 !important;
  margin: 0 auto;
  max-width: none !important;
  text-align: center;
  text-transform: uppercase;
}

main .hero-title-line {
  display: block;
}

main .hero-title-accent {
  color: var(--cine-accent);
}

main .hero-lede {
  color: #d3d6ee !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
  margin: 28px auto 0 !important;
  max-width: 540px !important;
  text-align: center !important;
}

main .hero-actions {
  gap: 16px !important;
  justify-content: center !important;
  margin-top: 38px !important;
}

main .hero .button {
  min-height: 52px;
  padding: 17px 34px;
}

@media (max-width: 860px) {
  main .hero-inner {
    padding: 96px 24px 86px !important;
  }

  main #hero-title {
    font-size: clamp(42px, 13vw, 88px) !important;
  }
}

@media (max-width: 680px) {
  main .hero-copy {
    text-align: center !important;
  }

  main .hero-kicker {
    font-size: 10px;
    letter-spacing: 0.34em;
    margin-bottom: 22px;
  }

  main #hero-title {
    font-size: clamp(38px, 13vw, 62px) !important;
    line-height: 1.02 !important;
  }

  main .hero-lede {
    font-size: 16px !important;
    margin-left: auto !important;
    max-width: 32ch !important;
  }

  main .hero-actions {
    align-items: stretch !important;
    flex-direction: column !important;
    margin-left: auto;
    margin-right: auto;
    max-width: 330px;
  }

  main .hero .button {
    width: 100%;
  }
}

/* Hero/nav reference match: transparent cinematic nav and stronger Anton display scale. */
body .site-header,
body .site-header.is-open {
  background: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  color: var(--cine-cream) !important;
  top: 3px;
}

body .site-header.is-scrolled {
  background: rgba(var(--cine-bg-rgb), 0.82) !important;
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--cine-line) !important;
}

body .nav {
  max-width: none;
  padding: 24px 48px;
}

body .nav-links {
  gap: 38px;
}

body .nav-links > a:not(.button) {
  color: #c4c8e4;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.26em;
  opacity: 1;
}

body .nav-links .button-primary {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: 999px;
  color: #fff;
  min-height: 42px;
  padding: 12px 24px;
}

body .nav-links .button-primary:hover {
  background: rgba(151, 164, 247, 0.12);
  border-color: var(--cine-accent);
}

main #hero-title {
  font-size: clamp(66px, 9.25vw, 150px) !important;
  letter-spacing: 1px;
  line-height: 1 !important;
}

main .hero-kicker {
  letter-spacing: 0.52em;
}

main .hero-title-line {
  white-space: nowrap;
}

main .hero-lede {
  margin-top: 30px !important;
}

main .hero-actions {
  margin-top: 48px !important;
}

@media (max-width: 1180px) {
  main #hero-title {
    font-size: clamp(54px, 9vw, 108px) !important;
  }
}

@media (max-width: 860px) {
  body .nav {
    padding: 16px 22px;
  }

}

@media (max-width: 680px) {
  main .hero-title-line {
    white-space: normal;
  }

  main #hero-title {
    font-size: clamp(40px, 12.5vw, 62px) !important;
  }

  main .hero-kicker {
    letter-spacing: 0.34em;
  }
}

/* Cinematic challenge section reference match. */
main #challenge {
  background: #04060f !important;
  border-top: 1px solid rgba(151, 164, 247, 0.12) !important;
  padding: 132px 0 144px !important;
}

main #challenge .section-inner {
  max-width: 1320px !important;
}

main #challenge .section-heading {
  display: block !important;
  margin: 0 0 76px !important;
  max-width: 980px !important;
  text-align: left !important;
}

main #challenge .section-heading .section-kicker {
  color: var(--cine-accent) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.48em !important;
  margin: 0 0 32px !important;
  text-align: left !important;
  text-transform: uppercase !important;
}

main #challenge .section-heading h2 {
  color: var(--cine-cream) !important;
  font-family: var(--display) !important;
  font-size: clamp(62px, 5.2vw, 88px) !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 1.02 !important;
  margin: 0 !important;
  max-width: 950px !important;
  text-align: left !important;
  text-transform: uppercase !important;
}

main #challenge .section-heading p {
  color: var(--cine-muted) !important;
  font-size: 20px !important;
  line-height: 1.72 !important;
  margin: 36px 0 0 !important;
  max-width: 780px !important;
  text-align: left !important;
}

main #challenge .stats-grid {
  align-items: stretch !important;
  display: grid !important;
  gap: 24px !important;
  grid-auto-rows: minmax(230px, auto) !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.5fr) minmax(260px, 0.5fr) !important;
}

body main #challenge .stat-card {
  background:
    radial-gradient(circle at 100% 0, rgba(151, 164, 247, 0.08), transparent 42%),
    rgba(20, 26, 54, 0.72) !important;
  border: 1px solid rgba(151, 164, 247, 0.14) !important;
  border-radius: 22px !important;
  box-shadow: none !important;
  color: var(--cine-cream) !important;
  min-height: 230px !important;
  padding: 38px 40px !important;
  position: relative !important;
}

body main #challenge .stat-card-dark {
  grid-column: 1 / 2 !important;
  grid-row: 1 / span 2 !important;
  justify-content: flex-start !important;
  min-height: 496px !important;
  padding: 48px !important;
}

body main #challenge .stat-card:nth-child(2),
body main #challenge .stat-card:nth-child(3) {
  grid-column: auto !important;
  grid-row: 1 / 2 !important;
}

body main #challenge .stat-card-accent {
  align-items: center !important;
  background: linear-gradient(120deg, #35409d 0%, #6370d8 100%) !important;
  border-color: transparent !important;
  display: grid !important;
  grid-column: 2 / 4 !important;
  grid-row: 2 / 3 !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  min-height: 232px !important;
  padding: 44px 48px !important;
}

body main #challenge .stat-card > .icon-badge {
  display: none !important;
}

body main #challenge .stat-card-dark .stat-card-top .icon-badge,
body main #challenge .stat-card-accent .stat-card-top .icon-badge {
  display: none !important;
}

body main #challenge .stat-card-top {
  margin: 0 !important;
}

body main #challenge .stat-label,
body main #challenge .stat-chip {
  color: var(--cine-accent) !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.22em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

body main #challenge .stat-chip {
  align-self: flex-start !important;
  border: 1px solid rgba(151, 164, 247, 0.44) !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  margin: 0 0 auto !important;
  padding: 7px 12px !important;
  width: fit-content !important;
}

body main #challenge .stat-stack {
  display: grid !important;
  gap: 0 !important;
  margin-top: 44px !important;
}

body main #challenge .stat-stack p {
  align-items: baseline !important;
  display: grid !important;
  gap: 22px !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  padding: 0 !important;
}

body main #challenge .stat-stack p + p {
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  margin-top: 40px !important;
  padding-top: 40px !important;
}

body main #challenge .stat-stack strong,
body main #challenge .stat-card-dark .stat-stack strong {
  color: var(--cine-cream) !important;
  font-family: var(--display) !important;
  font-size: clamp(86px, 8vw, 128px) !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.9 !important;
}

body main #challenge .stat-card-dark .stat-stack p:last-child strong {
  color: #8f99dd !important;
}

body main #challenge .stat-stack span {
  color: var(--cine-muted) !important;
  font-size: 17px !important;
  line-height: 1.45 !important;
  max-width: 25ch !important;
}

body main #challenge .stat-value {
  color: var(--cine-cream) !important;
  font-family: var(--display) !important;
  font-size: clamp(56px, 3.8vw, 72px) !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.95 !important;
  margin-top: 34px !important;
}

body main #challenge .stat-card:not(.stat-card-dark):not(.stat-card-accent) {
  justify-content: space-between !important;
}

body main #challenge .stat-card:not(.stat-card-dark):not(.stat-card-accent) > div {
  margin-top: auto !important;
}

body main #challenge .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  color: var(--cine-muted) !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  margin-top: 14px !important;
  max-width: 21ch !important;
}

body main #challenge .stat-card-accent .stat-card-top {
  grid-column: 1 / 2 !important;
}

body main #challenge .stat-card-accent .stat-label {
  color: rgba(235, 238, 255, 0.76) !important;
}

body main #challenge .stat-card-accent > .stat-accent-copy {
  display: block !important;
}

body main #challenge .stat-card-accent .stat-value {
  color: rgba(236, 238, 251, 0.78) !important;
  font-size: clamp(72px, 6.4vw, 106px) !important;
  grid-column: 2 / 3 !important;
  grid-row: 1 / span 2 !important;
  margin: 0 !important;
  white-space: nowrap !important;
}

body main #challenge .stat-card-accent .stat-accent-description {
  color: rgba(236, 238, 251, 0.78) !important;
  font-size: 18px !important;
  grid-column: auto !important;
  line-height: 1.55 !important;
  margin: 18px 0 0 !important;
  max-width: 33ch !important;
}

@media (max-width: 1080px) {
  main #challenge .section-heading h2 {
    font-size: clamp(46px, 7vw, 70px) !important;
  }

  main #challenge .stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body main #challenge .stat-card-dark,
  body main #challenge .stat-card-accent {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
  }

  body main #challenge .stat-card-accent {
    grid-template-columns: 1fr !important;
  }

  body main #challenge .stat-card-accent .stat-value,
  body main #challenge .stat-card-accent .stat-accent-description {
    grid-column: auto !important;
    grid-row: auto !important;
  }
}

@media (max-width: 680px) {
  main #challenge {
    padding: 88px 0 96px !important;
  }

  main #challenge .section-heading {
    margin-bottom: 48px !important;
  }

  main #challenge .section-heading .section-kicker {
    letter-spacing: 0.32em !important;
    margin-bottom: 22px !important;
  }

  main #challenge .section-heading h2 {
    font-size: clamp(38px, 12vw, 54px) !important;
  }

  main #challenge .section-heading p {
    font-size: 17px !important;
    line-height: 1.6 !important;
    margin-top: 24px !important;
  }

  main #challenge .stats-grid {
    grid-template-columns: 1fr !important;
  }

  body main #challenge .stat-card,
  body main #challenge .stat-card-dark,
  body main #challenge .stat-card-accent {
    min-height: auto !important;
    padding: 30px 24px !important;
  }

  body main #challenge .stat-stack p {
    grid-template-columns: 1fr !important;
  }

  body main #challenge .stat-stack strong,
  body main #challenge .stat-card-dark .stat-stack strong,
  body main #challenge .stat-card-accent .stat-value {
    font-size: clamp(58px, 18vw, 82px) !important;
  }
}

/* Kinetic challenge section implementation from 01 Kinetic, with Phosphor icons. */
main #challenge {
  background: #060912 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
  padding: 120px 0 !important;
}

main #challenge .section-inner {
  max-width: 1180px !important;
  padding-left: 44px !important;
  padding-right: 44px !important;
}

main #challenge .section-heading {
  align-items: end !important;
  display: grid !important;
  gap: 48px !important;
  grid-template-columns: 1.1fr 1fr !important;
  margin: 0 !important;
  max-width: none !important;
  text-align: left !important;
}

main #challenge .section-heading .section-kicker {
  color: #97a4f7 !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  grid-column: 1 / -1 !important;
  letter-spacing: 0.26em !important;
  line-height: 1.2 !important;
  margin: 0 0 -22px !important;
  text-align: left !important;
  text-transform: uppercase !important;
}

main #challenge .section-heading h2 {
  color: #eceefb !important;
  font-family: var(--display) !important;
  font-size: clamp(34px, 5vw, 68px) !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 1.05 !important;
  margin: 0 !important;
  max-width: none !important;
  text-align: left !important;
  text-transform: uppercase !important;
}

main #challenge .section-heading p {
  color: #a7accb !important;
  font-family: var(--sans) !important;
  font-size: 17px !important;
  line-height: 1.7 !important;
  margin: 0 !important;
  max-width: none !important;
  text-align: left !important;
}

main #challenge .stats-grid {
  align-items: stretch !important;
  display: grid !important;
  gap: 20px !important;
  grid-auto-rows: minmax(230px, auto) !important;
  grid-template-columns: 1.15fr 1fr 1fr !important;
  margin-top: 64px !important;
}

body main #challenge .stat-card,
body main #challenge .stat-card-dark,
body main #challenge .stat-card-accent {
  background: #141a36 !important;
  border: 1px solid rgba(255, 255, 255, 0.07) !important;
  border-radius: 22px !important;
  box-shadow: none !important;
  color: #eceefb !important;
  min-height: 230px !important;
  overflow: hidden !important;
  padding: 34px !important;
  transform: none;
}

body main #challenge .stat-card:hover,
body main #challenge .stat-card-dark:hover,
body main #challenge .stat-card-accent:hover {
  border-color: rgba(151, 164, 247, 0.34) !important;
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.28) !important;
  transform: translateY(-4px);
}

body main #challenge .stat-card-dark {
  display: flex !important;
  flex-direction: column !important;
  grid-column: auto !important;
  grid-row: span 2 !important;
  justify-content: center !important;
  min-height: 480px !important;
  padding: 44px !important;
}

body main #challenge .stat-card:nth-child(2),
body main #challenge .stat-card:nth-child(3) {
  display: flex !important;
  flex-direction: column !important;
  grid-column: auto !important;
  grid-row: auto !important;
  justify-content: space-between !important;
}

body main #challenge .stat-card-accent {
  align-items: center !important;
  background: linear-gradient(120deg, #3a44a0, #5560cf) !important;
  border-color: transparent !important;
  display: flex !important;
  gap: 40px !important;
  grid-column: span 2 !important;
  grid-row: auto !important;
  justify-content: space-between !important;
  min-height: 230px !important;
  padding: 42px !important;
}

body main #challenge .stat-card-top,
body main #challenge .stat-mini-head {
  align-items: center !important;
  display: flex !important;
  gap: 10px !important;
  justify-content: space-between !important;
  margin: 0 !important;
}

body main #challenge .stat-card-dark .stat-card-top,
body main #challenge .stat-card-accent .stat-card-top {
  justify-content: flex-start !important;
}

body main #challenge .icon-badge,
body main #challenge .stat-card > .icon-badge,
body main #challenge .stat-card-dark .stat-card-top .icon-badge,
body main #challenge .stat-card-accent .stat-card-top .icon-badge,
body main #challenge .stat-mini-head .icon-badge {
  color: #97a4f7 !important;
  display: inline-flex !important;
  flex: 0 0 auto !important;
  height: auto !important;
  width: auto !important;
}

body main #challenge .stat-card-accent .icon-badge {
  color: #dfe2ff !important;
}

body main #challenge .icon-badge i,
body main #challenge .stat-mini-head .icon-badge i {
  display: block !important;
  font-family: "Phosphor" !important;
  font-size: 24px !important;
  line-height: 1 !important;
}

body main #challenge .stat-label {
  color: #97a4f7 !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  text-transform: uppercase !important;
}

body main #challenge .stat-chip {
  align-items: center !important;
  border: 1px solid rgba(151, 164, 247, 0.35) !important;
  border-radius: 30px !important;
  color: #97a4f7 !important;
  display: inline-flex !important;
  font-family: var(--sans) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.15em !important;
  line-height: 1 !important;
  padding: 6px 11px !important;
  text-transform: uppercase !important;
  width: fit-content !important;
}

body main #challenge .stat-stack {
  display: block !important;
  margin-top: 38px !important;
}

body main #challenge .stat-stack p {
  align-items: flex-start !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  margin: 0 !important;
  padding: 0 !important;
}

body main #challenge .stat-stack p + p {
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  margin-top: 36px !important;
  padding-top: 36px !important;
}

body main #challenge .stat-stack strong,
body main #challenge .stat-card-dark .stat-stack strong {
  color: #fff !important;
  flex: 0 0 auto !important;
  font-family: var(--display) !important;
  font-size: 92px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.85 !important;
  white-space: nowrap !important;
}

body main #challenge .stat-card-dark .stat-stack p:last-child strong {
  color: #97a4f7 !important;
}

body main #challenge .stat-stack span {
  color: #a7accb !important;
  flex: 0 1 auto !important;
  font-family: var(--sans) !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
  max-width: 34ch !important;
  min-width: 0 !important;
  text-transform: none !important;
  white-space: normal !important;
}

body main #challenge .stat-value {
  color: #fff !important;
  display: block !important;
  font-family: var(--display) !important;
  font-size: 56px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.9 !important;
  margin: 0 !important;
  white-space: nowrap !important;
}

body main #challenge .stat-card:not(.stat-card-dark):not(.stat-card-accent) > div:last-child {
  margin-top: auto !important;
}

body main #challenge .stat-card > div:not(.stat-card-top):not(.stat-stack) > p {
  color: #9298bd !important;
  font-family: var(--sans) !important;
  font-size: 13.5px !important;
  line-height: 1.55 !important;
  margin: 12px 0 0 !important;
  max-width: none !important;
  text-transform: none !important;
  white-space: normal !important;
}

body main #challenge .stat-card-accent .stat-card-top {
  align-items: center !important;
  display: inline-flex !important;
  flex: 0 0 auto !important;
  gap: 8px !important;
  justify-content: flex-start !important;
  margin: 0 !important;
}

body main #challenge .stat-card-accent .stat-card-top .icon-badge {
  display: inline-flex !important;
  margin: 0 !important;
}

body main #challenge .stat-card-accent .stat-label {
  color: #dfe2ff !important;
  display: inline !important;
}

body main #challenge .stat-card-accent .stat-accent-copy {
  display: block !important;
  flex: 1 1 380px !important;
  min-width: 0 !important;
}

body main #challenge .stat-card-accent .stat-value {
  color: #fff !important;
  flex: 0 0 auto !important;
  font-family: var(--display) !important;
  font-size: 76px !important;
  font-weight: 400 !important;
  line-height: 0.9 !important;
  margin: 0 !important;
  order: 2 !important;
  white-space: nowrap !important;
}

body main #challenge .stat-card-accent .stat-accent-copy > p {
  color: #eef0ff !important;
  flex: 1 1 380px !important;
  font-family: var(--sans) !important;
  font-size: 16px !important;
  line-height: 1.55 !important;
  margin: 16px 0 0 !important;
  max-width: 380px !important;
  min-width: 0 !important;
  order: 1 !important;
  text-transform: none !important;
  white-space: normal !important;
}

@media (max-width: 1080px) {
  main #challenge .section-heading {
    grid-template-columns: 1fr !important;
  }

  main #challenge .section-heading .section-kicker {
    margin-bottom: -8px !important;
  }

  main #challenge .stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body main #challenge .stat-card-dark,
  body main #challenge .stat-card-accent {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 760px) {
  main #challenge {
    padding: 88px 0 !important;
  }

  main #challenge .section-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  main #challenge .stats-grid {
    grid-template-columns: 1fr !important;
    margin-top: 44px !important;
  }

  body main #challenge .stat-card,
  body main #challenge .stat-card-dark,
  body main #challenge .stat-card-accent {
    min-height: auto !important;
    padding: 28px 24px !important;
  }

  body main #challenge .stat-stack p,
  body main #challenge .stat-card-accent {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  body main #challenge .stat-card-accent .stat-accent-copy > p {
    min-width: 0 !important;
  }
}

/* Locked challenge grid: tall left metric, two top cards, short prevention card. */
@media (min-width: 1081px) {
  main #challenge .stats-grid {
    align-items: start !important;
    grid-auto-rows: auto !important;
    grid-template-columns: 1.15fr 1fr 1fr !important;
    grid-template-rows: 230px 230px !important;
  }

  body main #challenge .stat-card-dark {
    align-self: stretch !important;
    grid-column: 1 / 2 !important;
    grid-row: 1 / 3 !important;
    height: 480px !important;
    min-height: 480px !important;
  }

  body main #challenge .stat-card:nth-child(2),
  body main #challenge .stat-card:nth-child(3) {
    align-self: stretch !important;
    height: 230px !important;
    min-height: 230px !important;
  }

  body main #challenge .stat-card:nth-child(2) {
    grid-column: 2 / 3 !important;
    grid-row: 1 / 2 !important;
  }

  body main #challenge .stat-card:nth-child(3) {
    grid-column: 3 / 4 !important;
    grid-row: 1 / 2 !important;
  }

  body main #challenge .stat-card-accent {
    align-self: start !important;
    flex-direction: row !important;
    grid-column: 2 / 4 !important;
    grid-row: 2 / 3 !important;
    height: 230px !important;
    max-height: 230px !important;
    min-height: 230px !important;
    text-align: left !important;
  }

  body main #challenge .stat-card-accent .stat-accent-copy {
    flex: 1 1 380px !important;
    text-align: left !important;
  }

  body main #challenge .stat-card-accent .stat-card-top {
    text-align: left !important;
  }

  body main #challenge .stat-card-accent .stat-value {
    align-self: center !important;
    font-size: clamp(60px, 4.8vw, 76px) !important;
  }
}

@media (min-width: 761px) and (max-width: 1080px) {
  main #challenge .stats-grid {
    align-items: start !important;
    grid-auto-rows: auto !important;
  }

  body main #challenge .stat-card-accent {
    align-self: start !important;
    flex-direction: row !important;
    height: 230px !important;
    min-height: 230px !important;
    text-align: left !important;
  }
}

/* Final prevention-card reset: keeps the copy horizontal and the range in Anton. */
html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent {
  align-items: center !important;
  background: linear-gradient(120deg, #3a44a0 0%, #5560cf 100%) !important;
  border-color: transparent !important;
  display: flex !important;
  gap: 32px !important;
  justify-content: space-between !important;
  overflow: hidden !important;
  padding: 42px 46px !important;
  text-align: left !important;
}

html body main#main #challenge .stats-grid > article.stat-card {
  align-content: center !important;
}

html body main#main #challenge .stats-grid > article.stat-card:not(.stat-card-dark):not(.stat-card-accent) {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

html body main#main #challenge .stats-grid > article.stat-card:not(.stat-card-dark):not(.stat-card-accent) > div:last-child {
  margin-top: 34px !important;
}

html body main#main #challenge .stats-grid > article.stat-card-dark {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent > .stat-accent-copy {
  display: block !important;
  flex: 1 1 320px !important;
  grid-column: auto !important;
  grid-row: auto !important;
  max-width: 350px !important;
  min-width: 0 !important;
  order: 0 !important;
  text-align: left !important;
  width: auto !important;
}

html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-card-top {
  align-items: center !important;
  display: inline-flex !important;
  gap: 8px !important;
  grid-column: auto !important;
  grid-row: auto !important;
  justify-content: flex-start !important;
  margin: 0 !important;
  text-align: left !important;
}

html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-label {
  color: #dfe2ff !important;
  display: inline !important;
  flex: 0 0 auto !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  max-width: none !important;
  order: 0 !important;
  text-transform: uppercase !important;
  white-space: normal !important;
  width: auto !important;
}

html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-accent-description {
  color: #eef0ff !important;
  display: block !important;
  flex: 0 1 auto !important;
  font-family: var(--sans) !important;
  font-size: 16px !important;
  grid-column: auto !important;
  grid-row: auto !important;
  letter-spacing: 0 !important;
  line-height: 1.55 !important;
  margin: 16px 0 0 !important;
  max-width: 350px !important;
  min-width: 0 !important;
  order: 0 !important;
  overflow-wrap: normal !important;
  text-align: left !important;
  text-transform: none !important;
  white-space: normal !important;
  width: auto !important;
  word-break: normal !important;
  writing-mode: horizontal-tb !important;
}

html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-accent-value {
  align-self: center !important;
  color: #fff !important;
  display: block !important;
  flex: 0 0 auto !important;
  font-family: "Anton", Impact, sans-serif !important;
  font-size: clamp(64px, 4.8vw, 76px) !important;
  font-weight: 400 !important;
  grid-column: auto !important;
  grid-row: auto !important;
  letter-spacing: 0 !important;
  line-height: 0.9 !important;
  margin: 0 !important;
  order: 0 !important;
  text-align: right !important;
  white-space: nowrap !important;
}

@media (min-width: 1081px) {
  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent {
    grid-column: 2 / 4 !important;
    grid-row: 2 / 3 !important;
    height: 230px !important;
    max-height: 230px !important;
    min-height: 230px !important;
  }
}

@media (max-width: 760px) {
  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent {
    align-items: flex-start !important;
    flex-direction: column !important;
    height: auto !important;
    max-height: none !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-accent-value {
    text-align: left !important;
  }
}

/* Approach heading: use the full content container and center the title. */
html body main#main #approach .section-heading {
  display: block !important;
  margin: 0 auto 72px !important;
  max-width: var(--site-container) !important;
  text-align: center !important;
  width: 100% !important;
}

html body main#main #approach .section-heading .section-kicker {
  display: block !important;
  margin: 0 auto 34px !important;
  text-align: center !important;
  width: 100% !important;
}

html body main#main #approach .section-heading h2 {
  margin: 0 auto !important;
  max-width: 1180px !important;
  text-align: center !important;
  width: 100% !important;
}

@media (max-width: 760px) {
  html body main#main #approach .section-heading {
    margin-bottom: 48px !important;
  }

  html body main#main #approach .section-heading h2 {
    max-width: 100% !important;
  }
}

/* Workshops heading: centered over the full section container. */
html body main#main #workshops[data-hscroll] .split-heading {
  align-items: center !important;
  display: flex !important;
  flex-direction: column !important;
  margin: 0 auto 44px !important;
  max-width: var(--site-container) !important;
  padding-left: clamp(32px, 4vw, 56px) !important;
  padding-right: clamp(32px, 4vw, 56px) !important;
  text-align: center !important;
  width: 100% !important;
}

html body main#main #workshops[data-hscroll] .split-heading > div,
html body main#main #workshops[data-hscroll] .split-heading h2 {
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 1180px !important;
  text-align: center !important;
  width: 100% !important;
}

html body main#main #workshops .split-heading .section-kicker {
  display: block !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

html body main#main #workshops[data-hscroll] .split-heading > p {
  display: none !important;
}

/* Creative motion ticker between help and workshop sections. */
html body main#main .creative-ticker {
  background: #080d1d !important;
  border-bottom: 1px solid var(--cine-line) !important;
  border-top: 1px solid var(--cine-line) !important;
  color: #97a4f7 !important;
  overflow: hidden !important;
  position: relative !important;
  width: 100% !important;
}

html body main#main .creative-ticker-track {
  animation: wtmaTickerScroll 24s linear infinite !important;
  display: flex !important;
  width: max-content !important;
  will-change: transform !important;
}

html body main#main .creative-ticker-track span {
  flex: 0 0 auto !important;
  font-family: "Anton", Impact, sans-serif !important;
  font-size: clamp(30px, 3vw, 48px) !important;
  font-weight: 400 !important;
  letter-spacing: 0.08em !important;
  line-height: 1 !important;
  padding: 24px 0 !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

@keyframes wtmaTickerScroll {
  from {
    transform: translateX(0);
  }

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

@media (prefers-reduced-motion: reduce) {
  html body main#main .creative-ticker-track {
    animation: none !important;
    transform: translateX(0) !important;
  }
}

/* Testimonials: fixed-height carousel card with italic quote text. */
html body main#main .testimonials .testimonial-card {
  align-items: center !important;
  display: flex !important;
  flex-direction: column !important;
  height: clamp(390px, 30vw, 470px) !important;
  justify-content: center !important;
  min-height: 0 !important;
  padding: clamp(34px, 4vw, 56px) !important;
}

html body main#main .testimonials .testimonial-card blockquote {
  align-items: center !important;
  display: flex !important;
  flex: 0 0 auto !important;
  flex-direction: column !important;
  justify-content: center !important;
  margin: 0 !important;
  max-width: 960px !important;
  text-align: center !important;
  width: 100% !important;
}

html body main#main .testimonials .testimonial-card blockquote p {
  align-items: center !important;
  display: flex !important;
  font-style: italic !important;
  justify-content: center !important;
  margin: 0 auto 32px !important;
  min-height: calc(1.45em * 3) !important;
}

html body main#main .testimonials .testimonial-controls {
  flex: 0 0 auto !important;
  margin-top: 42px !important;
}

@media (max-width: 760px) {
  html body main#main .testimonials .testimonial-card {
    height: 430px !important;
    padding: 30px 22px !important;
  }

html body main#main .testimonials .testimonial-card blockquote p {
    min-height: calc(1.45em * 4) !important;
  }
}

/* Shared section container width: Challenge uses the same edges as the rest. */
html body main#main #challenge > .section-inner {
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: var(--site-container) !important;
  padding-left: 32px !important;
  padding-right: 32px !important;
  width: 100% !important;
}

@media (max-width: 760px) {
  html body main#main #challenge > .section-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

/* Compact Kinetic-style footer CTA. */
html body main#main .final-cta {
  align-items: center !important;
  background: #a8b2f6 !important;
  color: #080d1d !important;
  display: flex !important;
  min-height: auto !important;
  overflow: hidden !important;
  padding: clamp(72px, 8vw, 112px) 0 clamp(64px, 7vw, 96px) !important;
  position: relative !important;
  text-align: center !important;
}

html body main#main .final-cta::before {
  background: rgba(124, 137, 226, 0.18) !important;
  clip-path: polygon(50% 0, 63% 38%, 100% 38%, 70% 61%, 82% 100%, 50% 76%, 18% 100%, 30% 61%, 0 38%, 37% 38%) !important;
  content: "" !important;
  display: block !important;
  height: clamp(180px, 24vw, 360px) !important;
  left: clamp(-90px, -5vw, -28px) !important;
  position: absolute !important;
  top: auto !important;
  bottom: -18% !important;
  transform: rotate(-8deg) !important;
  width: clamp(180px, 24vw, 360px) !important;
  z-index: 0 !important;
}

html body main#main .final-cta::after,
html body main#main .final-cta .cta-bg-wrap {
  display: none !important;
}

html body main#main .final-cta .section-inner {
  max-width: var(--site-container) !important;
  padding-left: 32px !important;
  padding-right: 32px !important;
  position: relative !important;
  z-index: 1 !important;
}

html body main#main .final-cta .cta-card,
html body main#main .final-cta .cta-card-inner {
  background: transparent !important;
  clip-path: none !important;
  color: #080d1d !important;
  padding: 0 !important;
  text-align: center !important;
}

html body main#main .final-cta .cta-card-inner {
  align-items: center !important;
  display: flex !important;
  flex-direction: column !important;
}

html body main#main .final-cta .cta-card-head {
  display: block !important;
  margin: 0 0 24px !important;
  position: static !important;
  text-align: center !important;
}

html body main#main .final-cta .cta-kicker {
  color: #35409d !important;
  display: block !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.22em !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

html body main#main .final-cta h2,
html body main#main .final-cta h2 span {
  color: #080d1d !important;
  font-family: "Anton", Impact, sans-serif !important;
  font-size: clamp(54px, 7vw, 92px) !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.94 !important;
  margin: 0 auto !important;
  max-width: 900px !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

html body main#main .final-cta .cta-lede {
  color: rgba(8, 13, 29, 0.78) !important;
  font-family: var(--sans) !important;
  font-size: clamp(16px, 1.3vw, 20px) !important;
  line-height: 1.6 !important;
  margin: 30px auto 0 !important;
  max-width: 680px !important;
  text-align: center !important;
}

html body main#main .final-cta .cta-actions {
  display: flex !important;
  gap: 16px !important;
  justify-content: center !important;
  margin-top: 38px !important;
}

html body main#main .final-cta .button {
  border-radius: 7px !important;
  min-width: 260px !important;
}

html body main#main .final-cta .button-primary {
  background: #080d1d !important;
  border-color: #080d1d !important;
  color: #fff !important;
}

html body main#main .final-cta .button-outline {
  background: transparent !important;
  border-color: rgba(8, 13, 29, 0.28) !important;
  color: #080d1d !important;
}

html body main#main .final-cta .contact-links {
  color: rgba(8, 13, 29, 0.76) !important;
  display: flex !important;
  gap: 14px !important;
  justify-content: center !important;
  margin-top: 30px !important;
}

html body main#main .final-cta .contact-links a {
  color: #35409d !important;
}

html body main#main .final-cta .contact-links a::before {
  background: #35409d !important;
}

@media (max-width: 760px) {
  html body main#main .final-cta {
    padding: 64px 0 !important;
  }

  html body main#main .final-cta .section-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  html body main#main .final-cta .cta-actions,
  html body main#main .final-cta .contact-links {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  html body main#main .final-cta .button {
    min-width: 0 !important;
    width: 100% !important;
  }
}

/* Sonic line animation from 03 Sonic. */
html body main#main .sonic-line-divider {
  height: 120px !important;
  overflow: hidden !important;
  position: relative !important;
  z-index: 1 !important;
}

html body main#main .sonic-line-divider svg {
  height: 100% !important;
  inset: 0 !important;
  position: absolute !important;
  width: 100% !important;
}

html body main#main .sonic-line {
  fill: none !important;
  stroke-linecap: round !important;
}

html body main#main .sonic-line-primary {
  animation: sonicDashMove 14s linear infinite !important;
  opacity: 0.6 !important;
  stroke: #97a4f7 !important;
  stroke-dasharray: 8 10 !important;
  stroke-width: 2 !important;
}

html body main#main .sonic-line-secondary {
  animation: sonicDashMove 9s linear infinite !important;
  opacity: 0.5 !important;
  stroke: #3a44a0 !important;
  stroke-dasharray: 4 12 !important;
  stroke-width: 2 !important;
}

/* Mobile challenge stats: compact stacked cards instead of the desktop split layout. */
@media (max-width: 760px) {
  html body main#main #challenge {
    padding-bottom: 72px !important;
    padding-top: 72px !important;
  }

  html body main#main #challenge .stats-grid {
    gap: 16px !important;
    grid-auto-rows: auto !important;
    margin-top: 36px !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card,
  html body main#main #challenge .stats-grid > article.stat-card.stat-card-dark,
  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent {
    border-radius: 20px !important;
    height: auto !important;
    justify-content: flex-start !important;
    max-height: none !important;
    min-height: 0 !important;
    padding: 24px 22px !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card:not(.stat-card-dark):not(.stat-card-accent) > div:last-child {
    margin-top: 22px !important;
  }

  html body main#main #challenge .stat-stack {
    margin-top: 28px !important;
  }

  html body main#main #challenge .stat-stack p {
    gap: 10px !important;
  }

  html body main#main #challenge .stat-stack p + p {
    margin-top: 26px !important;
    padding-top: 26px !important;
  }

  html body main#main #challenge .stat-stack strong,
  html body main#main #challenge .stat-card-dark .stat-stack strong {
    font-size: clamp(56px, 17vw, 70px) !important;
  }

  html body main#main #challenge .stat-value,
  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-accent-value {
    font-size: clamp(52px, 16vw, 66px) !important;
    line-height: 0.92 !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent {
    align-items: flex-start !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
    justify-content: flex-start !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent > .stat-accent-copy {
    flex: 0 0 auto !important;
    max-width: none !important;
    width: 100% !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-card-top {
    gap: 10px !important;
    width: 100% !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-label {
    font-size: 10.5px !important;
    letter-spacing: 0.16em !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-accent-description {
    font-size: 16px !important;
    line-height: 1.55 !important;
    margin-top: 18px !important;
    max-width: none !important;
  }

  html body main#main #challenge .stats-grid > article.stat-card.stat-card-accent .stat-accent-value {
    align-self: flex-start !important;
    font-size: clamp(44px, 14.5vw, 62px) !important;
    margin-top: 0 !important;
    text-align: left !important;
  }
}

@keyframes sonicDashMove {
  to {
    stroke-dashoffset: -1000;
  }
}

@media (prefers-reduced-motion: reduce) {
  html body main#main .sonic-line-primary,
  html body main#main .sonic-line-secondary {
    animation: none !important;
  }
}

/* Unified middle-section surface: no dividers between sections. */
html body main#main {
  background: #060912 !important;
}

html body main#main > .section:not(.hero):not(.final-cta),
html body main#main #challenge,
html body main#main #approach,
html body main#main #workshops,
html body main#main #testimonials,
html body main#main #about,
html body main#main #partners,
html body main#main .section-cream,
html body main#main .section-tint,
html body main#main .partners,
html body main#main .testimonials {
  background: #060912 !important;
  border-bottom: 0 !important;
  border-top: 0 !important;
}

html body main#main .creative-ticker,
html body main#main .sonic-line-divider {
  background: #060912 !important;
  border-bottom: 0 !important;
  border-top: 0 !important;
}

html body main#main .creative-ticker {
  background: #080d1d !important;
}

html body main#main #workshops[data-hscroll] [data-hsticky] {
  background: #060912 !important;
}

/* Testimonials: keep the heading and quote mark visually separated. */
html body main#main .testimonials .testimonial-card #testimonials-title {
  line-height: 1.2 !important;
  margin: 0 !important;
}

html body main#main .testimonials .testimonial-card .quote-mark {
  display: block !important;
  font-size: clamp(42px, 3.4vw, 58px) !important;
  height: 48px !important;
  line-height: 1 !important;
  margin: 38px 0 10px !important;
}

html body main#main .testimonials .testimonial-card blockquote p {
  margin-top: 0 !important;
  white-space: pre-line !important;
}

/* Mobile testimonial spacing: avoid the kicker and carousel controls touching the card edges. */
@media (max-width: 760px) {
  html body main#main #testimonials {
    padding-bottom: 72px !important;
    padding-top: 72px !important;
  }

  html body main#main #testimonials .section-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  html body main#main .testimonials .testimonial-card {
    height: auto !important;
    justify-content: flex-start !important;
    min-height: 0 !important;
    padding: 46px 22px 34px !important;
  }

  html body main#main .testimonials .testimonial-card #testimonials-title {
    font-size: 11px !important;
    letter-spacing: 0.28em !important;
    margin: 0 0 26px !important;
    max-width: 100% !important;
    text-align: center !important;
  }

  html body main#main .testimonials .testimonial-card .quote-mark {
    height: auto !important;
    line-height: 1 !important;
    margin: 0 0 18px !important;
  }

  html body main#main .testimonials .testimonial-card blockquote p {
    display: block !important;
    font-size: 22px !important;
    line-height: 1.28 !important;
    margin: 0 auto 28px !important;
    min-height: 0 !important;
  }

  html body main#main .testimonials .testimonial-card blockquote footer {
    gap: 5px !important;
  }

  html body main#main .testimonials .testimonial-controls {
    gap: 18px !important;
    margin-top: 34px !important;
    padding-bottom: 0 !important;
  }

  html body main#main .testimonials .testimonial-controls > button {
    flex: 0 0 52px !important;
    height: 52px !important;
    width: 52px !important;
  }

  html body main#main .final-cta .button {
    font-size: 12px !important;
    min-width: 0 !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
    white-space: nowrap !important;
    width: 100% !important;
  }
}

/* Music Library & Motion: three-track card grid after How WTMA Helps. */
html body main#main #music-library {
  background: #060912 !important;
  color: #eceefb !important;
  padding: clamp(78px, 9vw, 126px) 0 !important;
}

html body main#main #music-library .section-inner {
  max-width: var(--site-container) !important;
  padding-left: 32px !important;
  padding-right: 32px !important;
}

html body main#main .music-library-heading {
  align-items: end !important;
  display: grid !important;
  gap: 28px 52px !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.62fr) !important;
  margin: 0 0 44px !important;
}

html body main#main .music-library-heading .section-kicker {
  color: #97a4f7 !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  grid-column: 1 / -1 !important;
  letter-spacing: 0.26em !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  text-align: left !important;
  text-transform: uppercase !important;
}

html body main#main .music-library-heading h2 {
  color: #eceefb !important;
  font-family: "Anton", Impact, sans-serif !important;
  font-size: clamp(54px, 6vw, 92px) !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.94 !important;
  margin: 0 !important;
  max-width: 10ch !important;
  text-align: left !important;
  text-transform: uppercase !important;
}

html body main#main .music-library-heading > p:last-child {
  color: #a7accb !important;
  font-size: clamp(16px, 1.4vw, 20px) !important;
  line-height: 1.62 !important;
  margin: 0 !important;
  max-width: 39ch !important;
  text-align: left !important;
}

html body main#main .music-track-grid {
  display: grid !important;
  gap: 18px !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

html body main#main .music-track-card {
  background:
    linear-gradient(180deg, rgba(151, 164, 247, 0.08), rgba(151, 164, 247, 0.015)),
    #141a36 !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 22px !important;
  color: #eceefb !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 390px !important;
  overflow: hidden !important;
  padding: 28px !important;
  position: relative !important;
  transition: border-color 220ms ease, box-shadow 220ms ease, transform 220ms ease !important;
}

html body main#main .music-track-card::before {
  background:
    linear-gradient(90deg, rgba(151, 164, 247, 0.1) 0 1px, transparent 1px) 0 0 / 34px 34px,
    linear-gradient(0deg, rgba(151, 164, 247, 0.08) 0 1px, transparent 1px) 0 0 / 34px 34px;
  content: "" !important;
  inset: 0 !important;
  opacity: 0.34 !important;
  pointer-events: none !important;
  position: absolute !important;
}

html body main#main .music-track-card:hover,
html body main#main .music-track-card.is-playing {
  border-color: rgba(151, 164, 247, 0.42) !important;
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.28) !important;
  transform: translateY(-4px) !important;
}

html body main#main .track-card-top,
html body main#main .track-meta,
html body main#main .track-play,
html body main#main .track-embed,
html body main#main .track-audio-player,
html body main#main .music-track-card h3,
html body main#main .music-track-card p,
html body main#main .track-wave {
  position: relative !important;
  z-index: 1 !important;
}

html body main#main .track-card-top {
  align-items: center !important;
  display: flex !important;
  justify-content: space-between !important;
  margin-bottom: 34px !important;
}

html body main#main .track-number {
  color: #97a4f7 !important;
  font-family: "Anton", Impact, sans-serif !important;
  font-size: 38px !important;
  line-height: 1 !important;
}

html body main#main .track-tag {
  border: 1px solid rgba(151, 164, 247, 0.28) !important;
  border-radius: 999px !important;
  color: #97a4f7 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  line-height: 1 !important;
  padding: 8px 10px !important;
  text-transform: uppercase !important;
}

html body main#main .music-track-card h3 {
  color: #fff !important;
  font-family: "Anton", Impact, sans-serif !important;
  font-size: clamp(30px, 3vw, 46px) !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.92 !important;
  margin: 0 !important;
  text-transform: uppercase !important;
}

html body main#main .music-track-card p {
  color: #a7accb !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  margin: 18px 0 0 !important;
}

html body main#main .track-wave {
  align-items: end !important;
  display: flex !important;
  gap: 7px !important;
  height: 78px !important;
  margin: auto 0 24px !important;
  padding-top: 26px !important;
}

html body main#main .track-wave span {
  animation: none !important;
  background: #97a4f7 !important;
  border-radius: 999px 999px 0 0 !important;
  display: block !important;
  flex: 1 1 0 !important;
  min-width: 8px !important;
  opacity: 0.48 !important;
}

html body main#main .track-wave span:nth-child(1) { height: 26%; }
html body main#main .track-wave span:nth-child(2) { height: 58%; }
html body main#main .track-wave span:nth-child(3) { height: 38%; }
html body main#main .track-wave span:nth-child(4) { height: 78%; }
html body main#main .track-wave span:nth-child(5) { height: 46%; }
html body main#main .track-wave span:nth-child(6) { height: 90%; }
html body main#main .track-wave span:nth-child(7) { height: 34%; }
html body main#main .track-wave span:nth-child(8) { height: 64%; }

html body main#main .track-embed {
  background: rgba(8, 13, 29, 0.72) !important;
  border: 1px solid rgba(151, 164, 247, 0.18) !important;
  border-radius: 14px !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
  margin: 24px 0 20px !important;
  overflow: hidden !important;
  width: 100% !important;
}

html body main#main .track-embed iframe {
  background: #080d1d !important;
  border: 0 !important;
  display: block !important;
  width: 100% !important;
}

html body main#main .track-embed.is-audio iframe {
  height: 140px !important;
}

html body main#main .track-embed.is-video {
  aspect-ratio: 16 / 9 !important;
}

html body main#main .track-embed.is-video iframe {
  height: 100% !important;
}

html body main#main .track-audio-player {
  align-items: center !important;
  background:
    linear-gradient(135deg, rgba(151, 164, 247, 0.15), rgba(8, 13, 29, 0.86)),
    #101631 !important;
  border: 1px solid rgba(151, 164, 247, 0.18) !important;
  border-radius: 14px !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 18px 36px rgba(0, 0, 0, 0.18) !important;
  display: grid !important;
  gap: 18px !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  margin: 24px 0 20px !important;
  min-height: 142px !important;
  overflow: hidden !important;
  padding: 16px !important;
  width: 100% !important;
}

html body main#main .track-audio-player audio {
  display: none !important;
}

html body main#main .track-audio-art {
  align-items: center !important;
  aspect-ratio: 1 !important;
  background:
    radial-gradient(circle at 38% 28%, rgba(255, 255, 255, 0.22), transparent 28%),
    linear-gradient(135deg, #2f3d86, #080d1d 72%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 8px !important;
  color: #cbd2ff !important;
  display: grid !important;
  font-size: 34px !important;
  justify-items: center !important;
}

html body main#main .track-audio-controls {
  display: grid !important;
  gap: 14px !important;
  min-width: 0 !important;
}

html body main#main .track-audio-controls strong {
  color: #fff !important;
  display: block !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

html body main#main .track-audio-row {
  align-items: center !important;
  display: grid !important;
  gap: 12px !important;
  grid-template-columns: 52px auto minmax(90px, 1fr) auto !important;
}

html body main#main .track-audio-toggle {
  align-items: center !important;
  background: #f6f4f0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  color: #080d1d !important;
  display: inline-flex !important;
  height: 52px !important;
  justify-content: center !important;
  padding: 0 !important;
  width: 52px !important;
}

html body main#main .track-audio-toggle i {
  font-size: 20px !important;
}

html body main#main .track-audio-player.is-playing .track-audio-toggle {
  background: #97a4f7 !important;
}

html body main#main .track-audio-time {
  color: #dfe2ff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  min-width: 36px !important;
  opacity: 0.9 !important;
}

html body main#main .track-audio-range {
  --audio-progress: 0%;
  appearance: none !important;
  background: linear-gradient(90deg, #97a4f7 var(--audio-progress), rgba(255, 255, 255, 0.34) var(--audio-progress)) !important;
  border-radius: 999px !important;
  cursor: pointer !important;
  height: 5px !important;
  min-width: 0 !important;
  width: 100% !important;
}

html body main#main .track-audio-range::-webkit-slider-thumb {
  appearance: none !important;
  background: #dfe2ff !important;
  border: 0 !important;
  border-radius: 999px !important;
  height: 14px !important;
  width: 14px !important;
}

html body main#main .track-audio-range::-moz-range-thumb {
  background: #dfe2ff !important;
  border: 0 !important;
  border-radius: 999px !important;
  height: 14px !important;
  width: 14px !important;
}

html body main#main .music-track-card.is-playing .track-wave span {
  animation: wtmaTrackPulse 900ms ease-in-out infinite alternate !important;
  opacity: 0.9 !important;
}

html body main#main .music-track-card.is-playing .track-wave span:nth-child(2n) {
  animation-delay: 160ms !important;
}

html body main#main .music-track-card.is-playing .track-wave span:nth-child(3n) {
  animation-delay: 280ms !important;
}

html body main#main .track-meta {
  border-top: 1px solid rgba(255, 255, 255, 0.09) !important;
  color: #dfe2ff !important;
  display: grid !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  gap: 10px !important;
  grid-template-columns: repeat(auto-fit, minmax(76px, 1fr)) !important;
  letter-spacing: 0.1em !important;
  padding-top: 18px !important;
  text-transform: uppercase !important;
}

html body main#main .track-play {
  align-items: center !important;
  align-self: flex-start !important;
  background: #97a4f7 !important;
  border: 0 !important;
  border-radius: 7px !important;
  color: #080d1d !important;
  display: inline-flex !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  gap: 8px !important;
  justify-content: center !important;
  line-height: 1 !important;
  margin-top: 22px !important;
  min-height: 42px !important;
  padding: 12px 16px !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
}

html body main#main .track-play i {
  font-size: 16px !important;
}

html body main#main .music-track-card.is-playing .track-play {
  background: #fff !important;
}

@keyframes wtmaTrackPulse {
  from {
    transform: scaleY(0.64);
  }

  to {
    transform: scaleY(1);
  }
}

@media (max-width: 980px) {
  html body main#main .music-library-heading,
  html body main#main .music-track-grid {
    grid-template-columns: 1fr !important;
  }

  html body main#main .music-library-heading h2,
  html body main#main .music-library-heading > p:last-child {
    max-width: none !important;
  }

  html body main#main .music-track-card {
    min-height: 0 !important;
  }
}

@media (max-width: 760px) {
  html body main#main #music-library {
    padding: 72px 0 !important;
  }

  html body main#main #music-library .section-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  html body main#main .music-library-heading {
    gap: 22px !important;
    margin-bottom: 32px !important;
  }

  html body main#main .music-library-heading h2 {
    font-size: 48px !important;
  }

  html body main#main .music-track-card {
    padding: 24px !important;
  }

  html body main#main .track-card-top {
    margin-bottom: 28px !important;
  }

  html body main#main .music-track-card h3 {
    font-size: 34px !important;
  }

  html body main#main .track-embed {
    margin: 20px 0 18px !important;
  }

  html body main#main .track-audio-player {
    gap: 14px !important;
    grid-template-columns: 78px minmax(0, 1fr) !important;
    margin: 20px 0 18px !important;
    padding: 14px !important;
  }

  html body main#main .track-audio-row {
    gap: 9px !important;
    grid-template-columns: 44px auto minmax(64px, 1fr) auto !important;
  }

  html body main#main .track-audio-toggle {
    height: 44px !important;
    width: 44px !important;
  }

  html body main#main .track-audio-time {
    font-size: 12px !important;
    min-width: 32px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  html body main#main .music-track-card.is-playing .track-wave span {
    animation: none !important;
  }
}
