/* ============================================================
   CIRCA. — The Circa School
   Design: avant-garde, rounded, flowing, slick premium
   Fonts: Fraunces (display, soft) + Instrument Serif (italic accent)
          + Bricolage Grotesque (UI) + Inter (body)
   Palette: cream / plum / blush / sky / honey / ink
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&family=Instrument+Serif:ital@0;1&family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700&family=Inter:wght@400;500;600&display=swap');

/* ---------- Reset ---------- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
body { min-height: 100dvh; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img, picture, video, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; }

/* ---------- Tokens ---------- */
:root {
  /* Palette */
  --cream: #F4ECDF;
  --cream-warm: #EBE1D0;
  --cream-deep: #E2D4BB;
  --ink: #17120F;
  --ink-soft: #3A332B;
  --plum: #452035;
  --plum-deep: #2B1121;
  --blush: #F0B59B;
  --blush-soft: #F6D1BE;
  --sky: #BCD0CF;
  --sky-deep: #6B8E8C;
  --honey: #E9B352;
  --honey-soft: #F2CE8D;
  --lime: #C6D68F;

  /* Fonts */
  --ff-display: 'Fraunces', ui-serif, Georgia, serif;
  --ff-italic: 'Instrument Serif', 'Fraunces', ui-serif, serif;
  --ff-sans: 'Bricolage Grotesque', ui-sans-serif, system-ui, sans-serif;
  --ff-body: 'Inter', ui-sans-serif, system-ui, sans-serif;

  /* Type scale — fluid, generous */
  --fs-xs: clamp(0.78rem, 0.75rem + 0.1vw, 0.84rem);
  --fs-sm: clamp(0.9rem, 0.86rem + 0.2vw, 0.98rem);
  --fs-base: clamp(1.02rem, 0.97rem + 0.25vw, 1.14rem);
  --fs-lg: clamp(1.18rem, 1.05rem + 0.6vw, 1.45rem);
  --fs-xl: clamp(1.55rem, 1.25rem + 1.5vw, 2.4rem);
  --fs-2xl: clamp(2.2rem, 1.5rem + 3vw, 3.8rem);
  --fs-3xl: clamp(3rem, 1.8rem + 6vw, 6.2rem);
  --fs-4xl: clamp(4rem, 2.2rem + 9vw, 9rem);

  /* Rhythm */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 64px;
  --sp-9: 96px;
  --sp-10: 128px;
  --sp-11: 180px;

  /* Shape — the brief is "rounded flowing" so radii are generous */
  --r-sm: 14px;
  --r-md: 24px;
  --r-lg: 40px;
  --r-xl: 64px;
  --r-2xl: 120px;
  --r-pill: 999px;

  /* Layout */
  --wrap: 1320px;
  --pad: clamp(20px, 4vw, 56px);

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-soft: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast: 180ms;
  --dur: 340ms;
  --dur-slow: 700ms;

  /* Elevation — very soft, feels pillowy */
  --shade-1: 0 1px 2px rgba(23, 18, 15, 0.04), 0 4px 18px rgba(23, 18, 15, 0.04);
  --shade-2: 0 2px 6px rgba(23, 18, 15, 0.06), 0 22px 52px -18px rgba(69, 32, 53, 0.18);
  --shade-3: 0 30px 90px -30px rgba(69, 32, 53, 0.35);
}

/* ---------- Base ---------- */
body {
  font-family: var(--ff-body);
  font-size: var(--fs-base);
  line-height: 1.55;
  color: var(--ink);
  background: var(--cream);
  overflow-x: hidden;
}

/* ---------- Layout ---------- */
.wrap {
  max-width: var(--wrap);
  margin-inline: auto;
  padding-inline: var(--pad);
  position: relative;
}

.section {
  padding-block: clamp(var(--sp-9), 9vw, var(--sp-11));
  position: relative;
}

.section--tight { padding-block: clamp(var(--sp-8), 6vw, var(--sp-9)); }

