:root {
  --bg: #f7fafc;
  --bg-strong: #ffffff;
  --ink: #111F39;
  --muted: #667085;
  --soft: #f2f7fa;
  --line: #00b8ba;
  --navy: #111F39;
  --light-blue: #6fbfc1;
  --cyan: #00b8ba;
  --gold: #b89a45;
  --blue: #1f5c8f;
  --orange: #c9893b;
  --green: #5f8d6a;
  --violet: #7f6ca8;
  --shadow: 0 20px 54px rgba(17, 31, 57, 0.075);
  --soft-shadow: 0 10px 28px rgba(17, 31, 57, 0.052);
  --radius: 8px;
  --smooth: cubic-bezier(0.2, 0.8, 0.2, 1);
  color-scheme: light;
}

html[data-theme="dark"],
html.dark {
  --bg: #0a1424;
  --bg-strong: #0f1d31;
  --ink: #e8eef8;
  --muted: #9aaec5;
  --soft: #15263d;
  --line: rgba(0, 184, 186, 0.32);
  --navy: #e8eef8;
  --shadow: 0 24px 60px rgba(0, 0, 0, 0.45);
  --soft-shadow: 0 10px 30px rgba(0, 0, 0, 0.28);
  color-scheme: dark;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

main > section {
  scroll-margin-top: 6.5rem;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at 10% 12%, rgba(0, 184, 186, 0.055), transparent 30rem),
    radial-gradient(circle at 90% 10%, rgba(184, 154, 69, 0.04), transparent 25rem),
    linear-gradient(180deg, var(--bg-strong), var(--bg) 36rem);
  color: var(--ink);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: 0;
  line-height: 1.6;
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

html.dark body,
html[data-theme="dark"] body {
  background:
    radial-gradient(circle at 12% 10%, rgba(0, 184, 186, 0.10), transparent 32rem),
    radial-gradient(circle at 88% 8%, rgba(31, 92, 143, 0.10), transparent 28rem),
    linear-gradient(180deg, #0a1424, #08111e 40rem);
}

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

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

button {
  font: inherit;
}

svg {
  width: 1em;
  height: 1em;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

::selection {
  color: var(--navy);
  background: rgba(0, 184, 186, 0.2);
}

:focus-visible {
  outline: 3px solid rgba(0, 184, 186, 0.28);
  outline-offset: 3px;
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 200;
  transform: translateY(-140%);
  background: var(--ink);
  color: var(--bg-strong);
  padding: 0.75rem 1rem;
  border-radius: var(--radius);
  transition: transform 0.2s ease;
}

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

.crawl-fallback {
  position: relative;
  z-index: 300;
  padding: 0.85rem 1rem;
  background: var(--bg-strong);
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  font: 600 0.9rem/1.5 Inter, system-ui, sans-serif;
}

.section-shell {
  width: min(1280px, calc(100% - 2rem));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0.75rem;
  z-index: 100;
  width: min(1280px, calc(100% - 2rem));
  margin: 0.75rem auto 0;
  min-height: 3.8rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  padding: 0.44rem 0.75rem;
  background: color-mix(in srgb, var(--bg-strong) 82%, transparent);
  border: 1.5px solid var(--cyan);
  border-radius: 999px;
  box-shadow: 0 10px 30px rgba(17, 31, 57, 0.06);
  backdrop-filter: blur(22px);
  isolation: isolate;
  overflow: visible;
}

.site-header::before {
  content: "";
  position: absolute;
  pointer-events: none;
  inset: 0.18rem;
  border-radius: inherit;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.7), transparent 38%, rgba(255, 255, 255, 0.52)),
    radial-gradient(circle at 12% 50%, rgba(0, 174, 176, 0.055), transparent 9rem);
  z-index: -1;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  min-height: 2.9rem;
  padding: 0.24rem 0.78rem 0.24rem 0.3rem;
  border: 1px solid transparent;
  border-radius: 999px;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 600;
  white-space: nowrap;
  min-width: 0;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.brand:hover {
  background: var(--bg-strong);
  border-color: color-mix(in srgb, var(--cyan) 28%, var(--line));
  transform: translateY(-1px);
}

.brand img {
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(0, 174, 176, 0.07);
}

.brand strong {
  color: var(--cyan);
}

.desktop-nav {
  display: flex;
  align-items: center;
  gap: 0.18rem;
  padding: 0.25rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 10%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--soft) 34%, transparent);
}

.desktop-nav a {
  min-width: 5.1rem;
  text-align: center;
  padding: 0.55rem 0.95rem;
  border-radius: 999px;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 600;
  transition: color 0.18s ease, background 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.desktop-nav a:hover,
.desktop-nav a.is-active {
  color: var(--cyan);
  background: var(--bg-strong);
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(17, 31, 57, 0.055);
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  min-height: 3rem;
  padding: 0 1.22rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 600;
  font-size: 0.98rem;
  position: relative;
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.button svg {
  width: 1.05rem;
  height: 1.05rem;
  transition: transform 0.18s ease;
}

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

.button:hover svg {
  transform: translateX(2px);
}

.button.primary {
  color: var(--navy);
  background: var(--cyan);
  border-color: color-mix(in srgb, var(--cyan) 70%, var(--bg-strong));
  box-shadow: 0 10px 20px rgba(0, 174, 176, 0.14);
}

.button.primary::after {
  display: none;
}

.button.primary:hover {
  background: color-mix(in srgb, var(--cyan) 88%, var(--bg-strong));
  box-shadow: 0 12px 22px rgba(0, 174, 176, 0.16);
}

.button.secondary {
  background: var(--bg-strong);
  color: var(--ink);
  border-color: var(--line);
}

.button.small {
  min-height: 2.8rem;
  padding: 0 1rem;
  font-size: 0.9rem;
}

.icon-button {
  width: 2.65rem;
  height: 2.65rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--bg-strong);
  color: var(--ink);
  cursor: pointer;
  transition: transform 0.18s ease, color 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.icon-button:hover {
  color: var(--cyan);
  border-color: color-mix(in srgb, var(--cyan) 46%, var(--line));
  background: color-mix(in srgb, var(--soft) 48%, var(--bg-strong));
  transform: translateY(-1px);
}

.menu-toggle {
  display: none;
  flex-direction: column;
  gap: 0.25rem;
}

.menu-toggle span {
  width: 1rem;
  height: 2px;
  background: currentColor;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.mobile-nav {
  display: none;
}

.hero {
  position: relative;
  margin-top: 0.5rem;
  padding: 2.25rem 4.1rem 0;
  min-height: min(720px, calc(100vh - 6rem));
  background:
    radial-gradient(circle at 72% 45%, rgba(0, 174, 176, 0.08), transparent 24rem),
    linear-gradient(165deg, var(--bg-strong), color-mix(in srgb, var(--soft) 78%, var(--bg-strong)));
  border: 1.5px solid var(--cyan);
  border-radius: var(--radius);
  overflow: hidden;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.22;
  background-image:
    linear-gradient(rgba(0, 174, 176, 0.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 174, 176, 0.08) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(90deg, black, transparent 58%);
}

.hero::after {
  content: "";
  position: absolute;
  right: 7%;
  top: 18%;
  width: min(38rem, 46vw);
  height: 31rem;
  pointer-events: none;
  background:
    repeating-linear-gradient(90deg, rgba(0, 174, 176, 0.1) 0 1px, transparent 1px 38px),
    repeating-linear-gradient(0deg, rgba(17, 31, 57, 0.06) 0 1px, transparent 1px 38px);
  border-radius: 50%;
  opacity: 0.06;
  transform: rotate(-8deg);
  mask-image: radial-gradient(circle, black 0 42%, transparent 72%);
  animation: meshDrift 14s var(--smooth) infinite;
}

.hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.03fr) minmax(420px, 0.82fr);
  gap: 3.2rem;
  align-items: start;
}

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

.platform-line {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.62rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  color: var(--cyan);
  background: color-mix(in srgb, var(--bg-strong) 78%, transparent);
  font-weight: 700;
  font-size: 0.94rem;
  box-shadow: var(--soft-shadow);
}

.spark {
  width: 0.85rem;
  height: 0.85rem;
  position: relative;
  display: inline-block;
}

.spark::before,
.spark::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--cyan);
  animation: pulseDot 1.9s ease-out infinite;
}

.spark::after {
  inset: 0.28rem;
  background: var(--blue);
  animation-delay: 0.34s;
}

h1,
h2,
h3,
p {
  margin: 0;
}

.hero h1 {
  max-width: 690px;
  margin: 1.35rem 0 1.05rem;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(3.05rem, 4.6vw, 3.82rem);
  line-height: 1.04;
  letter-spacing: 0;
  font-weight: 700;
}

.hero h1 span {
  display: block;
  margin-top: 0.32rem;
  font-size: clamp(2.35rem, 3.5vw, 2.95rem);
  line-height: 1.08;
  color: transparent;
  background: linear-gradient(90deg, var(--cyan), var(--gold) 54%, var(--navy) 92%);
  -webkit-background-clip: text;
  background-clip: text;
  background-size: 180% 100%;
  animation: gradientSlide 10s ease-in-out infinite;
  padding-bottom: 0.08em;
}

.hero-text {
  max-width: 620px;
  color: var(--muted);
  font-size: 1.18rem;
  line-height: 1.58;
}

.hero-text strong {
  color: var(--ink);
}

.hero-text .quiet {
  margin-top: 0.8rem;
  font-size: 0.96rem;
  font-style: italic;
  color: color-mix(in srgb, var(--muted) 76%, transparent);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin: 1.45rem 0 0.75rem;
}

.hero-actions .button.secondary {
  color: var(--navy);
  background: color-mix(in srgb, var(--bg-strong) 56%, transparent);
  border-color: color-mix(in srgb, var(--navy) 20%, var(--line));
  box-shadow: none;
}

.hero-trust {
  width: fit-content;
  max-width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
  align-items: center;
  color: color-mix(in srgb, var(--navy) 64%, var(--muted));
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.35;
  text-transform: uppercase;
}

.hero-trust span {
  color: var(--gold);
  letter-spacing: 0;
}

.proof-strip {
  display: flex;
  flex-wrap: wrap;
  width: fit-content;
  max-width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 72%, transparent);
  overflow: hidden;
}

.proof-strip span {
  padding: 0.68rem 0.9rem;
  color: var(--muted);
  font-size: 0.82rem;
  border-right: 1px solid var(--line);
  white-space: nowrap;
}

.proof-strip span:last-child {
  border-right: 0;
}

.brand-strip {
  position: relative;
  width: min(100%, 690px);
  display: grid;
  grid-template-columns: minmax(150px, 0.58fr) 1.65fr;
  gap: 0.78rem 1.1rem;
  align-items: center;
  margin-top: 1.15rem;
  padding: 0.82rem 0.98rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.9), rgba(248, 253, 255, 0.82)),
    radial-gradient(circle at 94% 10%, rgba(0, 174, 176, 0.06), transparent 12rem);
  box-shadow: var(--soft-shadow);
  overflow: hidden;
}

.brand-strip::before,
.brand-strip::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.brand-strip::before {
  inset-block: 0.85rem;
  left: calc(0.92rem + min(150px, 30%));
  width: 1px;
  background: color-mix(in srgb, var(--cyan) 28%, var(--line));
}

.brand-strip::after {
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--green), var(--violet), var(--orange), var(--blue));
  opacity: 0.72;
  transform-origin: left;
  animation: stripPulse 4.8s var(--smooth) infinite;
}

.strip-statement {
  display: grid;
  gap: 0.12rem;
  font-family: "Space Grotesk", Inter, sans-serif;
  color: var(--navy);
  text-transform: uppercase;
  line-height: 1.03;
}

.strip-statement strong,
.strip-statement span {
  font-size: 0.98rem;
  font-weight: 700;
}

.strip-statement span {
  color: var(--cyan);
}

.strip-window {
  min-width: 0;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}

.strip-symbols {
  width: max-content;
  display: flex;
  align-items: center;
  gap: 0.92rem;
  animation: symbolRun 11s linear infinite;
}

.brand-strip:hover .strip-symbols {
  animation-play-state: paused;
}

.strip-labels {
  display: none;
}

/* Unify hero brand-strip icons to a calm cyan palette */
.strip-symbols .brand-mark,
.strip-symbols .brand-mark.problem,
.strip-symbols .brand-mark.waves,
.strip-symbols .brand-mark.focus,
.strip-symbols .brand-mark.structure,
.strip-symbols .brand-mark.think,
.strip-symbols .brand-mark.adapt,
.strip-symbols .brand-mark.decoded,
.strip-symbols .brand-mark.opportunity {
  color: color-mix(in srgb, var(--cyan) 78%, var(--navy));
  opacity: 0.85;
}

.brand-mark {
  position: relative;
  width: 2rem;
  height: 2rem;
  justify-self: center;
  display: block;
  color: var(--cyan);
}

.brand-mark::before,
.brand-mark::after {
  content: "";
  position: absolute;
}

.brand-mark.problem {
  color: #a3a9b2;
}

.brand-mark.problem::before,
.brand-mark.problem::after {
  left: 50%;
  top: 0;
  width: 0.38rem;
  height: 100%;
  border-radius: 2px;
  background: currentColor;
  transform: translateX(-50%) rotate(45deg);
}

.brand-mark.problem::after {
  transform: translateX(-50%) rotate(-45deg);
}

.brand-mark.waves {
  color: #7fac42;
  background:
    repeating-linear-gradient(135deg, currentColor 0 4px, transparent 4px 8px),
    repeating-linear-gradient(45deg, transparent 0 5px, currentColor 5px 8px, transparent 8px 13px);
  mask-image: linear-gradient(90deg, black 0 72%, transparent);
}

.brand-mark.focus {
  color: #8f288d;
  background:
    radial-gradient(circle at 28% 28%, currentColor 0 26%, transparent 27%),
    radial-gradient(circle at 72% 28%, currentColor 0 26%, transparent 27%),
    radial-gradient(circle at 28% 72%, currentColor 0 26%, transparent 27%),
    radial-gradient(circle at 72% 72%, currentColor 0 26%, transparent 27%);
}

.brand-mark.structure {
  color: #1d5da8;
  background: repeating-linear-gradient(135deg, currentColor 0 0.28rem, transparent 0.28rem 0.58rem);
}

.brand-mark.think {
  color: #92d9e5;
  background:
    linear-gradient(135deg, currentColor 0 50%, transparent 50%) 0 0 / 50% 50%,
    linear-gradient(225deg, currentColor 0 50%, transparent 50%) 100% 0 / 50% 50%,
    linear-gradient(45deg, currentColor 0 50%, transparent 50%) 0 100% / 50% 50%,
    linear-gradient(315deg, currentColor 0 50%, transparent 50%) 100% 100% / 50% 50%;
  background-repeat: no-repeat;
}

.brand-mark.adapt {
  color: var(--orange);
  background: repeating-linear-gradient(0deg, transparent 0 0.22rem, currentColor 0.22rem 0.38rem, transparent 0.38rem 0.56rem);
  transform: skewX(-10deg);
}

.brand-mark.decoded {
  color: #8d9098;
  background:
    linear-gradient(currentColor, currentColor) 0 0 / 100% 0.18rem,
    linear-gradient(currentColor, currentColor) 0 50% / 70% 0.18rem,
    linear-gradient(currentColor, currentColor) 32% 100% / 68% 0.18rem,
    linear-gradient(currentColor, currentColor) 0 0 / 0.18rem 100%,
    linear-gradient(currentColor, currentColor) 50% 0 / 0.18rem 70%,
    linear-gradient(currentColor, currentColor) 100% 30% / 0.18rem 70%;
  background-repeat: no-repeat;
}

.brand-mark.opportunity {
  color: var(--cyan);
  background:
    linear-gradient(currentColor, currentColor) 0 0 / 45% 45%,
    linear-gradient(currentColor, currentColor) 100% 0 / 45% 45%,
    linear-gradient(currentColor, currentColor) 0 100% / 45% 45%,
    linear-gradient(currentColor, currentColor) 100% 100% / 45% 45%;
  background-repeat: no-repeat;
  border-radius: 4px;
}

.home-rail {
  position: relative;
  width: min(100%, 650px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.45rem;
  margin-top: 0.75rem;
  padding: 0.45rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 28%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 78%, transparent);
  box-shadow: var(--soft-shadow);
  overflow: hidden;
  backdrop-filter: blur(12px);
}

.rail-trace {
  position: absolute;
  left: 1.2rem;
  right: 1.2rem;
  top: 1.26rem;
  height: 2px;
  background: color-mix(in srgb, var(--line) 70%, transparent);
}

.rail-trace::after {
  content: "";
  display: block;
  width: 36%;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--cyan), var(--blue), transparent);
  animation: railSweep 4.8s var(--smooth) infinite;
}

.home-rail article {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.18rem;
  align-content: start;
  padding: 0.5rem;
  border-radius: 7px;
  background: color-mix(in srgb, var(--bg-strong) 82%, transparent);
  animation: railCardPulse 4.8s var(--smooth) infinite;
}

.home-rail article:nth-of-type(2) {
  animation-delay: 1.4s;
}

.home-rail article:nth-of-type(3) {
  animation-delay: 2.8s;
}

.home-rail i {
  width: 1rem;
  height: 1rem;
  display: block;
  border: 3px solid var(--bg-strong);
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--blue));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--cyan) 40%, var(--line)), 0 0 18px rgba(8, 175, 206, 0.18);
}

.home-rail article:nth-of-type(2) i {
  background: linear-gradient(135deg, var(--violet), var(--cyan));
}

.home-rail article:nth-of-type(3) i {
  background: linear-gradient(135deg, var(--orange), var(--green));
}

.home-rail strong {
  color: var(--ink);
  font-size: 0.84rem;
}

.home-rail small {
  color: var(--muted);
  font-size: 0.68rem;
  line-height: 1.28;
}

.hero-motif-ribbon {
  position: relative;
  z-index: 2;
  margin: 1rem -4.1rem 0;
  padding: 0.62rem 0;
  border-block: 1px solid color-mix(in srgb, var(--cyan) 20%, var(--line));
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.72), rgba(245, 252, 255, 0.7)),
    radial-gradient(circle at 12% 50%, rgba(8, 175, 206, 0.1), transparent 13rem);
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}

.hero-motif-ribbon::before,
.hero-motif-ribbon::after {
  content: "";
  position: absolute;
  inset-block: 0;
  width: 10rem;
  pointer-events: none;
  z-index: 2;
}

.hero-motif-ribbon::before {
  left: 0;
  background: linear-gradient(90deg, var(--bg-strong), transparent);
}

.hero-motif-ribbon::after {
  right: 0;
  background: linear-gradient(270deg, var(--bg-strong), transparent);
}

.motif-track {
  width: max-content;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding-inline: 4.1rem;
  animation: motifRun 18s linear infinite;
}

.hero-motif-ribbon .brand-mark {
  width: 2.25rem;
  height: 2.25rem;
  opacity: 0.86;
}

.hero-visual {
  position: relative;
  min-height: 0;
  display: grid;
  place-items: start center;
  perspective: 1200px;
  isolation: isolate;
}

.ai-field {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.field-mark {
  position: absolute;
  width: 3rem;
  height: 3rem;
  opacity: 0.14;
  filter: none;
  animation: symbolFloat 7s var(--smooth) infinite;
}

.mark-a {
  left: 4%;
  top: 15%;
}

.mark-b {
  right: 0;
  top: 31%;
  animation-delay: 1.2s;
}

.mark-c {
  left: 9%;
  bottom: 20%;
  animation-delay: 2.1s;
}

.mark-d {
  right: 8%;
  bottom: 7%;
  animation-delay: 3s;
}

.visual-brand-strip {
  position: absolute;
  right: -0.95rem;
  top: 52%;
  z-index: 4;
  display: grid;
  gap: 0.5rem;
  padding: 0.72rem 0.55rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 30%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg-strong) 78%, transparent);
  box-shadow: 0 18px 36px rgba(16, 35, 60, 0.1);
  backdrop-filter: blur(16px);
  transform: translateY(-50%);
}

