/* artvoic: один файл → кастомный CSS Elementor/темы. Токены :root — для всех блоков. */

:root {
  --artvoic-bg: #050505;
  --artvoic-accent: #00ffd1;
  /* Фиолетовый акцент (До/После, волна about-author) */
  --artvoic-accent-purple: #6c63ff;
  --artvoic-text: #ffffff;
  --artvoic-text-muted: rgba(255, 255, 255, 0.82);
  --artvoic-text-soft: rgba(255, 255, 255, 0.9);
  --artvoic-font-body: "Montserrat", system-ui, sans-serif;
  --artvoic-font-display: "Unbounded", "Montserrat", sans-serif;
  /* Второй экран: холоднее hero (изумруд → электрик / индиго), бесшовный стык за счёт общего базового тона */
  --directions-hub-base: #050508;
  /* Третий экран «Об авторе»: чуть глубже/нейтральнее, мягкий переход с directions-hub */
  --about-author-base: #06060e;
  /* «Социальное доказательство»: тот же тон, что «об авторе», но светлее — заметнее тело секции */
  --social-proof-base: #0c0c1e;
  /* Футер: стык с social-proof, глубже к «дну» страницы */
  --site-footer-base: #050510;
  --site-footer-deep: #020208;
  /* Лендинг курса: «Узнай себя» — верх стыкуется с низом hero-course (полоса волны → тот же тон, что --directions-hub-base) */
  --course-audience-base: #08091c;
  /* Следующий виджет после «Узнай себя» (тариф, программа): общий фон для бесшовного низа волны */
  --course-after-audience-base: #070817;
  /* Программа курса (таймлайн модулей) — стык после блока результатов */
  --course-program-base: #060a1b;
  /* Тарифы — тело секции; стык сверху с низом #course-pocket-studio (там же --course-pocket-surface) */
  --course-pricing-base: #06060f;
  /* FAQ курса — чуть глубже pricing, без резкого контраста */
  --course-faq-base: #070713;
  --course-pocket-surface: #0a0a0c;
  /* Волны между секциями курса (бирюза/электрик, стык с палитрой акцента) */
  --course-bridge-wave: #1e9fc4;
  --course-bridge-wave-soft: rgba(0, 214, 232, 0.48);
  /* Лендинг детского курса: бесшовные стыки секций */
  --kids-hero-base: #030206;
  --kids-results-base: #070819;
  --kids-program-base: #060b1e;
  --kids-mentor-base: #08071c;
  --kids-faq-base: #070716;
  --kids-pricing-base: #060511;
  /* Страница «Стоимость услуг» (виджет #price-services) */
  --price-services-base: #070716;
  /* Детский + очный взрослый интенсив (#intensivkids-*, #intensiv-msk-*) — мягкие индиго-стыки */
  --intensiv-kids-hero-base: #04040b;
  --intensiv-kids-mid: #070819;
  --intensiv-kids-deep: #050510;
}
/* ========== Лендинг детского курса: hero, результаты, наставник (сразу после :root: не держать только в конце файла — часть кастомного CSS на сайте обрезается по лимиту) ========== */

@keyframes kids-hero-cta-pulse {
  0%,
  100% {
    box-shadow:
      0 0 0 1px rgba(0, 255, 209, 0.45),
      0 0 0 0 rgba(0, 255, 209, 0.35),
      0 14px 44px rgba(0, 255, 209, 0.18);
  }
  50% {
    box-shadow:
      0 0 0 1px rgba(0, 255, 209, 0.75),
      0 0 0 14px rgba(0, 255, 209, 0),
      0 18px 52px rgba(0, 255, 209, 0.28);
  }
}

@keyframes kids-hero-ken {
  0% {
    transform: scale(1.05) translate(0, 0);
  }
  100% {
    transform: scale(1.12) translate(-1.5%, -1%);
  }
}

@keyframes kids-hero-overlay-breathe {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.82;
  }
}

:is(#kids-hero, #imx-hero, #pco-hero) {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--kids-hero-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

/* Плавный низ → тот же тон, что у #kids-results (--kids-results-base), бесшовный стык */
:is(#kids-hero, #imx-hero, #pco-hero)::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 3;
  height: clamp(120px, 32vh, 360px);
  pointer-events: none;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(7, 8, 25, 0.22) 28%,
    rgba(7, 8, 25, 0.72) 62%,
    var(--kids-results-base) 92%,
    var(--kids-results-base) 100%
  );
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__video,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__photo {
  z-index: 0;
  animation: kids-hero-ken 28s ease-in-out infinite alternate;
}

@media (prefers-reduced-motion: reduce) {
  :is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__photo {
    animation: none;
  }
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__video {
  z-index: 1;
  opacity: 0.88;
  mix-blend-mode: normal;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cinematic {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  animation: kids-hero-overlay-breathe 7s ease-in-out infinite;
  background:
    linear-gradient(125deg, rgba(0, 0, 0, 0.72) 0%, rgba(0, 0, 0, 0.35) 42%, transparent 72%),
    linear-gradient(315deg, rgba(0, 0, 0, 0.55) 0%, transparent 48%),
    linear-gradient(
      180deg,
      rgba(0, 0, 0, 0.2) 0%,
      rgba(0, 0, 0, 0.75) 48%,
      rgba(7, 8, 25, 0.82) 82%,
      rgba(7, 8, 25, 0.92) 100%
    ),
    radial-gradient(ellipse 85% 65% at 45% 38%, transparent 0%, rgba(0, 0, 0, 0.45) 100%);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__grid {
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.75fr);
  gap: clamp(1.5rem, 4vw, 2.75rem);
  align-items: end;
  min-height: 100vh;
  min-height: 100dvh;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(1.25rem, 4vw, 4rem) clamp(1.25rem, 5vw, 5rem) calc(6.5rem + clamp(56px, 10vh, 96px));
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__copy {
  max-width: min(40rem, 100%);
  padding-bottom: clamp(0.5rem, 3vh, 2rem);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__kicker {
  display: block;
  margin: 0 0 0.65rem;
  font-weight: 600;
  font-size: clamp(0.65rem, 0.42vw + 0.58rem, 0.8rem);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
  text-shadow: 0 0 24px rgba(0, 255, 209, 0.35);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__title {
  margin: 0 0 1rem;
  font-family: var(--artvoic-font-display);
  font-weight: 700;
  font-size: clamp(1.55rem, 2.2vw + 1rem, 2.65rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-shadow:
    0 0 40px rgba(0, 255, 209, 0.12),
    0 2px 24px rgba(0, 0, 0, 0.45);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__title-lead {
  display: block;
  margin-bottom: 0.42em;
  font-size: 0.92em;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--artvoic-text-soft);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__title-main {
  display: block;
  line-height: 1.12;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__subtitle {
  margin: 0 0 1.65rem;
  font-size: clamp(1rem, 0.35vw + 0.92rem, 1.15rem);
  line-height: 1.58;
  color: var(--artvoic-text-muted);
  max-width: 36em;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 1.85rem;
  font-family: var(--artvoic-font-body);
  font-weight: 700;
  font-size: 0.95rem;
  text-decoration: none;
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-radius: 2px;
  animation: kids-hero-cta-pulse 2.4s ease-in-out infinite;
  transition: transform 0.25s ease;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cta:hover {
  transform: translateY(-2px);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cta:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cta-note {
  margin: 0.65rem 0 0;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__frame {
  position: relative;
  justify-self: end;
  width: 100%;
  max-width: min(100%, 380px);
  border-radius: 6px;
  overflow: hidden;
  box-shadow:
    0 28px 72px rgba(0, 0, 0, 0.65),
    0 0 0 1px rgba(108, 99, 255, 0.35),
    0 0 48px rgba(0, 255, 209, 0.15);
  outline: 1px solid rgba(0, 255, 209, 0.2);
  outline-offset: 10px;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__frame img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__frame-tag {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.65rem 0.85rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.75), transparent);
}

@media (max-width: 900px) {
  :is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__grid {
    grid-template-columns: 1fr;
    align-items: center;
    text-align: center;
    padding-bottom: calc(5.5rem + clamp(56px, 10vh, 96px));
  }

  :is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__copy {
    padding-bottom: 0;
  }

  :is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cta {
    width: 100%;
    max-width: 22rem;
    justify-self: center;
  }

  :is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__frame {
    justify-self: center;
    max-width: min(340px, 88vw);
    order: -1;
  }
}

@media (prefers-reduced-motion: reduce) {
  :is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cinematic {
    animation: none;
  }

  :is(#kids-hero, #imx-hero, #pco-hero) .kids-hero__cta {
    animation: none;
    box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.45), 0 14px 44px rgba(0, 255, 209, 0.12);
  }
}

/* --- Результаты для мам: стекло + мини «До/После» --- */

:is(#kids-results, #imx-audience, #pco-audience) {
  position: relative;
  background:
    radial-gradient(ellipse 75% 58% at 50% 38%, rgba(108, 99, 255, 0.14), transparent 62%),
    radial-gradient(ellipse 65% 50% at 92% 48%, rgba(0, 255, 209, 0.09), transparent 55%),
    linear-gradient(
      180deg,
      var(--kids-results-base) 0%,
      var(--kids-results-base) 58%,
      var(--kids-program-base) 88%,
      var(--kids-program-base) 100%
    );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, var(--kids-results-base) 0%, rgba(7, 8, 25, 0) clamp(72px, 12vh, 140px)),
    radial-gradient(ellipse 52% 46% at 80% 26%, rgba(0, 255, 209, 0.2), transparent 58%),
    radial-gradient(ellipse 50% 44% at 14% 58%, rgba(108, 99, 255, 0.22), transparent 56%),
    radial-gradient(ellipse 90% 55% at 50% 105%, rgba(0, 214, 232, 0.12), transparent 52%);
  filter: blur(34px);
  opacity: 1;
  /* Низ без цветного ореола — совпадает с линейным фоном секции и верхом #kids-program */
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 calc(100% - clamp(80px, 16vh, 160px)), transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 calc(100% - clamp(80px, 16vh, 160px)), transparent 100%);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(4rem, 8vw, 6rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.5rem, 5vw, 4rem) + clamp(64px, 11vh, 108px));
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__head {
  text-align: center;
  max-width: 44rem;
  margin: 0 auto clamp(2rem, 4vw, 3rem);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__title {
  margin: 0 0 0.75rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #fff;
  text-shadow: 0 1px 28px rgba(0, 0, 0, 0.45);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__intro {
  margin: 0;
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-soft);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  height: 100%;
  margin: 0;
  padding: clamp(1.35rem, 2.8vw, 1.75rem);
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid rgba(255, 255, 255, 0.12);
  -webkit-backdrop-filter: blur(22px) saturate(150%);
  backdrop-filter: blur(22px) saturate(150%);
  box-shadow:
    0 24px 56px rgba(0, 0, 0, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease;
}

@media (hover: hover) and (pointer: fine) {
  :is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass:hover {
    transform: translateY(-4px);
    border-color: rgba(0, 255, 209, 0.28);
    box-shadow:
      0 32px 64px rgba(0, 0, 0, 0.42),
      0 0 40px rgba(108, 99, 255, 0.12),
      inset 0 1px 0 rgba(255, 255, 255, 0.1);
  }
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__top {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 0;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.08);
  border: 1px solid rgba(0, 255, 209, 0.22);
  box-shadow: 0 0 28px rgba(0, 255, 209, 0.12);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__icon svg,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__icon img {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__title {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.02rem, 0.3vw + 0.94rem, 1.18rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: #fff;
  text-shadow: 0 1px 18px rgba(0, 0, 0, 0.35);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__text {
  margin: 0;
  font-size: clamp(0.9rem, 0.22vw + 0.84rem, 0.98rem);
  line-height: 1.55;
  color: var(--artvoic-text-soft);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__media {
  margin-top: auto;
  flex: 1 1 auto;
  min-height: clamp(148px, 20vh, 216px);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.28);
  box-shadow:
    0 14px 36px rgba(0, 0, 0, 0.42),
    inset 0 0 0 1px rgba(0, 255, 209, 0.06);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass__media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: clamp(148px, 20vh, 216px);
  object-fit: cover;
  object-position: center;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare {
  margin-top: auto;
  padding: 0.85rem 0.95rem;
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare__label {
  margin: 0 0 0.5rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare__wave {
  height: 44px;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 0.65rem;
  background: rgba(255, 255, 255, 0.04);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kv-wave {
  position: relative;
  height: 100%;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kv-wave__layer {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 3px;
  padding: 8px 10px;
  transition: opacity 0.35s ease;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kv-wave__layer span {
  flex: 1;
  min-width: 3px;
  height: var(--h, 40%);
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.55);
  transform-origin: bottom;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare.is-after .kv-wave__layer--before {
  opacity: 0;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare.is-after .kv-wave__layer--after {
  opacity: 1;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare:not(.is-after) .kv-wave__layer--after {
  opacity: 0;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare:not(.is-after) .kv-wave__layer--before {
  opacity: 1;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kv-wave__layer--after span {
  background: linear-gradient(180deg, rgba(0, 255, 209, 0.85), rgba(108, 99, 255, 0.75));
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare__toggle {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.55rem;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare__btn {
  flex: 1;
  padding: 0.45rem 0.5rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.75);
  cursor: pointer;
  transition:
    background 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare__btn.is-active {
  color: var(--kids-results-base);
  background: var(--artvoic-accent);
  border-color: transparent;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-voice-compare__btn:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}


:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__cta-wrap {
  margin-top: clamp(2.25rem, 4vw, 3rem);
  text-align: center;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.75rem;
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.35), 0 12px 40px rgba(0, 255, 209, 0.12);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__cta:hover {
  transform: translateY(-2px);
}

:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__cta:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

@media (max-width: 768px) {
  :is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-results__grid {
    grid-template-columns: 1fr;
  }
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
  :is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .kids-glass {
    background: rgba(18, 18, 28, 0.92);
  }
}

/* --- Детский лендинг: вертикальные ролики со студии --- */

:is(#kids-studio-videos, #imx-backstage) {
  position: relative;
  /* Порядок на лендинге: после #kids-program, перед :is(#kids-mentor, #pco-mentor); база как у наставника для ровного полотна */
  background: var(--kids-mentor-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

/* Стык после «Путь героя»: тёмный мост гасит разницу фонов/ореола и линии волны */
:is(#kids-studio-videos, #imx-backstage)::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: clamp(88px, 17vh, 200px);
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.62) 0%,
    rgba(0, 0, 0, 0.28) 48%,
    rgba(0, 0, 0, 0.06) 82%,
    transparent 100%
  );
}

/* Низ: стык с волной и секцией наставника */
:is(#kids-studio-videos, #imx-backstage)::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(88px, 17vh, 200px);
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.58) 0%,
    rgba(0, 0, 0, 0.26) 48%,
    rgba(0, 0, 0, 0.07) 82%,
    transparent 100%
  );
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__glow {
  position: absolute;
  z-index: 0;
  inset: -18% -10% -12% -10%;
  background:
    radial-gradient(ellipse 50% 42% at 50% 22%, rgba(0, 255, 209, 0.085), transparent 55%),
    radial-gradient(ellipse 40% 38% at 82% 68%, rgba(108, 99, 255, 0.095), transparent 52%);
  filter: blur(40px);
  pointer-events: none;
  opacity: 0.92;
  /* Сверху и снизу гасим — нет второго «пятна» на стыке с программой и над волной */
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.5) 8%,
    #000 20%,
    #000 calc(100% - clamp(88px, 14vh, 140px)),
    rgba(0, 0, 0, 0.45) calc(100% - clamp(56px, 10vh, 96px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.5) 8%,
    #000 20%,
    #000 calc(100% - clamp(88px, 14vh, 140px)),
    rgba(0, 0, 0, 0.45) calc(100% - clamp(56px, 10vh, 96px)),
    transparent 100%
  );
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.5rem, 6vw, 4rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.5rem, 6vw, 4rem) + clamp(64px, 11vh, 108px));
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__head {
  text-align: center;
  max-width: 44rem;
  margin: 0 auto clamp(1.75rem, 4vw, 2.75rem);
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__title {
  margin: 0 0 0.85rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.35rem, 0.5vw + 1.15rem, 1.85rem);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #fff;
  text-shadow: 0 1px 24px rgba(0, 0, 0, 0.4);
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__intro {
  margin: 0;
  font-size: clamp(0.92rem, 0.25vw + 0.85rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.75rem, 2vw, 1.25rem);
  margin: 0;
  padding: 0;
  list-style: none;
  align-items: start;
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__item {
  min-width: 0;
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__frame {
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 9 / 16;
  max-height: min(72vh, 520px);
  margin: 0 auto;
  width: 100%;
  max-width: 220px;
  background: rgba(0, 0, 0, 0.35);
  box-shadow:
    0 20px 48px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(0, 255, 209, 0.14);
  outline: 1px solid rgba(108, 99, 255, 0.2);
  outline-offset: 4px;
}

:is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 900px) {
  :is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  :is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__frame {
    max-width: none;
  }
}

@media (max-width: 520px) {
  :is(#kids-studio-videos, #imx-backstage) .kids-studio-videos__grid {
    grid-template-columns: 1fr;
    max-width: 280px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* --- Наставник --- */

:is(#kids-mentor, #pco-mentor) {
  position: relative;
  background: linear-gradient(
    180deg,
    var(--kids-mentor-base) 0%,
    var(--kids-mentor-base) 52%,
    var(--kids-faq-base) 86%,
    var(--kids-faq-base) 100%
  );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

/* Стык после блока со студией — плавный вход в секцию наставника */
:is(#kids-mentor, #pco-mentor)::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: clamp(72px, 14vh, 160px);
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.52) 0%,
    rgba(0, 0, 0, 0.2) 52%,
    transparent 100%
  );
}

/* Низ: стык с волной и блоком FAQ */
:is(#kids-mentor, #pco-mentor)::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(88px, 16vh, 180px);
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.58) 0%,
    rgba(0, 0, 0, 0.24) 50%,
    rgba(0, 0, 0, 0.08) 82%,
    transparent 100%
  );
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__aurora {
  position: absolute;
  inset: -24%;
  background:
    radial-gradient(ellipse 44% 40% at 30% 20%, rgba(0, 255, 209, 0.1), transparent 52%),
    radial-gradient(ellipse 42% 38% at 72% 78%, rgba(108, 99, 255, 0.12), transparent 50%);
  filter: blur(46px);
  pointer-events: none;
  /* Верх — стык с #kids-studio-videos (волна/фон) или #kids-program; низ — стык с #kids-faq */
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.55) 14%,
    #000 28%,
    #000 calc(100% - clamp(80px, 16vh, 160px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.55) 14%,
    #000 28%,
    #000 calc(100% - clamp(80px, 16vh, 160px)),
    transparent 100%
  );
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(4rem, 8vw, 5.5rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.5rem, 5vw, 3.75rem) + clamp(64px, 11vh, 108px));
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: clamp(1.75rem, 4vw, 3rem);
  align-items: center;
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__content {
  min-width: 0;
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__visual {
  position: relative;
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__photo {
  display: block;
  width: 100%;
  max-width: 420px;
  margin: 0 auto;
  border-radius: 8px;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  box-shadow:
    0 28px 72px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(0, 255, 209, 0.18);
  outline: 1px solid rgba(108, 99, 255, 0.25);
  outline-offset: 8px;
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__badge {
  position: absolute;
  left: 8%;
  bottom: -1rem;
  padding: 0.65rem 1rem;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  box-shadow: 0 12px 32px rgba(0, 255, 209, 0.25);
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__title {
  margin: 0 0 1rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.35rem, 0.5vw + 1.15rem, 1.85rem);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #fff;
  text-shadow: 0 1px 28px rgba(0, 0, 0, 0.45);
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__lead {
  margin: 0 0 1.35rem;
  font-size: clamp(0.95rem, 0.25vw + 0.88rem, 1.05rem);
  line-height: 1.6;
  color: var(--artvoic-text-muted);
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__stats {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.85rem, 2vw, 1.25rem);
  margin: 0 0 1.5rem;
  padding: 0;
  list-style: none;
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__stats li {
  flex: 1 1 calc(50% - 1rem);
  min-width: 140px;
  padding: 0.85rem 1rem;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__stat-num {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.55rem, 2vw, 1.9rem);
  font-weight: 700;
  color: var(--artvoic-accent);
  line-height: 1;
  margin-bottom: 0.35rem;
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__stat-text {
  font-size: 0.82rem;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.65);
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__logos-label {
  margin: 0 0 0.65rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__logos {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

:is(#kids-mentor, #pco-mentor) .kids-mentor__logo {
  padding: 0.5rem 0.85rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.78);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

@media (max-width: 900px) {
  :is(#kids-mentor, #pco-mentor) .kids-mentor__inner {
    grid-template-columns: 1fr;
    text-align: center;
  }

  :is(#kids-mentor, #pco-mentor) .kids-mentor__stats {
    justify-content: center;
  }

  :is(#kids-mentor, #pco-mentor) .kids-mentor__logos {
    justify-content: center;
  }

  :is(#kids-mentor, #pco-mentor) .kids-mentor__badge {
    left: 50%;
    transform: translateX(-50%);
  }

  :is(#kids-mentor, #pco-mentor) .kids-mentor__visual {
    order: -1;
  }
}

#hero-dubbing, #hero-course {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--artvoic-bg);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
}

#hero-dubbing .hero-dubbing__bg-wrapper,
#hero-course .hero-dubbing__bg-wrapper,
#course-how-learning .hero-dubbing__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#hero-dubbing .hero-dubbing__aurora,
#hero-course .hero-dubbing__aurora,
#course-how-learning .hero-dubbing__aurora {
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(ellipse 48% 44% at 16% 30%, rgba(0, 255, 209, 0.32), transparent 55%),
    radial-gradient(ellipse 38% 48% at 92% 14%, rgba(120, 255, 230, 0.18), transparent 48%),
    radial-gradient(ellipse 52% 40% at 78% 88%, rgba(0, 255, 209, 0.2), transparent 52%),
    radial-gradient(ellipse 58% 52% at 48% 52%, rgba(0, 140, 150, 0.28), transparent 58%),
    radial-gradient(ellipse 35% 38% at 62% 22%, rgba(0, 255, 209, 0.12), transparent 50%);
  filter: blur(38px);
  transform-origin: 45% 40%;
  animation: hero-dubbing-aurora 18s ease-in-out infinite alternate;
}

#hero-dubbing .hero-dubbing__glow,
#hero-course .hero-dubbing__glow,
#course-how-learning .hero-dubbing__glow {
  position: absolute;
  top: 8%;
  left: -2%;
  width: min(58vw, 620px);
  height: min(58vw, 620px);
  background: radial-gradient(circle, rgba(0, 255, 209, 0.28) 0%, rgba(0, 255, 209, 0.06) 42%, transparent 70%);
  filter: blur(64px);
  animation: hero-dubbing-breath 11s ease-in-out infinite;
}

#hero-dubbing .hero-dubbing__glow::after,
#hero-course .hero-dubbing__glow::after,
#course-how-learning .hero-dubbing__glow::after {
  content: "";
  position: absolute;
  right: -40%;
  bottom: -35%;
  width: min(50vw, 520px);
  height: min(50vw, 520px);
  background: radial-gradient(circle, rgba(0, 200, 185, 0.22) 0%, transparent 65%);
  filter: blur(56px);
  animation: hero-dubbing-breath 15s ease-in-out infinite reverse;
  opacity: 0.85;
}

#hero-dubbing .hero-dubbing__overlay,
#hero-course .hero-dubbing__overlay,
#course-how-learning .hero-dubbing__overlay {
  position: absolute;
  inset: 0;
  /* Сверху — прежняя виньетка; снизу — мягкий «сход» в базовый цвет, без резкой границы со следующим блоком */
  background:
    linear-gradient(
      180deg,
      transparent 0%,
      transparent 52%,
      rgba(5, 5, 8, 0.35) 78%,
      var(--directions-hub-base) 100%
    ),
    radial-gradient(
      ellipse 95% 82% at 50% 38%,
      transparent 0%,
      rgba(5, 5, 5, 0.28) 62%,
      rgba(5, 5, 5, 0.65) 88%,
      var(--artvoic-bg) 100%
    );
}

/* Стык после #course-program: первые пиксели без «перетемнения» от радиальной виньетки */
#course-how-learning .hero-dubbing__overlay {
  background:
    linear-gradient(180deg, var(--directions-hub-base) 0%, rgba(5, 5, 8, 0) 14%),
    linear-gradient(
      180deg,
      transparent 0%,
      transparent 52%,
      rgba(5, 5, 8, 0.35) 78%,
      var(--directions-hub-base) 100%
    ),
    radial-gradient(
      ellipse 95% 82% at 50% 38%,
      transparent 0%,
      rgba(5, 5, 5, 0.28) 62%,
      rgba(5, 5, 5, 0.65) 88%,
      var(--artvoic-bg) 100%
    );
}

@keyframes hero-dubbing-aurora {
  0% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    opacity: 1;
  }
  33% {
    transform: translate(7%, -5%) scale(1.1) rotate(1.2deg);
    opacity: 1;
  }
  66% {
    transform: translate(-6%, 8%) scale(1.04) rotate(-0.7deg);
    opacity: 0.94;
  }
  100% {
    transform: translate(4%, 4%) scale(1.12) rotate(0.5deg);
    opacity: 1;
  }
}

@keyframes hero-dubbing-breath {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
    opacity: 0.55;
  }
  50% {
    transform: translate(8%, 12%) scale(1.28);
    opacity: 0.95;
  }
}

@keyframes hero-dubbing-orbit {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes hero-dubbing-pulse {
  0%,
  100% {
    transform: scale(0.92);
    opacity: 0.38;
  }
  50% {
    transform: scale(1.08);
    opacity: 0.8;
  }
}

@keyframes hero-dubbing-sound {
  0%,
  100% {
    transform: scaleY(0.35);
    opacity: 0.45;
  }
  50% {
    transform: scaleY(1);
    opacity: 1;
  }
}

/* Отдельное, чуть иное движение — визуально не «дублирует» hero и не бьётся в фазу */
@keyframes directions-hub-aurora {
  0% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    opacity: 1;
  }
  50% {
    transform: translate(-5%, 6%) scale(1.08) rotate(-0.9deg);
    opacity: 0.96;
  }
  100% {
    transform: translate(6%, -4%) scale(1.05) rotate(0.6deg);
    opacity: 1;
  }
}

@keyframes directions-hub-breath {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
    opacity: 0.5;
  }
  50% {
    transform: translate(-6%, 10%) scale(1.22);
    opacity: 0.88;
  }
}

@keyframes about-author-aurora {
  0% {
    transform: translate(0, 0) scale(1);
    opacity: 1;
  }
  50% {
    transform: translate(4%, 5%) scale(1.06) rotate(0.5deg);
    opacity: 0.93;
  }
  100% {
    transform: translate(-3%, -3%) scale(1.03) rotate(-0.4deg);
    opacity: 1;
  }
}

@keyframes about-author-breath {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
    opacity: 0.52;
  }
  50% {
    transform: translate(5%, -8%) scale(1.18);
    opacity: 0.95;
  }
}

@keyframes about-author-marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

#hero-dubbing .hero-dubbing__grid, #hero-course .hero-dubbing__grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.88fr);
  gap: clamp(1.5rem, 3.5vw, 2.75rem);
  align-items: center;
  min-height: 100vh;
  min-height: 100dvh;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(1.25rem, 4vw, 4rem) clamp(1.25rem, 5vw, 5rem) 6.5rem;
}

#hero-dubbing .hero-dubbing__copy, #hero-course .hero-dubbing__copy {
  max-width: min(36rem, 100%);
}

#hero-dubbing .hero-dubbing__title, #hero-course .hero-dubbing__title {
  margin: 0 0 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

#hero-dubbing .hero-dubbing__title-kicker, #hero-course .hero-dubbing__title-kicker {
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: clamp(0.65rem, 0.42vw + 0.58rem, 0.8rem);
  line-height: 1.4;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#hero-dubbing .hero-dubbing__title-main, #hero-course .hero-dubbing__title-main {
  font-family: var(--artvoic-font-display);
  font-weight: 700;
  font-size: clamp(1.7rem, 2.5vw + 0.95rem, 2.9rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-shadow: 0 0 42px rgba(0, 255, 209, 0.12);
}

#hero-dubbing .hero-dubbing__title-main--wow {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.02em;
  text-shadow: none;
}

#hero-dubbing .hero-dubbing__title-main--wow .hero-dubbing__title-main-line {
  display: block;
  font: inherit;
  font-size: inherit;
  line-height: 1.05;
  letter-spacing: inherit;
  text-shadow: 0 0 42px rgba(0, 255, 209, 0.14);
}

#hero-dubbing .hero-dubbing__title-main--wow .hero-dubbing__title-main-line--glow {
  margin-top: -0.02em;
  font-size: clamp(1.95rem, 2.85vw + 1.12rem, 3.35rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  color: transparent;
  background-image: linear-gradient(
    105deg,
    #7cf5ff 0%,
    #00ffd1 22%,
    #b8fff3 44%,
    #c4b5fd 72%,
    #00ffd1 100%
  );
  background-size: 240% 100%;
  background-position: 0% 50%;
  -webkit-background-clip: text;
  background-clip: text;
  animation: hero-dubbing-title-shimmer 7.5s ease-in-out infinite;
  filter: drop-shadow(0 0 22px rgba(0, 255, 209, 0.42)) drop-shadow(0 0 56px rgba(124, 245, 255, 0.22));
  will-change: background-position;
}

@keyframes hero-dubbing-title-shimmer {
  0%,
  100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

#hero-dubbing .hero-dubbing__title-line, #hero-course .hero-dubbing__title-line {
  font-family: var(--artvoic-font-display);
  font-weight: 500;
  font-size: clamp(1rem, 0.95vw + 0.72rem, 1.38rem);
  line-height: 1.22;
  letter-spacing: -0.02em;
  color: var(--artvoic-text-soft);
  max-width: 22em;
}

#hero-dubbing .hero-dubbing__subtitle, #hero-course .hero-dubbing__subtitle {
  margin: 0 0 1.75rem;
  font-size: clamp(1rem, 0.35vw + 0.92rem, 1.2rem);
  line-height: 1.58;
  font-weight: 400;
  color: var(--artvoic-text-muted);
}

#hero-dubbing .hero-dubbing__facts, #hero-course .hero-dubbing__facts {
  margin: 0 0 1.65rem;
  padding-left: 1rem;
  border-left: 2px solid rgba(0, 255, 209, 0.35);
}

#hero-dubbing .hero-dubbing__facts-kicker, #hero-course .hero-dubbing__facts-kicker {
  margin: 0 0 0.55rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: clamp(0.58rem, 0.35vw + 0.52rem, 0.7rem);
  line-height: 1.35;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(0, 255, 209, 0.85);
}

#hero-dubbing .hero-dubbing__facts-list, #hero-course .hero-dubbing__facts-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: clamp(0.82rem, 0.22vw + 0.76rem, 0.92rem);
  line-height: 1.45;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.78);
}

#hero-dubbing .hero-dubbing__facts-list li, #hero-course .hero-dubbing__facts-list li {
  margin: 0;
  padding: 0;
}

#hero-dubbing .hero-dubbing__cta,
#hero-course .hero-dubbing__cta,
#course-after-audience .course-results__cta,
#course-pricing .course-pricing__cta--primary,
:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--primary,
#price-services .price-services__cta:not(.price-services__cta--ghost) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.75rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.35), 0 12px 40px rgba(0, 255, 209, 0.12);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

#hero-dubbing .hero-dubbing__cta:hover,
#hero-course .hero-dubbing__cta:hover,
#course-after-audience .course-results__cta:hover,
#course-pricing .course-pricing__cta--primary:hover,
:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--primary:hover,
#price-services .price-services__cta:not(.price-services__cta--ghost):hover {
  transform: translateY(-2px);
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.55), 0 16px 48px rgba(0, 255, 209, 0.2);
}

#hero-dubbing .hero-dubbing__cta:focus-visible,
#hero-course .hero-dubbing__cta:focus-visible,
#course-after-audience .course-results__cta:focus-visible,
#course-pricing .course-pricing__cta--primary:focus-visible,
:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--primary:focus-visible,
#price-services .price-services__cta:not(.price-services__cta--ghost):focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#hero-dubbing .hero-dubbing__cta-wrap, #hero-course .hero-dubbing__cta-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.65rem;
}

#hero-dubbing .hero-dubbing__cta-note, #hero-course .hero-dubbing__cta-note {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--artvoic-text-muted);
}

#hero-dubbing .hero-dubbing__visual, #hero-course .hero-dubbing__visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  perspective: 1000px;
}

#hero-dubbing .hero-dubbing__parallax, #hero-course .hero-dubbing__parallax {
  position: relative;
  transform-style: preserve-3d;
  will-change: transform;
  width: 100%;
  max-width: min(100%, 430px);
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-stage {
  position: absolute;
  inset: -14% -16% -10%;
  z-index: 0;
  pointer-events: none;
  transform: translateZ(-80px);
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-stage::before,
:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-stage::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(18px);
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-stage::before {
  inset: 10% 4% 8%;
  background:
    radial-gradient(circle at 52% 30%, rgba(0, 255, 209, 0.34), transparent 38%),
    radial-gradient(circle at 75% 72%, rgba(108, 99, 255, 0.3), transparent 44%);
  opacity: 0.8;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-stage::after {
  left: 2%;
  right: 0;
  bottom: 2%;
  height: 28%;
  background: rgba(0, 255, 209, 0.28);
  opacity: 0.7;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-orbit {
  position: absolute;
  inset: 8%;
  border: 1px solid rgba(0, 255, 209, 0.22);
  border-radius: 42% 58% 46% 54% / 55% 45% 55% 45%;
  box-shadow: inset 0 0 34px rgba(0, 255, 209, 0.06), 0 0 30px rgba(0, 255, 209, 0.08);
  animation: hero-dubbing-orbit 22s linear infinite;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-orbit--two {
  inset: 2% 0 12% 6%;
  border-color: rgba(108, 99, 255, 0.24);
  transform: rotate(14deg);
  animation-duration: 30s;
  animation-direction: reverse;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-pulse {
  position: absolute;
  right: 7%;
  top: 14%;
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 999px;
  background: var(--artvoic-accent);
  box-shadow: 0 0 0 10px rgba(0, 255, 209, 0.12), 0 0 34px rgba(0, 255, 209, 0.8);
  animation: hero-dubbing-pulse 2.8s ease-in-out infinite;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__photo-card {
  position: relative;
  z-index: 1;
  margin: 0;
  padding: clamp(0.55rem, 1.2vw, 0.8rem);
  overflow: hidden;
  border-radius: 28px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.045)),
    rgba(5, 5, 5, 0.34);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow:
    0 36px 80px rgba(0, 0, 0, 0.62),
    0 0 0 1px rgba(0, 255, 209, 0.12),
    0 0 70px rgba(0, 255, 209, 0.16);
  backdrop-filter: blur(18px);
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__photo-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(0, 255, 209, 0.78), rgba(108, 99, 255, 0.5), rgba(255, 255, 255, 0.1));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__photo-glare {
  position: absolute;
  inset: -35% auto auto -55%;
  z-index: 2;
  width: 55%;
  height: 150%;
  pointer-events: none;
  background: linear-gradient(110deg, transparent 12%, rgba(255, 255, 255, 0.28) 48%, transparent 72%);
  transform: rotate(18deg);
  opacity: 0.45;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__photo {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 20px;
  will-change: transform;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.65), 0 0 0 1px rgba(0, 255, 209, 0.12);
  filter: saturate(1.08) contrast(1.05);
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-card {
  position: absolute;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.72rem 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  color: var(--artvoic-text);
  background: rgba(8, 10, 18, 0.58);
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.34), 0 0 34px rgba(0, 255, 209, 0.11);
  backdrop-filter: blur(18px);
  pointer-events: none;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-card--top {
  top: 9%;
  left: -8%;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-card--bottom {
  right: -9%;
  bottom: 14%;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-label {
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.86);
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-bars {
  display: inline-flex;
  align-items: center;
  gap: 0.18rem;
  height: 1rem;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-bars i {
  display: block;
  width: 0.16rem;
  height: 100%;
  border-radius: 999px;
  background: var(--artvoic-accent);
  transform-origin: 50% 100%;
  animation: hero-dubbing-sound 1.1s ease-in-out infinite;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-bars i:nth-child(2) {
  animation-delay: -0.18s;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-bars i:nth-child(3) {
  animation-delay: -0.36s;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-bars i:nth-child(4) {
  animation-delay: -0.54s;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-bars i:nth-child(5) {
  animation-delay: -0.72s;
}

:is(#hero-dubbing, #hero-course) .hero-dubbing__sound-dot {
  width: 0.58rem;
  height: 0.58rem;
  border-radius: 999px;
  background: var(--artvoic-accent);
  box-shadow: 0 0 0 7px rgba(0, 255, 209, 0.12), 0 0 28px rgba(0, 255, 209, 0.7);
}

#hero-dubbing .hero-dubbing__wave, #hero-course .hero-dubbing__wave {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: clamp(72px, 12vh, 120px);
  pointer-events: none;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}

#hero-dubbing .hero-dubbing__wave-track, #hero-course .hero-dubbing__wave-track {
  display: flex;
  width: 200%;
  height: 100%;
  animation: hero-dubbing-wave 24s linear infinite;
}

#hero-dubbing .hero-dubbing__wave-svg, #hero-course .hero-dubbing__wave-svg {
  flex: 0 0 50%;
  width: 50%;
  height: 100%;
  display: block;
}

#hero-dubbing .hero-dubbing__wave-line, #hero-course .hero-dubbing__wave-line {
  fill: none;
  stroke: var(--artvoic-accent);
  stroke-width: 1.75;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
  opacity: 0.5;
}

#hero-dubbing .hero-dubbing__wave-line--soft, #hero-course .hero-dubbing__wave-line--soft {
  stroke-width: 1.15;
  opacity: 0.28;
}

@keyframes hero-dubbing-wave {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-dubbing .hero-dubbing__wave-track,
  #hero-course .hero-dubbing__wave-track,
  #course-audience .course-audience__wave-track,
  #course-after-audience .course-after-audience__wave-track,
  #course-program .course-program__wave-track,
  :is(#kids-program, #imx-program) .course-program__wave-track,
  #imx-program .kids-landing__wave-track,
  :is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-track,
  #kids-results .kids-landing__wave-track,
  #imx-audience .kids-landing__wave-track,
  #pco-audience .kids-landing__wave-track,
  #imx-value .kids-landing__wave-track,
  #pco-advantages .kids-landing__wave-track,
  #kids-studio-videos .kids-landing__wave-track,
  #imx-backstage .kids-landing__wave-track,
  #pco-pricing .kids-landing__wave-track,
  #kids-mentor .kids-landing__wave-track,
  :is(#kids-faq, #imx-faq) .kids-landing__wave-track,
  #course-how-learning .course-how-learning__wave-track,
  #course-pocket-studio .course-pocket-studio__wave-track,
  :is(#intensivkids-hero, #intensivkids-about, #intensivkids-program, #intensivkids-moments, #intensiv-msk-hero, #intensiv-msk-about, #intensiv-msk-guest, #intensiv-msk-program, #intensiv-msk-how, #intensiv-msk-moments) .kids-landing__wave-track,
  #directions-hub .directions-hub__wave-track,
  #about-author .about-author__wave-track,
  #about-author .about-author__marquee-track,
  #social-proof .social-proof__aurora,
  #social-proof .social-proof__glow,
  #social-proof .social-proof__glow::after,
  #hero-dubbing .hero-dubbing__glow,
  #hero-course .hero-dubbing__glow,
  #course-how-learning .hero-dubbing__glow,
  #hero-dubbing .hero-dubbing__glow::after,
  #hero-course .hero-dubbing__glow::after,
  #course-how-learning .hero-dubbing__glow::after,
  #hero-dubbing .hero-dubbing__aurora,
  #hero-course .hero-dubbing__aurora,
  #course-how-learning .hero-dubbing__aurora,
  :is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-orbit,
  :is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-pulse,
  :is(#hero-dubbing, #hero-course) .hero-dubbing__sound-bars i,
  #directions-hub .directions-hub__glow,
  #directions-hub .directions-hub__glow::after,
  #directions-hub .directions-hub__aurora,
  #about-author .about-author__glow,
  #about-author .about-author__glow::after,
  #about-author .about-author__aurora {
    animation: none;
  }
  #hero-dubbing .hero-dubbing__title-main--wow .hero-dubbing__title-main-line--glow {
    animation: none;
    background-position: 0% 50%;
    will-change: auto;
  }
  #directions-hub .directions-hub__aurora,
  #directions-hub .directions-hub__glow,
  #directions-hub .directions-hub__glow::after {
    -webkit-mask-image: none;
    mask-image: none;
  }
  #hero-dubbing .hero-dubbing__cta,
  #hero-course .hero-dubbing__cta,
  #course-after-audience .course-results__cta,
  #course-pricing .course-pricing__cta--primary,
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--primary,
  #price-services .price-services__cta:not(.price-services__cta--ghost),
  #course-pricing .course-pricing__cta--ghost,
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--ghost,
  #course-pricing .course-pricing__cta--vip,
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--vip,
  #price-services .price-services__cta--ghost,
  #price-services .price-services__action-link {
    transition: none;
  }
  #directions-hub .directions-hub__card,
  #directions-hub .directions-hub__card.is-visible {
    opacity: 1;
    transform: none;
    transition: none;
  }
  #directions-hub .directions-hub__card.is-visible:hover {
    transform: none;
  }
  #directions-hub .directions-hub__card-bg {
    transition: none;
  }
  #directions-hub .directions-hub__card.is-visible:hover .directions-hub__card-bg {
    transform: none;
  }
  #directions-hub .directions-hub__btn {
    transition: none;
  }
  #about-author .about-author__aurora,
  #about-author .about-author__glow,
  #about-author .about-author__glow::after {
    -webkit-mask-image: none;
    mask-image: none;
  }
  #about-author .about-author__reveal.is-visible,
  #about-author .about-author__card.is-visible {
    opacity: 1;
    transform: none;
    transition: none;
  }
  #about-author .about-author__card.is-visible:hover {
    transform: none;
  }
  #about-author .about-author__video-play {
    transition: none;
  }
  #social-proof .social-proof__aurora,
  #social-proof .social-proof__glow,
  #social-proof .social-proof__glow::after {
    -webkit-mask-image: none;
    mask-image: none;
  }
  #social-proof .social-proof__portfolio-card:hover {
    transform: none;
  }
  #social-proof .social-proof__toggle-btn {
    transition: none;
  }
  #course-audience .course-audience__aurora,
  #course-audience .course-audience__glow,
  #course-audience .course-audience__glow::after {
    animation: none;
    -webkit-mask-image: none;
    mask-image: none;
  }
  #course-audience .course-audience__card,
  #course-audience .course-audience__card:hover {
    transform: none;
    transition: none;
  }
  #course-audience .course-audience__photo {
    transition: none;
  }
  #course-audience .course-audience__card:hover .course-audience__photo {
    transform: none;
  }
  #course-after-audience .course-after-audience__aurora,
  #course-after-audience .course-after-audience__glow,
  #course-after-audience .course-after-audience__glow::after {
    animation: none;
    -webkit-mask-image: none;
    mask-image: none;
  }
  #course-after-audience .course-results__card,
  #course-after-audience .course-results__card:hover {
    transform: none;
    transition: none;
  }
  #course-after-audience .cr-wave__layer {
    transition: none;
  }
  #course-after-audience .course-results__toggle-btn {
    transition: none;
  }
  #course-program .course-program__panel {
    transition: none;
  }
  #course-program .course-program__aurora,
  #course-program .course-program__glow,
  #course-program .course-program__glow::after,
  :is(#kids-program, #imx-program) .course-program__aurora,
  :is(#kids-program, #imx-program) .course-program__glow,
  :is(#kids-program, #imx-program) .course-program__glow::after {
    animation: none;
    -webkit-mask-image: none;
    mask-image: none;
  }
  #course-pricing .course-pricing__aurora,
  #course-pricing .course-pricing__glow,
  #course-pricing .course-pricing__glow::after,
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__aurora,
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__glow,
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__glow::after {
    animation: none;
    -webkit-mask-image: none;
    mask-image: none;
  }
  #price-services .price-services__aurora,
  #price-services .price-services__glow,
  #price-services .price-services__glow::after,
  #price-services .price-services__zone-glow {
    animation: none;
    -webkit-mask-image: none;
    mask-image: none;
  }
  #price-services .price-services__cta:not(.price-services__cta--ghost) {
    animation: none;
  }
  #price-services .price-services__action-link {
    animation: none;
  }
  #price-services .price-services__card {
    transition: none;
  }
  #price-services .price-services__card:hover {
    transform: none;
  }
  #course-after-audience .course-results-modal__gifts .price-services__action-link {
    animation: none;
  }
  #course-after-audience .course-results-modal__gifts .price-services__card {
    transition: none;
  }
  #course-after-audience .course-results-modal__gifts .price-services__card:hover {
    transform: none;
  }
  #course-how-learning .course-how-learning__glass,
  #course-how-learning .course-how-learning__illus,
  #course-how-learning .course-how-learning__bg-num {
    transition: none;
  }
  #course-how-learning .course-how-learning__node:hover .course-how-learning__illus {
    transform: none;
    filter: none;
  }
  #course-how-learning .course-how-learning__node:hover .course-how-learning__bg-num {
    transform: translate(-50%, -58%);
    color: rgba(255, 255, 255, 0.045);
  }
  #course-how-learning .course-how-learning__node:hover .course-how-learning__glass {
    background: rgba(255, 255, 255, 0.035);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
  }
  #course-pocket-studio .course-pocket-studio__aurora,
  #course-pocket-studio .course-pocket-studio__glow,
  #course-pocket-studio .course-pocket-studio__glow::after,
  #course-pocket-studio .course-pocket-studio__glow-sheen {
    animation: none;
    -webkit-mask-image: none;
    mask-image: none;
  }
  #course-pocket-studio .course-pocket-studio__neon--a,
  #course-pocket-studio .course-pocket-studio__neon--b,
  #course-pocket-studio .course-pocket-studio__photo-glow,
  #course-pocket-studio .course-pocket-studio__photo-stack,
  #course-pocket-studio .course-pocket-studio__photo-shine {
    animation: none;
  }
  #course-pocket-studio .course-pocket-studio__glass,
  #course-pocket-studio .course-pocket-studio__stat {
    transition: none;
  }
  #course-faq .course-program__trigger,
  #course-faq .course-program__chevron,
  #course-faq .course-program__panel,
  :is(#kids-faq, #imx-faq) .course-program__trigger,
  :is(#kids-faq, #imx-faq) .course-program__chevron,
  :is(#kids-faq, #imx-faq) .course-program__panel {
    transition: none;
  }
  #site-footer .site-footer__logo-link,
  #site-footer .site-footer__phone,
  #site-footer .site-footer__links a,
  #site-footer .site-footer__social-link {
    transition: none;
  }
}

