/* ══════════════════════════════════════════════
   RISC LESKOVAC — style.css
   Mobile-first. Geist + Instrument Serif.
   ══════════════════════════════════════════════ */

/* ── RESET & ROOT ─────────────────────────────────── */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  /* Colors */
  --bg:       #080C14;
  --bg2:      #0C1019;
  --bg3:      #101520;
  --bg4:      #141923;
  --surface:  rgba(255,255,255,0.03);
  --surface2: rgba(255,255,255,0.06);
  --border:   rgba(255,255,255,0.07);
  --border2:  rgba(255,255,255,0.12);
  --accent:   #4F8EF7;
  --accent2:  #8B5CF6;
  --accent3:  #06D6A0;
  --text:     #EEF2FF;
  --text2:    #8892AA;
  --text3:    #505A72;
  --grad:     linear-gradient(135deg, #4F8EF7 0%, #8B5CF6 100%);
  --grad2:    linear-gradient(135deg, #8B5CF6 0%, #06D6A0 100%);
  --glow:     0 0 40px rgba(79,142,247,0.15);

  /* Type scale */
  --text-xs:   clamp(0.7rem,  1.5vw, 0.75rem);
  --text-sm:   clamp(0.82rem, 1.8vw, 0.875rem);
  --text-base: clamp(0.9rem,  2vw,   1rem);
  --text-lg:   clamp(1rem,    2.5vw, 1.125rem);
  --text-xl:   clamp(1.1rem,  3vw,   1.35rem);
  --text-2xl:  clamp(1.3rem,  4vw,   1.75rem);
  --text-3xl:  clamp(1.6rem,  5vw,   2.25rem);
  --text-4xl:  clamp(2rem,    6vw,   3rem);
  --text-hero: clamp(2.4rem,  8vw,   5rem);

  /* Spacing */
  --s4: 4px; --s8: 8px; --s12: 12px; --s16: 16px;
  --s20: 20px; --s24: 24px; --s32: 32px; --s40: 40px;
  --s48: 48px; --s64: 64px; --s80: 80px; --s96: 96px;
  --s128: 128px;
  --section-py: clamp(64px, 10vw, 128px);
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Touch devices: restore default cursor */
@media (hover: none) {
  body { cursor: auto; }
}

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

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

/* ── CUSTOM CURSOR ────────────────────────────────── */

.cursor {
  display: none;
  position: fixed;
  top: 0; left: 0;
  width: 10px; height: 10px;
  border: 1.5px solid rgba(79,142,247,0.5);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transition: transform 0.15s ease, background 0.15s ease, border-color 0.15s ease, width 0.25s ease, height 0.25s ease;
  transform: translate(-50%, -50%);
  will-change: transform;
}

.cursor.hovering {
  width: 28px; height: 28px;
  background: rgba(79,142,247,0.12);
  border-color: transparent;
}

@media (hover: hover) and (pointer: fine) {
  .cursor { display: block; }
  body { cursor: none; }
  a, button, .card-program, .card-community, .gallery-card { cursor: none; }
}

/* ── TYPOGRAPHY ───────────────────────────────────── */

h1, h2, h3, h4, h5 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.08;
  color: var(--text);
}

h1 em, h2 em, h3 em {
  font-style: italic;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

p {
  font-size: var(--text-base);
  color: var(--text2);
  line-height: 1.7;
}

/* ── BUTTONS ──────────────────────────────────────── */

.btn-primary,
.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.65rem 1.5rem;
  border-radius: 8px;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  transition: transform 0.25s cubic-bezier(0.22,1,0.36,1), box-shadow 0.25s, opacity 0.2s;
  cursor: pointer;
  border: none;
  white-space: nowrap;
}

.btn-primary {
  background: var(--grad);
  color: #fff;
  box-shadow: 0 0 0 0 rgba(79,142,247,0);
}

.btn-primary:hover {
  opacity: 0.9;
  box-shadow: 0 4px 24px rgba(79,142,247,0.35);
  transform: translateY(-2px);
}

.btn-primary:active {
  transform: scale(0.97);
}

.btn-secondary {
  background: var(--surface2);
  color: var(--text);
  border: 1px solid var(--border2);
}

.btn-secondary:hover {
  background: rgba(255,255,255,0.09);
  border-color: rgba(255,255,255,0.18);
  transform: translateY(-2px);
}

.btn-secondary:active {
  transform: scale(0.97);
}

/* ── SECTION SHARED ───────────────────────────────── */

.section-header {
  text-align: center;
  max-width: 680px;
  margin: 0 auto var(--s48);
  padding: 0 var(--s24);
}

.section-eyebrow {
  display: inline-block;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--s16);
  padding: 5px 12px;
  border: 1px solid rgba(79,142,247,0.25);
  border-radius: 100px;
  background: rgba(79,142,247,0.06);
}