/* ---------- Type helpers ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--ff-sans);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--plum);
  padding: 10px 22px;
  background: rgba(240, 181, 155, 0.32);
  border-radius: var(--r-pill);
}

.eyebrow::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--plum);
}

.eyebrow--light {
  color: var(--cream);
  background: rgba(244, 236, 223, 0.15);
}

.eyebrow--light::before { background: var(--blush); }

.display {
  font-family: var(--ff-display);
  font-weight: 500;
  line-height: 0.94;
  letter-spacing: -0.035em;
  color: var(--ink);
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 100;
}

.display em, .display i {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--plum);
}

.display--mono { font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125; }

.h1 { font-size: var(--fs-3xl); }
.h2 { font-size: var(--fs-2xl); }
.h3 { font-size: var(--fs-xl); }
.h4 {
  font-family: var(--ff-sans);
  font-size: var(--fs-lg);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.lead {
  font-family: var(--ff-body);
  font-size: var(--fs-lg);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 46ch;
}

.body-text { color: var(--ink-soft); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  padding: 18px 30px 20px;
  font-family: var(--ff-sans);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: var(--r-pill);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  white-space: nowrap;
  line-height: 1;
}

.btn__arrow {
  width: 14px;
  height: 14px;
  transition: transform var(--dur) var(--ease);
}

.btn:hover .btn__arrow { transform: translate(2px, -2px); }

.btn--primary {
  background: var(--plum);
  color: var(--cream);
}

.btn--primary:hover {
  background: var(--plum-deep);
  transform: translateY(-1px);
  box-shadow: var(--shade-2);
}

.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: rgba(23, 18, 15, 0.18);
}

.btn--ghost:hover {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}

.btn--blush {
  background: var(--blush);
  color: var(--plum);
}

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

.btn--cream {
  background: var(--cream);
  color: var(--plum);
}

.btn--cream:hover {
  background: white;
  transform: translateY(-1px);
  box-shadow: var(--shade-2);
}

/* ---------- Header ---------- */
.site-header {
  position: sticky;
  top: var(--sp-4);
  z-index: 80;
  padding-top: var(--sp-4);
}

.nav-wrap {
  max-width: var(--wrap);
  margin-inline: auto;
  padding-inline: var(--pad);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
  padding: 12px 16px 12px 28px;
  background: rgba(244, 236, 223, 0.82);
  backdrop-filter: blur(24px) saturate(1.2);
  -webkit-backdrop-filter: blur(24px) saturate(1.2);
  border-radius: var(--r-pill);
  border: 1px solid rgba(23, 18, 15, 0.06);
  box-shadow: var(--shade-1);
}

.wordmark {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1.42rem;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-variation-settings: "SOFT" 100, "opsz" 60, "wdth" 125;
  display: inline-flex;
  align-items: baseline;
}

.wordmark__dot {
  width: 8px;
  height: 8px;
  background: var(--plum);
  border-radius: 50%;
  margin-left: 6px;
  margin-bottom: 4px;
  align-self: flex-end;
}

.nav__links {
  display: none;
  align-items: center;
  gap: var(--sp-5);
  margin-left: auto;
  margin-right: var(--sp-4);
}

.nav__link {
  font-family: var(--ff-sans);
  font-size: 0.94rem;
  font-weight: 500;
  color: var(--ink-soft);
  padding: 10px 16px;
  border-radius: var(--r-pill);
  transition: color var(--dur), background var(--dur);
}

.nav__link:hover { color: var(--ink); background: rgba(23, 18, 15, 0.04); }
.nav__link.is-active { color: var(--plum); }

.nav__cta { padding: 14px 22px 15px; font-size: 0.88rem; }

.nav__burger {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
  padding: 14px;
  border-radius: 50%;
  border: none;
  background: var(--ink);
  cursor: pointer;
  margin-left: auto;
}

.nav__burger span {
  width: 18px;
  height: 1.5px;
  background: var(--cream);
  border-radius: 2px;
  transition: transform var(--dur) var(--ease), opacity var(--dur);
}