@media (max-width: 900px) {
  #hero-dubbing .hero-dubbing__grid, #hero-course .hero-dubbing__grid {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    padding-bottom: 7rem;
  }

  #hero-dubbing .hero-dubbing__copy, #hero-course .hero-dubbing__copy {
    max-width: 36rem;
    order: 1;
  }

  #hero-dubbing .hero-dubbing__visual, #hero-course .hero-dubbing__visual {
    order: 2;
    padding-top: 0.5rem;
  }

  #hero-dubbing .hero-dubbing__title, #hero-course .hero-dubbing__title {
    gap: 0.4rem;
    align-items: center;
  }

  #hero-dubbing .hero-dubbing__title-kicker, #hero-course .hero-dubbing__title-kicker {
    font-size: clamp(0.6rem, 1.5vw + 0.5rem, 0.72rem);
    letter-spacing: 0.14em;
  }

  #hero-dubbing .hero-dubbing__title-main, #hero-course .hero-dubbing__title-main {
    font-size: clamp(1.45rem, 4.5vw + 0.55rem, 1.95rem);
    line-height: 1.12;
  }

  #hero-dubbing .hero-dubbing__title-main--wow {
    align-items: center;
  }

  #hero-dubbing .hero-dubbing__title-main--wow .hero-dubbing__title-main-line--glow {
    font-size: clamp(1.68rem, 5.2vw + 0.62rem, 2.28rem);
  }

  #hero-dubbing .hero-dubbing__title-line, #hero-course .hero-dubbing__title-line {
    font-size: clamp(0.92rem, 2.4vw + 0.55rem, 1.08rem);
    max-width: 24em;
  }

  #hero-dubbing .hero-dubbing__subtitle, #hero-course .hero-dubbing__subtitle {
    font-size: clamp(0.95rem, 2vw + 0.65rem, 1.05rem);
    margin-bottom: 1.5rem;
  }

  #hero-dubbing .hero-dubbing__facts, #hero-course .hero-dubbing__facts {
    margin-bottom: 1.5rem;
    padding-left: 0;
    padding-top: 1rem;
    border-left: none;
    border-top: 1px solid rgba(0, 255, 209, 0.22);
    max-width: min(28rem, 100%);
    margin-left: auto;
    margin-right: auto;
  }

  #hero-dubbing .hero-dubbing__facts-kicker, #hero-course .hero-dubbing__facts-kicker {
    text-align: center;
  }

  #hero-dubbing .hero-dubbing__facts-list, #hero-course .hero-dubbing__facts-list {
    align-items: center;
    text-align: center;
  }

  #hero-dubbing .hero-dubbing__cta-wrap, #hero-course .hero-dubbing__cta-wrap {
    align-items: center;
  }

  #hero-dubbing .hero-dubbing__parallax, #hero-course .hero-dubbing__parallax {
    max-width: min(280px, 72vw);
  }

  :is(#hero-dubbing, #hero-course) .hero-dubbing__portrait-stage {
    inset: -12% -12% -8%;
  }

  :is(#hero-dubbing, #hero-course) .hero-dubbing__photo-card {
    border-radius: 22px;
  }

  :is(#hero-dubbing, #hero-course) .hero-dubbing__photo {
    border-radius: 16px;
  }

  :is(#hero-dubbing, #hero-course) .hero-dubbing__sound-card {
    padding: 0.56rem 0.68rem;
  }

  :is(#hero-dubbing, #hero-course) .hero-dubbing__sound-card--top {
    left: -4%;
  }

  :is(#hero-dubbing, #hero-course) .hero-dubbing__sound-card--bottom {
    right: -4%;
    bottom: 10%;
  }

  :is(#hero-dubbing, #hero-course) .hero-dubbing__sound-label {
    font-size: 0.58rem;
  }
}

/* --- directions-hub: свой «холодный» неон, мягкий стык с hero (маска сверху + общий базовый тон) --- */

#directions-hub {
  --dh-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --dh-transition: 0.4s var(--dh-ease);

  position: relative;
  background: var(--directions-hub-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  /* Поджимает микро-зазор между секциями в вёрстке */
  margin-top: -1px;
  padding-top: 1px;
}

#directions-hub .directions-hub__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#directions-hub .directions-hub__aurora {
  position: absolute;
  inset: -32% -25% -28% -25%;
  transform-origin: 55% 45%;
  /* Электрик + индиго, без копирования мятной палитры hero */
  background:
    radial-gradient(ellipse 42% 48% at 78% 22%, rgba(64, 196, 255, 0.34), transparent 58%),
    radial-gradient(ellipse 46% 40% at 18% 65%, rgba(120, 140, 255, 0.18), transparent 52%),
    radial-gradient(ellipse 50% 44% at 88% 78%, rgba(0, 170, 255, 0.2), transparent 55%),
    radial-gradient(ellipse 55% 50% at 42% 48%, rgba(40, 80, 160, 0.24), transparent 60%),
    radial-gradient(ellipse 38% 42% at 62% 28%, rgba(90, 220, 255, 0.12), transparent 50%);
  filter: blur(40px);
  animation: directions-hub-aurora 22s ease-in-out infinite alternate;
  animation-delay: -7s;
  /* Сверху декор почти невидим — нет «второго такого же пятна» на стыке с hero */
  /* Сверху и снизу гасим декор — бесшовные стыки с hero и about (как полоса между hero и directions) */
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.45) 12%,
    #000 34%,
    #000 66%,
    rgba(0, 0, 0, 0.5) 82%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.45) 12%,
    #000 34%,
    #000 66%,
    rgba(0, 0, 0, 0.5) 82%,
    transparent 100%
  );
}

#directions-hub .directions-hub__glow {
  position: absolute;
  top: 18%;
  right: -8%;
  left: auto;
  width: min(62vw, 580px);
  height: min(62vw, 580px);
  background: radial-gradient(
    circle,
    rgba(80, 170, 255, 0.26) 0%,
    rgba(40, 100, 200, 0.08) 45%,
    transparent 72%
  );
  filter: blur(68px);
  animation: directions-hub-breath 13s ease-in-out infinite;
  animation-delay: -4s;
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 24%, #000 68%, transparent 100%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 24%, #000 68%, transparent 100%);
}

#directions-hub .directions-hub__glow::after {
  content: "";
  position: absolute;
  left: -55%;
  bottom: -40%;
  right: auto;
  width: min(54vw, 520px);
  height: min(54vw, 520px);
  background: radial-gradient(circle, rgba(100, 90, 220, 0.2) 0%, transparent 68%);
  filter: blur(58px);
  animation: directions-hub-breath 17s ease-in-out infinite reverse;
  animation-delay: -9s;
  opacity: 0.75;
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 28%, #000 65%, transparent 100%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 28%, #000 65%, transparent 100%);
}

#directions-hub .directions-hub__overlay {
  position: absolute;
  inset: 0;
  /* Верх: как от hero; низ: тот же приём, что у hero-dubbing — мягкий «сход» через тёмное к фону about */
  background:
    linear-gradient(
      180deg,
      transparent 0%,
      transparent 48%,
      rgba(6, 6, 14, 0.38) 74%,
      var(--about-author-base) 100%
    ),
    linear-gradient(180deg, var(--directions-hub-base) 0%, rgba(5, 5, 10, 0.92) 14%, transparent 32%),
    radial-gradient(
      ellipse 102% 88% at 50% 58%,
      transparent 0%,
      rgba(5, 5, 10, 0.32) 58%,
      rgba(5, 5, 12, 0.62) 84%,
      transparent 100%
    );
}

#directions-hub .directions-hub__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.5rem, 5vw, 4.5rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.5rem, 5vw, 4.5rem) + clamp(64px, 11vh, 108px));
}

/* Оболочка волны: directions-hub, about-author, course-audience — одна геометрия; stroke задаётся отдельно */
#directions-hub .directions-hub__wave,
#about-author .about-author__wave,
#course-audience .course-audience__wave,
#course-after-audience .course-after-audience__wave,
#course-program .course-program__wave,
:is(#kids-program, #imx-program) .course-program__wave,
#imx-program .kids-landing__wave,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave,
#kids-results .kids-landing__wave,
#imx-audience .kids-landing__wave,
#pco-audience .kids-landing__wave,
#imx-value .kids-landing__wave,
#pco-advantages .kids-landing__wave,
#kids-studio-videos .kids-landing__wave,
#imx-backstage .kids-landing__wave,
#pco-pricing .kids-landing__wave,
#kids-mentor .kids-landing__wave,
:is(#kids-faq, #imx-faq) .kids-landing__wave,
#course-how-learning .course-how-learning__wave,
#course-pocket-studio .course-pocket-studio__wave {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: clamp(72px, 12vh, 120px);
  pointer-events: none;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}

/* Волна над нижним затемнением hero — линия читается на видео/градиенте */
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave {
  z-index: 4;
}

#directions-hub .directions-hub__wave-track,
#about-author .about-author__wave-track,
#course-audience .course-audience__wave-track,
#course-after-audience .course-after-audience__wave-track,
#course-program .course-program__wave-track,
:is(#kids-program, #imx-program) .course-program__wave-track,
#imx-program .kids-landing__wave-track,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-track,
#kids-results .kids-landing__wave-track,
#imx-audience .kids-landing__wave-track,
#pco-audience .kids-landing__wave-track,
#imx-value .kids-landing__wave-track,
#pco-advantages .kids-landing__wave-track,
#kids-studio-videos .kids-landing__wave-track,
#imx-backstage .kids-landing__wave-track,
#pco-pricing .kids-landing__wave-track,
#kids-mentor .kids-landing__wave-track,
:is(#kids-faq, #imx-faq) .kids-landing__wave-track,
#course-how-learning .course-how-learning__wave-track,
#course-pocket-studio .course-pocket-studio__wave-track {
  display: flex;
  width: 200%;
  height: 100%;
  animation: hero-dubbing-wave 26s linear infinite;
}

#about-author .about-author__wave-track,
#course-pocket-studio .course-pocket-studio__wave-track {
  animation-duration: 28s;
}

#course-audience .course-audience__wave-track {
  animation-duration: 27s;
}

#course-after-audience .course-after-audience__wave-track {
  animation-duration: 30s;
}

#course-program .course-program__wave-track,
:is(#kids-program, #imx-program) .course-program__wave-track,
#imx-program .kids-landing__wave-track,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-track,
#kids-results .kids-landing__wave-track,
#imx-audience .kids-landing__wave-track,
#pco-audience .kids-landing__wave-track,
#imx-value .kids-landing__wave-track,
#pco-advantages .kids-landing__wave-track,
#kids-studio-videos .kids-landing__wave-track,
#imx-backstage .kids-landing__wave-track,
#pco-pricing .kids-landing__wave-track,
#kids-mentor .kids-landing__wave-track,
:is(#kids-faq, #imx-faq) .kids-landing__wave-track {
  animation-duration: 31s;
}

#course-how-learning .course-how-learning__wave-track {
  animation-duration: 33s;
}

#directions-hub .directions-hub__wave-svg,
#about-author .about-author__wave-svg,
#course-audience .course-audience__wave-svg,
#course-after-audience .course-after-audience__wave-svg,
#course-program .course-program__wave-svg,
:is(#kids-program, #imx-program) .course-program__wave-svg,
#imx-program .kids-landing__wave-svg,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-svg,
#kids-results .kids-landing__wave-svg,
#imx-audience .kids-landing__wave-svg,
#pco-audience .kids-landing__wave-svg,
#imx-value .kids-landing__wave-svg,
#pco-advantages .kids-landing__wave-svg,
#kids-studio-videos .kids-landing__wave-svg,
#imx-backstage .kids-landing__wave-svg,
#pco-pricing .kids-landing__wave-svg,
#kids-mentor .kids-landing__wave-svg,
:is(#kids-faq, #imx-faq) .kids-landing__wave-svg,
#course-how-learning .course-how-learning__wave-svg,
#course-pocket-studio .course-pocket-studio__wave-svg {
  flex: 0 0 50%;
  width: 50%;
  height: 100%;
  display: block;
}

#directions-hub .directions-hub__wave-line,
#about-author .about-author__wave-line,
#course-audience .course-audience__wave-line,
#course-after-audience .course-after-audience__wave-line,
#course-program .course-program__wave-line,
:is(#kids-program, #imx-program) .course-program__wave-line,
#imx-program .kids-landing__wave-line,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-line,
#kids-results .kids-landing__wave-line,
#imx-audience .kids-landing__wave-line,
#pco-audience .kids-landing__wave-line,
#imx-value .kids-landing__wave-line,
#pco-advantages .kids-landing__wave-line,
#kids-studio-videos .kids-landing__wave-line,
#imx-backstage .kids-landing__wave-line,
#pco-pricing .kids-landing__wave-line,
#kids-mentor .kids-landing__wave-line,
:is(#kids-faq, #imx-faq) .kids-landing__wave-line,
#course-how-learning .course-how-learning__wave-line,
#course-pocket-studio .course-pocket-studio__wave-line {
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
  opacity: 0.5;
}

#directions-hub .directions-hub__wave-line,
#course-audience .course-audience__wave-line,
#course-pocket-studio .course-pocket-studio__wave-line {
  stroke: var(--artvoic-accent);
}

#about-author .about-author__wave-line {
  stroke: var(--artvoic-accent-purple);
}

#directions-hub .directions-hub__wave-line--soft,
#about-author .about-author__wave-line--soft,
#course-audience .course-audience__wave-line--soft,
#course-after-audience .course-after-audience__wave-line--soft,
#course-program .course-program__wave-line--soft,
:is(#kids-program, #imx-program) .course-program__wave-line--soft,
#imx-program .kids-landing__wave-line--soft,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-line--soft,
#kids-results .kids-landing__wave-line--soft,
#imx-audience .kids-landing__wave-line--soft,
#pco-audience .kids-landing__wave-line--soft,
#imx-value .kids-landing__wave-line--soft,
#pco-advantages .kids-landing__wave-line--soft,
#kids-studio-videos .kids-landing__wave-line--soft,
#imx-backstage .kids-landing__wave-line--soft,
#pco-pricing .kids-landing__wave-line--soft,
#kids-mentor .kids-landing__wave-line--soft,
:is(#kids-faq, #imx-faq) .kids-landing__wave-line--soft,
#course-how-learning .course-how-learning__wave-line--soft,
#course-pocket-studio .course-pocket-studio__wave-line--soft {
  stroke-width: 1.15;
  opacity: 0.38;
}

#directions-hub .directions-hub__wave-line--soft,
#course-audience .course-audience__wave-line--soft,
#course-pocket-studio .course-pocket-studio__wave-line--soft {
  stroke: rgba(100, 220, 210, 0.72);
}

#about-author .about-author__wave-line--soft {
  stroke: rgba(180, 170, 255, 0.85);
}

#course-after-audience .course-after-audience__wave-line,
#course-program .course-program__wave-line,
:is(#kids-program, #imx-program) .course-program__wave-line,
#imx-program .kids-landing__wave-line,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-line,
#kids-results .kids-landing__wave-line,
#imx-audience .kids-landing__wave-line,
#pco-audience .kids-landing__wave-line,
#imx-value .kids-landing__wave-line,
#pco-advantages .kids-landing__wave-line,
#kids-studio-videos .kids-landing__wave-line,
#imx-backstage .kids-landing__wave-line,
#pco-pricing .kids-landing__wave-line,
#kids-mentor .kids-landing__wave-line,
:is(#kids-faq, #imx-faq) .kids-landing__wave-line,
#course-how-learning .course-how-learning__wave-line {
  stroke: var(--course-bridge-wave);
}

#course-after-audience .course-after-audience__wave-line--soft,
#course-program .course-program__wave-line--soft,
:is(#kids-program, #imx-program) .course-program__wave-line--soft,
#imx-program .kids-landing__wave-line--soft,
:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-line--soft,
#kids-results .kids-landing__wave-line--soft,
#imx-audience .kids-landing__wave-line--soft,
#pco-audience .kids-landing__wave-line--soft,
#imx-value .kids-landing__wave-line--soft,
#pco-advantages .kids-landing__wave-line--soft,
#kids-studio-videos .kids-landing__wave-line--soft,
#imx-backstage .kids-landing__wave-line--soft,
#pco-pricing .kids-landing__wave-line--soft,
#kids-mentor .kids-landing__wave-line--soft,
:is(#kids-faq, #imx-faq) .kids-landing__wave-line--soft,
#course-how-learning .course-how-learning__wave-line--soft {
  stroke: var(--course-bridge-wave-soft);
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-line {
  opacity: 0.82;
  stroke-width: 2;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave-line--soft {
  opacity: 0.55;
  stroke-width: 1.3;
}

#directions-hub .directions-hub__head {
  margin: 0 0 clamp(1.75rem, 4vw, 2.75rem);
  text-align: center;
}

#directions-hub .directions-hub__kicker {
  display: block;
  margin: 0 0 0.5rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: clamp(0.65rem, 0.42vw + 0.58rem, 0.8rem);
  line-height: 1.4;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#directions-hub .directions-hub__title {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-weight: 700;
  font-size: clamp(1.35rem, 2vw + 0.85rem, 2.15rem);
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-shadow:
    0 0 42px rgba(0, 255, 209, 0.14),
    0 2px 24px rgba(0, 0, 0, 0.85),
    0 0 1px rgba(0, 0, 0, 0.9);
}

#directions-hub .directions-hub__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1rem, 3vw, 1.75rem);
  list-style: none;
  margin: 0;
  padding: 0;
}

#directions-hub .directions-hub__card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: clamp(280px, 38vw, 360px);
  padding: 0;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  background: rgba(20, 20, 30, 0.4);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  text-decoration: none;
  color: inherit;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
  transition:
    transform var(--dh-transition),
    border-color var(--dh-transition),
    box-shadow var(--dh-transition);
  opacity: 0;
  transform: translateY(20px);
}

#directions-hub .directions-hub__card.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition:
    opacity 0.65s var(--dh-ease),
    transform 0.65s var(--dh-ease),
    border-color var(--dh-transition),
    box-shadow var(--dh-transition);
}

#directions-hub .directions-hub__grid > li:nth-child(1) .directions-hub__card.is-visible {
  transition-delay: 0s, 0s, 0s, 0s;
}

#directions-hub .directions-hub__grid > li:nth-child(2) .directions-hub__card.is-visible {
  transition-delay: 0.08s, 0.08s, 0s, 0s;
}

#directions-hub .directions-hub__grid > li:nth-child(3) .directions-hub__card.is-visible {
  transition-delay: 0.16s, 0.16s, 0s, 0s;
}

#directions-hub .directions-hub__grid > li:nth-child(4) .directions-hub__card.is-visible {
  transition-delay: 0.24s, 0.24s, 0s, 0s;
}

#directions-hub .directions-hub__card.is-visible:hover {
  transform: translateY(-10px);
  border-color: var(--artvoic-accent);
  box-shadow: 0 0 15px rgba(0, 255, 209, 0.3), 0 20px 48px rgba(0, 0, 0, 0.45);
}

#directions-hub .directions-hub__card:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 4px;
}

#directions-hub .directions-hub__card-bg-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  border-radius: inherit;
}

#directions-hub .directions-hub__card-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  transform-origin: center center;
  transition: transform var(--dh-transition);
  will-change: transform;
}

#directions-hub .directions-hub__card.is-visible:hover .directions-hub__card-bg {
  transform: scale(1.1);
}

#directions-hub .directions-hub__card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(8, 8, 8, 0.35) 0%,
    rgba(8, 8, 8, 0.72) 45%,
    rgba(5, 5, 8, 0.92) 100%
  );
  pointer-events: none;
}

#directions-hub .directions-hub__card-body {
  position: relative;
  z-index: 1;
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  padding: clamp(1.15rem, 3vw, 1.85rem);
}

#directions-hub .directions-hub__card-title {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-weight: 600;
  font-size: clamp(1rem, 1.1vw + 0.82rem, 1.28rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #fff;
}

#directions-hub .directions-hub__card-text {
  margin: 0;
  font-size: clamp(0.88rem, 0.35vw + 0.8rem, 1.02rem);
  line-height: 1.55;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.85);
  max-width: 42ch;
}

#directions-hub .directions-hub__btn {
  display: inline-flex;
  align-self: flex-start;
  align-items: center;
  justify-content: center;
  margin-top: 0.25rem;
  padding: 0.65rem 1.25rem;
  font-family: var(--artvoic-font-body);
  font-weight: 700;
  font-size: clamp(0.8rem, 0.25vw + 0.76rem, 0.95rem);
  line-height: 1.2;
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-radius: 8px;
  border: none;
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.35), 0 10px 32px rgba(0, 255, 209, 0.12);
  pointer-events: none;
  transition: filter 0.25s ease, box-shadow 0.25s ease;
}

#directions-hub .directions-hub__card.is-visible:hover .directions-hub__btn {
  filter: brightness(1.12);
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.55), 0 14px 40px rgba(0, 255, 209, 0.22);
}

@media (max-width: 768px) {
  #directions-hub .directions-hub__grid {
    grid-template-columns: 1fr;
  }

  #directions-hub .directions-hub__card-body {
    padding: clamp(1rem, 4vw, 1.25rem);
    gap: 0.65rem;
  }

  #directions-hub .directions-hub__btn {
    padding: 0.55rem 1rem;
    font-size: clamp(0.76rem, 2vw + 0.65rem, 0.88rem);
  }

  #directions-hub .directions-hub__card {
    min-height: 260px;
  }
}

/* --- about-author: об авторе — лёгкий тон, видео, карточки работ, лента брендов --- */

#about-author {
  --aa-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --aa-reveal: 0.65s var(--aa-ease);

  position: relative;
  background: var(--about-author-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#about-author .about-author__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#about-author .about-author__aurora {
  position: absolute;
  inset: -32% -24% -28% -24%;
  transform-origin: 40% 55%;
  background:
    radial-gradient(ellipse 52% 40% at 50% 6%, rgba(64, 196, 255, 0.14), transparent 58%),
    radial-gradient(ellipse 48% 44% at 72% 28%, rgba(0, 255, 209, 0.22), transparent 56%),
    radial-gradient(ellipse 50% 46% at 20% 68%, rgba(120, 170, 255, 0.14), transparent 54%),
    radial-gradient(ellipse 54% 40% at 55% 86%, rgba(0, 220, 195, 0.12), transparent 52%),
    radial-gradient(ellipse 62% 52% at 46% 48%, rgba(40, 55, 120, 0.26), transparent 60%);
  filter: blur(46px);
  animation: about-author-aurora 26s ease-in-out infinite alternate;
  animation-delay: -5s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.32) 10%,
    #000 32%,
    #000 68%,
    rgba(0, 0, 0, 0.35) 82%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.32) 10%,
    #000 32%,
    #000 68%,
    rgba(0, 0, 0, 0.35) 82%,
    transparent 100%
  );
}

#about-author .about-author__glow {
  position: absolute;
  top: 18%;
  left: -8%;
  width: min(58vw, 560px);
  height: min(58vw, 560px);
  background: radial-gradient(
    circle,
    rgba(0, 255, 209, 0.26) 0%,
    rgba(0, 255, 209, 0.08) 40%,
    transparent 68%
  );
  filter: blur(76px);
  animation: about-author-breath 16s ease-in-out infinite;
  animation-delay: -3s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.25) 0%,
    #000 34%,
    #000 62%,
    rgba(0, 0, 0, 0.45) 78%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.25) 0%,
    #000 34%,
    #000 62%,
    rgba(0, 0, 0, 0.45) 78%,
    transparent 100%
  );
}

#about-author .about-author__glow::after {
  content: "";
  position: absolute;
  right: -38%;
  top: -22%;
  width: min(52vw, 480px);
  height: min(52vw, 480px);
  background: radial-gradient(circle, rgba(130, 175, 255, 0.22) 0%, rgba(80, 100, 200, 0.06) 45%, transparent 66%);
  filter: blur(64px);
  animation: about-author-breath 19s ease-in-out infinite reverse;
  animation-delay: -8s;
  opacity: 1;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 32%,
    #000 58%,
    rgba(0, 0, 0, 0.4) 76%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 32%,
    #000 58%,
    rgba(0, 0, 0, 0.4) 76%,
    transparent 100%
  );
}

#about-author .about-author__overlay {
  position: absolute;
  inset: 0;
  background:
    /* Верх: продолжение directions через тот же базовый тёмный, затем тон секции — без шва */
    linear-gradient(
      180deg,
      var(--directions-hub-base) 0%,
      var(--about-author-base) 12%,
      rgba(6, 7, 16, 0.55) 20%,
      transparent 34%
    ),
    radial-gradient(
      ellipse 100% 84% at 50% 52%,
      transparent 0%,
      rgba(6, 6, 14, 0.22) 48%,
      rgba(6, 8, 22, 0.45) 72%,
      rgba(6, 6, 18, 0.55) 82%,
      rgba(7, 8, 20, 0.88) 92%,
      var(--social-proof-base) 100%
    );
}

#about-author .about-author__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.25rem, 4.5vw, 4rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.75rem, 5vw, 4.5rem) + clamp(64px, 11vh, 108px));
}

#about-author .about-author__head {
  text-align: center;
  max-width: 44rem;
  margin: 0 auto clamp(1.75rem, 3.5vw, 2.5rem);
}

#about-author .about-author__reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity var(--aa-reveal), transform var(--aa-reveal);
}

#about-author .about-author__reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

#about-author .about-author__title {
  margin: 0 0 0.45rem;
  font-family: var(--artvoic-font-display);
  font-weight: 700;
  font-size: clamp(1.65rem, 2.2vw + 0.95rem, 2.65rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-shadow:
    0 0 36px rgba(0, 255, 209, 0.1),
    0 2px 20px rgba(0, 0, 0, 0.75);
}

#about-author .about-author__tagline {
  margin: 0 0 1rem;
  font-family: var(--artvoic-font-display);
  font-weight: 500;
  font-size: clamp(0.95rem, 0.9vw + 0.72rem, 1.22rem);
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: var(--artvoic-text-soft);
}

#about-author .about-author__lead {
  margin: 0;
  font-size: clamp(0.92rem, 0.35vw + 0.82rem, 1.02rem);
  line-height: 1.65;
  font-weight: 400;
  color: var(--artvoic-text-muted);
}

#about-author .about-author__video-wrap {
  max-width: 800px;
  margin: 0 auto clamp(2rem, 4vw, 2.75rem);
}

#about-author .about-author__video-reveal {
  transition-delay: 0.06s;
}