.visual-brand-strip::before {
  content: "";
  position: absolute;
  inset: 0.42rem;
  border-radius: inherit;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, transparent);
  pointer-events: none;
}

.visual-brand-strip .brand-mark {
  width: 1.34rem;
  height: 1.34rem;
  animation: stripPop 4.8s var(--smooth) infinite;
}

.visual-brand-strip .brand-mark:nth-child(2) { animation-delay: 0.16s; }
.visual-brand-strip .brand-mark:nth-child(3) { animation-delay: 0.32s; }
.visual-brand-strip .brand-mark:nth-child(4) { animation-delay: 0.48s; }
.visual-brand-strip .brand-mark:nth-child(5) { animation-delay: 0.64s; }
.visual-brand-strip .brand-mark:nth-child(6) { animation-delay: 0.8s; }
.visual-brand-strip .brand-mark:nth-child(7) { animation-delay: 0.96s; }
.visual-brand-strip .brand-mark:nth-child(8) { animation-delay: 1.12s; }

.ai-console {
  position: relative;
  z-index: 3;
  width: min(100%, 488px);
  padding: 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 96%, transparent);
  box-shadow: 0 18px 44px rgba(17, 31, 57, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.82);
  transform-style: preserve-3d;
  will-change: transform;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  overflow: hidden;
}

.ai-console::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(0, 174, 176, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 174, 176, 0.035) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: 0.55;
  mask-image: linear-gradient(135deg, black, transparent 68%);
}

.ai-console > * {
  position: relative;
  z-index: 1;
}

.console-topline {
  position: absolute;
  top: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--cyan), var(--gold), var(--navy));
  background-size: 220% 100%;
  opacity: 0.58;
}

.console-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
}

.console-header span {
  color: var(--cyan);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.console-header h2 {
  margin-top: 0.15rem;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.25rem;
  line-height: 1.05;
}

.console-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.4rem;
}

.console-badges b {
  padding: 0.42rem 0.62rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: 999px;
  color: var(--navy);
  background: rgba(255, 255, 255, 0.86);
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  white-space: nowrap;
}

.signal-flow {
  display: grid;
  gap: 0.45rem;
  margin-top: 0.72rem;
}

.flow-row {
  position: relative;
  display: grid;
  grid-template-columns: 2rem 1fr;
  gap: 0.08rem 0.65rem;
  align-items: center;
  padding: 0.64rem 0.68rem;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
  overflow: hidden;
}

.flow-row::after {
  content: "";
  position: absolute;
  inset-block: 0;
  width: 32%;
  background: linear-gradient(90deg, transparent, rgba(0, 174, 176, 0.07), transparent);
  transform: translateX(-130%);
  animation: rowScan 4.8s var(--smooth) infinite;
}

.flow-row:nth-child(2)::after {
  animation-delay: 0.9s;
}

.flow-row:nth-child(3)::after {
  animation-delay: 1.8s;
}

.flow-row span {
  grid-row: span 2;
  width: 1.75rem;
  height: 1.75rem;
  display: grid;
  place-items: center;
  border-radius: 7px;
  color: var(--cyan);
  background: var(--soft);
  font-size: 0.72rem;
  font-weight: 700;
}

.flow-row strong {
  grid-column: 2;
  font-size: 0.84rem;
}

.flow-row small {
  grid-column: 2;
  grid-row: 2;
  color: var(--muted);
  font-size: 0.68rem;
}

.flow-row i {
  position: relative;
  grid-column: 2;
  grid-row: 3;
  height: 0.4rem;
  margin-top: 0.34rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cyan) 8%, var(--bg-strong));
  overflow: hidden;
}

.flow-row i::before,
.flow-row i::after {
  content: "";
  position: absolute;
  inset-block: 0;
  border-radius: inherit;
}

.flow-row i::before {
  left: 0;
  width: 76%;
  background: linear-gradient(90deg, var(--cyan), var(--navy));
  transform-origin: left;
  animation: signalBar 2.9s var(--smooth) infinite;
}

.flow-row i::after {
  width: 28%;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--gold) 70%, white), transparent);
  transform: translateX(-120%);
  animation: signalGlint 2.4s linear infinite;
}

.flow-row:nth-child(2) i::before {
  width: 64%;
  animation-delay: 0.28s;
}

.flow-row:nth-child(2) i::after {
  animation-delay: 0.42s;
}

.flow-row:nth-child(3) i::before {
  width: 70%;
  animation-delay: 0.56s;
}

.flow-row:nth-child(3) i::after {
  animation-delay: 0.84s;
}

.art-core {
  display: grid;
  grid-template-columns: 168px 1fr;
  gap: 1.25rem;
  align-items: center;
  margin-top: 0.8rem;
  padding: 1.1rem 1.25rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 14%, var(--line));
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
}

div.core-ring {
  position: relative !important;
  width: 168px !important;
  height: 168px !important;
  border-radius: 50% !important;
  background: var(--bg-strong) !important;
  border: 10px solid #0a6d76 !important;
  box-sizing: border-box !important;
  box-shadow: 0 10px 28px -18px rgba(15, 35, 70, 0.35) !important;
}

.core-ring::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: 50%;
  border: 1px dashed color-mix(in srgb, var(--cyan) 38%, transparent);
  animation: coreSpin 22s linear infinite;
}

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

.core-ring::after {
  content: "";
  position: absolute;
  inset: 36%;
  border-radius: 50%;
  background: color-mix(in srgb, var(--cyan) 12%, #fff);
  border: 1px solid color-mix(in srgb, var(--cyan) 30%, var(--line));
}

.core-node {
  position: absolute;
  z-index: 2;
  width: 2.1rem;
  height: 2.1rem;
  display: grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--cyan) 25%, var(--line));
  border-radius: 50%;
  background: var(--bg-strong);
  color: var(--navy);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 4px 10px -6px rgba(15, 35, 70, 0.3);
}

.core-node.cq { left: 50%; top: -1.55rem; margin-left: -1.05rem; }
.core-node.eq { right: -1.55rem; top: 50%; margin-top: -1.05rem; }
.core-node.mq { left: 50%; bottom: -1.55rem; margin-left: -1.05rem; }
.core-node.pq { left: -1.55rem; top: 50%; margin-top: -1.05rem; }

.core-center {
  display: grid;
  gap: 0.35rem;
  justify-items: start;
  text-align: left;
}

.core-center small,
.decision-layer span {
  color: var(--cyan);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.core-center strong {
  display: block;
  font-family: "Space Grotesk", Inter, sans-serif;
  color: var(--navy);
  font-size: clamp(3.55rem, 5vw, 4.1rem);
  line-height: 1.18;
  padding-bottom: 0.06em;
}

.core-center span {
  color: var(--muted);
  font-size: 0.88rem;
}

.decision-layer {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
  margin-top: 0.65rem;
}

.decision-layer div {
  padding: 0.62rem;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.84);
}

.decision-layer strong {
  display: block;
  margin-top: 0.2rem;
  color: var(--ink);
  font-size: 0.84rem;
}

.signal-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.signal {
  position: absolute;
  right: 1%;
  width: 72%;
  height: 70px;
  border-radius: 999px;
  border-top: 4px solid color-mix(in srgb, var(--cyan) 70%, transparent);
  filter: drop-shadow(0 0 18px rgba(8, 175, 206, 0.28));
  opacity: 0.75;
  animation: streamFlow 5.2s ease-in-out infinite;
}

.signal::before,
.signal::after {
  content: "";
  position: absolute;
  top: -7px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  color: var(--cyan);
  box-shadow: 0 0 14px currentColor;
  animation: dotTravel 3.2s linear infinite;
}

.signal::after {
  animation-delay: 1.4s;
}

.signal-a {
  top: 13%;
  color: var(--green);
  border-color: color-mix(in srgb, var(--green) 68%, transparent);
  transform: rotate(4deg);
}

.signal-b {
  top: 31%;
  color: var(--violet);
  border-color: color-mix(in srgb, var(--violet) 66%, transparent);
  animation-delay: 0.6s;
}

.signal-c {
  top: 49%;
  color: var(--cyan);
  border-color: color-mix(in srgb, var(--cyan) 68%, transparent);
  transform: rotate(-5deg);
  animation-delay: 1.2s;
}

.node {
  position: absolute;
  left: -8%;
  width: 2.65rem;
  height: 2.65rem;
  display: grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  background: var(--bg-strong);
  color: var(--ink);
  font-size: 0;
  font-weight: 800;
  border: 1px solid var(--line);
  box-shadow: var(--soft-shadow);
  animation: floaty 5s ease-in-out infinite;
}

.node::after {
  content: "";
  width: 0.9rem;
  height: 0.9rem;
  border-radius: 5px;
  background: currentColor;
}

.node-school {
  top: 11%;
  color: var(--green);
}

.node-app {
  top: 31%;
  color: var(--violet);
  animation-delay: 0.8s;
}

.node-physical {
  top: 50%;
  color: var(--orange);
  animation-delay: 1.4s;
}

.profile-card {
  position: relative;
  z-index: 3;
  width: min(100%, 490px);
  padding: 0.95rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 26%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--bg-strong) 96%, transparent), color-mix(in srgb, var(--soft) 30%, var(--bg-strong))),
    var(--bg-strong);
  box-shadow: var(--shadow), inset 0 1px 0 rgba(255, 255, 255, 0.7);
  transform-style: preserve-3d;
  will-change: transform;
  transition: transform 0.5s var(--smooth), box-shadow 0.5s var(--smooth);
}

.profile-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background: linear-gradient(115deg, rgba(255, 255, 255, 0.55), transparent 28%, transparent 72%, rgba(8, 175, 206, 0.1));
  opacity: 0.8;
}

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

.card-topline {
  position: absolute;
  top: -1px;
  left: 0;
  right: 0;
  height: 4px;
  border-radius: var(--radius) var(--radius) 0 0;
  background: linear-gradient(90deg, var(--cyan), var(--blue), var(--violet), var(--orange));
  background-size: 220% 100%;
  animation: gradientSlide 5s linear infinite;
}

.profile-header {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.avatar {
  width: 3.1rem;
  height: 3.1rem;
  display: grid;
  place-items: center;
  border: 2px solid rgba(8, 175, 206, 0.34);
  border-radius: 50%;
  color: var(--cyan);
  font-weight: 900;
  box-shadow: inset 0 0 0 8px rgba(8, 175, 206, 0.06);
}

.profile-header h2 {
  font-size: 1rem;
  font-weight: 900;
}

.profile-header p {
  margin-top: 0.2rem;
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
}

.verified {
  margin-left: auto;
  padding: 0.35rem 0.7rem;
  border: 1px solid color-mix(in srgb, var(--green) 42%, var(--line));
  border-radius: var(--radius);
  color: #0e9a50;
  background: rgba(34, 197, 94, 0.08);
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
}

.stream-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.48rem;
  margin-top: 1rem;
}

.stream-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0.58rem;
  background: color-mix(in srgb, var(--soft) 36%, var(--bg-strong));
  overflow: hidden;
  transition: transform 0.35s var(--smooth), border-color 0.35s var(--smooth), background 0.35s var(--smooth);
}

.stream-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--cyan) 42%, var(--line));
}

.stream-icon {
  width: 1.2rem;
  height: 1.2rem;
  display: block;
  border-radius: 5px;
  background: linear-gradient(135deg, var(--cyan), var(--blue));
}

.app-icon {
  background: linear-gradient(135deg, var(--violet), var(--blue));
}

.run-icon {
  background: linear-gradient(135deg, var(--orange), var(--green));
}

.stream-card strong,
.stream-card small {
  display: block;
}

.stream-card strong {
  margin-top: 0.35rem;
  font-size: 0.75rem;
}

.stream-card small {
  color: var(--cyan);
  font-size: 0.68rem;
}

.stream-card i {
  display: block;
  height: 3px;
  margin-top: 0.45rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--cyan), transparent, var(--cyan));
  background-size: 200% 100%;
  animation: streamMeter 2.6s linear infinite;
}

.score-layout {
  display: grid;
  grid-template-columns: 132px 1fr;
  align-items: center;
  gap: 1rem;
  margin-top: 0.75rem;
}

.score-orbit {
  position: relative;
  aspect-ratio: 1;
}

.score-orbit svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.ring {
  fill: transparent;
  stroke-width: 7;
}

.ring.muted {
  stroke: color-mix(in srgb, var(--line) 86%, transparent);
}

.ring-cq,
.ring-eq,
.ring-mq,
.ring-pq {
  stroke-dasharray: 440;
  stroke-dashoffset: 440;
  animation: drawRing 1.8s var(--smooth) forwards, orbitPulse 6.5s ease-in-out infinite;
}

.ring-cq {
  stroke: var(--cyan);
  --dash: 86;
}

.ring-eq {
  stroke: var(--violet);
  --dash: 110;
  animation-delay: 0.18s, 0s;
}

.ring-mq {
  stroke: var(--orange);
  --dash: 138;
  animation-delay: 0.3s, 0s;
}

.ring-pq {
  stroke: var(--green);
  --dash: 106;
  animation-delay: 0.42s, 0s;
}

.score-number {
  position: absolute;
  inset: 0;
  display: grid;
  place-content: center;
  text-align: center;
}

.score-number strong {
  font-size: 1.6rem;
  font-weight: 900;
}

.score-number span {
  color: var(--muted);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.metric-stack {
  display: grid;
  gap: 0.4rem;
}

.metric {
  position: relative;
  padding: 0.42rem 0.62rem 0.62rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--soft) 38%, var(--bg-strong));
  overflow: hidden;
  transition: transform 0.35s var(--smooth), border-color 0.35s var(--smooth), background 0.35s var(--smooth);
}

.metric::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 9%, transparent), transparent);
  transform: translateX(-120%);
  animation: metricScan 7s var(--smooth) infinite;
}

.metric:nth-child(2)::before {
  animation-delay: 1.2s;
}

.metric:nth-child(3)::before {
  animation-delay: 2.4s;
}

.metric:nth-child(4)::before {
  animation-delay: 3.6s;
}

.metric:hover {
  transform: translateX(4px);
  border-color: color-mix(in srgb, var(--accent) 40%, var(--line));
}

.metric span {
  display: block;
  color: var(--muted);
  font-size: 0.68rem;
}

.metric strong {
  display: block;
  margin-top: 0.1rem;
  font-size: 0.82rem;
}

.metric i {
  position: absolute;
  left: 0.62rem;
  right: 0.62rem;
  bottom: 0.34rem;
  height: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 70%, transparent);
  overflow: hidden;
}

.metric i::after {
  content: "";
  display: block;
  height: 100%;
  width: var(--metric);
  border-radius: inherit;
  background: var(--accent);
  transform-origin: left;
  transform: scaleX(0);
  animation: growBar 1.3s ease forwards;
}

.career-panel {
  margin-top: 0.75rem;
}

.panel-heading {
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  text-transform: uppercase;
  font-size: 0.68rem;
  font-weight: 900;
}

.panel-heading a {
  color: var(--cyan);
  text-transform: none;
}

.career-row {
  display: grid;
  grid-template-columns: 2rem 1fr auto;
  align-items: center;
  gap: 0.55rem;
  margin-top: 0.42rem;
  padding: 0.48rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  animation: rowLift 7s var(--smooth) infinite;
  transition: transform 0.35s var(--smooth), border-color 0.35s var(--smooth), box-shadow 0.35s var(--smooth);
}

.career-row:hover {
  border-color: color-mix(in srgb, var(--cyan) 36%, var(--line));
  box-shadow: 0 10px 24px rgba(8, 175, 206, 0.1);
}

.career-row:nth-child(3) {
  animation-delay: 0.7s;
}

.career-row:nth-child(4) {
  animation-delay: 1.4s;
}

.mini-icon {
  width: 1.8rem;
  height: 1.8rem;
  display: block;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--cyan), var(--blue));
}

.palette {
  background: conic-gradient(var(--cyan), var(--violet), var(--orange), var(--green), var(--cyan));
}

.dna {
  background: linear-gradient(135deg, var(--violet), var(--cyan));
}

.bars {
  background: linear-gradient(90deg, var(--green) 0 25%, var(--blue) 25% 50%, var(--orange) 50% 75%, var(--cyan) 75%);
}

.career-row strong,
.career-row small {
  display: block;
}

.career-row strong {
  font-size: 0.82rem;
}

.career-row small {
  color: var(--muted);
  font-size: 0.68rem;
}

.career-row b {
  color: var(--cyan);
  font-size: 0.78rem;
}

.live-chip {
  position: absolute;
  z-index: 4;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
  color: var(--ink);
  font-size: 0.76rem;
  font-weight: 900;
  animation: floaty 4.5s ease-in-out infinite;
}

.chip-a {
  top: -2%;
  right: -1%;
}

.chip-b {
  bottom: -10%;
  left: 6%;
  animation-delay: 1.1s;
}

.credibility-band {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.7rem;
  align-items: center;
  margin: 1rem -4.1rem 0;
  padding: 0.95rem 4.1rem 1.05rem;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.96), rgba(247, 253, 255, 0.9)),
    radial-gradient(circle at 12% 50%, rgba(8, 175, 206, 0.1), transparent 13rem);
  border-top: 1px solid color-mix(in srgb, var(--cyan) 20%, var(--line));
  overflow: hidden;
}

.credibility-band::before,
.credibility-band::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.credibility-band::before {
  left: 4.1rem;
  right: 4.1rem;
  top: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #ef3340, #ffb000, #7fac42, #08afce, #1d5da8, #8f288d);
  background-size: 180% 100%;
  animation: streamMeter 7s linear infinite;
}

.credibility-band::after {
  inset: 0;
  background-image:
    linear-gradient(rgba(8, 175, 206, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(8, 175, 206, 0.06) 1px, transparent 1px);
  background-size: 42px 42px;
  opacity: 0.5;
  mask-image: linear-gradient(90deg, transparent, black 18%, black 82%, transparent);
}

.credibility-band div {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.42rem;
  min-height: 5.05rem;
  padding: 0.7rem 0.62rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg-strong) 86%, transparent);
  box-shadow: 0 12px 26px rgba(16, 35, 60, 0.06);
  transition: transform 0.32s var(--smooth), border-color 0.32s var(--smooth), box-shadow 0.32s var(--smooth);
  animation: recognitionLift 8s var(--smooth) infinite;
}

.credibility-band div:nth-child(2) { animation-delay: 0.45s; }
.credibility-band div:nth-child(3) { animation-delay: 0.9s; }
.credibility-band div:nth-child(4) { animation-delay: 1.35s; }
.credibility-band div:nth-child(5) { animation-delay: 1.8s; }

.credibility-band div:hover {
  animation-play-state: paused;
  border-color: color-mix(in srgb, var(--cyan) 42%, var(--line));
  box-shadow: 0 18px 34px rgba(16, 35, 60, 0.1);
  transform: translateY(-3px);
}

.credibility-band span {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
}

.credibility-band img {
  max-width: 100%;
  max-height: 38px;
  object-fit: contain;
  filter: saturate(0.98) contrast(1.02);
}

.credibility-band .logo-zoho {
  max-height: 42px;
}

.credibility-band .logo-nvidia {
  max-height: 44px;
}

.shift-section {
  padding: 0.5rem 0 5rem;
}

.section-heading {
  max-width: 760px;
}

.section-heading.center {
  margin-inline: auto;
  text-align: center;
}