.nav__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (min-width: 900px) {
  .nav__links { display: inline-flex; }
  .nav__burger { display: none; }
}

.nav-mobile {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: var(--cream);
  padding: var(--sp-9) var(--pad) var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  transform: translateY(-100%);
  transition: transform var(--dur-slow) var(--ease);
}

.nav-mobile.is-open { transform: translateY(0); }

.nav-mobile a {
  font-family: var(--ff-display);
  font-size: clamp(2.2rem, 8vw, 3rem);
  font-weight: 500;
  letter-spacing: -0.03em;
  color: var(--ink);
  padding-block: var(--sp-2);
}

.nav-mobile a em {
  font-family: var(--ff-italic);
  font-style: italic;
  color: var(--plum);
}

@media (min-width: 900px) {
  .nav-mobile { display: none; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding-block: clamp(var(--sp-8), 6vw, var(--sp-10)) var(--sp-9);
  position: relative;
  overflow: hidden;
}

.hero__inner {
  position: relative;
  z-index: 2;
}

.hero__row {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
  margin-bottom: var(--sp-6);
}

.hero__stamp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 82px;
  height: 82px;
  border-radius: 50%;
  background: var(--honey);
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: 0.94rem;
  color: var(--plum-deep);
  text-align: center;
  line-height: 1.15;
  animation: spin 24s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

.hero__headline {
  font-family: var(--ff-display);
  font-size: var(--fs-4xl);
  font-weight: 500;
  line-height: 0.88;
  letter-spacing: -0.045em;
  color: var(--ink);
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125;
  max-width: 16ch;
}

.hero__headline em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
  letter-spacing: -0.025em;
  font-variation-settings: normal;
  display: inline-block;
  transform: translateY(4px);
}

.hero__sub {
  margin-top: var(--sp-6);
  max-width: 46ch;
  font-size: var(--fs-lg);
  color: var(--ink-soft);
  line-height: 1.55;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-6);
}

/* Organic blobs behind hero */
.hero__blobs {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.85;
}

.blob--a {
  width: 680px;
  height: 680px;
  right: -180px;
  top: -220px;
  background: radial-gradient(circle at 30% 30%, var(--blush), var(--blush-soft) 40%, transparent 72%);
}

.blob--b {
  width: 540px;
  height: 540px;
  left: -100px;
  bottom: -260px;
  background: radial-gradient(circle at 60% 40%, var(--sky), var(--cream-deep) 60%, transparent 80%);
}

.blob--c {
  width: 320px;
  height: 320px;
  right: 22%;
  bottom: 8%;
  background: radial-gradient(circle at 50% 50%, var(--honey-soft), transparent 70%);
  opacity: 0.6;
}

/* Hero figure — layered organic shape + asymmetric photo stand-in */
.hero__figure {
  position: relative;
  margin-top: clamp(var(--sp-8), 8vw, var(--sp-9));
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--sp-5);
  align-items: stretch;
}

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

.pill-card {
  background: var(--cream-warm);
  border-radius: var(--r-2xl);
  padding: clamp(28px, 4vw, 52px);
  position: relative;
  overflow: hidden;
  min-height: 340px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid rgba(23, 18, 15, 0.06);
}

.pill-card--plum {
  background: var(--plum);
  color: var(--cream);
}
.pill-card--plum .pill-card__stat { color: var(--cream); }
.pill-card--plum .pill-card__caption { color: rgba(244, 236, 223, 0.75); }

.pill-card--blush { background: var(--blush); }
.pill-card--sky { background: var(--sky); }
.pill-card--honey { background: var(--honey); }
.pill-card--lime { background: var(--lime); }

.pill-card__stat {
  font-family: var(--ff-display);
  font-size: clamp(5rem, 10vw, 9rem);
  font-weight: 500;
  line-height: 0.85;
  letter-spacing: -0.05em;
  color: var(--ink);
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125;
}

.pill-card__stat em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  font-size: 0.55em;
  color: var(--plum);
  letter-spacing: -0.02em;
}

.pill-card--plum .pill-card__stat em { color: var(--blush); }