#about-author .about-author__video-box {
  position: relative;
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.4);
  background: rgba(12, 12, 20, 0.65);
  aspect-ratio: 16 / 9;
}

#about-author .about-author__video-box video {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
  object-fit: contain;
  background: #0a0a10;
}

#about-author .about-author__video-poster {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: center;
  padding: 0;
  margin: 0;
  border: none;
  cursor: pointer;
  background: transparent;
  color: inherit;
  font: inherit;
  -webkit-appearance: none;
  appearance: none;
}

#about-author .about-author__video-poster.is-hidden {
  display: none;
}

#about-author .about-author__video-poster-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#about-author .about-author__video-poster-shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5, 5, 12, 0.35) 0%, rgba(5, 5, 14, 0.55) 100%);
  pointer-events: none;
}

#about-author .about-author__video-play {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(3.5rem, 8vw, 4.5rem);
  height: clamp(3.5rem, 8vw, 4.5rem);
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.5);
  background: rgba(0, 255, 209, 0.22);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.35),
    0 12px 40px rgba(0, 0, 0, 0.45);
  color: var(--artvoic-text);
  transition:
    transform 0.25s var(--aa-ease),
    background 0.25s ease,
    border-color 0.25s ease,
    box-shadow 0.25s ease;
}

#about-author .about-author__video-play::before {
  content: "";
  width: 0;
  height: 0;
  margin-left: 4px;
  border-style: solid;
  border-width: 0.55em 0 0.55em 0.9em;
  border-color: transparent transparent transparent currentColor;
}

#about-author .about-author__video-poster:hover .about-author__video-play,
#about-author .about-author__video-poster:focus-visible .about-author__video-play {
  transform: scale(1.06);
  background: rgba(0, 255, 209, 0.35);
  border-color: var(--artvoic-accent);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.5),
    0 16px 48px rgba(0, 255, 209, 0.15);
}

#about-author .about-author__video-poster:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 4px;
}

#about-author .about-author__video-caption {
  margin: 0.65rem 0 0;
  text-align: center;
  font-size: clamp(0.72rem, 0.2vw + 0.68rem, 0.82rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
}

#about-author .about-author__section-title {
  margin: 0 0 clamp(1.25rem, 2.5vw, 1.65rem);
  font-family: var(--artvoic-font-display);
  font-weight: 600;
  font-size: clamp(1.15rem, 1.4vw + 0.82rem, 1.55rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-align: center;
  text-shadow: 0 0 28px rgba(0, 255, 209, 0.08);
}

#about-author .about-author__works-head-reveal {
  transition-delay: 0.08s;
}

#about-author .about-author__cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.75rem, 1.5vw, 1.15rem);
  list-style: none;
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
  padding: 0;
}

#about-author .about-author__card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: clamp(1rem, 2.2vw, 1.35rem);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(18, 18, 28, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 6px 28px rgba(0, 0, 0, 0.28);
  transition:
    opacity 0.65s var(--aa-ease),
    transform 0.65s var(--aa-ease),
    border-color 0.4s var(--aa-ease),
    box-shadow 0.4s var(--aa-ease);
  opacity: 0;
  transform: translateY(20px);
}

#about-author .about-author__card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

#about-author .about-author__cards > li:nth-child(1) .about-author__card.is-visible {
  transition-delay: 0s, 0s, 0s, 0s;
}
#about-author .about-author__cards > li:nth-child(2) .about-author__card.is-visible {
  transition-delay: 0.06s, 0.06s, 0s, 0s;
}
#about-author .about-author__cards > li:nth-child(3) .about-author__card.is-visible {
  transition-delay: 0.12s, 0.12s, 0s, 0s;
}
#about-author .about-author__cards > li:nth-child(4) .about-author__card.is-visible {
  transition-delay: 0.18s, 0.18s, 0s, 0s;
}

#about-author .about-author__card.is-visible:hover {
  transform: translateY(-6px);
  border-color: rgba(0, 255, 209, 0.35);
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.12), 0 14px 40px rgba(0, 0, 0, 0.38);
}

#about-author .about-author__card-icon {
  font-size: 1.35rem;
  line-height: 1;
  margin-bottom: 0.5rem;
  display: block;
}

#about-author .about-author__card-title {
  margin: 0 0 0.65rem;
  font-family: var(--artvoic-font-display);
  font-weight: 600;
  font-size: clamp(0.88rem, 0.5vw + 0.78rem, 1.05rem);
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
}

#about-author .about-author__card-list {
  margin: 0;
  padding: 0 0 0 1.05rem;
  list-style: disc;
  font-size: clamp(0.78rem, 0.22vw + 0.72rem, 0.88rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.78);
}

#about-author .about-author__card-list li {
  margin-bottom: 0.35em;
}

#about-author .about-author__card-list li:last-child {
  margin-bottom: 0;
}

#about-author .about-author__brands {
  margin-top: clamp(0.25rem, 1vw, 0.5rem);
  padding: clamp(0.65rem, 1.5vw, 0.85rem) 0;
  border-radius: 14px;
  border: 1px solid rgba(0, 255, 209, 0.12);
  background: linear-gradient(180deg, rgba(12, 14, 28, 0.65) 0%, rgba(8, 9, 20, 0.4) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 12px 40px rgba(0, 0, 0, 0.35);
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

#about-author .about-author__marquee {
  width: 100%;
  min-height: clamp(44px, 8vw, 64px);
}

#about-author .about-author__marquee-track {
  display: flex;
  width: max-content;
  align-items: center;
  animation: about-author-marquee 52s linear infinite;
  will-change: transform;
}

#about-author .about-author__marquee-group {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  gap: clamp(2rem, 5vw, 3.75rem);
  padding: 0 clamp(1.25rem, 3vw, 2rem);
}

#about-author .about-author__marquee-item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.88;
}

#about-author .about-author__marquee-item img {
  display: block;
  height: clamp(32px, 5vw, 52px);
  width: auto;
  max-width: min(180px, 38vw);
  object-fit: contain;
  object-position: center;
  filter: grayscale(0.15) brightness(1.08) contrast(1.02);
  transition: filter 0.4s var(--aa-ease), opacity 0.4s var(--aa-ease);
}

#about-author .about-author__brands:hover .about-author__marquee-item img {
  filter: grayscale(0) brightness(1.12) contrast(1.03);
  opacity: 1;
}

@media (max-width: 1099px) {
  #about-author .about-author__cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  #about-author .about-author__cards {
    grid-template-columns: 1fr;
  }

  #about-author .about-author__card.is-visible:hover {
    transform: translateY(0);
  }

  #about-author .about-author__marquee-group {
    gap: clamp(1.35rem, 6vw, 2.25rem);
  }
}

/* --- social-proof: социальное доказательство — портфолио до/после, отзывы, цифры, логотипы --- */

#social-proof {
  --sp-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --sp-portfolio-accent: var(--artvoic-accent-purple);
  --sp-card-bg: #1a1a1a;
  --sp-card-border: #2a2a2a;

  position: relative;
  background: var(--social-proof-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#social-proof .social-proof__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* Фон — те же слои и значения, что у #about-author (aurora / glow / overlay), анимации те же */
#social-proof .social-proof__aurora {
  position: absolute;
  inset: -32% -24% -28% -24%;
  transform-origin: 40% 55%;
  background:
    radial-gradient(ellipse 52% 40% at 50% 6%, rgba(64, 196, 255, 0.14), transparent 58%),
    radial-gradient(ellipse 48% 44% at 72% 28%, rgba(0, 255, 209, 0.22), transparent 56%),
    radial-gradient(ellipse 50% 46% at 20% 68%, rgba(120, 170, 255, 0.14), transparent 54%),
    radial-gradient(ellipse 54% 40% at 55% 86%, rgba(0, 220, 195, 0.12), transparent 52%),
    radial-gradient(ellipse 62% 52% at 46% 48%, rgba(40, 55, 120, 0.26), transparent 60%);
  filter: blur(46px);
  animation: about-author-aurora 26s ease-in-out infinite alternate;
  animation-delay: -5s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.32) 10%,
    #000 32%,
    #000 68%,
    rgba(0, 0, 0, 0.35) 82%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.32) 10%,
    #000 32%,
    #000 68%,
    rgba(0, 0, 0, 0.35) 82%,
    transparent 100%
  );
}

#social-proof .social-proof__glow {
  position: absolute;
  top: 18%;
  left: -8%;
  width: min(58vw, 560px);
  height: min(58vw, 560px);
  background: radial-gradient(
    circle,
    rgba(0, 255, 209, 0.26) 0%,
    rgba(0, 255, 209, 0.08) 40%,
    transparent 68%
  );
  filter: blur(76px);
  animation: about-author-breath 16s ease-in-out infinite;
  animation-delay: -3s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.25) 0%,
    #000 34%,
    #000 62%,
    rgba(0, 0, 0, 0.45) 78%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.25) 0%,
    #000 34%,
    #000 62%,
    rgba(0, 0, 0, 0.45) 78%,
    transparent 100%
  );
}

#social-proof .social-proof__glow::after {
  content: "";
  position: absolute;
  right: -38%;
  top: -22%;
  width: min(52vw, 480px);
  height: min(52vw, 480px);
  background: radial-gradient(circle, rgba(130, 175, 255, 0.22) 0%, rgba(80, 100, 200, 0.06) 45%, transparent 66%);
  filter: blur(64px);
  animation: about-author-breath 19s ease-in-out infinite reverse;
  animation-delay: -8s;
  opacity: 1;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 32%,
    #000 58%,
    rgba(0, 0, 0, 0.4) 76%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 32%,
    #000 58%,
    rgba(0, 0, 0, 0.4) 76%,
    transparent 100%
  );
}

/* Верх: стык с «об авторе»; низ: тот же radial, что в about-author__overlay (финал — база секции) */
#social-proof .social-proof__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      var(--about-author-base) 0%,
      var(--social-proof-base) 12%,
      rgba(12, 12, 26, 0.55) 20%,
      transparent 34%
    ),
    radial-gradient(
      ellipse 100% 84% at 50% 52%,
      transparent 0%,
      rgba(6, 6, 14, 0.22) 48%,
      rgba(6, 8, 22, 0.45) 72%,
      rgba(6, 6, 18, 0.55) 82%,
      rgba(7, 8, 20, 0.88) 92%,
      var(--social-proof-base) 100%
    );
}

#social-proof .social-proof__inner {
  position: relative;
  z-index: 2;
  /* BFC: отступы дочерних блоков не схлопываются с краями и с соседней секцией — без «влезания» под about-author */
  display: flow-root;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.25rem, 4.5vw, 4rem) clamp(1.25rem, 5vw, 5rem)
    clamp(2.5rem, 5vw, 4.5rem);
}

#social-proof .social-proof__head {
  margin: 0 0 clamp(0.35rem, 1.5vw, 0.65rem);
  text-align: center;
}

#social-proof .social-proof__kicker {
  display: block;
  margin: 0 0 0.5rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: clamp(0.65rem, 0.42vw + 0.58rem, 0.8rem);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sp-portfolio-accent);
}

#social-proof .social-proof__kicker--muted {
  color: var(--artvoic-accent);
}

#social-proof .social-proof__title-main {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-weight: 700;
  font-size: clamp(1.25rem, 1.8vw + 0.75rem, 2rem);
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-shadow:
    0 0 40px rgba(108, 99, 255, 0.12),
    0 2px 24px rgba(0, 0, 0, 0.85);
}

#social-proof .social-proof__title-sub {
  margin: 0.65rem 0 0;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(0.88rem, 0.35vw + 0.78rem, 0.98rem);
  line-height: 1.6;
  color: var(--artvoic-text-muted);
}

#social-proof .social-proof__portfolio {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.35rem);
  /* Тема: ol, ul { margin: 0 0 1.5em 3em } — задаём все стороны явно (трёхзначный shorthand не обязателен) */
  margin-top: clamp(1.75rem, 3.5vw, 2.5rem);
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  list-style: none;
  padding: 0;
}

#social-proof .social-proof__portfolio > li {
  float: none;
}

#social-proof .social-proof__portfolio-card {
  display: flex;
  flex-direction: column;
  padding: clamp(1.1rem, 2vw, 1.35rem);
  border-radius: 16px;
  border: 1px solid var(--sp-card-border);
  background: var(--sp-card-bg);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
  transition:
    transform 0.35s var(--sp-ease),
    border-color 0.35s var(--sp-ease),
    box-shadow 0.35s var(--sp-ease);
}

#social-proof .social-proof__portfolio-card:hover {
  transform: translateY(-4px);
  border-color: rgba(108, 99, 255, 0.45);
  box-shadow:
    0 0 0 1px rgba(108, 99, 255, 0.12),
    0 20px 48px rgba(0, 0, 0, 0.45);
}

#social-proof .social-proof__card-name {
  margin: 0 0 0.25rem;
  font-family: var(--artvoic-font-display);
  font-weight: 600;
  font-size: clamp(1rem, 0.8vw + 0.82rem, 1.2rem);
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
}

#social-proof .social-proof__card-skill {
  margin: 0 0 1rem;
  font-size: clamp(0.8rem, 0.25vw + 0.74rem, 0.88rem);
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.4;
}

#social-proof .social-proof__wave-wrap {
  position: relative;
  height: clamp(52px, 10vw, 72px);
  margin-bottom: 1rem;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

#social-proof .sp-wave {
  position: absolute;
  inset: 0;
  padding: 10px clamp(10px, 2vw, 14px);
  box-sizing: border-box;
}

#social-proof .sp-wave__layer {
  position: absolute;
  left: clamp(10px, 2vw, 14px);
  right: clamp(10px, 2vw, 14px);
  top: 10px;
  bottom: 10px;
  display: flex;
  align-items: center;
  gap: 3px;
  pointer-events: none;
  transition: opacity 0.45s var(--sp-ease);
}

#social-proof .sp-wave__layer--before {
  opacity: 1;
}

#social-proof .sp-wave__layer--after {
  opacity: 0;
}

#social-proof .social-proof__portfolio-card.is-after .sp-wave__layer--before {
  opacity: 0;
}

#social-proof .social-proof__portfolio-card.is-after .sp-wave__layer--after {
  opacity: 1;
}

#social-proof .sp-wave__layer span {
  flex: 1 1 auto;
  align-self: center;
  min-width: 2px;
  height: var(--h, 40%);
  min-height: 5px;
  border-radius: 2px;
  background: linear-gradient(
    180deg,
    rgba(108, 99, 255, 0.95) 0%,
    rgba(108, 99, 255, 0.35) 55%,
    rgba(108, 99, 255, 0.15) 100%
  );
  box-shadow: 0 0 12px rgba(108, 99, 255, 0.15);
}

#social-proof .social-proof__toggle {
  display: flex;
  margin-top: auto;
  padding: 3px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.08);
  gap: 2px;
}

#social-proof .social-proof__toggle-btn {
  flex: 1;
  margin: 0;
  padding: 0.5rem 0.65rem;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: clamp(0.68rem, 0.2vw + 0.64rem, 0.78rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  background: transparent;
  transition:
    background 0.3s var(--sp-ease),
    color 0.3s var(--sp-ease),
    box-shadow 0.3s var(--sp-ease);
}

#social-proof .social-proof__toggle-btn:hover {
  color: rgba(255, 255, 255, 0.82);
}

#social-proof .social-proof__toggle-btn.is-active {
  color: #0a0a12;
  background: var(--sp-portfolio-accent);
  box-shadow: 0 0 20px rgba(108, 99, 255, 0.35);
}

#social-proof .social-proof__toggle-btn:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}

#social-proof .social-proof__cta-wrap {
  display: flex;
  justify-content: center;
  padding-block: 64px;
}

#social-proof .social-proof__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.95rem 1.85rem;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: clamp(0.82rem, 0.35vw + 0.72rem, 0.95rem);
  letter-spacing: 0.02em;
  text-decoration: none;
  color: #050505;
  background: var(--artvoic-accent);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.35),
    0 14px 40px rgba(0, 255, 209, 0.2);
  transition:
    transform 0.25s var(--sp-ease),
    box-shadow 0.25s ease,
    filter 0.25s ease;
}

#social-proof .social-proof__cta:hover {
  transform: translateY(-2px);
  filter: brightness(1.06);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.5),
    0 18px 48px rgba(0, 255, 209, 0.28);
}

#social-proof .social-proof__cta:focus-visible {
  outline: 2px solid var(--artvoic-text);
  outline-offset: 4px;
}

#social-proof .social-proof__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 3vw, 2rem);
  margin: 0;
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(12, 12, 22, 0.45);
  text-align: center;
}

#social-proof .social-proof__stat-val {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-weight: 700;
  font-size: 48px;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-shadow: 0 0 32px rgba(0, 255, 209, 0.12);
}

#social-proof .social-proof__stat-label {
  margin: 0.45rem 0 0;
  font-size: 14px;
  line-height: 1.45;
  color: var(--artvoic-text-muted);
}

#social-proof .social-proof__videos-head {
  margin: 0 0 clamp(1.25rem, 2.5vw, 1.65rem);
}

#social-proof .social-proof__videos {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.85rem, 1.8vw, 1.15rem);
  list-style: none;
  margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
  padding: 0;
  max-width: min(880px, 100%);
  margin-left: auto;
  margin-right: auto;
}

#social-proof .social-proof__video-card {
  margin: 0;
}

#social-proof .social-proof__video-open {
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  border: none;
  background: none;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  border-radius: 14px;
  overflow: hidden;
  transition: transform 0.3s var(--sp-ease);
}

#social-proof .social-proof__video-open:hover {
  transform: translateY(-3px);
}

#social-proof .social-proof__video-open:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#social-proof .social-proof__video-thumb {
  position: relative;
  aspect-ratio: 16 / 10;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: #12121a;
}

#social-proof .social-proof__video-thumb img,
#social-proof .social-proof__video-thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

#social-proof .social-proof__video-thumb video {
  pointer-events: none;
}

#social-proof .social-proof__video-shade {
  position: absolute;
  inset: 0;
  background: rgba(5, 5, 12, 0.6);
  pointer-events: none;
  transition: background 0.3s ease;
}

#social-proof .social-proof__video-open:hover .social-proof__video-shade {
  background: rgba(5, 5, 12, 0.45);
}

#social-proof .social-proof__video-play-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

#social-proof .social-proof__video-play-icon::before {
  content: "";
  width: clamp(2.75rem, 6vw, 3.5rem);
  height: clamp(2.75rem, 6vw, 3.5rem);
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.55);
  background: rgba(0, 255, 209, 0.22);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.35),
    0 10px 32px rgba(0, 0, 0, 0.4);
}

#social-proof .social-proof__video-play-icon::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  margin-left: 5px;
  border-style: solid;
  border-width: 0.5em 0 0.5em 0.85em;
  border-color: transparent transparent transparent var(--artvoic-text);
}

#social-proof .social-proof__video-meta {
  margin-top: 0.65rem;
}

#social-proof .social-proof__video-name {
  margin: 0;
  font-weight: 600;
  font-size: clamp(0.85rem, 0.28vw + 0.76rem, 0.92rem);
  color: var(--artvoic-text);
}

#social-proof .social-proof__video-quote {
  margin: 0.3rem 0 0;
  font-size: clamp(0.78rem, 0.2vw + 0.72rem, 0.85rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.58);
}

#social-proof .social-proof__modal {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: grid;
  place-items: center;
  padding: 1.25rem;
  box-sizing: border-box;
}

#social-proof .social-proof__modal[hidden] {
  display: none;
}

#social-proof .social-proof__modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 2, 8, 0.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

#social-proof .social-proof__modal-dialog {
  position: relative;
  z-index: 1;
  width: min(960px, 100%);
  max-height: min(90vh, 900px);
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 16px;
  background: #0c0c14;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.1),
    0 28px 80px rgba(0, 0, 0, 0.65);
  overflow: hidden;
}

#social-proof .social-proof__modal-top {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0.5rem 0.65rem 0;
}

#social-proof .social-proof__modal-close {
  margin: 0;
  padding: 0.4rem 0.75rem;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-family: var(--artvoic-font-body);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.08);
  transition: background 0.2s ease;
}

#social-proof .social-proof__modal-close:hover {
  background: rgba(255, 255, 255, 0.14);
}

#social-proof .social-proof__modal-close:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}

#social-proof .social-proof__modal-embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
}

#social-proof .social-proof__modal-embed iframe,
#social-proof .social-proof__modal-embed .social-proof__modal-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

#social-proof .social-proof__modal-embed .social-proof__modal-video {
  object-fit: contain;
  background: #000;
}

#social-proof .social-proof__modal-title {
  margin: 0;
  padding: 0 1rem 1rem;
  font-size: 0.88rem;
  color: var(--artvoic-text-muted);
}

#social-proof .social-proof__audit-anchor {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Elementor: у секции/контейнера не должно оставаться лишнего padding/margin под HTML-виджетом */
.elementor-section:has(#social-proof),
.e-con:has(#social-proof) {
  margin-bottom: 0;
  padding-bottom: 0;
}

@media (max-width: 991px) {
  #social-proof .social-proof__videos {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  #social-proof .social-proof__portfolio {
    grid-template-columns: 1fr;
  }

  #social-proof .social-proof__portfolio-card:hover {
    transform: none;
  }

  #social-proof .social-proof__wave-wrap {
    height: clamp(44px, 14vw, 56px);
  }

  #social-proof .social-proof__stats {
    grid-template-columns: 1fr;
    text-align: center;
  }

  #social-proof .social-proof__stat-val {
    font-size: clamp(2rem, 10vw + 1rem, 48px);
  }

  #social-proof .social-proof__videos {
    grid-template-columns: 1fr;
  }

  #social-proof .social-proof__video-open:hover {
    transform: none;
  }
}

/* --- course-audience: лендинг курса — «Узнай себя», 3 типа учеников (якорь #course-audience) --- */

@keyframes course-audience-aurora {
  0% {
    transform: translate3d(-1.5%, 0.5%, 0) scale(1);
  }
  100% {
    transform: translate3d(1.8%, -0.8%, 0) scale(1.025);
  }
}

@keyframes course-audience-breath {
  0%,
  100% {
    opacity: 0.55;
    transform: scale(1);
  }
  50% {
    opacity: 0.72;
    transform: scale(1.04);
  }
}

#course-audience {
  --ca-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ca-card: 0.4s var(--ca-ease);

  position: relative;
  background: var(--course-audience-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#course-audience .course-audience__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#course-audience .course-audience__aurora {
  position: absolute;
  inset: -30% -22% -26% -22%;
  transform-origin: 45% 40%;
  background:
    radial-gradient(ellipse 50% 42% at 38% 12%, rgba(0, 255, 209, 0.14), transparent 55%),
    radial-gradient(ellipse 46% 48% at 78% 32%, rgba(108, 99, 255, 0.2), transparent 54%),
    radial-gradient(ellipse 52% 44% at 18% 72%, rgba(0, 200, 255, 0.1), transparent 52%),
    radial-gradient(ellipse 56% 42% at 58% 82%, rgba(0, 255, 209, 0.08), transparent 50%),
    radial-gradient(ellipse 58% 50% at 50% 50%, rgba(30, 40, 90, 0.28), transparent 62%);
  filter: blur(48px);
  animation: course-audience-aurora 24s ease-in-out infinite alternate;
  animation-delay: -4s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.3) 8%,
    #000 28%,
    #000 72%,
    rgba(0, 0, 0, 0.35) 88%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.3) 8%,
    #000 28%,
    #000 72%,
    rgba(0, 0, 0, 0.35) 88%,
    transparent 100%
  );
}

#course-audience .course-audience__glow {
  position: absolute;
  top: 22%;
  right: -6%;
  width: min(52vw, 500px);
  height: min(52vw, 500px);
  background: radial-gradient(
    circle,
    rgba(0, 255, 209, 0.2) 0%,
    rgba(108, 99, 255, 0.1) 42%,
    transparent 68%
  );
  filter: blur(72px);
  animation: course-audience-breath 15s ease-in-out infinite;
  animation-delay: -2s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 36%,
    #000 62%,
    rgba(0, 0, 0, 0.4) 78%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 36%,
    #000 62%,
    rgba(0, 0, 0, 0.4) 78%,
    transparent 100%
  );
}

#course-audience .course-audience__glow::after {
  content: "";
  position: absolute;
  left: -55%;
  bottom: -18%;
  width: min(48vw, 440px);
  height: min(48vw, 440px);
  background: radial-gradient(circle, rgba(130, 175, 255, 0.16) 0%, rgba(60, 80, 160, 0.06) 48%, transparent 66%);
  filter: blur(60px);
  animation: course-audience-breath 18s ease-in-out infinite reverse;
  animation-delay: -7s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.18) 0%,
    #000 34%,
    #000 58%,
    rgba(0, 0, 0, 0.38) 74%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.18) 0%,
    #000 34%,
    #000 58%,
    rgba(0, 0, 0, 0.38) 74%,
    transparent 100%
  );
}

#course-audience .course-audience__overlay {
  position: absolute;
  inset: 0;
  /* Слои снизу вверх: атмосфера → низ (стык с #course-after-audience) → верх (стык с низом hero-course, тот же #050508 что и полоса под волной) */
  background:
    linear-gradient(
      180deg,
      var(--directions-hub-base) 0%,
      var(--course-audience-base) 14%,
      rgba(8, 9, 28, 0.65) 22%,
      transparent 38%
    ),
    linear-gradient(
      180deg,
      transparent 0%,
      transparent 56%,
      rgba(7, 8, 23, 0.42) 80%,
      var(--course-after-audience-base) 100%
    ),
    radial-gradient(
      ellipse 100% 84% at 50% 46%,
      transparent 0%,
      rgba(8, 9, 28, 0.22) 44%,
      rgba(6, 8, 22, 0.45) 70%,
      var(--course-audience-base) 100%
    );
}

#course-audience .course-audience__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.5rem, 5vw, 4.25rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(3rem, 6vw, 4.75rem) + clamp(64px, 11vh, 108px));
}

#course-audience .course-audience__head {
  text-align: center;
  max-width: 40rem;
  margin: 0 auto clamp(2rem, 4vw, 2.75rem);
}

#course-audience .course-audience__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#course-audience .course-audience__title {
  margin: 0 0 0.85rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 24px rgba(0, 0, 0, 0.35);
}

#course-audience .course-audience__intro {
  margin: 0 0 0.65rem;
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-audience .course-audience__intro-q {
  color: var(--artvoic-text-soft);
  font-weight: 600;
}

#course-audience .course-audience__note {
  margin: 0;
  font-size: clamp(0.78rem, 0.35vw + 0.72rem, 0.88rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.55);
}

#course-audience .course-audience__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.1rem, 2.8vw, 1.65rem);
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: stretch;
}

#course-audience .course-audience__card {
  height: 100%;
  display: flex;
  flex-direction: column;
  border-radius: 1.1rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(
    165deg,
    rgba(255, 255, 255, 0.07) 0%,
    rgba(12, 14, 32, 0.65) 42%,
    rgba(6, 8, 22, 0.88) 100%
  );
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  overflow: hidden;
  transition:
    transform var(--ca-card),
    border-color var(--ca-card),
    box-shadow var(--ca-card);
}

#course-audience .course-audience__card:hover {
  transform: translateY(-8px);
  border-color: rgba(0, 255, 209, 0.32);
  box-shadow:
    0 28px 56px rgba(0, 0, 0, 0.5),
    0 0 0 1px rgba(0, 255, 209, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

#course-audience .course-audience__card-top {
  position: relative;
  display: grid;
  gap: 0;
}

#course-audience .course-audience__icon {
  position: absolute;
  top: 0.85rem;
  left: 0.85rem;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(3.5rem, 7.5vw, 4.6rem);
  height: clamp(3.5rem, 7.5vw, 4.6rem);
  border-radius: 0.95rem;
  color: var(--course-audience-base);
  background: linear-gradient(145deg, rgba(0, 255, 209, 0.95) 0%, rgba(0, 220, 185, 0.88) 100%);
  box-shadow:
    0 8px 28px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.12) inset;
}

#course-audience .course-audience__icon--mask {
  background: linear-gradient(145deg, rgba(108, 99, 255, 0.95) 0%, rgba(0, 255, 209, 0.75) 100%);
}

#course-audience .course-audience__icon-svg {
  width: 58%;
  height: 58%;
  object-fit: contain;
  display: block;
}

#course-audience .course-audience__icon--mask .course-audience__icon-svg {
  width: 54%;
  height: 54%;
}

#course-audience .course-audience__photo-wrap {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #0a0c18;
}

#course-audience .course-audience__photo-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8, 9, 28, 0.15) 0%, rgba(8, 9, 28, 0.65) 100%);
  pointer-events: none;
}

#course-audience .course-audience__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1);
  transition: transform 0.55s var(--ca-ease);
}

#course-audience .course-audience__card:hover .course-audience__photo {
  transform: scale(1.06);
}

#course-audience .course-audience__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: clamp(1rem, 2.2vw, 1.35rem) clamp(1rem, 2.5vw, 1.35rem) clamp(1.15rem, 2.5vw, 1.45rem);
}

#course-audience .course-audience__card-title {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-weight: 700;
  font-size: clamp(1.05rem, 0.75vw + 0.88rem, 1.28rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
}

#course-audience .course-audience__lead {
  margin: 0;
  font-size: clamp(0.86rem, 0.35vw + 0.78rem, 0.95rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-audience .course-audience__dl {
  margin: 0.15rem 0 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

#course-audience .course-audience__di {
  margin: 0;
}

#course-audience .course-audience__di dt {
  margin: 0 0 0.2rem;
  font-size: clamp(0.68rem, 0.2vw + 0.64rem, 0.74rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#course-audience .course-audience__di dd {
  margin: 0;
  font-size: clamp(0.82rem, 0.28vw + 0.76rem, 0.9rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.78);
}

#course-audience .course-audience__blocker {
  margin: auto 0 0;
  padding-top: 0.75rem;
  margin-top: 0.35rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  font-size: clamp(0.8rem, 0.25vw + 0.74rem, 0.88rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.72);
}

#course-audience .course-audience__blocker span {
  display: inline;
  font-weight: 600;
  color: var(--artvoic-accent-purple);
}

#course-audience .course-audience__blocker span::after {
  content: ":";
  font-weight: 600;
}

@media (max-width: 900px) {
  #course-audience .course-audience__grid {
    grid-template-columns: 1fr;
    max-width: 32rem;
    margin: 0 auto;
  }

  #course-audience .course-audience__card:hover {
    transform: none;
  }

  #course-audience .course-audience__card:hover .course-audience__photo {
    transform: none;
  }
}

@media (max-width: 768px) {
  #course-audience .course-audience__head {
    text-align: left;
  }

  #course-audience .course-audience__wave {
    height: clamp(48px, 11vw, 76px);
  }

  #course-after-audience .course-after-audience__wave,
  #course-program .course-program__wave,
  #imx-program .kids-landing__wave,
  :is(#intensivkids-hero, #intensivkids-about, #intensivkids-program, #intensivkids-moments, #intensiv-msk-hero, #intensiv-msk-about, #intensiv-msk-guest, #intensiv-msk-program, #intensiv-msk-how, #intensiv-msk-moments) .kids-landing__wave,
  #course-how-learning .course-how-learning__wave {
    height: clamp(48px, 11vw, 76px);
  }
}

/* Elementor: без лишней «ступеньки» под виджетом */
.elementor-section:has(#course-audience),
.e-con:has(#course-audience) {
  margin-bottom: 0;
  padding-bottom: 0;
}

/* --- course-after-audience: результаты обучения + до/после — стык с низом #course-audience / волной --- */

@keyframes course-after-aurora {
  0% {
    transform: translate3d(1.2%, -0.4%, 0) scale(1);
  }
  100% {
    transform: translate3d(-1.4%, 1%, 0) scale(1.03);
  }
}

@keyframes course-after-breath {
  0%,
  100% {
    opacity: 0.48;
    transform: scale(1);
  }
  50% {
    opacity: 0.66;
    transform: scale(1.05);
  }
}

#course-after-audience {
  --cr-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --cr-card: 0.4s var(--cr-ease);

  position: relative;
  background: var(--course-after-audience-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#course-after-audience .course-after-audience__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#course-after-audience .course-after-audience__aurora {
  position: absolute;
  inset: -28% -20% -24% -20%;
  transform-origin: 52% 36%;
  background:
    radial-gradient(ellipse 44% 40% at 62% 18%, rgba(108, 99, 255, 0.16), transparent 56%),
    radial-gradient(ellipse 48% 46% at 22% 38%, rgba(0, 255, 209, 0.11), transparent 54%),
    radial-gradient(ellipse 50% 42% at 78% 68%, rgba(0, 200, 255, 0.09), transparent 52%),
    radial-gradient(ellipse 54% 48% at 50% 50%, rgba(28, 36, 72, 0.26), transparent 60%);
  filter: blur(46px);
  animation: course-after-aurora 26s ease-in-out infinite alternate;
  animation-delay: -6s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.35) 0%,
    #000 22%,
    #000 78%,
    rgba(0, 0, 0, 0.4) 92%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.35) 0%,
    #000 22%,
    #000 78%,
    rgba(0, 0, 0, 0.4) 92%,
    transparent 100%
  );
}

#course-after-audience .course-after-audience__glow {
  position: absolute;
  top: 18%;
  left: -8%;
  width: min(46vw, 440px);
  height: min(46vw, 440px);
  background: radial-gradient(
    circle,
    rgba(0, 255, 209, 0.15) 0%,
    rgba(108, 99, 255, 0.09) 44%,
    transparent 68%
  );
  filter: blur(68px);
  animation: course-after-breath 17s ease-in-out infinite;
  animation-delay: -3s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.25) 0%,
    #000 38%,
    #000 64%,
    rgba(0, 0, 0, 0.35) 82%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.25) 0%,
    #000 38%,
    #000 64%,
    rgba(0, 0, 0, 0.35) 82%,
    transparent 100%
  );
}

#course-after-audience .course-after-audience__glow::after {
  content: "";
  position: absolute;
  right: -90%;
  bottom: -25%;
  width: min(44vw, 420px);
  height: min(44vw, 420px);
  background: radial-gradient(circle, rgba(108, 99, 255, 0.14) 0%, rgba(50, 60, 120, 0.06) 50%, transparent 68%);
  filter: blur(58px);
  animation: course-after-breath 19s ease-in-out infinite reverse;
  animation-delay: -9s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 36%,
    #000 58%,
    rgba(0, 0, 0, 0.36) 76%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    #000 36%,
    #000 58%,
    rgba(0, 0, 0, 0.36) 76%,
    transparent 100%
  );
}

#course-after-audience .course-after-audience__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      transparent 50%,
      rgba(6, 10, 27, 0.45) 88%,
      var(--course-program-base) 100%
    ),
    linear-gradient(
      180deg,
      var(--course-audience-base) 0%,
      var(--course-after-audience-base) 16%,
      transparent 34%
    ),
    radial-gradient(
      ellipse 102% 88% at 50% 42%,
      transparent 0%,
      rgba(7, 8, 23, 0.35) 55%,
      rgba(5, 6, 18, 0.55) 78%,
      var(--course-program-base) 100%
    );
}

#course-after-audience .course-after-audience__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.25rem, 4.5vw, 3.75rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.75rem, 5.5vw, 4.25rem) + clamp(64px, 11vh, 108px));
}

#course-after-audience .course-results__head {
  text-align: center;
  max-width: 44rem;
  margin: 0 auto clamp(2rem, 4vw, 2.75rem);
}

#course-after-audience .course-results__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#course-after-audience .course-results__title {
  margin: 0 0 0.85rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 24px rgba(0, 0, 0, 0.35);
}

#course-after-audience .course-results__intro {
  margin: 0;
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-after-audience .course-results__split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, min(36vw, 400px));
  gap: clamp(1.5rem, 3.5vw, 2.75rem);
  align-items: stretch;
}

#course-after-audience .course-results__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.35rem);
  width: 100%;
  min-width: 0;
  align-self: stretch;
}

#course-after-audience .course-results__card {
  height: 100%;
  display: flex;
  flex-direction: column;
  border-radius: 1.1rem;
  border: 1px solid rgba(0, 255, 209, 0.22);
  background: linear-gradient(
    155deg,
    rgba(255, 255, 255, 0.08) 0%,
    rgba(12, 14, 36, 0.72) 48%,
    rgba(6, 8, 24, 0.92) 100%
  );
  box-shadow:
    0 4px 28px rgba(0, 0, 0, 0.4),
    0 0 48px rgba(0, 255, 209, 0.1),
    0 0 88px rgba(108, 99, 255, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
  overflow: hidden;
  transition:
    transform var(--cr-card),
    border-color var(--cr-card),
    box-shadow var(--cr-card);
}