.section-heading p,
.future-copy > p,
.responsibility-inner > p,
.team-copy > p {
  color: var(--cyan);
  font-weight: 900;
  text-transform: uppercase;
  font-size: 0.78rem;
}

.section-heading h2,
.future-copy h2,
.responsibility h2,
.team-copy h2,
.final-cta h2 {
  margin-top: 0.7rem;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 3rem;
  line-height: 1.04;
  letter-spacing: 0;
}

.section-heading span,
.future-copy > span,
.responsibility-inner > span {
  display: block;
  margin-top: 1rem;
  color: var(--muted);
  font-size: 1.05rem;
}

.story-tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  margin-top: 2rem;
}

.story-card {
  position: relative;
  min-height: 0;
  display: grid;
  grid-template-rows: 190px 1fr;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  isolation: isolate;
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
  transition: transform 0.28s var(--smooth), box-shadow 0.28s var(--smooth), border-color 0.28s var(--smooth);
}

.story-card img,
.empty-room {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s ease;
}

.shift-photo-3 {
  object-position: center 58%;
  filter: saturate(0.9) contrast(0.95) brightness(1.04);
}

.story-card:hover {
  border-color: color-mix(in srgb, var(--cyan) 34%, var(--line));
  box-shadow: 0 18px 44px rgba(15, 43, 71, 0.1);
  transform: translateY(-4px);
}

.story-card:hover img,
.story-card:hover .empty-room {
  transform: scale(1.035);
}

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

.story-card div:last-child {
  position: relative;
  z-index: 2;
  padding: 1.15rem;
  color: var(--ink);
}

.story-card h3 {
  max-width: 290px;
  font-size: 1.1rem;
}

.story-card p {
  max-width: 320px;
  margin-top: 0.45rem;
  color: var(--muted);
  font-size: 0.9rem;
}

.story-card span {
  display: block;
  width: 3.4rem;
  height: 3px;
  margin-top: 0.9rem;
  border-radius: 999px;
  background: var(--cyan);
  transform-origin: left;
  animation: growShrink 3.2s ease-in-out infinite;
}

.empty-room {
  position: relative;
  background:
    radial-gradient(circle at 18% 24%, rgba(8, 175, 206, 0.18), transparent 9rem),
    radial-gradient(circle at 82% 32%, rgba(34, 197, 94, 0.16), transparent 8rem),
    repeating-linear-gradient(90deg, transparent 0 22px, rgba(8, 175, 206, 0.08) 22px 23px),
    repeating-linear-gradient(0deg, transparent 0 22px, rgba(51, 103, 245, 0.06) 22px 23px),
    linear-gradient(135deg, #ffffff, #eef8fc);
}

.empty-room::before,
.empty-room::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.empty-room::before {
  left: 12%;
  right: 12%;
  top: 22%;
  height: 42%;
  border: 1px solid rgba(8, 175, 206, 0.22);
  border-radius: var(--radius);
  background:
    linear-gradient(90deg, rgba(8, 175, 206, 0.16) 0 30%, transparent 30% 100%),
    linear-gradient(180deg, transparent 0 46%, rgba(8, 175, 206, 0.18) 46% 52%, transparent 52% 100%),
    rgba(255, 255, 255, 0.64);
}

.empty-room::after {
  left: 20%;
  right: 20%;
  bottom: 22%;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--cyan), var(--blue), var(--green));
  opacity: 0.78;
}

.reality,
.audience-section,
.students-section,
.future-section,
.team-section {
  display: grid;
  grid-template-columns: 0.88fr 1.12fr;
  gap: 4rem;
  align-items: center;
  padding: 5.5rem 0;
}

.image-frame,
.classroom-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: 0 18px 44px rgba(15, 43, 71, 0.1);
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  background:
    radial-gradient(circle at 20% 18%, rgba(8, 175, 206, 0.1), transparent 12rem),
    var(--bg-strong);
}

.image-frame img,
.classroom-card img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  filter: brightness(1.14) contrast(0.9) saturate(0.88);
}

.image-frame img.reality-photo {
  object-position: center center;
  filter: brightness(1.02) contrast(0.98) saturate(0.96);
}

.classroom-card img.school-photo {
  object-position: center 54%;
  filter: brightness(1.02) contrast(0.97) saturate(0.88);
}

.image-frame::after,
.classroom-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.18), transparent 34%, rgba(255, 255, 255, 0.16)),
    linear-gradient(180deg, transparent 62%, rgba(255, 255, 255, 0.1));
}

.scan-line {
  position: absolute;
  inset-inline: 0;
  height: 3px;
  top: 0;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  box-shadow: 0 0 12px rgba(8, 175, 206, 0.36);
  opacity: 0.62;
  animation: scan 4s ease-in-out infinite;
}

.stacked-points {
  display: grid;
  gap: 0.75rem;
  margin-top: 2rem;
}

.stacked-points article,
.feature-list article,
.student-points article,
.art-grid article {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.stacked-points article {
  display: grid;
  grid-template-columns: 3.2rem minmax(0, 1fr);
  gap: 0.9rem;
  padding: 1rem;
}

.stacked-points span {
  grid-row: 1 / span 2;
  width: 2.3rem;
  height: 2.3rem;
  display: grid;
  place-items: center;
  border-radius: var(--radius);
  background: var(--soft);
  color: var(--cyan);
  font-weight: 900;
}

.stacked-points h3,
.art-grid h3 {
  font-size: 1rem;
}

.stacked-points p,
.art-grid p,
.feature-list p,
.student-points span {
  margin-top: 0.35rem;
  color: var(--muted);
}

.stacked-points p {
  grid-column: 2;
  max-width: 56rem;
  line-height: 1.55;
}

.art-section {
  padding: 5.5rem 0;
}

.art-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
  margin-top: 2.4rem;
}

.art-grid article {
  padding: 1.2rem;
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.art-grid article:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow);
}

.art-graphic {
  width: 4.45rem;
  height: 4.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.1rem;
  color: var(--cyan);
  font-family: "Material Symbols Rounded";
  font-size: 4.45rem;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  direction: ltr;
  font-variation-settings: "FILL" 0, "wght" 500, "GRAD" 0, "opsz" 48;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
}

.art-think {
  color: var(--cyan);
}

.art-behave {
  color: var(--green);
}

.art-decide {
  color: var(--violet);
}

.art-grow {
  color: var(--gold);
}

.art-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1rem;
  padding: 1rem 1.2rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 32%, var(--line));
  border-radius: var(--radius);
  background: linear-gradient(90deg, color-mix(in srgb, var(--cyan) 10%, var(--bg-strong)), var(--bg-strong));
}

.art-cta p {
  color: var(--muted);
}

.art-cta a,
.text-link,
.initiative-card a {
  color: var(--cyan);
  font-weight: 900;
}

.audience-section {
  grid-template-columns: 1fr 0.9fr;
}

.feature-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  margin-top: 2rem;
}

.feature-list article,
.student-points article {
  padding: 1rem;
}

.feature-list strong,
.student-points strong {
  display: block;
  font-size: 0.96rem;
}

.inline-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-top: 1.6rem;
}

.ops-overlay {
  position: absolute;
  left: 1.1rem;
  right: 1.1rem;
  bottom: 1.1rem;
  padding: 1rem;
  border-radius: var(--radius);
  background: color-mix(in srgb, #071322 72%, transparent);
  color: #fff;
  backdrop-filter: blur(18px);
}

.ops-overlay span,
.ops-overlay small {
  display: block;
  color: rgba(255, 255, 255, 0.76);
}

.ops-overlay strong {
  display: block;
  font-size: 3rem;
  line-height: 1;
}

.ops-overlay i {
  display: block;
  height: 4px;
  margin-top: 0.9rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--cyan) 0 92%, rgba(255, 255, 255, 0.18) 92%);
}

.students-section {
  grid-template-columns: 0.86fr 1.14fr;
}

.student-phone {
  display: grid;
  place-items: center;
}

.phone-shell {
  width: min(330px, 100%);
  min-height: 590px;
  padding: 1.2rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 30%, var(--line));
  border-radius: 28px;
  background:
    radial-gradient(circle at 50% 0, rgba(8, 175, 206, 0.22), transparent 11rem),
    linear-gradient(180deg, var(--bg-strong), var(--soft));
  box-shadow: var(--shadow);
  position: relative;
  animation: phoneFloat 5.5s ease-in-out infinite;
}

.phone-top {
  width: 5rem;
  height: 0.45rem;
  margin: 0 auto 2rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 80%, var(--ink));
}

.habit-card,
.path-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  padding: 1rem;
  box-shadow: var(--soft-shadow);
}

.habit-card span,
.path-card span {
  color: var(--cyan);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.habit-card strong,
.path-card strong {
  display: block;
  margin-top: 0.45rem;
  font-size: 1.3rem;
}

.habit-bars {
  display: grid;
  gap: 0.55rem;
  margin-top: 1.25rem;
}

.habit-bars i {
  height: 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 78%, transparent);
  overflow: hidden;
}

.habit-bars i::after {
  content: "";
  display: block;
  width: var(--w);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--cyan), var(--blue));
  animation: growBar 1.2s ease forwards;
}

.path-card {
  margin-top: 1rem;
  background: #071322;
  color: #fff;
}

.path-card p {
  margin-top: 0.55rem;
  color: rgba(255, 255, 255, 0.72);
}

.phone-nav {
  position: absolute;
  left: 50%;
  bottom: 1.25rem;
  transform: translateX(-50%);
  display: flex;
  gap: 0.45rem;
}

.phone-nav b {
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 999px;
  background: var(--cyan);
  opacity: 0.35;
}

.phone-nav b:first-child {
  width: 1.7rem;
  opacity: 1;
}

.student-points {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  margin-top: 2rem;
}

.student-points span {
  display: block;
}

.no-pressure {
  margin-top: 1.5rem;
  color: var(--cyan);
  font-weight: 900;
}

.responsibility {
  padding: 5rem 0;
}

.responsibility-inner {
  padding: 3.8rem;
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 15% 20%, color-mix(in srgb, var(--cyan) 14%, transparent), transparent 18rem),
    linear-gradient(135deg, var(--bg-strong), color-mix(in srgb, var(--soft) 70%, var(--bg-strong)));
  color: var(--ink);
  text-align: center;
  box-shadow: var(--soft-shadow);
  border: 1px solid color-mix(in srgb, var(--cyan) 22%, var(--line));
  overflow: hidden;
  position: relative;
}

.shield-mark {
  width: 3.2rem;
  height: 3.2rem;
  display: inline-block;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.32);
  margin-bottom: 0.9rem;
  position: relative;
}

.shield-mark::after {
  content: "";
  position: absolute;
  inset: 0.8rem 1rem 0.65rem;
  border: 2px solid var(--cyan);
  border-top: 0;
  border-radius: 0 0 50% 50%;
}

.responsibility-inner h2 {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.responsibility-inner > span {
  color: var(--muted);
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.ethics-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.7rem;
  margin-top: 2rem;
}

.ethics-row strong {
  padding: 0.72rem 1rem;
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--cyan) 8%, var(--bg-strong));
  border: 1px solid color-mix(in srgb, var(--cyan) 20%, var(--line));
}

.future-section {
  grid-template-columns: 1fr 0.9fr;
  gap: 4.6rem;
}

.future-lines {
  position: relative;
  display: grid;
  gap: 0.8rem;
  margin: 1.7rem 0;
}

.future-lines p {
  position: relative;
  padding: 1.05rem 1.1rem 1.05rem 3rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 14%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--cyan) 5%, transparent), transparent 38%),
    var(--bg-strong);
  color: var(--muted);
  box-shadow: 0 8px 22px rgba(17, 31, 57, 0.045);
}

.future-lines p::before {
  content: "";
  position: absolute;
  left: 1.05rem;
  top: 1.1rem;
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 999px;
  background: var(--cyan);
  box-shadow: 0 0 0 0.42rem color-mix(in srgb, var(--cyan) 10%, transparent);
}

.future-lines p:nth-child(2)::before {
  background: var(--gold);
  box-shadow: 0 0 0 0.42rem color-mix(in srgb, var(--gold) 14%, transparent);
}

.future-lines strong {
  color: var(--ink);
}

.future-copy .button {
  margin-top: 1.7rem;
}

.initiative-card {
  position: relative;
  overflow: hidden;
  min-height: 430px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.9rem;
  padding: 2rem;
  border: 1px solid color-mix(in srgb, var(--gold) 28%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(250, 247, 239, 0.88)),
    var(--bg-strong);
  box-shadow: 0 22px 54px rgba(17, 31, 57, 0.09);
  transform-style: preserve-3d;
  will-change: transform;
  isolation: isolate;
}

html[data-theme="dark"] .initiative-card {
  background: linear-gradient(145deg, #2a160b, var(--bg-strong));
}

.initiative-glow {
  position: absolute;
  right: -3rem;
  top: -3rem;
  width: 22rem;
  height: 22rem;
  border-radius: 50%;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--cyan) 15%, transparent), transparent 58%),
    conic-gradient(from 160deg, transparent, color-mix(in srgb, var(--gold) 40%, transparent), transparent, color-mix(in srgb, var(--cyan) 24%, transparent), transparent);
  opacity: 0.7;
  filter: blur(2px);
  animation: slowSpin 18s linear infinite;
  z-index: -1;
}

.initiative-card::before {
  content: "";
  position: absolute;
  inset: 1rem;
  border: 1px solid color-mix(in srgb, var(--gold) 18%, transparent);
  border-radius: inherit;
  pointer-events: none;
}

.initiative-card::after {
  content: "";
  position: absolute;
  left: 2rem;
  right: 2rem;
  top: 1.2rem;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--cyan), var(--gold), transparent);
  opacity: 0.76;
}

.initiative-visual {
  position: absolute;
  right: -0.8rem;
  top: 1.4rem;
  width: 10rem;
  height: 10rem;
  pointer-events: none;
  z-index: 0;
  opacity: 0.82;
}

.initiative-orbit {
  position: absolute;
  inset: 0;
  border: 1px solid color-mix(in srgb, var(--cyan) 26%, transparent);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--bg-strong) 76%, transparent) 0 24%, transparent 25%),
    conic-gradient(from 210deg, var(--cyan), var(--gold), color-mix(in srgb, var(--navy) 74%, transparent), var(--cyan));
  opacity: 0.2;
}

.initiative-node {
  position: absolute;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius);
  background: var(--bg-strong);
  border: 1px solid color-mix(in srgb, var(--cyan) 22%, var(--line));
  box-shadow: 0 10px 22px rgba(17, 31, 57, 0.08);
  opacity: 0.86;
}

.initiative-node::before {
  content: "";
  position: absolute;
  inset: 0.55rem;
  border-radius: 4px;
  background: currentColor;
}

.initiative-node.node-a {
  left: 0.6rem;
  top: 1.2rem;
  color: var(--cyan);
}

.initiative-node.node-b {
  right: 0.2rem;
  top: 4.4rem;
  color: var(--gold);
}

.initiative-node.node-c {
  left: 3.6rem;
  bottom: 0.8rem;
  color: var(--green);
}

.initiative-card p {
  position: relative;
  z-index: 1;
  color: color-mix(in srgb, var(--gold) 82%, var(--navy));
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.8rem;
  letter-spacing: 0.03em;
}

.initiative-card h3 {
  position: relative;
  z-index: 1;
  align-self: flex-start;
  width: min(100%, 392px);
  max-width: 392px;
  font-size: clamp(1.85rem, 3vw, 2.25rem);
  line-height: 1.08;
  letter-spacing: 0;
}

.initiative-card span {
  position: relative;
  z-index: 1;
  max-width: 460px;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.55;
}

.initiative-card a {
  position: relative;
  z-index: 1;
  width: fit-content;
  padding-top: 0.25rem;
  border-bottom: 2px solid color-mix(in srgb, var(--cyan) 30%, transparent);
  font-weight: 700;
}

.partners {
  padding: 5rem 0 3rem;
}

.partner-marquee {
  overflow: hidden;
  margin-top: 2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
  mask-image: linear-gradient(90deg, transparent, black 7%, black 93%, transparent);
}

.marquee-track {
  display: flex;
  width: max-content;
  gap: 0.75rem;
  padding: 0.75rem;
  animation: marquee 22s linear infinite;
}

.partner-marquee:hover .marquee-track {
  animation-play-state: paused;
}

.marquee-track article {
  width: 250px;
  display: grid;
  grid-template-columns: 4rem 1fr;
  gap: 0.75rem;
  align-items: center;
  padding: 0.75rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--soft);
}

.marquee-track img {
  width: 4rem;
  height: 4rem;
  object-fit: contain;
  padding: 0.2rem;
  border-radius: var(--radius);
  background: var(--bg-strong);
}

.marquee-track span,
.marquee-track small {
  display: block;
}

.marquee-track span {
  font-weight: 900;
}

.marquee-track small {
  color: var(--muted);
}

.team-section {
  grid-template-columns: 0.85fr 1.15fr;
  gap: 4rem;
  align-items: center;
  padding: 4.5rem 0 5.5rem;
}

.team-copy {
  position: relative;
  padding-left: 1.25rem;
}

.team-copy::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35rem;
  bottom: 0.35rem;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--cyan), color-mix(in srgb, var(--cyan) 30%, transparent));
}

.team-copy span {
  display: block;
  margin-top: 0.7rem;
  color: var(--muted);
}

.team-copy .team-lede {
  margin-top: 1.25rem;
  color: var(--muted);
  font-size: 0.98rem;
  line-height: 1.65;
  max-width: 32ch;
}

.team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}

.team-grid article {
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  border: 1px solid color-mix(in srgb, var(--navy, #111F39) 14%, var(--line));
  border-radius: 20px;
  background: #ffffff;
  box-shadow: 0 6px 18px rgba(15, 43, 71, 0.06);
  overflow: hidden;
  padding: 0.9rem 0.9rem 1.1rem;
  transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.team-grid article:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--cyan) 55%, transparent);
  box-shadow: 0 18px 40px rgba(0, 184, 186, 0.18), 0 2px 8px rgba(15, 43, 71, 0.08);
}

.team-photo {
  height: 190px;
  display: block;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--cyan) 12%, var(--line));
  border-radius: 14px;
  background: var(--bg-strong);
}

.team-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  filter: grayscale(1);
  transition: filter 0.3s ease, transform 0.35s ease;
}

.team-grid article:hover img {
  filter: grayscale(0);
  transform: scale(1.03);
}

.team-grid strong,
.team-grid span {
  display: block;
  padding-inline: 0.25rem;
}

.team-grid strong {
  padding-top: 0.9rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy, #111F39);
  letter-spacing: -0.01em;
}

.team-grid span {
  padding-top: 0.15rem;
  color: var(--muted);
  font-size: 0.85rem;
  font-weight: 400;
}

@media (max-width: 960px) {
  .team-section {
    grid-template-columns: 1fr;
    gap: 2.25rem;
    padding: 3.5rem 0 4rem;
  }
  .team-copy { padding-left: 1rem; }
  .team-copy .team-lede { max-width: none; }
}

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


.final-cta {
  margin-bottom: 5rem;
  padding: 4rem 2rem;
  text-align: center;
  border: 1px solid color-mix(in srgb, var(--cyan) 34%, var(--line));
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 50% 0, rgba(8, 175, 206, 0.22), transparent 18rem),
    var(--bg-strong);
  box-shadow: var(--shadow);
}

.final-cta p {
  max-width: 620px;
  margin: 1rem auto 1.8rem;
  color: var(--muted);
  font-size: 1.06rem;
}