.pill-card__caption {
  font-family: var(--ff-sans);
  font-size: 0.98rem;
  font-weight: 500;
  color: var(--ink-soft);
  margin-top: var(--sp-4);
  max-width: 28ch;
}

.pill-card__tag {
  position: absolute;
  top: var(--sp-5);
  right: var(--sp-5);
  font-family: var(--ff-sans);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 8px 16px;
  background: rgba(23, 18, 15, 0.08);
  color: var(--ink);
  border-radius: var(--r-pill);
}

.pill-card--plum .pill-card__tag {
  background: rgba(244, 236, 223, 0.18);
  color: var(--cream);
}

.hero-marquee {
  margin-top: var(--sp-9);
  white-space: nowrap;
  overflow: hidden;
  border-top: 1px solid rgba(23, 18, 15, 0.1);
  border-bottom: 1px solid rgba(23, 18, 15, 0.1);
  padding-block: var(--sp-5);
  position: relative;
  z-index: 2;
}

.marquee__track {
  display: inline-block;
  animation: marquee 42s linear infinite;
  padding-right: var(--sp-8);
}

.marquee__track em {
  font-family: var(--ff-italic);
  font-style: italic;
  color: var(--plum);
}

.marquee__track > span {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  font-variation-settings: "SOFT" 100, "opsz" 144;
  margin-right: var(--sp-6);
  display: inline-block;
}

.marquee__dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  background: var(--plum);
  border-radius: 50%;
  margin: 0 var(--sp-5) 10px;
  vertical-align: middle;
}

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

/* ============================================================
   PHILOSOPHY — THREE PRINCIPLES
   ============================================================ */
.principles {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-top: var(--sp-8);
}

@media (min-width: 720px) {
  .principles { grid-template-columns: repeat(3, 1fr); }
}

.principle {
  background: var(--cream-warm);
  border-radius: var(--r-xl);
  padding: clamp(28px, 3vw, 40px);
  position: relative;
  overflow: hidden;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  min-height: 420px;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(23, 18, 15, 0.05);
}

.principle:hover {
  transform: translateY(-6px);
  box-shadow: var(--shade-2);
}

.principle__ring {
  width: 94px;
  height: 94px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  position: relative;
  margin-bottom: var(--sp-5);
  flex-shrink: 0;
}

.principle:nth-child(1) .principle__ring { background: var(--blush); }
.principle:nth-child(2) .principle__ring { background: var(--sky); }
.principle:nth-child(3) .principle__ring { background: var(--honey); }

.principle__ring svg {
  width: 42px;
  height: 42px;
  color: var(--plum);
}

.principle__num {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-5);
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--ink-soft);
  opacity: 0.5;
}

.principle h3 {
  font-family: var(--ff-display);
  font-size: clamp(1.6rem, 2.5vw, 2.1rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--ink);
  font-variation-settings: "SOFT" 100, "opsz" 72, "wdth" 125;
  margin-bottom: var(--sp-4);
}

.principle h3 em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
  letter-spacing: -0.015em;
}

.principle p {
  color: var(--ink-soft);
  font-size: 1rem;
  line-height: 1.6;
}

/* ============================================================
   STAGES (age brackets)
   ============================================================ */
.stages {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-top: var(--sp-8);
}