#course-after-audience .course-results__card:hover {
  transform: translateY(-6px);
  border-color: rgba(0, 255, 209, 0.38);
  box-shadow:
    0 22px 48px rgba(0, 0, 0, 0.5),
    0 0 56px rgba(0, 255, 209, 0.16),
    0 0 100px rgba(108, 99, 255, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.09);
}

#course-after-audience .course-results__card--interactive {
  cursor: pointer;
}

#course-after-audience .course-results__card--interactive:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#course-after-audience .course-results__modal {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: grid;
  place-items: center;
  padding: 1.25rem;
  box-sizing: border-box;
}

#course-after-audience .course-results__modal[hidden] {
  display: none;
}

#course-after-audience .course-results__modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 2, 8, 0.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

#course-after-audience .course-results__modal-dialog {
  position: relative;
  z-index: 1;
  width: min(960px, 100%);
  max-height: min(90vh, 900px);
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: 0;
  margin: 0;
  border-radius: 16px;
  background: #0c0c14;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.1),
    0 28px 80px rgba(0, 0, 0, 0.65);
  overflow: hidden;
}

#course-after-audience .course-results__modal-dialog--gifts {
  width: min(920px, 100%);
  max-height: min(92vh, 920px);
  overflow-x: hidden;
  overflow-y: auto;
}

#course-after-audience .course-results__modal-top {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-shrink: 0;
  padding: 0.5rem 0.65rem 0;
}

#course-after-audience .course-results__modal-close {
  margin: 0;
  padding: 0.4rem 0.75rem;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-family: var(--artvoic-font-body);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.08);
  transition: background 0.2s ease;
}

#course-after-audience .course-results__modal-close:hover {
  background: rgba(255, 255, 255, 0.14);
}

#course-after-audience .course-results__modal-close:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}

#course-after-audience .course-results__modal-embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  flex-shrink: 0;
  background: #000;
}

#course-after-audience .course-results__modal-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
  object-fit: contain;
  background: #000;
}

#course-after-audience .course-results__modal-caption {
  margin: 0;
  flex-shrink: 0;
  padding: 0 1rem 1rem;
  font-size: 0.88rem;
  color: var(--artvoic-text-muted);
}

#course-after-audience .course-results__modal-gifts-heading {
  margin: 0;
  flex-shrink: 0;
  padding: 0.25rem clamp(1rem, 3vw, 1.35rem) 0.25rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1rem, 0.42vw + 0.88rem, 1.28rem);
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: -0.02em;
  text-align: center;
  color: var(--artvoic-text);
  text-shadow: 0 1px 22px rgba(0, 0, 0, 0.35);
}

/* Карточки как на странице «Стоимость», встроенные в модал результатов курса */
#course-after-audience .course-results-modal__gifts {
  --ps-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ps-card: rgba(18, 18, 28, 0.55);
  --ps-card-border: rgba(255, 255, 255, 0.12);

  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2vw, 1.35rem);
  padding: clamp(0.85rem, 2vw, 1.35rem);
  padding-top: 0.5rem;
}

#course-after-audience .course-results-modal__gifts .price-services__card {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr);
  gap: clamp(1rem, 3vw, 1.75rem);
  align-items: start;
  margin-bottom: 0;
  padding: clamp(1.1rem, 2.2vw, 1.45rem);
  border-radius: 20px;
  border: 1px solid var(--ps-card-border);
  background: var(--ps-card);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.22);
  transition:
    border-color 0.35s var(--ps-ease),
    box-shadow 0.35s var(--ps-ease),
    transform 0.35s var(--ps-ease);
}

#course-after-audience .course-results-modal__gifts .price-services__card:hover {
  border-color: rgba(0, 255, 209, 0.28);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.12),
    0 16px 44px rgba(0, 255, 209, 0.08),
    0 12px 36px rgba(0, 0, 0, 0.35);
  transform: translateY(-2px);
}

#course-after-audience .course-results-modal__gifts .price-services__card-visual {
  border-radius: 16px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.06);
  align-self: stretch;
}

#course-after-audience .course-results-modal__gifts .price-services__card-visual img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

#course-after-audience .course-results-modal__gifts .price-services__card-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

#course-after-audience .course-results-modal__gifts .price-services__name {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1rem, 0.35vw + 0.88rem, 1.15rem);
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-transform: uppercase;
}

#course-after-audience .course-results-modal__gifts .price-services__body {
  margin: 0;
  font-size: clamp(0.88rem, 0.22vw + 0.82rem, 0.96rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-after-audience .course-results-modal__gifts .price-services__meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem 1rem;
  margin: 0.35rem 0 0;
  padding: 0.65rem 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

#course-after-audience .course-results-modal__gifts .price-services__meta dt {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(0, 255, 209, 0.75);
}

#course-after-audience .course-results-modal__gifts .price-services__meta dd {
  margin: 0.2rem 0 0;
  font-size: clamp(0.86rem, 0.2vw + 0.8rem, 0.95rem);
  line-height: 1.45;
  color: var(--artvoic-text);
}

#course-after-audience .course-results-modal__gifts .price-services__action-link {
  align-self: flex-start;
  margin-top: 0.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.62rem 1.2rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.06);
  border-radius: 4px;
  border: 1px solid rgba(0, 255, 209, 0.42);
  animation: price-services-link-glow 3.6s ease-in-out infinite;
  transition:
    color 0.25s var(--ps-ease),
    background 0.25s var(--ps-ease),
    transform 0.25s var(--ps-ease),
    border-color 0.25s var(--ps-ease);
}

#course-after-audience .course-results-modal__gifts .price-services__action-link:hover {
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-color: var(--artvoic-accent);
  transform: translateY(-2px);
}

#course-after-audience .course-results-modal__gifts .price-services__action-link:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

@media (max-width: 720px) {
  #course-after-audience .course-results-modal__gifts .price-services__card {
    grid-template-columns: 1fr;
  }

  #course-after-audience .course-results-modal__gifts .price-services__card-visual {
    max-width: 280px;
    margin: 0 auto;
  }

  #course-after-audience .course-results-modal__gifts .price-services__meta {
    grid-template-columns: 1fr;
  }
}

#course-after-audience .course-results__card-visual {
  position: relative;
  min-height: clamp(132px, 28vw, 156px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  padding: 1rem 1rem 0.85rem;
  background: radial-gradient(ellipse 90% 120% at 50% 0%, rgba(0, 255, 209, 0.07), transparent 55%),
    linear-gradient(180deg, rgba(10, 12, 28, 0.95) 0%, rgba(6, 8, 20, 0.55) 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

#course-after-audience .course-results__mini-player {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.85rem;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(0, 255, 209, 0.18);
  box-shadow: 0 0 24px rgba(0, 255, 209, 0.08);
}

#course-after-audience .course-results__mini-play {
  position: relative;
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  background: linear-gradient(145deg, rgba(0, 255, 209, 0.95), rgba(0, 210, 176, 0.88));
  box-shadow:
    0 6px 18px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(255, 255, 255, 0.12) inset;
}

#course-after-audience .course-results__mini-play::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(calc(-50% + 2px), -50%);
  border-style: solid;
  border-width: 0.32rem 0 0.32rem 0.52rem;
  border-color: transparent transparent transparent var(--course-after-audience-base);
}

#course-after-audience .course-results__mini-bars {
  display: flex;
  align-items: center;
  gap: 3px;
  height: 2.25rem;
}

#course-after-audience .course-results__mini-bars span {
  width: 3px;
  align-self: center;
  height: var(--h, 45%);
  min-height: 4px;
  border-radius: 2px;
  background: linear-gradient(180deg, rgba(0, 255, 209, 0.9) 0%, rgba(108, 99, 255, 0.45) 100%);
  opacity: 0.85;
}

#course-after-audience .course-results__visual-tag {
  font-size: clamp(0.65rem, 0.2vw + 0.6rem, 0.74rem);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.52);
}

#course-after-audience .course-results__demo-audio {
  width: 100%;
  max-width: min(100%, 20rem);
  margin: 0;
}

#course-after-audience .course-results__card-visual--mic .course-results__mic-img {
  width: clamp(4rem, 9vw, 5rem);
  height: auto;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 0 18px rgba(0, 255, 209, 0.22));
}

#course-after-audience .course-results__ready {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: clamp(0.72rem, 0.18vw + 0.68rem, 0.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.9);
  background: rgba(0, 255, 209, 0.12);
  border: 1px solid rgba(0, 255, 209, 0.35);
  box-shadow: 0 0 20px rgba(0, 255, 209, 0.12);
}

#course-after-audience .course-results__ready-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 4px;
  font-size: 0.65rem;
  color: var(--course-after-audience-base);
  background: var(--artvoic-accent);
}

#course-after-audience .course-results__card-visual--film {
  padding: 0;
  min-height: clamp(132px, 28vw, 156px);
  overflow: hidden;
}

#course-after-audience .course-results__film-still {
  width: 100%;
  height: 100%;
  min-height: clamp(132px, 28vw, 156px);
  object-fit: cover;
  object-position: center;
  opacity: 0.88;
}

#course-after-audience .course-results__film-grain {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    -12deg,
    transparent,
    transparent 1px,
    rgba(0, 0, 0, 0.04) 1px,
    rgba(0, 0, 0, 0.04) 2px
  );
  mix-blend-mode: multiply;
}

#course-after-audience .course-results__film-wave {
  position: absolute;
  left: 0.65rem;
  right: 0.65rem;
  bottom: 0.55rem;
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 2.5rem;
  padding: 0.35rem 0.5rem;
  border-radius: 8px;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.2) 100%);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

#course-after-audience .course-results__film-wave span {
  flex: 1;
  min-width: 2px;
  height: var(--h, 42%);
  border-radius: 2px;
  background: linear-gradient(180deg, rgba(108, 99, 255, 0.95) 0%, rgba(0, 255, 209, 0.35) 100%);
}

#course-after-audience .course-results__film-wave span:nth-child(odd) {
  --h: 35%;
}
#course-after-audience .course-results__film-wave span:nth-child(3n) {
  --h: 62%;
}
#course-after-audience .course-results__film-wave span:nth-child(4n) {
  --h: 48%;
}
#course-after-audience .course-results__film-wave span:nth-child(5n) {
  --h: 72%;
}

#course-after-audience .course-results__cert-sheet {
  position: relative;
  width: min(100%, 220px);
  aspect-ratio: 4 / 3;
  padding: 1.1rem 1.25rem;
  border-radius: 6px;
  background: linear-gradient(145deg, rgba(254, 252, 248, 0.96) 0%, rgba(236, 230, 220, 0.92) 100%);
  box-shadow:
    0 12px 32px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(0, 255, 209, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

#course-after-audience .course-results__cert-brand {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: rgba(20, 22, 40, 0.88);
  margin-bottom: 0.85rem;
}

#course-after-audience .course-results__cert-line {
  display: block;
  height: 5px;
  border-radius: 2px;
  background: rgba(20, 22, 40, 0.12);
  margin-bottom: 0.45rem;
}

#course-after-audience .course-results__cert-line--short {
  width: 42%;
}

#course-after-audience .course-results__cert-seal {
  position: absolute;
  right: 0.75rem;
  bottom: 0.75rem;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 50%;
  border: 2px solid rgba(0, 255, 209, 0.55);
  background: radial-gradient(circle at 32% 30%, rgba(0, 255, 209, 0.25), rgba(108, 99, 255, 0.15));
  box-shadow: 0 0 0 1px rgba(108, 99, 255, 0.35) inset, 0 6px 14px rgba(0, 0, 0, 0.2);
}

#course-after-audience .course-results__card-body {
  padding: clamp(1rem, 2.2vw, 1.25rem) clamp(1rem, 2.5vw, 1.25rem) clamp(1.15rem, 2.5vw, 1.35rem);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

#course-after-audience .course-results__sense {
  margin: 0;
  font-size: clamp(0.76rem, 0.2vw + 0.7rem, 0.84rem);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--artvoic-accent);
  line-height: 1.4;
}

#course-after-audience .course-results__card-title {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1rem, 0.35vw + 0.92rem, 1.18rem);
  font-weight: 600;
  line-height: 1.28;
  color: var(--artvoic-text);
}

#course-after-audience .course-results__detail {
  margin: 0;
  font-size: clamp(0.82rem, 0.22vw + 0.76rem, 0.92rem);
  line-height: 1.52;
  color: var(--artvoic-text-muted);
}

#course-after-audience .course-results__aside {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  min-width: 0;
}

#course-after-audience .course-results__compare {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  width: 100%;
  padding: clamp(1.1rem, 2.5vw, 1.35rem);
  border-radius: 1.1rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(168deg, rgba(255, 255, 255, 0.06) 0%, rgba(10, 12, 30, 0.9) 100%);
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.4),
    0 0 40px rgba(108, 99, 255, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

#course-after-audience .course-results__compare-title {
  margin: 0 0 0.45rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(0.95rem, 0.3vw + 0.86rem, 1.08rem);
  font-weight: 600;
  color: var(--artvoic-text);
}

#course-after-audience .course-results__compare-lead {
  margin: 0;
  font-size: clamp(0.78rem, 0.2vw + 0.72rem, 0.88rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.62);
  margin-bottom: 0.85rem;
}

#course-after-audience .course-results__wave-shell {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7;
  margin-bottom: 0.75rem;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

@media (min-width: 961px) {
  #course-after-audience .course-results__wave-shell {
    flex: 1 1 auto;
    min-height: clamp(104px, 14vh, 200px);
    aspect-ratio: unset;
    margin-bottom: 0;
  }

  #course-after-audience .course-results__toggle {
    margin-top: 0.75rem;
    flex-shrink: 0;
  }
}

#course-after-audience .cr-wave {
  position: absolute;
  inset: 0;
  padding: 10px clamp(10px, 2vw, 14px);
  box-sizing: border-box;
}

#course-after-audience .cr-wave__layer {
  position: absolute;
  left: clamp(10px, 2vw, 14px);
  right: clamp(10px, 2vw, 14px);
  top: 10px;
  bottom: 10px;
  display: flex;
  align-items: center;
  gap: 3px;
  pointer-events: none;
  transition: opacity 0.45s var(--cr-ease);
}

#course-after-audience .cr-wave__layer--before {
  opacity: 1;
}

#course-after-audience .cr-wave__layer--after {
  opacity: 0;
}

#course-after-audience .course-results__compare.is-after .cr-wave__layer--before {
  opacity: 0;
}

#course-after-audience .course-results__compare.is-after .cr-wave__layer--after {
  opacity: 1;
}

#course-after-audience .cr-wave__layer span {
  flex: 1 1 auto;
  align-self: center;
  min-width: 2px;
  height: var(--h, 40%);
  min-height: 5px;
  border-radius: 2px;
  background: linear-gradient(
    180deg,
    rgba(0, 255, 209, 0.92) 0%,
    rgba(0, 255, 209, 0.32) 55%,
    rgba(108, 99, 255, 0.18) 100%
  );
  box-shadow: 0 0 12px rgba(0, 255, 209, 0.12);
}

#course-after-audience .course-results__toggle {
  display: flex;
  margin-bottom: 0.65rem;
  padding: 3px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.08);
  gap: 2px;
}

#course-after-audience .course-results__toggle-btn {
  flex: 1;
  margin: 0;
  padding: 0.5rem 0.5rem;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: clamp(0.62rem, 0.18vw + 0.58rem, 0.72rem);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  background: transparent;
  transition:
    background 0.3s var(--cr-ease),
    color 0.3s var(--cr-ease),
    box-shadow 0.3s var(--cr-ease);
}

#course-after-audience .course-results__toggle-btn:hover {
  color: rgba(255, 255, 255, 0.82);
}

#course-after-audience .course-results__toggle-btn.is-active {
  color: var(--course-after-audience-base);
  background: var(--artvoic-accent);
  box-shadow: 0 0 22px rgba(0, 255, 209, 0.35);
}

#course-after-audience .course-results__toggle-btn:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}

/* .course-results__audio: нативные controls убраны — мини-плеер .artvoic-voice-mini */
#course-after-audience .course-results__compare > .artvoic-voice-mini {
  margin-top: auto;
}

#course-after-audience .course-results__micro {
  margin: clamp(2rem, 4vw, 2.75rem) auto 0;
  max-width: 38rem;
  text-align: center;
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.05rem);
  line-height: 1.55;
  font-weight: 500;
  font-style: italic;
  color: rgba(255, 255, 255, 0.78);
}

#course-after-audience .course-results__cta-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.65rem;
  margin-top: clamp(1.5rem, 3vw, 2rem);
  text-align: center;
}

#course-after-audience .course-results__cta-note {
  margin: 0;
  font-size: 0.84rem;
  color: rgba(255, 255, 255, 0.58);
  line-height: 1.45;
}

#course-after-audience .course-results__cta-link {
  color: var(--artvoic-accent);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 255, 209, 0.35);
  transition: color 0.2s ease, border-color 0.2s ease;
}

#course-after-audience .course-results__cta-link:hover {
  color: #7dffeb;
  border-color: rgba(0, 255, 209, 0.55);
}

@media (max-width: 960px) {
  #course-after-audience .course-results__split {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  #course-after-audience .course-results__aside {
    height: auto;
    order: -1;
  }

  #course-after-audience .course-results__compare {
    flex: none;
  }
}

@media (max-width: 640px) {
  #course-after-audience .course-results__grid {
    grid-template-columns: 1fr;
  }

  #course-after-audience .course-results__card:hover {
    transform: none;
  }
}

.elementor-section:has(#course-after-audience),
.e-con:has(#course-after-audience) {
  margin-bottom: 0;
  padding-bottom: 0;
}

.elementor-section:has(#course-program),
.e-con:has(#course-program) {
  margin-bottom: 0;
  padding-bottom: 0;
}

.elementor-section:has(#course-how-learning),
.e-con:has(#course-how-learning) {
  margin-bottom: 0;
  padding-bottom: 0;
}

.elementor-section:has(#course-pricing),
.e-con:has(#course-pricing) {
  margin-bottom: 0;
  padding-bottom: 0;
}

.elementor-section:has(#price-services),
.e-con:has(#price-services) {
  margin-bottom: 0;
  padding-bottom: 0;
}

.elementor-section:has(#course-faq),
.e-con:has(#course-faq) {
  margin-bottom: 0;
  padding-bottom: 0;
}

.elementor-section:has(#kids-hero),
.elementor-section:has(#imx-hero),
.elementor-section:has(#pco-hero),
.e-con:has(#kids-hero),
.e-con:has(#imx-hero),
.e-con:has(#pco-hero),
.elementor-section:has(#kids-results),
.e-con:has(#kids-results),
.elementor-section:has(#kids-program),
.elementor-section:has(#imx-program),
.e-con:has(#kids-program),
.e-con:has(#imx-program),
.elementor-section:has(#kids-studio-videos),
.e-con:has(#kids-studio-videos),
.elementor-section:has(:is(#kids-mentor, #pco-mentor)),
.e-con:has(:is(#kids-mentor, #pco-mentor)),
.elementor-section:has(#kids-faq),
.e-con:has(#kids-faq),
.elementor-section:has(#kids-pricing),
.e-con:has(#kids-pricing) {
  margin-bottom: 0;
  padding-bottom: 0;
  overflow: visible;
}

.elementor-widget-container:has(#kids-hero),
.elementor-widget-container:has(#imx-hero),
.elementor-widget-container:has(#pco-hero),
.elementor-widget-container:has(#kids-results),
.elementor-widget-container:has(#kids-program),
.elementor-widget-container:has(#imx-program),
.elementor-widget-container:has(#kids-studio-videos),
.elementor-widget-container:has(:is(#kids-mentor, #pco-mentor)),
.elementor-widget-container:has(#kids-faq),
.elementor-widget-container:has(#kids-pricing),
.elementor-widget-html:has(#kids-hero),
.elementor-widget-html:has(#imx-hero),
.elementor-widget-html:has(#pco-hero),
.elementor-widget-html:has(#kids-results),
.elementor-widget-html:has(#kids-program),
.elementor-widget-html:has(#imx-program),
.elementor-widget-html:has(#kids-studio-videos),
.elementor-widget-html:has(:is(#kids-mentor, #pco-mentor)),
.elementor-widget-html:has(#kids-faq),
.elementor-widget-html:has(#kids-pricing) {
  overflow: visible;
}

.elementor-section:has(#course-pocket-studio),
.e-con:has(#course-pocket-studio) {
  margin-bottom: 0;
  padding-bottom: 0;
}

/* --- course-how-learning: «Как проходит обучение», фон как у hero (классы hero-dubbing__) --- */

#course-how-learning {
  --chl-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --chl-step: 0.45s var(--chl-ease);

  position: relative;
  background: var(--directions-hub-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#course-how-learning .course-how-learning__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(5rem, 9vw, 7.5rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.5rem, 5vw, 3.75rem) + clamp(64px, 11vh, 108px));
}

#course-how-learning .course-how-learning__head {
  text-align: center;
  max-width: 52rem;
  margin: 0 auto clamp(1.35rem, 3.2vw, 2rem);
}

#course-how-learning .course-how-learning__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#course-how-learning .course-how-learning__title {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: baseline;
  gap: 0.35em 0.45em;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 24px rgba(0, 0, 0, 0.35);
}

#course-how-learning .course-how-learning__title-plain {
  font-weight: 600;
  letter-spacing: -0.02em;
}

#course-how-learning .course-how-learning__title-accent {
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--artvoic-accent);
  text-shadow:
    0 0 26px rgba(0, 255, 209, 0.14),
    0 1px 24px rgba(0, 0, 0, 0.35);
}

#course-how-learning .course-how-learning__path {
  position: relative;
  padding: clamp(0.65rem, 2vw, 1.35rem) 0 clamp(1rem, 2vw, 1.5rem);
}

#course-how-learning .course-how-learning__rail {
  position: absolute;
  left: 5%;
  right: 5%;
  top: 50%;
  height: 2px;
  transform: translateY(-50%);
  border-radius: 999px;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 255, 209, 0.08) 15%,
    rgba(0, 255, 209, 0.22) 50%,
    rgba(0, 255, 209, 0.08) 85%,
    transparent 100%
  );
  box-shadow: 0 0 24px rgba(0, 255, 209, 0.06);
}

#course-how-learning .course-how-learning__track {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.65rem, 2vw, 1.25rem);
  min-height: clamp(300px, 32vw, 420px);
  align-items: center;
  position: relative;
  z-index: 1;
}

#course-how-learning .course-how-learning__node {
  position: relative;
  height: 100%;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  outline: none;
}

#course-how-learning .course-how-learning__node:focus-visible .course-how-learning__glass {
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.45),
    0 0 0 2px rgba(0, 255, 209, 0.45);
}

#course-how-learning .course-how-learning__bg-num {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 0;
  transform: translate(-50%, -58%);
  font-family: var(--artvoic-font-display);
  font-size: clamp(3.25rem, 12vw, 7.25rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.05em;
  color: rgba(255, 255, 255, 0.04);
  pointer-events: none;
  user-select: none;
  transition:
    transform var(--chl-step),
    color var(--chl-step);
}

#course-how-learning .course-how-learning__glass {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 16rem;
  margin: 0 auto;
  padding: clamp(1.35rem, 3.2vw, 1.9rem) clamp(1.1rem, 2.6vw, 1.4rem);
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.04);
  -webkit-backdrop-filter: blur(20px) saturate(145%);
  backdrop-filter: blur(20px) saturate(145%);
  box-shadow:
    0 16px 48px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  transition:
    transform var(--chl-step),
    background var(--chl-step),
    box-shadow var(--chl-step);
}

#course-how-learning .course-how-learning__track > li:nth-child(odd) .course-how-learning__glass {
  transform: translateY(clamp(-1.35rem, -3.5vw, -2.75rem));
}

#course-how-learning .course-how-learning__track > li:nth-child(even) .course-how-learning__glass {
  transform: translateY(clamp(1.35rem, 3.5vw, 2.75rem));
}

#course-how-learning .course-how-learning__visual {
  display: flex;
  justify-content: center;
  margin-bottom: clamp(0.85rem, 2vw, 1.15rem);
}

#course-how-learning .course-how-learning__illus {
  width: clamp(4.5rem, 11vw, 6rem);
  height: auto;
  display: block;
  transition:
    transform var(--chl-step),
    filter var(--chl-step);
}

#course-how-learning .course-how-learning__step-title {
  margin: 0 0 0.45rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.05rem, 0.55vw + 0.92rem, 1.28rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
}

#course-how-learning .course-how-learning__step-benefit {
  margin: 0;
  font-size: clamp(0.94rem, 0.25vw + 0.88rem, 1.05rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.58);
}

#course-how-learning .course-how-learning__node:hover .course-how-learning__bg-num {
  color: rgba(0, 255, 209, 0.1);
  transform: translate(-50%, -58%) scale(1.06);
}

#course-how-learning .course-how-learning__node:hover .course-how-learning__illus {
  transform: scale(1.08) translateY(-2px);
  filter: drop-shadow(0 0 22px rgba(0, 255, 209, 0.38));
}

#course-how-learning .course-how-learning__node:hover .course-how-learning__glass {
  background: rgba(255, 255, 255, 0.065);
  box-shadow:
    0 20px 56px rgba(0, 0, 0, 0.48),
    0 0 40px rgba(0, 255, 209, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

@media (max-width: 900px) {
  #course-how-learning .course-how-learning__inner {
    padding:
      clamp(2rem, 5vw, 2.75rem) clamp(1rem, 4vw, 1.25rem)
      calc(clamp(1.75rem, 4.5vw, 2.35rem) + clamp(48px, 11vw, 76px));
  }

  #course-how-learning .course-how-learning__head {
    margin-bottom: clamp(0.85rem, 2.5vw, 1.2rem);
  }

  #course-how-learning .course-how-learning__path {
    padding: clamp(0.35rem, 1.5vw, 0.65rem) 0 clamp(0.35rem, 1.5vw, 0.65rem);
  }

  #course-how-learning .course-how-learning__rail {
    left: 0.375rem;
    right: auto;
    top: 0;
    bottom: 0;
    width: 2px;
    height: auto;
    transform: none;
    background: linear-gradient(
      180deg,
      transparent 0%,
      rgba(0, 255, 209, 0.1) 20%,
      rgba(0, 255, 209, 0.2) 50%,
      rgba(0, 255, 209, 0.1) 80%,
      transparent 100%
    );
  }

  #course-how-learning .course-how-learning__track {
    grid-template-columns: 1fr;
    min-height: 0;
    gap: clamp(0.85rem, 3vw, 1.15rem);
    padding-left: clamp(0.9rem, 3.5vw, 1.05rem);
  }

  #course-how-learning .course-how-learning__track > li:nth-child(odd) .course-how-learning__glass,
  #course-how-learning .course-how-learning__track > li:nth-child(even) .course-how-learning__glass {
    transform: none;
  }

  #course-how-learning .course-how-learning__node:hover .course-how-learning__illus {
    transform: scale(1.05) translateY(-1px);
  }
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
  #course-how-learning .course-how-learning__glass {
    background: rgba(22, 22, 22, 0.88);
  }
}

/* --- course-pocket-studio: «Студия у вас в кармане», эволюция звука (якорь #course-pocket-studio) --- */

@keyframes course-pocket-studio-aurora {
  0% {
    transform: translate3d(0.8%, -0.35%, 0) scale(1);
  }
  100% {
    transform: translate3d(-1%, 0.55%, 0) scale(1.035);
  }
}

@keyframes course-pocket-studio-breath {
  0%,
  100% {
    opacity: 0.44;
    transform: scale(1);
  }
  50% {
    opacity: 0.64;
    transform: scale(1.07);
  }
}

@keyframes course-pocket-studio-sheen {
  0%,
  100% {
    transform: translate3d(-6%, 4%, 0) scale(1);
    opacity: 0.35;
  }
  50% {
    transform: translate3d(5%, -4%, 0) scale(1.04);
    opacity: 0.6;
  }
}

@keyframes course-pocket-studio-neon-pulse {
  0%,
  100% {
    opacity: 0.65;
  }
  50% {
    opacity: 1;
  }
}

@keyframes course-pocket-studio-photo-float {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-7px);
  }
}

@keyframes course-pocket-studio-photo-shimmer {
  0%,
  100% {
    background-position: 8% 50%;
    opacity: 0.72;
  }
  50% {
    background-position: 92% 50%;
    opacity: 0.98;
  }
}

#course-pocket-studio {
  --cps-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --cps-panel: 0.4s var(--cps-ease);
  --cps-bg: var(--course-pocket-surface);

  position: relative;
  /* Верх совпадает с низом #course-how-learning / #course-pricing (--directions-hub-base), без полосы «другого» фона */
  background: linear-gradient(
    180deg,
    var(--directions-hub-base) 0%,
    var(--cps-bg) clamp(100px, 14vw, 200px),
    var(--cps-bg) 100%
  );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#course-pocket-studio .course-pocket-studio__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#course-pocket-studio .course-pocket-studio__aurora {
  position: absolute;
  inset: -26% -22% -22% -22%;
  transform-origin: 48% 40%;
  background:
    radial-gradient(ellipse 48% 44% at 22% 28%, rgba(0, 255, 209, 0.1), transparent 56%),
    radial-gradient(ellipse 46% 42% at 78% 42%, rgba(108, 99, 255, 0.055), transparent 54%),
    radial-gradient(ellipse 42% 40% at 65% 78%, rgba(212, 175, 55, 0.045), transparent 52%),
    radial-gradient(ellipse 54% 48% at 50% 50%, rgba(18, 22, 28, 0.52), transparent 58%);
  filter: blur(48px);
  animation: course-pocket-studio-aurora 22s ease-in-out infinite alternate;
  animation-delay: -3s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.5) 0%,
    #000 10%,
    #000 78%,
    rgba(0, 0, 0, 0.34) 90%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.5) 0%,
    #000 10%,
    #000 78%,
    rgba(0, 0, 0, 0.34) 90%,
    transparent 100%
  );
}

#course-pocket-studio .course-pocket-studio__glow {
  position: absolute;
  top: 16%;
  left: -10%;
  width: min(44vw, 400px);
  height: min(44vw, 400px);
  background: radial-gradient(
    circle,
    rgba(0, 255, 209, 0.1) 0%,
    rgba(0, 255, 209, 0.038) 46%,
    transparent 68%
  );
  filter: blur(58px);
  animation: course-pocket-studio-breath 17s ease-in-out infinite;
  animation-delay: -5s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.42) 0%,
    #000 28%,
    #000 62%,
    rgba(0, 0, 0, 0.28) 76%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.42) 0%,
    #000 28%,
    #000 62%,
    rgba(0, 0, 0, 0.28) 76%,
    transparent 100%
  );
}

#course-pocket-studio .course-pocket-studio__glow::after {
  content: "";
  position: absolute;
  right: -92%;
  top: 6%;
  width: min(40vw, 360px);
  height: min(40vw, 360px);
  background: radial-gradient(
    circle,
    rgba(0, 255, 209, 0.075) 0%,
    rgba(108, 99, 255, 0.06) 44%,
    rgba(20, 24, 28, 0.06) 52%,
    transparent 68%
  );
  filter: blur(52px);
  animation: course-pocket-studio-breath 19s ease-in-out infinite reverse;
  animation-delay: -10s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.38) 0%,
    #000 30%,
    #000 58%,
    rgba(0, 0, 0, 0.32) 74%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.38) 0%,
    #000 30%,
    #000 58%,
    rgba(0, 0, 0, 0.32) 74%,
    transparent 100%
  );
}

#course-pocket-studio .course-pocket-studio__glow-sheen {
  position: absolute;
  inset: -8% 10% 25% -20%;
  background: radial-gradient(ellipse 70% 55% at 55% 48%, rgba(0, 255, 209, 0.07), transparent 62%);
  filter: blur(70px);
  mix-blend-mode: screen;
  opacity: 0.55;
  animation: course-pocket-studio-sheen 14s ease-in-out infinite;
  animation-delay: -2s;
  pointer-events: none;
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 88%, transparent 100%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 88%, transparent 100%);
}

#course-pocket-studio .course-pocket-studio__mesh {
  position: absolute;
  inset: 0;
  opacity: 0.1;
  background-image: radial-gradient(rgba(255, 255, 255, 0.5) 0.55px, transparent 0.55px);
  background-size: 22px 22px;
}

#course-pocket-studio .course-pocket-studio__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      var(--directions-hub-base) 0%,
      rgba(5, 5, 12, 0) min(28%, 260px)
    ),
    linear-gradient(160deg, rgba(6, 7, 12, 0.55) 0%, transparent 42%),
    linear-gradient(180deg, transparent 52%, rgba(5, 6, 10, 0.9) 100%),
    radial-gradient(ellipse 98% 74% at 50% 42%, transparent 0%, rgba(10, 10, 12, 0.4) 58%, var(--cps-bg) 100%);
}

#course-pocket-studio .course-pocket-studio__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding:
    clamp(4.5rem, 9vw, 7rem) clamp(1.25rem, 5vw, 3.5rem)
    calc(clamp(5.75rem, 11vw, 8.5rem) + clamp(64px, 11vh, 108px));
}

#course-pocket-studio .course-pocket-studio__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  gap: clamp(1.75rem, 4vw, 3.25rem);
  align-items: center;
}

#course-pocket-studio .course-pocket-studio__visual-col {
  position: relative;
}

#course-pocket-studio .course-pocket-studio__visual-frame {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: clamp(280px, 40vw, 440px);
}

#course-pocket-studio .course-pocket-studio__neon {
  position: absolute;
  border-radius: 50%;
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
  animation: course-pocket-studio-neon-pulse 5s ease-in-out infinite;
}

#course-pocket-studio .course-pocket-studio__neon--a {
  width: min(72%, 360px);
  aspect-ratio: 1;
  left: 50%;
  top: 52%;
  transform: translate(-50%, -50%);
  background: radial-gradient(
    circle,
    rgba(0, 255, 209, 0.22) 0%,
    rgba(0, 168, 150, 0.12) 42%,
    rgba(212, 175, 55, 0.07) 62%,
    transparent 74%
  );
  animation-delay: -1s;
}

#course-pocket-studio .course-pocket-studio__neon--b {
  width: min(48%, 240px);
  aspect-ratio: 1;
  left: 18%;
  top: 28%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(108, 99, 255, 0.18) 0%, rgba(0, 255, 209, 0.08) 45%, transparent 68%);
  animation-duration: 6.5s;
  animation-delay: -2.5s;
}

#course-pocket-studio .course-pocket-studio__photo-stack {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: min(380px, 92vw);
  margin: 0 auto;
  animation: course-pocket-studio-photo-float 6.5s ease-in-out infinite;
}

#course-pocket-studio .course-pocket-studio__photo-glow {
  position: absolute;
  inset: 8% 2% 6% 2%;
  border-radius: 1.45rem;
  background: radial-gradient(ellipse 80% 70% at 50% 42%, rgba(0, 255, 209, 0.35), transparent 65%);
  filter: blur(32px);
  opacity: 0.75;
  z-index: 0;
  pointer-events: none;
  animation: course-pocket-studio-neon-pulse 4s ease-in-out infinite;
  animation-delay: -0.5s;
}

#course-pocket-studio .course-pocket-studio__photo-frame {
  position: relative;
  z-index: 1;
  border-radius: 1.45rem;
  overflow: hidden;
  outline: 1px solid rgba(0, 255, 209, 0.32);
  outline-offset: 4px;
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.72),
    0 0 0 1px rgba(0, 255, 209, 0.22),
    0 0 56px rgba(0, 255, 209, 0.14),
    0 0 120px rgba(108, 99, 255, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

#course-pocket-studio .course-pocket-studio__photo {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: 50% 38%;
  border-radius: 1.45rem;
  transform: scale(1.02);
  filter: saturate(1.06) contrast(1.04);
}

#course-pocket-studio .course-pocket-studio__photo-shine {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    105deg,
    transparent 0%,
    transparent 42%,
    rgba(255, 255, 255, 0.16) 50%,
    rgba(0, 255, 209, 0.06) 54%,
    transparent 60%,
    transparent 100%
  );
  background-size: 220% 100%;
  opacity: 0.85;
  animation: course-pocket-studio-photo-shimmer 14s ease-in-out infinite;
}

#course-pocket-studio .course-pocket-studio__stat {
  position: absolute;
  right: clamp(-0.25rem, -1.5vw, -1.25rem);
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  max-width: min(200px, 46vw);
  padding: 0.85rem 1rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  backdrop-filter: blur(18px) saturate(150%);
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
  transition:
    box-shadow var(--cps-panel),
    background var(--cps-panel);
}

#course-pocket-studio .course-pocket-studio__stat-value {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.65rem, 3.5vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--artvoic-accent);
  text-shadow: 0 0 28px rgba(0, 255, 209, 0.25);
  margin-bottom: 0.35rem;
}

#course-pocket-studio .course-pocket-studio__stat-text {
  display: block;
  font-size: clamp(0.72rem, 0.2vw + 0.68rem, 0.8rem);
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 500;
}