.footer {
  position: relative;
  overflow: hidden;
  margin-top: 4rem;
  padding: 3.4rem 0 1.2rem;
  color: rgba(255, 255, 255, 0.65);
  background:
    radial-gradient(800px 400px at 88% 8%, rgba(0, 184, 186, 0.14), transparent 70%),
    radial-gradient(600px 300px at 4% 90%, rgba(0, 184, 186, 0.06), transparent 70%),
    linear-gradient(180deg, #121b2c 0%, #0d1422 100%);
}

/* Subtle noise texture */
.footer::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.035 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  pointer-events: none;
  opacity: 0.5;
  mix-blend-mode: overlay;
}

.footer::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.18), transparent);
}

.footer-inner {
  position: relative;
  z-index: 1;
  max-width: 1180px;
  margin: 0 auto;
}

.footer-main {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1.1fr 1fr;
  gap: clamp(1.5rem, 3vw, 2.8rem);
  align-items: start;
}


.footer-logo-row {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.footer-logo-row img {
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 50%;
  box-shadow: 0 8px 20px rgba(0, 184, 186, 0.22);
}

.footer-brand strong {
  display: block;
  font-family: "Space Grotesk", Inter, sans-serif;
  color: #fff;
  font-size: 1.12rem;
  letter-spacing: -0.01em;
}

.footer-brand strong span {
  color: #00B8BA;
}

.footer-brand p {
  max-width: 20rem;
  margin: 1.1rem 0 1.4rem;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.65;
  font-size: 0.92rem;
}

.footer-meta {
  display: grid;
  gap: 0.6rem;
}

.footer-meta a,
.footer-meta span {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.88rem;
}

.footer-meta svg {
  width: 0.95rem;
  height: 0.95rem;
  flex: 0 0 auto;
  color: rgba(255, 255, 255, 0.4);
}

.footer p,
.footer span,
.footer a {
  color: rgba(255, 255, 255, 0.55);
}

.footer-col {
  display: grid;
  gap: 0.85rem;
  align-content: start;
}

.footer-title {
  margin-bottom: 0.4rem;
  color: #ffffff !important;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.footer a {
  width: fit-content;
  font-size: 0.92rem;
  transition: color 0.2s ease, transform 0.2s ease;
}

.footer a:hover {
  color: #00B8BA;
  transform: translateX(2px);
}

.footer-entity {
  margin-top: 0.4rem;
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.4) !important;
  line-height: 1.55;
  max-width: 18rem;
}

/* Social row */
.footer-socials {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 10px;
  margin-top: 0.2rem;
}

.footer-socials a {
  width: 40px;
  height: 40px;
  display: inline-grid;
  place-items: center;
  border-radius: 12px;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  transition: transform 0.25s ease, box-shadow 0.25s ease, filter 0.25s ease;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.18);
}

.footer-socials a svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
  color: #fff;
}

.footer-socials a[aria-label="Instagram"] {
  background: linear-gradient(135deg, #F58529 0%, #DD2A7B 50%, #515BD4 100%);
}

.footer-socials a[aria-label="Facebook"] {
  background: #1877F2;
}

.footer-socials a[aria-label="LinkedIn"] {
  background: #0A66C2;
}

.footer-socials a:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.32);
  filter: brightness(1.05);
}

.footer-bottom {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-top: 2.4rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.8rem;
}

.footer-bottom p,
.footer-bottom span {
  margin: 0;
  color: rgba(255, 255, 255, 0.42);
  line-height: 1;
}



.floating-actions {
  position: fixed;
  z-index: 9999;
  right: 24px;
  bottom: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
}

.floating-actions[data-hidden="true"] {
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
  visibility: hidden;
}


/* Stack order: social toggle (top) -> social group -> Call -> WhatsApp (bottom-most, closest to thumb) */
.floating-actions > .social-toggle { order: 1; }
.floating-actions > .social-group  { order: 2; }
.floating-actions > a[aria-label="Call Now"]  { order: 3; }
.floating-actions > a[aria-label="WhatsApp"] { order: 4; }

.floating-actions a {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #111F39;
  color: #fff;
  border: none;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
  transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
  position: relative;
  text-decoration: none;
}

.floating-actions a svg,
.floating-actions .social-toggle svg {
  width: 24px;
  height: 24px;
  fill: #fff;
  color: #fff;
  stroke: #fff;
}
.floating-actions a.social-ig svg,
.floating-actions a.social-fb svg,
.floating-actions a.social-li svg,
.floating-actions .social-toggle svg {
  width: 18px;
  height: 18px;
}

.floating-actions a[aria-label="Call Now"] {
  background: #111F39;
  box-shadow: 0 10px 24px rgba(17, 31, 57, 0.35);
}
.floating-actions a[aria-label="Call Now"]:hover {
  background: #1a2e54;
  box-shadow: 0 14px 30px rgba(17, 31, 57, 0.45);
}
.floating-actions a[aria-label="WhatsApp"] {
  background: #16A34A;
  box-shadow: 0 10px 24px rgba(22, 163, 74, 0.4);
}
.floating-actions a[aria-label="WhatsApp"]:hover {
  background: #128c7e;
  box-shadow: 0 14px 30px rgba(22, 163, 74, 0.5);
}

/* Hover label tooltip for primary actions */
.floating-actions a[aria-label="Call Now"]::after,
.floating-actions a[aria-label="WhatsApp"]::after {
  content: attr(aria-label);
  position: absolute;
  right: calc(100% + 0.6rem);
  top: 50%;
  transform: translateY(-50%) translateX(6px);
  background: #0d1217;
  color: #fff;
  font-size: 0.78rem;
  font-weight: 600;
  padding: 0.35rem 0.65rem;
  border-radius: 0.5rem;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.floating-actions a[aria-label="Call Now"]:hover::after,
.floating-actions a[aria-label="WhatsApp"]:hover::after {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}


.floating-actions a:hover {
  transform: scale(1.05);
}

@media (max-width: 600px) {
  .floating-actions {
    right: 0.9rem;
    bottom: calc(0.9rem + env(safe-area-inset-bottom, 0px));
  }
  .floating-actions a {
    width: 48px;
    height: 48px;
  }
  .floating-actions a svg { width: 20px; height: 20px; }
}

/* Footer "Follow us" social icons */
.footer-follow {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.footer-socials {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.footer-socials a {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.12);
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
}
.footer-socials a svg {
  width: 18px;
  height: 18px;
}
.footer-socials a:hover {
  background: var(--cyan, #12B3D6);
  border-color: var(--cyan, #12B3D6);
  color: #fff;
  transform: translateY(-2px);
}


.school-page {
  background:
    radial-gradient(circle at 10% 8%, rgba(0, 174, 176, 0.08), transparent 30rem),
    radial-gradient(circle at 92% 14%, rgba(184, 154, 69, 0.08), transparent 24rem),
    linear-gradient(180deg, #fff, var(--bg) 34rem);
}

.school-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(24rem, 0.78fr);
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: center;
  min-height: calc(100vh - 5.2rem);
  padding: 5.4rem 0 4.2rem;
}

.school-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 1rem;
  color: var(--cyan);
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.school-hero h1 {
  max-width: 740px;
  margin: 0;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(3.2rem, 6.2vw, 6.6rem);
  line-height: 0.95;
  letter-spacing: -0.02em;
}

.school-hero-copy > p {
  max-width: 680px;
  margin: 1.45rem 0 0;
  color: var(--muted);
  font-size: 1.16rem;
  line-height: 1.75;
}

.school-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 2rem;
}

.school-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
  margin-top: 1.35rem;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.school-trust span {
  width: 0.35rem;
  height: 0.35rem;
  border-radius: 50%;
  background: var(--gold);
}

.school-console-card {
  position: relative;
  overflow: hidden;
  padding: 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 34%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(0, 174, 176, 0.1), transparent 36%),
    var(--bg-strong);
  box-shadow: var(--shadow);
}

.school-console-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(0, 174, 176, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 174, 176, 0.06) 1px, transparent 1px);
  background-size: 22px 22px;
}

.school-console-top,
.school-console-grid,
.school-console-flow {
  position: relative;
  z-index: 1;
}

.school-console-top {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
  padding: 0.8rem;
}

.school-console-top span {
  color: var(--cyan);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.school-console-top strong {
  display: block;
  margin-top: 0.2rem;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.65rem;
}

.school-console-top b {
  padding: 0.5rem 0.75rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 28%, var(--line));
  border-radius: 999px;
  color: var(--ink);
  background: var(--bg-strong);
  font-size: 0.75rem;
  text-transform: uppercase;
}

.school-console-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 1rem;
}

.school-console-grid article {
  min-height: 9rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.8);
  box-shadow: var(--soft-shadow);
}

.school-console-grid .material-symbols-rounded,
.school-feature-grid .material-symbols-rounded,
.service-catalogue .material-symbols-rounded {
  display: inline-grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-bottom: 1rem;
  border-radius: var(--radius);
  color: var(--cyan);
  background: color-mix(in srgb, var(--cyan) 9%, #fff);
  font-size: 1.6rem;
}

.school-console-grid strong {
  display: block;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.55rem;
  line-height: 1;
}

.school-console-grid small {
  display: block;
  margin-top: 0.55rem;
  color: var(--muted);
}

.school-console-flow {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.9rem;
  padding: 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--cyan) 6%, #fff);
}

.school-console-flow i {
  display: block;
  width: 100%;
  height: 0.35rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--cyan), var(--gold), var(--blue), var(--cyan));
  background-size: 200% 100%;
  animation: streamMeter 4s linear infinite;
}

.school-console-flow span {
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 700;
}

.school-compare,
.school-stack,
.school-ai,
.school-art,
.school-services,
.school-day,
.school-proof {
  padding: 4.8rem 0;
}

.compare-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 2rem;
}

.compare-card {
  padding: 1.6rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.compare-card h3 {
  margin: 0 0 1.1rem;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.45rem;
}

.compare-card ul {
  display: grid;
  gap: 0.85rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.compare-card li {
  position: relative;
  padding-left: 1.35rem;
  color: var(--muted);
}

.compare-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
}

.compare-card.old {
  border-color: rgba(201, 137, 59, 0.26);
}

.compare-card.old li::before {
  background: var(--orange);
}

.compare-card.new {
  border-color: color-mix(in srgb, var(--cyan) 34%, var(--line));
  background:
    radial-gradient(circle at 100% 0, rgba(0, 174, 176, 0.12), transparent 12rem),
    var(--bg-strong);
}

.compare-card.new li::before {
  background: var(--cyan);
}

.school-stack .section-heading,
.school-services .section-heading,
.school-day .section-heading {
  max-width: 720px;
}

.money-leak-banner {
  display: grid;
  grid-template-columns: minmax(13rem, 0.42fr) minmax(0, 1fr);
  gap: 1.25rem;
  align-items: center;
  overflow: hidden;
  margin-top: 2rem;
  padding: 1.25rem;
  border: 1px solid color-mix(in srgb, var(--gold) 36%, var(--line));
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 18% 35%, rgba(184, 154, 69, 0.22), transparent 11rem),
    linear-gradient(135deg, #fff, color-mix(in srgb, var(--gold) 7%, #fff));
  box-shadow: var(--soft-shadow);
}

.money-leak-banner h3 {
  max-width: 720px;
  margin: 0.2rem 0 0;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.65rem);
  line-height: 1.05;
}

.money-leak-banner p {
  max-width: 760px;
  margin: 0.8rem 0 0;
  color: var(--muted);
}

.money-leak-banner > div:last-child > span {
  color: var(--orange);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

.tap-animation {
  position: relative;
  min-height: 12rem;
  overflow: hidden;
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, rgba(17, 31, 57, 0.05), transparent),
    color-mix(in srgb, var(--cyan) 5%, #fff);
}

.tap-pipe,
.tap-body,
.tap-neck,
.water-stream,
.tap-animation i {
  position: absolute;
  display: block;
}

.tap-pipe {
  left: 20%;
  top: 1.35rem;
  width: 52%;
  height: 1.05rem;
  border-radius: 999px 0 0 999px;
  background: var(--navy);
}

.tap-body {
  left: 53%;
  top: 1.35rem;
  width: 2.9rem;
  height: 3rem;
  border-radius: 0 0 0.8rem 0.8rem;
  background: var(--navy);
}

.tap-body::before {
  content: "";
  position: absolute;
  left: 0.5rem;
  top: -0.75rem;
  width: 1.9rem;
  height: 0.75rem;
  border-radius: 999px 999px 0 0;
  background: var(--blue);
}

.tap-neck {
  left: 59%;
  top: 4.05rem;
  width: 1.45rem;
  height: 1.4rem;
  border-radius: 0 0 0.45rem 0.45rem;
  background: var(--navy);
}

.water-stream {
  left: calc(59% + 0.38rem);
  top: 5.2rem;
  width: 0.65rem;
  height: 5.6rem;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(0, 174, 176, 0.28), rgba(0, 174, 176, 0.75), rgba(31, 92, 143, 0.14));
  transform-origin: top;
  animation: waterRun 0.9s ease-in-out infinite;
}

.coin {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background:
    radial-gradient(circle at 34% 28%, #fff1b8, transparent 22%),
    linear-gradient(135deg, var(--gold), var(--orange));
  box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.32), 0 8px 16px rgba(184, 154, 69, 0.24);
}

.coin::after {
  content: "";
  position: absolute;
  inset: 0.55rem;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.55);
}

.coin-a {
  left: 46%;
  top: 4.7rem;
  animation: coinDrop 2.4s linear infinite;
}

.coin-b {
  left: 62%;
  top: 5.35rem;
  animation: coinDrop 2.4s linear 0.72s infinite;
}

.coin-c {
  left: 54%;
  top: 6rem;
  animation: coinDrop 2.4s linear 1.35s infinite;
}

.splash {
  bottom: 1.05rem;
  width: 4.2rem;
  height: 0.8rem;
  border: 2px solid color-mix(in srgb, var(--cyan) 58%, #fff);
  border-top: 0;
  border-radius: 0 0 999px 999px;
  opacity: 0.45;
  animation: splashPulse 1.4s ease-in-out infinite;
}

.splash-a {
  left: 45%;
}

.splash-b {
  left: 54%;
  animation-delay: 0.45s;
}

.school-feature-grid,
.service-catalogue,
.proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 2rem;
}

.school-feature-grid article,
.service-catalogue article,
.proof-grid article {
  min-height: 15rem;
  padding: 1.25rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.service-catalogue article {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: auto;
  padding: 0.9rem 0.9rem 1.15rem;
}

.service-photo {
  width: 100%;
  aspect-ratio: 4 / 3;
  height: auto;
  margin: 0 0 1rem;
  border-radius: calc(var(--radius) - 2px);
  background-color: color-mix(in srgb, var(--soft) 70%, var(--bg-strong));
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.36),
    0 1px 0 rgba(17, 31, 57, 0.04);
}

.photo-smart-board { background-image: url("assets/service-smart-board.jpg"); }
.photo-ai-readiness { background-image: url("assets/service-ai-readiness.jpg"); }
.photo-career { background-image: url("assets/service-career.jpg"); background-position: center 42%; }
.photo-stem { background-image: url("assets/service-stem.jpg"); background-position: center 54%; }
.photo-research { background-image: url("assets/service-research.jpg"); }
.photo-competition { background-image: url("assets/service-competition.jpg"); background-position: center 44%; }
.photo-marketing { background-image: url("assets/service-marketing.jpg"); }
.photo-branding { background-image: url("assets/service-branding.jpg"); }
.photo-uniforms { background-image: url("assets/service-uniforms.jpg"); }
.photo-printing { background-image: url("assets/service-printing.jpg"); }
.photo-interior { background-image: url("assets/service-interior.jpg"); }
.photo-magazine { background-image: url("assets/service-magazine.jpg"); }

.service-catalogue article .material-symbols-rounded {
  margin: 0 0 0.9rem;
}

.service-catalogue article h3,
.service-catalogue article p {
  padding-inline: 0.1rem;
}

.service-catalogue article p {
  padding-bottom: 0;
}

.school-feature-grid h3,
.service-catalogue h3 {
  margin: 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.12rem;
}

.school-feature-grid p,
.service-catalogue p {
  margin: 0.75rem 0 0;
  color: var(--muted);
}

.school-ai-card {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(22rem, 0.75fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  padding: 3rem;
  border-radius: var(--radius);
  color: #fff;
  background:
    radial-gradient(circle at 78% 18%, rgba(0, 174, 176, 0.24), transparent 18rem),
    linear-gradient(135deg, #182334, var(--navy));
  box-shadow: var(--shadow);
}

.school-ai-card .school-label {
  color: var(--cyan);
}

.school-ai-card h2 {
  margin: 0;
  max-width: 560px;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(2.4rem, 4vw, 4.4rem);
  line-height: 1;
}

.school-ai-card p {
  max-width: 620px;
  color: rgba(255, 255, 255, 0.68);
}

.agent-flow {
  display: grid;
  gap: 0.75rem;
}

.agent-flow article {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: 0.8rem;
  align-items: center;
  padding: 0.95rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.06);
}

.agent-flow .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  color: var(--cyan);
  background: rgba(0, 174, 176, 0.12);
  font-size: 1.55rem;
}

.agent-flow strong {
  color: rgba(255, 255, 255, 0.86);
}

.art-dimension-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
  margin-top: 2rem;
}

.art-dimension-grid article {
  padding: 1.35rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.art-dimension-grid b {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 1rem;
  border-radius: 50%;
  color: #fff;
  background: var(--cyan);
  font-family: "Space Grotesk", Inter, sans-serif;
}

.art-dimension-grid article:nth-child(2) b {
  background: var(--green);
}

.art-dimension-grid article:nth-child(3) b {
  background: var(--violet);
}

.art-dimension-grid article:nth-child(4) b {
  background: var(--blue);
}

.art-dimension-grid h3 {
  margin: 0;
}

.art-dimension-grid p {
  margin: 0.65rem 0 0;
  color: var(--muted);
}

.service-catalogue article {
  min-height: 21rem;
}

.service-catalogue .material-symbols-rounded {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, #fff);
}

.school-timeline {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 2rem;
}

.school-timeline article {
  display: grid;
  grid-template-columns: 6.2rem 1fr;
  gap: 1rem;
  align-items: start;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
}

.school-timeline time {
  color: var(--cyan);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.school-timeline strong,
.school-timeline span {
  grid-column: 2;
}

.school-timeline strong {
  margin-bottom: -0.5rem;
}

.school-timeline span {
  color: var(--muted);
}

.proof-grid article {
  min-height: 7rem;
  display: grid;
  place-items: center start;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.05rem;
  font-weight: 800;
}

.school-final {
  margin-bottom: 4rem;
  padding: 4rem 2rem;
  border-radius: var(--radius);
  text-align: center;
  color: #fff;
  background:
    radial-gradient(circle at 18% 20%, rgba(0, 174, 176, 0.26), transparent 18rem),
    linear-gradient(135deg, #182334, var(--navy));
  box-shadow: var(--shadow);
}

.school-final h2 {
  max-width: 820px;
  margin: 0 auto;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(2.4rem, 5vw, 5rem);
  line-height: 1;
}

.school-final p {
  max-width: 720px;
  margin: 1rem auto 1.8rem;
  color: rgba(255, 255, 255, 0.68);
}

.school-final > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
}

.partner-page main {
  padding-top: 1.5rem;
}

.partner-hero {
  min-height: min(760px, calc(100vh - 5.5rem));
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(28rem, 0.72fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  padding: clamp(3.5rem, 5.5vw, 5.5rem) 0 3rem;
}

.partner-hero-copy {
  max-width: 760px;
}

.partner-kicker,
.strip-copy p:first-child,
.vidyaa-card p,
.pillars-copy p,
.partner-roadmap .section-heading p {
  margin: 0 0 0.8rem;
  color: var(--cyan);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.partner-hero h1 {
  max-width: 780px;
  margin: 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(3.5rem, 6.4vw, 5.9rem);
  line-height: 0.97;
  letter-spacing: 0;
}

.partner-hero-copy > p:not(.partner-kicker) {
  max-width: 680px;
  margin: 1.2rem 0 0;
  color: var(--muted);
  font-size: clamp(1.05rem, 1.5vw, 1.32rem);
  line-height: 1.55;
}

.partner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-top: 1.75rem;
}

.partner-proof-line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
  margin-top: 1.2rem;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.partner-proof-line span {
  width: 0.28rem;
  height: 0.28rem;
  border-radius: 50%;
  background: var(--gold);
}

.partner-symbol-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(13rem, 0.78fr) minmax(0, 1fr);
  gap: 1rem;
  min-height: 520px;
  padding: 1.1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 20%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--bg-strong) 94%, transparent), var(--bg-strong)),
    linear-gradient(90deg, rgba(17, 31, 57, 0.04), rgba(0, 174, 176, 0.04));
  box-shadow: var(--shadow);
  transform-style: preserve-3d;
  isolation: isolate;
}