@media (min-width: 820px) {
  .stages { grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
}

.stage {
  position: relative;
  padding: var(--sp-7);
  border-radius: var(--r-xl);
  min-height: 520px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  transition: transform var(--dur-slow) var(--ease);
}

.stage:hover { transform: translateY(-8px); }

.stage--infant {
  background: linear-gradient(155deg, var(--blush) 0%, var(--blush-soft) 70%);
  color: var(--plum-deep);
}

.stage--middle {
  background: linear-gradient(155deg, var(--sky) 0%, #D6E3E2 70%);
  color: var(--plum-deep);
}

.stage--sixth {
  background: linear-gradient(155deg, var(--plum) 0%, var(--plum-deep) 70%);
  color: var(--cream);
}

.stage__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.stage__age {
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: 1.05rem;
  opacity: 0.8;
}

.stage__pill {
  font-family: var(--ff-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 8px 16px;
  border-radius: var(--r-pill);
  background: rgba(23, 18, 15, 0.09);
}

.stage--sixth .stage__pill { background: rgba(244, 236, 223, 0.18); color: var(--cream); }

.stage__title {
  font-family: var(--ff-display);
  font-size: clamp(2.6rem, 5vw, 4rem);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125;
  margin-top: auto;
}

.stage__title em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.02em;
}

.stage--sixth .stage__title em { color: var(--blush); }

.stage__desc {
  font-size: 1rem;
  line-height: 1.55;
  margin-top: var(--sp-5);
  max-width: 32ch;
  opacity: 0.9;
}

.stage__cta {
  margin-top: var(--sp-5);
  font-family: var(--ff-sans);
  font-weight: 600;
  font-size: 0.94rem;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  transition: gap var(--dur);
}

.stage:hover .stage__cta { gap: 14px; }

.stage__shape {
  position: absolute;
  border-radius: 50%;
  opacity: 0.35;
  pointer-events: none;
}

.stage--infant .stage__shape {
  width: 240px;
  height: 240px;
  top: -60px;
  right: -60px;
  background: var(--honey-soft);
}

.stage--middle .stage__shape {
  width: 280px;
  height: 280px;
  top: -80px;
  right: -80px;
  background: rgba(244, 236, 223, 0.7);
}

.stage--sixth .stage__shape {
  width: 220px;
  height: 220px;
  top: -60px;
  right: -60px;
  background: var(--blush);
  opacity: 0.3;
}

/* ============================================================
   VOICES (testimonials)
   ============================================================ */
.voices {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-top: var(--sp-8);
}

@media (min-width: 820px) {
  .voices { grid-template-columns: 2fr 1.3fr; }
  .voice--b { margin-top: var(--sp-8); }
}

.voice {
  background: var(--cream-warm);
  border-radius: var(--r-xl);
  padding: clamp(32px, 4vw, 56px);
  position: relative;
  overflow: hidden;
}

.voice--plum { background: var(--plum); color: var(--cream); }
.voice--blush { background: var(--blush); }
.voice--sky { background: var(--sky); }

.voice__mark {
  position: absolute;
  top: 20px;
  right: 36px;
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: 6rem;
  line-height: 1;
  color: var(--plum);
  opacity: 0.2;
  pointer-events: none;
}

.voice--plum .voice__mark { color: var(--blush); opacity: 0.5; }

.voice__quote {
  font-family: var(--ff-display);
  font-weight: 400;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-variation-settings: "SOFT" 100, "opsz" 72, "wdth" 105;
  position: relative;
  z-index: 1;
}

.voice__quote em {
  font-family: var(--ff-italic);
  font-style: italic;
  color: var(--plum);
}
.voice--plum .voice__quote em { color: var(--blush); }

.voice__attr {
  margin-top: var(--sp-6);
  display: flex;
  gap: var(--sp-3);
  align-items: center;
}

.voice__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(23, 18, 15, 0.08);
  display: grid;
  place-items: center;
  font-family: var(--ff-sans);
  font-weight: 600;
  color: var(--ink);
}

.voice--plum .voice__avatar {
  background: rgba(244, 236, 223, 0.15);
  color: var(--cream);
}

.voice__name {
  font-family: var(--ff-sans);
  font-weight: 600;
  font-size: 1rem;
}

.voice__role {
  font-size: 0.9rem;
  opacity: 0.7;
}

/* ============================================================
   CTA BANNER
   ============================================================ */
.banner {
  background: var(--ink);
  color: var(--cream);
  border-radius: var(--r-2xl);
  padding: clamp(48px, 6vw, 88px) clamp(32px, 5vw, 72px);
  position: relative;
  overflow: hidden;
  display: grid;
  gap: var(--sp-6);
}

.banner__headline {
  font-family: var(--ff-display);
  font-size: clamp(2.6rem, 6vw, 5rem);
  font-weight: 500;
  line-height: 0.92;
  letter-spacing: -0.04em;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125;
  max-width: 18ch;
  position: relative;
  z-index: 2;
}

.banner__headline em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--blush);
  letter-spacing: -0.02em;
}