#course-pocket-studio .course-pocket-studio__glass {
  padding: clamp(1.85rem, 4vw, 2.65rem) clamp(1.5rem, 3.8vw, 2.35rem);
  border-radius: 1.5rem;
  background: rgba(255, 255, 255, 0.045);
  border: 1px solid rgba(255, 255, 255, 0.09);
  -webkit-backdrop-filter: blur(22px) saturate(155%);
  backdrop-filter: blur(22px) saturate(155%);
  box-shadow:
    0 28px 64px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

#course-pocket-studio .course-pocket-studio__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#course-pocket-studio .course-pocket-studio__title {
  margin: 0 0 0.85rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 24px rgba(0, 0, 0, 0.35);
}

#course-pocket-studio .course-pocket-studio__lead {
  margin: 0 0 clamp(1.5rem, 3vw, 2rem);
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
  max-width: 38rem;
}

#course-pocket-studio .course-pocket-studio__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(1.15rem, 2.5vw, 1.45rem);
}

#course-pocket-studio .course-pocket-studio__item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

#course-pocket-studio .course-pocket-studio__icon {
  flex-shrink: 0;
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 13px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.04);
}

#course-pocket-studio .course-pocket-studio__icon svg,
#course-pocket-studio .course-pocket-studio__icon img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

#course-pocket-studio .course-pocket-studio__item-text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding-top: 0.05rem;
}

#course-pocket-studio .course-pocket-studio__item-title {
  font-family: var(--artvoic-font-body);
  font-size: clamp(1rem, 0.25vw + 0.94rem, 1.08rem);
  font-weight: 600;
  line-height: 1.25;
  color: var(--artvoic-text);
}

#course-pocket-studio .course-pocket-studio__item-desc {
  font-size: clamp(0.88rem, 0.2vw + 0.84rem, 0.98rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.55);
}

@media (hover: hover) and (pointer: fine) {
  #course-pocket-studio .course-pocket-studio__stat:hover {
    background: rgba(255, 255, 255, 0.07);
    box-shadow:
      0 22px 50px rgba(0, 0, 0, 0.45),
      0 0 30px rgba(0, 255, 209, 0.06),
      inset 0 1px 0 rgba(255, 255, 255, 0.09);
  }
}

@media (max-width: 900px) {
  #course-pocket-studio .course-pocket-studio__inner {
    padding:
      clamp(2.5rem, 6vw, 3.25rem) clamp(1rem, 4vw, 1.25rem)
      calc(clamp(4.5rem, 10vw, 6rem) + clamp(56px, 10vh, 96px));
  }

  #course-pocket-studio .course-pocket-studio__grid {
    grid-template-columns: 1fr;
    gap: clamp(1.5rem, 4vw, 2rem);
  }

  #course-pocket-studio .course-pocket-studio__visual-col {
    order: -1;
  }

  #course-pocket-studio .course-pocket-studio__visual-frame {
    min-height: clamp(260px, 72vw, 400px);
  }

  #course-pocket-studio .course-pocket-studio__photo-stack {
    max-width: min(340px, 88vw);
  }

  #course-pocket-studio .course-pocket-studio__stat {
    position: relative;
    right: auto;
    top: auto;
    transform: none;
    max-width: 22rem;
    margin: clamp(1rem, 3vw, 1.35rem) auto 0;
    text-align: center;
  }
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
  #course-pocket-studio .course-pocket-studio__glass {
    background: rgba(22, 22, 26, 0.9);
  }

  #course-pocket-studio .course-pocket-studio__stat {
    background: rgba(26, 26, 30, 0.92);
  }
}

/* --- course-program: программа курса — таймлайн + аккордеон ≤900px --- */

@keyframes course-program-aurora {
  0% {
    transform: translate3d(-0.8%, 0.2%, 0) scale(1);
  }
  100% {
    transform: translate3d(1.2%, -0.6%, 0) scale(1.04);
  }
}

@keyframes course-program-breath {
  0%,
  100% {
    opacity: 0.42;
    transform: scale(1);
  }
  50% {
    opacity: 0.58;
    transform: scale(1.06);
  }
}

/* --- course-faq: аккордеон на тех же .course-program__*, что и в #course-program --- */
#course-faq,
#kids-faq,
#imx-faq {
  --cp-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --cp-panel: 0.48s var(--cp-ease);

  position: relative;
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#course-faq {
  background: var(--course-faq-base);
}

#kids-faq {
  background: linear-gradient(
    180deg,
    var(--kids-faq-base) 0%,
    var(--kids-faq-base) 48%,
    #0c0c24 62%,
    var(--kids-pricing-base) 88%,
    var(--kids-pricing-base) 100%
  );
}

/* Стык после наставника — мягкий спуск в FAQ (фон + свечения не «переламываются») */
:is(#kids-faq, #imx-faq)::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: clamp(72px, 14vh, 168px);
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.56) 0%,
    rgba(0, 0, 0, 0.22) 50%,
    transparent 100%
  );
}

:is(#kids-faq, #imx-faq) .kids-results__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 50% 44% at 78% 18%, rgba(0, 255, 209, 0.18), transparent 55%),
    radial-gradient(ellipse 48% 40% at 12% 60%, rgba(108, 99, 255, 0.22), transparent 52%);
  filter: blur(40px);
  opacity: 0.92;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    #000 clamp(72px, 14vh, 140px),
    #000 calc(100% - clamp(80px, 16vh, 160px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    #000 clamp(72px, 14vh, 140px),
    #000 calc(100% - clamp(80px, 16vh, 160px)),
    transparent 100%
  );
}

#course-program {
  --cp-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --cp-panel: 0.48s var(--cp-ease);

  position: relative;
  /* Низ секции = тот же тон, что у #course-how-learning, чтобы волна и маски не ловили контрастный стык */
  background: linear-gradient(
    180deg,
    var(--course-program-base) 0%,
    var(--course-program-base) 58%,
    #05050c 82%,
    var(--directions-hub-base) 100%
  );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

/* Детский лендинг: программа «Путь героя» (после блока результатов для мам) */
:is(#kids-program, #imx-program) {
  --cp-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --cp-panel: 0.48s var(--cp-ease);

  position: relative;
  background: linear-gradient(
    180deg,
    var(--kids-program-base) 0%,
    var(--kids-program-base) 58%,
    #0a0618 82%,
    var(--kids-mentor-base) 100%
  );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

/* Низ: стык с волной и блоком «Со студии» */
:is(#kids-program, #imx-program)::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(88px, 17vh, 200px);
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.62) 0%,
    rgba(0, 0, 0, 0.28) 48%,
    rgba(0, 0, 0, 0.06) 82%,
    transparent 100%
  );
}

#course-program .course-program__bg-wrapper,
:is(#kids-program, #imx-program) .course-program__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#course-program .course-program__aurora,
:is(#kids-program, #imx-program) .course-program__aurora {
  position: absolute;
  inset: -26% -18% -22% -18%;
  transform-origin: 40% 32%;
  background:
    radial-gradient(ellipse 46% 42% at 72% 22%, rgba(0, 255, 209, 0.12), transparent 55%),
    radial-gradient(ellipse 50% 44% at 18% 48%, rgba(108, 99, 255, 0.14), transparent 54%),
    radial-gradient(ellipse 48% 40% at 58% 72%, rgba(0, 160, 200, 0.08), transparent 52%),
    radial-gradient(ellipse 56% 50% at 48% 48%, rgba(20, 28, 56, 0.32), transparent 58%);
  filter: blur(44px);
  animation: course-program-aurora 24s ease-in-out infinite alternate;
  animation-delay: -4s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.3) 0%,
    #000 20%,
    #000 76%,
    rgba(0, 0, 0, 0.38) 91%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.3) 0%,
    #000 20%,
    #000 76%,
    rgba(0, 0, 0, 0.38) 91%,
    transparent 100%
  );
}

#course-program .course-program__glow,
:is(#kids-program, #imx-program) .course-program__glow {
  position: absolute;
  top: 12%;
  right: -6%;
  width: min(44vw, 400px);
  height: min(44vw, 400px);
  background: radial-gradient(
    circle,
    rgba(108, 99, 255, 0.16) 0%,
    rgba(0, 255, 209, 0.08) 42%,
    transparent 68%
  );
  filter: blur(62px);
  animation: course-program-breath 16s ease-in-out infinite;
  animation-delay: -5s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.22) 0%,
    #000 36%,
    #000 62%,
    rgba(0, 0, 0, 0.32) 80%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.22) 0%,
    #000 36%,
    #000 62%,
    rgba(0, 0, 0, 0.32) 80%,
    transparent 100%
  );
}

#course-program .course-program__glow::after,
:is(#kids-program, #imx-program) .course-program__glow::after {
  content: "";
  position: absolute;
  left: -95%;
  bottom: -20%;
  width: min(42vw, 380px);
  height: min(42vw, 380px);
  background: radial-gradient(circle, rgba(0, 255, 209, 0.11) 0%, rgba(40, 50, 100, 0.06) 50%, transparent 68%);
  filter: blur(54px);
  animation: course-program-breath 18s ease-in-out infinite reverse;
  animation-delay: -10s;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.18) 0%,
    #000 34%,
    #000 58%,
    rgba(0, 0, 0, 0.34) 74%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.18) 0%,
    #000 34%,
    #000 58%,
    rgba(0, 0, 0, 0.34) 74%,
    transparent 100%
  );
}

#course-program .course-program__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      transparent 45%,
      rgba(5, 5, 10, 0.38) 76%,
      rgba(5, 5, 8, 0.92) 92%,
      var(--directions-hub-base) 100%
    ),
    linear-gradient(
      180deg,
      var(--course-after-audience-base) 0%,
      var(--course-program-base) 14%,
      transparent 32%
    ),
    radial-gradient(
      ellipse 100% 86% at 50% 40%,
      transparent 0%,
      rgba(6, 10, 27, 0.38) 56%,
      rgba(5, 5, 10, 0.45) 78%,
      var(--directions-hub-base) 100%
    );
}

:is(#kids-program, #imx-program) .course-program__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      transparent 45%,
      rgba(5, 5, 14, 0.38) 76%,
      rgba(8, 5, 18, 0.92) 92%,
      var(--kids-mentor-base) 100%
    ),
    linear-gradient(180deg, var(--kids-program-base) 0%, var(--kids-program-base) 14%, transparent 32%),
    radial-gradient(
      ellipse 100% 86% at 50% 40%,
      transparent 0%,
      rgba(8, 12, 32, 0.38) 56%,
      rgba(5, 5, 14, 0.45) 78%,
      var(--kids-mentor-base) 100%
    );
}

/* Стык с #kids-results: аврора слабее у верхнего края */
:is(#kids-program, #imx-program) .course-program__aurora {
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.4) 8%,
    #000 22%,
    #000 76%,
    rgba(0, 0, 0, 0.38) 91%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.4) 8%,
    #000 22%,
    #000 76%,
    rgba(0, 0, 0, 0.38) 91%,
    transparent 100%
  );
}

/* Низ секции: только линейный фон — ровный переход в :is(#kids-mentor, #pco-mentor) */
:is(#kids-program, #imx-program) .course-program__bg-wrapper {
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 calc(100% - clamp(80px, 16vh, 160px)), transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 calc(100% - clamp(80px, 16vh, 160px)), transparent 100%);
}

#course-program .course-program__inner,
:is(#kids-program, #imx-program) .course-program__inner,
#course-faq .course-program__inner,
:is(#kids-faq, #imx-faq) .course-program__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.25rem, 4.5vw, 3.75rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.75rem, 5.5vw, 4.5rem) + clamp(64px, 11vh, 108px));
}

#course-faq .course-program__inner {
  padding-bottom: clamp(2.75rem, 5.5vw, 4.25rem);
}

/* Детский FAQ: запас под волну (не наезжает на аккордеон) + стык с #kids-pricing */
:is(#kids-faq, #imx-faq) .course-program__inner {
  padding-bottom: calc(
    clamp(2.75rem, 5.5vw, 4.25rem) + clamp(72px, 12vh, 120px) + clamp(0.75rem, 2.5vw, 1.5rem)
  );
}

/* Интенсив: FAQ без нижней волны — обычный отступ */
#imx-faq .course-program__inner {
  padding-bottom: clamp(2.75rem, 5.5vw, 4.25rem);
}

#course-program .course-program__head,
:is(#kids-program, #imx-program) .course-program__head,
#course-faq .course-program__head,
:is(#kids-faq, #imx-faq) .course-program__head {
  text-align: center;
  max-width: 40rem;
  margin: 0 auto clamp(2rem, 4vw, 2.75rem);
}

#course-program .course-program__kicker,
:is(#kids-program, #imx-program) .course-program__kicker,
#course-faq .course-program__kicker,
:is(#kids-faq, #imx-faq) .course-program__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#course-program .course-program__title,
:is(#kids-program, #imx-program) .course-program__title,
#course-faq .course-program__title,
:is(#kids-faq, #imx-faq) .course-program__title {
  margin: 0 0 0.85rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 22px rgba(0, 0, 0, 0.35);
}

#course-faq .course-program__title:last-child,
:is(#kids-faq, #imx-faq) .course-program__title:last-child {
  margin-bottom: 0;
}

#course-program .course-program__intro,
:is(#kids-program, #imx-program) .course-program__intro,
:is(#kids-faq, #imx-faq) .course-program__intro {
  margin: 0;
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-program .course-program__track,
:is(#kids-program, #imx-program) .course-program__track {
  position: relative;
}

#course-program .course-program__list,
:is(#kids-program, #imx-program) .course-program__list,
#course-faq .course-program__list,
:is(#kids-faq, #imx-faq) .course-program__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(1.15rem, 2.8vw, 1.85rem);
}

#course-program .course-program__list::before,
:is(#kids-program, #imx-program) .course-program__list::before {
  content: "";
  position: absolute;
  left: calc(1.5rem - 1px);
  top: 0.75rem;
  bottom: 0.75rem;
  width: 3px;
  margin-left: -1px;
  border-radius: 3px;
  background: linear-gradient(
    180deg,
    rgba(0, 255, 209, 0.5) 0%,
    rgba(108, 99, 255, 0.35) 48%,
    rgba(0, 255, 209, 0.38) 100%
  );
  box-shadow: 0 0 18px rgba(0, 255, 209, 0.12);
  pointer-events: none;
}

#course-program .course-program__item,
:is(#kids-program, #imx-program) .course-program__item {
  display: grid;
  grid-template-columns: 3rem minmax(0, 1fr);
  gap: clamp(0.85rem, 2.5vw, 1.35rem);
  align-items: start;
}

#course-faq .course-program__item,
:is(#kids-faq, #imx-faq) .course-program__item {
  display: block;
}

#course-program .course-program__marker,
:is(#kids-program, #imx-program) .course-program__marker {
  position: relative;
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

#course-program .course-program__marker-ring,
:is(#kids-program, #imx-program) .course-program__marker-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: linear-gradient(145deg, rgba(12, 16, 36, 0.95), rgba(6, 10, 28, 0.98));
  border: 2px solid rgba(0, 255, 209, 0.35);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.35),
    0 8px 24px rgba(0, 0, 0, 0.35);
}

#course-program .course-program__item.is-open .course-program__marker-ring,
:is(#kids-program, #imx-program) .course-program__item.is-open .course-program__marker-ring {
  border-color: rgba(0, 255, 209, 0.55);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.35),
    0 0 22px rgba(0, 255, 209, 0.18),
    0 8px 24px rgba(0, 0, 0, 0.35);
}

#course-program .course-program__icon,
:is(#kids-program, #imx-program) .course-program__icon {
  position: relative;
  width: 1.35rem;
  height: 1.35rem;
  color: var(--artvoic-accent);
}

#course-program .course-program__body,
:is(#kids-program, #imx-program) .course-program__body,
#course-faq .course-program__body,
:is(#kids-faq, #imx-faq) .course-program__body {
  min-width: 0;
  border-radius: 18px;
  padding: 0;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.07);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
  overflow: hidden;
}

#course-program .course-program__item-title,
:is(#kids-program, #imx-program) .course-program__item-title,
#course-faq .course-program__item-title,
:is(#kids-faq, #imx-faq) .course-program__item-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
}

#course-program .course-program__trigger,
:is(#kids-program, #imx-program) .course-program__trigger,
#course-faq .course-program__trigger,
:is(#kids-faq, #imx-faq) .course-program__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: clamp(1rem, 2.2vw, 1.2rem) clamp(1rem, 2.5vw, 1.35rem);
  margin: 0;
  border: none;
  background: rgba(255, 255, 255, 0.03);
  color: var(--artvoic-text);
  font: inherit;
  font-weight: 600;
  font-size: clamp(0.95rem, 0.25vw + 0.88rem, 1.06rem);
  line-height: 1.3;
  text-align: left;
  cursor: pointer;
  transition:
    background 0.25s var(--cp-ease),
    color 0.25s var(--cp-ease),
    text-shadow 0.25s var(--cp-ease);
}

#course-faq .course-program__trigger,
:is(#kids-faq, #imx-faq) .course-program__trigger {
  font-weight: 700;
}

#course-program .course-program__trigger:hover,
:is(#kids-program, #imx-program) .course-program__trigger:hover {
  background: rgba(255, 255, 255, 0.055);
}

#course-faq .course-program__trigger:hover,
:is(#kids-faq, #imx-faq) .course-program__trigger:hover {
  color: var(--artvoic-accent);
  text-shadow:
    0 0 18px rgba(0, 255, 209, 0.45),
    0 0 36px rgba(0, 255, 209, 0.2);
  background: rgba(0, 255, 209, 0.06);
}

#course-program .course-program__trigger:focus-visible,
:is(#kids-program, #imx-program) .course-program__trigger:focus-visible,
#course-faq .course-program__trigger:focus-visible,
:is(#kids-faq, #imx-faq) .course-program__trigger:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}

#course-program .course-program__chevron,
:is(#kids-program, #imx-program) .course-program__chevron,
#course-faq .course-program__chevron,
:is(#kids-faq, #imx-faq) .course-program__chevron {
  flex-shrink: 0;
  width: 0.55rem;
  height: 0.55rem;
  border-right: 2px solid var(--artvoic-accent);
  border-bottom: 2px solid var(--artvoic-accent);
  transform: rotate(-45deg);
  margin-top: -0.2rem;
  opacity: 0.85;
  transition: transform 0.35s var(--cp-ease);
}

#course-program .course-program__item.is-open .course-program__chevron,
:is(#kids-program, #imx-program) .course-program__item.is-open .course-program__chevron,
#course-faq .course-program__item.is-open .course-program__chevron,
:is(#kids-faq, #imx-faq) .course-program__item.is-open .course-program__chevron {
  transform: rotate(45deg);
  margin-top: 0.15rem;
}

#course-program .course-program__panel,
:is(#kids-program, #imx-program) .course-program__panel,
#course-faq .course-program__panel,
:is(#kids-faq, #imx-faq) .course-program__panel {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows var(--cp-panel);
}

#course-program .course-program__panel-inner,
:is(#kids-program, #imx-program) .course-program__panel-inner,
#course-faq .course-program__panel-inner,
:is(#kids-faq, #imx-faq) .course-program__panel-inner {
  overflow: hidden;
  min-height: 0;
  padding: 0 clamp(1rem, 2.5vw, 1.35rem) clamp(1.1rem, 2.5vw, 1.35rem);
}

#course-faq .course-program__panel-inner,
:is(#kids-faq, #imx-faq) .course-program__panel-inner {
  padding-top: 0;
}

#course-faq .course-program__item:not(.is-open) .course-program__panel,
:is(#kids-faq, #imx-faq) .course-program__item:not(.is-open) .course-program__panel {
  grid-template-rows: 0fr;
  min-height: 0;
  overflow: hidden;
}

#course-faq .course-program__item:not(.is-open) .course-program__panel-inner,
:is(#kids-faq, #imx-faq) .course-program__item:not(.is-open) .course-program__panel-inner {
  padding: 0;
  margin: 0;
}

#course-faq .course-program__item.is-open .course-program__panel,
:is(#kids-faq, #imx-faq) .course-program__item.is-open .course-program__panel {
  grid-template-rows: 1fr;
}

#course-program .course-program__label,
:is(#kids-program, #imx-program) .course-program__label {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
}

#course-program .course-program__label:not(:first-child),
:is(#kids-program, #imx-program) .course-program__label:not(:first-child) {
  margin-top: 1.1rem;
}

#course-program .course-program__lead,
:is(#kids-program, #imx-program) .course-program__lead,
#course-faq .course-program__lead,
:is(#kids-faq, #imx-faq) .course-program__lead {
  margin: 0;
  font-size: clamp(0.9rem, 0.22vw + 0.85rem, 0.98rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-faq .course-program__panel-inner .course-program__lead,
:is(#kids-faq, #imx-faq) .course-program__panel-inner .course-program__lead {
  font-size: clamp(0.86rem, 0.2vw + 0.8rem, 0.94rem);
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 400;
}

#course-program .course-program__bullets,
:is(#kids-program, #imx-program) .course-program__bullets {
  margin: 0.35rem 0 0;
  padding-left: 1.15rem;
  font-size: clamp(0.88rem, 0.2vw + 0.82rem, 0.95rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.82);
}

#course-program .course-program__bullets li,
:is(#kids-program, #imx-program) .course-program__bullets li {
  margin-bottom: 0.45rem;
}

#course-program .course-program__bullets li:last-child,
:is(#kids-program, #imx-program) .course-program__bullets li:last-child {
  margin-bottom: 0;
}

#course-program .course-program__result,
:is(#kids-program, #imx-program) .course-program__result {
  margin: 1.15rem 0 0;
  padding: 0.95rem 1.05rem;
  border-radius: 12px;
  border-left: 3px solid var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.07);
  font-size: clamp(0.9rem, 0.22vw + 0.84rem, 0.98rem);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.88);
}

#course-program .course-program__result strong,
:is(#kids-program, #imx-program) .course-program__result strong {
  display: block;
  margin-bottom: 0.4rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(0.88rem, 0.18vw + 0.82rem, 0.96rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--artvoic-accent);
}

@media (max-width: 900px) {
  #course-program .course-program__item:not(.is-open) .course-program__panel,
  :is(#kids-program, #imx-program) .course-program__item:not(.is-open) .course-program__panel {
    grid-template-rows: 0fr;
  }

  #course-program .course-program__item.is-open .course-program__panel,
  :is(#kids-program, #imx-program) .course-program__item.is-open .course-program__panel {
    grid-template-rows: 1fr;
  }
}

@media (min-width: 901px) {
  #course-program .course-program__panel,
  :is(#kids-program, #imx-program) .course-program__panel {
    grid-template-rows: 1fr;
  }

  #course-program .course-program__chevron,
  :is(#kids-program, #imx-program) .course-program__chevron {
    display: none;
  }

  #course-program .course-program__trigger,
  :is(#kids-program, #imx-program) .course-program__trigger {
    cursor: default;
    pointer-events: none;
  }

  #course-program .course-program__trigger:hover,
  :is(#kids-program, #imx-program) .course-program__trigger:hover {
    background: rgba(255, 255, 255, 0.03);
  }

  #course-faq .course-program__chevron,
  :is(#kids-faq, #imx-faq) .course-program__chevron {
    display: block;
  }

  #course-faq .course-program__trigger,
  :is(#kids-faq, #imx-faq) .course-program__trigger {
    cursor: pointer;
    pointer-events: auto;
  }

  #course-faq .course-program__trigger:hover,
  :is(#kids-faq, #imx-faq) .course-program__trigger:hover {
    color: var(--artvoic-accent);
    text-shadow:
      0 0 18px rgba(0, 255, 209, 0.45),
      0 0 36px rgba(0, 255, 209, 0.2);
    background: rgba(0, 255, 209, 0.06);
  }
}

@media (max-width: 520px) {
  #course-program .course-program__list::before,
  :is(#kids-program, #imx-program) .course-program__list::before {
    left: calc(1.25rem - 1px);
  }

  #course-program .course-program__item,
  :is(#kids-program, #imx-program) .course-program__item {
    grid-template-columns: 2.6rem minmax(0, 1fr);
    gap: 0.75rem;
  }

  #course-program .course-program__marker,
  :is(#kids-program, #imx-program) .course-program__marker {
    width: 2.6rem;
    height: 2.6rem;
  }

  #course-program .course-program__icon,
  :is(#kids-program, #imx-program) .course-program__icon {
    width: 1.2rem;
    height: 1.2rem;
  }
}

/* --- course-pricing: тарифы (между программой и «Как проходит процесс») --- */

@keyframes course-pricing-aurora {
  0% {
    transform: translate3d(0.4%, -0.3%, 0) scale(1);
  }
  100% {
    transform: translate3d(-0.9%, 0.5%, 0) scale(1.03);
  }
}

@keyframes course-pricing-breath {
  0%,
  100% {
    opacity: 0.38;
    transform: scale(1);
  }
  50% {
    opacity: 0.52;
    transform: scale(1.05);
  }
}

#course-pricing {
  --cpz-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --cpz-card: #1a1a1a;
  --cpz-vip-gold: #e8c872;
  --cpz-vip-gold-dim: rgba(232, 200, 114, 0.55);

  position: relative;
  /* Верх: как низ «Студии в кармане» (чёрный / поверхность кармана), без цветного «ободка» */
  background: linear-gradient(
    180deg,
    var(--artvoic-bg) 0%,
    var(--course-pocket-surface) min(18%, 140px),
    var(--course-pricing-base) 38%,
    var(--directions-hub-base) 100%
  );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#course-pricing .course-pricing__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#course-pricing .course-pricing__aurora {
  position: absolute;
  inset: -28% -20% -24% -20%;
  transform-origin: 55% 35%;
  background:
    radial-gradient(ellipse 44% 40% at 20% 30%, rgba(0, 255, 209, 0.09), transparent 54%),
    radial-gradient(ellipse 48% 42% at 78% 65%, rgba(108, 99, 255, 0.11), transparent 52%),
    radial-gradient(ellipse 42% 38% at 50% 50%, rgba(232, 200, 114, 0.06), transparent 56%);
  filter: blur(46px);
  animation: course-pricing-aurora 22s ease-in-out infinite alternate;
  animation-delay: -3s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 12%,
    #000 26%,
    #000 78%,
    rgba(0, 0, 0, 0.4) 92%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 12%,
    #000 26%,
    #000 78%,
    rgba(0, 0, 0, 0.4) 92%,
    transparent 100%
  );
}

#course-pricing .course-pricing__glow {
  position: absolute;
  top: 22%;
  left: -8%;
  width: min(46vw, 420px);
  height: min(46vw, 420px);
  background: radial-gradient(circle, rgba(0, 255, 209, 0.1) 0%, rgba(60, 50, 120, 0.06) 50%, transparent 68%);
  filter: blur(58px);
  animation: course-pricing-breath 15s ease-in-out infinite;
  animation-delay: -6s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 14%,
    #000 32%,
    #000 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 14%,
    #000 32%,
    #000 100%
  );
}

#course-pricing .course-pricing__glow::after {
  content: "";
  position: absolute;
  right: -110%;
  bottom: -25%;
  width: min(40vw, 360px);
  height: min(40vw, 360px);
  background: radial-gradient(circle, rgba(232, 200, 114, 0.08) 0%, transparent 65%);
  filter: blur(52px);
  animation: course-pricing-breath 17s ease-in-out infinite reverse;
  animation-delay: -9s;
}

#course-pricing .course-pricing__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      var(--artvoic-bg) 0%,
      rgba(10, 10, 12, 0) min(28%, 300px)
    ),
    radial-gradient(ellipse 100% 88% at 50% 42%, transparent 0%, rgba(5, 5, 12, 0.35) 62%, rgba(5, 5, 8, 0.55) 100%);
}

#course-pricing .course-pricing__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(2.5rem, 5vw, 4rem) clamp(1.25rem, 5vw, 5rem) clamp(2.75rem, 5.5vw, 4.25rem);
}

#course-pricing .course-pricing__head {
  text-align: center;
  max-width: 44rem;
  margin: 0 auto clamp(2rem, 4vw, 2.85rem);
}

#course-pricing .course-pricing__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#course-pricing .course-pricing__title {
  margin: 0 0 0.85rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 22px rgba(0, 0, 0, 0.35);
}

#course-pricing .course-pricing__intro {
  margin: 0;
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-pricing .course-pricing__scroller {
  margin-bottom: clamp(1.75rem, 3.5vw, 2.5rem);
}

#course-pricing .course-pricing__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
  align-items: stretch;
}

#course-pricing .course-pricing__cell {
  min-width: 0;
  display: flex;
}

#course-pricing .course-pricing__cell--featured {
  position: relative;
  z-index: 1;
}

#course-pricing .course-pricing__featured-shell {
  position: relative;
  width: 100%;
  padding: 3px;
  border-radius: 1.625rem;
  background: linear-gradient(
    135deg,
    rgba(0, 255, 209, 0.95) 0%,
    rgba(108, 99, 255, 0.85) 45%,
    rgba(0, 255, 209, 0.75) 100%
  );
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.25),
    0 20px 56px rgba(0, 255, 209, 0.12),
    0 24px 64px rgba(0, 0, 0, 0.35);
}

#course-pricing .course-pricing__badge {
  position: absolute;
  top: -11px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  padding: 0.35rem 1rem 0.4rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--artvoic-bg);
  background: linear-gradient(180deg, #00ffe0 0%, var(--artvoic-accent) 100%);
  border-radius: 999px;
  box-shadow:
    0 2px 0 rgba(0, 0, 0, 0.22),
    0 8px 28px rgba(0, 255, 209, 0.35);
  white-space: nowrap;
}

#course-pricing .course-pricing__card {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: clamp(1.35rem, 2.8vw, 1.75rem);
  background: var(--cpz-card);
  border-radius: 1.5rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.35);
}

#course-pricing .course-pricing__card--featured {
  border: none;
  border-radius: calc(1.5rem - 3px);
  box-shadow: none;
  padding-top: clamp(1.6rem, 3vw, 2rem);
}

#course-pricing .course-pricing__card--vip {
  position: relative;
  background:
    linear-gradient(160deg, rgba(232, 200, 114, 0.07) 0%, transparent 42%),
    linear-gradient(180deg, #141018 0%, var(--cpz-card) 38%);
  border: 1px solid rgba(232, 200, 114, 0.28);
  box-shadow:
    0 0 0 1px rgba(232, 200, 114, 0.06),
    0 24px 56px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

#course-pricing .course-pricing__vip-ribbon {
  margin: 0 0 0.35rem;
  font-family: var(--artvoic-font-display);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--cpz-vip-gold-dim);
}

#course-pricing .course-pricing__name {
  margin: 0 0 0.35rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.05rem, 0.35vw + 0.95rem, 1.2rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
}

#course-pricing .course-pricing__card--vip .course-pricing__name {
  font-size: clamp(1.1rem, 0.4vw + 1rem, 1.28rem);
  letter-spacing: -0.01em;
}

#course-pricing .course-pricing__tagline {
  margin: 0 0 1.1rem;
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--artvoic-text-muted);
}

#course-pricing .course-pricing__price {
  margin: 0 0 1.25rem;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

#course-pricing .course-pricing__price-num {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: clamp(2rem, 1.15vw + 1.55rem, 2.45rem);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
}

#course-pricing .course-pricing__price--vip .course-pricing__price-num {
  font-size: clamp(2rem, 0.95vw + 1.5rem, 2.2rem);
  background: linear-gradient(110deg, #fff 10%, var(--cpz-vip-gold) 92%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

#course-pricing .course-pricing__price-note {
  display: block;
  margin-top: 0.45rem;
  font-size: 0.78rem;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.55);
  font-weight: 500;
}

#course-pricing .course-pricing__features {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

#course-pricing .course-pricing__features li {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  font-size: 0.89rem;
  line-height: 1.45;
  color: var(--artvoic-text-soft);
}

#course-pricing .course-pricing__check {
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  margin-top: 0.06rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(0, 255, 209, 0.12);
  color: var(--artvoic-accent);
}

#course-pricing .course-pricing__check svg {
  width: 0.72rem;
  height: 0.72rem;
}

#course-pricing .course-pricing__check--vip {
  background: rgba(232, 200, 114, 0.12);
  color: var(--cpz-vip-gold);
}

#course-pricing .course-pricing__cta-block {
  margin-top: 1.35rem;
  padding-top: 0.25rem;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
}

#course-pricing .course-pricing__cta-note {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.48);
  text-align: center;
}

#course-pricing .course-pricing__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.5rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.92rem;
  text-decoration: none;
  text-align: center;
  border-radius: 2px;
  transition:
    transform 0.25s var(--cpz-ease),
    box-shadow 0.25s var(--cpz-ease),
    background 0.25s var(--cpz-ease),
    color 0.25s var(--cpz-ease),
    border-color 0.25s var(--cpz-ease);
}

#course-pricing .course-pricing__cta--ghost {
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.06);
  border: 2px solid rgba(0, 255, 209, 0.45);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2);
}

#course-pricing .course-pricing__cta--ghost:hover {
  transform: translateY(-2px);
  background: rgba(0, 255, 209, 0.12);
  border-color: rgba(0, 255, 209, 0.65);
}

#course-pricing .course-pricing__cta--ghost:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#course-pricing .course-pricing__cta--vip {
  color: #0a0908;
  background: linear-gradient(180deg, #f0dfa0 0%, var(--cpz-vip-gold) 48%, #c9a24a 100%);
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow:
    0 0 0 1px rgba(232, 200, 114, 0.4),
    0 14px 40px rgba(232, 200, 114, 0.22);
  font-weight: 700;
  letter-spacing: 0.03em;
}

#course-pricing .course-pricing__cta--vip:hover {
  transform: translateY(-2px);
  box-shadow:
    0 0 0 1px rgba(232, 200, 114, 0.55),
    0 18px 48px rgba(232, 200, 114, 0.28);
}

#course-pricing .course-pricing__cta--vip:focus-visible {
  outline: 2px solid var(--cpz-vip-gold);
  outline-offset: 3px;
}

#course-pricing .course-pricing__trust {
  max-width: 44rem;
  margin: 0 auto;
  padding: clamp(1.25rem, 2.5vw, 1.65rem) clamp(1rem, 3vw, 1.5rem);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

#course-pricing .course-pricing__trust-line {
  margin: 0;
  font-size: clamp(0.82rem, 0.22vw + 0.78rem, 0.9rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#course-pricing .course-pricing__trust-line strong {
  color: var(--artvoic-text-soft);
  font-weight: 600;
}

#course-pricing .course-pricing__trust-line + .course-pricing__trust-line {
  margin-top: 0.65rem;
}

@media (min-width: 992px) {
  #course-pricing .course-pricing__cell--featured {
    align-self: flex-start;
    transform: translateY(-16px);
  }
}

@media (min-width: 640px) and (max-width: 991px) {
  #course-pricing .course-pricing__scroller {
    overflow-x: auto;
    overflow-y: visible;
    margin-left: -1rem;
    margin-right: -1rem;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-bottom: 0.5rem;
    scroll-snap-type: x mandatory;
    scrollbar-color: rgba(0, 255, 209, 0.35) rgba(255, 255, 255, 0.06);
    -webkit-overflow-scrolling: touch;
  }

  #course-pricing .course-pricing__grid {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    align-items: stretch;
  }

  #course-pricing .course-pricing__cell {
    flex: 0 0 min(78vw, 320px);
    scroll-snap-align: center;
  }

  #course-pricing .course-pricing__cell--featured {
    flex-basis: min(82vw, 340px);
  }
}

@media (max-width: 639px) {
  #course-pricing .course-pricing__grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  #course-pricing .course-pricing__cell--featured {
    order: -1;
  }
}

/* --- site-footer --- */