.partner-symbol-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0, 174, 176, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 174, 176, 0.045) 1px, transparent 1px);
  background-size: 38px 38px;
  pointer-events: none;
}

.symbol-stage {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 100%;
  border-radius: calc(var(--radius) - 2px);
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 48%, color-mix(in srgb, var(--cyan) 12%, transparent), transparent 13rem),
    color-mix(in srgb, var(--soft) 55%, transparent);
}

.symbol-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.36)),
    radial-gradient(circle at 50% 48%, rgba(0, 174, 176, 0.08), transparent 12rem);
  pointer-events: none;
}

.symbol-photo {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: 44% center;
  filter: saturate(0.9) contrast(0.98);
}

.symbol-logo {
  position: relative;
  z-index: 3;
  width: 8.6rem;
  height: 8.6rem;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  object-fit: cover;
  object-position: center;
  background: #5f9cf4;
  border: 0.55rem solid #5f9cf4;
  box-shadow: 0 16px 34px rgba(17, 31, 57, 0.14);
}

.symbol-orbit,
.symbol-dot {
  position: absolute;
  z-index: 2;
  border-radius: 50%;
}

.symbol-orbit {
  inset: 18%;
  border: 1px dashed color-mix(in srgb, var(--cyan) 42%, transparent);
  animation: partnerOrbit 18s linear infinite;
}

.orbit-two {
  inset: 28%;
  border-color: color-mix(in srgb, var(--gold) 52%, transparent);
  animation-duration: 12s;
  animation-direction: reverse;
}

.symbol-dot {
  z-index: 2;
  width: 1rem;
  height: 1rem;
  background: var(--cyan);
  box-shadow: 0 0 0 0 rgba(0, 174, 176, 0.18);
  animation: dotBreath 2.8s ease-in-out infinite;
}

.dot-one {
  left: 16%;
  top: 24%;
}

.dot-two {
  right: 14%;
  top: 38%;
  background: var(--gold);
  animation-delay: 0.6s;
}

.dot-three {
  left: 34%;
  bottom: 17%;
  background: var(--green);
  animation-delay: 1.1s;
}

.symbol-notes {
  position: relative;
  z-index: 2;
  display: grid;
  align-content: center;
  gap: 0.75rem;
}

.symbol-notes article {
  display: grid;
  grid-template-columns: 2.6rem 1fr;
  gap: 0.72rem;
  align-items: start;
  padding: 0.85rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 12%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 80%, transparent);
  backdrop-filter: blur(12px);
}

.symbol-notes .material-symbols-rounded,
.pathway-grid .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: var(--radius);
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, #fff);
  font-size: 1.45rem;
}

.symbol-notes strong {
  display: block;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 0.88rem;
  text-transform: uppercase;
}

.symbol-notes p {
  margin: 0.2rem 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.45;
}

.partner-strip-system {
  display: grid;
  grid-template-columns: minmax(0, 0.55fr) minmax(0, 1fr);
  gap: clamp(1.4rem, 4vw, 4rem);
  align-items: center;
  padding: 2rem 0 4rem;
}

.strip-copy h2 {
  max-width: 440px;
  margin: 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(2rem, 3.5vw, 3.4rem);
  line-height: 1.02;
  text-transform: uppercase;
}

.strip-copy h2::first-line {
  color: var(--navy);
}

.strip-copy p {
  max-width: 540px;
  color: var(--muted);
}

.partner-strip-board {
  position: relative;
  overflow: hidden;
  padding: 1.1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.strip-line {
  position: relative;
  height: 0.55rem;
  margin-bottom: 1rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 62%, transparent);
  overflow: hidden;
}

.strip-line span {
  position: absolute;
  inset-block: 0;
  left: 0;
  width: 72%;
  border-radius: inherit;
  transform-origin: left;
  animation: stripLoad 5s var(--smooth) infinite;
}

.primary-strip span {
  background: linear-gradient(90deg, var(--navy) 0 52%, var(--cyan) 52% 100%);
}

.accent-strip span {
  width: 64%;
  background: linear-gradient(90deg, var(--violet) 0 45%, var(--orange) 45% 100%);
  animation-delay: 0.35s;
}

.success-strip span {
  width: 44%;
  background: var(--green);
  animation-delay: 0.7s;
}

.pattern-river {
  width: max-content;
  display: flex;
  gap: 1.15rem;
  align-items: center;
  padding-top: 0.25rem;
  animation: motifRun 20s linear infinite;
}

.pattern-river .brand-mark {
  width: 2.6rem;
  height: 2.6rem;
  opacity: 0.92;
}

.vidyaa-section {
  padding: 3rem 0;
}

.vidyaa-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(24rem, 0.72fr);
  gap: 2rem;
  align-items: center;
  padding: clamp(1.5rem, 4vw, 3rem);
  border: 1px solid color-mix(in srgb, var(--gold) 34%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--gold) 8%, #fff), var(--bg-strong)),
    var(--bg-strong);
  box-shadow: var(--shadow);
}

.vidyaa-card h2,
.partner-final h2 {
  max-width: 820px;
  margin: 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(2.35rem, 5vw, 5rem);
  line-height: 0.98;
}

.vidyaa-card span,
.partner-final p,
.pillars-copy span {
  display: block;
  max-width: 640px;
  margin-top: 1rem;
  color: var(--muted);
  font-size: 1.08rem;
}

.impact-flow {
  position: relative;
  display: grid;
  gap: 0.7rem;
}

.impact-flow article {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 4rem;
  padding: 0.9rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 86%, transparent);
}

.impact-flow strong {
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
}

.impact-flow article span {
  width: 40%;
  height: 0.42rem;
  margin: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--cyan), var(--navy));
  transform-origin: left;
  animation: impactMeter 2.8s ease-in-out infinite;
}

.impact-flow article:nth-child(2) span { animation-delay: 0.25s; }
.impact-flow article:nth-child(3) span { animation-delay: 0.5s; }
.impact-flow article:nth-child(4) span { animation-delay: 0.75s; }

.impact-flow > i {
  position: absolute;
  left: 1.25rem;
  top: 2rem;
  bottom: 2rem;
  width: 2px;
  background: linear-gradient(180deg, transparent, var(--cyan), var(--gold), transparent);
  animation: flowScan 3.4s linear infinite;
}

.pathways-section {
  padding: 4rem 0;
}

.pathway-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 2rem;
}

.pathway-grid article {
  min-height: 16rem;
  padding: 1.25rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.pathway-grid article:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--cyan) 34%, var(--line));
  box-shadow: var(--shadow);
}

.pathway-grid article:nth-child(2) .material-symbols-rounded { color: var(--green); background: color-mix(in srgb, var(--green) 12%, #fff); }
.pathway-grid article:nth-child(3) .material-symbols-rounded { color: var(--violet); background: color-mix(in srgb, var(--violet) 12%, #fff); }
.pathway-grid article:nth-child(4) .material-symbols-rounded { color: var(--cyan); background: color-mix(in srgb, var(--cyan) 12%, #fff); }
.pathway-grid article:nth-child(5) .material-symbols-rounded { color: var(--orange); background: color-mix(in srgb, var(--orange) 12%, #fff); }
.pathway-grid article:nth-child(6) .material-symbols-rounded { color: var(--gold); background: color-mix(in srgb, var(--gold) 12%, #fff); }

.pathway-grid h3 {
  margin: 1.15rem 0 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.18rem;
}

.pathway-grid p {
  margin: 0.75rem 0 0;
  color: var(--muted);
}

.pathway-grid p strong {
  color: var(--ink);
  font-weight: 800;
}

.ngo-partner-section,
.institution-section {
  padding: 4rem 0;
}

.ngo-partner-hero {
  display: grid;
  grid-template-columns: minmax(18rem, 0.52fr) minmax(0, 1fr);
  gap: clamp(1.1rem, 3vw, 2.4rem);
  align-items: stretch;
}

.aina-identity-card {
  position: relative;
  overflow: hidden;
  min-height: 21rem;
  padding: 1.3rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cyan) 7%, #fff), var(--bg-strong) 55%),
    var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.aina-identity-card::after {
  content: "";
  position: absolute;
  left: 1.3rem;
  right: 1.3rem;
  bottom: 1.1rem;
  height: 0.2rem;
  border-radius: 999px;
  background: linear-gradient(90deg, #d9232e, #f2d23b 31%, #6fc4dc 55%, #1a267a 78%, var(--cyan));
  opacity: 0.78;
}

.aina-mark {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 13.5rem;
  border: 1px solid color-mix(in srgb, var(--navy) 8%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 82%, transparent);
}

.aina-mark span {
  position: absolute;
  width: 5.2rem;
  height: 5.2rem;
  border: 1px solid color-mix(in srgb, var(--navy) 24%, transparent);
  clip-path: polygon(50% 0, 100% 100%, 0 74%);
  animation: ainaFloat 7s ease-in-out infinite;
}

.aina-mark span:nth-child(1) {
  left: 12%;
  top: 9%;
  background: #e52d2d;
  transform: rotate(-36deg);
}

.aina-mark span:nth-child(2) {
  right: 12%;
  top: 12%;
  background: #c8c8c8;
  transform: rotate(39deg);
  animation-delay: 0.3s;
}

.aina-mark span:nth-child(3) {
  left: 12%;
  bottom: 10%;
  background: #f1e642;
  transform: rotate(-140deg);
  animation-delay: 0.6s;
}

.aina-mark span:nth-child(4) {
  right: 12%;
  bottom: 9%;
  background: #15198e;
  transform: rotate(150deg);
  animation-delay: 0.9s;
}

.aina-mark strong {
  position: relative;
  z-index: 1;
  color: #111;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: 1;
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.12em;
  text-shadow: 0.24rem 0.24rem 1rem rgba(17, 31, 57, 0.18);
}

.aina-identity-card > p,
.ngo-partner-copy > p {
  margin: 1rem 0 0;
  color: var(--cyan);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.aina-identity-card h2 {
  margin: 0.3rem 0 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(1.5rem, 2.4vw, 2.35rem);
  line-height: 1.05;
}

.ngo-partner-copy {
  position: relative;
  overflow: hidden;
  display: grid;
  align-content: center;
  padding: clamp(1.5rem, 4vw, 3rem);
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--cyan) 9%, #fff), transparent 62%),
    var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.ngo-partner-copy::before {
  content: "";
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  top: 0;
  height: 0.22rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--navy), var(--cyan), var(--gold), var(--green));
}

.ngo-partner-copy h2 {
  max-width: 740px;
  margin: 0.55rem 0 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(2.2rem, 4.5vw, 4.65rem);
  line-height: 0.98;
}

.ngo-partner-copy span,
.ngo-statement,
.institution-intro {
  color: var(--muted);
  font-size: 1.08rem;
  line-height: 1.75;
}

.ngo-partner-copy span {
  display: block;
  max-width: 760px;
  margin-top: 1rem;
}

.ngo-statement,
.institution-intro {
  max-width: 900px;
  margin: 1.7rem auto 0;
  text-align: center;
}

.partner-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
}

.partner-detail-card {
  min-height: 20rem;
  padding: clamp(1.2rem, 3vw, 2rem);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.detail-card-title {
  display: flex;
  gap: 0.7rem;
  align-items: center;
  color: var(--cyan);
}

.detail-card-title.gold {
  color: var(--gold);
}

.detail-card-title .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius);
  background: color-mix(in srgb, currentColor 10%, #fff);
  font-size: 1.4rem;
}

.detail-card-title h3 {
  margin: 0;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.25rem;
}

.partner-detail-card ul {
  display: grid;
  gap: 0.75rem;
  margin: 1.2rem 0 0;
  padding: 0;
  list-style: none;
}

.partner-detail-card li {
  position: relative;
  padding-left: 1.25rem;
  color: var(--muted);
}

.partner-detail-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: currentColor;
  color: var(--cyan);
  box-shadow: 0 0 0 0.22rem color-mix(in srgb, var(--cyan) 9%, transparent);
}

.partner-detail-card:nth-child(2) li::before {
  color: var(--gold);
  box-shadow: 0 0 0 0.22rem color-mix(in srgb, var(--gold) 10%, transparent);
}

.institution-section {
  position: relative;
}

.institution-focus-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
  margin-top: 2rem;
}

.institution-focus-grid article {
  position: relative;
  min-height: 11.8rem;
  padding: 1.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  text-align: center;
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.institution-focus-grid article::before {
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  top: 0;
  height: 0.22rem;
  border-radius: 999px;
  background: var(--cyan);
}

.institution-focus-grid article:nth-child(2)::before { background: var(--violet); }
.institution-focus-grid article:nth-child(3)::before { background: var(--gold); }
.institution-focus-grid article:nth-child(4)::before { background: var(--green); }

.institution-focus-grid .material-symbols-rounded {
  color: var(--cyan);
  font-size: 2.25rem;
}

.institution-focus-grid article:nth-child(2) .material-symbols-rounded { color: var(--violet); }
.institution-focus-grid article:nth-child(3) .material-symbols-rounded { color: var(--gold); }
.institution-focus-grid article:nth-child(4) .material-symbols-rounded { color: var(--green); }

.institution-focus-grid strong {
  display: block;
  margin-top: 0.5rem;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.08rem;
}

.institution-focus-grid p {
  margin: 0.45rem 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
}

.institution-needs {
  margin-top: 1rem;
}

.coming-soon-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.coming-card {
  min-height: 14rem;
  overflow: hidden;
  padding: 0 0 clamp(1.3rem, 3vw, 2rem);
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  text-align: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cyan) 6%, #fff), var(--bg-strong) 62%),
    var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.coming-photo {
  position: relative;
  height: 11rem;
  margin-bottom: 1.4rem;
  overflow: hidden;
  background: color-mix(in srgb, var(--cyan) 8%, var(--soft));
}

.coming-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 45%, rgba(255, 255, 255, 0.72)),
    linear-gradient(90deg, rgba(17, 31, 57, 0.1), transparent 42%, rgba(0, 174, 176, 0.08));
  pointer-events: none;
}

.coming-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
  filter: saturate(0.92) contrast(0.98);
}

.coming-card:nth-child(1) .coming-photo img {
  object-position: 62% 42%;
}

.coming-card:nth-child(2) .coming-photo img {
  object-position: 48% 38%;
}

.coming-card .material-symbols-rounded {
  color: var(--cyan);
  font-size: 2.6rem;
}

.coming-card h3 {
  margin: 0.45rem 0 0;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.coming-card strong {
  display: block;
  margin-top: 0.4rem;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.65rem;
}

.coming-card p {
  max-width: 460px;
  margin: 0.7rem auto 0;
  padding-inline: 1.4rem;
  color: var(--muted);
}

.pillars-section {
  display: grid;
  grid-template-columns: minmax(0, 0.54fr) minmax(0, 1fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: start;
  padding: 4rem 0;
}

.pillars-copy h2 {
  margin: 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(2.2rem, 4vw, 4.2rem);
  line-height: 1;
}

.pillar-track {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.pillar-track article {
  position: relative;
  overflow: hidden;
  min-height: 19.5rem;
  padding: 0.8rem 0.8rem 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.pillar-track article::before {
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  top: 0;
  height: 0.22rem;
  z-index: 2;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--navy), var(--cyan));
}

.pillar-track article:nth-child(2)::before { background: linear-gradient(90deg, var(--cyan), var(--green)); }
.pillar-track article:nth-child(3)::before { background: linear-gradient(90deg, var(--violet), var(--orange)); }
.pillar-track article:nth-child(4)::before { background: linear-gradient(90deg, var(--gold), var(--green)); }

.pillar-photo {
  position: relative;
  overflow: hidden;
  height: 8.5rem;
  margin-bottom: 0.9rem;
  border-radius: calc(var(--radius) - 1px);
  background: color-mix(in srgb, var(--cyan) 8%, var(--soft));
}

.pillar-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 42%, rgba(17, 31, 57, 0.22)),
    linear-gradient(90deg, rgba(255, 255, 255, 0.22), transparent 58%);
  pointer-events: none;
}

.pillar-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.92) contrast(0.98);
  transition: transform 0.2s ease;
}

.pillar-track article:hover .pillar-photo img {
  transform: scale(1.03);
}

.pillar-track article:nth-child(1) .pillar-photo img { object-position: 62% 42%; }
.pillar-track article:nth-child(2) .pillar-photo img { object-position: 48% 38%; }
.pillar-track article:nth-child(3) .pillar-photo img { object-position: center; }
.pillar-track article:nth-child(4) .pillar-photo img { object-position: 48% 38%; }

.pillar-track b {
  display: block;
  color: color-mix(in srgb, var(--cyan) 76%, var(--navy));
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 0.8rem;
}

.pillar-track strong {
  display: block;
  margin-top: 0.55rem;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 1.42rem;
}

.pillar-track span {
  display: block;
  margin-top: 0.55rem;
  color: var(--muted);
}

.partner-roadmap {
  padding: 4rem 0;
}

.roadmap-line {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 2rem;
}

.roadmap-line::before {
  content: "";
  position: absolute;
  left: 2rem;
  right: 2rem;
  top: 2.1rem;
  height: 2px;
  background: linear-gradient(90deg, var(--navy), var(--cyan), var(--gold), var(--green));
  opacity: 0.48;
}

.roadmap-line article {
  position: relative;
  min-height: 12.5rem;
  padding: 4rem 1rem 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 92%, transparent);
  box-shadow: var(--soft-shadow);
}

.roadmap-line article::before {
  content: "";
  position: absolute;
  left: 1.25rem;
  top: 1.58rem;
  width: 1.05rem;
  height: 1.05rem;
  border: 3px solid var(--bg-strong);
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--cyan) 34%, var(--line));
  animation: dotBreath 3s ease-in-out infinite;
}

.roadmap-line article:nth-child(2)::before { background: var(--green); animation-delay: 0.25s; }
.roadmap-line article:nth-child(3)::before { background: var(--gold); animation-delay: 0.5s; }
.roadmap-line article:nth-child(4)::before { background: var(--violet); animation-delay: 0.75s; }