.section-title {
  font-size: var(--text-4xl);
  margin-bottom: var(--s16);
  letter-spacing: -0.025em;
}

.section-sub {
  font-size: var(--text-base);
  color: var(--text2);
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ── CARD BASE ────────────────────────────────────── */

.card-base {
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: clamp(20px, 4vw, 32px);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
  position: relative;
  overflow: hidden;
}

.card-base::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad);
  opacity: 0;
  transition: opacity 0.25s;
}

.card-base:hover {
  border-color: rgba(79,142,247,0.3);
  box-shadow: 0 8px 40px rgba(79,142,247,0.1), inset 0 0 0 1px rgba(79,142,247,0.15);
  transform: translateY(-3px);
}

.card-base:hover::before {
  opacity: 1;
}

.card-base:active {
  transform: scale(0.985);
  border-color: rgba(79,142,247,0.25);
}

/* ── NAV ──────────────────────────────────────────── */

#nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 200;
  padding: 0 var(--s24);
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid transparent;
  transition: background 0.3s ease, border-color 0.3s ease, backdrop-filter 0.3s ease;
}

#nav.scrolled {
  background: rgba(8,12,20,0.85);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border-color: rgba(255,255,255,0.06);
}

.nav-logo {
  display: flex;
  align-items: baseline;
  gap: 4px;
  text-decoration: none;
  flex-shrink: 0;
}

.nav-logo__risc {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: 1.25rem;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.nav-logo__city {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 0.9rem;
  font-weight: 300;
  color: var(--text2);
  letter-spacing: 0.02em;
}

.nav-links {
  display: none;
  gap: 2rem;
  list-style: none;
  align-items: center;
}

.nav-links a {
  font-size: var(--text-sm);
  color: var(--text2);
  font-weight: 400;
  transition: color 0.2s;
}

.nav-links a:hover { color: var(--text); }

.nav-cta {
  display: none;
}

.nav-hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--s12);
  min-width: 44px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: background 0.2s;
}

.nav-hamburger:hover { background: var(--surface2); }

.nav-hamburger span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--text);
  border-radius: 2px;
  transition: transform 0.3s, opacity 0.3s;
  transform-origin: center;
}

.nav-hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── MOBILE MENU ──────────────────────────────────── */

.mobile-menu {
  position: fixed;
  top: 64px; left: 0; right: 0;
  background: rgba(8,12,20,0.97);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: var(--s24);
  gap: var(--s8);
  z-index: 190;
  transform: translateY(-120%);
  opacity: 0;
  transition: transform 0.35s cubic-bezier(0.22,1,0.36,1), opacity 0.3s;
  pointer-events: none;
}

.mobile-menu.open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
}

.mobile-menu__link {
  display: block;
  padding: var(--s12) var(--s16);
  font-size: var(--text-lg);
  color: var(--text2);
  border-radius: 8px;
  transition: background 0.2s, color 0.2s;
  min-height: 44px;
  display: flex;
  align-items: center;
}

.mobile-menu__link:hover {
  background: var(--surface2);
  color: var(--text);
}

.mobile-menu__cta {
  margin-top: var(--s8);
  background: var(--grad);
  color: #fff;
  padding: var(--s12) var(--s24);
  border-radius: 8px;
  font-weight: 500;
  text-align: center;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── HERO ─────────────────────────────────────────── */

.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 100px var(--s24) var(--s80);
  overflow: hidden;
}

#heroCanvas {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  display: none; /* Hidden on mobile, shown via JS on desktop */
}