/* Elementor: убрать белую щель между секциями (фон колонки, gap flex-контейнеров, --display) */
.elementor-widget-html:has(#site-footer),
.elementor-widget-html:has(#site-footer) > .elementor-widget-container {
  --display: block;
  display: block !important;
}

.elementor-widget-html:has(#site-footer) > .elementor-widget-container {
  margin: 0 !important;
  padding: 0 !important;
}

.elementor-column:has(#site-footer),
.elementor-column:has(.elementor-widget-html #site-footer) {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  background-color: transparent !important;
}

.elementor-section:has(#site-footer),
.e-con:has(#site-footer) {
  margin-top: 0 !important;
  padding-top: 0 !important;
  background-color: transparent !important;
  background-image: none !important;
}

#site-footer {
  position: relative;
  display: block !important;
  /* Перекрытие подсветки фона темы и субпиксельного зазора под предыдущим блоком */
  margin-top: -12px;
  padding-top: calc(12px + 1px);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  isolation: isolate;
  overflow: hidden;
  background-color: var(--site-footer-deep);
  background-image:
    radial-gradient(ellipse 140% 95% at 50% -55%, rgba(0, 255, 209, 0.11), transparent 58%),
    radial-gradient(ellipse 80% 70% at 100% 30%, rgba(108, 99, 255, 0.12), transparent 55%),
    radial-gradient(ellipse 60% 50% at 0% 85%, rgba(0, 255, 209, 0.05), transparent 50%),
    linear-gradient(
      180deg,
      var(--social-proof-base) 0%,
      var(--site-footer-base) min(28%, 180px),
      var(--site-footer-deep) 72%,
      #010106 100%
    );
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

#site-footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 255, 209, 0.18) 22%,
    rgba(108, 99, 255, 0.32) 50%,
    rgba(0, 255, 209, 0.18) 78%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
  opacity: 0.85;
}

#site-footer::after {
  content: "";
  position: absolute;
  inset: -2px 0 auto 0;
  height: min(280px, 42vh);
  background: radial-gradient(ellipse 70% 100% at 50% 0%, rgba(108, 99, 255, 0.06), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

#site-footer .site-footer__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding:
    clamp(2.25rem, 4.2vw, 3.25rem) clamp(1.25rem, 5vw, 5rem)
    clamp(2rem, 4vw, 3rem);
}

#site-footer .site-footer__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(1.75rem, 4vw, 3rem);
  align-items: start;
  padding-bottom: clamp(1.75rem, 3vw, 2.5rem);
}

#site-footer .site-footer__brand {
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2vw, 1.35rem);
}

#site-footer .site-footer__logo-link {
  display: inline-flex;
  align-self: flex-start;
  line-height: 0;
  border-radius: 10px;
  /* Отступ между логотипом и неоновой «рамкой» при hover */
  padding: clamp(0.45rem, 1.2vw, 0.7rem) clamp(0.55rem, 1.6vw, 0.95rem);
  transition:
    opacity 0.2s ease,
    box-shadow 0.25s ease,
    transform 0.25s ease;
}

#site-footer .site-footer__logo-link:hover {
  opacity: 0.95;
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.25), 0 12px 36px rgba(0, 255, 209, 0.08);
}

#site-footer .site-footer__logo-link:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 4px;
}

#site-footer .site-footer__logo {
  display: block;
  width: auto;
  max-width: min(280px, 72vw);
  height: auto;
}

#site-footer .site-footer__copyright {
  margin: 0;
  font-size: clamp(0.82rem, 0.25vw + 0.75rem, 0.9rem);
  font-weight: 500;
  line-height: 1.5;
  color: var(--artvoic-text-muted);
  letter-spacing: 0.02em;
}

#site-footer .site-footer__legal {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-style: normal;
  font-size: clamp(0.75rem, 0.2vw + 0.7rem, 0.82rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.55);
}

#site-footer .site-footer__legal-line {
  display: block;
}

#site-footer .site-footer__contact {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  text-align: right;
  gap: clamp(0.65rem, 1.5vw, 0.9rem);
}

#site-footer .site-footer__contact-lead {
  margin: 0;
  max-width: 22rem;
  font-size: clamp(0.78rem, 0.22vw + 0.72rem, 0.86rem);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.58);
}

#site-footer .site-footer__phone {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.2rem, 2vw + 0.85rem, 1.75rem);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-decoration: none;
  transition:
    color 0.2s ease,
    text-shadow 0.25s ease;
}

#site-footer .site-footer__phone:hover {
  color: var(--artvoic-accent);
  text-shadow: 0 0 28px rgba(0, 255, 209, 0.35);
}

#site-footer .site-footer__phone:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 4px;
  border-radius: 2px;
}

#site-footer .site-footer__schedule {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  max-width: 20rem;
  font-size: clamp(0.75rem, 0.18vw + 0.7rem, 0.82rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.55);
}

#site-footer .site-footer__schedule p {
  margin: 0;
}

#site-footer .site-footer__social {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: flex-end;
  margin: 0.35rem 0 0;
  padding: 0;
  list-style: none;
}

#site-footer .site-footer__social li {
  list-style: none;
  margin: 0;
  padding: 0;
}

#site-footer .site-footer__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 12px;
  color: var(--artvoic-text-muted);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
  transition:
    color 0.2s ease,
    background 0.2s ease,
    border-color 0.2s ease,
    transform 0.25s ease,
    box-shadow 0.25s ease;
}

#site-footer .site-footer__social-link:hover {
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.1);
  border-color: rgba(0, 255, 209, 0.35);
  transform: translateY(-2px);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.2),
    0 12px 32px rgba(0, 255, 209, 0.12);
}

#site-footer .site-footer__social-link:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}

#site-footer .site-footer__social-icon {
  width: 1.15rem;
  height: 1.15rem;
}

#site-footer .site-footer__nav {
  padding-top: clamp(1.35rem, 2.5vw, 1.75rem);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

#site-footer .site-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem clamp(0.35rem, 1.5vw, 0.85rem);
  margin: 0;
  padding: 0;
  list-style: none;
  justify-content: flex-start;
  align-items: baseline;
}

#site-footer .site-footer__links li {
  position: relative;
  display: inline-flex;
  align-items: center;
  max-width: 100%;
}

#site-footer .site-footer__links li:not(:last-child)::after {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  margin-left: clamp(0.35rem, 1.5vw, 0.85rem);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  flex-shrink: 0;
}

#site-footer .site-footer__links a {
  font-size: clamp(0.72rem, 0.18vw + 0.68rem, 0.8rem);
  line-height: 1.45;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.58);
  text-decoration: none;
  text-underline-offset: 0.2em;
  transition:
    color 0.2s ease,
    text-decoration-color 0.2s ease;
}

#site-footer .site-footer__links a:hover {
  color: var(--artvoic-accent);
  text-decoration: underline;
  text-decoration-color: rgba(0, 255, 209, 0.55);
}

#site-footer .site-footer__links a:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
  border-radius: 2px;
}

@media (max-width: 768px) {
  #site-footer .site-footer__top {
    grid-template-columns: 1fr;
  }

  #site-footer .site-footer__contact {
    align-items: flex-start;
    text-align: left;
  }

  #site-footer .site-footer__social {
    justify-content: flex-start;
  }

  #site-footer .site-footer__links {
    flex-direction: column;
    align-items: stretch;
    gap: 0.15rem;
  }

  #site-footer .site-footer__links li:not(:last-child)::after {
    display: none;
  }

  #site-footer .site-footer__links a {
    display: block;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  }

  #site-footer .site-footer__links li:last-child a {
    border-bottom: none;
  }
}

@media (min-width: 769px) and (max-width: 900px) {
  #site-footer .site-footer__links {
    column-gap: 0.5rem;
    row-gap: 0.65rem;
  }
}


/* --- kids-pricing: детский лендинг (классы .course-pricing__*) --- */
/* --- course-pricing: тарифы (между программой и «Как проходит процесс») --- */

@keyframes course-pricing-aurora {
  0% {
    transform: translate3d(0.4%, -0.3%, 0) scale(1);
  }
  100% {
    transform: translate3d(-0.9%, 0.5%, 0) scale(1.03);
  }
}

@keyframes course-pricing-breath {
  0%,
  100% {
    opacity: 0.38;
    transform: scale(1);
  }
  50% {
    opacity: 0.52;
    transform: scale(1.05);
  }
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) {
  --cpz-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --cpz-card: #1a1a1a;
  --cpz-vip-gold: #e8c872;
  --cpz-vip-gold-dim: rgba(232, 200, 114, 0.55);

  position: relative;
  /* Верх = низ #kids-faq (kids-pricing-base), без нижней волны — бесшовный стык */
  background: linear-gradient(
    180deg,
    var(--kids-pricing-base) 0%,
    var(--kids-pricing-base) 40%,
    var(--artvoic-bg) 100%
  );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  /* Верх — ровный стык с #kids-faq (ниже — декор как обычно) */
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 clamp(72px, 14vh, 140px), #000 100%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 clamp(72px, 14vh, 140px), #000 100%);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__aurora {
  position: absolute;
  inset: -28% -20% -24% -20%;
  transform-origin: 55% 35%;
  background:
    radial-gradient(ellipse 44% 40% at 20% 30%, rgba(0, 255, 209, 0.09), transparent 54%),
    radial-gradient(ellipse 48% 42% at 78% 65%, rgba(108, 99, 255, 0.11), transparent 52%),
    radial-gradient(ellipse 42% 38% at 50% 50%, rgba(232, 200, 114, 0.06), transparent 56%);
  filter: blur(46px);
  animation: course-pricing-aurora 22s ease-in-out infinite alternate;
  animation-delay: -3s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 12%,
    #000 26%,
    #000 78%,
    rgba(0, 0, 0, 0.4) 92%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 12%,
    #000 26%,
    #000 78%,
    rgba(0, 0, 0, 0.4) 92%,
    transparent 100%
  );
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__glow {
  position: absolute;
  top: 22%;
  left: -8%;
  width: min(46vw, 420px);
  height: min(46vw, 420px);
  background: radial-gradient(circle, rgba(0, 255, 209, 0.1) 0%, rgba(60, 50, 120, 0.06) 50%, transparent 68%);
  filter: blur(58px);
  animation: course-pricing-breath 15s ease-in-out infinite;
  animation-delay: -6s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 14%,
    #000 32%,
    #000 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 14%,
    #000 32%,
    #000 100%
  );
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__glow::after {
  content: "";
  position: absolute;
  right: -110%;
  bottom: -25%;
  width: min(40vw, 360px);
  height: min(40vw, 360px);
  background: radial-gradient(circle, rgba(232, 200, 114, 0.08) 0%, transparent 65%);
  filter: blur(52px);
  animation: course-pricing-breath 17s ease-in-out infinite reverse;
  animation-delay: -9s;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      var(--kids-pricing-base) 0%,
      rgba(10, 10, 12, 0) min(28%, 300px)
    ),
    radial-gradient(ellipse 100% 88% at 50% 42%, transparent 0%, rgba(5, 5, 12, 0.35) 62%, rgba(5, 5, 8, 0.55) 100%);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(2.5rem, 5vw, 4rem) clamp(1.25rem, 5vw, 5rem) clamp(2.75rem, 5.5vw, 4.25rem);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__head {
  text-align: center;
  max-width: 44rem;
  margin: 0 auto clamp(2rem, 4vw, 2.85rem);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.68rem, 0.35vw + 0.62rem, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__title {
  margin: 0 0 0.85rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 0.55vw + 1.25rem, 2rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 22px rgba(0, 0, 0, 0.35);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__intro {
  margin: 0;
  font-size: clamp(0.92rem, 0.28vw + 0.84rem, 1.02rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__scroller {
  margin-bottom: clamp(1.75rem, 3.5vw, 2.5rem);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
  align-items: stretch;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cell {
  min-width: 0;
  display: flex;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cell--featured {
  position: relative;
  z-index: 1;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__featured-shell {
  position: relative;
  width: 100%;
  padding: 3px;
  border-radius: 1.625rem;
  background: linear-gradient(
    135deg,
    rgba(0, 255, 209, 0.95) 0%,
    rgba(108, 99, 255, 0.85) 45%,
    rgba(0, 255, 209, 0.75) 100%
  );
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.25),
    0 20px 56px rgba(0, 255, 209, 0.12),
    0 24px 64px rgba(0, 0, 0, 0.35);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__badge {
  position: absolute;
  top: -11px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  padding: 0.35rem 1rem 0.4rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--artvoic-bg);
  background: linear-gradient(180deg, #00ffe0 0%, var(--artvoic-accent) 100%);
  border-radius: 999px;
  box-shadow:
    0 2px 0 rgba(0, 0, 0, 0.22),
    0 8px 28px rgba(0, 255, 209, 0.35);
  white-space: nowrap;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__card {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: clamp(1.35rem, 2.8vw, 1.75rem);
  background: var(--cpz-card);
  border-radius: 1.5rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.35);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__card--featured {
  border: none;
  border-radius: calc(1.5rem - 3px);
  box-shadow: none;
  padding-top: clamp(1.6rem, 3vw, 2rem);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__card--vip {
  position: relative;
  background:
    linear-gradient(160deg, rgba(232, 200, 114, 0.07) 0%, transparent 42%),
    linear-gradient(180deg, #141018 0%, var(--cpz-card) 38%);
  border: 1px solid rgba(232, 200, 114, 0.28);
  box-shadow:
    0 0 0 1px rgba(232, 200, 114, 0.06),
    0 24px 56px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__vip-ribbon {
  margin: 0 0 0.35rem;
  font-family: var(--artvoic-font-display);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--cpz-vip-gold-dim);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__name {
  margin: 0 0 0.35rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.05rem, 0.35vw + 0.95rem, 1.2rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__card--vip .course-pricing__name {
  font-size: clamp(1.1rem, 0.4vw + 1rem, 1.28rem);
  letter-spacing: -0.01em;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__tagline {
  margin: 0 0 1.1rem;
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--artvoic-text-muted);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__price {
  margin: 0 0 1.25rem;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__price-num {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: clamp(2rem, 1.15vw + 1.55rem, 2.45rem);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__price--vip .course-pricing__price-num {
  font-size: clamp(2rem, 0.95vw + 1.5rem, 2.2rem);
  background: linear-gradient(110deg, #fff 10%, var(--cpz-vip-gold) 92%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__price-note {
  display: block;
  margin-top: 0.45rem;
  font-size: 0.78rem;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.55);
  font-weight: 500;
}

/* Детский тариф: меньший кегль, чтобы сумма и ₽ умещались в строку карточки */
#kids-pricing .course-pricing__price-num {
  font-size: clamp(1.45rem, 0.75vw + 1.05rem, 1.8rem);
  line-height: 1.12;
}

#kids-pricing .course-pricing__price--vip .course-pricing__price-num {
  font-size: clamp(1.45rem, 0.65vw + 1rem, 1.72rem);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__features {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__features li {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  font-size: 0.89rem;
  line-height: 1.45;
  color: var(--artvoic-text-soft);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__check {
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  margin-top: 0.06rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(0, 255, 209, 0.12);
  color: var(--artvoic-accent);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__check svg {
  width: 0.72rem;
  height: 0.72rem;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__check--vip {
  background: rgba(232, 200, 114, 0.12);
  color: var(--cpz-vip-gold);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta-block {
  margin-top: 1.35rem;
  padding-top: 0.25rem;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta-note {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.48);
  text-align: center;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.5rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.92rem;
  text-decoration: none;
  text-align: center;
  border-radius: 2px;
  transition:
    transform 0.25s var(--cpz-ease),
    box-shadow 0.25s var(--cpz-ease),
    background 0.25s var(--cpz-ease),
    color 0.25s var(--cpz-ease),
    border-color 0.25s var(--cpz-ease);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--ghost {
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.06);
  border: 2px solid rgba(0, 255, 209, 0.45);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--ghost:hover {
  transform: translateY(-2px);
  background: rgba(0, 255, 209, 0.12);
  border-color: rgba(0, 255, 209, 0.65);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--ghost:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--vip {
  color: #0a0908;
  background: linear-gradient(180deg, #f0dfa0 0%, var(--cpz-vip-gold) 48%, #c9a24a 100%);
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow:
    0 0 0 1px rgba(232, 200, 114, 0.4),
    0 14px 40px rgba(232, 200, 114, 0.22);
  font-weight: 700;
  letter-spacing: 0.03em;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--vip:hover {
  transform: translateY(-2px);
  box-shadow:
    0 0 0 1px rgba(232, 200, 114, 0.55),
    0 18px 48px rgba(232, 200, 114, 0.28);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cta--vip:focus-visible {
  outline: 2px solid var(--cpz-vip-gold);
  outline-offset: 3px;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__trust {
  max-width: 44rem;
  margin: 0 auto;
  padding: clamp(1.25rem, 2.5vw, 1.65rem) clamp(1rem, 3vw, 1.5rem);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__trust-line {
  margin: 0;
  font-size: clamp(0.82rem, 0.22vw + 0.78rem, 0.9rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__trust-line strong {
  color: var(--artvoic-text-soft);
  font-weight: 600;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__trust-line + .course-pricing__trust-line {
  margin-top: 0.65rem;
}

/* Персональный коучинг: место между «Честность…» и нижней волной */
#pco-pricing .course-pricing__inner {
  padding-bottom: calc(
    clamp(2.75rem, 5.5vw, 4.25rem) + clamp(64px, 11vh, 108px) + clamp(0.75rem, 2.5vw, 1.5rem)
  );
}

@media (min-width: 992px) {
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cell--featured {
    align-self: flex-start;
    transform: translateY(-16px);
  }
}

@media (min-width: 640px) and (max-width: 991px) {
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__scroller {
    overflow-x: auto;
    overflow-y: visible;
    margin-left: -1rem;
    margin-right: -1rem;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-bottom: 0.5rem;
    scroll-snap-type: x mandatory;
    scrollbar-color: rgba(0, 255, 209, 0.35) rgba(255, 255, 255, 0.06);
    -webkit-overflow-scrolling: touch;
  }

  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__grid {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    align-items: stretch;
  }

  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cell {
    flex: 0 0 min(78vw, 320px);
    scroll-snap-align: center;
  }

  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cell--featured {
    flex-basis: min(82vw, 340px);
  }
}

@media (max-width: 639px) {
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cell--featured {
    order: -1;
  }
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .kids-pricing__lead {
  margin-top: clamp(2rem, 4vw, 3rem);
  padding: clamp(1.35rem, 3vw, 2rem) clamp(1.25rem, 3vw, 2rem);
  border-radius: 1.25rem;
  background: rgba(0, 255, 209, 0.06);
  border: 1px solid rgba(0, 255, 209, 0.22);
  text-align: center;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .kids-pricing__lead-title {
  margin: 0 0 0.5rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.05rem, 0.4vw + 0.95rem, 1.35rem);
  font-weight: 600;
  color: #fff;
  text-shadow: 0 1px 22px rgba(0, 0, 0, 0.4);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .kids-pricing__lead-text {
  margin: 0 0 1rem;
  font-size: clamp(0.88rem, 0.25vw + 0.82rem, 0.98rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .kids-pricing__lead-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 1.5rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-radius: 2px;
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.35),
    0 10px 36px rgba(0, 255, 209, 0.12);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .kids-pricing__lead-cta:hover {
  transform: translateY(-2px);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .kids-pricing__lead-cta:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

@media (max-width: 1100px) {
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Персональный коучинг: всегда три равные колонки на планшете/десктопе (в общем блоке выше — 2 колонки при ≤1100px). */
@media (min-width: 641px) {
  #pco-pricing .course-pricing__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__grid {
    grid-template-columns: 1fr;
  }
}


@media (min-width: 1101px) {
  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__grid {
    align-items: stretch;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  /* Три тарифа — не 4-колоночная сетка kids-лендинга */
  #pco-pricing .course-pricing__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  :is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__cell--featured .course-pricing__featured-shell {
    min-height: 100%;
  }
}

/* Центральная карточка: без translateY и без подъёма по z-index — иначе перекрывает соседние при узких колонках */
#pco-pricing .course-pricing__cell--featured {
  transform: none;
  align-self: stretch;
  z-index: 0;
}

/* Персональный коучинг: чуть компактнее заголовки карточек — длинные слова («Индивидуально») не распирают колонку */
#pco-pricing .course-pricing__name {
  font-size: clamp(0.98rem, 0.28vw + 0.88rem, 1.1rem);
}

#pco-pricing .course-pricing__card--vip .course-pricing__name {
  font-size: clamp(1.02rem, 0.32vw + 0.92rem, 1.15rem);
}

#pco-pricing .course-pricing__price-num {
  font-size: clamp(1.5rem, 0.75vw + 1.2rem, 1.85rem);
  line-height: 1.18;
  overflow-wrap: break-word;
}

#pco-pricing .course-pricing__price--vip .course-pricing__price-num {
  font-size: clamp(1.45rem, 0.65vw + 1.15rem, 1.75rem);
}

/* ========== Интенсив Москва (#imx-*): фон и уникальная разметка ========== */

#imx-faq {
  background: linear-gradient(
    180deg,
    var(--kids-faq-base) 0%,
    var(--kids-faq-base) 42%,
    #0a0a14 70%,
    var(--artvoic-bg) 100%
  );
}

:is(#imx-value, #pco-advantages) {
  position: relative;
  /* Как #imx-backstage: та же база и «мост» у верхнего края — стык с низом backstage/волны без полосы */
  background: var(--kids-mentor-base);
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

/* Стык с низом #imx-backstage: зеркально к его ::after (там затемнение снизу — здесь сверху, одинаковые стопы) */
:is(#imx-value, #pco-advantages)::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: clamp(88px, 17vh, 200px);
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.58) 0%,
    rgba(0, 0, 0, 0.26) 48%,
    rgba(0, 0, 0, 0.07) 82%,
    transparent 100%
  );
}

/* Ниже шапки — мягкий уход в тон FAQ/тарифов */
:is(#imx-value, #pco-advantages)::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    transparent 0%,
    transparent min(28%, clamp(180px, 28vh, 320px)),
    var(--kids-faq-base) 52%,
    var(--kids-pricing-base) 100%
  );
}

/* Как .kids-studio-videos__glow: лёгкая аврора + маска; над телом ::after, под тёмным «мостом» ::before */
:is(#imx-value, #pco-advantages) .kids-results__bg {
  z-index: 1;
  background:
    radial-gradient(ellipse 50% 42% at 50% 22%, rgba(0, 255, 209, 0.085), transparent 55%),
    radial-gradient(ellipse 40% 38% at 82% 68%, rgba(108, 99, 255, 0.095), transparent 52%);
  filter: blur(40px);
  opacity: 0.9;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.5) 8%,
    #000 20%,
    #000 calc(100% - clamp(88px, 14vh, 140px)),
    rgba(0, 0, 0, 0.45) calc(100% - clamp(56px, 10vh, 96px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.5) 8%,
    #000 20%,
    #000 calc(100% - clamp(88px, 14vh, 140px)),
    rgba(0, 0, 0, 0.45) calc(100% - clamp(56px, 10vh, 96px)),
    transparent 100%
  );
}

:is(#imx-value, #pco-advantages) .kids-results__inner {
  z-index: 3;
}

:is(#imx-value, #pco-advantages) .kids-results__head {
  margin-bottom: clamp(1.75rem, 3vw, 2.5rem);
}

:is(#imx-value, #pco-advantages) .imx-value-list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

:is(#imx-value, #pco-advantages) .imx-value-list > li {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding: 1.1rem 1.2rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

:is(#imx-value, #pco-advantages) .imx-value-list__check {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  display: grid;
  place-items: center;
  border-radius: 10px;
  color: var(--artvoic-bg);
  background: linear-gradient(135deg, var(--artvoic-accent), #00c4a8);
}

:is(#imx-value, #pco-advantages) .imx-value-list__check svg {
  width: 1rem;
  height: 1rem;
}

:is(#imx-value, #pco-advantages) .imx-value-list__name {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 0.35rem;
}

:is(#imx-value, #pco-advantages) .imx-value-list__desc {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.5;
  color: var(--artvoic-text-muted);
}

/* Персональный коучинг: плавный низ «Для кого» → «Почему индивидуальная…» (мост к тону #pco-advantages + волна поверх, как у блока тарифов) */
#pco-audience::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: clamp(140px, 28vh, 320px);
  pointer-events: none;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(6, 11, 30, 0.2) 32%,
    rgba(8, 7, 28, 0.55) 68%,
    var(--kids-mentor-base) 92%,
    var(--kids-mentor-base) 100%
  );
}

#pco-audience .kids-landing__wave {
  z-index: 3;
}

/* После волны #pco-audience — мягче, чем стык с #imx-backstage (тот же логический предыдущий блок отсутствует) */
#pco-advantages::before {
  background: linear-gradient(
    180deg,
    rgba(7, 8, 25, 0.38) 0%,
    rgba(8, 7, 28, 0.14) 50%,
    transparent 100%
  );
  height: clamp(72px, 14vh, 160px);
}

:is(#imx-hero, #pco-hero) .kids-hero__kicker {
  text-shadow: 0 0 28px rgba(0, 255, 209, 0.45);
}

:is(#imx-hero, #pco-hero) .kids-hero__copy {
  max-width: min(42rem, 100%);
}

:is(#imx-hero, #pco-hero) .kids-hero__subtitle {
  margin-bottom: 1.25rem;
}

:is(#imx-hero, #pco-hero) .kids-hero__neon {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 50% at 75% 20%, rgba(0, 255, 209, 0.12), transparent 55%),
    radial-gradient(ellipse 55% 45% at 18% 70%, rgba(108, 99, 255, 0.18), transparent 50%),
    radial-gradient(ellipse 40% 35% at 50% 100%, rgba(0, 255, 209, 0.08), transparent 45%);
  mix-blend-mode: screen;
  opacity: 0.9;
}

:is(#imx-hero, #pco-hero) .kids-hero__triggers {
  list-style: none;
  margin: 0 0 1.35rem;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.6rem, 2vw, 0.85rem);
}

:is(#imx-hero, #pco-hero) .kids-hero__trigger {
  margin: 0;
  min-width: 0;
  padding: 0.75rem 0.85rem;
  border-radius: 14px;
  background: rgba(12, 12, 22, 0.72);
  border: 1px solid rgba(0, 255, 209, 0.22);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

:is(#imx-hero, #pco-hero) .kids-hero__trigger--urgent {
  border-color: rgba(108, 99, 255, 0.45);
  box-shadow:
    0 0 0 1px rgba(108, 99, 255, 0.2),
    0 8px 28px rgba(0, 0, 0, 0.35);
}

:is(#imx-hero, #pco-hero) .kids-hero__trigger-label {
  display: block;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 0.35rem;
}

:is(#imx-hero, #pco-hero) .kids-hero__trigger-value {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: clamp(0.88rem, 0.5vw + 0.8rem, 1.05rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

:is(#imx-hero, #pco-hero) .kids-hero__trigger-note {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.72rem;
  color: var(--artvoic-text-muted);
  line-height: 1.3;
}

:is(#kids-hero, #imx-hero, #pco-hero) .kids-landing__wave {
  z-index: 6;
}

@media (max-width: 900px) {
  :is(#imx-hero, #pco-hero) .kids-hero__triggers {
    grid-template-columns: 1fr;
  }
}

:is(#imx-audience, #pco-audience) .kids-glass__badge {
  display: inline-block;
  margin-left: 0.35rem;
  padding: 0.12rem 0.45rem;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  vertical-align: middle;
  color: var(--artvoic-bg);
  background: var(--artvoic-accent-purple);
  border-radius: 6px;
}

:is(#imx-audience, #pco-audience) .kids-results__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 1024px) {
  :is(#imx-audience, #pco-audience) .kids-results__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  :is(#imx-audience, #pco-audience) .kids-results__grid {
    grid-template-columns: 1fr;
  }
}

#imx-program .course-program__inner {
  padding:
    clamp(2.75rem, 6vw, 4.25rem) clamp(1.25rem, 5vw, 5rem)
    calc(clamp(2.5rem, 5vw, 4rem) + clamp(64px, 11vh, 108px));
}

#imx-program .course-program__head {
  max-width: 46rem;
}

#imx-program .imx-timeline {
  max-width: 720px;
  margin: 0 auto;
  position: relative;
  padding-left: clamp(1.25rem, 4vw, 2rem);
}

#imx-program .imx-timeline::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35rem;
  bottom: 0.35rem;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--artvoic-accent) 0%, var(--artvoic-accent-purple) 45%, rgba(108, 99, 255, 0.35) 100%);
  box-shadow: 0 0 20px rgba(0, 255, 209, 0.35);
}

#imx-program .imx-timeline__day {
  margin-bottom: clamp(2rem, 4vw, 2.75rem);
}

#imx-program .imx-timeline__day:last-child {
  margin-bottom: 0;
}

#imx-program .imx-timeline__day-title {
  margin: 0 0 1.25rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.1rem, 0.4vw + 0.98rem, 1.35rem);
  font-weight: 700;
  color: #fff;
}

#imx-program .imx-timeline__day-num {
  display: inline-block;
  margin-right: 0.5rem;
  padding: 0.15rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--artvoic-bg);
  background: linear-gradient(90deg, var(--artvoic-accent), #8fffea);
  border-radius: 999px;
  vertical-align: middle;
}

#imx-program .imx-timeline__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

#imx-program .imx-timeline__slot {
  display: grid;
  grid-template-columns: minmax(0, 7.5rem) minmax(0, 1fr);
  gap: clamp(0.75rem, 2vw, 1.1rem);
  align-items: start;
  padding: 1rem 1.1rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

#imx-program .imx-timeline__slot--accent {
  border-color: rgba(0, 255, 209, 0.28);
  background: rgba(0, 255, 209, 0.06);
}

#imx-program .imx-timeline__time {
  font-size: clamp(0.78rem, 0.2vw + 0.74rem, 0.88rem);
  font-weight: 700;
  color: var(--artvoic-accent);
  letter-spacing: 0.02em;
  white-space: nowrap;
}

#imx-program .imx-timeline__slot-title {
  display: block;
  font-size: clamp(0.95rem, 0.25vw + 0.88rem, 1.05rem);
  font-weight: 700;
  margin-bottom: 0.35rem;
}

#imx-program .imx-timeline__slot-text {
  margin: 0;
  font-size: clamp(0.86rem, 0.2vw + 0.8rem, 0.94rem);
  line-height: 1.5;
  color: var(--artvoic-text-muted);
}

@media (max-width: 560px) {
  #imx-program .imx-timeline__slot {
    grid-template-columns: 1fr;
  }

  #imx-program .imx-timeline__time {
    white-space: normal;
  }
}

#imx-backstage .imx-backstage__mosaic {
  list-style: none;
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(140px, 1fr));
  gap: clamp(0.65rem, 1.8vw, 1rem);
}

#imx-backstage .imx-backstage__cell {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(0, 255, 209, 0.14);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.4);
}

#imx-backstage .imx-backstage__cell img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 160px;
}

#imx-backstage .imx-backstage__cell--wide {
  grid-column: span 2;
}

#imx-backstage .imx-backstage__cell--tall {
  grid-row: span 2;
}

#imx-backstage .imx-backstage__reel {
  max-width: 920px;
  margin: 0 auto;
}

#imx-backstage .imx-backstage__reel-label {
  margin: 0 0 0.65rem;
  font-size: clamp(0.78rem, 0.22vw + 0.72rem, 0.88rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#imx-backstage .imx-backstage__reel-frame {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 20px 56px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(108, 99, 255, 0.2);
}

#imx-backstage .imx-backstage__reel-video {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #000;
}

#imx-backstage .imx-backstage__reel-hint {
  margin: 0.75rem 0 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.55);
  text-align: center;
}

@media (max-width: 900px) {
  #imx-backstage .imx-backstage__mosaic {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: none;
  }

  #imx-backstage .imx-backstage__cell--tall {
    grid-row: span 1;
  }
}

@media (max-width: 520px) {
  #imx-backstage .imx-backstage__mosaic {
    grid-template-columns: 1fr;
  }

  #imx-backstage .imx-backstage__cell--wide {
    grid-column: span 1;
  }
}

#imx-pricing .course-pricing__scroller {
  display: flex;
  justify-content: center;
}

#imx-pricing .course-pricing__grid {
  grid-template-columns: 1fr;
  max-width: 520px;
  width: 100%;
}

#imx-pricing .course-pricing__price--secondary {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px dashed rgba(255, 255, 255, 0.15);
}

#imx-pricing .course-pricing__price--secondary .course-pricing__price-num {
  color: rgba(255, 255, 255, 0.55);
  font-size: clamp(1.25rem, 0.5vw + 1.05rem, 1.6rem);
}

#imx-pricing .course-pricing__installment {
  margin: 0.85rem 0 0;
  font-size: 0.88rem;
  color: var(--artvoic-text-soft);
}

#imx-faq .imx-faq__map-wrap {
  margin-top: 1rem;
  display: grid;
  gap: 1rem;
}

#imx-faq .imx-faq__map {
  width: 100%;
  max-width: 100%;
  min-height: 220px;
  border: 0;
  border-radius: 12px;
  filter: grayscale(0.2) contrast(1.05);
}

#imx-faq .imx-faq__entrance {
  margin: 0;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

#imx-faq .imx-faq__entrance img {
  display: block;
  width: 100%;
  height: auto;
}

#imx-faq .imx-faq__caption {
  padding: 0.5rem 0.85rem;
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.55);
  background: rgba(0, 0, 0, 0.35);
}

:is(#kids-pricing, #imx-pricing, #pco-pricing) .course-pricing__included-label {
  margin: 1rem 0 0.65rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
}

/* Персональный коучинг (#pco-*): видео и вторая вводная в блоке наставника */
#pco-hero .kids-hero__cta-note a {
  color: rgba(200, 255, 248, 0.95);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

#pco-hero .kids-hero__cta-note a:hover {
  color: #fff;
}

#pco-mentor .pco-mentor__video {
  margin-top: 0;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  aspect-ratio: 16 / 9;
  background: #000;
}

#pco-mentor .pco-mentor__video video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

#pco-mentor .pco-mentor__video-caption {
  margin: 0.65rem 0 0;
  font-size: 0.78rem;
  color: var(--artvoic-text-muted);
  line-height: 1.45;
}

#pco-mentor .pco-mentor__closing {
  margin-top: 1rem;
  margin-bottom: 0;
}

/* ПКО наставник: бесшовный стык с низом #pco-pricing (--artvoic-bg), без верхнего затемнения ::before и без нижней волны */
#pco-mentor {
  background: linear-gradient(
    180deg,
    var(--artvoic-bg) 0%,
    var(--artvoic-bg) min(16%, 100px),
    var(--kids-mentor-base) min(36%, 240px),
    var(--kids-mentor-base) 52%,
    var(--kids-faq-base) 86%,
    var(--kids-faq-base) 100%
  );
}

#pco-mentor::before {
  display: none;
}

/* Аврора ПКО: бирюзовый блик был у самого верха слева — маска резала его горизонтальной «полкой»; ниже центр блика и длинный мягкий вход сверху */
#pco-mentor .kids-mentor__aurora {
  background:
    radial-gradient(ellipse 46% 42% at 28% 38%, rgba(0, 255, 209, 0.072), transparent 58%),
    radial-gradient(ellipse 42% 38% at 72% 78%, rgba(108, 99, 255, 0.1), transparent 50%);
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 6%,
    rgba(0, 0, 0, 0.12) 14%,
    rgba(0, 0, 0, 0.35) 24%,
    rgba(0, 0, 0, 0.62) 34%,
    #000 44%,
    #000 calc(100% - clamp(80px, 16vh, 160px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 6%,
    rgba(0, 0, 0, 0.12) 14%,
    rgba(0, 0, 0, 0.35) 24%,
    rgba(0, 0, 0, 0.62) 34%,
    #000 44%,
    #000 calc(100% - clamp(80px, 16vh, 160px)),
    transparent 100%
  );
}

/* ПКО: вводная на всю ширину; ряд фото | видео+проекты (проекты прижаты к низу колонки); снизу — статы и педагогика на всю ширину */
#pco-mentor .kids-mentor__inner {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-areas:
    "intro intro"
    "visual media"
    "underPhoto underPhoto";
  align-items: start;
  column-gap: clamp(1.25rem, 3vw, 2rem);
  row-gap: clamp(1.1rem, 2vw, 1.45rem);
  padding-bottom: clamp(2.5rem, 5vw, 3.75rem);
}

#pco-mentor .pco-mentor__intro {
  grid-area: intro;
}

#pco-mentor .pco-mentor__intro .kids-mentor__lead {
  margin-bottom: 0;
}

#pco-mentor .kids-mentor__visual {
  grid-area: visual;
}

#pco-mentor .pco-mentor__media-col {
  grid-area: media;
  min-width: 0;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

#pco-mentor .pco-mentor__media-foot {
  margin-top: auto;
  padding-top: clamp(0.85rem, 2.2vw, 1.35rem);
}

#pco-mentor .pco-mentor__media-foot .kids-mentor__logos-label {
  margin-top: 0;
}

#pco-mentor .pco-mentor__under-photo {
  grid-area: underPhoto;
  min-width: 0;
}

#pco-mentor .kids-mentor__photo {
  max-width: none;
  width: 100%;
  margin: 0;
  aspect-ratio: 4 / 5;
}

#pco-mentor .pco-mentor__under-photo .kids-mentor__stats {
  margin-bottom: 0;
}

@media (max-width: 900px) {
  #pco-mentor .kids-mentor__inner {
    grid-template-columns: 1fr;
    grid-template-areas:
      "intro"
      "visual"
      "media"
      "underPhoto";
    row-gap: clamp(1rem, 3vw, 1.35rem);
  }

  #pco-mentor .pco-mentor__media-col {
    align-self: start;
  }

  #pco-mentor .pco-mentor__media-foot {
    margin-top: 0;
    padding-top: clamp(0.35rem, 2vw, 0.65rem);
  }

  #pco-mentor .pco-mentor__intro .kids-mentor__lead {
    margin-bottom: 0;
  }

  #pco-mentor .kids-mentor__photo {
    max-width: min(360px, 88vw);
    margin-left: auto;
    margin-right: auto;
  }
}