.banner__sub {
  font-size: var(--fs-lg);
  opacity: 0.75;
  max-width: 42ch;
  position: relative;
  z-index: 2;
}

.banner__actions {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}

.banner__blob {
  position: absolute;
  width: 680px;
  height: 680px;
  border-radius: 50%;
  filter: blur(80px);
  right: -200px;
  top: -200px;
  background: radial-gradient(circle, var(--plum) 0%, transparent 70%);
  opacity: 0.9;
  z-index: 0;
}

.banner__blob--b {
  left: -300px;
  bottom: -300px;
  top: auto;
  right: auto;
  background: radial-gradient(circle, var(--sky-deep) 0%, transparent 70%);
  opacity: 0.45;
}

/* ============================================================
   SECTION HEADERS (reusable)
   ============================================================ */
.section__head {
  display: grid;
  gap: var(--sp-4);
  max-width: 44ch;
}

.section__head--wide { max-width: 56ch; }

.section__head .h1,
.section__head .h2 {
  font-family: var(--ff-display);
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 0.96;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 105;
  color: var(--ink);
}

.section__head .h1 em,
.section__head .h2 em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
  letter-spacing: -0.02em;
}

/* ============================================================
   PAGE HEADER (inner pages)
   ============================================================ */
.page-head {
  padding-block: clamp(var(--sp-9), 8vw, var(--sp-10)) var(--sp-8);
  position: relative;
  overflow: hidden;
}

.page-head__eyebrow { margin-bottom: var(--sp-5); }

.page-head__title {
  font-family: var(--ff-display);
  font-size: clamp(3rem, 8vw, 7rem);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: -0.045em;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125;
  color: var(--ink);
  max-width: 16ch;
}

.page-head__title em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
  letter-spacing: -0.025em;
}

.page-head__sub {
  margin-top: var(--sp-5);
  font-size: var(--fs-lg);
  color: var(--ink-soft);
  max-width: 52ch;
}

.page-head__ambient {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: -1;
}

.page-head__ambient .blob { filter: blur(80px); }

/* ============================================================
   PROGRAMMES — detail rows
   ============================================================ */
.programme {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-top: var(--sp-8);
  padding: clamp(32px, 4vw, 64px);
  border-radius: var(--r-2xl);
  overflow: hidden;
  position: relative;
}

@media (min-width: 820px) {
  .programme { grid-template-columns: 1fr 1fr; gap: var(--sp-7); }
  .programme--reverse > :first-child { order: 2; }
}

.programme--infant {
  background: linear-gradient(160deg, var(--blush-soft), var(--cream-warm));
}

.programme--middle {
  background: linear-gradient(160deg, var(--sky), var(--cream-warm));
}

.programme--sixth {
  background: linear-gradient(160deg, var(--plum), var(--plum-deep));
  color: var(--cream);
}

.programme__figure {
  border-radius: var(--r-xl);
  aspect-ratio: 4 / 5;
  position: relative;
  overflow: hidden;
  min-height: 380px;
  display: grid;
  place-items: center;
}

.programme--infant .programme__figure { background: var(--blush); }
.programme--middle .programme__figure { background: var(--sky-deep); }
.programme--sixth .programme__figure { background: var(--plum-deep); }

.programme__figure-num {
  font-family: var(--ff-display);
  font-size: clamp(8rem, 18vw, 16rem);
  font-weight: 500;
  line-height: 0.85;
  letter-spacing: -0.05em;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125;
  color: var(--cream);
}

.programme--infant .programme__figure-num { color: var(--cream); }
.programme--middle .programme__figure-num { color: var(--cream); }
.programme--sixth .programme__figure-num { color: var(--blush); }