.hero-mesh {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(79,142,247,0.18) 0%, transparent 70%),
    radial-gradient(ellipse 50% 50% at 80% 80%, rgba(139,92,246,0.14) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 20% 70%, rgba(6,214,160,0.09) 0%, transparent 60%);
  animation: mesh-shift 12s ease-in-out infinite alternate;
}

@keyframes mesh-shift {
  0%   {
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%,   rgba(79,142,247,0.22) 0%, transparent 70%),
      radial-gradient(ellipse 55% 55% at 85% 80%,  rgba(139,92,246,0.18) 0%, transparent 60%),
      radial-gradient(ellipse 45% 45% at 15% 75%,  rgba(6,214,160,0.11) 0%, transparent 60%);
  }
  33%  {
    background:
      radial-gradient(ellipse 70% 70% at 60% 10%,  rgba(139,92,246,0.2) 0%, transparent 70%),
      radial-gradient(ellipse 50% 60% at 20% 85%,  rgba(79,142,247,0.16) 0%, transparent 60%),
      radial-gradient(ellipse 40% 40% at 80% 60%,  rgba(6,214,160,0.12) 0%, transparent 55%);
  }
  66%  {
    background:
      radial-gradient(ellipse 90% 50% at 40% 5%,   rgba(79,142,247,0.18) 0%, transparent 70%),
      radial-gradient(ellipse 45% 65% at 75% 90%,  rgba(6,214,160,0.13) 0%, transparent 60%),
      radial-gradient(ellipse 50% 40% at 25% 60%,  rgba(139,92,246,0.15) 0%, transparent 55%);
  }
  100% {
    background:
      radial-gradient(ellipse 75% 65% at 55% 0%,   rgba(139,92,246,0.2) 0%, transparent 70%),
      radial-gradient(ellipse 60% 50% at 80% 75%,  rgba(79,142,247,0.16) 0%, transparent 60%),
      radial-gradient(ellipse 42% 48% at 18% 70%,  rgba(6,214,160,0.1) 0%, transparent 60%);
  }
}

.hero-grid {
  position: absolute; inset: 0; z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 30%, black 20%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 30%, black 20%, transparent 100%);
}

/* Floating orbs — CSS-only, visible on all viewports */
.hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  z-index: 0;
  will-change: transform;
}

.hero-orb--1 {
  width: 320px; height: 320px;
  top: -80px; left: -60px;
  background: radial-gradient(circle, rgba(79,142,247,0.25) 0%, transparent 70%);
  animation: orb-float-1 18s ease-in-out infinite;
}

.hero-orb--2 {
  width: 280px; height: 280px;
  bottom: 0; right: -40px;
  background: radial-gradient(circle, rgba(139,92,246,0.22) 0%, transparent 70%);
  animation: orb-float-2 22s ease-in-out infinite;
}

.hero-orb--3 {
  width: 200px; height: 200px;
  top: 40%; left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(6,214,160,0.12) 0%, transparent 70%);
  animation: orb-float-3 26s ease-in-out infinite;
}

@keyframes orb-float-1 {
  0%,100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(40px, 30px) scale(1.08); }
  66%      { transform: translate(-20px, 50px) scale(0.95); }
}

@keyframes orb-float-2 {
  0%,100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(-50px, -30px) scale(1.1); }
  66%      { transform: translate(20px, -60px) scale(0.92); }
}

@keyframes orb-float-3 {
  0%,100% { transform: translate(-50%, -50%) scale(1); opacity: 0.6; }
  50%      { transform: translate(-50%, -60%) scale(1.15); opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-orb { animation: none; }
  .hero-mesh { animation: none; }
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 800px;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s8);
  font-size: var(--text-xs);
  font-weight: 400;
  color: var(--text2);
  border: 1px solid var(--border2);
  border-radius: 100px;
  padding: 6px 14px;
  margin-bottom: var(--s32);
  background: rgba(255,255,255,0.03);
  letter-spacing: 0.02em;
}

.hero-badge__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent3);
  flex-shrink: 0;
  animation: pulse-dot 2.2s ease infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(0.85); }
}

.hero-h1 {
  font-size: var(--text-hero);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin-bottom: var(--s24);
  color: var(--text);
}