.roadmap-line time {
  color: var(--cyan);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.roadmap-line strong {
  display: block;
  margin-top: 0.5rem;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
}

.roadmap-line span {
  display: block;
  margin-top: 0.55rem;
  color: var(--muted);
  font-size: 0.92rem;
}

.partner-final {
  margin: 4rem auto;
  padding: clamp(2rem, 5vw, 4rem);
  border: 1px solid color-mix(in srgb, var(--cyan) 24%, var(--line));
  border-radius: var(--radius);
  text-align: center;
  background:
    radial-gradient(circle at 50% 0, rgba(0, 174, 176, 0.14), transparent 20rem),
    var(--bg-strong);
  box-shadow: var(--shadow);
}

.partner-final h2,
.partner-final p {
  margin-left: auto;
  margin-right: auto;
}

.partner-final .button {
  margin-top: 1.6rem;
}

.mini-pattern-strip {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  margin-bottom: 1.4rem;
}

.mini-pattern-strip .brand-mark {
  width: 2rem;
  height: 2rem;
  animation: stripPop 4.8s var(--smooth) infinite;
}

.mini-pattern-strip .brand-mark:nth-child(2) { animation-delay: 0.18s; }
.mini-pattern-strip .brand-mark:nth-child(3) { animation-delay: 0.36s; }
.mini-pattern-strip .brand-mark:nth-child(4) { animation-delay: 0.54s; }
.mini-pattern-strip .brand-mark:nth-child(5) { animation-delay: 0.72s; }

.about-page main {
  padding-top: 0.5rem;
}

.about-page {
  --about-section-y: clamp(3.2rem, 5vw, 5rem);
  --about-section-gap: clamp(1.4rem, 3.2vw, 3.5rem);
}

/* Safety: keep About sections breathing even if the page class isn't on <body> yet
   (e.g. first paint before React mounts effects, or static crawl) */
.about-hero,
.about-story-section,
.about-build-section,
.about-art-section,
.about-workflow-section,
.about-reveal-section,
.about-ecosystem-section,
.about-shift-section,
.about-mission-section,
.about-values-section,
.about-team-section,
.about-company-section,
.about-final {
  --about-section-y: clamp(3.2rem, 5vw, 5rem);
  --about-section-gap: clamp(1.4rem, 3.2vw, 3.5rem);
}

.about-kicker {
  margin: 0 0 0.85rem;
  color: var(--cyan);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.about-hero {
  min-height: calc(100vh - 5.5rem);
  display: grid;
  grid-template-columns: minmax(0, 0.98fr) minmax(31rem, 0.82fr);
  gap: clamp(2.2rem, 6vw, 6.5rem);
  align-items: center;
  padding: clamp(2.2rem, 4.4vw, 3.8rem) 0 clamp(2.4rem, 4.5vw, 3.8rem);
}

.about-hero-copy h1,
.about-story-copy h2,
.about-build-section h2,
.about-art-copy h2,
.about-workflow-copy h2,
.about-reveal-copy h2,
.about-shift-copy h2,
.about-values-section h2,
.about-team-intro h2,
.about-company-card h2,
.about-final h2 {
  margin: 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  color: var(--ink);
  letter-spacing: 0;
  line-height: 1.04;
}

.about-hero-copy h1 {
  max-width: 850px;
  font-size: clamp(3.6rem, 6.2vw, 5.65rem);
  line-height: 1.02;
}

.about-hero-copy h1 span {
  display: block;
  color: transparent;
  background: linear-gradient(90deg, var(--cyan), var(--green), var(--gold));
  background-size: 180% 100%;
  background-clip: text;
  animation: gradientSlide 8s ease infinite;
}

.about-hero-copy > p {
  max-width: 650px;
  margin: 1.55rem 0 0;
  color: var(--muted);
  font-size: clamp(1.08rem, 1.7vw, 1.32rem);
  line-height: 1.65;
}

.about-hero-actions,
.about-trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.7rem;
  margin-top: 1.55rem;
}

.about-trust {
  gap: 0.75rem;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
}

.about-trust span {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}

.about-trust span:not(:last-child)::after {
  content: "";
  width: 0.25rem;
  height: 0.25rem;
  border-radius: 50%;
  background: var(--gold);
}

.about-pattern-card {
  position: relative;
  min-height: 22rem;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(12rem, 0.84fr) minmax(16rem, 1fr);
  gap: 1.2rem;
  padding: 1.2rem;
  border: 1px solid color-mix(in srgb, #00B8BA 18%, var(--line));
  border-radius: calc(var(--radius) * 1.5);
  background:
    linear-gradient(rgba(0, 184, 186, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 184, 186, 0.035) 1px, transparent 1px),
    #FFFFFF;
  background-size: 2.25rem 2.25rem, 2.25rem 2.25rem, auto;
  box-shadow: 0 24px 64px rgba(17, 31, 57, 0.07);
}


.about-trajectory-card {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  grid-template-columns: 1fr;
  gap: 0.9rem;
  padding: clamp(1rem, 2vw, 1.35rem);
  color: var(--ink);
}

.trajectory-label {
  width: fit-content;
  padding: 0.58rem 0.76rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 24%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg-strong) 88%, transparent);
  color: var(--cyan);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.about-trajectory-svg {
  width: 100%;
  height: auto;
  min-height: 20rem;
  color: var(--navy);
}

html[data-theme="dark"] .about-trajectory-svg {
  color: var(--ink);
}

/* === Signals → Pattern → Profile diagram === */
.trajectory-stage {
  fill: #111F39;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.22em;
  opacity: 0.72;
}
.trajectory-stage-mid { fill: #00B8BA; opacity: 0.95; }
.trajectory-stage-end { fill: #C7A84E; opacity: 0.95; }

.trajectory-step-arrow {
  color: #111F39;
  stroke: currentColor;
  stroke-width: 1.2;
  stroke-linecap: round;
  opacity: 0.4;
}

.trajectory-line {
  color: #00B8BA;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-dasharray: 520;
  animation: trajectoryDraw 5s var(--smooth) infinite;
}

.signal-chips text {
  font-family: "Space Grotesk", Inter, sans-serif;
  fill: #111F39;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  dominant-baseline: middle;
}
.signal-chips .chip-sub {
  font-weight: 500;
  fill: #111F39;
  opacity: 0.55;
  letter-spacing: 0.02em;
}
.signal-chip rect {
  fill: #FFFFFF;
  stroke: #00B8BA;
  stroke-width: 1;
  stroke-opacity: 0.5;
}
.signal-chip .chip-dot { fill: #00B8BA; }
.signal-chip:nth-of-type(2) .chip-dot { fill: #C7A84E; }
.signal-chip:nth-of-type(2) rect { stroke: #C7A84E; }
.signal-chip:nth-of-type(3) .chip-dot { fill: #111F39; }
.signal-chip:nth-of-type(3) rect { stroke: #111F39; stroke-opacity: 0.35; }
.signal-chip:nth-of-type(4) .chip-dot { fill: #00B8BA; }

.wave-node circle {
  fill: #FFFFFF;
  stroke: #00B8BA;
  stroke-width: 1.6;
}
.wave-node:nth-of-type(2) circle { stroke: #C7A84E; }
.wave-node:nth-of-type(3) circle { stroke: #111F39; }


.trajectory-profile { color: #111F39; }
.trajectory-profile .profile-card {
  fill: #FFFFFF;
  stroke: #111F39;
  stroke-width: 1.6;
}
.trajectory-profile .profile-halo {
  fill: rgba(0, 184, 186, 0.08);
  stroke: none;
}
.trajectory-profile .profile-head {
  fill: none;
  stroke: #111F39;
  stroke-width: 2;
}
.trajectory-profile .profile-shoulders {
  fill: none;
  stroke: #111F39;
  stroke-width: 2;
  stroke-linecap: round;
}
.trajectory-profile .profile-rule {
  stroke: #C7A84E;
  stroke-width: 1.4;
  stroke-linecap: round;
  opacity: 0.7;
}
.trajectory-profile .profile-title {
  fill: #111F39;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-anchor: middle;
  dominant-baseline: middle;
}
.trajectory-profile .profile-pulse {
  fill: #00B8BA;
  animation: dotBreath 2.8s ease-in-out infinite;
}
.trajectory-profile .profile-pulse-alt { fill: #C7A84E; }

html[data-theme="dark"] .about-pattern-card {
  background:
    linear-gradient(rgba(0, 184, 186, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 184, 186, 0.05) 1px, transparent 1px),
    var(--bg-strong);
}
html[data-theme="dark"] .signal-chip rect,
html[data-theme="dark"] .wave-node circle,
html[data-theme="dark"] .trajectory-profile .profile-card { fill: var(--bg-strong); }
html[data-theme="dark"] .signal-chips text,
html[data-theme="dark"] .signal-chips .chip-sub,
html[data-theme="dark"] .trajectory-stage,
html[data-theme="dark"] .trajectory-profile .profile-title { fill: var(--ink); }
html[data-theme="dark"] .trajectory-profile .profile-head,
html[data-theme="dark"] .trajectory-profile .profile-shoulders { stroke: var(--ink); }



.trajectory-caption {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  align-items: center;
  gap: 1.25rem;
  padding: 0.95rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 90%, transparent);
}

.trajectory-caption strong {
  color: var(--ink);
  font-weight: 900;
  white-space: nowrap;
}

.trajectory-caption span {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 650;
  text-align: right;
}

.about-grid-glow {
  position: absolute;
  inset: 1.2rem auto 1.2rem 1.2rem;
  width: min(16rem, 42%);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(0, 174, 176, 0.035));
  border: 1px solid rgba(17, 31, 57, 0.055);
}

.about-symbol-stage {
  position: relative;
  z-index: 1;
  min-height: 23.5rem;
  display: grid;
  place-items: center;
}

.about-symbol-orbit {
  position: absolute;
  width: 14rem;
  height: 14rem;
  border: 1px dashed color-mix(in srgb, var(--cyan) 45%, transparent);
  border-radius: 50%;
  animation: partnerOrbit 18s linear infinite;
}

.about-symbol-orbit::before,
.about-symbol-orbit::after {
  content: "";
  position: absolute;
  inset: 1.8rem;
  border: 1px dashed color-mix(in srgb, var(--gold) 42%, transparent);
  border-radius: 50%;
}

.about-symbol-orbit::after {
  inset: 3.6rem;
  border-color: color-mix(in srgb, var(--green) 38%, transparent);
}

.about-symbol-orbit span {
  position: absolute;
  width: 0.85rem;
  height: 0.85rem;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 0 8px rgba(0, 174, 176, 0.1);
}

.about-symbol-orbit span:nth-child(1) { left: 10%; top: 22%; }
.about-symbol-orbit span:nth-child(2) { right: 5%; top: 48%; background: var(--gold); box-shadow: 0 0 0 8px rgba(184, 154, 69, 0.1); }
.about-symbol-orbit span:nth-child(3) { left: 38%; bottom: 4%; background: var(--green); box-shadow: 0 0 0 8px rgba(95, 141, 106, 0.1); }

.about-symbol-core {
  position: relative;
  z-index: 2;
  width: 7.6rem;
  height: 7.6rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #5a98f6;
  box-shadow: 0 20px 44px rgba(31, 92, 143, 0.18);
  animation: dotBreath 4.6s ease-in-out infinite;
}

.about-symbol-core img {
  width: 5.35rem;
  height: 5.35rem;
  border-radius: 50%;
  object-fit: cover;
  filter: brightness(0) invert(1);
}

.about-signal-stack {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 0.85rem;
}

.about-signal-stack article {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.85rem;
  min-height: 6.6rem;
  padding: 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 88%, transparent);
  box-shadow: var(--soft-shadow);
}

.about-signal-stack article::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--cyan);
}

.about-signal-stack article:nth-child(2)::before { background: var(--gold); }
.about-signal-stack article:nth-child(3)::before { background: var(--green); }

.about-signal-stack .material-symbols-rounded {
  width: 2.9rem;
  height: 2.9rem;
  display: grid;
  place-items: center;
  border-radius: var(--radius);
  background: var(--soft);
  color: var(--blue);
  font-size: 1.62rem;
}

.about-signal-stack strong {
  display: block;
  color: var(--ink);
  font-weight: 850;
}

.about-signal-stack small {
  color: var(--muted);
  font-weight: 600;
}

.about-signal-stack i {
  grid-column: 1 / -1;
  position: relative;
  height: 0.32rem;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cyan) 12%, var(--soft));
}

.about-signal-stack i::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 72%;
  border-radius: inherit;
  transform-origin: left;
  background: linear-gradient(90deg, var(--cyan), var(--navy));
  animation: signalBar 3.8s ease-in-out infinite;
}

.about-story-section,
.about-build-section,
.about-art-section,
.about-workflow-section,
.about-reveal-section,
.about-ecosystem-section,
.about-shift-section,
.about-mission-section,
.about-values-section,
.about-team-section,
.about-company-section {
  overflow: visible;
  padding: var(--about-section-y) 0;
}

.about-story-grid,
.about-art-section,
.about-reveal-section,
.about-shift-section {
  display: grid;
  grid-template-columns: minmax(0, 0.76fr) minmax(0, 1.24fr);
  gap: var(--about-section-gap);
  align-items: start;
}

.about-story-grid {
  position: relative;
  grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.8fr);
  gap: clamp(1.2rem, 3vw, 2rem);
  padding: clamp(1rem, 2.4vw, 1.6rem);
  border: 1px solid color-mix(in srgb, var(--cyan) 16%, var(--line));
  border-radius: calc(var(--radius) * 1.6);
  background:
    linear-gradient(120deg, color-mix(in srgb, var(--cyan) 7%, transparent), transparent 62%),
    var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.about-story-grid::after {
  content: "";
  position: absolute;
  top: 1.6rem;
  bottom: 1.6rem;
  left: 50%;
  width: 1px;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--cyan) 30%, var(--line)), transparent);
}

.about-story-copy,
.about-belief-card,
.about-art-card,
.about-company-card {
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) * 1.5);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.about-story-copy {
  padding: clamp(1.4rem, 3vw, 2.4rem);
  border: 0;
  background: transparent;
  box-shadow: none;
}

.about-story-copy h2,
.about-art-copy h2,
.about-workflow-copy h2,
.about-reveal-copy h2,
.about-shift-copy h2,
.about-team-intro h2,
.about-company-card h2 {
  font-size: clamp(2.3rem, 4.6vw, 4.25rem);
}

.about-story-lines {
  display: grid;
  gap: 0.75rem;
  margin: 1.3rem 0;
}

.about-story-lines p {
  margin: 0;
  padding: 0.9rem 1rem;
  border-radius: var(--radius);
  color: var(--muted);
  background: color-mix(in srgb, var(--soft) 58%, transparent);
  font-size: 1.04rem;
  font-weight: 650;
}

.about-story-copy strong {
  display: block;
  color: var(--ink);
  font-size: 1.06rem;
  line-height: 1.55;
}

.about-belief-card {
  display: grid;
  align-content: center;
  padding: clamp(1.4rem, 3vw, 2.25rem);
  border: 0;
  background: color-mix(in srgb, var(--soft) 50%, var(--bg-strong));
  box-shadow: none;
}

.about-belief-pills {
  display: grid;
  gap: 0.75rem;
}

.about-belief-pills span {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 3.7rem;
  padding: 0.85rem 1rem 0.85rem 2.6rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: 999px;
  color: var(--ink);
  background: var(--bg-strong);
  font-weight: 800;
}

.about-belief-pills span::before {
  content: "";
  position: absolute;
  left: 1rem;
  width: 0.72rem;
  height: 0.72rem;
  border-radius: 50%;
  background: var(--cyan);
  animation: dotBreath 3.4s ease-in-out infinite;
}

.about-belief-pills span:nth-child(2)::before { background: var(--gold); animation-delay: 0.25s; }
.about-belief-pills span:nth-child(3)::before { background: var(--green); animation-delay: 0.5s; }

.about-build-section .section-heading,
.about-ecosystem-section .section-heading,
.about-values-section .section-heading {
  margin-bottom: 1.8rem;
}

.about-system-grid,
.about-ecosystem-grid,
.about-values-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.about-system-grid article,
.about-ecosystem-grid article,
.about-values-grid article,
.about-mission-section article {
  position: relative;
  overflow: hidden;
  min-height: 15.5rem;
  padding: 1.25rem;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) * 1.4);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.about-system-grid article:hover,
.about-ecosystem-grid article:hover,
.about-values-grid article:hover,
.about-team-grid article:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--cyan) 28%, var(--line));
  box-shadow: 0 16px 36px rgba(17, 31, 57, 0.08);
}

.about-system-grid article::before,
.about-ecosystem-grid article::before,
.about-values-grid article::before {
  content: "";
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  top: 0;
  height: 0.22rem;
  border-radius: 0 0 999px 999px;
  background: linear-gradient(90deg, var(--navy), var(--cyan));
  transform-origin: left;
  animation: impactMeter 4s ease-in-out infinite;
}

.about-system-grid article:nth-child(2)::before,
.about-ecosystem-grid article:nth-child(2)::before,
.about-values-grid article:nth-child(2)::before {
  background: linear-gradient(90deg, var(--cyan), var(--green));
  animation-delay: 0.3s;
}

.about-system-grid article:nth-child(3)::before,
.about-ecosystem-grid article:nth-child(3)::before,
.about-values-grid article:nth-child(3)::before {
  background: linear-gradient(90deg, var(--gold), var(--green));
  animation-delay: 0.6s;
}

.about-system-grid .material-symbols-rounded,
.about-ecosystem-grid .material-symbols-rounded {
  width: 3.3rem;
  height: 3.3rem;
  display: grid;
  place-items: center;
  margin-bottom: 1.4rem;
  border-radius: var(--radius);
  background: var(--soft);
  color: var(--blue);
  font-size: 1.8rem;
}

.about-system-grid strong,
.about-ecosystem-grid h3,
.about-values-grid strong {
  display: block;
  margin: 0 0 0.75rem;
  color: var(--ink);
  font-size: 1.16rem;
  font-weight: 850;
}

.about-system-grid p,
.about-ecosystem-grid p,
.about-values-grid p,
.about-art-copy p,
.about-workflow-copy p,
.about-reveal-copy p,
.about-shift-copy p,
.about-team-intro p {
  margin: 0;
  color: var(--muted);
  font-size: 1.02rem;
  line-height: 1.65;
}

.about-art-copy {
  max-width: 620px;
}

.about-art-note {
  margin-top: 1.3rem;
  padding: 1rem 1.1rem;
  border-left: 4px solid var(--cyan);
  border-radius: var(--radius);
  color: var(--ink);
  background: color-mix(in srgb, var(--cyan) 8%, var(--bg-strong));
  font-weight: 850;
}

.about-art-card {
  position: relative;
  overflow: hidden;
  padding: clamp(1.4rem, 3vw, 2.1rem);
}

.about-art-card::before {
  content: "";
  position: absolute;
  inset: 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 16%, transparent);
  border-radius: var(--radius);
  pointer-events: none;
}

.about-art-title {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.about-art-title span {
  color: var(--cyan);
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}

.about-art-title strong {
  font-family: "Space Grotesk", Inter, sans-serif;
  color: var(--ink);
  font-size: clamp(3.4rem, 7vw, 6rem);
  line-height: 0.85;
}

.about-art-card p {
  position: relative;
  z-index: 1;
  margin: 0 0 1.3rem;
  color: var(--muted);
  font-size: 1.06rem;
  line-height: 1.7;
}

.about-question-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.about-question-grid span {
  min-height: 5rem;
  display: flex;
  align-items: center;
  padding: 0.9rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--ink);
  background: color-mix(in srgb, var(--soft) 42%, var(--bg-strong));
  font-weight: 750;
}

.about-workflow-section {
  display: grid;
  grid-template-columns: minmax(0, 0.74fr) minmax(0, 1.26fr);
  gap: var(--about-section-gap);
  align-items: start;
}

.about-action-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.about-action-chips span {
  position: relative;
  overflow: hidden;
  min-height: 3.25rem;
  display: inline-flex;
  align-items: center;
  padding: 0.75rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 22%, var(--line));
  border-radius: 999px;
  background: var(--bg-strong);
  color: var(--ink);
  font-weight: 800;
  box-shadow: var(--soft-shadow);
}