.programme__figure-num em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
  font-size: 0.35em;
  letter-spacing: -0.02em;
  display: block;
  margin-top: var(--sp-3);
}

.programme__content > .eyebrow {
  margin-bottom: var(--sp-5);
}

.programme__headline {
  font-family: var(--ff-display);
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  font-weight: 500;
  line-height: 0.94;
  letter-spacing: -0.035em;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 115;
}

.programme__headline em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
  letter-spacing: -0.02em;
}

.programme--sixth .programme__headline em { color: var(--blush); }

.programme__body {
  margin-top: var(--sp-5);
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 44ch;
  opacity: 0.88;
}

.programme__subjects {
  margin-top: var(--sp-6);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.programme__subject {
  padding: 8px 18px;
  border-radius: var(--r-pill);
  font-family: var(--ff-sans);
  font-size: 0.86rem;
  font-weight: 500;
  background: rgba(23, 18, 15, 0.07);
  color: var(--ink);
}

.programme--sixth .programme__subject {
  background: rgba(244, 236, 223, 0.14);
  color: var(--cream);
}

/* ============================================================
   ADMISSIONS PROCESS
   ============================================================ */
.process {
  display: grid;
  gap: var(--sp-3);
  margin-top: var(--sp-8);
  counter-reset: step;
}

.process__step {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--sp-5);
  padding: var(--sp-6) var(--sp-7);
  background: var(--cream-warm);
  border-radius: var(--r-xl);
  align-items: start;
  transition: background var(--dur);
}

.process__step:hover { background: var(--cream-deep); }

.process__num {
  font-family: var(--ff-display);
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: -0.03em;
  font-variation-settings: "SOFT" 100, "opsz" 96, "wdth" 125;
  color: var(--plum);
  min-width: 1.2em;
}

.process__num em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
}

.process__body h4 {
  font-family: var(--ff-display);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  font-variation-settings: "SOFT" 100, "opsz" 48, "wdth" 115;
  margin-bottom: var(--sp-2);
}

.process__body p {
  color: var(--ink-soft);
  max-width: 60ch;
}

.process__when {
  font-family: var(--ff-italic);
  font-style: italic;
  color: var(--plum);
  font-size: 1.1rem;
  align-self: center;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .process__step { grid-template-columns: 1fr; }
  .process__when { text-align: right; }
}

/* Key dates */
.dates {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
  margin-top: var(--sp-8);
}

@media (min-width: 720px) {
  .dates { grid-template-columns: repeat(3, 1fr); }
}

.date {
  background: var(--cream-warm);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  border: 1px solid rgba(23, 18, 15, 0.04);
}

.date__label {
  font-family: var(--ff-sans);
  font-size: 0.84rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--plum);
  margin-bottom: var(--sp-3);
}

.date__day {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 1;
  font-variation-settings: "SOFT" 100, "opsz" 96, "wdth" 115;
}

.date__day em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
}

.date__note {
  margin-top: var(--sp-3);
  color: var(--ink-soft);
  font-size: 0.96rem;
}

/* Fees */
.fees {
  margin-top: var(--sp-8);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}

@media (min-width: 820px) {
  .fees { grid-template-columns: repeat(3, 1fr); }
}

.fee {
  background: var(--plum);
  color: var(--cream);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
  position: relative;
  overflow: hidden;
}

.fee--blush { background: var(--blush); color: var(--plum-deep); }
.fee--sky { background: var(--sky); color: var(--plum-deep); }

.fee__label {
  font-family: var(--ff-sans);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.8rem;
  opacity: 0.7;
}

.fee__amt {
  font-family: var(--ff-display);
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-top: var(--sp-4);
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 125;
}

.fee__amt em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  font-size: 0.5em;
}

.fee__note {
  margin-top: var(--sp-4);
  font-size: 0.95rem;
  opacity: 0.85;
}

/* ============================================================
   FORM
   ============================================================ */
.booking {
  background: var(--cream-warm);
  border-radius: var(--r-2xl);
  padding: clamp(32px, 5vw, 72px);
  margin-top: var(--sp-8);
  position: relative;
  overflow: hidden;
}