.hero-h1 em {
  font-style: italic;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-sub {
  font-size: var(--text-lg);
  color: var(--text2);
  max-width: 520px;
  margin: 0 auto var(--s40);
  line-height: 1.7;
  font-weight: 300;
}

.hero-actions {
  display: flex;
  flex-direction: column;
  gap: var(--s12);
  align-items: center;
}

.hero-scroll {
  position: absolute;
  bottom: var(--s32);
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}

.hero-scroll span {
  display: block;
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, var(--accent), transparent);
  animation: scroll-line 2s ease infinite;
}

@keyframes scroll-line {
  0% { opacity: 0; transform: scaleY(0); transform-origin: top; }
  50% { opacity: 1; transform: scaleY(1); transform-origin: top; }
  100% { opacity: 0; transform: scaleY(1); transform-origin: bottom; }
}

/* ── STATS ────────────────────────────────────────── */

.stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: var(--s32) var(--s24);
  gap: var(--s32) 0;
}

.stat-divider { display: none; }

.stat-item {
  text-align: center;
  padding: 0 var(--s16);
}

.stat-num {
  font-family: 'Fraunces', Georgia, serif;
  font-size: var(--text-4xl);
  font-weight: 400;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: var(--s8);
}

.stat-label {
  font-size: var(--text-xs);
  color: var(--text3);
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ── PROGRAMS ─────────────────────────────────────── */

.section-programs {
  padding: var(--section-py) 0;
  background: var(--bg);
}

.programs-scroll-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 0 var(--s24);
}

.programs-scroll-wrap::-webkit-scrollbar { display: none; }

.programs-grid {
  display: flex;
  gap: var(--s16);
  width: max-content;
  padding-bottom: var(--s8);
}

.card-program {
  width: 85vw;
  max-width: 340px;
  flex-shrink: 0;
  scroll-snap-align: start;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: clamp(20px, 4vw, 32px);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: var(--s12);
}

.card-program::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad);
  opacity: 0;
  transition: opacity 0.25s;
}

.card-program:hover {
  border-color: rgba(79,142,247,0.3);
  box-shadow: 0 8px 40px rgba(79,142,247,0.1), inset 0 0 0 1px rgba(79,142,247,0.15);
  transform: translateY(-3px);
}

.card-program:hover::before { opacity: 1; }

.card-program:active {
  transform: scale(0.985);
  border-color: rgba(79,142,247,0.25);
}

.card-program__icon {
  font-size: 1.75rem;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 12px;
  flex-shrink: 0;
}

.card-program__icon--blue   { background: rgba(79,142,247,0.12); }
.card-program__icon--purple { background: rgba(139,92,246,0.12); }
.card-program__icon--green  { background: rgba(6,214,160,0.12); }
.card-program__icon--orange { background: rgba(251,146,60,0.12); }

.card-program__tag {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.card-program__title {
  font-size: var(--text-xl);
  margin: 0;
  line-height: 1.2;
}

.card-program__desc {
  font-size: var(--text-sm);
  color: var(--text2);
  line-height: 1.65;
  flex: 1;
}

.card-program__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s8);
}

.card-program__pill {
  font-size: var(--text-xs);
  color: var(--text3);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 3px 10px;
  white-space: nowrap;
}

.card-link {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: auto;
  transition: gap 0.2s;
}

.card-link:hover { gap: 8px; }

.programs-dots {
  display: flex;
  justify-content: center;
  gap: var(--s8);
  margin-top: var(--s20);
  padding: 0 var(--s24);
}

.programs-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--border2);
  transition: background 0.2s, transform 0.2s;
}

.programs-dot.active {
  background: var(--accent);
  transform: scale(1.3);
}

/* ── HOW IT WORKS ─────────────────────────────────── */

.section-how {
  padding: var(--section-py) var(--s24);
  background: var(--bg2);
  position: relative;
}

.how-timeline {
  display: none;
}

.how-steps {
  display: flex;
  flex-direction: column;
  gap: var(--s32);
  max-width: 680px;
  margin: 0 auto;
  position: relative;
}

/* Vertical timeline line on mobile */
.how-steps::before {
  content: '';
  position: absolute;
  left: 22px;
  top: 0; bottom: 0;
  width: 1px;
  background: linear-gradient(to bottom, var(--accent), var(--accent2), transparent);
  opacity: 0.3;
}