.about-action-chips span::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 38%;
  background: linear-gradient(90deg, transparent, rgba(0, 174, 176, 0.12), transparent);
  transform: translateX(-120%);
  animation: signalGlint 5s ease-in-out infinite;
}

.about-action-chips span:nth-child(2)::after { animation-delay: 0.25s; }
.about-action-chips span:nth-child(3)::after { animation-delay: 0.5s; }
.about-action-chips span:nth-child(4)::after { animation-delay: 0.75s; }
.about-action-chips span:nth-child(5)::after { animation-delay: 1s; }

.about-reveal-list {
  display: grid;
  gap: 0.7rem;
}

.about-reveal-list article {
  display: grid;
  grid-template-columns: 3.2rem 1fr;
  gap: 1rem;
  align-items: center;
  min-height: 4.7rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
  animation: rowLift 5s ease-in-out infinite;
}

.about-reveal-list article:nth-child(2) { animation-delay: 0.2s; }
.about-reveal-list article:nth-child(3) { animation-delay: 0.4s; }
.about-reveal-list article:nth-child(4) { animation-delay: 0.6s; }
.about-reveal-list article:nth-child(5) { animation-delay: 0.8s; }

.about-reveal-list span {
  width: 2.55rem;
  height: 2.55rem;
  display: grid;
  place-items: center;
  border-radius: var(--radius);
  color: var(--cyan);
  background: var(--soft);
  font-weight: 900;
}

.about-reveal-list strong {
  color: var(--ink);
  font-size: 1.08rem;
}

.about-ecosystem-grid article {
  min-height: 20rem;
}

.about-ecosystem-grid a {
  display: inline-flex;
  margin-top: 1.2rem;
  color: var(--cyan);
  font-weight: 850;
}

.about-shift-stack {
  display: grid;
  gap: 0.8rem;
}

.about-shift-stack article {
  display: grid;
  grid-template-columns: minmax(8rem, 0.85fr) minmax(5rem, 0.25fr) minmax(8rem, 1fr);
  gap: 1rem;
  align-items: center;
  min-height: 5rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.about-shift-stack span {
  color: var(--muted);
  font-weight: 750;
}

.about-shift-stack i {
  position: relative;
  height: 2px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cyan) 16%, var(--line));
}

.about-shift-stack i::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 50%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--cyan), var(--gold));
  animation: railSweep 3.6s ease-in-out infinite;
}

.about-shift-stack strong {
  color: var(--ink);
  font-size: 1.2rem;
  font-weight: 900;
}

.about-mission-section {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.about-mission-section article {
  min-height: 14rem;
  display: grid;
  align-content: end;
}

.about-mission-section article:nth-child(1) {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cyan) 11%, transparent), transparent 58%),
    var(--bg-strong);
}

.about-mission-section article:nth-child(2) {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--navy) 9%, transparent), transparent 58%),
    var(--bg-strong);
}

.about-mission-section span {
  color: var(--cyan);
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}

.about-mission-section p {
  max-width: 520px;
  margin: 0.8rem 0 0;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(1.65rem, 3vw, 2.5rem);
  font-weight: 700;
  line-height: 1.1;
}

.about-values-grid article {
  min-height: 11rem;
}

.about-team-section {
  display: block;
}

.about-team-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.95rem;
  margin-top: clamp(1.6rem, 4vw, 3rem);
}

.about-team-intro {
  max-width: 760px;
}

.about-team-grid article {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 22rem;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) * 1.4);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.about-team-grid .linkedin-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin: auto 1rem 1rem;
  align-self: flex-start;
  padding: 10px 14px;
  font-size: 0.85rem;
  font-weight: 500;
  line-height: 1;
  color: #111F39;
  background: transparent;
  border: 1px solid #00B8BA;
  border-radius: 9999px;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.about-team-grid .linkedin-pill svg {
  width: 16px;
  height: 16px;
  flex: none;
  display: block;
}

.about-team-grid .linkedin-pill:hover,
.about-team-grid .linkedin-pill:focus-visible {
  background-color: rgba(0, 184, 186, 0.12);
  color: #111F39;
  box-shadow: 0 4px 12px rgba(0, 184, 186, 0.18);
  transform: translateY(-1px);
  outline: none;
}

.about-team-grid img,
.about-member-placeholder > div {
  width: 100%;
  height: 12rem;
  object-fit: cover;
  object-position: top center;
  background: linear-gradient(135deg, rgba(0, 174, 176, 0.08), rgba(17, 31, 57, 0.04));
  filter: grayscale(1) contrast(1.05);
}

.about-member-placeholder > div {
  display: grid;
  place-items: center;
}

.about-member-placeholder .material-symbols-rounded {
  width: 5.4rem;
  height: 5.4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--bg-strong);
  color: var(--cyan);
  font-size: 3rem;
  box-shadow: var(--soft-shadow);
}

.about-team-grid h3,
.about-team-grid strong,
.about-team-grid p {
  margin-inline: 1rem;
}

.about-team-grid h3 {
  margin-top: 0.95rem;
  margin-bottom: 0.2rem;
  color: var(--ink);
  font-size: 1.08rem;
  line-height: 1.2;
}

.about-team-grid strong {
  display: block;
  margin-bottom: 0.75rem;
  color: var(--cyan);
  font-size: 0.9rem;
}

.about-team-grid p {
  margin-top: 0;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.55;
}

.about-company-card {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.28fr);
  gap: clamp(1.4rem, 4vw, 3rem);
  align-items: start;
  padding: clamp(1.4rem, 3vw, 2.4rem);
}

.about-company-card h2 {
  font-size: clamp(2rem, 4vw, 3.5rem);
}

.about-company-card dl {
  display: grid;
  gap: 0.7rem;
  margin: 0;
}

.about-company-card dl div {
  display: grid;
  grid-template-columns: minmax(8rem, 0.42fr) minmax(0, 1fr);
  gap: 1rem;
  padding: 0.8rem 0;
  border-bottom: 1px solid var(--line);
}

.about-company-card dt {
  color: var(--muted);
  font-weight: 800;
}

.about-company-card dd {
  margin: 0;
  color: var(--ink);
  font-weight: 750;
}

.about-final {
  position: relative;
  overflow: hidden;
  display: grid;
  justify-items: center;
  gap: 1rem;
  margin-top: 2rem;
  padding: clamp(3rem, 7vw, 5.6rem) 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 26%, var(--line));
  border-radius: calc(var(--radius) * 1.6);
  background:
    linear-gradient(rgba(0, 174, 176, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 174, 176, 0.04) 1px, transparent 1px),
    var(--bg-strong);
  background-size: 2.25rem 2.25rem, 2.25rem 2.25rem, auto;
  text-align: center;
  box-shadow: var(--shadow);
}

.about-final h2 {
  font-size: clamp(2.35rem, 5vw, 4.6rem);
}

.about-final p {
  max-width: 620px;
  margin: 0;
  color: var(--muted);
  font-size: 1.08rem;
}

.about-final-monogram {
  width: 4.2rem;
  height: 4.2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 16px 36px color-mix(in srgb, var(--cyan) 18%, transparent);
  animation: dotBreath 4.2s ease-in-out infinite;
}

.about-final-monogram img {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  object-fit: cover;
  filter: brightness(0) invert(1);
}

.student-launch-page main {
  padding-top: 0.5rem;
}

.student-launch-kicker {
  margin: 0 0 0.85rem;
  color: var(--cyan);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.student-launch-hero {
  min-height: calc(100vh - 5.5rem);
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(29rem, 0.8fr);
  gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
  padding: clamp(2.6rem, 5vw, 4.4rem) 0 clamp(3rem, 5vw, 4.5rem);
}

.student-launch-copy h1,
.student-preview-section h2,
.student-launch-final h2 {
  margin: 0;
  font-family: "Space Grotesk", Inter, sans-serif;
  color: var(--ink);
  letter-spacing: 0;
  line-height: 0.98;
}

.student-launch-copy h1 {
  max-width: 780px;
  font-size: clamp(3.8rem, 7vw, 6.6rem);
}

.student-launch-copy h1 span {
  display: block;
  color: transparent;
  background: linear-gradient(90deg, var(--cyan), var(--green), var(--gold));
  background-size: 180% 100%;
  background-clip: text;
  animation: gradientSlide 8s ease infinite;
}

.student-launch-copy > p {
  max-width: 650px;
  margin: 1.45rem 0 0;
  color: var(--muted);
  font-size: clamp(1.08rem, 1.7vw, 1.28rem);
  line-height: 1.65;
}

.student-launch-actions,
.student-launch-proof {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-top: 1.45rem;
}

.student-launch-proof {
  gap: 0.7rem;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
}

.student-launch-proof span {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
}

.student-launch-proof span:not(:last-child)::after {
  content: "";
  width: 0.25rem;
  height: 0.25rem;
  border-radius: 50%;
  background: var(--gold);
}

.launch-countdown-card {
  position: relative;
  overflow: hidden;
  padding: clamp(1.2rem, 3vw, 1.8rem);
  border: 1px solid color-mix(in srgb, var(--cyan) 26%, var(--line));
  border-radius: calc(var(--radius) * 1.6);
  background:
    linear-gradient(rgba(0, 174, 176, 0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 174, 176, 0.055) 1px, transparent 1px),
    var(--bg-strong);
  background-size: 2rem 2rem, 2rem 2rem, auto;
  box-shadow: 0 24px 64px rgba(17, 31, 57, 0.09);
}

.launch-countdown-card::before {
  content: "";
  position: absolute;
  left: 1.2rem;
  right: 1.2rem;
  top: 0;
  height: 0.22rem;
  border-radius: 0 0 999px 999px;
  background: linear-gradient(90deg, var(--navy), var(--cyan), var(--gold), var(--green));
  background-size: 220% 100%;
  animation: headerStrip 8s linear infinite;
}

.launch-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.launch-card-top span {
  color: var(--cyan);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.launch-card-top strong {
  color: var(--ink);
  font-weight: 900;
}

.campus-brand-lockup {
  display: grid;
  place-items: center;
  height: clamp(5.4rem, 8vw, 6.4rem);
  margin: 0 0 0.7rem;
  padding: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--cyan) 14%, var(--line));
  border-radius: var(--radius);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.campus-brand-lockup img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.campus-launch-copy {
  margin-bottom: 0.7rem;
  padding: 0.82rem 0.9rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 82%, transparent);
  box-shadow: var(--soft-shadow);
}

.campus-launch-copy h2 {
  margin: 0;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(1.28rem, 2vw, 1.78rem);
  line-height: 1.08;
  letter-spacing: 0;
}

.campus-launch-copy p {
  margin: 0.55rem 0 0;
  color: var(--muted);
  font-size: 0.92rem;
  font-weight: 650;
  line-height: 1.55;
  text-align: left;
}

.campus-feature-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.7rem;
}

.campus-feature-row span {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0.35rem 0.65rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 22%, var(--line));
  border-radius: 999px;
  color: var(--ink);
  background: var(--bg-strong);
  font-size: 0.76rem;
  font-weight: 850;
  text-transform: uppercase;
}

.countdown-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.countdown-grid article {
  min-height: 6.15rem;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--bg-strong) 86%, transparent);
  box-shadow: var(--soft-shadow);
}

.countdown-grid strong {
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: clamp(2.3rem, 5vw, 3.75rem);
  line-height: 0.9;
}

.countdown-grid span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.launch-progress {
  position: relative;
  overflow: hidden;
  height: 0.42rem;
  margin-top: 1.2rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cyan) 13%, var(--soft));
}

.launch-progress span {
  position: absolute;
  inset: 0 auto 0 0;
  width: 68%;
  border-radius: inherit;
  transform-origin: left;
  background: linear-gradient(90deg, var(--cyan), var(--navy), var(--gold));
  animation: signalBar 4.2s ease-in-out infinite;
}

.launch-countdown-card p {
  margin: 1rem 0 0;
  color: var(--muted);
  font-weight: 700;
  text-align: center;
}

.student-preview-section {
  padding: clamp(3.5rem, 7vw, 6rem) 0;
}

.student-preview-section .section-heading {
  margin-bottom: 1.8rem;
}

.student-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.student-preview-grid article {
  position: relative;
  overflow: hidden;
  min-height: 18rem;
  padding: 1.25rem;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) * 1.4);
  background: var(--bg-strong);
  box-shadow: var(--soft-shadow);
}

.student-preview-grid article::before {
  content: "";
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  top: 0;
  height: 0.22rem;
  border-radius: 0 0 999px 999px;
  background: linear-gradient(90deg, var(--navy), var(--cyan));
  transform-origin: left;
  animation: impactMeter 4s ease-in-out infinite;
}

.student-preview-grid article:nth-child(2)::before {
  background: linear-gradient(90deg, var(--cyan), var(--green));
  animation-delay: 0.25s;
}

.student-preview-grid article:nth-child(3)::before {
  background: linear-gradient(90deg, var(--gold), var(--green));
  animation-delay: 0.5s;
}

.student-preview-grid .material-symbols-rounded {
  width: 3.3rem;
  height: 3.3rem;
  display: grid;
  place-items: center;
  margin-bottom: 1.4rem;
  border-radius: var(--radius);
  background: var(--soft);
  color: var(--blue);
  font-size: 1.8rem;
}

.student-preview-grid h3 {
  margin: 0 0 0.75rem;
  color: var(--ink);
  font-size: 1.16rem;
}

.student-preview-grid p {
  margin: 0;
  color: var(--muted);
  font-size: 1.02rem;
  line-height: 1.65;
}

.student-launch-final {
  position: relative;
  overflow: hidden;
  display: grid;
  justify-items: center;
  gap: 1rem;
  margin-top: 1rem;
  padding: clamp(3rem, 7vw, 5.6rem) 1rem;
  border: 1px solid color-mix(in srgb, var(--cyan) 26%, var(--line));
  border-radius: calc(var(--radius) * 1.6);
  background: var(--bg-strong);
  text-align: center;
  box-shadow: var(--shadow);
}

.student-launch-final h2 {
  font-size: clamp(2.35rem, 5vw, 4.6rem);
}

.student-launch-final p {
  max-width: 620px;
  margin: 0;
  color: var(--muted);
  font-size: 1.08rem;
}

@media (max-width: 1100px) {
  .about-hero,
  .about-story-grid,
  .about-art-section,
  .about-workflow-section,
  .about-reveal-section,
  .about-shift-section,
  .about-team-section,
  .about-company-card {
    grid-template-columns: 1fr;
  }

  .about-hero {
    min-height: auto;
    padding-top: 4.6rem;
  }

  .about-pattern-card {
    max-width: 760px;
  }

  .about-story-grid::after {
    display: none;
  }

  .about-team-intro {
    max-width: 760px;
    margin-inline: auto;
    text-align: center;
  }

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

  .student-launch-hero {
    min-height: auto;
    grid-template-columns: 1fr;
    padding-top: 4.6rem;
  }
}

@media (max-width: 760px) {
  .about-hero-copy h1 {
    font-size: 3.35rem;
  }

  .about-pattern-card,
  .about-system-grid,
  .about-ecosystem-grid,
  .about-values-grid,
  .about-mission-section,
  .about-team-grid,
  .about-question-grid {
    grid-template-columns: 1fr;
  }

  .about-pattern-card {
    min-height: auto;
  }

  .about-trajectory-svg {
    min-height: 16rem;
  }

  .trajectory-caption {
    display: grid;
  }

  .trajectory-caption span {
    text-align: left;
  }

  .about-grid-glow {
    display: none;
  }

  .about-symbol-stage {
    min-height: 18rem;
  }

  .about-symbol-orbit {
    width: 13rem;
    height: 13rem;
  }

  .about-symbol-core {
    width: 7rem;
    height: 7rem;
  }

  .about-symbol-core img {
    width: 5rem;
    height: 5rem;
  }

  .about-hero-actions .button,
  .about-final .button {
    width: 100%;
  }

  .about-trust {
    display: grid;
  }

  .about-trust span::after {
    display: none;
  }

  .about-shift-stack article,
  .about-company-card dl div {
    grid-template-columns: 1fr;
    gap: 0.4rem;
  }

  .about-shift-stack i {
    width: 100%;
  }

  .student-launch-copy h1 {
    font-size: 3.35rem;
  }

  .student-launch-actions .button,
  .student-launch-final .button {
    width: 100%;
  }

  .student-launch-proof {
    display: grid;
  }

  .student-launch-proof span::after {
    display: none;
  }

  .countdown-grid,
  .student-preview-grid {
    grid-template-columns: 1fr;
  }

  .countdown-grid article {
    min-height: 7.8rem;
  }
}

@keyframes ainaFloat {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -0.35rem; }
}

/* Progressive enhancement: only hide reveal items when JS has confirmed observer is wired.
   Without the .dm-js class on <html>, content stays visible (no-JS, crawlers, full-page screenshots). */
.dm-js [data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  filter: blur(8px);
  transition: opacity 0.8s ease, transform 0.8s ease, filter 0.8s ease;
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.shift-section > .section-heading[data-reveal] {
  opacity: 1;
  transform: none;
  filter: none;
}

@keyframes sheen {
  0%, 48% { transform: translateX(-120%); }
  68%, 100% { transform: translateX(120%); }
}

@keyframes pulseDot {
  0% { transform: scale(0.4); opacity: 0.9; }
  100% { transform: scale(2.4); opacity: 0; }
}

@keyframes gradientSlide {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

@keyframes meshDrift {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(-8deg); opacity: 0.14; }
  50% { transform: translate3d(12px, -10px, 0) rotate(-5deg); opacity: 0.24; }
}

@keyframes railSweep {
  0% { transform: translateX(-42%); opacity: 0; }
  12%, 84% { opacity: 1; }
  100% { transform: translateX(228%); opacity: 0; }
}

@keyframes railSweepY {
  0% { transform: translateY(-36%); opacity: 0; }
  12%, 84% { opacity: 1; }
  100% { transform: translateY(232%); opacity: 0; }
}

@keyframes railCardPulse {
  0%, 100% {
    border-color: transparent;
    box-shadow: none;
    transform: translateY(0);
  }
  42%, 58% {
    border-color: color-mix(in srgb, var(--cyan) 32%, transparent);
    box-shadow: 0 10px 22px rgba(8, 175, 206, 0.08);
    transform: translateY(-1px);
  }
}

@keyframes stripPulse {
  0%, 100% { transform: scaleX(0.22); opacity: 0.72; }
  50% { transform: scaleX(1); opacity: 1; }
}

@keyframes headerStrip {
  to { background-position: 200% 50%; }
}

@keyframes symbolRun {
  to { transform: translateX(calc(-50% - 0.39rem)); }
}

@keyframes motifRun {
  to { transform: translateX(calc(-50% - 0.75rem)); }
}

@keyframes stripPop {
  0%, 100% { transform: translateY(0) scale(1); opacity: 0.72; }
  46%, 58% { transform: translateY(-2px) scale(1.08); opacity: 1; }
}

@keyframes symbolFloat {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg); }
  50% { transform: translate3d(10px, -12px, 0) rotate(4deg); }
}

@keyframes rowScan {
  0%, 42% { transform: translateX(-130%); opacity: 0; }
  54% { opacity: 1; }
  82%, 100% { transform: translateX(330%); opacity: 0; }
}

@keyframes coreSpin {
  to { transform: rotate(360deg); }
}

@keyframes streamFlow {
  0%, 100% { transform: translateX(0) translateY(0) scaleX(1); opacity: 0.54; }
  50% { transform: translateX(18px) translateY(-7px) scaleX(1.06); opacity: 0.92; }
}

@keyframes dotTravel {
  0% { left: 4%; opacity: 0; }
  12% { opacity: 1; }
  88% { opacity: 1; }
  100% { left: 92%; opacity: 0; }
}