/* --- site-header: фиксированный прозрачный бар, лого + гамбургер, панель выезжает справа --- */

@keyframes site-header-panel-aurora {
  0% {
    transform: translate3d(-2%, -1%, 0) scale(1.02);
    opacity: 0.85;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate3d(2%, 1.5%, 0) scale(1.05);
    opacity: 0.9;
  }
}

@keyframes site-header-panel-shimmer {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}

@keyframes site-header-panel-scan {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(100%);
  }
}

@keyframes site-header-nav-pill-sheen {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}

@keyframes site-header-nav-pill-glow {
  0%,
  100% {
    box-shadow:
      0 0 0 1px rgba(0, 255, 209, 0.22),
      0 0 20px rgba(0, 255, 209, 0.06),
      0 6px 24px rgba(8, 12, 40, 0.55),
      inset 0 1px 0 rgba(255, 255, 255, 0.06);
  }
  50% {
    box-shadow:
      0 0 0 1px rgba(0, 255, 209, 0.38),
      0 0 28px rgba(0, 255, 209, 0.14),
      0 10px 32px rgba(30, 20, 70, 0.45),
      inset 0 1px 0 rgba(255, 255, 255, 0.08);
  }
}

.elementor-widget-html:has(#site-header),
.elementor-widget-html:has(#site-header) > .elementor-widget-container {
  --display: block;
  display: block !important;
}

.elementor-widget-html:has(#site-header) > .elementor-widget-container {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

/* Мобилка: контент не уходит под фиксированный бар (лого + отступы хедера) */
@media (max-width: 768px) {
  body:has(#site-header) {
    padding-top: clamp(4.1rem, 20vw, 5.35rem);
  }

  html:has(#site-header) {
    scroll-padding-top: clamp(4.1rem, 20vw, 5.35rem);
  }
}

#site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10050;
  pointer-events: none;
  font-family: var(--artvoic-font-body);
  color: var(--artvoic-text);
}

#site-header * {
  box-sizing: border-box;
}

#site-header .screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

#site-header .site-header__bar {
  pointer-events: auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(0.65rem, 2vw, 1rem) clamp(1rem, 4vw, 2rem) 0;
}

/* Панель меню (drawer) выше по z-index, чем бар без позиции — иначе кнопка-«крестик» оказывается под плашкой. */
#site-header.site-header--open .site-header__bar {
  position: relative;
  z-index: 10060;
}

/* Мобилка: подложка в тон сайта; без скругления — иначе у body просвечивают «углы». */
@media (max-width: 768px) {
  #site-header .site-header__bar {
    align-items: center;
    max-width: none;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding: clamp(0.65rem, 2vw, 0.85rem) clamp(1rem, 4vw, 1.35rem);
    border-radius: 0;
    background: linear-gradient(
      180deg,
      rgba(3, 3, 14, 0.94) 0%,
      rgba(5, 5, 22, 0.88) 55%,
      rgba(5, 5, 22, 0.72) 100%
    );
    border: 1px solid rgba(0, 255, 209, 0.12);
    border-top: none;
    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.04) inset,
      0 12px 40px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    transition:
      background 0.4s ease,
      border-color 0.4s ease,
      box-shadow 0.4s ease,
      backdrop-filter 0.4s ease,
      border-width 0.4s ease;
  }

  /* После скролла: уезжает фон полосы, остаётся только кнопка меню (у неё свой стиль). */
  #site-header.site-header--scrolled:not(.site-header--open) .site-header__bar {
    background: transparent;
    border-color: transparent;
    border-width: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

}

@media (max-width: 768px) and (prefers-reduced-motion: reduce) {
  #site-header .site-header__bar {
    transition-duration: 0.15s;
  }
}

#site-header .site-header__logo-box {
  flex: 0 0 auto;
  min-width: 0;
  transition:
    transform 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.35s ease;
  will-change: transform, opacity;
}

#site-header.site-header--scrolled .site-header__logo-box {
  transform: translateY(calc(-100% - 8px));
  opacity: 0;
  pointer-events: none;
}

/* Пока открыто меню — лого и клик по нему снова видимы (не прячем из-за скролла). */
#site-header.site-header--open .site-header__logo-box {
  transform: none;
  opacity: 1;
  pointer-events: auto;
}

@media (prefers-reduced-motion: reduce) {
  #site-header .site-header__logo-box {
    transition: opacity 0.2s ease;
  }

  #site-header.site-header--scrolled .site-header__logo-box {
    transform: none;
    opacity: 0;
  }

  #site-header.site-header--open .site-header__logo-box {
    opacity: 1;
    pointer-events: auto;
  }
}

#site-header .site-header__logo-link {
  display: inline-flex;
  line-height: 0;
  border-radius: 10px;
  padding: clamp(0.35rem, 1vw, 0.55rem) clamp(0.45rem, 1.2vw, 0.75rem);
  transition:
    opacity 0.2s ease,
    box-shadow 0.25s ease,
    transform 0.25s ease;
}

#site-header .site-header__logo-link:hover {
  opacity: 0.95;
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px rgba(0, 255, 209, 0.25), 0 12px 36px rgba(0, 255, 209, 0.08);
}

#site-header .site-header__logo-link:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 4px;
}

#site-header .site-header__logo {
  display: block;
  width: auto;
  max-width: min(240px, 58vw);
  height: auto;
}

@media (max-width: 768px) {
  #site-header .site-header__logo {
    max-width: min(200px, 64vw);
  }
}

#site-header .site-header__burger {
  flex-shrink: 0;
  pointer-events: auto;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 3rem;
  height: 3rem;
  margin: 0;
  padding: 0;
  border-radius: 12px;
  cursor: pointer;
  color: var(--artvoic-text);
  background: rgba(5, 5, 16, 0.45);
  border: 1px solid rgba(0, 255, 209, 0.22);
  box-shadow:
    0 0 0 1px rgba(108, 99, 255, 0.12),
    0 8px 28px rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition:
    color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.25s ease,
    transform 0.25s ease;
}

#site-header .site-header__burger:hover {
  color: var(--artvoic-accent);
  border-color: rgba(0, 255, 209, 0.45);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.25),
    0 12px 36px rgba(0, 255, 209, 0.12);
}

#site-header .site-header__burger:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#site-header .site-header__burger-line {
  display: block;
  width: 1.35rem;
  height: 2px;
  border-radius: 2px;
  background: currentColor;
  box-shadow: 0 0 10px rgba(0, 255, 209, 0.35);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.25s ease;
  transform-origin: center;
}

#site-header.site-header--open .site-header__burger-line:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}

#site-header.site-header--open .site-header__burger-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

#site-header.site-header--open .site-header__burger-line:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}

#site-header .site-header__backdrop {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 10051;
  background: rgba(2, 2, 12, 0.62);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.35s ease,
    visibility 0.35s ease;
}

#site-header.site-header--open .site-header__backdrop {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
}

#site-header .site-header__drawer {
  pointer-events: none;
  position: fixed;
  top: 0;
  right: 0;
  left: auto;
  bottom: 0;
  z-index: 10052;
  width: min(100vw - 1.25rem, 26rem);
  max-width: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 1.25rem 0 0 1.25rem;
  border: 1px solid rgba(0, 255, 209, 0.2);
  border-right: none;
  box-shadow:
    0 0 0 1px rgba(108, 99, 255, 0.15),
    -16px 0 48px rgba(0, 0, 0, 0.55),
    4px 0 40px rgba(0, 255, 209, 0.08);
  transform: translate3d(105%, 0, 0);
  visibility: hidden;
  transition:
    transform 0.45s cubic-bezier(0.32, 0.72, 0, 1),
    visibility 0.45s;
}

#site-header.site-header--open .site-header__drawer {
  pointer-events: auto;
  transform: translate3d(0, 0, 0);
  visibility: visible;
}

/* Мобилка: панель ниже полосы с лого — «Куда дальше» не под баром. */
@media (max-width: 768px) {
  #site-header.site-header--open .site-header__drawer {
    top: calc(env(safe-area-inset-top, 0px) + clamp(6.65rem, 11vw, 8rem));
    bottom: 0;
    height: auto;
    border-radius: 0 0 0 1.15rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  #site-header .site-header__drawer {
    transition: transform 0.2s ease, visibility 0.2s;
  }
}

#site-header .site-header__drawer-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background: linear-gradient(
    165deg,
    #03030a 0%,
    var(--site-footer-base) 38%,
    #05051a 100%
  );
}

#site-header .site-header__drawer-bg::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(ellipse 80% 70% at 20% 15%, rgba(0, 255, 209, 0.18), transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 40%, rgba(108, 99, 255, 0.28), transparent 50%),
    radial-gradient(ellipse 50% 45% at 40% 90%, rgba(0, 255, 209, 0.1), transparent 45%);
  animation: site-header-panel-aurora 14s ease-in-out infinite alternate;
}

@media (prefers-reduced-motion: reduce) {
  #site-header .site-header__drawer-bg::before {
    animation: none;
  }
}

#site-header .site-header__drawer-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background: linear-gradient(
    120deg,
    rgba(0, 255, 209, 0.06) 0%,
    transparent 40%,
    rgba(108, 99, 255, 0.1) 55%,
    transparent 75%,
    rgba(0, 255, 209, 0.05) 100%
  );
  background-size: 220% 220%;
  animation: site-header-panel-shimmer 10s ease infinite alternate;
}

@media (prefers-reduced-motion: reduce) {
  #site-header .site-header__drawer-bg::after {
    animation: none;
    opacity: 0.2;
  }
}

#site-header .site-header__drawer-scan {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 40%;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 255, 209, 0.04) 45%,
    transparent 90%
  );
  animation: site-header-panel-scan 7s linear infinite;
}

@media (prefers-reduced-motion: reduce) {
  #site-header .site-header__drawer-scan {
    display: none;
  }
}

#site-header .site-header__drawer-inner {
  position: relative;
  z-index: 2;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: clamp(1.15rem, 3.5vw, 1.65rem) clamp(1rem, 3vw, 1.35rem) clamp(1.5rem, 4vw, 2rem);
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 255, 209, 0.35) transparent;
}

#site-header .site-header__drawer-inner::-webkit-scrollbar {
  width: 6px;
}

#site-header .site-header__drawer-inner::-webkit-scrollbar-thumb {
  background: rgba(0, 255, 209, 0.28);
  border-radius: 4px;
}

#site-header .site-header__drawer .site-header__nav-label {
  margin: 0 0 1rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(0.72rem, 0.15vw + 0.68rem, 0.8rem);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(0, 255, 209, 0.75);
  text-shadow: 0 0 24px rgba(0, 255, 209, 0.25);
}

#site-header .site-header__drawer .site-header__nav-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

#site-header .site-header__drawer .site-header__nav-list > li {
  margin: 0;
}

/* Выезжающая панель (гамбургер): плашка — миниатюра слева, текст справа; градиент + неон */
#site-header .site-header__drawer .site-header__nav-link {
  --site-header-pill-bg1: #0a0e22;
  --site-header-pill-bg2: #12183a;
  --site-header-pill-bg3: #0c1228;

  position: relative;
  z-index: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.75rem;
  min-height: clamp(6.2rem, 14vw, 6.6rem);
  padding: 0.55rem 0.9rem 0.55rem 0.5rem;
  border-radius: 1rem;
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(0, 255, 209, 0.18);
  background: linear-gradient(
    145deg,
    var(--site-header-pill-bg1) 0%,
    var(--site-header-pill-bg2) 48%,
    var(--site-header-pill-bg3) 100%
  );
  box-shadow:
    0 0 0 1px rgba(108, 99, 255, 0.12),
    0 6px 28px rgba(0, 0, 0, 0.45),
    0 0 24px rgba(0, 255, 209, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
  animation: site-header-nav-pill-glow 5s ease-in-out infinite;
  transition:
    border-color 0.28s ease,
    box-shadow 0.28s ease,
    transform 0.28s ease,
    color 0.2s ease;
}

#site-header .site-header__drawer .site-header__nav-link::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: inherit;
  background: linear-gradient(
    125deg,
    rgba(0, 255, 209, 0.14) 0%,
    rgba(108, 99, 255, 0.12) 35%,
    transparent 55%,
    rgba(0, 255, 209, 0.08) 85%,
    rgba(30, 100, 160, 0.12) 100%
  );
  background-size: 220% 220%;
  animation: site-header-nav-pill-sheen 10s ease-in-out infinite alternate;
  opacity: 0.65;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  #site-header .site-header__drawer .site-header__nav-link {
    animation: none;
  }

  #site-header .site-header__drawer .site-header__nav-link::before {
    animation: none;
    opacity: 0.35;
  }
}

#site-header .site-header__drawer .site-header__nav-link:hover {
  border-color: rgba(0, 255, 209, 0.42);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.22),
    0 0 32px rgba(0, 255, 209, 0.14),
    0 12px 36px rgba(12, 8, 40, 0.55),
    inset 0 1px 0 rgba(255, 255, 255, 0.09);
  transform: translateY(-2px);
}

#site-header .site-header__drawer .site-header__nav-link:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#site-header .site-header__drawer .site-header__nav-thumb {
  position: relative;
  flex: 0 0 auto;
  width: 5.25rem;
  height: 5.25rem;
  border-radius: 0.75rem;
  overflow: hidden;
  background: linear-gradient(145deg, #080c1a, #121828);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.2),
    0 4px 16px rgba(0, 0, 0, 0.4),
    0 0 18px rgba(0, 255, 209, 0.08);
}

#site-header .site-header__drawer .site-header__nav-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

#site-header .site-header__drawer .site-header__nav-link:hover .site-header__nav-thumb img {
  transform: scale(1.06);
}

#site-header .site-header__drawer .site-header__nav-thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
  pointer-events: none;
}

#site-header .site-header__drawer .site-header__nav-title {
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(0.8rem, 0.35vw + 0.74rem, 0.92rem);
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  word-break: break-word;
  hyphens: auto;
}

@media (max-width: 480px) {
  #site-header .site-header__drawer .site-header__nav-link {
    border-radius: 0.9rem;
    padding: 0.45rem 0.72rem 0.45rem 0.45rem;
  }

  #site-header .site-header__drawer .site-header__nav-title {
    font-size: clamp(0.74rem, 2.8vw + 0.55rem, 0.86rem);
  }
}

#site-header .site-header__contact {
  margin-top: clamp(1.35rem, 4vw, 1.85rem);
  padding-top: clamp(1.15rem, 3vw, 1.5rem);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

#site-header .site-header__contact-lead {
  margin: 0 0 0.5rem;
  font-size: clamp(0.78rem, 0.2vw + 0.72rem, 0.85rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.58);
}

#site-header .site-header__phone {
  display: inline-block;
  margin: 0 0 0.65rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.05rem, 1.5vw + 0.85rem, 1.45rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-decoration: none;
  transition: color 0.2s ease, text-shadow 0.25s ease;
}

#site-header .site-header__phone:hover {
  color: var(--artvoic-accent);
  text-shadow: 0 0 28px rgba(0, 255, 209, 0.35);
}

#site-header .site-header__phone:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 4px;
  border-radius: 2px;
}

#site-header .site-header__schedule {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: clamp(0.74rem, 0.18vw + 0.7rem, 0.82rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.55);
}

#site-header .site-header__schedule p {
  margin: 0;
}

@media (max-width: 420px) {
  #site-header .site-header__drawer {
    width: 100%;
    max-width: 100%;
    border-radius: 0.85rem 0 0 0.85rem;
  }

  #site-header.site-header--open .site-header__drawer {
    border-radius: 0 0 0 0.85rem;
  }
}

@media (max-width: 380px) {
  #site-header .site-header__logo {
    max-width: min(200px, 70vw);
  }

  #site-header .site-header__burger {
    width: 2.75rem;
    height: 2.75rem;
  }
}

/* --- price-services: страница «Стоимость услуг» (Elementor, только тело) --- */

@keyframes price-services-aurora {
  0% {
    transform: translate3d(-0.6%, 0.4%, 0) scale(1);
  }
  100% {
    transform: translate3d(0.8%, -0.7%, 0) scale(1.035);
  }
}

@keyframes price-services-breath {
  0%,
  100% {
    opacity: 0.34;
    transform: scale(1);
  }
  50% {
    opacity: 0.5;
    transform: scale(1.06);
  }
}

@keyframes price-services-zone-breathe {
  0%,
  100% {
    opacity: 0.28;
    transform: scale(1);
  }
  50% {
    opacity: 0.44;
    transform: scale(1.03);
  }
}

@keyframes price-services-link-glow {
  0%,
  100% {
    box-shadow:
      0 0 0 1px rgba(0, 255, 209, 0.35),
      0 0 18px rgba(0, 255, 209, 0.12);
  }
  50% {
    box-shadow:
      0 0 0 1px rgba(0, 255, 209, 0.55),
      0 0 28px rgba(0, 255, 209, 0.22);
  }
}

#price-services {
  --ps-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ps-card: rgba(18, 18, 28, 0.55);
  --ps-card-border: rgba(255, 255, 255, 0.12);

  position: relative;
  background: linear-gradient(
    180deg,
    var(--artvoic-bg) 0%,
    var(--directions-hub-base) min(22%, 160px),
    var(--price-services-base) 52%,
    var(--site-footer-base) 100%
  );
  color: var(--artvoic-text);
  font-family: var(--artvoic-font-body);
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
  padding-top: 1px;
}

#price-services .price-services__bg-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#price-services .price-services__aurora {
  position: absolute;
  inset: -26% -18% -22% -18%;
  transform-origin: 48% 38%;
  background:
    radial-gradient(ellipse 46% 42% at 22% 28%, rgba(0, 255, 209, 0.11), transparent 55%),
    radial-gradient(ellipse 44% 40% at 82% 62%, rgba(108, 99, 255, 0.12), transparent 53%),
    radial-gradient(ellipse 38% 36% at 50% 72%, rgba(30, 159, 196, 0.08), transparent 58%);
  filter: blur(50px);
  animation: price-services-aurora 26s ease-in-out infinite alternate;
  animation-delay: -4s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 10%,
    #000 24%,
    #000 80%,
    rgba(0, 0, 0, 0.35) 93%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 10%,
    #000 24%,
    #000 80%,
    rgba(0, 0, 0, 0.35) 93%,
    transparent 100%
  );
}

#price-services .price-services__glow {
  position: absolute;
  top: 18%;
  right: -6%;
  width: min(52vw, 480px);
  height: min(52vw, 480px);
  background: radial-gradient(circle, rgba(0, 255, 209, 0.09) 0%, rgba(70, 60, 140, 0.07) 48%, transparent 70%);
  filter: blur(62px);
  animation: price-services-breath 16s ease-in-out infinite;
  animation-delay: -5s;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 12%,
    #000 30%,
    #000 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    transparent 12%,
    #000 30%,
    #000 100%
  );
}

#price-services .price-services__glow::after {
  content: "";
  position: absolute;
  left: -115%;
  bottom: 8%;
  width: min(44vw, 400px);
  height: min(44vw, 400px);
  background: radial-gradient(circle, rgba(108, 99, 255, 0.09) 0%, transparent 68%);
  filter: blur(54px);
  animation: price-services-breath 19s ease-in-out infinite reverse;
  animation-delay: -8s;
}

#price-services .price-services__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      var(--artvoic-bg) 0%,
      rgba(8, 8, 14, 0) min(26%, 280px)
    ),
    radial-gradient(ellipse 100% 85% at 50% 45%, transparent 0%, rgba(5, 5, 12, 0.38) 62%, rgba(5, 6, 14, 0.58) 100%);
}

#price-services .price-services__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(2.5rem, 5vw, 4rem) clamp(1.15rem, 4vw, 3rem) clamp(3rem, 6vw, 4.5rem);
}

#price-services .price-services__head {
  text-align: center;
  max-width: 40rem;
  margin: 0 auto clamp(2.25rem, 4vw, 3rem);
}

#price-services .price-services__kicker {
  display: block;
  margin-bottom: 0.5rem;
  font-size: clamp(0.68rem, 0.32vw + 0.62rem, 0.76rem);
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
}

#price-services .price-services__title {
  margin: 0 0 0.75rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.65rem, 1.2vw + 1.2rem, 2.35rem);
  font-weight: 600;
  line-height: 1.18;
  letter-spacing: -0.03em;
  color: var(--artvoic-text);
  text-shadow: 0 1px 26px rgba(0, 0, 0, 0.35);
}

#price-services .price-services__lead {
  margin: 0;
  font-size: clamp(0.94rem, 0.28vw + 0.86rem, 1.05rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#price-services .price-services__zone {
  position: relative;
  margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
  padding: clamp(1.5rem, 3vw, 2.25rem);
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(
    165deg,
    rgba(255, 255, 255, 0.04) 0%,
    rgba(12, 12, 22, 0.35) 45%,
    rgba(8, 8, 16, 0.5) 100%
  );
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.28);
}

#price-services .price-services__zone-glow {
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  opacity: 0.35;
  animation: price-services-zone-breathe 11s ease-in-out infinite;
}

#price-services .price-services__zone--online .price-services__zone-glow {
  background: radial-gradient(ellipse 70% 55% at 12% 18%, rgba(0, 255, 209, 0.14), transparent 62%);
  animation-delay: -2s;
}

#price-services .price-services__zone--offline .price-services__zone-glow {
  background: radial-gradient(ellipse 68% 52% at 88% 22%, rgba(108, 99, 255, 0.15), transparent 60%);
  animation-delay: -5s;
}

#price-services .price-services__zone--kids .price-services__zone-glow {
  background: radial-gradient(ellipse 65% 50% at 50% 10%, rgba(30, 159, 196, 0.13), transparent 58%);
  animation-delay: -3.5s;
}

#price-services .price-services__zone-title {
  position: relative;
  z-index: 1;
  margin: 0 0 clamp(1.35rem, 2.8vw, 1.85rem);
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.15rem, 0.55vw + 0.98rem, 1.45rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  text-align: center;
  text-transform: uppercase;
  color: var(--artvoic-text);
  text-shadow: 0 0 40px rgba(0, 255, 209, 0.08);
}

#price-services .price-services__card {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr);
  gap: clamp(1rem, 3vw, 1.75rem);
  align-items: start;
  margin-bottom: clamp(1rem, 2vw, 1.35rem);
  padding: clamp(1.1rem, 2.2vw, 1.45rem);
  border-radius: 20px;
  border: 1px solid var(--ps-card-border);
  background: var(--ps-card);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.22);
  transition:
    border-color 0.35s var(--ps-ease),
    box-shadow 0.35s var(--ps-ease),
    transform 0.35s var(--ps-ease);
}

#price-services .price-services__card:last-child {
  margin-bottom: 0;
}

#price-services .price-services__card:hover {
  border-color: rgba(0, 255, 209, 0.28);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.12),
    0 16px 44px rgba(0, 255, 209, 0.08),
    0 12px 36px rgba(0, 0, 0, 0.35);
  transform: translateY(-2px);
}

#price-services .price-services__card--wide {
  grid-template-columns: minmax(0, 200px) minmax(0, 1fr);
}

#price-services .price-services__card-visual {
  border-radius: 16px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.06);
  align-self: stretch;
}

#price-services .price-services__card-visual img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

#price-services .price-services__card-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

#price-services .price-services__name {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1rem, 0.35vw + 0.88rem, 1.15rem);
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--artvoic-text);
  text-transform: uppercase;
}

#price-services .price-services__body {
  margin: 0;
  font-size: clamp(0.88rem, 0.22vw + 0.82rem, 0.96rem);
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#price-services .price-services__body p {
  margin: 0 0 0.5rem;
}

#price-services .price-services__body p:last-child {
  margin-bottom: 0;
}

#price-services .price-services__blocks {
  margin: 0.35rem 0 0;
  padding-left: 1.15rem;
  font-size: clamp(0.86rem, 0.2vw + 0.8rem, 0.94rem);
  line-height: 1.5;
  color: var(--artvoic-text-soft);
}

#price-services .price-services__blocks li {
  margin-bottom: 0.25rem;
}

#price-services .price-services__meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem 1rem;
  margin: 0.35rem 0 0;
  padding: 0.65rem 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

#price-services .price-services__meta dt {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(0, 255, 209, 0.75);
}

#price-services .price-services__meta dd {
  margin: 0.2rem 0 0;
  font-size: clamp(0.86rem, 0.2vw + 0.8rem, 0.95rem);
  line-height: 1.45;
  color: var(--artvoic-text);
}

#price-services .price-services__action-link {
  align-self: flex-start;
  margin-top: 0.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.62rem 1.2rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.06);
  border-radius: 4px;
  border: 1px solid rgba(0, 255, 209, 0.42);
  animation: price-services-link-glow 3.6s ease-in-out infinite;
  transition:
    color 0.25s var(--ps-ease),
    background 0.25s var(--ps-ease),
    transform 0.25s var(--ps-ease),
    border-color 0.25s var(--ps-ease);
}

#price-services .price-services__action-link:hover {
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-color: var(--artvoic-accent);
  transform: translateY(-2px);
}

#price-services .price-services__action-link:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#price-services .price-services__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  margin-top: clamp(2rem, 4vw, 2.75rem);
  padding-top: clamp(1.5rem, 3vw, 2rem);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

#price-services .price-services__cta:not(.price-services__cta--ghost) {
  animation: kids-hero-cta-pulse 3.2s ease-in-out infinite;
}

#price-services .price-services__cta--ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.75rem;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  color: var(--artvoic-accent);
  background: transparent;
  border-radius: 4px;
  border: 2px solid rgba(0, 255, 209, 0.55);
  box-shadow:
    0 0 22px rgba(0, 255, 209, 0.15),
    inset 0 0 24px rgba(0, 255, 209, 0.06);
  transition:
    color 0.25s var(--ps-ease),
    background 0.25s var(--ps-ease),
    border-color 0.25s var(--ps-ease),
    transform 0.25s var(--ps-ease),
    box-shadow 0.25s var(--ps-ease);
}

#price-services .price-services__cta--ghost:hover {
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  border-color: var(--artvoic-accent);
  transform: translateY(-2px);
  box-shadow:
    0 0 36px rgba(0, 255, 209, 0.35),
    0 12px 40px rgba(0, 255, 209, 0.18);
}

#price-services .price-services__cta--ghost:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

@media (max-width: 720px) {
  #price-services .price-services__card,
  #price-services .price-services__card--wide {
    grid-template-columns: 1fr;
  }

  #price-services .price-services__card-visual {
    max-width: 280px;
    margin: 0 auto;
  }

  #price-services .price-services__meta {
    grid-template-columns: 1fr;
  }

  #price-services .price-services__cta-row {
    flex-direction: column;
  }

  #price-services .price-services__cta,
  #price-services .price-services__cta--ghost {
    width: 100%;
    max-width: 22rem;
    justify-content: center;
  }
}

/* --- Детский интенсив + очный взрослый (#intensivkids-*, #intensiv-msk-*) — общие .intkids-* --- */

@keyframes intkids-smoke-float-a {
  0% {
    transform: translate(-6%, -2%) rotate(0deg) scale(1);
    opacity: 0.35;
  }
  50% {
    opacity: 0.55;
  }
  100% {
    transform: translate(8%, 4%) rotate(4deg) scale(1.08);
    opacity: 0.4;
  }
}

@keyframes intkids-smoke-float-b {
  0% {
    transform: translate(5%, 3%) rotate(0deg) scale(1.02);
    opacity: 0.28;
  }
  55% {
    opacity: 0.48;
  }
  100% {
    transform: translate(-7%, -5%) rotate(-3deg) scale(1.1);
    opacity: 0.32;
  }
}

@keyframes intkids-aurora-sheen {
  0%,
  100% {
    opacity: 0.55;
    transform: translate(0, 0) scale(1);
  }
  50% {
    opacity: 0.82;
    transform: translate(-2%, 1%) scale(1.03);
  }
}

@keyframes intkids-neon-ring {
  0%,
  100% {
    box-shadow:
      inset 0 0 60px rgba(0, 255, 209, 0.08),
      0 0 0 1px rgba(0, 255, 209, 0.28),
      0 0 48px rgba(108, 99, 255, 0.22);
  }
  50% {
    box-shadow:
      inset 0 0 80px rgba(0, 255, 209, 0.12),
      0 0 0 1px rgba(0, 255, 209, 0.45),
      0 0 72px rgba(0, 255, 209, 0.2);
  }
}

/* Блик на плашке лого — в духе движения .kids-landing__wave-line */
@keyframes intkids-logo-plate-flow {
  0%,
  100% {
    opacity: 0.42;
    transform: translateX(-32%) skewX(-14deg);
  }
  50% {
    opacity: 0.78;
    transform: translateX(32%) skewX(-14deg);
  }
}

#intensivkids-hero, #intensiv-msk-hero,
#intensivkids-about, #intensiv-msk-about,
#intensivkids-program, #intensiv-msk-program,
#intensivkids-pay, #intensiv-msk-pay,
#intensivkids-moments, #intensiv-msk-moments,
#intensiv-msk-guest,
#intensiv-msk-how {
  margin-top: -1px;
  padding-top: 1px;
  position: relative;
  isolation: isolate;
  font-family: var(--artvoic-font-body);
  overflow: clip;
  color: var(--artvoic-text-muted);
}

#intensivkids-hero .intkids-hero__layout, #intensiv-msk-hero .intkids-hero__layout,
#intensivkids-about .intkids-section__inner, #intensiv-msk-about .intkids-section__inner,
#intensivkids-program .intkids-section__inner, #intensiv-msk-program .intkids-section__inner,
#intensivkids-pay .intkids-section__inner, #intensiv-msk-pay .intkids-section__inner,
#intensivkids-moments .intkids-section__inner, #intensiv-msk-moments .intkids-section__inner,
#intensiv-msk-guest .intkids-section__inner,
#intensiv-msk-how .intkids-section__inner {
  position: relative;
  z-index: 2;
  box-sizing: border-box;
}

#intensivkids-reviews-app, #intensiv-msk-reviews-app,
#intensivkids-map, #intensiv-msk-map {
  margin-top: -1px;
  padding-top: 1px;
}

/* Hero */
#intensivkids-hero, #intensiv-msk-hero {
  padding-top: clamp(2.75rem, 6vw, 5rem);
  padding-left: 1.35rem;
  padding-right: 1.35rem;
  padding-bottom: calc(clamp(5rem, 10vw, 7rem) + clamp(64px, 11vh, 108px));
  background: radial-gradient(120% 80% at 50% 0%, #0d1030 0%, var(--intensiv-kids-hero-base) 52%, #020205 100%);
  min-height: min(92vh, 900px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Разделители .kids-landing__wave: стили синхронны с imx/kids лендингами (иначе SVG-path → чёрная заливка по умолчанию) */
:is(#intensivkids-hero, #intensivkids-about, #intensivkids-program, #intensivkids-moments, #intensiv-msk-hero, #intensiv-msk-about, #intensiv-msk-guest, #intensiv-msk-program, #intensiv-msk-how, #intensiv-msk-moments) .kids-landing__wave {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: clamp(72px, 12vh, 120px);
  pointer-events: none;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}

#intensivkids-hero .kids-landing__wave, #intensiv-msk-hero .kids-landing__wave {
  z-index: 4;
}

:is(#intensivkids-hero, #intensivkids-about, #intensivkids-program, #intensivkids-moments, #intensiv-msk-hero, #intensiv-msk-about, #intensiv-msk-guest, #intensiv-msk-program, #intensiv-msk-how, #intensiv-msk-moments) .kids-landing__wave-track {
  display: flex;
  width: 200%;
  height: 100%;
  animation: hero-dubbing-wave 31s linear infinite;
}

:is(#intensivkids-hero, #intensivkids-about, #intensivkids-program, #intensivkids-moments, #intensiv-msk-hero, #intensiv-msk-about, #intensiv-msk-guest, #intensiv-msk-program, #intensiv-msk-how, #intensiv-msk-moments) .kids-landing__wave-svg {
  flex: 0 0 50%;
  width: 50%;
  height: 100%;
  display: block;
}

:is(#intensivkids-about, #intensivkids-program, #intensivkids-moments, #intensiv-msk-about, #intensiv-msk-guest, #intensiv-msk-program, #intensiv-msk-how, #intensiv-msk-moments) .kids-landing__wave-line {
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
  opacity: 0.5;
  stroke: var(--course-bridge-wave);
}

:is(#intensivkids-about, #intensivkids-program, #intensivkids-moments, #intensiv-msk-about, #intensiv-msk-guest, #intensiv-msk-program, #intensiv-msk-how, #intensiv-msk-moments) .kids-landing__wave-line--soft {
  fill: none;
  stroke-width: 1.15;
  opacity: 0.38;
  stroke: var(--course-bridge-wave-soft);
}

#intensivkids-hero .kids-landing__wave-line, #intensiv-msk-hero .kids-landing__wave-line {
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
  opacity: 0.82;
  stroke: var(--course-bridge-wave);
}

#intensivkids-hero .kids-landing__wave-line--soft, #intensiv-msk-hero .kids-landing__wave-line--soft {
  fill: none;
  stroke-width: 1.3;
  opacity: 0.55;
  stroke: var(--course-bridge-wave-soft);
}

#intensivkids-hero .intkids-bg-stack, #intensiv-msk-hero .intkids-bg-stack {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

#intensivkids-hero .intkids-bg-stack::before, #intensiv-msk-hero .intkids-bg-stack::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(5, 5, 8, 0.35) 45%, var(--intensiv-kids-mid) 100%);
}

#intensivkids-hero .intkids-smoke, #intensiv-msk-hero .intkids-smoke {
  position: absolute;
  border-radius: 50%;
  filter: blur(68px);
  opacity: 0.45;
  mix-blend-mode: screen;
  animation: intkids-smoke-float-a 42s ease-in-out infinite alternate;
}

#intensivkids-hero .intkids-smoke:nth-child(1), #intensiv-msk-hero .intkids-smoke:nth-child(1) {
  width: min(140%, 1200px);
  height: min(95%, 700px);
  left: -30%;
  top: -10%;
  background: radial-gradient(circle at 35% 40%, rgba(0, 255, 209, 0.32) 0%, rgba(108, 99, 255, 0.18) 42%, transparent 72%);
}

#intensivkids-hero .intkids-smoke:nth-child(2), #intensiv-msk-hero .intkids-smoke:nth-child(2) {
  width: min(120%, 1000px);
  height: 80%;
  right: -25%;
  bottom: -25%;
  background: radial-gradient(circle at 60% 55%, rgba(80, 200, 255, 0.22) 0%, rgba(0, 255, 209, 0.12) 45%, transparent 70%);
  animation-name: intkids-smoke-float-b;
  animation-duration: 54s;
}

#intensivkids-hero .intkids-smoke:nth-child(3), #intensiv-msk-hero .intkids-smoke:nth-child(3) {
  width: min(90%, 700px);
  height: 50%;
  left: 10%;
  bottom: -5%;
  filter: blur(90px);
  opacity: 0.28;
  background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.09) 0%, transparent 65%);
  animation-duration: 60s;
}

#intensivkids-hero .intkids-aurora, #intensiv-msk-hero .intkids-aurora {
  position: absolute;
  inset: -20% -10% auto;
  height: 70%;
  background:
    radial-gradient(ellipse 80% 65% at 20% 20%, rgba(0, 255, 209, 0.2) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 85% 10%, rgba(108, 99, 255, 0.25) 0%, transparent 50%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 100%);
  opacity: 0.7;
  animation: intkids-aurora-sheen 26s ease-in-out infinite;
}

#intensivkids-hero .intkids-grain, #intensiv-msk-hero .intkids-grain {
  position: absolute;
  inset: 0;
  opacity: 0.06;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
  pointer-events: none;
}

#intensivkids-hero .intkids-vignette, #intensiv-msk-hero .intkids-vignette {
  position: absolute;
  inset: 0;
  box-shadow:
    inset 0 0 120px rgba(0, 0, 0, 0.75),
    inset 0 -80px 140px rgba(5, 5, 12, 0.9);
  pointer-events: none;
}

#intensivkids-hero .intkids-hero__layout, #intensiv-msk-hero .intkids-hero__layout {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  display: grid;
  gap: clamp(2rem, 5vw, 3.5rem);
  align-items: center;
}

@media (min-width: 900px) {
  #intensivkids-hero .intkids-hero__layout, #intensiv-msk-hero .intkids-hero__layout {
    grid-template-columns: minmax(0, 1.08fr) minmax(260px, 0.92fr);
  }
}