.how-step {
  display: grid;
  grid-template-columns: 48px 1fr;
  grid-template-rows: auto auto;
  column-gap: var(--s20);
  row-gap: var(--s4);
  padding-left: 0;
}

.how-step__num {
  font-family: 'Fraunces', Georgia, serif;
  font-size: var(--text-2xl);
  font-weight: 400;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  grid-row: 1 / 3;
  align-self: center;
  text-align: center;
  position: relative;
  z-index: 1;
}

.how-step__title {
  font-size: var(--text-xl);
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  line-height: 1.2;
  align-self: end;
}

.how-step__desc {
  font-size: var(--text-sm);
  color: var(--text2);
  line-height: 1.65;
  align-self: start;
}

/* ── BENEFITS ─────────────────────────────────────── */

.section-benefits {
  padding: var(--section-py) var(--s24);
  background: var(--bg);
}

.benefits-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--s64);
}

.benefits-text {
  flex: 1;
}

.benefits-text .section-title {
  text-align: left;
  margin-bottom: var(--s16);
}

.benefits-text .section-eyebrow {
  display: inline-block;
  margin-bottom: var(--s16);
}

.benefits-text .section-sub {
  text-align: left;
  margin: 0 0 var(--s40);
}

.benefits-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--s24);
}

.benefit-item {
  display: flex;
  gap: var(--s16);
  align-items: flex-start;
}

.benefit-item__icon {
  font-size: 1.25rem;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  flex-shrink: 0;
}

.benefit-item__title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: var(--text-lg);
  font-weight: 400;
  margin-bottom: 4px;
  line-height: 1.3;
}

.benefit-item__desc {
  font-size: var(--text-sm);
  color: var(--text2);
  line-height: 1.65;
}

.benefits-visual {
  display: none;
  flex: 0 0 360px;
  position: relative;
}

.visual-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: var(--s20);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.vc__label {
  font-size: var(--text-xs);
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--s8);
}

.vc__value {
  font-size: var(--text-base);
  font-weight: 500;
  margin-bottom: 4px;
}

.vc__sub {
  font-size: var(--text-xs);
  color: var(--text3);
  margin-bottom: var(--s12);
}

.vc__bar {
  height: 3px;
  background: var(--surface2);
  border-radius: 2px;
  overflow: hidden;
}

.vc__fill {
  height: 100%;
  width: var(--fill);
  background: var(--grad);
  border-radius: 2px;
}

.vc1 { margin-bottom: var(--s16); }
.vc2 { margin-bottom: var(--s16); transform: translateX(var(--s24)); }

/* ── GALLERY ──────────────────────────────────────── */

.section-gallery {
  padding: var(--section-py) var(--s24);
  background: var(--bg2);
}

/*
  GALLERY GRID — Photo replacement guide:
  Replace .gallery-card__placeholder content with:
  <img src="photo.jpg" alt="Alt text" loading="lazy" style="width:100%;height:100%;object-fit:cover;border-radius:inherit;">
*/
.gallery-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--s16);
}

.gallery-card {
  border-radius: 12px;
  border: 1px solid var(--border);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, var(--bg3), var(--bg4));
  transition: transform 0.25s, border-color 0.25s;
  position: relative;
  cursor: pointer;
}

.gallery-card:hover {
  transform: scale(1.01);
  border-color: var(--border2);
}

.gallery-card__placeholder {
  width: 100%; height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--s12);
}

.gallery-card__icon {
  font-size: 2rem;
  opacity: 0.4;
}

.gallery-card__label {
  font-size: var(--text-xs);
  color: var(--text3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.gallery-caption {
  text-align: center;
  margin-top: var(--s24);
  font-size: var(--text-sm);
  color: var(--text3);
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

/* ── COMMUNITY ────────────────────────────────────── */

.section-community {
  padding: var(--section-py) 0;
  background: var(--bg);
}

.community-scroll-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 0 var(--s24);
}

.community-scroll-wrap::-webkit-scrollbar { display: none; }

.community-grid {
  display: flex;
  gap: var(--s16);
  width: max-content;
}

.card-community {
  width: 85vw;
  max-width: 280px;
  flex-shrink: 0;
  scroll-snap-align: start;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: clamp(20px, 4vw, 28px);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: var(--s12);
}

.card-community::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad2);
  opacity: 0;
  transition: opacity 0.25s;
}