.booking__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-7);
}

@media (min-width: 820px) {
  .booking__grid { grid-template-columns: 0.85fr 1.15fr; gap: var(--sp-8); }
}

.booking__intro h2 {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 0.98;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 115;
}

.booking__intro h2 em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--plum);
}

.booking__intro p {
  margin-top: var(--sp-4);
  color: var(--ink-soft);
  max-width: 34ch;
}

.booking__contact {
  margin-top: var(--sp-6);
  display: grid;
  gap: var(--sp-3);
}

.booking__contact a,
.booking__contact span {
  font-family: var(--ff-sans);
  font-weight: 500;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
}

.form {
  display: grid;
  gap: var(--sp-4);
}

.form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}

@media (min-width: 600px) {
  .form__row--2 { grid-template-columns: 1fr 1fr; }
}

.form__field {
  display: grid;
  gap: 8px;
}

.form__label {
  font-family: var(--ff-sans);
  font-size: 0.84rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  text-transform: uppercase;
}

.form__input,
.form__select,
.form__textarea {
  width: 100%;
  padding: 18px 22px;
  background: var(--cream);
  border: 1.5px solid transparent;
  border-radius: var(--r-md);
  font-family: var(--ff-body);
  font-size: 1rem;
  color: var(--ink);
  transition: border-color var(--dur), background var(--dur);
}

.form__input:focus,
.form__select:focus,
.form__textarea:focus {
  outline: none;
  border-color: var(--plum);
  background: white;
}

.form__textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.55;
}

.form__honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.form__submit {
  margin-top: var(--sp-2);
  justify-self: start;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: var(--ink);
  color: var(--cream);
  padding-top: var(--sp-9);
  padding-bottom: var(--sp-5);
  margin-top: var(--sp-9);
  position: relative;
  overflow: hidden;
}

.footer__top {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-7);
  padding-bottom: var(--sp-8);
  border-bottom: 1px solid rgba(244, 236, 223, 0.12);
}

@media (min-width: 820px) {
  .footer__top { grid-template-columns: 1.4fr 1fr 1fr 1fr; }
}

.footer__headline {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 0.98;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wdth" 115;
}

.footer__headline em {
  font-family: var(--ff-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--blush);
}

.footer__col h5 {
  font-family: var(--ff-sans);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blush);
  margin-bottom: var(--sp-4);
}

.footer__col a,
.footer__col p {
  display: block;
  font-family: var(--ff-body);
  color: rgba(244, 236, 223, 0.72);
  font-size: 1rem;
  padding-block: 4px;
  transition: color var(--dur);
}

.footer__col a:hover { color: var(--cream); }

.footer__bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--sp-4);
  padding-top: var(--sp-5);
  font-family: var(--ff-sans);
  font-size: 0.84rem;
  color: rgba(244, 236, 223, 0.45);
}

.footer__wordmark {
  font-family: var(--ff-display);
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--cream);
  font-variation-settings: "SOFT" 100, "opsz" 96, "wdth" 125;
  display: inline-flex;
  align-items: baseline;
  margin-bottom: var(--sp-4);
}

.footer__wordmark .wordmark__dot {
  background: var(--blush);
  width: 10px;
  height: 10px;
  margin-left: 8px;
  margin-bottom: 8px;
}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--dur-slow) var(--ease-soft), transform var(--dur-slow) var(--ease-soft);
}

.reveal.is-in {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; }
  .hero__stamp, .marquee__track { animation: none !important; }
}

/* ============================================================
   UTILITIES
   ============================================================ */
.mt-2 { margin-top: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }
.mt-5 { margin-top: var(--sp-5); }
.mt-6 { margin-top: var(--sp-6); }
.mt-7 { margin-top: var(--sp-7); }
.mt-8 { margin-top: var(--sp-8); }
.mt-9 { margin-top: var(--sp-9); }

.center { text-align: center; }
.ink { color: var(--ink); }
.plum { color: var(--plum); }