@keyframes floaty {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

@keyframes recognitionLift {
  0%, 100% {
    transform: translateY(0);
    box-shadow: 0 12px 26px rgba(16, 35, 60, 0.06);
  }
  45%, 58% {
    transform: translateY(-2px);
    box-shadow: 0 18px 32px rgba(16, 35, 60, 0.09);
  }
}

@keyframes streamMeter {
  0% { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

@keyframes signalBar {
  0%, 100% { transform: scaleX(0.72); opacity: 0.72; }
  50% { transform: scaleX(1); opacity: 1; }
}

@keyframes trajectoryDraw {
  0% {
    stroke-dashoffset: 420;
    opacity: 0.25;
  }
  24%, 72% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
  100% {
    stroke-dashoffset: -420;
    opacity: 0.25;
  }
}

@keyframes signalGlint {
  to { transform: translateX(420%); }
}

@keyframes drawRing {
  to { stroke-dashoffset: var(--dash); }
}

@keyframes orbitPulse {
  0%, 100% { filter: drop-shadow(0 0 0 transparent); }
  50% { filter: drop-shadow(0 0 8px currentColor); }
}

@keyframes growBar {
  to { transform: scaleX(1); }
}

@keyframes metricScan {
  0%, 45% { transform: translateX(-120%); opacity: 0; }
  55% { opacity: 1; }
  80%, 100% { transform: translateX(120%); opacity: 0; }
}

@keyframes rowLift {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(7px); }
}

@keyframes growShrink {
  0%, 100% { transform: scaleX(0.42); }
  50% { transform: scaleX(1); }
}

@keyframes scan {
  0%, 100% { top: 0; opacity: 0.2; }
  50% { top: 100%; opacity: 1; }
}

@keyframes phoneFloat {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50% { transform: translateY(-14px) rotate(1deg); }
}

@keyframes slowSpin {
  to { transform: translateX(-50%) rotate(360deg); }
}

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

@keyframes waterRun {
  0%, 100% { transform: scaleY(0.82); opacity: 0.62; }
  50% { transform: scaleY(1); opacity: 1; }
}

@keyframes coinDrop {
  0% { transform: translateY(-1.4rem) rotate(0deg) scale(0.82); opacity: 0; }
  14% { opacity: 1; }
  78% { opacity: 1; }
  100% { transform: translateY(5.4rem) rotate(270deg) scale(1); opacity: 0; }
}

@keyframes splashPulse {
  0%, 100% { transform: scaleX(0.72); opacity: 0.26; }
  50% { transform: scaleX(1); opacity: 0.58; }
}

@keyframes partnerOrbit {
  to { transform: rotate(360deg); }
}

@keyframes dotBreath {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(0, 174, 176, 0.18);
  }
  50% {
    transform: scale(1.08);
    box-shadow: 0 0 0 12px rgba(0, 174, 176, 0);
  }
}

@keyframes stripLoad {
  0%, 100% { transform: scaleX(0.72); }
  48%, 62% { transform: scaleX(1); }
}

@keyframes impactMeter {
  0%, 100% {
    transform: scaleX(0.58);
    opacity: 0.62;
  }
  50% {
    transform: scaleX(1);
    opacity: 1;
  }
}

@keyframes flowScan {
  0% {
    clip-path: inset(0 0 100% 0);
    opacity: 0.2;
  }
  48%, 62% {
    clip-path: inset(0 0 0 0);
    opacity: 0.72;
  }
  100% {
    clip-path: inset(100% 0 0 0);
    opacity: 0.2;
  }
}

@media (max-width: 1100px) {
  .desktop-nav,
  .header-actions .button {
    display: none;
  }

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

  .site-header.menu-open .menu-toggle span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
  }

  .site-header.menu-open .menu-toggle span:nth-child(2) {
    opacity: 0;
  }

  .site-header.menu-open .menu-toggle span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
  }

  .mobile-nav {
    position: absolute;
    top: calc(100% + 0.5rem);
    left: 0;
    right: 0;
    display: grid;
    gap: 0.3rem;
    padding: 0.8rem;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--bg-strong);
    box-shadow: var(--shadow);
    transform-origin: top;
    transform: scaleY(0.94);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
  }

  .site-header.menu-open .mobile-nav {
    transform: scaleY(1);
    opacity: 1;
    pointer-events: auto;
  }

  .mobile-nav a {
    padding: 0.8rem;
    border-radius: 7px;
    color: var(--muted);
    font-weight: 800;
  }

  .mobile-nav a:hover {
    background: var(--soft);
    color: var(--cyan);
  }

  .hero {
    padding: 5rem 1.4rem 0;
  }

  .hero-grid,
  .reality,
  .audience-section,
  .students-section,
  .future-section,
  .team-section,
  .school-hero,
  .school-ai-card,
  .partner-hero,
  .partner-strip-system,
  .vidyaa-card,
  .ngo-partner-hero,
  .pillars-section {
    grid-template-columns: 1fr;
  }

  .school-hero {
    min-height: auto;
    padding-top: 4rem;
  }

  .school-console-card {
    max-width: 640px;
  }

  .hero h1 {
    font-size: 4rem;
  }

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

  .credibility-band {
    margin-inline: -1.4rem;
    padding-inline: 1.4rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .credibility-band::before {
    left: 1.4rem;
    right: 1.4rem;
  }

  .art-grid,
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-main {
    grid-template-columns: 1.4fr 1fr 1fr;
  }
  .footer-brand {
    grid-column: 1 / -1;
  }

  .partner-symbol-card {
    max-width: 760px;
  }

  .pathway-grid,
  .roadmap-line,
  .institution-focus-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

@media (max-width: 760px) {
  .site-header {
    width: min(100% - 1rem, 1160px);
    top: 0.5rem;
  }

  .brand span {
    max-width: none;
    overflow: visible;
    text-overflow: clip;
  }

  .hero {
    min-height: auto;
    padding-top: 4rem;
  }

  .hero h1 {
    font-size: 2.72rem;
    line-height: 1.08;
  }

  .hero-text {
    font-size: 1.05rem;
  }

  .platform-line {
    font-size: 0.78rem;
  }

  .proof-strip,
  .brand-strip,
  .home-rail,
  .hero-actions,
  .inline-actions,
  .art-cta,
  .ethics-row {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .proof-strip span {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .proof-strip span:last-child {
    border-bottom: 0;
  }

  .brand-strip {
    grid-template-columns: 1fr;
    gap: 0.7rem;
    margin-top: 1rem;
    padding: 0.8rem;
  }

  .brand-strip::before {
    display: none;
  }

  .strip-statement {
    grid-template-columns: auto auto;
    justify-content: start;
    gap: 0.35rem;
  }

  .strip-statement strong,
  .strip-statement span {
    font-size: 0.86rem;
  }

  .strip-symbols {
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 0.3rem;
  }

  .strip-labels {
    display: none;
  }

  .brand-mark {
    width: 1.35rem;
    height: 1.35rem;
  }

  .home-rail {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    margin-top: 0.9rem;
    padding: 0.5rem;
  }

  .rail-trace {
    left: 1.15rem;
    right: auto;
    top: 0.95rem;
    bottom: 0.95rem;
    width: 2px;
    height: auto;
  }

  .rail-trace::after {
    width: 100%;
    height: 32%;
    animation-name: railSweepY;
  }

  .home-rail article {
    grid-template-columns: 1.35rem minmax(0, 1fr);
    column-gap: 0.55rem;
    align-items: start;
    padding: 0.58rem;
  }

  .home-rail i {
    grid-row: span 2;
    margin-top: 0.08rem;
  }

  .home-rail small {
    font-size: 0.74rem;
    line-height: 1.35;
  }

  .hero-grid {
    gap: 2rem;
  }

  .hero-visual {
    min-height: 700px;
    place-items: start center;
  }

  .visual-brand-strip {
    left: 50%;
    right: auto;
    top: auto;
    bottom: 0.5rem;
    grid-auto-flow: column;
    grid-template-columns: repeat(8, 1fr);
    gap: 0.38rem;
    padding: 0.5rem 0.62rem;
    transform: translateX(-50%);
  }

  .visual-brand-strip .brand-mark {
    width: 1.05rem;
    height: 1.05rem;
  }

  .signal-layer,
  .live-chip {
    display: none;
  }

  .score-layout,
  .stream-grid,
  .story-tiles,
  .feature-list,
  .student-points,
  .art-grid,
  .team-grid,
  .compare-grid,
  .school-feature-grid,
  .service-catalogue,
  .art-dimension-grid,
  .school-timeline,
  .proof-grid,
  .pathway-grid,
  .partner-detail-grid,
  .institution-focus-grid,
  .coming-soon-grid,
  .pillar-track,
  .roadmap-line,
  .footer-main {
    grid-template-columns: 1fr;
  }

  .partner-page main {
    padding-top: 0.5rem;
  }

  .partner-hero {
    min-height: auto;
    padding-top: 4rem;
  }

  .partner-hero h1 {
    font-size: 3.1rem;
    line-height: 1;
  }

  .partner-actions .button {
    width: 100%;
    justify-content: center;
  }

  .partner-symbol-card {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .symbol-stage {
    min-height: 17rem;
  }

  .symbol-logo {
    width: 6.6rem;
    height: 6.6rem;
  }

  .partner-strip-system,
  .vidyaa-section,
  .pathways-section,
  .ngo-partner-section,
  .institution-section,
  .pillars-section,
  .partner-roadmap {
    padding: 2.6rem 0;
  }

  .pattern-river .brand-mark {
    width: 2rem;
    height: 2rem;
  }

  .roadmap-line::before {
    left: 1.78rem;
    right: auto;
    top: 1.4rem;
    bottom: 1.4rem;
    width: 2px;
    height: auto;
    background: linear-gradient(180deg, var(--navy), var(--cyan), var(--gold), var(--green));
  }

  .roadmap-line article {
    min-height: auto;
    padding-top: 3.5rem;
  }

  .partner-final h2 {
    font-size: 2.15rem;
  }

  .school-hero h1 {
    font-size: 3.15rem;
  }

  .school-hero-copy > p {
    font-size: 1rem;
  }

  .school-hero-actions .button,
  .school-final .button {
    width: 100%;
    justify-content: center;
  }

  .school-console-grid {
    grid-template-columns: 1fr;
  }

  .money-leak-banner {
    grid-template-columns: 1fr;
    padding: 1rem;
  }

  .tap-animation {
    min-height: 10rem;
  }

  .service-photo {
    height: auto;
    aspect-ratio: 4 / 3;
  }

  .service-catalogue article {
    min-height: auto;
    padding: 0.75rem 0.75rem 1rem;
  }

  .school-ai-card,
  .school-final {
    padding: 2rem 1rem;
  }

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

  .school-timeline strong,
  .school-timeline span {
    grid-column: auto;
  }

  .footer {
    margin-top: 3rem;
    padding-block: 3rem 1.7rem;
  }

  .footer {
    padding: 3.2rem 0 1.4rem;
  }
  .footer-main {
    gap: 2.2rem;
  }
  .footer-socials {
    justify-content: flex-start;
  }
  .footer-bottom {
    display: grid;
    gap: 0.5rem;
    text-align: left;
    margin-top: 2.4rem;
  }

  .credibility-band {
    grid-template-columns: 1fr;
    gap: 0.62rem;
    padding-block: 0.9rem;
  }

  .credibility-band div {
    min-height: 4.35rem;
    border-radius: var(--radius);
  }

  .profile-card {
    padding: 0.8rem;
  }

  .story-card {
    min-height: 0;
    grid-template-rows: 180px 1fr;
  }

  .section-heading h2,
  .future-copy h2,
  .responsibility h2,
  .team-copy h2,
  .final-cta h2 {
    font-size: 2.15rem;
  }

  .reality,
  .audience-section,
  .students-section,
  .future-section,
  .team-section,
  .art-section {
    padding: 3.5rem 0;
    gap: 2rem;
  }

  .image-frame img,
  .classroom-card img {
    height: 330px;
  }

  .responsibility-inner {
    padding: 2.3rem 1rem;
  }

  .initiative-card {
    min-height: auto;
    padding: 1.45rem;
  }

  .initiative-card::before {
    inset: 0.75rem;
  }

  .initiative-card::after {
    left: 1.45rem;
    right: 1.45rem;
  }

  .initiative-visual {
    width: 8rem;
    height: 8rem;
    right: -2rem;
    top: 0.7rem;
    opacity: 0.24;
  }

  .initiative-node {
    width: 1.75rem;
    height: 1.75rem;
    opacity: 0.58;
  }

  .initiative-card h3 {
    font-size: 1.72rem;
  }

  .floating-actions {
    display: none;
  }
}

@media (max-width: 360px) {
  .site-header {
    gap: 0.45rem;
    padding: 0.48rem 0.55rem;
    min-height: 3.55rem;
  }

  .brand {
    gap: 0.45rem;
    font-size: 0.92rem;
  }

  .brand img {
    width: 1.9rem;
    height: 1.9rem;
    box-shadow: 0 0 0 3px rgba(8, 175, 206, 0.08);
  }

  .header-actions {
    gap: 0.35rem;
  }

  .icon-button {
    width: 2.35rem;
    height: 2.35rem;
  }

  .hero {
    padding-inline: 1rem;
  }

  .hero h1 {
    font-size: 2.58rem;
  }

  .strip-statement {
    grid-template-columns: 1fr;
    gap: 0.08rem;
  }

  .brand-mark {
    width: 1.18rem;
    height: 1.18rem;
  }
}

/* Whole-site polish layer */
.site-header {
  border-color: color-mix(in srgb, var(--cyan) 18%, rgba(17, 31, 57, 0.08));
  box-shadow: 0 14px 38px rgba(17, 31, 57, 0.065);
}

.site-header::after {
  opacity: 0.34;
}

.desktop-nav a,
.mobile-nav a,
.button,
.icon-button {
  -webkit-tap-highlight-color: transparent;
}

.button {
  font-weight: 700;
  letter-spacing: -0.005em;
}

.button.primary {
  color: #0d1e35;
  background: linear-gradient(135deg, var(--cyan), color-mix(in srgb, var(--cyan) 80%, #fff));
  box-shadow: 0 12px 26px rgba(0, 184, 186, 0.16);
}

.button.primary:hover {
  background: linear-gradient(135deg, color-mix(in srgb, var(--cyan) 92%, #fff), var(--cyan));
  box-shadow: 0 16px 30px rgba(0, 184, 186, 0.18);
}

.button.secondary {
  background: color-mix(in srgb, var(--bg-strong) 88%, transparent);
  border-color: var(--cyan);
  box-shadow: 0 8px 20px rgba(17, 31, 57, 0.035);
}

.button.secondary:hover {
  border-color: color-mix(in srgb, var(--cyan) 32%, var(--line));
  background: var(--bg-strong);
}

.section-heading p,
.future-copy > p,
.responsibility-inner > p,
.team-copy > p,
.school-label,
.partner-kicker,
.about-kicker,
.student-launch-kicker {
  letter-spacing: 0.06em;
}

.section-heading h2,
.future-copy h2,
.responsibility h2,
.team-copy h2,
.final-cta h2,
.school-hero h1,
.partner-hero h1,
.about-hero-copy h1,
.student-launch-copy h1 {
  text-wrap: balance;
}

.section-heading span,
.future-copy > span,
.responsibility-inner > span,
.school-hero-copy > p,
.partner-hero-copy > p:not(.partner-kicker),
.about-hero-copy > p,
.student-launch-copy > p {
  color: color-mix(in srgb, var(--muted) 92%, var(--ink));
}

.hero,
.school-console-card,
.partner-symbol-card,
.about-pattern-card,
.launch-countdown-card,
.final-cta,
.school-final,
.partner-final,
.about-final,
.student-launch-final {
  border-color: color-mix(in srgb, var(--cyan) 18%, var(--line));
  box-shadow: 0 22px 60px rgba(17, 31, 57, 0.07);
}

.story-card,
.feature-list article,
.student-points article,
.art-grid article,
.team-grid article,
.compare-card,
.school-feature-grid article,
.service-catalogue article,
.proof-grid article,
.pathway-grid article,
.partner-detail-card,
.coming-card,
.roadmap-line article,
.about-system-grid article,
.about-ecosystem-grid article,
.about-values-grid article,
.about-mission-section article,
.about-team-grid article,
.student-preview-grid article,
.countdown-grid article {
  border-color: color-mix(in srgb, var(--navy) 9%, transparent);
  background-color: color-mix(in srgb, var(--bg-strong) 96%, transparent);
  box-shadow: 0 10px 30px rgba(17, 31, 57, 0.048);
}

.story-card:hover,
.feature-list article:hover,
.student-points article:hover,
.art-grid article:hover,
.team-grid article:hover,
.school-feature-grid article:hover,
.service-catalogue article:hover,
.pathway-grid article:hover,
.about-system-grid article:hover,
.about-ecosystem-grid article:hover,
.about-values-grid article:hover,
.about-team-grid article:hover,
.student-preview-grid article:hover {
  border-color: color-mix(in srgb, var(--cyan) 32%, var(--line));
  box-shadow: 0 18px 42px rgba(17, 31, 57, 0.075);
}

.story-card img,
.image-frame img,
.classroom-card img,
.school-photo,
.service-photo img,
.partner-photo-card img,
.ngo-partner-photo img,
.about-team-grid img {
  filter: saturate(0.96) contrast(1.02);
}

.footer {
  background:
    radial-gradient(circle at 82% 14%, rgba(0, 184, 186, 0.12), transparent 20rem),
    linear-gradient(160deg, #101b2c 0%, #111f39 58%, #0a1424 100%);
}

.footer-bottom {
  border-top-color: rgba(255, 255, 255, 0.18);
}

.floating-actions a {
  box-shadow: 0 14px 30px rgba(17, 31, 57, 0.15);
}

.dm-js [data-reveal]:not(.is-visible) {
  transform: translateY(18px);
  filter: blur(5px);
  transition-duration: 0.68s;
}

@media (max-width: 760px) {
  .button {
    min-height: 3rem;
  }

  .site-header {
    box-shadow: 0 12px 30px rgba(17, 31, 57, 0.07);
  }

  .hero,
  .school-hero,
  .partner-hero,
  .about-hero,
  .student-launch-hero {
    padding-top: 4.4rem;
  }
}

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

/* Tint the AI-layer card and the final CTA card with a soft cyan-blue
   so they separate visually from the off-white page background.
   (User-requested fix: cards were reading as near-white and merging in.) */
.school-ai-card,
.school-final {
  background:
    radial-gradient(circle at 82% 14%, rgba(18, 179, 214, 0.18), transparent 18rem),
    linear-gradient(135deg,
      color-mix(in srgb, var(--cyan) 14%, #ffffff) 0%,
      color-mix(in srgb, var(--cyan) 22%, #f4fbfd) 100%) !important;
  color: #0d1e35 !important;
  border: 1px solid color-mix(in srgb, var(--cyan) 38%, transparent) !important;
  box-shadow: 0 18px 48px rgba(18, 179, 214, 0.14) !important;
}
.school-ai-card h2,
.school-final h2 {
  color: #0d1e35 !important;
}
.school-ai-card p,
.school-final p {
  color: rgba(13, 30, 53, 0.78) !important;
}
.school-ai-card .school-label {
  color: color-mix(in srgb, var(--cyan) 72%, #0d1e35) !important;
}
.school-ai-card .agent-flow article {
  background: rgba(255, 255, 255, 0.7) !important;
  border: 1px solid color-mix(in srgb, var(--cyan) 28%, transparent) !important;
  color: #0d1e35 !important;
}
.school-ai-card .agent-flow article strong,
.school-ai-card .agent-flow article span {
  color: #0d1e35 !important;
}