.card-community:hover {
  border-color: rgba(139,92,246,0.3);
  box-shadow: 0 8px 40px rgba(139,92,246,0.1);
  transform: translateY(-3px);
}

.card-community:hover::before { opacity: 1; }
.card-community:active { transform: scale(0.985); }

.card-community__icon {
  font-size: 1.5rem;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: var(--surface2);
  border-radius: 10px;
}

.card-community__title {
  font-size: var(--text-lg);
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  line-height: 1.2;
}

.card-community__desc {
  font-size: var(--text-sm);
  color: var(--text2);
  line-height: 1.65;
}

/* ── PARTNERS ─────────────────────────────────────── */

.section-partners {
  padding: var(--s48) var(--s24);
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  text-align: center;
}

.partners-label {
  font-size: var(--text-xs);
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--s24);
}

.partners-logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--s8) var(--s24);
}

.partner-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--text-sm);
  color: var(--text3);
  font-weight: 400;
  padding: 8px 16px;
  border-radius: 8px;
  transition: color 0.2s, background 0.2s;
  min-height: 44px;
}

.partner-logo:hover {
  color: var(--text2);
  background: var(--surface2);
}

.partner-logo__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--grad);
  background-size: 200%;
  flex-shrink: 0;
}

/* ── FINAL CTA ────────────────────────────────────── */

.section-cta {
  padding: var(--section-py) var(--s24);
  background: var(--bg);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.section-cta__glow {
  position: absolute;
  top: -40%;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 400px;
  background: radial-gradient(ellipse at center, rgba(79,142,247,0.15) 0%, rgba(139,92,246,0.1) 40%, transparent 70%);
  pointer-events: none;
}

.section-cta__content {
  position: relative;
  z-index: 1;
  max-width: 680px;
  margin: 0 auto;
}

.section-cta__title {
  font-size: var(--text-4xl);
  letter-spacing: -0.025em;
  margin-bottom: var(--s24);
  margin-top: var(--s16);
}

.section-cta__sub {
  font-size: var(--text-lg);
  color: var(--text2);
  max-width: 520px;
  margin: 0 auto var(--s40);
  line-height: 1.65;
}

.section-cta__actions {
  display: flex;
  flex-direction: column;
  gap: var(--s12);
  align-items: center;
  margin-bottom: var(--s24);
}

.section-cta__urgency {
  font-size: var(--text-xs);
  color: var(--text3);
  letter-spacing: 0.04em;
}

/* ── FOOTER ───────────────────────────────────────── */

.footer {
  background: var(--bg2);
  border-top: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

.footer-noise {
  position: absolute; inset: 0;
  opacity: 0.025;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}

.footer-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s40);
  padding: var(--s64) var(--s24) var(--s48);
  max-width: 1200px;
  margin: 0 auto;
}

.footer-brand__tagline {
  margin-top: var(--s12);
  font-size: var(--text-sm);
  color: var(--text3);
  max-width: 280px;
  line-height: 1.65;
}

.footer-col__title {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: var(--s16);
}

.footer-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--s12);
}

.footer-col a {
  font-size: var(--text-sm);
  color: var(--text3);
  transition: color 0.2s;
}

.footer-col a:hover { color: var(--text2); }

.footer-bottom {
  display: flex;
  flex-direction: column;
  gap: var(--s16);
  align-items: center;
  padding: var(--s24) var(--s24);
  border-top: 1px solid var(--border);
  max-width: 1200px;
  margin: 0 auto;
}

.footer-bottom__copy {
  font-size: var(--text-xs);
  color: var(--text3);
}

.footer-bottom__social {
  display: flex;
  gap: var(--s16);
}