#intensivkids-hero .intkids-date-pill, #intensiv-msk-hero .intkids-date-pill {
  display: inline-block;
  padding: 0.35rem 1rem;
  border-radius: 999px;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.95rem, 4.3vw, 3.15rem);
  font-weight: 700;
  color: var(--artvoic-accent);
  text-shadow:
    0 0 24px rgba(0, 255, 209, 0.45),
    0 0 2px rgba(0, 0, 0, 0.8);
  letter-spacing: 0.04em;
  border: 1px solid rgba(0, 255, 209, 0.35);
  background: rgba(0, 0, 0, 0.28);
}

#intensivkids-hero .intkids-kicker-line, #intensiv-msk-hero .intkids-kicker-line {
  margin: 1rem 0 0;
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--artvoic-text-soft);
}

#intensivkids-hero .intkids-hero__title, #intensiv-msk-hero .intkids-hero__title {
  margin: 0.75rem 0 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.85rem, 4.8vw, 3.05rem);
  line-height: 1.08;
  color: var(--artvoic-text);
  font-weight: 700;
}

#intensivkids-hero .intkids-hero__title span, #intensiv-msk-hero .intkids-hero__title span {
  display: block;
  color: var(--artvoic-text);
  text-shadow:
    0 0 52px rgba(0, 255, 209, 0.32),
    0 2px 28px rgba(0, 0, 0, 0.75);
}

#intensivkids-hero .intkids-countwrap, #intensiv-msk-hero .intkids-countwrap {
  margin-top: 1.75rem;
}

#intensivkids-hero .intkids-countdown, #intensiv-msk-hero .intkids-countdown {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.65rem;
  max-width: 420px;
}

#intensivkids-hero .intkids-countdown__cell, #intensiv-msk-hero .intkids-countdown__cell {
  text-align: center;
  padding: 0.75rem 0.5rem;
  border-radius: 14px;
  background: rgba(8, 10, 30, 0.65);
  border: 1px solid rgba(0, 255, 209, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 0 28px rgba(0, 255, 209, 0.08);
  animation: intkids-neon-ring 6s ease-in-out infinite;
}

#intensivkids-hero .intkids-countdown__num, #intensiv-msk-hero .intkids-countdown__num {
  display: block;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.65rem, 3.8vw, 2.05rem);
  font-weight: 700;
  color: var(--artvoic-accent);
  line-height: 1.05;
}

#intensivkids-hero .intkids-countdown__lab, #intensiv-msk-hero .intkids-countdown__lab {
  display: block;
  margin-top: 0.3rem;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--artvoic-text-muted);
}

#intensivkids-hero .intkids-phone, #intensiv-msk-hero .intkids-phone {
  margin-top: 2rem;
}

#intensivkids-hero .intkids-phone a, #intensiv-msk-hero .intkids-phone a {
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.55rem, 3.2vw, 2rem);
  color: var(--artvoic-text);
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 255, 209, 0.35);
  transition: color 0.2s ease, border-color 0.2s ease;
}

#intensivkids-hero .intkids-phone a:hover, #intensiv-msk-hero .intkids-phone a:hover {
  color: var(--artvoic-accent);
  border-color: var(--artvoic-accent);
}

#intensivkids-hero .intkids-phone-note, #intensiv-msk-hero .intkids-phone-note {
  margin: 0.45rem 0 0;
  font-size: 0.95rem;
}

#intensivkids-hero .intkids-hero-panel, #intensiv-msk-hero .intkids-hero-panel {
  position: relative;
  border-radius: 22px;
  padding: 1.35rem;
  background: linear-gradient(145deg, rgba(16, 20, 42, 0.85) 0%, rgba(8, 8, 20, 0.72) 100%);
  border: 1px solid rgba(108, 99, 255, 0.28);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.06),
    0 26px 80px rgba(0, 0, 0, 0.55),
    0 0 56px rgba(0, 255, 209, 0.1);
}

#intensivkids-hero .intkids-hero-panel::before, #intensiv-msk-hero .intkids-hero-panel::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 23px;
  background: linear-gradient(130deg, rgba(0, 255, 209, 0.35), transparent 42%, rgba(108, 99, 255, 0.35));
  opacity: 0.35;
  z-index: -1;
}

/* Плашка под logo_menu.png — те же оттенки, что у #intensivkids-hero .kids-landing__wave-line */
#intensivkids-hero .intkids-hero-logo-plate, #intensiv-msk-hero .intkids-hero-logo-plate {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 0.9rem;
  padding: 0.55rem 1.05rem;
  border-radius: 18px;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(
    136deg,
    color-mix(in srgb, var(--course-bridge-wave) 88%, transparent) 0%,
    var(--course-bridge-wave-soft) 38%,
    color-mix(in srgb, var(--artvoic-accent) 72%, transparent) 72%,
    color-mix(in srgb, var(--course-bridge-wave) 78%, transparent) 100%
  );
  border: 1px solid rgba(0, 214, 232, 0.72);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.25),
    0 0 40px rgba(0, 214, 232, 0.42),
    0 0 76px rgba(30, 159, 196, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

#intensivkids-hero .intkids-hero-logo-plate::after, #intensiv-msk-hero .intkids-hero-logo-plate::after {
  content: "";
  position: absolute;
  top: -45%;
  left: -15%;
  width: 58%;
  height: 210%;
  background: linear-gradient(
    100deg,
    transparent 0%,
    rgba(255, 255, 255, 0.22) 42%,
    rgba(0, 255, 255, 0.35) 52%,
    transparent 72%
  );
  mix-blend-mode: soft-light;
  animation: intkids-logo-plate-flow 13s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}

#intensivkids-hero .intkids-hero-logo, #intensiv-msk-hero .intkids-hero-logo {
  display: block;
  position: relative;
  z-index: 1;
  width: clamp(220px, 72%, 340px);
  height: auto;
  margin: 0;
  filter:
    drop-shadow(0 2px 12px rgba(0, 0, 0, 0.55))
    drop-shadow(0 0 22px rgba(0, 214, 232, 0.38));
}

#intensivkids-hero .intkids-cta-row, #intensiv-msk-hero .intkids-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.35rem;
  justify-content: center;
}

#intensivkids-hero .intkids-btn, #intensiv-msk-hero .intkids-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.92rem 1.6rem;
  border-radius: 999px;
  font-family: var(--artvoic-font-body);
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition:
    transform 0.22s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.22s ease;
}

#intensivkids-hero .intkids-btn--primary, #intensiv-msk-hero .intkids-btn--primary {
  background: var(--artvoic-accent);
  color: #03110e;
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.5),
    0 14px 40px rgba(0, 255, 209, 0.28);
}

#intensivkids-hero .intkids-btn--primary:hover, #intensiv-msk-hero .intkids-btn--primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 0 36px rgba(0, 255, 209, 0.4),
    0 18px 48px rgba(0, 255, 209, 0.22);
}

#intensivkids-hero .intkids-btn--outline, #intensiv-msk-hero .intkids-btn--outline {
  background: transparent;
  color: var(--artvoic-accent);
  border: 1px solid rgba(0, 255, 209, 0.45);
  box-shadow: none;
}

#intensivkids-hero .intkids-btn--outline:hover, #intensiv-msk-hero .intkids-btn--outline:hover {
  transform: translateY(-2px);
  background: rgba(0, 255, 209, 0.08);
  border-color: var(--artvoic-accent);
}

#intensivkids-hero .intkids-tagline-mini, #intensiv-msk-hero .intkids-tagline-mini {
  text-align: center;
  margin: 0.35rem 0 0;
  font-size: 0.82rem;
  color: var(--artvoic-text-muted);
}

/* About */
#intensivkids-about, #intensiv-msk-about {
  padding-top: clamp(3rem, 7vw, 5rem);
  padding-left: 1.35rem;
  padding-right: 1.35rem;
  padding-bottom: calc(clamp(3rem, 7vw, 5rem) + clamp(72px, 12vh, 120px));
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-mid) 0%,
    var(--intensiv-kids-mid) 52%,
    var(--intensiv-kids-deep) 100%
  );
}

/* Стык с hero: общий базовый тон + смягчающее пятно (как .kids-results__bg) без «выбела» сверху */
#intensivkids-about::before, #intensiv-msk-about::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      var(--intensiv-kids-hero-base) 0%,
      var(--intensiv-kids-mid) clamp(72px, 13vh, 130px),
      rgba(7, 8, 25, 0) clamp(120px, 22vh, 240px)
    ),
    radial-gradient(ellipse 70% 50% at 84% 32%, rgba(0, 255, 209, 0.1), transparent 58%),
    radial-gradient(ellipse 68% 48% at 14% 58%, rgba(108, 99, 255, 0.14), transparent 56%);
  filter: blur(30px);
  opacity: 0.92;
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 calc(100% - clamp(76px, 15vh, 150px)), transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 calc(100% - clamp(76px, 15vh, 150px)), transparent 100%);
}

#intensivkids-about .intkids-about__stripe, #intensiv-msk-about .intkids-about__stripe {
  text-align: center;
  margin: 0 0 2.75rem;
}

#intensivkids-about .intkids-school-title, #intensiv-msk-about .intkids-school-title {
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.55rem, 3.8vw, 2.05rem);
  color: var(--artvoic-text);
  letter-spacing: 0.06em;
  margin: 0;
}

#intensivkids-about .intkids-about__grid, #intensiv-msk-about .intkids-about__grid {
  max-width: 1120px;
  margin: 0 auto;
  display: grid;
  gap: clamp(2rem, 4vw, 3rem);
}

@media (min-width: 900px) {
  #intensivkids-about .intkids-about__grid, #intensiv-msk-about .intkids-about__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }
}

#intensivkids-about .intkids-profile, #intensiv-msk-about .intkids-profile {
  padding: clamp(1.25rem, 3vw, 1.85rem);
  border-radius: 22px;
  background: rgba(10, 12, 34, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.45);
}

#intensivkids-about .intkids-profile__img, #intensiv-msk-about .intkids-profile__img {
  display: block;
  width: 100%;
  max-width: 320px;
  height: auto;
  margin: 0 auto 1.25rem;
  border-radius: 18px;
  object-fit: cover;
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.2),
    0 16px 48px rgba(0, 0, 0, 0.5);
}

#intensivkids-about .intkids-profile__img--tall, #intensiv-msk-about .intkids-profile__img--tall {
  max-width: 280px;
  aspect-ratio: 2 / 3;
}

#intensivkids-about .intkids-profile__label, #intensiv-msk-about .intkids-profile__label {
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
  margin: 0 0 0.5rem;
}

#intensivkids-about .intkids-profile h3, #intensiv-msk-about .intkids-profile h3 {
  margin: 0 0 0.6rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.25rem, 2.5vw, 1.55rem);
  color: var(--artvoic-text);
}

#intensivkids-about .intkids-profile h3 a, #intensiv-msk-about .intkids-profile h3 a {
  color: var(--artvoic-text);
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 255, 209, 0.25);
}

#intensivkids-about .intkids-profile h3 a:hover, #intensiv-msk-about .intkids-profile h3 a:hover {
  color: var(--artvoic-accent);
}

#intensivkids-about .intkids-profile__role, #intensiv-msk-about .intkids-profile__role {
  margin: 0 0 1rem;
  font-size: 0.95rem;
  color: var(--artvoic-text-soft);
}

#intensivkids-about .intkids-profile__text, #intensiv-msk-about .intkids-profile__text {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
}

#intensivkids-about .intkids-kp-btn, #intensiv-msk-about .intkids-kp-btn {
  display: inline-flex;
  margin-top: 1.1rem;
  padding: 0.65rem 1.2rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-decoration: none;
  color: #03110e;
  background: var(--artvoic-accent);
  box-shadow: 0 0 24px rgba(0, 255, 209, 0.25);
}

#intensivkids-about .intkids-kp-btn:hover, #intensiv-msk-about .intkids-kp-btn:hover {
  transform: translateY(-1px);
}


/* Взрослый интенсив: гость (#intensiv-msk-guest) и блок «Как проходят» (#intensiv-msk-how) */
#intensiv-msk-guest {
  padding-top: clamp(3rem, 7vw, 5.25rem);
  padding-left: 1.35rem;
  padding-right: 1.35rem;
  padding-bottom: calc(clamp(3rem, 7vw, 5.25rem) + clamp(72px, 12vh, 120px));
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-deep) 0%,
    #08091a 38%,
    var(--intensiv-kids-mid) 100%
  );
}

#intensiv-msk-guest::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 62% 56% at 24% 52%, rgba(108, 99, 255, 0.1), transparent 62%);
  filter: blur(32px);
  opacity: 0.72;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.6) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 280px),
    #000 calc(100% - clamp(76px, 15vh, 150px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.6) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 280px),
    #000 calc(100% - clamp(76px, 15vh, 150px)),
    transparent 100%
  );
}

#intensiv-msk-guest .intkids-section__head {
  max-width: 720px;
  margin: 0 auto 2rem;
  text-align: center;
}

#intensiv-msk-guest .intkids-section__kicker {
  display: block;
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
  margin-bottom: 0.6rem;
}

#intensiv-msk-guest .intkids-section__title {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 3.4vw, 2rem);
  color: var(--artvoic-text);
}

#intensiv-msk-guest .intkids-guest-grid {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  gap: clamp(1.5rem, 4vw, 2.5rem);
  align-items: start;
  grid-template-columns: 1fr;
}

@media (min-width: 880px) {
  #intensiv-msk-guest .intkids-guest-grid {
    grid-template-columns: minmax(220px, 320px) 1fr;
  }
}

#intensiv-msk-guest .intkids-guest-photo {
  margin: 0;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(0, 255, 209, 0.2);
  box-shadow:
    0 0 40px rgba(108, 99, 255, 0.12),
    0 20px 50px rgba(0, 0, 0, 0.45);
}

#intensiv-msk-guest .intkids-guest-photo img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: middle;
}

#intensiv-msk-guest .intkids-guest-name {
  margin: 0 0 0.35rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.25rem, 2.5vw, 1.6rem);
  color: var(--artvoic-text);
}

#intensiv-msk-guest .intkids-guest-tag {
  margin: 0 0 1rem;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(178, 184, 219, 0.85);
}

#intensiv-msk-guest .intkids-guest-lead {
  margin: 0 0 1rem;
  font-size: 0.95rem;
  line-height: 1.55;
}

#intensiv-msk-guest .intkids-guest-filmography {
  margin: 0;
  padding: 1rem 1.1rem;
  max-height: min(280px, 40vh);
  overflow: auto;
  font-size: 0.86rem;
  line-height: 1.5;
  color: rgba(210, 214, 235, 0.92);
  background: rgba(8, 10, 26, 0.65);
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
}

#intensiv-msk-guest .intkids-guest-filmography p {
  margin: 0 0 0.75rem;
}

#intensiv-msk-guest .intkids-guest-filmography p:last-child {
  margin-bottom: 0;
}

#intensiv-msk-guest .intkids-guest-master {
  margin: 1.25rem 0 0;
  font-size: 0.9rem;
  line-height: 1.55;
}

#intensiv-msk-guest .intkids-vote-note {
  margin: 1rem 0 0.75rem;
  font-size: 0.88rem;
  line-height: 1.5;
}

#intensiv-msk-guest .intkids-vote-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.25rem;
}

#intensiv-msk-guest .intkids-vote-row a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.35rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid rgba(0, 255, 209, 0.35);
  color: var(--artvoic-accent);
  background: rgba(0, 255, 209, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

#intensiv-msk-guest .intkids-vote-row a:hover {
  transform: translateY(-2px);
  background: rgba(0, 255, 209, 0.12);
  box-shadow: 0 0 28px rgba(0, 255, 209, 0.2);
}

#intensiv-msk-how {
  margin-top: -1px;
  padding-top: 1px;
  position: relative;
  isolation: isolate;
  font-family: var(--artvoic-font-body);
  overflow: clip;
  color: var(--artvoic-text-muted);
  padding: clamp(2.5rem, 6vw, 4rem) 1.35rem;
  padding-bottom: calc(clamp(2.5rem, 6vw, 4rem) + clamp(72px, 12vh, 120px));
  background: linear-gradient(180deg, var(--intensiv-kids-mid) 0%, var(--intensiv-kids-deep) 100%);
}

#intensiv-msk-how .intkids-section__inner {
  position: relative;
  z-index: 2;
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

#intensiv-msk-how .intkids-how-title {
  margin: 0 0 1rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.2rem, 2.8vw, 1.65rem);
  color: var(--artvoic-text);
}

#intensiv-msk-how .intkids-how-frame {
  margin: 0 auto;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(0, 255, 209, 0.22);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
  aspect-ratio: 16 / 9;
  max-width: 100%;
}

#intensiv-msk-how .intkids-how-frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Program */
#intensivkids-program, #intensiv-msk-program {
  padding-top: clamp(3rem, 7vw, 5.25rem);
  padding-left: 1.35rem;
  padding-right: 1.35rem;
  padding-bottom: calc(clamp(3rem, 7vw, 5.25rem) + clamp(72px, 12vh, 120px));
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-deep) 0%,
    #08091a 38%,
    var(--intensiv-kids-mid) 100%
  );
}

/* Приглушённое акцентное пятно по центру — верх секции только линейный фон без «выбела» у стыка */
#intensivkids-program::before, #intensiv-msk-program::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 70% 58% at 76% 58%, rgba(0, 255, 209, 0.07), transparent 62%);
  filter: blur(32px);
  opacity: 0.75;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.6) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 280px),
    #000 calc(100% - clamp(76px, 15vh, 150px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.6) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 280px),
    #000 calc(100% - clamp(76px, 15vh, 150px)),
    transparent 100%
  );
}

#intensivkids-program .intkids-section__head, #intensiv-msk-program .intkids-section__head {
  max-width: 720px;
  margin: 0 auto 2.5rem;
  text-align: center;
}

#intensivkids-program .intkids-section__kicker, #intensiv-msk-program .intkids-section__kicker {
  display: block;
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--artvoic-accent);
  margin-bottom: 0.6rem;
}

#intensivkids-program .intkids-section__title, #intensiv-msk-program .intkids-section__title {
  margin: 0;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 3.4vw, 2rem);
  color: var(--artvoic-text);
}

#intensivkids-program .intkids-steps, #intensiv-msk-program .intkids-steps {
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  gap: 1.1rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

#intensivkids-program .intkids-step, #intensiv-msk-program .intkids-step {
  position: relative;
  padding: 1.35rem 1.25rem 1.35rem 1.5rem;
  border-radius: 16px;
  background: rgba(12, 14, 32, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.07);
  box-shadow:
    inset 0 1px rgba(255, 255, 255, 0.04),
    0 0 32px rgba(108, 99, 255, 0.06);
}

#intensivkids-program .intkids-step::before, #intensiv-msk-program .intkids-step::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  bottom: 14px;
  width: 3px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--artvoic-accent), var(--artvoic-accent-purple));
  box-shadow: 0 0 16px rgba(0, 255, 209, 0.5);
}

#intensivkids-program .intkids-step h4, #intensiv-msk-program .intkids-step h4 {
  margin: 0 0 0.75rem;
  font-family: var(--artvoic-font-display);
  font-size: 1.12rem;
  color: var(--artvoic-text);
}

#intensivkids-program .intkids-step ul, #intensiv-msk-program .intkids-step ul {
  margin: 0;
  padding: 0 0 0 1.05rem;
  font-size: 0.93rem;
  line-height: 1.52;
}

#intensivkids-program .intkids-program-cta-wrap, #intensiv-msk-program .intkids-program-cta-wrap {
  text-align: center;
  margin-top: 2.5rem;
}

#intensivkids-program .intkids-btn-buy, #intensiv-msk-program .intkids-btn-buy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 2.35rem;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.88rem;
  text-decoration: none;
  background: linear-gradient(120deg, var(--artvoic-accent), #54ffe0);
  color: #061211;
  box-shadow:
    0 0 40px rgba(0, 255, 209, 0.35),
    0 16px 40px rgba(0, 0, 0, 0.4);
}

#intensivkids-program .intkids-btn-buy:hover, #intensiv-msk-program .intkids-btn-buy:hover {
  transform: translateY(-2px);
  box-shadow:
    0 0 48px rgba(0, 255, 209, 0.45),
    0 20px 52px rgba(0, 0, 0, 0.45);
}

/* Pay / юный актёр дубляжа — без радиала «латуни» сверху (стык с #intensivkids-moments) */
#intensivkids-pay, #intensiv-msk-pay {
  padding: clamp(3rem, 8vw, 5.75rem) 1.35rem;
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-mid) 0%,
    var(--intensiv-kids-deep) 58%,
    var(--intensiv-kids-deep) 100%
  );
}

#intensivkids-pay::before, #intensiv-msk-pay::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 76% 60% at 52% 58%, rgba(0, 255, 209, 0.07), transparent 64%),
    radial-gradient(ellipse 66% 50% at 82% 32%, rgba(108, 99, 255, 0.1), transparent 58%);
  filter: blur(36px);
  opacity: 0.85;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.58) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 260px),
    #000 calc(100% - 48px),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.58) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 260px),
    #000 calc(100% - 48px),
    transparent 100%
  );
}

#intensivkids-pay .intkids-pay-card, #intensiv-msk-pay .intkids-pay-card {
  max-width: 640px;
  margin: 0 auto;
  padding: clamp(1.85rem, 5vw, 2.65rem);
  border-radius: 26px;
  text-align: center;
  background: linear-gradient(160deg, rgba(18, 22, 48, 0.92), rgba(6, 7, 20, 0.88));
  border: 1px solid rgba(0, 255, 209, 0.25);
  box-shadow:
    0 0 80px rgba(108, 99, 255, 0.15),
    0 32px 80px rgba(0, 0, 0, 0.55);
}

#intensivkids-pay .intkids-pay-card h3, #intensiv-msk-pay .intkids-pay-card h3 {
  margin: 0 0 0.75rem;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.45rem, 3.8vw, 1.95rem);
  color: var(--artvoic-text);
}

#intensivkids-pay .intkids-pay-meta, #intensiv-msk-pay .intkids-pay-meta {
  margin: 1.35rem 0;
  font-size: 1.05rem;
  line-height: 1.68;
}

#intensivkids-pay .intkids-pay-meta strong, #intensiv-msk-pay .intkids-pay-meta strong {
  color: var(--artvoic-text);
}

#intensivkids-pay .intkids-urgency, #intensiv-msk-pay .intkids-urgency {
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.25rem, 3vw, 1.65rem);
  color: var(--artvoic-accent);
  text-shadow: 0 0 24px rgba(0, 255, 209, 0.35);
  margin: 1rem 0 0;
}

#intensivkids-pay .intkids-pay-notes, #intensiv-msk-pay .intkids-pay-notes {
  max-width: 560px;
  margin: 1.75rem auto 0;
  text-align: left;
  font-size: 0.95rem;
  line-height: 1.6;
}

#intensivkids-pay .intkids-pay-notes p:last-child, #intensiv-msk-pay .intkids-pay-notes p:last-child {
  text-align: right;
  margin-top: 2rem;
  font-family: var(--artvoic-font-display);
  font-size: 1.05rem;
  color: var(--artvoic-accent);
}

/* Gallery + tasks */
#intensivkids-moments, #intensiv-msk-moments {
  padding-top: clamp(3rem, 7vw, 5rem);
  padding-left: 1.35rem;
  padding-right: 1.35rem;
  padding-bottom: calc(clamp(4rem, 9vw, 6rem) + clamp(72px, 12vh, 120px));
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-mid) 0%,
    #070718 52%,
    var(--intensiv-kids-mid) 100%
  );
}

#intensivkids-moments::before, #intensiv-msk-moments::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 76% 56% at 52% 40%, rgba(108, 99, 255, 0.11), transparent 62%),
    radial-gradient(ellipse 64% 50% at 92% 72%, rgba(0, 255, 209, 0.07), transparent 58%);
  filter: blur(34px);
  opacity: 0.88;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.55) clamp(72px, 12vh, 140px),
    #000 clamp(112px, 18vh, 220px),
    #000 calc(100% - clamp(76px, 15vh, 150px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.55) clamp(72px, 12vh, 140px),
    #000 clamp(112px, 18vh, 220px),
    #000 calc(100% - clamp(76px, 15vh, 150px)),
    transparent 100%
  );
}

#intensivkids-moments .intkids-section__inner, #intensiv-msk-moments .intkids-section__inner {
  max-width: 1160px;
  margin: 0 auto;
}

#intensivkids-moments .intkids-tasks h3, #intensiv-msk-moments .intkids-tasks h3 {
  font-family: var(--artvoic-font-display);
  font-size: 1.2rem;
  color: var(--artvoic-text);
  letter-spacing: 0.06em;
  margin: 0 0 1rem;
}

#intensivkids-moments .intkids-tasks ul, #intensiv-msk-moments .intkids-tasks ul {
  columns: 1;
  gap: 1.75rem;
  margin: 0 0 2.5rem;
  padding: 0 0 0 1.2rem;
  font-size: 0.95rem;
  line-height: 1.55;
}

@media (min-width: 720px) {
  #intensivkids-moments .intkids-tasks ul, #intensiv-msk-moments .intkids-tasks ul {
    columns: 2;
  }
}

#intensivkids-moments .intkids-mosaic-head, #intensiv-msk-moments .intkids-mosaic-head {
  font-family: var(--artvoic-font-display);
  font-size: 1.05rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--artvoic-text-soft);
  margin: 0 0 1.25rem;
}

#intensivkids-moments .intkids-mosaic, #intensiv-msk-moments .intkids-mosaic {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 0.55rem;
}

@media (min-width: 600px) {
  #intensivkids-moments .intkids-mosaic, #intensiv-msk-moments .intkids-mosaic {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }
}

#intensivkids-moments .intkids-mosaic a, #intensiv-msk-moments .intkids-mosaic a {
  position: relative;
  display: block;
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 1;
  border: 1px solid rgba(0, 255, 209, 0.12);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.45);
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease;
}

#intensivkids-moments .intkids-mosaic a:hover, #intensiv-msk-moments .intkids-mosaic a:hover {
  transform: translateY(-3px) scale(1.02);
  box-shadow:
    0 0 28px rgba(0, 255, 209, 0.25),
    0 16px 40px rgba(0, 0, 0, 0.55);
  z-index: 1;
}

#intensivkids-moments .intkids-mosaic img, #intensiv-msk-moments .intkids-mosaic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Reviews */
#intensivkids-reviews-app, #intensiv-msk-reviews-app {
  padding: clamp(2.5rem, 6vw, 4rem) 1.35rem;
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-deep) 0%,
    var(--intensiv-kids-deep) 100%
  );
  position: relative;
}

/* Мягкий сход после блока оплаты (база была mid/deep смешением) */
#intensivkids-reviews-app::before, #intensiv-msk-reviews-app::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-mid) 0%,
    var(--intensiv-kids-deep) clamp(88px, 15vh, 160px),
    transparent clamp(140px, 24vh, 280px)
  );
  opacity: 0.55;
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 min(72%, calc(100% - 72px)), transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 min(72%, calc(100% - 72px)), transparent 100%);
}

#intensivkids-reviews-app .intkids-reviews-head, #intensiv-msk-reviews-app .intkids-reviews-head {
  position: relative;
  z-index: 1;
  text-align: center;
  font-family: var(--artvoic-font-display);
  font-size: 1.05rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--artvoic-text);
  margin: 0 0 1.5rem;
}

#intensivkids-reviews-app .intkids-review-frame-wrap, #intensiv-msk-reviews-app .intkids-review-frame-wrap {
  position: relative;
  z-index: 1;
  max-width: 540px;
  margin: 0 auto;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(0, 255, 209, 0.2);
  box-shadow:
    0 0 48px rgba(108, 99, 255, 0.12),
    0 24px 56px rgba(0, 0, 0, 0.5);
}

#intensivkids-reviews-app iframe, #intensiv-msk-reviews-app iframe {
  display: block;
  width: 100%;
  max-width: 528px;
  height: min(824px, 85vh);
  margin: 0 auto;
}

/* Map */
#intensivkids-map, #intensiv-msk-map {
  padding: clamp(2.75rem, 7vw, 5rem) 1.35rem clamp(4rem, 9vw, 6rem);
  background: linear-gradient(
    180deg,
    var(--intensiv-kids-deep) 0%,
    var(--intensiv-kids-mid) 62%,
    var(--site-footer-base) 100%
  );
  position: relative;
}

#intensivkids-map::before, #intensiv-msk-map::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 72% 56% at 80% 30%, rgba(0, 255, 209, 0.08), transparent 58%),
    radial-gradient(ellipse 68% 52% at 14% 64%, rgba(108, 99, 255, 0.11), transparent 56%);
  filter: blur(32px);
  opacity: 0.82;
  -webkit-mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.62) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 260px),
    #000 calc(100% - clamp(72px, 14vh, 140px)),
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    transparent 0%,
    rgba(0, 0, 0, 0.62) clamp(96px, 16vh, 180px),
    #000 clamp(140px, 22vh, 260px),
    #000 calc(100% - clamp(72px, 14vh, 140px)),
    transparent 100%
  );
}


#intensivkids-map .intkids-map-head, #intensiv-msk-map .intkids-map-head {
  position: relative;
  z-index: 1;
  text-align: center;
  font-family: var(--artvoic-font-display);
  font-size: clamp(1.35rem, 3.2vw, 1.75rem);
  color: var(--artvoic-text);
  margin: 0 0 2rem;
}

#intensivkids-map .intkids-map-grid, #intensiv-msk-map .intkids-map-grid {
  position: relative;
  z-index: 1;
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  gap: 1.75rem;
  align-items: stretch;
}

@media (min-width: 860px) {
  #intensivkids-map .intkids-map-grid, #intensiv-msk-map .intkids-map-grid {
    grid-template-columns: 1.1fr 0.9fr;
  }
}

#intensivkids-map .intkids-map-frame, #intensiv-msk-map .intkids-map-frame {
  border-radius: 18px;
  overflow: hidden;
  min-height: 320px;
  border: 1px solid rgba(0, 255, 209, 0.15);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

#intensivkids-map .intkids-map-frame iframe, #intensiv-msk-map .intkids-map-frame iframe {
  width: 100%;
  height: 100%;
  min-height: 320px;
  border: 0;
  display: block;
}

#intensivkids-map .intkids-address-block, #intensiv-msk-map .intkids-address-block {
  padding: 1.35rem 1.5rem;
  border-radius: 18px;
  background: rgba(10, 12, 30, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

#intensivkids-map .intkids-address-block p, #intensiv-msk-map .intkids-address-block p {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--artvoic-text-muted);
}

#intensivkids-map .intkids-address-block strong, #intensiv-msk-map .intkids-address-block strong {
  color: var(--artvoic-accent);
}

#intensivkids-map .intkids-map-phone, #intensiv-msk-map .intkids-map-phone {
  margin-top: 1.5rem;
}

#intensivkids-map .intkids-map-phone a, #intensiv-msk-map .intkids-map-phone a {
  font-family: var(--artvoic-font-display);
  font-size: 1.45rem;
  color: var(--artvoic-text);
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 255, 209, 0.3);
}

#intensivkids-map .intkids-map-phone-note, #intensiv-msk-map .intkids-map-phone-note {
  margin: 0.35rem 0 0;
  font-size: 0.95rem;
}

@media (prefers-reduced-motion: reduce) {
  #intensivkids-hero .intkids-smoke, #intensiv-msk-hero .intkids-smoke,
  #intensivkids-hero .intkids-aurora, #intensiv-msk-hero .intkids-aurora,
  #intensivkids-hero .intkids-countdown__cell, #intensiv-msk-hero .intkids-countdown__cell {
    animation: none !important;
  }

  #intensivkids-hero .intkids-hero-logo-plate::after, #intensiv-msk-hero .intkids-hero-logo-plate::after {
    animation: none;
  }

  #intensivkids-moments .intkids-mosaic a, #intensiv-msk-moments .intkids-mosaic a {
    transition: none;
  }
}

/* --- artvoic-voice-mini: мини-плеер «до / после» (общий UI) --- */
#social-proof .artvoic-voice-mini,
#course-after-audience .artvoic-voice-mini,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini {
  position: relative;
  margin-top: 0.65rem;
  padding: 0.5rem 0.55rem 0.5rem 0.45rem;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.35);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

#social-proof .artvoic-voice-mini__native,
#course-after-audience .artvoic-voice-mini__native,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__native {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

#social-proof .artvoic-voice-mini__row,
#course-after-audience .artvoic-voice-mini__row,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__row {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
}

#social-proof .artvoic-voice-mini__play,
#course-after-audience .artvoic-voice-mini__play,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__play {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--artvoic-font-body);
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    filter 0.18s ease;
}

#social-proof .artvoic-voice-mini__play {
  color: #0a0a12;
  background: var(--sp-portfolio-accent);
  box-shadow: 0 0 0 1px rgba(108, 99, 255, 0.35), 0 6px 18px rgba(108, 99, 255, 0.25);
}

#course-after-audience .artvoic-voice-mini__play,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__play {
  color: var(--artvoic-bg);
  background: var(--artvoic-accent);
  box-shadow:
    0 0 0 1px rgba(0, 255, 209, 0.35),
    0 6px 20px rgba(0, 255, 209, 0.18);
}

#social-proof .artvoic-voice-mini__play:hover,
#course-after-audience .artvoic-voice-mini__play:hover,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__play:hover {
  transform: scale(1.04);
  filter: brightness(1.06);
}

#social-proof .artvoic-voice-mini__play:focus-visible,
#course-after-audience .artvoic-voice-mini__play:focus-visible,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__play:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 2px;
}

#social-proof .artvoic-voice-mini__ico,
#course-after-audience .artvoic-voice-mini__ico,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__ico {
  display: block;
  flex-shrink: 0;
}

#social-proof .artvoic-voice-mini__ico--pause,
#course-after-audience .artvoic-voice-mini__ico--pause,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__ico--pause {
  display: none;
}

#social-proof .artvoic-voice-mini.is-playing .artvoic-voice-mini__ico--play,
#course-after-audience .artvoic-voice-mini.is-playing .artvoic-voice-mini__ico--play,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini.is-playing .artvoic-voice-mini__ico--play {
  display: none;
}

#social-proof .artvoic-voice-mini.is-playing .artvoic-voice-mini__ico--pause,
#course-after-audience .artvoic-voice-mini.is-playing .artvoic-voice-mini__ico--pause,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini.is-playing .artvoic-voice-mini__ico--pause {
  display: block;
}

#social-proof .artvoic-voice-mini__rail,
#course-after-audience .artvoic-voice-mini__rail,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__rail {
  position: relative;
  flex: 1;
  min-width: 0;
  height: 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  cursor: pointer;
}

#social-proof .artvoic-voice-mini__rail:focus-visible,
#course-after-audience .artvoic-voice-mini__rail:focus-visible,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__rail:focus-visible {
  outline: 2px solid var(--artvoic-accent);
  outline-offset: 3px;
}

#social-proof .artvoic-voice-mini__fill,
#course-after-audience .artvoic-voice-mini__fill,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0%;
  border-radius: inherit;
  pointer-events: none;
  transition: width 0.08s linear;
}

#social-proof .artvoic-voice-mini__fill {
  background: linear-gradient(90deg, rgba(108, 99, 255, 0.92), rgba(176, 159, 255, 0.95));
}

#course-after-audience .artvoic-voice-mini__fill,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__fill {
  background: linear-gradient(90deg, rgba(0, 255, 209, 0.88), rgba(125, 255, 235, 0.95));
}

#social-proof .artvoic-voice-mini__time,
#course-after-audience .artvoic-voice-mini__time,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__time {
  flex-shrink: 0;
  font-family: var(--artvoic-font-body);
  font-size: clamp(0.62rem, 0.12vw + 0.58rem, 0.72rem);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.65);
  white-space: nowrap;
}

#social-proof .artvoic-voice-mini__sep,
#course-after-audience .artvoic-voice-mini__sep,
:is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__sep {
  margin: 0 0.1em;
  opacity: 0.55;
}

@media (prefers-reduced-motion: reduce) {
  #social-proof .artvoic-voice-mini__fill,
  #course-after-audience .artvoic-voice-mini__fill,
  :is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__fill {
    transition: none;
  }

  #social-proof .artvoic-voice-mini__play,
  #course-after-audience .artvoic-voice-mini__play,
  :is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__play {
    transition: none;
  }

  #social-proof .artvoic-voice-mini__play:hover,
  #course-after-audience .artvoic-voice-mini__play:hover,
  :is(#kids-results, #imx-audience, #imx-value, #pco-audience, #pco-advantages) .artvoic-voice-mini__play:hover {
    transform: none;
    filter: none;
  }
}

/* --- Плагин Artvoic Leads: модальные окна заявок --- */
/* Базовые стили подключаются из плагина (assets/public.css). При необходимости переопределите здесь классы .artvoic-lead-* */