.footer-bottom__social a {
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 8px;
  border: 1px solid var(--border);
  color: var(--text3);
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.footer-bottom__social a:hover {
  color: var(--text);
  border-color: var(--border2);
  background: var(--surface2);
}

/* ── REVEAL ANIMATIONS ────────────────────────────── */

@media (prefers-reduced-motion: no-preference) {
  .reveal-item {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.55s cubic-bezier(0.22,1,0.36,1), transform 0.55s cubic-bezier(0.22,1,0.36,1);
  }

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

  /* Word/em reveal */
  .char {
    display: inline-block;
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.5s cubic-bezier(0.22,1,0.36,1), transform 0.5s cubic-bezier(0.22,1,0.36,1);
    transition-delay: calc(var(--i) * 60ms);
  }

  /* em.char must keep its gradient — override display for inline flow */
  em.char {
    display: inline;
  }

  .chars-visible .char {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ══════════════════════════════════════════════
   TABLET — min-width: 640px
   ══════════════════════════════════════════════ */

@media (min-width: 640px) {
  .stats {
    grid-template-columns: repeat(3, 1fr);
    padding: var(--s40) var(--s40);
  }

  .hero-actions {
    flex-direction: row;
    justify-content: center;
  }

  .section-cta__actions {
    flex-direction: row;
    justify-content: center;
  }

  .gallery-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: auto auto;
    gap: var(--s16);
  }

  .gallery-card { aspect-ratio: 4 / 3; }
  .gallery-card--large {
    grid-column: 1 / 3;
    grid-row: 1;
    aspect-ratio: 16 / 9;
  }
  .gallery-card--tall {
    grid-column: 3;
    aspect-ratio: auto;
    min-height: 200px;
  }

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

  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
  }
}

/* ══════════════════════════════════════════════
   DESKTOP — min-width: 1024px
   ══════════════════════════════════════════════ */

@media (min-width: 1024px) {
  #nav { padding: 0 var(--s40); height: 72px; }

  .nav-links { display: flex; }
  .nav-cta { display: inline-flex; }
  .nav-hamburger { display: none; }

  .stats {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: var(--s32) var(--s64);
  }

  .stat-divider {
    display: block;
    width: 1px;
    height: 40px;
    background: var(--border);
    flex-shrink: 0;
  }

  .stat-item { padding: 0 var(--s48); }

  .programs-scroll-wrap {
    overflow: visible;
    padding: 0 var(--s64);
  }

  .programs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    width: auto;
    gap: var(--s24);
  }

  .card-program {
    width: auto;
    max-width: none;
    scroll-snap-align: unset;
  }

  .programs-dots { display: none; }

  .how-timeline {
    display: block;
    padding: 0 var(--s64);
    margin-bottom: -30px;
    position: relative;
    z-index: 0;
  }

  .how-path { width: 100%; height: 60px; }

  .how-steps {
    flex-direction: row;
    gap: 0;
    max-width: none;
    padding: 0 var(--s64);
    align-items: flex-start;
  }

  .how-steps::before { display: none; }

  .how-step {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0 var(--s16);
    grid-template-columns: unset;
  }

  .how-step__num {
    font-size: var(--text-3xl);
    margin-bottom: var(--s16);
    grid-row: unset;
    align-self: unset;
  }

  .how-step__title { text-align: center; }
  .how-step__desc { text-align: center; }

  .benefits-inner {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--s96);
  }

  .benefits-visual {
    display: flex;
    flex-direction: column;
    flex: 0 0 340px;
  }

  .community-scroll-wrap {
    overflow: visible;
    padding: 0 var(--s64);
  }

  .community-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    width: auto;
    gap: var(--s20);
  }

  .card-community {
    width: auto;
    max-width: none;
    scroll-snap-align: unset;
  }

  .gallery-grid {
    grid-template-columns: 2fr 1fr 1fr;
  }

  .gallery-card--large { grid-column: 1; }
  .gallery-card--tall { grid-column: 2; }
  .gallery-card:nth-child(3) { grid-column: 3; }

  .footer-top {
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    padding: var(--s80) var(--s64) var(--s64);
  }

  .section-programs,
  .section-how,
  .section-benefits,
  .section-gallery,
  .section-community,
  .section-cta {
    padding-left: 0;
    padding-right: 0;
  }
}

/* ══════════════════════════════════════════════
   WIDE — min-width: 1280px
   ══════════════════════════════════════════════ */

@media (min-width: 1280px) {
  .section-header { padding: 0; }
}
