:root {
  --green: #45bd4a;
  --green-2: #7adf64;
  --white: #ffffff;

  /*
    Базовая desktop-композиция:
    горизонтальные размеры — от vw, вертикальные позиции — от svh.
    Так макет на ноутбуке, 2K/4K и проекторе сохраняет одинаковую композицию,
    но не съезжает вниз на широких/невысоких окнах.
  */
  --nav-strip-h: clamp(54px, 4.8vw, 92px);

  --font-title: "CoFo Kak Black", "CoFo Kak", "Aptos Black", Verdana, sans-serif;
  --font-body: "Aptos Light", "Aptos", Verdana, sans-serif;
  --font-nav: "Aptos", Verdana, sans-serif;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
html { scroll-behavior: smooth; }
 
body {
  margin: 0;
  overflow: hidden;
  background: #07161d;
  color: var(--white);
  font-family: var(--font-body);
  font-weight: 300;
  font-synthesis: none;
}

.deck {
  position: relative;
  width: 100vw;
  height: 100svh;
  overflow: hidden;
}

.slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  isolation: isolate;
  background: #062732;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate3d(1.2vw, 0, 0);
  transition: opacity .35s ease, transform .35s ease, visibility .35s ease;
}

.slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate3d(0, 0, 0);
}

.bg,
.bg-vignette {
  position: absolute;
  inset: 0;
}

.bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.bg-vignette {
  z-index: 1;
  background:
    radial-gradient(circle at center, rgba(0,0,0,0) 0 16%, rgba(0,0,0,.07) 42%, rgba(0,0,0,.20) 100%),
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.13));
}

/* Лого опущено и выровнено по верхнему фасаду */
.logo {
  position: absolute;
  /* ниже, чтобы визуально центр логотипа совпадал с верхней схемой здания */
  top: clamp(64px, 8.15svh, 96px);
  left: clamp(34px, 3.35vw, 78px);
  width: clamp(190px, 15.15vw, 330px);
  height: auto;
  z-index: 6;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.18));
  animation-delay: .1s;
}

/* Верхняя схема стоит на том же уровне, что и лого */
.facade-line {
  position: absolute;
  top: clamp(46px, 5.8svh, 72px);
  left: clamp(390px, 32.7vw, 820px);
  width: clamp(390px, 31.6vw, 780px);
  height: auto;
  z-index: 5;
  opacity: .96;
  animation-delay: .35s;
  animation-duration: 1.25s;
}

.building {
  position: absolute;
  right: -2.2%;
  bottom: 0;
  width: clamp(680px, 52vw, 1500px);
  height: auto;
  z-index: 3;
  filter: drop-shadow(0 20px 32px rgba(0,0,0,.28));
  animation-delay: .55s;
  animation-duration: 1.1s;
}

/*
  Заголовок помещён в область из красной разметки:
  выше, компактнее по вертикали, без налезания на авторство.
*/
.title-wrap {
  position: absolute;
  top: clamp(188px, 22.6svh, 252px);
  left: clamp(38px, 3.75vw, 94px);
  width: 66vw;
  max-width: 1380px;
  z-index: 7;
  animation-delay: .25s;
}

h1 {
  margin: 0;
  font-family: var(--font-title);
  font-weight: 900;
  font-synthesis: none;
  font-size: clamp(2.65rem, min(3.78vw, 8.05svh), 7.25rem);
  line-height: .965;
  letter-spacing: .006em;
  text-transform: uppercase;
  white-space: nowrap;
  color: #fff;
  text-shadow: 0 12px 26px rgba(0,0,0,.18);
}

h1 span {
  text-transform: none;
}

/* Блок авторства стоит в нижней красной зоне и не пересекается с 2026 года */
.speaker-card {
  position: absolute;
  left: clamp(38px, 3.75vw, 94px);
  /* немного выше, как в макете */
  top: clamp(470px, 57.7svh, 685px);
  width: clamp(430px, 36vw, 780px);
  min-height: clamp(98px, 9.3vw, 180px);
  z-index: 8;
  padding: clamp(16px, 1.45vw, 34px) clamp(22px, 1.95vw, 46px) clamp(12px, 1vw, 28px);
  animation-delay: .8s;
}

.speaker-card p {
  display: inline;
  margin: 0;
  padding: .16em .22em .18em;
  background: var(--green);
  font-family: "Aptos Light", "Aptos", Verdana, sans-serif;
  font-weight: 300;
  font-synthesis: none;
  font-size: clamp(1.04rem, 1.36vw, 2.12rem);
  line-height: 1.28;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.speaker-card time {
  display: block;
  margin-top: clamp(6px, .62vw, 16px);
  font-family: "Aptos Light", "Aptos", Verdana, sans-serif;
  font-weight: 300;
  font-synthesis: none;
  font-size: clamp(.78rem, .84vw, 1.3rem);
  line-height: 1;
}

.corner {
  position: absolute;
  width: clamp(26px, 5.8%, 56px);
  aspect-ratio: 1;
  border-color: #fff;
  opacity: .98;
}

.corner-tl { left: 0; top: 0; border-top: clamp(3px, .22vw, 6px) solid; border-left: clamp(3px, .22vw, 6px) solid; }
.corner-tr { right: 0; top: 0; border-top: clamp(3px, .22vw, 6px) solid; border-right: clamp(3px, .22vw, 6px) solid; }
.corner-bl { left: 0; bottom: 0; border-bottom: clamp(3px, .22vw, 6px) solid; border-left: clamp(3px, .22vw, 6px) solid; }
.corner-br { right: 0; bottom: 0; border-bottom: clamp(3px, .22vw, 6px) solid; border-right: clamp(3px, .22vw, 6px) solid; }

.slide-nav {
  position: absolute;
  left: clamp(30px, 2.75vw, 74px);
  right: clamp(30px, 2.75vw, 74px);
  /* чуть ниже, ближе к нижней границе */
  bottom: max(clamp(4px, .42vw, 12px), env(safe-area-inset-bottom));
  min-height: var(--nav-strip-h);
  padding: clamp(6px, .48vw, 10px);
  display: flex;
  flex-wrap: nowrap;
  gap: clamp(3px, .26vw, 6px);
  align-items: center;
  z-index: 30;
  border-radius: clamp(14px, .95vw, 22px);
  border: 1px solid rgba(111, 224, 255, .18);
  background:
    linear-gradient(180deg, rgba(7, 20, 28, .18), rgba(8, 22, 31, .76) 28%, rgba(8, 22, 31, .94)),
    radial-gradient(circle at 50% 0%, rgba(0, 211, 255, .12), transparent 48%);
  backdrop-filter: blur(10px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 16px 34px rgba(0,0,0,.32);
}

.slide-nav::before {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  top: -10px;
  height: 20px;
  border-radius: 999px;
  background: radial-gradient(circle at center, rgba(45,170,255,.20), rgba(45,170,255,0) 70%);
  filter: blur(10px);
  pointer-events: none;
}

.slide-nav a {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
  height: clamp(32px, 2.8vw, 56px);
  display: inline-grid;
  place-items: center;
  text-decoration: none;
  color: rgba(255,255,255,.92);
  border-radius: clamp(8px, .55vw, 13px);
  border: 1px solid rgba(121, 230, 255, .18);
  background: linear-gradient(180deg, rgba(13,38,49,.55), rgba(8,23,30,.82));
  font-family: var(--font-nav);
  font-weight: 400;
  font-synthesis: none;
  font-size: clamp(.66rem, .76vw, 1rem);
  line-height: 1;
  white-space: nowrap;
  transition: transform .18s ease, filter .18s ease, opacity .18s ease, background .18s ease, border-color .18s ease;
}

.slide-nav a:hover {
  transform: translateY(-2px);
  filter: brightness(1.08);
}

.slide-nav a[aria-current="page"] {
  color: #fff;
  border-color: rgba(154, 255, 146, .62);
  background: linear-gradient(180deg, #5fd462, #42b64a);
  box-shadow: 0 0 0 1px rgba(255,255,255,.15) inset, 0 0 22px rgba(95,212,98,.28);
}

.slide-nav a[aria-disabled="true"] {
  cursor: default;
}

@keyframes localFadeInLeft { from { opacity: 0; transform: translate3d(-36px,0,0); } to { opacity: 1; transform: none; } }
@keyframes localFadeInUp { from { opacity: 0; transform: translate3d(0,34px,0); } to { opacity: 1; transform: none; } }
@keyframes localFadeInDown { from { opacity: 0; transform: translate3d(0,-24px,0); } to { opacity: 1; transform: none; } }
@keyframes localFadeIn { from { opacity: 0; } to { opacity: 1; } }

.animate__fadeInLeft { animation-name: localFadeInLeft; }
.animate__fadeInUp { animation-name: localFadeInUp; }
.animate__fadeInDown { animation-name: localFadeInDown; }
.animate__fadeIn { animation-name: localFadeIn; }
.animate__animated { animation-duration: .95s; animation-fill-mode: both; animation-timing-function: cubic-bezier(.2,.75,.25,1); }

/* Только планшеты/очень компактный landscape. Desktop-экраны этим не затрагиваются. */
@media (max-width: 1024px) and (orientation: landscape) {
  :root { --nav-strip-h: clamp(46px, 7.2svh, 60px); }

  .logo {
    top: 46px;
    left: 3%;
    width: clamp(144px, 16vw, 188px);
  }

  .facade-line {
    top: 30px;
    left: 34%;
    width: clamp(245px, 31vw, 350px);
  }

  .title-wrap {
    top: clamp(118px, 22svh, 150px);
    left: 3.2%;
    width: 66vw;
  }

  h1 {
    font-size: clamp(1.68rem, min(4.28vw, 7.35svh), 2.85rem);
    line-height: .97;
  }

  .building {
    right: -5%;
    width: clamp(410px, 54vw, 575px);
  }

  .speaker-card {
    left: 3.2%;
    top: clamp(304px, 57.5svh, 392px);
    width: clamp(300px, 39vw, 430px);
    min-height: clamp(76px, 12svh, 100px);
    padding: 11px 16px 8px;
  }

  .speaker-card p {
    font-size: clamp(.78rem, 1.58vw, 1rem);
    line-height: 1.25;
  }

  .speaker-card time {
    margin-top: 5px;
    font-size: clamp(.64rem, 1vw, .82rem);
  }

  .corner { width: clamp(20px, 5%, 32px); }

  .slide-nav {
    left: 2%;
    right: 2%;
    bottom: max(4px, env(safe-area-inset-bottom));
    padding: 5px;
    gap: 2px;
    border-radius: 14px;
  }

  .slide-nav a {
    height: clamp(27px, 4.2svh, 35px);
    border-radius: 8px;
    font-size: clamp(.58rem, 1.36svh, .76rem);
  }
}



/* ===== Slide 3: Изменения ===== */

.slide-changes .bg {
  opacity: .56;
  filter: saturate(1.03) contrast(1.04);
}

.slide-changes .bg-vignette {
  background:
    radial-gradient(circle at 40% 48%, rgba(0, 71, 93, .28), transparent 34%),
    linear-gradient(90deg, rgba(0,0,0,.20), rgba(0,0,0,.06) 50%, rgba(0,0,0,.18)),
    linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.04) 45%, rgba(0,0,0,.22));
}

.changes-logo {
  top: clamp(34px, 4.9svh, 60px);
  left: clamp(40px, 4vw, 90px);
  width: clamp(184px, 14vw, 304px);
}

.changes-facade-line {
  top: clamp(42px, 5.45svh, 74px);
  left: auto;
  right: -3.5%;
  width: clamp(370px, 33vw, 780px);
  opacity: .82;
}

.changes-shell {
  position: absolute;
  inset: 0;
  z-index: 7;
  padding:
    clamp(34px, 4.1svh, 60px)
    clamp(34px, 3.1vw, 74px)
    calc(var(--nav-strip-h) + clamp(12px, 1.2svh, 22px));
}

.changes-head {
  position: absolute;
  top: clamp(34px, 4.3svh, 58px);
  left: 22.8vw;
  display: flex;
  align-items: center;
}

.changes-head h2 {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-synthesis: none;
  font-size: clamp(2rem, min(2.45vw, 5.2svh), 4.45rem);
  line-height: .98;
  letter-spacing: .012em;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 10px 22px rgba(0,0,0,.22);
}

.changes-table {
  position: absolute;
  top: clamp(106px, 13.6svh, 158px);
  left: clamp(26px, 2.25vw, 56px);
  right: clamp(26px, 2.25vw, 56px);
  bottom: calc(var(--nav-strip-h) + clamp(8px, .9svh, 16px));
  display: grid;
  grid-template-rows: 42px repeat(8, auto);
  gap: 8px;
}

.changes-row {
  display: grid;
  grid-template-columns: 2.05fr .62fr .68fr 1.65fr;
  border: 1px solid rgba(95, 208, 170, .14);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(6, 27, 35, .42), rgba(4, 20, 27, .55));
  overflow: hidden;
  backdrop-filter: blur(4px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

.changes-row-span {
  grid-template-columns: 2.05fr 1.30fr 1.65fr;
}

.changes-header-row {
  min-height: 42px;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.changes-cell {
  padding: 10px 12px;
  border-right: 1px solid rgba(95, 208, 170, .12);
  color: rgba(255,255,255,.95);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.changes-row .changes-cell:last-child,
.changes-row-span .changes-cell:last-child {
  border-right: 0;
}

.changes-topic-head,
.changes-year {
  justify-content: center;
  padding: 0 8px;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(1.06rem, 1.22vw, 1.55rem);
  color: #fff;
}

.changes-topic-head {
  justify-content: center;
  text-align: center;
  color: rgba(255,255,255,.84);
}

.changes-topic {
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-size: clamp(.84rem, .92vw, 1.1rem);
  line-height: 1.18;
}

.changes-center {
  justify-content: center;
  text-align: center;
}

.changes-value {
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-variant-numeric: tabular-nums;
  font-size: clamp(1.45rem, 1.85vw, 2.35rem);
  line-height: 1;
  letter-spacing: .01em;
}

.changes-mark {
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-size: clamp(1.72rem, 2.1vw, 2.8rem);
  line-height: 1;
}

.changes-note {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-size: clamp(.74rem, .78vw, .92rem);
  line-height: 1.18;
  color: rgba(255,255,255,.92);
}

.changes-note span {
  display: block;
  margin-bottom: 3px;
}

.changes-note-center {
  align-items: center;
  text-align: center;
}

.changes-span-note {
  font-size: clamp(.8rem, .84vw, 1rem);
  color: rgba(255,255,255,.92);
}

.changes-empty {
  color: transparent;
}

.is-alert-soft {
  color: #ff8b82;
}

.is-soft-muted {
  color: rgba(255,255,255,.92);
}

.is-positive-soft {
  color: #ff8b82;
}

.changes-row-tall .changes-cell,
.changes-row-mid .changes-cell {
  padding-top: 9px;
  padding-bottom: 9px;
}

@media (max-width: 1366px) and (orientation: landscape) {
  .changes-head {
    left: 23vw;
  }

  .changes-table {
    top: clamp(96px, 13svh, 138px);
    gap: 6px;
    grid-template-rows: 36px repeat(8, auto);
  }

  .changes-row {
    grid-template-columns: 1.95fr .6fr .66fr 1.79fr;
    border-radius: 12px;
  }

  .changes-row-span {
    grid-template-columns: 1.95fr 1.26fr 1.79fr;
  }

  .changes-cell {
    padding: 8px 10px;
  }

  .changes-topic-head,
  .changes-year {
    font-size: clamp(.94rem, 1.06vw, 1.2rem);
  }

  .changes-topic {
    font-size: clamp(.74rem, .82vw, .92rem);
    line-height: 1.16;
  }

  .changes-value {
    font-size: clamp(1.22rem, 1.58vw, 1.85rem);
  }

  .changes-mark {
    font-size: clamp(1.4rem, 1.72vw, 2.1rem);
  }

  .changes-note,
  .changes-span-note {
    font-size: clamp(.64rem, .68vw, .8rem);
    line-height: 1.14;
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  .changes-logo {
    top: 30px;
    width: clamp(132px, 15vw, 170px);
  }

  .changes-facade-line {
    top: 34px;
    width: clamp(260px, 31vw, 370px);
  }

  .changes-head {
    top: 32px;
    left: 24vw;
  }

  .changes-head h2 {
    font-size: clamp(1.25rem, 2.3vw, 1.7rem);
  }

  .changes-table {
    top: 92px;
    left: 2.2%;
    right: 2.2%;
    bottom: calc(var(--nav-strip-h) + 8px);
    gap: 5px;
    grid-template-rows: 30px repeat(8, auto);
  }

  .changes-row {
    grid-template-columns: 1.78fr .56fr .62fr 1.86fr;
    border-radius: 10px;
  }

  .changes-row-span {
    grid-template-columns: 1.78fr 1.18fr 1.86fr;
  }

  .changes-cell {
    padding: 6px 8px;
  }

  .changes-topic-head,
  .changes-year {
    font-size: .76rem;
  }

  .changes-topic {
    font-size: .62rem;
    line-height: 1.13;
  }

  .changes-value {
    font-size: 1rem;
  }

  .changes-mark {
    font-size: 1.18rem;
  }

  .changes-note,
  .changes-span-note {
    font-size: .54rem;
    line-height: 1.12;
  }
}

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

/* ===== Slide 2: close to original PPT layout ===== */

.slide-kpi {
  font-family: "Aptos", Verdana, sans-serif;
}

.slide-kpi .bg {
  opacity: .58;
  filter: saturate(1.05) contrast(1.04);
}

.slide-kpi .bg-vignette {
  background:
    radial-gradient(circle at 44% 47%, rgba(0, 56, 70, .34), transparent 35%),
    linear-gradient(90deg, rgba(0,0,0,.22), rgba(0,0,0,.06) 50%, rgba(0,0,0,.2)),
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.04) 48%, rgba(0,0,0,.24));
}

.kpi-logo {
  top: clamp(34px, 4.9svh, 60px);
  left: clamp(40px, 4vw, 90px);
  width: clamp(184px, 14.5vw, 318px);
}

.kpi-facade-top {
  top: clamp(48px, 6.3svh, 86px);
  left: auto;
  right: -3.5%;
  width: clamp(370px, 33vw, 780px);
  opacity: .82;
}

.kpi-facade-bottom {
  position: absolute;
  left: -5%;
  top: auto;
  bottom: clamp(132px, 15.2svh, 200px);
  width: clamp(340px, 29vw, 700px);
  opacity: .72;
  z-index: 3;
}

.kpi-page {
  position: absolute;
  inset: 0;
  z-index: 7;
}

.kpi-title {
  position: absolute;
  top: clamp(34px, 4.3svh, 58px);
  left: 22.8vw;
  margin: 0;
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-synthesis: none;
  font-size: clamp(2rem, min(2.45vw, 5.2svh), 4.45rem);
  line-height: .98;
  letter-spacing: .012em;
  text-transform: uppercase;
  text-shadow: 0 10px 22px rgba(0,0,0,.22);
}

.kpi-total {
  position: absolute;
  top: clamp(118px, 15.2svh, 178px);
  left: clamp(54px, 4.2vw, 112px);
  display: flex;
  align-items: baseline;
  gap: clamp(18px, 2vw, 44px);
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.18));
}

.kpi-total strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(4.1rem, min(6.1vw, 13svh), 10.8rem);
  line-height: .82;
  letter-spacing: .11em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  background: linear-gradient(90deg, #b87cff 0%, #87a5ff 32%, #4cc4ff 64%, #1ce89f 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.kpi-total span {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(1.45rem, min(2vw, 4.3svh), 3.4rem);
  line-height: 1;
  background: linear-gradient(90deg, #8aa6ff 0%, #54c4ff 48%, #1ce89f 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.kpi-table {
  position: absolute;
  top: clamp(232px, 28.8svh, 330px);
  left: clamp(60px, 4.2vw, 112px);
  width: min(67vw, 1350px);
  display: grid;
  grid-template-rows: repeat(3, auto);
  row-gap: clamp(34px, 5.2svh, 84px);
}

.kpi-row {
  display: grid;
  grid-template-columns: minmax(320px, 33vw) minmax(170px, 14vw) minmax(220px, 18vw);
  align-items: start;
  column-gap: clamp(22px, 2.2vw, 58px);
}

.kpi-row h3 {
  margin: clamp(8px, .75vw, 16px) 0 0;
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-synthesis: none;
  font-size: clamp(1.38rem, min(1.72vw, 3.6svh), 3rem);
  line-height: 1.02;
  text-transform: uppercase;
}

.kpi-green,
.kpi-blue,
.kpi-side strong {
  display: block;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-synthesis: none;
  font-size: clamp(3rem, min(4vw, 8.8svh), 7.4rem);
  line-height: .86;
  letter-spacing: .03em;
  font-variant-numeric: tabular-nums;
}

.kpi-green {
  color: #00e88a;
}

.kpi-blue,
.kpi-side strong {
  color: #05aef1;
}

.kpi-side span {
  display: block;
  margin-top: clamp(6px, .45vw, 10px);
  color: #00b9ff;
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-size: clamp(.82rem, min(.92vw, 2svh), 1.55rem);
  line-height: 1.06;
}

.kpi-side b {
  font-weight: 400;
  font-variant-numeric: tabular-nums;
}

.kpi-bottom-totals {
  position: absolute;
  left: clamp(430px, 34.1vw, 860px);
  right: auto;
  top: calc(clamp(565px, 70.65svh, 805px) - 5px);
  bottom: auto;
  display: grid;
  grid-template-columns: auto auto;
  gap: clamp(54px, 6.8vw, 160px);
  align-items: start;
  justify-items: center;
  text-align: center;
  min-width: 0;
  z-index: 8;
}

.kpi-bottom-totals strong {
  display: block;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(3.25rem, min(4.45vw, 9.25svh), 7.4rem);
  line-height: .82;
  letter-spacing: .08em;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.kpi-bottom-totals span {
  display: block;
  margin-top: clamp(8px, .6vw, 14px);
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(1.08rem, min(1.28vw, 2.8svh), 2.1rem);
  line-height: .98;
}

.kpi-bottom-totals div:first-child span {
  color: #00e88a;
}

.kpi-bottom-totals div:nth-child(2) span {
  color: #05aef1;
}

.kpi-bottom-totals div:nth-child(2) {
  transform: translateX(clamp(-72px, -3.2vw, -28px));
}

.kpi-bottom-totals > div {
  display: inline-grid;
  justify-items: center;
  text-align: center;
}

.kpi-bottom-totals span {
  width: 100%;
  text-align: center;
}


.kpi-dashboard {
  position: absolute;
  top: clamp(196px, 24.8svh, 296px);
  right: clamp(70px, 5.8vw, 138px);
  width: clamp(250px, 20vw, 440px);
  height: clamp(118px, 12svh, 182px);
  z-index: 8;
}

.kpi-dashboard strong {
  position: absolute;
  transform: none;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-synthesis: none;
  font-size: clamp(2.2rem, min(3vw, 6.6svh), 5.6rem);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  background: linear-gradient(105deg, #b77cff 0%, #79a7ff 48%, #20d7ff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.22));
}

.kpi-dashboard strong:first-of-type {
  top: 8%;
  left: 12%;
}

.kpi-dashboard strong:last-of-type {
  right: 10%;
  bottom: 8%;
}

.kpi-dashboard .corner {
  width: clamp(26px, 2vw, 44px);
  border-color: #00e88a;
}

.kpi-dashboard-link {
  position: absolute;
  right: clamp(70px, 5.8vw, 138px);
  left: auto;
  bottom: calc(var(--nav-strip-h) + clamp(32px, 3.7svh, 54px));
  z-index: 8;
  color: rgba(255,255,255,.92);
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-size: clamp(.95rem, min(1.05vw, 2.2svh), 1.75rem);
  line-height: 1;
  text-transform: uppercase;
  text-decoration: underline;
  text-underline-offset: .18em;
  text-shadow: 0 8px 18px rgba(0,0,0,.32);
}

@media (max-width: 1280px) and (orientation: landscape) {
  .kpi-title { left: 23vw; font-size: clamp(1.6rem, 2.35vw, 2.25rem); }
  .kpi-total { top: clamp(106px, 15svh, 138px); }
  .kpi-total strong { font-size: clamp(3.5rem, 5.6vw, 5.8rem); }
  .kpi-total span { font-size: clamp(1.18rem, 1.85vw, 1.9rem); }
  .kpi-table { top: clamp(200px, 29svh, 245px); row-gap: clamp(24px, 4.2svh, 44px); }
  .kpi-row { grid-template-columns: 31vw 13.5vw 18vw; column-gap: 28px; }
  .kpi-row h3 { font-size: clamp(1.12rem, 1.6vw, 1.55rem); }
  .kpi-green, .kpi-blue, .kpi-side strong { font-size: clamp(2.4rem, 3.7vw, 3.95rem); }
  .kpi-bottom-totals { left: 34vw; right: auto; top: calc(clamp(512px, 69.85svh, 618px) - 5px); bottom: auto; grid-template-columns: auto auto; gap: 42px; }
  .kpi-bottom-totals strong { font-size: clamp(2.55rem, 3.95vw, 4.05rem); }
  .kpi-bottom-totals span { font-size: clamp(.88rem, 1.18vw, 1.18rem); }
  .kpi-dashboard { top: clamp(175px, 25svh, 220px); right: 4.8vw; width: 250px; height: 128px; }
  .kpi-dashboard-link { right: 4.8vw; left: auto; bottom: calc(var(--nav-strip-h) + 26px); }
}

@media (max-width: 1024px) and (orientation: landscape) {
  .kpi-logo { top: 30px; width: clamp(130px, 15vw, 170px); }
  .kpi-facade-top { top: 34px; width: clamp(260px, 31vw, 370px); }
  .kpi-title { left: 24vw; top: 32px; font-size: clamp(1.25rem, 2.3vw, 1.7rem); }
  .kpi-total { top: 92px; left: 4vw; gap: 14px; }
  .kpi-total strong { font-size: clamp(2.75rem, 5.6vw, 3.8rem); }
  .kpi-total span { font-size: clamp(.95rem, 1.8vw, 1.25rem); background: linear-gradient(90deg, #8aa6ff 0%, #54c4ff 50%, #1ce89f 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
  .kpi-table { top: 172px; left: 4vw; width: 69vw; row-gap: 18px; }
  .kpi-row { grid-template-columns: 30vw 13vw 18vw; column-gap: 18px; }
  .kpi-row h3 { font-size: clamp(.88rem, 1.52vw, 1.1rem); }
  .kpi-green, .kpi-blue, .kpi-side strong { font-size: clamp(1.75rem, 3.4vw, 2.4rem); }
  .kpi-side span { font-size: .62rem; }
  .kpi-dashboard { top: 166px; right: 4vw; width: 176px; height: 88px; }
  .kpi-dashboard strong { font-size: 1.8rem; background: linear-gradient(105deg, #b77cff 0%, #79a7ff 48%, #20d7ff 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
  .kpi-dashboard strong:first-of-type { top: 8%; left: 12%; }
  .kpi-dashboard strong:last-of-type { right: 10%; bottom: 8%; }
  .kpi-bottom-totals { left: 33vw; right: auto; top: 441px; bottom: auto; grid-template-columns: auto auto; gap: 24px; }
  .kpi-bottom-totals strong { font-size: clamp(1.8rem, 3.65vw, 2.35rem); }
  .kpi-bottom-totals span { font-size: clamp(.66rem, 1.18vw, .84rem); }
  .kpi-dashboard-link { right: 4vw; left: auto; bottom: calc(var(--nav-strip-h) + 16px); font-size: .68rem; }
    .kpi-bottom-totals div:nth-child(2) { transform: translateX(-18px); }
  .kpi-facade-bottom { bottom: 96px; width: 285px; }
}


/* Slide 3 final table alignment overrides */
.slide-changes .changes-cell,
.slide-changes .changes-topic,
.slide-changes .changes-note,
.slide-changes .changes-span-note {
  justify-content: center;
  align-items: center;
  text-align: center;
}

.slide-changes .changes-note span {
  text-align: center;
}


/* ===== Slide 2: stable KPI grid refinement ===== */

.slide-kpi {
  --kpi-left: clamp(46px, 3.8vw, 92px);
  --kpi-right: clamp(42px, 3.4vw, 92px);
  --kpi-table-top: clamp(210px, 27svh, 320px);
  --kpi-row-h: clamp(92px, 14svh, 178px);
  --kpi-row-gap: clamp(7px, 1.1svh, 14px);
  --kpi-cols: minmax(260px, 2.55fr) minmax(135px, .92fr) minmax(42px, .32fr) minmax(150px, .92fr) minmax(48px, .5fr);
}

/* 5 110 мест (без учета...) — как в референсе */
.slide-kpi .kpi-total {
  top: clamp(110px, 14.2svh, 172px);
  left: var(--kpi-left);
  display: flex;
  align-items: baseline;
  gap: clamp(14px, 1.2vw, 28px);
  white-space: nowrap;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.18));
}

.slide-kpi .kpi-total strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-synthesis: none;
  font-size: clamp(4.1rem, min(6.25vw, 12.8svh), 10.6rem);
  line-height: .82;
  letter-spacing: .10em;
  font-variant-numeric: tabular-nums;
  background: linear-gradient(90deg, #b77dff 0%, #8ba1ff 42%, #51c6ff 72%, #1fe6a3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.slide-kpi .kpi-total-word {
  display: inline-block;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(1.42rem, min(1.92vw, 4svh), 3.25rem);
  line-height: 1;
  color: #5fc0ff;
  background: none;
  -webkit-background-clip: initial;
  background-clip: initial;
}

.slide-kpi .kpi-total small {
  display: inline-block;
  margin-left: clamp(-8px, -.35vw, -3px);
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(.72rem, min(.95vw, 2svh), 1.48rem);
  line-height: 1;
  color: #28e7aa;
}

/* точная сетка строк: подпись / зеленое значение / разделитель / синее значение / запас */
.slide-kpi .kpi-table {
  top: var(--kpi-table-top);
  left: var(--kpi-left);
  right: var(--kpi-right);
  width: auto;
  display: grid;
  grid-template-rows: repeat(3, var(--kpi-row-h));
  gap: var(--kpi-row-gap);
}

.slide-kpi .kpi-row {
  display: grid;
  grid-template-columns: var(--kpi-cols);
  align-items: center;
  min-height: var(--kpi-row-h);
  height: var(--kpi-row-h);
  column-gap: 0;
  border-radius: clamp(12px, .9vw, 18px);
  border: 1px solid rgba(111, 224, 255, .14);
  background:
    linear-gradient(180deg, rgba(6, 27, 35, .34), rgba(4, 20, 27, .46));
  overflow: hidden;
}

.slide-kpi .kpi-row h3 {
  grid-column: 1;
  align-self: center;
  justify-self: start;
  margin: 0;
  padding-left: clamp(18px, 1.7vw, 42px);
  max-width: 100%;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.28rem, min(1.82vw, 3.6svh), 3.1rem);
  line-height: 1.04;
  letter-spacing: .005em;
  color: #fff;
  text-transform: uppercase;
}

.slide-kpi .kpi-row > .kpi-green {
  grid-column: 2;
  justify-self: center;
  align-self: center;
}

.slide-kpi .kpi-side {
  grid-column: 4;
  justify-self: center;
  align-self: center;
  min-width: 0;
  width: max-content;
}

.slide-kpi .kpi-green,
.slide-kpi .kpi-blue,
.slide-kpi .kpi-side strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(3.15rem, min(4.35vw, 8.8svh), 7.55rem);
  line-height: .86;
  letter-spacing: .07em;
  font-variant-numeric: tabular-nums;
}

.slide-kpi .kpi-side span {
  display: block;
  margin-top: clamp(7px, .55vw, 12px);
  color: #00b9ff;
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-size: clamp(.78rem, min(.9vw, 1.8svh), 1.35rem);
  line-height: 1.08;
  text-align: left;
  white-space: nowrap;
}

/* нижний блок — строго в тех же колонках, без разъезда при масштабировании */
.slide-kpi .kpi-bottom-totals {
  left: var(--kpi-left);
  right: var(--kpi-right);
  top: calc(
    var(--kpi-table-top)
    + var(--kpi-row-h)
    + var(--kpi-row-h)
    + var(--kpi-row-h)
    + var(--kpi-row-gap)
    + var(--kpi-row-gap)
    + clamp(10px, 1.4svh, 22px)
  );
  bottom: auto;
  width: auto;
  min-width: 0;
  display: grid;
  grid-template-columns: var(--kpi-cols);
  gap: 0;
  align-items: start;
  justify-items: center;
  text-align: center;
  z-index: 8;
}

.slide-kpi .kpi-bottom-totals > div {
  display: inline-grid;
  justify-items: center;
  text-align: center;
  transform: none;
}

.slide-kpi .kpi-bottom-totals > div:first-child {
  grid-column: 2;
}

.slide-kpi .kpi-bottom-totals > div:nth-child(2) {
  grid-column: 4;
  transform: none;
}

.slide-kpi .kpi-bottom-totals strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(3rem, min(4.45vw, 8.8svh), 7.4rem);
  line-height: .82;
  letter-spacing: .08em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.slide-kpi .kpi-bottom-totals span {
  width: 100%;
  margin-top: clamp(7px, .6vw, 14px);
  text-align: center;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(.98rem, min(1.28vw, 2.55svh), 2.05rem);
  line-height: .98;
}

@media (max-width: 1366px) and (orientation: landscape) {
  .slide-kpi {
    --kpi-left: clamp(32px, 3.2vw, 54px);
    --kpi-right: clamp(28px, 2.8vw, 48px);
    --kpi-table-top: clamp(188px, 26.3svh, 226px);
    --kpi-row-h: clamp(82px, 13.4svh, 104px);
    --kpi-row-gap: 7px;
    --kpi-cols: minmax(230px, 2.45fr) minmax(112px, .9fr) minmax(34px, .30fr) minmax(126px, .9fr) minmax(34px, .42fr);
  }

  .slide-kpi .kpi-total {
    top: clamp(94px, 13.8svh, 120px);
    gap: 14px;
  }

  .slide-kpi .kpi-total strong {
    font-size: clamp(3.25rem, 5.55vw, 5.35rem);
  }

  .slide-kpi .kpi-total-word {
    font-size: clamp(1.05rem, 1.75vw, 1.65rem);
  }

  .slide-kpi .kpi-total small {
    font-size: clamp(.58rem, .86vw, .82rem);
  }

  .slide-kpi .kpi-row h3 {
    padding-left: 22px;
    font-size: clamp(1rem, 1.62vw, 1.45rem);
  }

  .slide-kpi .kpi-green,
  .slide-kpi .kpi-blue,
  .slide-kpi .kpi-side strong {
    font-size: clamp(2.35rem, 3.8vw, 3.9rem);
  }

  .slide-kpi .kpi-side span {
    font-size: clamp(.62rem, .86vw, .8rem);
  }

  .slide-kpi .kpi-bottom-totals strong {
    font-size: clamp(2.3rem, 3.9vw, 3.95rem);
  }

  .slide-kpi .kpi-bottom-totals span {
    font-size: clamp(.72rem, 1.12vw, 1.08rem);
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  .slide-kpi {
    --kpi-left: 3vw;
    --kpi-right: 2.5vw;
    --kpi-table-top: 166px;
    --kpi-row-h: 72px;
    --kpi-row-gap: 6px;
    --kpi-cols: minmax(185px, 2.25fr) minmax(80px, .86fr) minmax(24px, .24fr) minmax(90px, .86fr) minmax(20px, .35fr);
  }

  .slide-kpi .kpi-total {
    top: 86px;
    gap: 10px;
  }

  .slide-kpi .kpi-total strong {
    font-size: clamp(2.55rem, 5.5vw, 3.55rem);
  }

  .slide-kpi .kpi-total-word {
    font-size: clamp(.9rem, 1.75vw, 1.12rem);
  }

  .slide-kpi .kpi-total small {
    font-size: clamp(.48rem, .9vw, .62rem);
  }

  .slide-kpi .kpi-row {
    border-radius: 10px;
  }

  .slide-kpi .kpi-row h3 {
    padding-left: 14px;
    font-size: clamp(.76rem, 1.62vw, 1rem);
  }

  .slide-kpi .kpi-green,
  .slide-kpi .kpi-blue,
  .slide-kpi .kpi-side strong {
    font-size: clamp(1.75rem, 3.6vw, 2.35rem);
  }

  .slide-kpi .kpi-side span {
    margin-top: 5px;
    font-size: .56rem;
  }

  .slide-kpi .kpi-bottom-totals strong {
    font-size: clamp(1.6rem, 3.5vw, 2.25rem);
  }

  .slide-kpi .kpi-bottom-totals span {
    font-size: clamp(.55rem, 1.1vw, .74rem);
  }
}


/* Slide 2: remove 74,4/75,4 block and move dashboard link left */
.slide-kpi .kpi-dashboard {
  display: none !important;
}

.slide-kpi .kpi-dashboard-link {
  left: var(--kpi-left) !important;
  right: auto !important;
  bottom: calc(var(--nav-strip-h) + clamp(30px, 3.6svh, 54px)) !important;
  text-align: left;
}


/* ===== Slide 4: restore previous slide-2 changes + refine changes table ===== */

/* More room for 2026 content: narrower topic and 2024/2025 columns, wider 2026. */
#slide-4 .changes-row {
  grid-template-columns: 2.05fr .56fr .56fr 1.95fr;
}

#slide-4 .changes-row-span {
  grid-template-columns: 2.05fr 1.12fr 1.95fr;
}

/* Center everything in cells vertically and horizontally. */
#slide-4 .changes-cell,
#slide-4 .changes-topic,
#slide-4 .changes-note,
#slide-4 .changes-span-2 {
  align-items: center;
  justify-content: center;
  text-align: center;
}

/* 2026 content with a red plus: plus is vertically centered, text gets the rest of the cell. */
#slide-4 .changes-note-with-sign {
  display: grid;
  grid-template-columns: clamp(30px, 2.7vw, 56px) minmax(0, 1fr);
  align-items: center;
  justify-items: center;
  column-gap: clamp(8px, .7vw, 14px);
  padding: clamp(8px, .75vw, 14px) clamp(10px, .95vw, 18px);
  text-align: left;
}

#slide-4 .changes-sign {
  align-self: center;
  justify-self: center;
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 700;
  font-size: clamp(1.9rem, 2.25vw, 3rem);
  line-height: 1;
}

#slide-4 .changes-note-copy {
  display: flex;
  width: 100%;
  min-width: 0;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  text-align: left;
  gap: 2px;
  font-family: "Aptos", Verdana, sans-serif;
  font-weight: 400;
  font-size: clamp(.68rem, .74vw, .9rem);
  line-height: 1.14;
}

#slide-4 .changes-note-copy span {
  display: block;
  width: 100%;
}

/* Red is softer than pure red, but still readable. */
#slide-4 .is-alert-soft {
  color: #ff8b82;
}

#slide-4 .is-soft-muted {
  color: rgba(255,255,255,.92);
}

/* Ensure long rows have enough height without clipping. */
#slide-4 .changes-row-tall {
  min-height: clamp(76px, 9.6svh, 116px);
}

#slide-4 .changes-row-mid {
  min-height: clamp(62px, 7.5svh, 92px);
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-4 .changes-row {
    grid-template-columns: 1.95fr .52fr .52fr 2.05fr;
  }

  #slide-4 .changes-row-span {
    grid-template-columns: 1.95fr 1.04fr 2.05fr;
  }

  #slide-4 .changes-note-with-sign {
    grid-template-columns: 34px minmax(0, 1fr);
    column-gap: 8px;
    padding: 7px 10px;
  }

  #slide-4 .changes-sign {
    font-size: clamp(1.45rem, 1.8vw, 2.25rem);
  }

  #slide-4 .changes-note-copy {
    font-size: clamp(.58rem, .64vw, .78rem);
    line-height: 1.11;
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-4 .changes-row {
    grid-template-columns: 1.72fr .48fr .48fr 2.14fr;
  }

  #slide-4 .changes-row-span {
    grid-template-columns: 1.72fr .96fr 2.14fr;
  }

  #slide-4 .changes-note-with-sign {
    grid-template-columns: 24px minmax(0, 1fr);
    column-gap: 6px;
    padding: 6px 8px;
  }

  #slide-4 .changes-sign {
    font-size: 1.14rem;
  }

  #slide-4 .changes-note-copy {
    font-size: .5rem;
    line-height: 1.08;
  }
}


/* ===== Slide 4: compact balanced table override ===== */

/* Равномерная компактная сетка: верхние строки не схлопываются,
   нижние строки не растягивают всю таблицу. */
#slide-4 .changes-table {
  top: clamp(116px, 14.4svh, 168px);
  left: clamp(30px, 2.8vw, 66px);
  right: clamp(30px, 2.8vw, 66px);
  bottom: calc(var(--nav-strip-h) + clamp(30px, 3.2svh, 52px));
  display: grid;
  grid-template-rows:
    clamp(34px, 4.2svh, 48px)
    minmax(0, .82fr)
    minmax(0, .82fr)
    minmax(0, .74fr)
    minmax(0, 1.06fr)
    minmax(0, .88fr)
    minmax(0, .96fr)
    minmax(0, .72fr)
    minmax(0, .72fr);
  gap: clamp(5px, .72svh, 9px);
}

/* Левая колонка уже, 2026 шире. 2024/2025 компактные и равные. */
#slide-4 .changes-row {
  grid-template-columns: 1.66fr .48fr .48fr 2.38fr;
  min-height: 0 !important;
  height: 100%;
  align-items: stretch;
  border-radius: clamp(10px, .78vw, 15px);
}

#slide-4 .changes-row-span {
  grid-template-columns: 1.66fr .96fr 2.38fr;
  min-height: 0 !important;
}

/* Убираем старые min-height, из-за которых нижние строки раздувались. */
#slide-4 .changes-row-tall,
#slide-4 .changes-row-mid {
  min-height: 0 !important;
}

#slide-4 .changes-cell {
  padding: clamp(6px, .62vw, 12px) clamp(7px, .72vw, 14px);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

#slide-4 .changes-topic {
  font-size: clamp(.72rem, .84vw, 1.02rem);
  line-height: 1.14;
  max-width: 100%;
}

#slide-4 .changes-value {
  font-size: clamp(1.35rem, 1.7vw, 2.22rem);
}

#slide-4 .changes-mark {
  font-size: clamp(1.45rem, 1.85vw, 2.48rem);
}

#slide-4 .changes-note,
#slide-4 .changes-span-2 {
  font-size: clamp(.64rem, .72vw, .9rem);
  line-height: 1.12;
}

/* 2026: плюс отдельно, весь остальной объем отдаем тексту справа. */
#slide-4 .changes-note-with-sign {
  display: grid;
  grid-template-columns: clamp(26px, 2.2vw, 46px) minmax(0, 1fr);
  align-items: center;
  justify-items: center;
  column-gap: clamp(6px, .55vw, 12px);
  padding: clamp(6px, .58vw, 10px) clamp(8px, .82vw, 16px);
  min-width: 0;
}

#slide-4 .changes-sign {
  align-self: center;
  justify-self: center;
  font-size: clamp(1.55rem, 1.95vw, 2.65rem);
  line-height: 1;
}

#slide-4 .changes-note-copy {
  width: 100%;
  min-width: 0;
  align-items: flex-start;
  justify-content: center;
  text-align: left;
  font-size: clamp(.58rem, .66vw, .82rem);
  line-height: 1.1;
  gap: 1px;
}

#slide-4 .changes-note-copy span {
  display: block;
  width: 100%;
  overflow-wrap: anywhere;
  word-break: normal;
}

/* На обычных ноутбуках делаем еще компактнее, но без схлопывания верхних строк. */
@media (max-width: 1366px) and (orientation: landscape) {
  #slide-4 .changes-table {
    top: clamp(102px, 14svh, 132px);
    left: 2%;
    right: 2%;
    bottom: calc(var(--nav-strip-h) + 28px);
    grid-template-rows:
      34px
      minmax(0, .82fr)
      minmax(0, .82fr)
      minmax(0, .72fr)
      minmax(0, 1.02fr)
      minmax(0, .84fr)
      minmax(0, .92fr)
      minmax(0, .70fr)
      minmax(0, .70fr);
    gap: 5px;
  }

  #slide-4 .changes-row {
    grid-template-columns: 1.55fr .46fr .46fr 2.53fr;
  }

  #slide-4 .changes-row-span {
    grid-template-columns: 1.55fr .92fr 2.53fr;
  }

  #slide-4 .changes-cell {
    padding: 6px 9px;
  }

  #slide-4 .changes-topic {
    font-size: clamp(.62rem, .75vw, .84rem);
    line-height: 1.12;
  }

  #slide-4 .changes-value {
    font-size: clamp(1.1rem, 1.5vw, 1.75rem);
  }

  #slide-4 .changes-mark {
    font-size: clamp(1.22rem, 1.55vw, 1.9rem);
  }

  #slide-4 .changes-note,
  #slide-4 .changes-span-2 {
    font-size: clamp(.54rem, .62vw, .72rem);
    line-height: 1.1;
  }

  #slide-4 .changes-note-with-sign {
    grid-template-columns: 30px minmax(0, 1fr);
    column-gap: 6px;
    padding: 5px 8px;
  }

  #slide-4 .changes-sign {
    font-size: clamp(1.2rem, 1.58vw, 1.9rem);
  }

  #slide-4 .changes-note-copy {
    font-size: clamp(.48rem, .56vw, .66rem);
    line-height: 1.08;
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-4 .changes-table {
    top: 92px;
    left: 1.8%;
    right: 1.8%;
    bottom: calc(var(--nav-strip-h) + 18px);
    grid-template-rows:
      28px
      minmax(0, .82fr)
      minmax(0, .82fr)
      minmax(0, .72fr)
      minmax(0, 1.02fr)
      minmax(0, .84fr)
      minmax(0, .92fr)
      minmax(0, .70fr)
      minmax(0, .70fr);
    gap: 4px;
  }

  #slide-4 .changes-row {
    grid-template-columns: 1.42fr .42fr .42fr 2.74fr;
    border-radius: 8px;
  }

  #slide-4 .changes-row-span {
    grid-template-columns: 1.42fr .84fr 2.74fr;
  }

  #slide-4 .changes-cell {
    padding: 5px 6px;
  }

  #slide-4 .changes-topic {
    font-size: .54rem;
    line-height: 1.1;
  }

  #slide-4 .changes-value {
    font-size: .95rem;
  }

  #slide-4 .changes-mark {
    font-size: 1.05rem;
  }

  #slide-4 .changes-note,
  #slide-4 .changes-span-2 {
    font-size: .48rem;
    line-height: 1.08;
  }

  #slide-4 .changes-note-with-sign {
    grid-template-columns: 22px minmax(0, 1fr);
    column-gap: 5px;
    padding: 4px 6px;
  }

  #slide-4 .changes-sign {
    font-size: 1.05rem;
  }

  #slide-4 .changes-note-copy {
    font-size: .43rem;
    line-height: 1.06;
  }
}


/* ===== Shared section slides 3, 5-10 ===== */
.section-logo {
  top: clamp(34px, 4.9svh, 60px);
  left: clamp(40px, 4vw, 90px);
  width: clamp(184px, 14vw, 304px);
  z-index: 7;
}
.section-title {
  position: absolute;
  z-index: 8;
  top: clamp(34px, 4.3svh, 58px);
  left: 21.8vw;
}
.section-title h2 {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(2rem, min(2.45vw, 5.2svh), 4.45rem);
  line-height: .98;
  letter-spacing: .012em;
  color: #fff;
  text-transform: uppercase;
  text-shadow: 0 10px 22px rgba(0,0,0,.22);
}
.section-ribbon {
  position: absolute;
  pointer-events: none;
  z-index: 2;
  opacity: .58;
  filter: saturate(1.15);
}
.section-ribbon-top {
  right: -6%;
  top: -7%;
  width: clamp(420px, 45vw, 980px);
}
.section-ribbon-bottom {
  left: -8%;
  bottom: -9%;
  width: clamp(420px, 46vw, 980px);
}
.slide-plan .bg,
.slide-ready .bg,
.slide-indicators .bg,
.slide-analytics .bg,
.slide-rating .bg {
  opacity: .58;
  filter: saturate(1.04) contrast(1.04);
}
.slide-plan .bg-vignette,
.slide-ready .bg-vignette,
.slide-indicators .bg-vignette,
.slide-analytics .bg-vignette,
.slide-rating .bg-vignette {
  background:
    radial-gradient(circle at 43% 47%, rgba(0, 68, 90, .30), transparent 34%),
    linear-gradient(90deg, rgba(0,0,0,.20), rgba(0,0,0,.06) 50%, rgba(0,0,0,.18)),
    linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.04) 45%, rgba(0,0,0,.23));
}

/* Slide 3 plan */
.plan-facade {
  position: absolute;
  z-index: 6;
  left: clamp(42px, 4vw, 92px);
  top: clamp(210px, 28svh, 325px);
  width: clamp(520px, 48vw, 1100px);
  opacity: .9;
}
.plan-left {
  position: absolute;
  z-index: 7;
  left: clamp(42px, 3.7vw, 90px);
  top: clamp(350px, 48svh, 485px);
}
.plan-left h2,
.plan-footer {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.75rem, 2.65vw, 4.2rem);
  line-height: .95;
  letter-spacing: .04em;
  text-transform: uppercase;
  background: linear-gradient(90deg, #b77cff 0%, #58baff 50%, #19e5a0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.plan-list {
  position: absolute;
  z-index: 7;
  right: clamp(60px, 5.3vw, 132px);
  top: clamp(165px, 22.5svh, 245px);
  width: min(43vw, 690px);
  padding-left: clamp(34px, 3vw, 72px);
}
.plan-list ol {
  margin: 0;
  padding-left: 0;
  list-style-position: inside;
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(1.12rem, 1.62vw, 2.5rem);
  line-height: 1.42;
  color: rgba(255,255,255,.94);
}
.plan-list li { margin: 0 0 clamp(12px, 1.6svh, 24px); }
.plan-bracket {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: clamp(20px, 2vw, 42px);
  border-left: 2px solid rgba(0,180,255,.62);
  border-top: 2px solid rgba(0,180,255,.62);
  border-bottom: 2px solid rgba(0,180,255,.62);
  border-radius: 8px 0 0 8px;
}
.plan-arrows span {
  position: absolute;
  right: clamp(315px, 26vw, 590px);
  z-index: 7;
  width: clamp(34px, 3vw, 64px);
  height: clamp(72px, 7svh, 130px);
  border-right: 2px solid #46bf42;
  border-bottom: 2px solid #46bf42;
  transform: rotate(45deg);
  opacity: .95;
}
.plan-arrows span:first-child { top: clamp(82px, 10.5svh, 132px); }
.plan-arrows span:last-child { top: clamp(430px, 58svh, 570px); }
.plan-footer {
  position: absolute;
  z-index: 7;
  right: clamp(105px, 9vw, 220px);
  bottom: calc(var(--nav-strip-h) + clamp(75px, 9.2svh, 130px));
  text-align: center;
  font-size: clamp(1.55rem, 2.25vw, 3.8rem);
}

/* Slides 5-6 readiness */
.slide-ready .section-title-ready { left: 22vw; }
.ready-grid {
  position: absolute;
  z-index: 7;
  left: clamp(38px, 3.2vw, 76px);
  right: clamp(38px, 3.2vw, 76px);
  top: clamp(120px, 16svh, 185px);
  bottom: calc(var(--nav-strip-h) + clamp(24px, 2.8svh, 48px));
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(14px, 1.6vw, 36px);
  align-content: start;
}
.ready-column {
  display: grid;
  grid-auto-rows: minmax(0, 1fr);
  gap: clamp(8px, 1.08svh, 14px);
  min-height: 0;
}
.ready-card {
  display: flex;
  align-items: center;
  min-height: 0;
  padding: clamp(9px, .9vw, 18px) clamp(12px, 1.1vw, 24px);
  border-radius: clamp(8px, .6vw, 14px);
  color: #041015;
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(.76rem, .92vw, 1.15rem);
  line-height: 1.14;
  background: linear-gradient(92deg, #ca73ff 0%, #68b9ff 47%, #08d88d 100%);
  box-shadow: 0 12px 26px rgba(0,0,0,.18);
}
.ready-card-plain {
  color: rgba(255,255,255,.94);
  background: rgba(4, 20, 27, .35);
  border: 1px solid rgba(100,220,190,.12);
  box-shadow: none;
}
.ready-card em {
  color: rgba(255,255,255,.86);
  font-style: italic;
}
.drop-card {
  opacity: 0;
  transform: translateY(-35px);
}
.slide.is-active .drop-card {
  animation: dropIn .56s cubic-bezier(.2,.75,.25,1) forwards;
  animation-delay: calc(var(--i) * 90ms);
}
@keyframes dropIn {
  0% { opacity: 0; transform: translateY(-45px); }
  70% { opacity: 1; transform: translateY(5px); }
  100% { opacity: 1; transform: translateY(0); }
}
.ready-grid.compact { 
  top: clamp(125px, 17svh, 185px);
  bottom: auto;
  grid-template-columns: 1fr 1fr;
  min-height: clamp(210px, 33svh, 340px);
}
.ready-grid.compact .ready-column { grid-auto-rows: minmax(74px, auto); }

/* Slide 7 */
.indicator-ribbon {
  position: absolute;
  pointer-events: none;
  z-index: 2;
  opacity: .66;
}
.indicator-ribbon-top {
  right: -8%;
  top: -8%;
  width: clamp(520px, 58vw, 1180px);
}
.indicator-ribbon-bottom {
  left: -8%;
  bottom: -10%;
  width: clamp(540px, 55vw, 1200px);
}
.indicator-link {
  position: absolute;
  z-index: 8;
  left: clamp(44px, 3.5vw, 84px);
  top: clamp(290px, 39svh, 420px);
  color: rgba(255,255,255,.96);
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(1.2rem, 1.85vw, 3rem);
  line-height: 1;
  text-decoration: underline;
  text-underline-offset: .16em;
}

/* Slides 8-9 charts */
.analytics-tabs {
  position: absolute;
  left: clamp(38px, 3vw, 76px);
  top: clamp(118px, 16svh, 170px);
  display: grid;
  gap: clamp(10px, 1.1svh, 16px);
  width: min(56vw, 820px);
  z-index: 8;
}
.analytics-tabs span {
  padding: .36em .62em;
  border-radius: 10px;
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(1rem, 1.45vw, 2rem);
  color: #061014;
  background: linear-gradient(92deg, #ca73ff 0%, #68b9ff 47%, #08d88d 100%);
}
.chart-layout {
  position: absolute;
  z-index: 8;
  left: clamp(80px, 7vw, 170px);
  right: clamp(66px, 5vw, 140px);
  top: clamp(315px, 44svh, 430px);
  bottom: calc(var(--nav-strip-h) + clamp(52px, 6svh, 96px));
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(58px, 7vw, 145px);
  align-items: center;
}
.chart-layout-top {
  top: clamp(130px, 18svh, 190px);
  bottom: calc(var(--nav-strip-h) + clamp(245px, 31svh, 355px));
}
.chart-card h3 {
  margin: 0 0 clamp(18px, 2.2svh, 34px);
  text-align: center;
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(.95rem, 1.22vw, 1.65rem);
  font-weight: 400;
  color: rgba(255,255,255,.86);
}
.bar-chart {
  display: grid;
  gap: clamp(6px, .9svh, 12px);
}
.chart-row {
  display: grid;
  grid-template-columns: minmax(130px, 44%) 1fr auto;
  gap: 10px;
  align-items: center;
  color: #fff;
  font-family: "Aptos", Verdana, sans-serif;
}
.chart-label {
  text-align: right;
  font-size: clamp(.76rem, .95vw, 1.2rem);
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.chart-track {
  height: clamp(8px, 1.08svh, 14px);
  position: relative;
  border-left: 1px solid rgba(255,255,255,.65);
}
.chart-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  display: block;
}
.slide.is-active .chart-fill {
  animation: growBar 1.1s cubic-bezier(.18,.82,.25,1) forwards;
  animation-delay: calc(var(--i) * 75ms);
}
.chart-fill.green { background: #08d88d; }
.chart-fill.blue { background: #06aeea; }
.chart-fill.blue2 { background: #4387ff; }
.chart-fill.yellow { background: #f6c400; }
.chart-value {
  min-width: 2.1em;
  font-size: clamp(.76rem, .95vw, 1.2rem);
}
.chart-axis {
  display: flex;
  justify-content: space-between;
  margin-left: 44%;
  margin-top: 10px;
  color: rgba(255,255,255,.35);
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(.7rem, .85vw, 1rem);
}
@keyframes growBar { to { width: var(--w); } }
.practice-row {
  position: absolute;
  z-index: 8;
  left: clamp(70px, 6.2vw, 150px);
  right: clamp(52px, 4.2vw, 120px);
  bottom: calc(var(--nav-strip-h) + clamp(46px, 4.8svh, 76px));
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(22px, 3vw, 62px);
  align-items: center;
}
.practice-row h3 {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.65rem, 2.45vw, 4rem);
  color: #fff;
  text-transform: uppercase;
}
.practice-logo-row {
  display: flex;
  align-items: center;
  gap: clamp(24px, 3vw, 70px);
}
.practice-tpu { width: clamp(190px, 18vw, 355px); }
.practice-ai { width: clamp(58px, 5.2vw, 110px); }
.university-logos {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: clamp(18px, 2.2vw, 55px);
  align-items: center;
}
.university-logos img {
  max-height: clamp(55px, 7svh, 112px);
  max-width: 100%;
  object-fit: contain;
}

/* Slide 10 rating */
.rating-facade {
  position: absolute;
  right: -3%;
  top: clamp(50px, 6.4svh, 92px);
  width: clamp(370px, 33vw, 780px);
  z-index: 5;
  opacity: .85;
}
.rating-title {
  position: absolute;
  z-index: 8;
  left: clamp(42px, 3.8vw, 92px);
  top: clamp(112px, 14svh, 175px);
}
.rating-title h2 {
  margin: 0;
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(2rem, 3.15vw, 5.5rem);
  line-height: .95;
}
.rating-ribbon-left {
  position: absolute;
  left: -8%;
  bottom: 1%;
  width: clamp(300px, 23vw, 620px);
  opacity: .72;
  z-index: 2;
}
.rating-content {
  position: absolute;
  z-index: 8;
  left: clamp(250px, 19.5vw, 480px);
  right: clamp(120px, 9vw, 230px);
  top: clamp(170px, 23svh, 250px);
  bottom: calc(var(--nav-strip-h) + clamp(56px, 6svh, 100px));
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(60px, 7vw, 145px);
}
.rating-subjects h3 {
  margin: 0 0 clamp(22px, 2.2svh, 34px);
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.65rem, 2.55vw, 4.2rem);
  line-height: .95;
  background: linear-gradient(90deg,#18e894,#46c2ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.rating-subjects ul {
  list-style: none;
  margin: 0;
  padding: 0 0 0 28px;
  border-left: 2px solid #46bf42;
}
.rating-subjects li {
  position: relative;
  padding: clamp(5px, .6svh, 9px) 0 clamp(5px, .6svh, 9px) clamp(20px, 1.5vw, 34px);
  color: #fff;
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(.92rem, 1.12vw, 1.5rem);
  line-height: 1.15;
}
.rating-subjects li::before {
  content: "";
  position: absolute;
  left: -28px;
  top: 50%;
  width: 28px;
  border-top: 2px solid #46bf42;
}
.rating-subjects span { text-decoration: underline; text-underline-offset: 2px; }
.rating-results {
  display: grid;
  grid-template-rows: auto 1fr 1fr 1fr;
  gap: clamp(14px, 1.6svh, 28px);
}
.rating-logos {
  display: flex;
  align-items: center;
  gap: 24px;
}
.rating-logos img { width: clamp(150px, 15vw, 300px); }
.rating-click {
  width: clamp(42px, 4vw, 76px);
  height: clamp(42px, 4vw, 76px);
  display: grid;
  place-items: center;
  background: #42b64a;
  color: #fff;
  font-size: clamp(1.3rem, 2vw, 3rem);
}
.rating-box {
  display: grid;
  place-items: center;
  position: relative;
  border-radius: 18px;
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.25rem, 2vw, 3.5rem);
  line-height: 1.05;
  text-align: center;
  text-transform: uppercase;
}
.rating-box::before,
.rating-box::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 3px solid transparent;
  border-color: #46bf42;
  clip-path: polygon(0 0, 20% 0, 20% 8%, 8% 8%, 8% 22%, 0 22%, 0 0, 100% 0, 100% 22%, 92% 22%, 92% 8%, 80% 8%, 80% 0, 100% 0, 100% 100%, 80% 100%, 80% 92%, 92% 92%, 92% 78%, 100% 78%, 100% 100%, 0 100%, 0 78%, 8% 78%, 8% 92%, 20% 92%, 20% 100%, 0 100%);
}
.rating-link {
  position: absolute;
  z-index: 9;
  right: clamp(250px, 20vw, 520px);
  bottom: calc(var(--nav-strip-h) + clamp(18px, 2svh, 34px));
  color: #fff;
  background: #42b64a;
  padding: .38em 2.2em;
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(.85rem, 1.1vw, 1.6rem);
}

/* responsive for selected slides */
@media (max-width: 1366px) and (orientation: landscape) {
  .section-title h2 { font-size: clamp(1.6rem, 2.35vw, 2.25rem); }
  .plan-list ol { font-size: clamp(.95rem, 1.48vw, 1.35rem); }
  .plan-left h2, .plan-footer { font-size: clamp(1.45rem, 2.45vw, 2.2rem); }
  .ready-card { font-size: clamp(.66rem, .82vw, .84rem); padding: 8px 12px; }
  .chart-layout { left: 72px; right: 54px; gap: 70px; }
  .chart-label { font-size: .78rem; }
  .chart-value { font-size: .82rem; }
  .practice-row { bottom: calc(var(--nav-strip-h) + 34px); }
  .university-logos img { max-height: 72px; }
  .rating-title h2 { font-size: 2.15rem; }
  .rating-content { left: 20vw; right: 9vw; gap: 70px; }
  .rating-subjects h3 { font-size: 2.1rem; }
  .rating-subjects li { font-size: .9rem; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  .section-logo { top: 30px; width: clamp(132px, 15vw, 170px); }
  .section-title { top: 32px; left: 24vw; }
  .section-title h2 { font-size: clamp(1.25rem, 2.3vw, 1.7rem); }
  .ready-grid { top: 94px; left: 2.5%; right: 2.5%; gap: 10px; }
  .ready-card { font-size: .54rem; padding: 6px 8px; border-radius: 7px; }
  .indicator-link { top: 230px; font-size: 1rem; }
  .analytics-tabs { top: 85px; width: 58vw; gap: 7px; }
  .analytics-tabs span { font-size: .78rem; }
  .chart-layout { top: 220px; left: 36px; right: 32px; gap: 36px; }
  .chart-layout-top { top: 92px; bottom: 240px; }
  .chart-label, .chart-value { font-size: .55rem; }
  .chart-card h3 { font-size: .78rem; }
  .practice-row { bottom: calc(var(--nav-strip-h) + 22px); left: 48px; gap: 20px; }
  .practice-row h3 { font-size: 1.45rem; }
  .university-logos { gap: 18px; }
  .university-logos img { max-height: 48px; }
  .rating-title { top: 88px; }
  .rating-title h2 { font-size: 1.5rem; }
  .rating-content { top: 145px; left: 19vw; right: 7vw; gap: 38px; }
  .rating-subjects h3 { font-size: 1.35rem; }
  .rating-subjects li { font-size: .62rem; }
  .rating-box { font-size: 1rem; }
}


/* ===== FIX 2026-06 merge slides 5-6 + renumber 7-10 ===== */

/* Typography: titles Aptos Black; content Aptos Display/Aptos. */
#slide-3 h2, #slide-5 h2, #slide-6 h2, #slide-7 h2, #slide-8 h2, #slide-9 h2,
#slide-8 .practice-row h3,
#slide-9 .rating-subjects h3 {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-weight: 900;
}
#slide-3, #slide-5, #slide-6, #slide-7, #slide-8, #slide-9 {
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
}

/* Slide 3: add breathing room from facade and draw arrows. */
#slide-3 .plan-facade {
  left: clamp(56px, 4.4vw, 112px);
  top: clamp(198px, 29svh, 285px);
  width: clamp(500px, 47vw, 930px);
}
#slide-3 .plan-left {
  left: clamp(64px, 5vw, 118px);
  top: clamp(366px, 49svh, 482px);
}
#slide-3 .plan-list {
  right: clamp(58px, 4.8vw, 122px);
  top: clamp(195px, 26.5svh, 306px);
}
#slide-3 .plan-footer {
  right: clamp(72px, 8vw, 188px);
  bottom: calc(var(--nav-strip-h) + clamp(82px, 10.4svh, 152px));
}
#slide-3 .plan-arrows { right: clamp(240px, 25vw, 520px); }
#slide-3 .plan-arrows .draw-arrow {
  display: block;
  position: relative;
  width: clamp(24px, 2.1vw, 42px);
  height: clamp(54px, 6.8svh, 86px);
  border-left: 2px solid #3fbd46;
  opacity: .95;
  animation: arrowDraw 1.05s ease-in-out 0s 3 both;
}
#slide-3 .plan-arrows .draw-arrow::after {
  content: "";
  position: absolute;
  left: -10px;
  bottom: -2px;
  width: 18px;
  height: 18px;
  border-right: 2px solid #3fbd46;
  border-bottom: 2px solid #3fbd46;
  transform: rotate(45deg);
}
#slide-3 .plan-arrows .draw-arrow:nth-child(2) { animation-delay: .32s; }
@keyframes arrowDraw {
  0% { transform: translateY(-16px); clip-path: inset(0 0 100% 0); opacity: 0; }
  45% { clip-path: inset(0 0 0 0); opacity: 1; }
  100% { transform: translateY(0); clip-path: inset(0 0 0 0); opacity: 1; }
}

/* Slide 5: old 5+6 merged into one slide, two columns, drop animation. */
#slide-5 .ready-grid-merged {
  position: absolute;
  left: clamp(38px, 3vw, 76px);
  right: clamp(38px, 3vw, 76px);
  top: clamp(116px, 15.5svh, 176px);
  bottom: calc(var(--nav-strip-h) + clamp(20px, 2.4svh, 42px));
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(14px, 1.3vw, 28px);
}
#slide-5 .ready-grid-merged .ready-column {
  display: grid;
  grid-template-rows: repeat(9, minmax(0, 1fr));
  gap: clamp(6px, .72svh, 10px);
}
#slide-5 .ready-grid-merged .ready-card {
  min-height: 0;
  height: 100%;
  display: flex;
  align-items: center;
  padding: clamp(7px, .75vw, 14px) clamp(12px, 1.05vw, 22px);
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.70rem, .86vw, 1.04rem);
  line-height: 1.08;
  color: #07161d;
  opacity: 0;
  transform: translateY(-26px);
  animation: blockDrop .58s cubic-bezier(.2,.8,.2,1) calc(.15s + var(--i) * .055s) forwards;
}
#slide-5 .ready-grid-merged .ready-card-plain {
  color: #fff;
  background: transparent;
  border: 0;
}
#slide-5 .ready-grid-merged .ready-card em { color: rgba(255,255,255,.92); }
@keyframes blockDrop { to { opacity: 1; transform: translateY(0); } }

/* Analytics charts: values sit at bar end, not in a separate column. */
#slide-7 .chart-layout, #slide-8 .chart-layout {
  left: clamp(80px, 7vw, 170px);
  right: clamp(80px, 7vw, 170px);
  justify-content: center;
  align-items: center;
}
#slide-7 .chart-row, #slide-8 .chart-row {
  grid-template-columns: minmax(140px, 42%) 1fr;
  gap: 10px;
}
#slide-7 .chart-track, #slide-8 .chart-track {
  position: relative;
  overflow: visible;
}
#slide-7 .chart-value, #slide-8 .chart-value {
  position: absolute;
  left: calc(var(--w) + 8px);
  top: 50%;
  transform: translateY(-50%);
  min-width: 2.2em;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  color: #fff;
  line-height: 1;
}
#slide-7.is-active .chart-fill, #slide-8.is-active .chart-fill {
  animation: growBar 1.05s cubic-bezier(.16,.84,.32,1) calc(var(--i) * .08s) forwards;
}
@keyframes growBar { from { width: 0; } to { width: var(--w); } }
#slide-7 .analytics-tabs {
  left: clamp(42px, 3.2vw, 82px);
  top: clamp(118px, 15.7svh, 178px);
  width: min(58vw, 760px);
}
#slide-7 .chart-layout { top: clamp(255px, 34svh, 330px); }
#slide-8 .chart-layout-top { top: clamp(142px, 18.5svh, 220px); }

/* Slide 8 best practices block: lower and closer to screenshot. */
#slide-8 .practice-row {
  left: clamp(70px, 5.8vw, 145px);
  right: clamp(70px, 5.8vw, 145px);
  bottom: calc(var(--nav-strip-h) + clamp(34px, 4.2svh, 70px));
  grid-template-columns: 1fr;
  gap: clamp(18px, 2.6svh, 40px);
}
#slide-8 .practice-row h3 {
  margin: 0 0 clamp(4px, .8svh, 10px);
  font-size: clamp(1.9rem, 3vw, 4.5rem);
  text-align: left;
}
#slide-8 .practice-logo-row {
  position: absolute;
  left: 36%;
  top: 0;
  display: flex;
  gap: clamp(28px, 3.8vw, 78px);
  align-items: center;
}
#slide-8 .practice-tpu { width: clamp(168px, 14vw, 310px); }
#slide-8 .practice-ai { width: clamp(62px, 5.5vw, 115px); }
#slide-8 .university-logos {
  display: grid;
  grid-template-columns: 1.05fr 1.08fr 1.15fr .82fr .92fr 1.05fr;
  gap: clamp(28px, 3.2vw, 68px);
  align-items: center;
  margin-top: clamp(82px, 11svh, 150px);
}
#slide-8 .university-logos img {
  max-width: 100%;
  max-height: clamp(56px, 7.8svh, 118px);
  object-fit: contain;
}

/* Slide 9 rating: title right of logo, subject links drop down, corner boxes in CoFo. */
#slide-9 .section-logo { top: clamp(32px, 4.5svh, 58px); }
#slide-9 .rating-title { left: clamp(280px, 22vw, 490px); top: clamp(42px, 5svh, 78px); }
#slide-9 .rating-title h2 { font-size: clamp(2rem, min(2.9vw, 5.8svh), 5.2rem); line-height: .96; }
#slide-9 .rating-facade { right: -10%; top: clamp(54px, 7svh, 100px); width: clamp(430px, 38vw, 930px); opacity: .84; }
#slide-9 .rating-ribbon-left { left: -2.4%; bottom: clamp(70px, 9svh, 150px); width: clamp(240px, 18vw, 430px); opacity: .8; }
#slide-9 .rating-content {
  top: clamp(145px, 19svh, 240px);
  left: clamp(250px, 19.5vw, 460px);
  right: clamp(170px, 14vw, 340px);
  bottom: calc(var(--nav-strip-h) + clamp(70px, 8.8svh, 120px));
  grid-template-columns: minmax(380px, 1.05fr) minmax(390px, 1.2fr);
  gap: clamp(64px, 7.4vw, 160px);
}
#slide-9 .rating-subjects h3 {
  color: #00e88a;
  font-size: clamp(2rem, min(3.05vw, 6.1svh), 5.4rem);
  line-height: .88;
  margin: 0 0 clamp(22px, 2.8svh, 42px);
}
#slide-9 .rating-subjects ul { margin: 0; padding: 0 0 0 clamp(38px, 3vw, 72px); list-style: none; position: relative; }
#slide-9 .rating-subjects ul::before { content: ""; position: absolute; left: clamp(14px, 1.15vw, 26px); top: 8px; bottom: 8px; width: 2px; background: #44bd4a; }
#slide-9 .rating-subjects li {
  position: relative;
  margin: 0 0 clamp(9px, 1.05svh, 16px);
  display: flex;
  align-items: center;
  gap: 10px;
  opacity: 0;
  transform: translateY(-18px);
  animation: listDrop .55s cubic-bezier(.2,.8,.2,1) calc(.35s + var(--i) * .075s) forwards;
}
#slide-9 .rating-subjects li::before { content: ""; position: absolute; left: calc(clamp(-24px, -1.85vw, -12px)); top: 50%; width: clamp(16px, 1.35vw, 30px); height: 2px; background: #44bd4a; }
#slide-9 .rating-subjects a {
  color: #fff;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.95rem, 1.22vw, 1.85rem);
  line-height: 1.15;
  text-decoration: underline;
  text-underline-offset: .16em;
}
#slide-9 .rating-qs-badge { width: clamp(52px, 4.2vw, 86px); height: auto; object-fit: contain; }
#slide-9 .rating-results { display: grid; grid-template-rows: auto 1fr 1fr 1.15fr; gap: clamp(20px, 2.4svh, 42px); }
#slide-9 .rating-logos { display: flex; align-items: center; gap: clamp(22px, 2vw, 48px); justify-content: center; }
#slide-9 .rating-raex-link img { width: clamp(165px, 14.5vw, 330px); height: auto; }
#slide-9 .rating-click { width: clamp(52px, 4.8vw, 96px); aspect-ratio: 1; display: grid; place-items: center; background: #43b64a; }
#slide-9 .rating-click img { width: 82%; height: 82%; object-fit: contain; }
#slide-9 .rating-box {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(66px, 8.6svh, 126px);
  background: transparent;
  font-family: "CoFo Kak Black", "CoFo Kak", "Aptos Black", Verdana, sans-serif !important;
  font-size: clamp(1.55rem, min(2.2vw, 4.4svh), 3.9rem);
  line-height: 1;
  text-align: center;
  color: #fff;
  border: 0;
}
#slide-9 .rating-box::before, #slide-9 .rating-box::after { content: ""; position: absolute; width: clamp(22px, 2vw, 44px); height: clamp(22px, 2vw, 44px); pointer-events: none; }
#slide-9 .rating-box::before { left: 0; top: 0; border-left: 3px solid #44bd4a; border-top: 3px solid #44bd4a; }
#slide-9 .rating-box::after { right: 0; bottom: 0; border-right: 3px solid #44bd4a; border-bottom: 3px solid #44bd4a; }
#slide-9 .rating-link {
  left: auto;
  right: clamp(185px, 16vw, 390px);
  bottom: calc(var(--nav-strip-h) + clamp(32px, 4svh, 58px));
  width: clamp(360px, 34vw, 760px);
  background: #43b64a;
  color: #fff;
  text-align: center;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.9rem, 1.12vw, 1.55rem);
}
@keyframes listDrop { to { opacity: 1; transform: translateY(0); } }

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-5 .ready-grid-merged .ready-card { font-size: clamp(.58rem, .78vw, .82rem); padding: 5px 10px; }
  #slide-7 .chart-layout, #slide-8 .chart-layout { left: 6vw; right: 6vw; }
  #slide-7 .chart-row, #slide-8 .chart-row { grid-template-columns: minmax(120px, 40%) 1fr; }
  #slide-8 .practice-row { bottom: calc(var(--nav-strip-h) + 28px); }
  #slide-8 .university-logos { margin-top: 92px; gap: 34px; }
  #slide-9 .rating-content { left: 19vw; right: 10vw; gap: 74px; }
  #slide-9 .rating-subjects a { font-size: .9rem; }
  #slide-9 .rating-box { font-size: 1.6rem; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-5 .ready-grid-merged { top: 96px; }
  #slide-5 .ready-grid-merged .ready-card { font-size: .48rem; padding: 4px 7px; }
  #slide-7 .chart-layout, #slide-8 .chart-layout { left: 4vw; right: 4vw; }
  #slide-7 .chart-row, #slide-8 .chart-row { grid-template-columns: minmax(92px, 38%) 1fr; gap: 7px; }
  #slide-7 .chart-value, #slide-8 .chart-value { font-size: .62rem; }
  #slide-9 .rating-content { left: 18vw; right: 6vw; grid-template-columns: 1fr 1.02fr; gap: 38px; }
  #slide-9 .rating-subjects a { font-size: .64rem; }
  #slide-9 .rating-box { font-size: 1.05rem; }
}


/* ===== FINAL PATCH: user requested tuning for slides 5, 7, 8, 9 ===== */

/* Slide 5: preserve the combined slide, make card text bigger and make the fall animation obvious. */
#slide-5 .ready-grid-merged {
  top: clamp(108px, 14.8svh, 166px) !important;
  left: clamp(34px, 2.8vw, 72px) !important;
  right: clamp(34px, 5.8vw, 120px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(18px, 2.2svh, 38px)) !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: clamp(14px, 1.35vw, 28px) !important;
}
#slide-5 .ready-grid-merged .ready-column {
  display: grid !important;
  grid-template-rows: repeat(9, minmax(0, 1fr)) !important;
  gap: clamp(7px, .88svh, 12px) !important;
}
#slide-5 .ready-grid-merged .ready-card {
  min-height: 0 !important;
  height: 100% !important;
  align-items: center !important;
  border-radius: clamp(8px, .7vw, 14px) !important;
  padding: clamp(9px, .95vw, 18px) clamp(14px, 1.18vw, 26px) !important;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(.92rem, 1.14vw, 1.58rem) !important;
  line-height: 1.12 !important;
  opacity: 0;
  transform: translate3d(0,-58px,0) scale(.98);
  will-change: transform, opacity;
}
#slide-5 .ready-grid-merged .ready-card-plain {
  color: rgba(255,255,255,.94) !important;
  background: transparent !important;
  padding-left: clamp(12px, 1vw, 22px) !important;
}
#slide-5:not(.is-active) .drop-card {
  animation: none !important;
  opacity: 0 !important;
  transform: translate3d(0,-58px,0) scale(.98) !important;
}
#slide-5.is-active .drop-card {
  animation: dropCardOneByOne .72s cubic-bezier(.18,.92,.2,1.05) calc(.18s + var(--i) * .085s) both !important;
}
@keyframes dropCardOneByOne {
  0% { opacity: 0; transform: translate3d(0,-70px,0) scale(.985); filter: blur(3px); }
  68% { opacity: 1; transform: translate3d(0,5px,0) scale(1); filter: blur(0); }
  100% { opacity: 1; transform: translate3d(0,0,0) scale(1); filter: blur(0); }
}

/* Slide 7: center the three selector blocks without animate.css transform pushing them to the right. */
#slide-7 .analytics-tabs {
  left: 50% !important;
  right: auto !important;
  width: min(58vw, 760px) !important;
  translate: -50% 0 !important;
  transform: none !important;
  animation-name: fadeIn !important;
  display: grid !important;
  gap: clamp(10px, 1.3svh, 18px) !important;
}
#slide-7 .analytics-tabs span {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(1.05rem, 1.35vw, 2rem) !important;
}

/* Charts: values at the end of each bar, not in a separate column. */
#slide-7 .chart-row,
#slide-8 .chart-row {
  grid-template-columns: minmax(145px, 41%) 1fr !important;
  position: relative !important;
  gap: clamp(8px, .85vw, 14px) !important;
}
#slide-7 .chart-track,
#slide-8 .chart-track {
  position: relative !important;
  overflow: visible !important;
}
#slide-7 .chart-value,
#slide-8 .chart-value {
  position: absolute !important;
  left: calc(var(--w) + 8px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  min-width: 2.2em !important;
  color: #fff !important;
  line-height: 1 !important;
  text-align: left !important;
}
#slide-7.is-active .chart-fill,
#slide-8.is-active .chart-fill {
  animation: growBarsAgain 1.1s cubic-bezier(.16,.84,.32,1) calc(var(--i) * .075s) forwards !important;
}
@keyframes growBarsAgain { from { width: 0; } to { width: var(--w); } }

/* Slide 8: best practices block directly after charts, compact spacing between logos. */
#slide-8 .chart-layout-top {
  top: clamp(112px, 15.8svh, 176px) !important;
  height: clamp(238px, 34svh, 348px) !important;
  left: clamp(82px, 6.3vw, 150px) !important;
  right: clamp(82px, 6.3vw, 150px) !important;
  bottom: auto !important;
}
#slide-8 .practice-row {
  position: absolute !important;
  left: clamp(70px, 5.6vw, 138px) !important;
  right: clamp(70px, 5.6vw, 138px) !important;
  top: clamp(455px, 60.5svh, 610px) !important;
  bottom: auto !important;
  display: grid !important;
  grid-template-rows: auto auto !important;
  gap: clamp(18px, 2.3svh, 32px) !important;
}
#slide-8 .practice-row h3 {
  margin: 0 !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(2rem, 3.05vw, 4.6rem) !important;
  line-height: .98 !important;
  letter-spacing: .01em !important;
}
#slide-8 .practice-logo-row {
  position: absolute !important;
  left: clamp(360px, 34vw, 690px) !important;
  top: clamp(2px, .3svh, 8px) !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: clamp(28px, 3.2vw, 58px) !important;
}
#slide-8 .practice-tpu { width: clamp(165px, 13.3vw, 275px) !important; }
#slide-8 .practice-ai { width: clamp(58px, 4.9vw, 98px) !important; }
#slide-8 .university-logos {
  margin-top: clamp(58px, 6.6svh, 90px) !important;
  display: grid !important;
  grid-template-columns: .82fr 1.02fr 1.02fr .86fr .86fr .98fr !important;
  gap: clamp(18px, 2.05vw, 38px) !important;
  align-items: center !important;
}
#slide-8 .university-logos img {
  max-width: 100% !important;
  max-height: clamp(58px, 7.8svh, 112px) !important;
  object-fit: contain !important;
}

/* Slide 9: rebuild visual hierarchy to match the screenshot: compact content, list links, corner frames, CoFo text. */
#slide-9 .section-logo {
  top: clamp(30px, 4.4svh, 58px) !important;
  left: clamp(38px, 3.4vw, 80px) !important;
}
#slide-9 .rating-title {
  top: clamp(86px, 12svh, 142px) !important;
  left: clamp(48px, 4vw, 90px) !important;
  right: auto !important;
  width: auto !important;
}
#slide-9 .rating-title h2 {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(1.9rem, 2.9vw, 5rem) !important;
  line-height: .96 !important;
  color: #fff !important;
}
#slide-9 .rating-facade {
  top: clamp(48px, 6.5svh, 86px) !important;
  right: -6.5% !important;
  width: clamp(420px, 38vw, 880px) !important;
  opacity: .84 !important;
}
#slide-9 .rating-ribbon-left {
  left: -3.2% !important;
  bottom: clamp(76px, 9.3svh, 155px) !important;
  width: clamp(235px, 18vw, 420px) !important;
  opacity: .76 !important;
}
#slide-9 .rating-content {
  position: absolute !important;
  z-index: 8 !important;
  top: clamp(145px, 20.2svh, 230px) !important;
  left: clamp(255px, 20vw, 470px) !important;
  right: clamp(170px, 14vw, 330px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(64px, 8.2svh, 118px)) !important;
  display: grid !important;
  grid-template-columns: minmax(330px, .98fr) minmax(410px, 1.14fr) !important;
  gap: clamp(58px, 7vw, 145px) !important;
}
#slide-9 .rating-subjects h3 {
  margin: 0 0 clamp(20px, 2.6svh, 38px) !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  color: #00e88a !important;
  font-size: clamp(2rem, 3.1vw, 5.4rem) !important;
  line-height: .88 !important;
  letter-spacing: .01em !important;
}
#slide-9 .rating-subjects ul {
  position: relative !important;
  margin: 0 !important;
  padding: 0 0 0 clamp(42px, 3.2vw, 74px) !important;
  list-style: none !important;
}
#slide-9 .rating-subjects ul::before {
  content: "" !important;
  position: absolute !important;
  left: clamp(16px, 1.25vw, 28px) !important;
  top: 7px !important;
  bottom: 7px !important;
  width: 2px !important;
  background: #44bd4a !important;
}
#slide-9 .rating-subjects li {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  gap: clamp(8px, .8vw, 14px) !important;
  margin: 0 0 clamp(9px, 1.05svh, 16px) !important;
  opacity: 0;
  transform: translateY(-20px);
}
#slide-9.is-active .rating-subjects li {
  animation: ratingListDrop .55s cubic-bezier(.2,.84,.2,1) calc(.2s + var(--i) * .075s) forwards !important;
}
#slide-9 .rating-subjects li::before {
  content: "" !important;
  position: absolute !important;
  left: calc(clamp(-28px, -2vw, -15px)) !important;
  top: 50% !important;
  width: clamp(18px, 1.45vw, 32px) !important;
  height: 2px !important;
  background: #44bd4a !important;
}
#slide-9 .rating-subjects a {
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  color: #fff !important;
  text-decoration: underline !important;
  text-underline-offset: .16em !important;
  font-size: clamp(.95rem, 1.18vw, 1.75rem) !important;
  line-height: 1.13 !important;
}
#slide-9 .rating-qs-badge {
  width: clamp(50px, 4vw, 84px) !important;
  height: auto !important;
  object-fit: contain !important;
}
#slide-9 .rating-results {
  display: grid !important;
  grid-template-rows: auto 1fr 1fr 1.12fr !important;
  gap: clamp(18px, 2.3svh, 38px) !important;
}
#slide-9 .rating-logos {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(20px, 1.8vw, 42px) !important;
}
#slide-9 .rating-raex-link img {
  width: clamp(164px, 14.2vw, 310px) !important;
  height: auto !important;
}
#slide-9 .rating-click {
  width: clamp(52px, 4.6vw, 92px) !important;
  aspect-ratio: 1 !important;
  display: grid !important;
  place-items: center !important;
  background: #43b64a !important;
  border-radius: 0 !important;
  text-decoration: none !important;
}
#slide-9 .rating-click img { display: none !important; }
#slide-9 .rating-click .click-hand {
  color: #fff !important;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(1.8rem, 2.25vw, 3rem) !important;
  line-height: 1 !important;
  transform: rotate(-15deg) translateY(-2px) !important;
}
#slide-9 .rating-box {
  position: relative !important;
  display: grid !important;
  place-items: center !important;
  min-height: clamp(64px, 8.4svh, 124px) !important;
  background: transparent !important;
  border: 0 !important;
  color: #fff !important;
  text-align: center !important;
  font-family: "CoFo Kak Black", "CoFo Kak", "Aptos Black", Verdana, sans-serif !important;
  font-size: clamp(1.55rem, 2.16vw, 3.8rem) !important;
  line-height: 1 !important;
}
#slide-9 .rating-box::before,
#slide-9 .rating-box::after {
  content: "" !important;
  position: absolute !important;
  width: clamp(22px, 2vw, 44px) !important;
  height: clamp(22px, 2vw, 44px) !important;
  pointer-events: none !important;
}
#slide-9 .rating-box::before {
  left: 0 !important; top: 0 !important;
  border-left: 3px solid #44bd4a !important;
  border-top: 3px solid #44bd4a !important;
}
#slide-9 .rating-box::after {
  right: 0 !important; bottom: 0 !important;
  border-right: 3px solid #44bd4a !important;
  border-bottom: 3px solid #44bd4a !important;
}
#slide-9 .rating-link {
  left: auto !important;
  right: clamp(172px, 14vw, 330px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(28px, 3.7svh, 56px)) !important;
  width: clamp(360px, 34vw, 760px) !important;
  background: #43b64a !important;
  color: #fff !important;
  text-align: center !important;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(.9rem, 1.1vw, 1.55rem) !important;
}
@keyframes ratingListDrop { to { opacity: 1; transform: translateY(0); } }

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-5 .ready-grid-merged .ready-card { font-size: clamp(.68rem, .9vw, .96rem) !important; padding: 6px 10px !important; }
  #slide-7 .analytics-tabs { width: min(58vw, 720px) !important; }
  #slide-8 .practice-row { top: 455px !important; }
  #slide-8 .practice-logo-row { left: 35vw !important; gap: 32px !important; }
  #slide-8 .university-logos { gap: 24px !important; margin-top: 52px !important; }
  #slide-9 .rating-content { left: 19vw !important; right: 9vw !important; gap: 66px !important; }
  #slide-9 .rating-subjects a { font-size: .9rem !important; }
  #slide-9 .rating-box { font-size: 1.55rem !important; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-5 .ready-grid-merged { top: 94px !important; right: 5vw !important; }
  #slide-5 .ready-grid-merged .ready-card { font-size: .56rem !important; padding: 4px 7px !important; }
  #slide-7 .analytics-tabs { width: 62vw !important; }
  #slide-8 .chart-layout-top { top: 92px !important; height: 216px !important; left: 4vw !important; right: 4vw !important; }
  #slide-8 .practice-row { top: 340px !important; left: 5vw !important; right: 5vw !important; }
  #slide-8 .practice-logo-row { left: 37vw !important; top: 0 !important; gap: 22px !important; }
  #slide-8 .university-logos { gap: 16px !important; margin-top: 34px !important; }
  #slide-8 .university-logos img { max-height: 58px !important; }
  #slide-9 .rating-content { left: 18vw !important; right: 5vw !important; grid-template-columns: .92fr 1.08fr !important; gap: 30px !important; }
  #slide-9 .rating-subjects a { font-size: .62rem !important; }
  #slide-9 .rating-box { font-size: 1.04rem !important; }
}


/* ===== Targeted patch: slide 7, 8, 9 from user comments ===== */

/* Slide 7: selector blocks centered exactly in the slide, not shifted right */
#slide-7 .analytics-tabs {
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  translate: none !important;
  width: min(60vw, 780px) !important;
  animation-name: fadeIn !important;
}
#slide-7 .analytics-tabs span {
  justify-content: center !important;
  text-align: center !important;
}

/* Tooltipped labels should show as helpful */
#slide-7 .chart-label[title],
#slide-8 .chart-label[title] {
  cursor: help;
}

/* Slide 8: TPU logo + AI logo aligned with "ЛУЧШИЕ ПРАКТИКИ" */
#slide-8 .practice-row {
  top: clamp(438px, 58.2svh, 590px) !important;
  left: clamp(72px, 5.5vw, 142px) !important;
  right: clamp(72px, 5.5vw, 142px) !important;
  gap: 0 !important;
}
#slide-8 .practice-row h3 {
  display: inline-block !important;
  vertical-align: middle !important;
}
#slide-8 .practice-logo-row {
  position: absolute !important;
  left: clamp(345px, 31.5vw, 640px) !important;
  top: clamp(-4px, -0.3svh, 2px) !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: clamp(24px, 2.5vw, 46px) !important;
}
#slide-8 .practice-tpu {
  width: clamp(178px, 14.5vw, 292px) !important;
}
#slide-8 .practice-ai {
  width: clamp(64px, 5.4vw, 110px) !important;
}

/* Slide 8: only seven logos, larger, tighter, one row */
#slide-8 .university-logos {
  margin-top: clamp(44px, 5.2svh, 70px) !important;
  display: grid !important;
  grid-template-columns: .75fr 1fr .95fr .82fr .86fr .9fr 1.05fr !important;
  gap: clamp(10px, 1.25vw, 24px) !important;
  align-items: center !important;
  justify-items: center !important;
}
#slide-8 .university-logos img {
  max-width: 100% !important;
  max-height: clamp(74px, 10svh, 142px) !important;
  object-fit: contain !important;
}

/* Slide 9: title to the right of logo; facade pushed strongly right */
#slide-9 .rating-title {
  top: clamp(38px, 5.15svh, 72px) !important;
  left: clamp(265px, 21.5vw, 455px) !important;
  right: auto !important;
  width: auto !important;
}
#slide-9 .rating-title h2 {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(1.95rem, 2.95vw, 5.05rem) !important;
  line-height: .96 !important;
}
#slide-9 .rating-facade {
  top: clamp(50px, 6.6svh, 92px) !important;
  right: -18% !important;
  width: clamp(440px, 41vw, 960px) !important;
  opacity: .82 !important;
}

/* Slide 9: compact two-column composition like the screenshot */
#slide-9 .rating-content {
  top: clamp(130px, 18svh, 210px) !important;
  left: clamp(235px, 18vw, 430px) !important;
  right: clamp(92px, 7.8vw, 190px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(58px, 7.4svh, 102px)) !important;
  grid-template-columns: minmax(330px, .92fr) minmax(390px, 1.08fr) !important;
  gap: clamp(44px, 5.2vw, 110px) !important;
}
#slide-9 .rating-subjects h3 {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(1.85rem, 2.75vw, 4.9rem) !important;
  line-height: .88 !important;
  margin-bottom: clamp(16px, 1.9svh, 30px) !important;
}
#slide-9 .rating-subjects ul {
  padding-left: clamp(36px, 2.8vw, 64px) !important;
}
#slide-9 .rating-subjects li {
  margin-bottom: clamp(6px, .78svh, 12px) !important;
  min-height: clamp(20px, 2.7svh, 34px) !important;
}
#slide-9 .rating-subjects a {
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(.88rem, 1.06vw, 1.55rem) !important;
  line-height: 1.08 !important;
}

/* Slide 9: right side ratings positioned opposite the requested subject groups */
#slide-9 .rating-results {
  position: relative !important;
  display: block !important;
  min-height: 100% !important;
}
#slide-9 .rating-logos {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(18px, 1.8vw, 38px) !important;
}
#slide-9 .rating-raex-link img {
  width: clamp(154px, 13vw, 285px) !important;
}
#slide-9 .rating-click {
  width: clamp(48px, 4.4vw, 86px) !important;
}

#slide-9 .rating-box {
  position: absolute !important;
  left: 2% !important;
  right: 2% !important;
  min-height: clamp(58px, 7.6svh, 108px) !important;
  display: grid !important;
  place-items: center !important;
  background:
    linear-gradient(#44bd4a 0 0) left top / clamp(22px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) left top / 3px clamp(22px, 2vw, 42px) no-repeat,
    linear-gradient(#44bd4a 0 0) right top / clamp(22px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) right top / 3px clamp(22px, 2vw, 42px) no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / clamp(22px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / 3px clamp(22px, 2vw, 42px) no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / clamp(22px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / 3px clamp(22px, 2vw, 42px) no-repeat !important;
  border: 0 !important;
}
#slide-9 .rating-box::before,
#slide-9 .rating-box::after {
  display: none !important;
}
#slide-9 .rating-box strong {
  font-family: "CoFo Kak Black", "CoFo Kak", "Aptos Black", Verdana, sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(1.4rem, 2.05vw, 3.55rem) !important;
  line-height: 1.02 !important;
}
#slide-9 .rating-box-top {
  top: clamp(70px, 9.4svh, 126px) !important;
}
#slide-9 .rating-box-mid {
  top: clamp(172px, 23.3svh, 285px) !important;
}
#slide-9 .rating-box-bottom {
  top: clamp(372px, 50.8svh, 610px) !important;
}
#slide-9 .rating-link {
  right: clamp(92px, 7.8vw, 190px) !important;
  width: clamp(360px, 33vw, 730px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(26px, 3.5svh, 52px)) !important;
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-7 .analytics-tabs { width: min(60vw, 720px) !important; }
  #slide-8 .practice-row { top: 430px !important; }
  #slide-8 .practice-logo-row { left: 32vw !important; top: -4px !important; gap: 28px !important; }
  #slide-8 .university-logos { gap: 14px !important; margin-top: 44px !important; }
  #slide-8 .university-logos img { max-height: 86px !important; }
  #slide-9 .rating-content { left: 18vw !important; right: 6.8vw !important; gap: 50px !important; }
  #slide-9 .rating-subjects a { font-size: .82rem !important; }
  #slide-9 .rating-box strong { font-size: 1.45rem !important; }
  #slide-9 .rating-box-top { top: 66px !important; }
  #slide-9 .rating-box-mid { top: 162px !important; }
  #slide-9 .rating-box-bottom { top: 342px !important; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-7 .analytics-tabs { width: 66vw !important; }
  #slide-8 .practice-row { top: 328px !important; left: 5vw !important; right: 5vw !important; }
  #slide-8 .practice-logo-row { left: 36vw !important; top: -2px !important; gap: 18px !important; }
  #slide-8 .practice-tpu { width: 135px !important; }
  #slide-8 .practice-ai { width: 50px !important; }
  #slide-8 .university-logos { gap: 10px !important; margin-top: 30px !important; }
  #slide-8 .university-logos img { max-height: 54px !important; }
  #slide-9 .rating-title { left: 22vw !important; top: 32px !important; }
  #slide-9 .rating-content { left: 17vw !important; right: 4vw !important; gap: 26px !important; grid-template-columns: .94fr 1.06fr !important; }
  #slide-9 .rating-subjects a { font-size: .56rem !important; }
  #slide-9 .rating-box strong { font-size: 1rem !important; }
  #slide-9 .rating-box-top { top: 54px !important; }
  #slide-9 .rating-box-mid { top: 132px !important; }
  #slide-9 .rating-box-bottom { top: 270px !important; }
}


/* ===== FINAL-2: slide 8 logos + slide 9 invisible table/rank brackets ===== */

/* Slide 8: raise TPU/AI logos and make university logos bigger/tighter */
#slide-8 .practice-row {
  top: clamp(420px, 56svh, 565px) !important;
  left: clamp(68px, 5.2vw, 130px) !important;
  right: clamp(68px, 5.2vw, 130px) !important;
}
#slide-8 .practice-row h3 {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(2.15rem, 3.2vw, 4.9rem) !important;
  line-height: .96 !important;
}
#slide-8 .practice-logo-row {
  position: absolute !important;
  left: clamp(370px, 32vw, 660px) !important;
  top: clamp(-22px, -2.1svh, -10px) !important;
  display: flex !important;
  align-items: center !important;
  gap: clamp(18px, 1.9vw, 36px) !important;
  margin: 0 !important;
}
#slide-8 .practice-tpu { width: clamp(190px, 15.5vw, 320px) !important; }
#slide-8 .practice-ai { width: clamp(72px, 6vw, 120px) !important; }
#slide-8 .university-logos {
  margin-top: clamp(34px, 4.1svh, 58px) !important;
  display: grid !important;
  grid-template-columns: .72fr 1.05fr .82fr .72fr .72fr .82fr 1.02fr !important;
  gap: clamp(6px, .85vw, 18px) !important;
  align-items: center !important;
  justify-items: center !important;
}
#slide-8 .university-logos img {
  max-height: clamp(92px, 12.4svh, 170px) !important;
  max-width: 100% !important;
  object-fit: contain !important;
}

/* Slide 9: title right of logo and facade far up/right, with part outside viewport */
#slide-9 .section-logo {
  top: clamp(30px, 4.35svh, 58px) !important;
  left: clamp(38px, 3.35vw, 78px) !important;
}
#slide-9 .rating-title {
  position: absolute !important;
  top: clamp(34px, 4.6svh, 64px) !important;
  left: clamp(310px, 24vw, 545px) !important;
  right: auto !important;
  width: auto !important;
  z-index: 10 !important;
}
#slide-9 .rating-title h2 {
  margin: 0 !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(2.05rem, 3.05vw, 5.2rem) !important;
  line-height: .96 !important;
  color: #fff !important;
}
#slide-9 .rating-facade {
  top: clamp(18px, 2.6svh, 42px) !important;
  right: -28% !important;
  width: clamp(520px, 48vw, 1120px) !important;
  opacity: .84 !important;
}
#slide-9 .rating-ribbon-left {
  left: -3.5% !important;
  bottom: clamp(72px, 9svh, 150px) !important;
  width: clamp(245px, 19vw, 435px) !important;
  opacity: .76 !important;
}

/* Slide 9: unified invisible table binds subjects and TOP blocks */
#slide-9 .rating-layout {
  position: absolute !important;
  z-index: 12 !important;
  top: clamp(138px, 19svh, 230px) !important;
  left: clamp(260px, 20vw, 470px) !important;
  right: clamp(120px, 9.5vw, 240px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(62px, 8svh, 118px)) !important;
  display: grid !important;
  grid-template-columns: minmax(350px, .92fr) minmax(390px, 1fr) !important;
  grid-template-rows: auto 1fr !important;
  column-gap: clamp(18px, 2vw, 42px) !important;
  row-gap: clamp(14px, 1.6svh, 28px) !important;
}
#slide-9 .rating-heading { grid-column: 1; grid-row: 1; }
#slide-9 .rating-heading h3 {
  margin: 0 !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  color: #00e88a !important;
  font-size: clamp(2.05rem, 3.15vw, 5.55rem) !important;
  line-height: .88 !important;
}
#slide-9 .rating-logos {
  grid-column: 2 !important;
  grid-row: 1 !important;
  position: static !important;
  width: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(18px, 1.8vw, 38px) !important;
}
#slide-9 .rating-raex-link img { width: clamp(170px, 14vw, 300px) !important; height: auto !important; }
#slide-9 .rating-click {
  width: clamp(52px, 4.45vw, 88px) !important;
  aspect-ratio: 1 !important;
  display: grid !important;
  place-items: center !important;
  background: #43b64a !important;
  border-radius: 0 !important;
  text-decoration: none !important;
}
#slide-9 .rating-click img { display: none !important; }
#slide-9 .rating-click .click-hand {
  color: #fff !important;
  font-size: clamp(1.75rem, 2.2vw, 3rem) !important;
  line-height: 1 !important;
  transform: rotate(-15deg) translateY(-1px) !important;
}
#slide-9 .rating-grid-table {
  grid-column: 1 / span 2 !important;
  grid-row: 2 !important;
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(350px, .92fr) minmax(390px, 1fr) !important;
  grid-template-rows: repeat(10, minmax(0, 1fr)) !important;
  column-gap: clamp(18px, 2vw, 42px) !important;
  min-height: 0 !important;
}

/* One-piece shelf rail */
#slide-9 .rating-grid-table::before {
  content: "" !important;
  position: absolute !important;
  left: clamp(18px, 1.28vw, 31px) !important;
  top: clamp(7px, .75svh, 14px) !important;
  bottom: clamp(7px, .75svh, 14px) !important;
  width: 2px !important;
  background: #44bd4a !important;
  z-index: 1 !important;
}
#slide-9 .rating-subject-row {
  grid-column: 1 !important;
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
  padding-left: clamp(54px, 4.4vw, 88px) !important;
  opacity: 0;
  transform: translateY(-18px);
  z-index: 2 !important;
}
#slide-9.is-active .rating-subject-row {
  animation: ratingListDrop2 .5s cubic-bezier(.2,.84,.2,1) calc(.16s + var(--i) * .07s) forwards !important;
}
#slide-9 .rating-subject-row::before {
  content: "" !important;
  position: absolute !important;
  left: clamp(18px, 1.28vw, 31px) !important;
  top: 50% !important;
  width: clamp(24px, 2.15vw, 43px) !important;
  height: 2px !important;
  background: #44bd4a !important;
  transform: translateY(-50%) !important;
}
#slide-9 .rating-subject-row a {
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  color: #fff !important;
  font-size: clamp(.92rem, 1.12vw, 1.65rem) !important;
  line-height: 1.06 !important;
  text-decoration: underline !important;
  text-underline-offset: .16em !important;
}
#slide-9 .rating-qs-badge {
  width: clamp(48px, 3.7vw, 80px) !important;
  height: auto !important;
  margin-left: clamp(8px, .7vw, 14px) !important;
}

/* TOP blocks are real grid-row spans, so they are tied to subject rows */
#slide-9 .rating-rank {
  grid-column: 2 !important;
  position: relative !important;
  display: grid !important;
  place-items: center !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  margin: clamp(4px, .55svh, 8px) 0 !important;
  background:
    linear-gradient(#44bd4a 0 0) left top / clamp(24px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) left top / 3px clamp(24px, 2vw, 42px) no-repeat,
    linear-gradient(#44bd4a 0 0) right top / clamp(24px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) right top / 3px clamp(24px, 2vw, 42px) no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / clamp(24px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / 3px clamp(24px, 2vw, 42px) no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / clamp(24px, 2vw, 42px) 3px no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / 3px clamp(24px, 2vw, 42px) no-repeat !important;
  border: 0 !important;
  border-radius: 0 !important;
}
#slide-9 .rating-rank::before,
#slide-9 .rating-rank::after { display: none !important; }
#slide-9 .rating-rank-1 { grid-row: 1 / span 2 !important; }
#slide-9 .rating-rank-3 { grid-row: 3 / span 2 !important; }
#slide-9 .rating-rank-10 { grid-row: 7 / span 2 !important; }
#slide-9 .rating-rank strong {
  font-family: "CoFo Kak Black", "CoFo Kak", "Aptos Black", Verdana, sans-serif !important;
  font-weight: 900 !important;
  color: #fff !important;
  text-align: center !important;
  font-size: clamp(1.45rem, 2.05vw, 3.55rem) !important;
  line-height: 1.03 !important;
}
#slide-9 .rating-link {
  left: auto !important;
  right: clamp(120px, 9.5vw, 240px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(26px, 3.5svh, 52px)) !important;
  width: clamp(390px, 36vw, 760px) !important;
  background: #43b64a !important;
  color: #fff !important;
  text-align: center !important;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
}
@keyframes ratingListDrop2 { to { opacity: 1; transform: translateY(0); } }

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-8 .practice-row { top: 410px !important; }
  #slide-8 .practice-logo-row { left: 32vw !important; top: -18px !important; gap: 20px !important; }
  #slide-8 .practice-tpu { width: 210px !important; }
  #slide-8 .practice-ai { width: 78px !important; }
  #slide-8 .university-logos { gap: 8px !important; margin-top: 34px !important; }
  #slide-8 .university-logos img { max-height: 104px !important; }

  #slide-9 .rating-title { left: 24vw !important; top: 34px !important; }
  #slide-9 .rating-facade { top: 16px !important; right: -30% !important; width: 48vw !important; }
  #slide-9 .rating-layout { left: 18.8vw !important; right: 6vw !important; column-gap: 24px !important; }
  #slide-9 .rating-grid-table { column-gap: 24px !important; }
  #slide-9 .rating-subject-row a { font-size: .84rem !important; }
  #slide-9 .rating-rank strong { font-size: 1.44rem !important; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-8 .practice-row { top: 318px !important; }
  #slide-8 .practice-logo-row { left: 36vw !important; top: -10px !important; gap: 12px !important; }
  #slide-8 .practice-tpu { width: 145px !important; }
  #slide-8 .practice-ai { width: 55px !important; }
  #slide-8 .university-logos { gap: 6px !important; margin-top: 28px !important; }
  #slide-8 .university-logos img { max-height: 66px !important; }

  #slide-9 .rating-title { left: 24vw !important; top: 28px !important; }
  #slide-9 .rating-facade { right: -34% !important; top: 10px !important; width: 52vw !important; }
  #slide-9 .rating-layout { left: 17vw !important; right: 3.8vw !important; top: 92px !important; bottom: calc(var(--nav-strip-h) + 48px) !important; column-gap: 16px !important; }
  #slide-9 .rating-heading h3 { font-size: 1.55rem !important; }
  #slide-9 .rating-grid-table { column-gap: 16px !important; }
  #slide-9 .rating-subject-row { padding-left: 38px !important; }
  #slide-9 .rating-subject-row a { font-size: .55rem !important; }
  #slide-9 .rating-rank strong { font-size: .96rem !important; }
  #slide-9 .rating-link { right: 3.8vw !important; width: 39vw !important; }
}


/* ===== FINAL FIX: slide 8 logos + slide 9 right table/brackets/facade ===== */

/* Slide 8: align TPU + AI higher and keep them on the title line */
#slide-8 .practice-row {
  top: clamp(428px, 57svh, 574px) !important;
  left: clamp(58px, 4.8vw, 122px) !important;
  right: clamp(50px, 4.2vw, 96px) !important;
}
#slide-8 .practice-row h3 {
  font-size: clamp(2.15rem, 3.18vw, 4.8rem) !important;
  line-height: .96 !important;
}
#slide-8 .practice-logo-row {
  left: clamp(365px, 34vw, 700px) !important;
  top: clamp(-34px, -3.5svh, -18px) !important;
  gap: clamp(18px, 1.8vw, 36px) !important;
  align-items: flex-start !important;
}
#slide-8 .practice-tpu {
  width: clamp(205px, 16.5vw, 330px) !important;
}
#slide-8 .practice-ai {
  width: clamp(78px, 6.4vw, 126px) !important;
}

/* Slide 8: only requested logos, larger and tighter in one line */
#slide-8 .university-logos {
  margin-top: clamp(34px, 4.1svh, 58px) !important;
  grid-template-columns: .66fr .92fr .8fr .72fr .76fr .78fr 1.08fr !important;
  gap: clamp(4px, .78vw, 16px) !important;
  align-items: center !important;
  justify-items: center !important;
}
#slide-8 .university-logos img {
  max-width: 112% !important;
  max-height: clamp(92px, 12svh, 165px) !important;
  object-fit: contain !important;
}

/* Slide 9: title remains right of logo, facade moved far right/up so most is offscreen */
#slide-9 .rating-title {
  top: clamp(34px, 4.8svh, 66px) !important;
  left: clamp(300px, 22vw, 500px) !important;
  z-index: 14 !important;
}
#slide-9 .rating-title h2 {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(2rem, 3.05vw, 5.15rem) !important;
  line-height: .95 !important;
}
#slide-9 .rating-facade {
  top: clamp(-52px, -5.6svh, -20px) !important;
  right: -42vw !important;
  width: clamp(620px, 56vw, 1240px) !important;
  opacity: .82 !important;
  transform: none !important;
}

/* Slide 9: invisible table with fixed left column and close right column */
#slide-9 .rating-layout {
  top: clamp(136px, 18.6svh, 220px) !important;
  left: clamp(280px, 17.3vw, 405px) !important;
  right: clamp(160px, 12vw, 300px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(62px, 7.8svh, 112px)) !important;
  grid-template-columns: clamp(420px, 28vw, 555px) minmax(430px, 1fr) !important;
  column-gap: clamp(8px, .65vw, 18px) !important;
}
#slide-9 .rating-heading {
  grid-column: 1 !important;
}
#slide-9 .rating-heading h3 {
  font-size: clamp(1.95rem, 2.9vw, 5.15rem) !important;
  line-height: .88 !important;
  margin: 0 !important;
}
#slide-9 .rating-logos {
  grid-column: 2 !important;
  justify-content: center !important;
  gap: 0 !important;
}
#slide-9 .rating-click {
  display: none !important;
}
#slide-9 .rating-raex-link img {
  width: clamp(170px, 13.8vw, 310px) !important;
}

/* A real row grid: ranks are bound to subject rows and sit right next to them */
#slide-9 .rating-grid-table {
  grid-column: 1 / span 2 !important;
  display: grid !important;
  grid-template-columns: clamp(420px, 28vw, 555px) minmax(430px, 1fr) !important;
  grid-template-rows: repeat(10, minmax(0, 1fr)) !important;
  column-gap: clamp(8px, .65vw, 18px) !important;
}

/* Left rail: one clean vertical rail with short shelves */
#slide-9 .rating-grid-table::before {
  left: clamp(14px, 1vw, 24px) !important;
  top: clamp(4px, .45svh, 8px) !important;
  bottom: clamp(4px, .45svh, 8px) !important;
  width: 2px !important;
  background: #44bd4a !important;
}
#slide-9 .rating-subject-row {
  grid-column: 1 !important;
  padding-left: clamp(48px, 3.6vw, 74px) !important;
  align-items: center !important;
}
#slide-9 .rating-subject-row::before {
  left: clamp(14px, 1vw, 24px) !important;
  width: clamp(24px, 1.8vw, 36px) !important;
  height: 2px !important;
  background: #44bd4a !important;
}
#slide-9 .rating-subject-row a {
  font-size: clamp(.9rem, 1.05vw, 1.5rem) !important;
  line-height: 1.07 !important;
}

/* Rank blocks: sharp small corner brackets only; no rounded/long framing */
#slide-9 .rating-rank {
  grid-column: 2 !important;
  justify-self: stretch !important;
  align-self: stretch !important;
  margin: clamp(3px, .45svh, 7px) 0 !important;
  border: none !important;
  border-radius: 0 !important;
  background:
    linear-gradient(#44bd4a 0 0) left top / 18px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) left top / 2px 18px no-repeat,
    linear-gradient(#44bd4a 0 0) right top / 18px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) right top / 2px 18px no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / 18px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / 2px 18px no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / 18px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / 2px 18px no-repeat !important;
}
#slide-9 .rating-rank::before,
#slide-9 .rating-rank::after {
  display: none !important;
}
#slide-9 .rating-rank-1 {
  grid-row: 1 / span 2 !important;
}
#slide-9 .rating-rank-3 {
  grid-row: 3 / span 2 !important;
}
#slide-9 .rating-rank-10 {
  grid-row: 7 / span 2 !important;
}
#slide-9 .rating-rank strong {
  font-family: "CoFo Kak Black", "CoFo Kak", "Aptos Black", Verdana, sans-serif !important;
  font-size: clamp(1.35rem, 1.92vw, 3.25rem) !important;
  line-height: 1.02 !important;
}

/* Link stays under right rating column */
#slide-9 .rating-link {
  right: clamp(160px, 12vw, 300px) !important;
  width: minmax(0, 1fr) !important;
  width: clamp(430px, 36vw, 780px) !important;
}

/* Laptop tuning */
@media (max-width: 1366px) and (orientation: landscape) {
  #slide-8 .practice-row { top: 398px !important; }
  #slide-8 .practice-logo-row { left: 34vw !important; top: -24px !important; gap: 16px !important; }
  #slide-8 .practice-tpu { width: 220px !important; }
  #slide-8 .practice-ai { width: 84px !important; }
  #slide-8 .university-logos { gap: 6px !important; margin-top: 30px !important; }
  #slide-8 .university-logos img { max-height: 116px !important; }

  #slide-9 .rating-title { left: 23vw !important; top: 30px !important; }
  #slide-9 .rating-facade { top: -44px !important; right: -46vw !important; width: 62vw !important; }
  #slide-9 .rating-layout {
    left: 17.2vw !important;
    right: 10vw !important;
    grid-template-columns: 410px minmax(410px, 1fr) !important;
    column-gap: 10px !important;
  }
  #slide-9 .rating-grid-table {
    grid-template-columns: 410px minmax(410px, 1fr) !important;
    column-gap: 10px !important;
  }
  #slide-9 .rating-subject-row a { font-size: .78rem !important; }
  #slide-9 .rating-rank strong { font-size: 1.38rem !important; }
  #slide-9 .rating-link { right: 10vw !important; width: 420px !important; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-8 .practice-row { top: 306px !important; }
  #slide-8 .practice-logo-row { left: 37vw !important; top: -16px !important; gap: 10px !important; }
  #slide-8 .practice-tpu { width: 150px !important; }
  #slide-8 .practice-ai { width: 56px !important; }
  #slide-8 .university-logos { gap: 4px !important; margin-top: 24px !important; }
  #slide-8 .university-logos img { max-height: 74px !important; }

  #slide-9 .rating-title { left: 24vw !important; top: 24px !important; }
  #slide-9 .rating-facade { top: -35px !important; right: -50vw !important; width: 66vw !important; }
  #slide-9 .rating-layout {
    left: 16.5vw !important;
    right: 4.5vw !important;
    top: 86px !important;
    grid-template-columns: 320px minmax(315px, 1fr) !important;
    column-gap: 8px !important;
  }
  #slide-9 .rating-grid-table {
    grid-template-columns: 320px minmax(315px, 1fr) !important;
    column-gap: 8px !important;
  }
  #slide-9 .rating-subject-row { padding-left: 38px !important; }
  #slide-9 .rating-subject-row a { font-size: .52rem !important; }
  #slide-9 .rating-rank strong { font-size: .92rem !important; }
  #slide-9 .rating-link { right: 4.5vw !important; width: 315px !important; }
}


/* ===== LAST ALIGNMENT PATCH: slide 8 logos + slide 9 facade/table ===== */

/* 8 слайд: TPU/AI строго в одну строку с заголовком */
#slide-8 .practice-row {
  top: clamp(430px, 57.2svh, 574px) !important;
  left: clamp(42px, 3.4vw, 82px) !important;
  right: clamp(42px, 3.4vw, 82px) !important;
}
#slide-8 .practice-row h3 {
  margin: 0 !important;
  line-height: .96 !important;
}
#slide-8 .practice-logo-row {
  position: absolute !important;
  left: clamp(600px, 36vw, 760px) !important;
  top: 0px !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: clamp(34px, 2.9vw, 58px) !important;
}
#slide-8 .practice-tpu {
  width: clamp(220px, 17.2vw, 350px) !important;
}
#slide-8 .practice-ai {
  width: clamp(82px, 6.6vw, 132px) !important;
}

/* 8 слайд: нижние логотипы крупнее и плотнее */
#slide-8 .university-logos {
  margin-top: clamp(34px, 4.1svh, 56px) !important;
  display: grid !important;
  grid-template-columns: .64fr .96fr .78fr .70fr .72fr .74fr 1.1fr !important;
  gap: clamp(2px, .55vw, 12px) !important;
  align-items: center !important;
  justify-items: center !important;
}
#slide-8 .university-logos img {
  max-width: 116% !important;
  max-height: clamp(98px, 12.8svh, 176px) !important;
  object-fit: contain !important;
}

/* 9 слайд: facade-line уходит вправо и ниже, без центровки */
#slide-9 .rating-facade {
  left: auto !important;
  top: clamp(42px, 5.8svh, 92px) !important;
  right: -43vw !important;
  width: clamp(650px, 62vw, 1360px) !important;
  opacity: .82 !important;
  transform: none !important;
  z-index: 5 !important;
}

/* 9 слайд: правая колонка ближе к предметам */
#slide-9 .rating-layout {
  left: clamp(265px, 16.8vw, 385px) !important;
  right: clamp(150px, 10vw, 260px) !important;
  grid-template-columns: clamp(365px, 23vw, 455px) minmax(430px, 1fr) !important;
  column-gap: clamp(6px, .45vw, 12px) !important;
}
#slide-9 .rating-grid-table {
  grid-template-columns: clamp(365px, 23vw, 455px) minmax(430px, 1fr) !important;
  column-gap: clamp(6px, .45vw, 12px) !important;
}

/* 9 слайд: аккуратная цельная полка слева */
#slide-9 .rating-grid-table::before {
  left: clamp(14px, .95vw, 22px) !important;
  width: 2px !important;
  background: #44bd4a !important;
}
#slide-9 .rating-subject-row {
  padding-left: clamp(46px, 3.2vw, 66px) !important;
}
#slide-9 .rating-subject-row::before {
  left: clamp(14px, .95vw, 22px) !important;
  width: clamp(24px, 1.6vw, 34px) !important;
  height: 2px !important;
  background: #44bd4a !important;
}
#slide-9 .rating-subject-row a {
  font-size: clamp(.88rem, 1.02vw, 1.42rem) !important;
  line-height: 1.06 !important;
}

/* 9 слайд: только короткие острые уголки, без больших скобок */
#slide-9 .rating-rank {
  background:
    linear-gradient(#44bd4a 0 0) left top / 12px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) left top / 2px 12px no-repeat,
    linear-gradient(#44bd4a 0 0) right top / 12px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) right top / 2px 12px no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / 12px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) left bottom / 2px 12px no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / 12px 2px no-repeat,
    linear-gradient(#44bd4a 0 0) right bottom / 2px 12px no-repeat !important;
  border-radius: 0 !important;
  margin: clamp(4px, .5svh, 7px) 0 !important;
}
#slide-9 .rating-rank::before,
#slide-9 .rating-rank::after {
  display: none !important;
}
#slide-9 .rating-rank strong {
  font-family: "CoFo Kak Black", "CoFo Kak", "Aptos Black", Verdana, sans-serif !important;
}

/* 9 слайд: убрать остатки блока клика, если HTML был не обновлен */
#slide-9 .rating-click {
  display: none !important;
}

/* ноутбуки */
@media (max-width: 1366px) and (orientation: landscape) {
  #slide-8 .practice-row { top: 404px !important; }
  #slide-8 .practice-logo-row {
    left: 34.5vw !important;
    top: 0px !important;
    gap: 34px !important;
  }
  #slide-8 .practice-tpu { width: 235px !important; }
  #slide-8 .practice-ai { width: 90px !important; }
  #slide-8 .university-logos { gap: 4px !important; margin-top: 30px !important; }
  #slide-8 .university-logos img { max-height: 124px !important; }

  #slide-9 .rating-facade {
    left: auto !important;
    top: 38px !important;
    right: -46vw !important;
    width: 66vw !important;
  }
  #slide-9 .rating-layout {
    left: 17vw !important;
    right: 8vw !important;
    grid-template-columns: 380px minmax(410px, 1fr) !important;
    column-gap: 8px !important;
  }
  #slide-9 .rating-grid-table {
    grid-template-columns: 380px minmax(410px, 1fr) !important;
    column-gap: 8px !important;
  }
  #slide-9 .rating-subject-row a { font-size: .76rem !important; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-8 .practice-row { top: 312px !important; }
  #slide-8 .practice-logo-row {
    left: 37vw !important;
    top: 0px !important;
    gap: 18px !important;
  }
  #slide-8 .practice-tpu { width: 155px !important; }
  #slide-8 .practice-ai { width: 60px !important; }
  #slide-8 .university-logos { gap: 3px !important; margin-top: 24px !important; }
  #slide-8 .university-logos img { max-height: 78px !important; }

  #slide-9 .rating-facade {
    left: auto !important;
    top: 32px !important;
    right: -54vw !important;
    width: 74vw !important;
  }
  #slide-9 .rating-layout {
    left: 16.4vw !important;
    right: 4vw !important;
    grid-template-columns: 300px minmax(310px, 1fr) !important;
    column-gap: 6px !important;
  }
  #slide-9 .rating-grid-table {
    grid-template-columns: 300px minmax(310px, 1fr) !important;
    column-gap: 6px !important;
  }
  #slide-9 .rating-subject-row { padding-left: 36px !important; }
  #slide-9 .rating-subject-row a { font-size: .5rem !important; }
}


/* ===== Continue deck: slides 10-13 ===== */

/* Keep slide 8 logo row aligned with "ЛУЧШИЕ ПРАКТИКИ" */
#slide-8 .practice-logo-row {
  top: -40px !important;
}

/* Common section logo sizing */
.slide-current-changes .section-logo,
.slide-campaign-map .section-logo,
.slide-events .section-logo {
  top: clamp(28px, 4svh, 52px);
  left: clamp(42px, 3.5vw, 80px);
  width: clamp(170px, 13vw, 290px);
}

/* Slide 10 */
.slide-current-changes .bg { opacity: .60; }
.current-head {
  position: absolute;
  top: clamp(32px, 4.2svh, 56px);
  left: clamp(240px, 18vw, 430px);
  z-index: 8;
}
.current-head h2,
.campaign-head h2,
.events-head h2,
.target-head h2 {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .01em;
}
.current-head h2 { font-size: clamp(1.7rem, 2.35vw, 4.1rem); }

.current-label {
  position: absolute;
  top: clamp(104px, 14.4svh, 158px);
  left: clamp(55px, 4.2vw, 102px);
  z-index: 8;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  color: #ff2424;
  font-size: clamp(1.7rem, 2.2vw, 3.9rem);
  text-transform: uppercase;
}

.block-icons {
  position: absolute;
  z-index: 8;
  top: clamp(185px, 26svh, 305px);
  left: clamp(54px, 4.2vw, 110px);
  right: clamp(80px, 8vw, 185px);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(70px, 7.2vw, 155px);
  align-items: center;
  justify-items: center;
}
.block-icon {
  width: clamp(130px, 12vw, 238px);
  max-height: clamp(130px, 12vw, 238px);
  object-fit: contain;
  animation-delay: calc(.12s + var(--i) * .12s);
}
.current-brace {
  position: absolute;
  z-index: 7;
  left: clamp(38px, 3vw, 74px);
  right: clamp(92px, 8vw, 180px);
  top: clamp(390px, 53.5svh, 560px);
  height: clamp(20px, 3svh, 40px);
  border-bottom: 2px solid rgba(2, 164, 231, .68);
}
.current-brace::before,
.current-brace::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 10px;
  height: 18px;
  border-bottom: 2px solid rgba(2, 164, 231, .68);
}
.current-brace::before { left: 0; border-left: 2px solid rgba(2, 164, 231, .68); }
.current-brace::after { right: 0; border-right: 2px solid rgba(2, 164, 231, .68); }
.max-logo {
  position: absolute;
  z-index: 8;
  left: 50%;
  bottom: calc(var(--nav-strip-h) + clamp(52px, 7svh, 94px));
  width: clamp(280px, 26vw, 540px);
  transform: translateX(-50%);
}

/* Slide 11 */
.slide-campaign-map .bg { opacity: .58; }
.campaign-ribbon-top {
  position: absolute;
  z-index: 3;
  right: -4%;
  top: -10%;
  width: clamp(430px, 42vw, 880px);
  opacity: .62;
}
.campaign-head {
  position: absolute;
  top: clamp(26px, 3.8svh, 52px);
  left: clamp(255px, 20vw, 480px);
  z-index: 8;
}
.campaign-head h2 { font-size: clamp(1.8rem, 2.6vw, 4.7rem); }
.entry-point {
  position: absolute;
  top: clamp(78px, 12svh, 150px);
  left: 50%;
  transform: translateX(-15%);
  z-index: 8;
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 18px;
  color: #fff;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.95rem, 1.15vw, 1.7rem);
}
.entry-arrow {
  color: #08b7ff;
  font-size: clamp(4rem, 6vw, 8rem);
  line-height: .7;
  animation: entryArrowPulse 1.5s ease-in-out infinite;
}
@keyframes entryArrowPulse {
  0%, 100% { transform: translateY(-4px); opacity: .8; }
  50% { transform: translateY(8px); opacity: 1; }
}
.campaign-facade {
  position: absolute;
  z-index: 7;
  top: clamp(160px, 24svh, 255px);
  left: 50%;
  width: clamp(360px, 31vw, 680px);
  transform: translateX(-50%);
  opacity: .95;
}
.audience-line {
  position: absolute;
  z-index: 8;
  top: clamp(270px, 39svh, 410px);
  left: 50%;
  transform: translateX(-50%);
  width: min(68vw, 1120px);
  text-align: center;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(1.05rem, 1.45vw, 2.3rem);
  background: linear-gradient(90deg, #c17aff, #60b7ff, #00e58d);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  white-space: nowrap;
}
.audience-line::after {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  bottom: clamp(-18px, -1.9svh, -10px);
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(87, 183, 255, .9), transparent);
}
.program-grid {
  position: absolute;
  z-index: 8;
  left: clamp(80px, 6vw, 150px);
  right: clamp(80px, 6vw, 150px);
  bottom: calc(var(--nav-strip-h) + clamp(42px, 5.5svh, 92px));
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 1.4vw, 24px) clamp(45px, 5vw, 110px);
}
.program-grid a {
  display: grid;
  place-items: center;
  min-height: clamp(38px, 5.4svh, 68px);
  padding: 0 16px;
  border-radius: 10px;
  color: #fff;
  text-decoration: none;
  text-align: center;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(.72rem, .94vw, 1.35rem);
  background: linear-gradient(100deg, #c87cff, #63b3ff 46%, #00dd8a);
  box-shadow: 0 12px 26px rgba(0, 0, 0, .18);
}

/* Slide 12 */
.slide-events .bg { opacity: .57; }
.events-head {
  position: absolute;
  top: clamp(28px, 4svh, 56px);
  left: clamp(245px, 19vw, 455px);
  z-index: 8;
}
.events-head h2 { font-size: clamp(2rem, 2.7vw, 4.8rem); }
.events-pill {
  position: absolute;
  z-index: 8;
  top: clamp(104px, 14.4svh, 160px);
  left: clamp(45px, 3.6vw, 90px);
  width: clamp(255px, 21vw, 440px);
  height: clamp(42px, 5.2svh, 66px);
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: linear-gradient(100deg, #be7aff, #62b9ff 47%, #00dc8a);
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(.85rem, 1vw, 1.45rem);
}
.events-video {
  position: absolute;
  z-index: 8;
  top: clamp(46px, 6.2svh, 84px);
  right: clamp(120px, 10vw, 230px);
  width: clamp(360px, 34vw, 690px);
  aspect-ratio: 16 / 9;
  border-radius: clamp(22px, 2.2vw, 46px);
  padding: 5px;
  background: linear-gradient(135deg, rgba(190, 122, 255, .75), rgba(255,255,255,.18), rgba(255, 132, 210, .55));
  box-shadow: 0 18px 46px rgba(0, 0, 0, .38);
}
.events-video video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: clamp(18px, 1.85vw, 38px);
  background: #001f28;
}
.events-count {
  position: absolute;
  z-index: 8;
  top: clamp(180px, 26svh, 300px);
  left: clamp(48px, 3.8vw, 90px);
  display: flex;
  align-items: baseline;
  gap: clamp(16px, 1.6vw, 30px);
}
.events-count strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(4.4rem, 6.3vw, 10rem);
  line-height: .9;
  background: linear-gradient(90deg, #b176ff, #58c5ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.events-count span {
  color: #61d9f4;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.4rem, 1.8vw, 3rem);
}
.events-content {
  position: absolute;
  z-index: 8;
  left: clamp(48px, 3.8vw, 90px);
  right: clamp(60px, 5vw, 120px);
  top: clamp(292px, 42svh, 460px);
  display: grid;
  grid-template-columns: 1fr 1.38fr;
  gap: clamp(56px, 6vw, 120px);
  color: #fff;
}
.events-content h3 {
  margin: 0 0 10px;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.25rem, 1.55vw, 2.6rem);
  text-transform: uppercase;
}
.events-content ul {
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.95rem, 1.1vw, 1.7rem);
  line-height: 1.26;
}
.events-content li::before { content: "- "; }
.events-notes {
  position: absolute;
  z-index: 8;
  left: clamp(48px, 3.8vw, 90px);
  bottom: calc(var(--nav-strip-h) + clamp(48px, 5.8svh, 90px));
  width: min(68vw, 1060px);
  color: #fff;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.88rem, 1vw, 1.5rem);
  line-height: 1.25;
}
.events-dashboard {
  position: absolute;
  z-index: 9;
  right: clamp(60px, 5vw, 120px);
  bottom: calc(var(--nav-strip-h) + clamp(30px, 4.3svh, 68px));
  color: #fff;
  text-decoration: underline;
  text-underline-offset: .15em;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.9rem, 1.1vw, 1.65rem);
}

/* Slide 13 */
.slide-target-admission .bg { opacity: .58; }
.target-logo {
  position: absolute;
  z-index: 9;
  top: clamp(28px, 3.6svh, 54px);
  right: clamp(48px, 4vw, 92px);
  width: clamp(170px, 13vw, 292px);
}
.target-ribbon-top {
  position: absolute;
  right: -5%;
  top: -8%;
  width: clamp(450px, 42vw, 860px);
  opacity: .68;
}
.target-ribbon-left {
  position: absolute;
  left: -4%;
  bottom: 0;
  width: clamp(210px, 18vw, 420px);
  opacity: .68;
}
.target-head {
  position: absolute;
  z-index: 8;
  top: clamp(32px, 4svh, 58px);
  left: clamp(205px, 16vw, 380px);
}
.target-head h2 { font-size: clamp(2.4rem, 3.4vw, 6rem); }
.target-stats {
  position: absolute;
  z-index: 8;
  left: clamp(58px, 5vw, 120px);
  top: clamp(150px, 22svh, 260px);
  bottom: calc(var(--nav-strip-h) + clamp(54px, 7svh, 120px));
  display: grid;
  grid-template-rows: repeat(3, 1fr);
  align-items: center;
}
.target-stats div {
  display: grid;
  grid-template-columns: auto auto;
  column-gap: 14px;
  align-items: baseline;
}
.target-stats strong,
.target-stats span {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  color: #00e88a;
  line-height: .9;
}
.target-stats strong { font-size: clamp(2.9rem, 4.4vw, 7.6rem); }
.target-stats span { font-size: clamp(2.2rem, 3.2vw, 5.2rem); }
.target-stats small {
  grid-column: 1 / span 2;
  color: #fff;
  text-align: center;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.82rem, .95vw, 1.5rem);
}
.target-lists {
  position: absolute;
  z-index: 8;
  left: clamp(290px, 24vw, 520px);
  right: clamp(70px, 7vw, 160px);
  top: clamp(125px, 18.2svh, 210px);
  bottom: calc(var(--nav-strip-h) + clamp(45px, 6svh, 100px));
  display: grid;
  grid-template-rows: 1.08fr 1.45fr .8fr;
  gap: clamp(18px, 2.6svh, 36px);
  color: #fff;
}
.target-lists h3 {
  margin: 0 0 12px;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(.95rem, 1.05vw, 1.7rem);
}
.target-lists p {
  margin: 0;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
  font-size: clamp(.82rem, .92vw, 1.35rem);
  line-height: 1.22;
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-8 .practice-logo-row { top: -40px !important; }

  .block-icons { top: 170px; gap: 88px; }
  .block-icon { width: 150px; }
  .current-brace { top: 380px; }
  .max-logo { width: 350px; }

  .campaign-facade { top: 150px; width: 420px; }
  .audience-line { top: 250px; }
  .program-grid { left: 66px; right: 66px; gap: 12px 42px; }

  .events-video { right: 112px; width: 420px; }
  .events-content { top: 275px; gap: 50px; }
  .events-notes { bottom: calc(var(--nav-strip-h) + 44px); }

  .target-lists { left: 270px; right: 60px; gap: 18px; }
  .target-lists p { font-size: .78rem; }
}
@media (max-width: 1024px) and (orientation: landscape) {
  .current-head { left: 210px; }
  .current-label { top: 90px; font-size: 1.2rem; }
  .block-icons { top: 142px; left: 45px; right: 70px; gap: 42px; }
  .block-icon { width: 105px; }
  .current-brace { top: 310px; }
  .max-logo { width: 260px; }

  .campaign-head { left: 230px; }
  .campaign-facade { top: 130px; width: 320px; }
  .audience-line { top: 215px; font-size: .78rem; }
  .program-grid { left: 48px; right: 48px; bottom: calc(var(--nav-strip-h) + 30px); gap: 8px 26px; }
  .program-grid a { min-height: 32px; font-size: .58rem; }

  .events-video { right: 70px; width: 330px; }
  .events-count { top: 165px; }
  .events-content { top: 245px; grid-template-columns: 1fr 1.25fr; gap: 34px; }
  .events-content ul { font-size: .68rem; }
  .events-notes { font-size: .62rem; }

  .target-logo { width: 150px; }
  .target-head { left: 180px; }
  .target-lists { left: 230px; right: 45px; gap: 10px; }
  .target-lists h3 { font-size: .68rem; margin-bottom: 6px; }
  .target-lists p { font-size: .55rem; }
}


/* ===== Patch for slides 10-13 requested layout fixes ===== */

/* Slide 10: title without number and proper curly blue brace */
#slide-10 .current-head {
  left: clamp(300px, 20.5vw, 510px) !important;
}
#slide-10 .current-head h2 {
  font-size: clamp(1.95rem, 2.55vw, 4.45rem) !important;
}
#slide-10 .current-brace {
  border: 0 !important;
  height: clamp(42px, 6.8svh, 80px) !important;
  top: clamp(388px, 52.5svh, 552px) !important;
  left: clamp(28px, 2.3vw, 58px) !important;
  right: clamp(92px, 8vw, 180px) !important;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%201200%2078%27%20preserveAspectRatio%3D%27none%27%3E%0A%3Cpath%20d%3D%27M8%204%20C8%2034%208%2038%2028%2038%20H570%20C586%2038%20586%2074%20600%2074%20C614%2074%20614%2038%20630%2038%20H1172%20C1192%2038%201192%2034%201192%204%27%20fill%3D%27none%27%20stroke%3D%27%25230087b7%27%20stroke-width%3D%273%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%0A%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
  background-position: center !important;
}
#slide-10 .current-brace::before,
#slide-10 .current-brace::after {
  display: none !important;
}

/* Slide 11: center entry arrow on facade, audience text left/center and curly brace below */
#slide-11 .entry-point {
  left: 50% !important;
  transform: translateX(-46%) !important;
  top: clamp(78px, 11.7svh, 146px) !important;
}
#slide-11 .entry-arrow {
  transform: translateX(-28px) !important;
}
#slide-11 .campaign-facade {
  left: 50% !important;
  transform: translateX(-50%) !important;
}
#slide-11 .audience-line {
  left: 48.5% !important;
  top: clamp(285px, 40.5svh, 422px) !important;
  width: min(76vw, 1240px) !important;
  transform: translateX(-50%) !important;
  font-size: clamp(.98rem, 1.36vw, 2.15rem) !important;
  white-space: nowrap !important;
  overflow: visible !important;
}
#slide-11 .audience-line::after {
  left: 0 !important;
  right: 0 !important;
  bottom: clamp(-44px, -5.2svh, -28px) !important;
  height: clamp(30px, 4.6svh, 62px) !important;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%201200%2070%27%20preserveAspectRatio%3D%27none%27%3E%0A%3Cpath%20d%3D%27M24%206%20C24%2034%2024%2038%2046%2038%20H570%20C586%2038%20586%2066%20600%2066%20C614%2066%20614%2038%20630%2038%20H1154%20C1176%2038%201176%2034%201176%206%27%20fill%3D%27none%27%20stroke%3D%27%25234ba7ff%27%20stroke-width%3D%272.5%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27%20opacity%3D%27.85%27/%3E%0A%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
  background-position: center !important;
}

/* Slide 12: move teachers/directors below video and make notes larger/bolder */
#slide-12 .events-content section:nth-child(2) {
  padding-top: clamp(82px, 12.5svh, 150px) !important;
}
#slide-12 .events-content section:nth-child(2) h3 {
  margin-bottom: clamp(12px, 1.4svh, 20px) !important;
}
#slide-12 .events-notes {
  font-size: clamp(1rem, 1.18vw, 1.75rem) !important;
  line-height: 1.28 !important;
  font-weight: 700 !important;
}
#slide-12 .events-notes p {
  margin: 0 0 clamp(18px, 2.4svh, 32px) !important;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif !important;
  font-weight: 700 !important;
}
#slide-12 .events-notes p:last-child {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-weight: 900 !important;
  letter-spacing: .01em !important;
}

/* Slide 13: title up/right + stats and content aligned by an invisible 3-row grid */
#slide-13 .target-head {
  top: clamp(16px, 2.4svh, 36px) !important;
  left: clamp(260px, 19vw, 450px) !important;
}
#slide-13 .target-head h2 {
  font-size: clamp(2.55rem, 3.55vw, 6.2rem) !important;
}
#slide-13 .target-stats,
#slide-13 .target-lists {
  top: clamp(132px, 18.3svh, 218px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(46px, 6.2svh, 98px)) !important;
  display: grid !important;
  grid-template-rows: repeat(3, minmax(0, 1fr)) !important;
  row-gap: clamp(18px, 2.5svh, 34px) !important;
}
#slide-13 .target-stats {
  left: clamp(62px, 5vw, 118px) !important;
  width: clamp(250px, 18vw, 390px) !important;
  align-items: stretch !important;
}
#slide-13 .target-stats div {
  align-self: center !important;
  justify-self: center !important;
  width: 100% !important;
  display: grid !important;
  grid-template-columns: auto auto !important;
  justify-content: center !important;
  align-items: baseline !important;
  column-gap: clamp(12px, 1vw, 22px) !important;
  text-align: center !important;
}
#slide-13 .target-stats small {
  justify-self: center !important;
  text-align: center !important;
}
#slide-13 .target-lists {
  left: clamp(330px, 24vw, 520px) !important;
  right: clamp(76px, 7vw, 155px) !important;
  color: #fff !important;
}
#slide-13 .target-lists section {
  align-self: center !important;
  justify-self: stretch !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}
#slide-13 .target-lists h3 {
  margin: 0 0 clamp(8px, 1svh, 14px) !important;
}
#slide-13 .target-lists p {
  margin: 0 !important;
}

/* Laptop tuning */
@media (max-width: 1366px) and (orientation: landscape) {
  #slide-10 .current-head { left: 250px !important; }
  #slide-10 .current-brace { top: 370px !important; }

  #slide-11 .entry-point { transform: translateX(-47%) !important; }
  #slide-11 .audience-line {
    left: 48% !important;
    top: 262px !important;
    width: 78vw !important;
    font-size: 1rem !important;
  }

  #slide-12 .events-content section:nth-child(2) { padding-top: 86px !important; }
  #slide-12 .events-notes { font-size: .92rem !important; }

  #slide-13 .target-head { top: 20px !important; left: 245px !important; }
  #slide-13 .target-stats,
  #slide-13 .target-lists {
    top: 120px !important;
    bottom: calc(var(--nav-strip-h) + 44px) !important;
    row-gap: 16px !important;
  }
  #slide-13 .target-stats { width: 280px !important; left: 55px !important; }
  #slide-13 .target-lists { left: 330px !important; right: 55px !important; }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-10 .current-head { left: 210px !important; }
  #slide-10 .current-brace { top: 298px !important; }

  #slide-11 .entry-point { transform: translateX(-49%) !important; }
  #slide-11 .audience-line {
    top: 220px !important;
    width: 80vw !important;
    font-size: .7rem !important;
  }

  #slide-12 .events-content section:nth-child(2) { padding-top: 62px !important; }
  #slide-12 .events-notes { font-size: .66rem !important; }

  #slide-13 .target-head { top: 16px !important; left: 205px !important; }
  #slide-13 .target-stats,
  #slide-13 .target-lists {
    top: 100px !important;
    bottom: calc(var(--nav-strip-h) + 34px) !important;
    row-gap: 10px !important;
  }
  #slide-13 .target-stats { width: 195px !important; left: 38px !important; }
  #slide-13 .target-lists { left: 248px !important; right: 36px !important; }
}


/* ===== Final requested patch: slide 10 bracket, slide 11 entry/brace, slide 12 spacing ===== */

/* Slide 10: синяя фигурная скобка как в референсе */
#slide-10 .current-brace {
  border: 0 !important;
  left: 0 !important;
  right: 0 !important;
  top: clamp(424px, 57.2svh, 606px) !important;
  height: clamp(58px, 8.6svh, 106px) !important;
  background: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%201800%2092%22%20preserveAspectRatio%3D%22none%22%3E%0A%3Cpath%20d%3D%22M2%204%20C2%2046%202%2050%2050%2050%20H858%20C882%2050%20882%2090%20900%2090%20C918%2090%20918%2050%20942%2050%20H1750%20C1798%2050%201798%2046%201798%204%22%20fill%3D%22none%22%20stroke%3D%22%230087b7%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22/%3E%0A%3C/svg%3E") center / 100% 100% no-repeat !important;
  z-index: 8 !important;
}
#slide-10 .current-brace::before,
#slide-10 .current-brace::after {
  display: none !important;
}

/* Slide 11: стрелка по центру фасада, как указано */
#slide-11 .entry-point {
  left: 57.5% !important;
  transform: translateX(-46%) !important;
  top: clamp(78px, 11.7svh, 146px) !important;
}
#slide-11 .entry-arrow {
  transform: none !important;
}

/* Slide 11: текст и фигурная скобка под ним */
#slide-11 .audience-line {
  left: 50% !important;
  transform: translateX(-50%) !important;
  top: clamp(294px, 41.8svh, 438px) !important;
  width: min(58vw, 980px) !important;
  text-align: center !important;
  white-space: nowrap !important;
  overflow: visible !important;
}
#slide-11 .audience-line::after {
  content: "" !important;
  position: absolute !important;
  left: -2% !important;
  right: -2% !important;
  bottom: clamp(-58px, -6.7svh, -36px) !important;
  height: clamp(42px, 6.2svh, 76px) !important;
  background: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%20980%2076%22%20preserveAspectRatio%3D%22none%22%3E%0A%3Cpath%20d%3D%22M12%204%20C12%2038%2012%2042%2044%2042%20H452%20C474%2042%20474%2072%20490%2072%20C506%2072%20506%2042%20528%2042%20H936%20C968%2042%20968%2038%20968%204%22%20fill%3D%22none%22%20stroke%3D%22%230087b7%22%20stroke-width%3D%223%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22/%3E%0A%3C/svg%3E") center / 100% 100% no-repeat !important;
}

/* Slide 12: разрыв перед XXVII + перенос блока ниже, чтобы не налезал на списки */
#slide-12 .events-note-break {
  display: block !important;
  height: clamp(16px, 2.3svh, 32px) !important;
}
#slide-12 .events-notes {
  bottom: calc(var(--nav-strip-h) + clamp(24px, 3.6svh, 56px)) !important;
  font-size: clamp(1rem, 1.17vw, 1.72rem) !important;
  line-height: 1.28 !important;
  font-weight: 700 !important;
}
#slide-12 .events-notes p:first-of-type {
  margin-top: clamp(12px, 1.8svh, 26px) !important;
}
#slide-12 .events-notes p:last-child {
  margin-top: clamp(18px, 2.6svh, 34px) !important;
  font-weight: 900 !important;
}

/* Адаптация */
@media (max-width: 1366px) and (orientation: landscape) {
  #slide-10 .current-brace {
    top: 382px !important;
    height: 68px !important;
  }
  #slide-11 .entry-point {
    left: 57.5% !important;
  }
  #slide-11 .audience-line {
    top: 268px !important;
    width: 60vw !important;
  }
  #slide-12 .events-notes {
    bottom: calc(var(--nav-strip-h) + 22px) !important;
    font-size: .9rem !important;
  }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-10 .current-brace {
    top: 308px !important;
    height: 52px !important;
  }
  #slide-11 .entry-point {
    left: 57.5% !important;
  }
  #slide-11 .audience-line {
    top: 226px !important;
    width: 62vw !important;
  }
  #slide-12 .events-notes {
    bottom: calc(var(--nav-strip-h) + 16px) !important;
    font-size: .62rem !important;
  }
}


/* ===== Slide 11 final: exact entry position, real brace image, animated down arrow ===== */

#slide-11 .entry-point {
  left: 55.7% !important;
  transform: translateX(-46%) !important;
  top: clamp(78px, 11.7svh, 146px) !important;
}

#slide-11 .entry-arrow {
  display: inline-block !important;
  animation: slide11ArrowBounce 1.15s ease-in-out infinite !important;
  will-change: transform;
}

@keyframes slide11ArrowBounce {
  0%, 100% {
    transform: translateY(-4px);
  }
  50% {
    transform: translateY(11px);
  }
}

/* Используем приложенную фигурную скобку как изображение, без округлых SVG-кривых */
#slide-11 .audience-line::after {
  content: "" !important;
  position: absolute !important;
  left: -4% !important;
  right: -4% !important;
  bottom: clamp(-62px, -7svh, -40px) !important;
  height: clamp(44px, 6.6svh, 80px) !important;
  background-image: url("assets/ppt-media/brace-figure.png") !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
  background-position: center !important;
}

/* Та же нормальная фигурная скобка на 10 слайде */
#slide-10 .current-brace {
  background-image: url("assets/ppt-media/brace-figure.png") !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
  background-position: center !important;
  border: 0 !important;
}
#slide-10 .current-brace::before,
#slide-10 .current-brace::after {
  display: none !important;
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-11 .entry-point {
    left: 55.7% !important;
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-11 .entry-point {
    left: 55.7% !important;
  }
}


/* ===== Slide 4: larger readable table text, tighter padding ===== */

/* Больше полезной площади под таблицу */
#slide-4 .changes-table {
  top: clamp(108px, 13.7svh, 158px) !important;
  bottom: calc(var(--nav-strip-h) + clamp(22px, 2.5svh, 42px)) !important;
  gap: clamp(3px, .46svh, 6px) !important;
}

/* Меньше паддинги — больше места тексту */
#slide-4 .changes-cell {
  padding: clamp(4px, .42vw, 8px) clamp(5px, .5vw, 10px) !important;
}

/* Левые формулировки крупнее */
#slide-4 .changes-topic {
  font-size: clamp(.86rem, 1.02vw, 1.24rem) !important;
  line-height: 1.12 !important;
  font-weight: 500 !important;
}

/* Тексты в 2024–2025 и обычные примечания крупнее */
#slide-4 .changes-note,
#slide-4 .changes-span-2,
#slide-4 .changes-note-center {
  font-size: clamp(.76rem, .88vw, 1.06rem) !important;
  line-height: 1.12 !important;
  font-weight: 500 !important;
}

/* Правый текст 2026 крупнее, но без вылезания */
#slide-4 .changes-note-with-sign {
  grid-template-columns: clamp(22px, 1.8vw, 38px) minmax(0, 1fr) !important;
  column-gap: clamp(4px, .38vw, 8px) !important;
  padding: clamp(3px, .36vw, 7px) clamp(5px, .55vw, 10px) !important;
}

#slide-4 .changes-note-copy {
  font-size: clamp(.70rem, .82vw, 1rem) !important;
  line-height: 1.08 !important;
  font-weight: 500 !important;
  gap: 0 !important;
}

#slide-4 .changes-note-copy span {
  margin-bottom: 1px !important;
}

/* Знаки не должны съедать место у текста */
#slide-4 .changes-sign {
  font-size: clamp(1.42rem, 1.78vw, 2.36rem) !important;
}

#slide-4 .changes-mark {
  font-size: clamp(1.55rem, 1.95vw, 2.55rem) !important;
}

/* Числа также чуть крупнее */
#slide-4 .changes-value {
  font-size: clamp(1.48rem, 1.88vw, 2.38rem) !important;
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-4 .changes-table {
    top: 96px !important;
    bottom: calc(var(--nav-strip-h) + 22px) !important;
    gap: 4px !important;
  }

  #slide-4 .changes-cell {
    padding: 4px 7px !important;
  }

  #slide-4 .changes-topic {
    font-size: clamp(.70rem, .86vw, .96rem) !important;
    line-height: 1.09 !important;
  }

  #slide-4 .changes-note,
  #slide-4 .changes-span-2,
  #slide-4 .changes-note-center {
    font-size: clamp(.62rem, .74vw, .84rem) !important;
    line-height: 1.08 !important;
  }

  #slide-4 .changes-note-with-sign {
    grid-template-columns: 26px minmax(0, 1fr) !important;
    column-gap: 4px !important;
    padding: 3px 6px !important;
  }

  #slide-4 .changes-note-copy {
    font-size: clamp(.56rem, .66vw, .76rem) !important;
    line-height: 1.05 !important;
  }

  #slide-4 .changes-value {
    font-size: clamp(1.22rem, 1.58vw, 1.9rem) !important;
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-4 .changes-table {
    top: 88px !important;
    bottom: calc(var(--nav-strip-h) + 14px) !important;
    gap: 3px !important;
  }

  #slide-4 .changes-cell {
    padding: 3px 5px !important;
  }

  #slide-4 .changes-topic {
    font-size: .58rem !important;
    line-height: 1.08 !important;
  }

  #slide-4 .changes-note,
  #slide-4 .changes-span-2,
  #slide-4 .changes-note-center {
    font-size: .52rem !important;
    line-height: 1.06 !important;
  }

  #slide-4 .changes-note-with-sign {
    grid-template-columns: 20px minmax(0, 1fr) !important;
    padding: 3px 5px !important;
  }

  #slide-4 .changes-note-copy {
    font-size: .47rem !important;
    line-height: 1.04 !important;
  }
}


/* ===== Slides 14-17: event continuation ===== */

.slide-events-more,
.slide-events-master,
.slide-events-communication,
.slide-abiturient {
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
}

.slide-events-more .bg,
.slide-events-master .bg,
.slide-events-communication .bg,
.slide-abiturient .bg {
  opacity: .58;
}

.events-more-logo,
.events-master-logo,
.events-communication-logo,
.abiturient-logo {
  top: clamp(24px, 3.8svh, 50px);
  left: clamp(38px, 3.4vw, 76px);
  width: clamp(165px, 13vw, 285px);
}

.events-more-ribbon,
.events-master-ribbon,
.events-communication-ribbon,
.abiturient-ribbon {
  position: absolute;
  right: -3%;
  top: -10%;
  width: clamp(420px, 40vw, 860px);
  opacity: .58;
  z-index: 3;
}

.events-more-head,
.events-master-head,
.events-communication-head,
.abiturient-head {
  position: absolute;
  z-index: 8;
  top: clamp(31px, 4.1svh, 58px);
  left: clamp(255px, 19vw, 455px);
}

.events-more-head h2,
.events-master-head h2,
.events-communication-head h2,
.abiturient-head h2 {
  margin: 0;
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  text-transform: uppercase;
  font-size: clamp(1.85rem, 2.55vw, 4.6rem);
  line-height: .95;
}

/* Slide 14 */
.event-block {
  position: absolute;
  z-index: 8;
  color: #fff;
  opacity: 0;
  transform: translateY(24px);
}
#slide-14.is-active .event-block {
  animation: eventBlockIn .64s ease-out calc(.12s + var(--i) * .22s) forwards;
}
@keyframes eventBlockIn {
  to { opacity: 1; transform: translateY(0); }
}

.event-pill {
  display: grid;
  place-items: center;
  min-height: clamp(36px, 4.8svh, 60px);
  padding: 0 clamp(18px, 1.6vw, 34px);
  border-radius: 9px;
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(.75rem, .94vw, 1.35rem);
  background: linear-gradient(100deg, #b77bff, #59c2f2 46%, #00dc8a);
  box-shadow: 0 12px 26px rgba(0,0,0,.18);
}

.event-block-talents {
  left: clamp(46px, 3.7vw, 92px);
  top: clamp(108px, 15svh, 170px);
  width: min(44vw, 600px);
}

.event-block-spo {
  right: clamp(72px, 9vw, 200px);
  top: clamp(108px, 15svh, 170px);
  width: min(41vw, 570px);
}

.event-block-foreign {
  left: clamp(44px, 3.5vw, 88px);
  right: clamp(52px, 4vw, 100px);
  top: clamp(280px, 38svh, 405px);
}

.event-block ul {
  list-style: none;
  margin: clamp(26px, 3.2svh, 44px) 0 0;
  padding: 0 0 0 clamp(8px, .6vw, 16px);
  font-size: clamp(1rem, 1.16vw, 1.72rem);
  line-height: 1.28;
}
.event-block li::before { content: "- "; }

.foreign-grid {
  margin-top: clamp(24px, 3svh, 42px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(150px, 14vw, 260px);
  gap: clamp(28px, 3vw, 62px);
  align-items: center;
}
.foreign-text p {
  margin: 0 0 clamp(5px, .6svh, 9px);
  font-size: clamp(.9rem, 1.05vw, 1.52rem);
  line-height: 1.23;
}
.foreign-text p::before { content: "- "; }
.ruid-app {
  width: 100%;
  max-height: clamp(180px, 25svh, 335px);
  object-fit: contain;
  justify-self: center;
}

/* Slide 15 */
.master-pill,
.asp-pill,
.communication-pill,
.metaverse-pill,
.site-pill {
  position: absolute;
  z-index: 8;
  display: grid;
  place-items: center;
  min-height: clamp(38px, 5.1svh, 64px);
  border-radius: 9px;
  background: linear-gradient(100deg, #00d99b, #68bdff 52%, #c079ff);
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(.8rem, .95vw, 1.45rem);
  padding: 0 clamp(18px, 1.6vw, 34px);
}
.master-pill {
  top: clamp(100px, 14svh, 160px);
  left: clamp(42px, 3.5vw, 84px);
  width: clamp(250px, 22vw, 450px);
}
.master-copy {
  position: absolute;
  z-index: 8;
  top: clamp(178px, 26svh, 285px);
  left: clamp(45px, 3.6vw, 90px);
  right: clamp(70px, 6vw, 140px);
  color: #fff;
  font-size: clamp(.96rem, 1.08vw, 1.68rem);
  line-height: 1.35;
}
.master-copy p { margin: 0 0 clamp(12px, 1.8svh, 24px); }
.master-copy .with-dot::before {
  content: "•";
  display: inline-block;
  margin-right: clamp(18px, 1.9vw, 38px);
}

.master-numbers {
  position: absolute;
  z-index: 8;
  left: clamp(46px, 3.8vw, 90px);
  right: clamp(74px, 8vw, 170px);
  top: clamp(345px, 49svh, 515px);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: clamp(28px, 3.6vw, 80px);
}
.master-number {
  display: flex;
  align-items: baseline;
  gap: clamp(16px, 1.5vw, 32px);
}
.master-number.left { justify-content: flex-start; }
.master-number.right { justify-content: flex-end; }
.master-number strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(4.4rem, 6.1vw, 10rem);
  line-height: .9;
  font-variant-numeric: tabular-nums;
}
.master-number.left strong {
  background: linear-gradient(90deg, #b176ff, #55c8ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.master-number.right strong {
  color: #00aeef;
}
.master-number span {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.35rem, 1.9vw, 3.2rem);
  font-weight: 900;
  color: #5bdff2;
  text-transform: lowercase;
}
.master-number.right span { color: #00aeef; text-transform: uppercase; }
.master-arrow {
  color: #3dbd48;
  font-size: clamp(3.4rem, 5vw, 8rem);
  line-height: 1;
  animation: arrowMove 1.35s ease-in-out infinite;
}
@keyframes arrowMove {
  0%,100% { transform: translateX(-8px); opacity: .75; }
  50% { transform: translateX(10px); opacity: 1; }
}

.asp-pill {
  left: clamp(34px, 3vw, 74px);
  bottom: calc(var(--nav-strip-h) + clamp(110px, 14svh, 190px));
  width: clamp(260px, 22vw, 460px);
}
.asp-note {
  position: absolute;
  z-index: 8;
  left: clamp(350px, 32vw, 670px);
  bottom: calc(var(--nav-strip-h) + clamp(120px, 15svh, 200px));
  color: #fff;
  font-size: clamp(1rem, 1.18vw, 1.8rem);
}

/* Slide 16 */
.communication-pill {
  top: clamp(100px, 14svh, 162px);
  left: clamp(35px, 3vw, 78px);
  width: clamp(300px, 26vw, 520px);
}
.communication-metrics {
  position: absolute;
  z-index: 8;
  top: clamp(190px, 26svh, 300px);
  left: clamp(64px, 5.2vw, 130px);
  right: clamp(395px, 32vw, 670px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(32px, 4vw, 84px);
  color: #fff;
}
.metric-number {
  display: flex;
  align-items: baseline;
  gap: 4px;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  line-height: .9;
  background: linear-gradient(90deg, #b176ff, #4ac4ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.metric-number span,
.metric-number strong {
  font-size: clamp(3.8rem, 5.2vw, 8.6rem);
}
.comm-metric small {
  display: block;
  margin-top: clamp(15px, 1.8svh, 28px);
  color: #fff;
  font-size: clamp(.85rem, 1vw, 1.5rem);
}
.parents-channel {
  position: absolute;
  z-index: 8;
  top: clamp(318px, 43svh, 470px);
  left: clamp(355px, 29vw, 640px);
  color: #fff;
  font-size: clamp(.9rem, 1.08vw, 1.65rem);
}
.communication-phone {
  position: absolute;
  z-index: 8;
  right: clamp(78px, 7vw, 150px);
  top: clamp(48px, 7svh, 90px);
  width: clamp(155px, 13vw, 280px);
  max-height: clamp(350px, 54svh, 620px);
  object-fit: contain;
}
.metaverse-pill {
  left: clamp(35px, 3vw, 78px);
  bottom: calc(var(--nav-strip-h) + clamp(210px, 27svh, 340px));
  width: clamp(300px, 26vw, 520px);
}
.communication-blocks {
  position: absolute;
  z-index: 8;
  left: clamp(32px, 2.8vw, 72px);
  right: clamp(270px, 22vw, 520px);
  bottom: calc(var(--nav-strip-h) + clamp(16px, 2.4svh, 42px));
  display: grid;
  gap: clamp(10px, 1.25svh, 18px);
}
.comm-block {
  min-height: clamp(36px, 4.5svh, 58px);
  display: flex;
  align-items: center;
  padding: 0 clamp(16px, 1.4vw, 30px);
  border-radius: 9px;
  color: #07161d;
  font-size: clamp(.78rem, .92vw, 1.3rem);
  background: linear-gradient(100deg, #b77bff, #62baff 48%, #00dc8a);
  opacity: 0;
  transform: translateY(-36px);
}
#slide-16.is-active .comm-block {
  animation: dropInEventBlock .55s cubic-bezier(.16,.84,.22,1.05) calc(.15s + var(--i) * .14s) forwards;
}
@keyframes dropInEventBlock {
  0% { opacity: 0; transform: translateY(-40px); filter: blur(3px); }
  70% { opacity: 1; transform: translateY(5px); filter: blur(0); }
  100% { opacity: 1; transform: translateY(0); }
}

/* Slide 17 */
.site-pill {
  top: clamp(90px, 13svh, 150px);
  left: clamp(34px, 3vw, 74px);
  width: clamp(480px, 42vw, 860px);
  justify-content: start;
  place-items: center start;
  background: linear-gradient(100deg, #b77bff, #61c2f3 46%, #00dc8a);
  color: #09191f;
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
}
.abiturient-list {
  position: absolute;
  z-index: 8;
  top: clamp(220px, 31svh, 340px);
  left: clamp(50px, 4vw, 95px);
  width: min(52vw, 880px);
  color: #fff;
  font-size: clamp(1rem, 1.2vw, 1.8rem);
  line-height: 1.28;
}
.abiturient-list p {
  margin: 0 0 clamp(24px, 3svh, 42px);
}
.abiturient-list p::before { content: "- "; }

.abiturient-phone {
  position: absolute;
  z-index: 8;
  right: clamp(310px, 26vw, 560px);
  top: clamp(110px, 14svh, 180px);
  width: clamp(210px, 17.5vw, 360px);
  max-height: clamp(450px, 65svh, 720px);
  object-fit: contain;
}
.abiturient-link {
  position: absolute;
  z-index: 9;
  right: clamp(86px, 7vw, 180px);
  top: clamp(300px, 42svh, 470px);
  color: #fff;
  text-decoration: none;
  font-style: italic;
  font-size: clamp(1.05rem, 1.28vw, 2rem);
  line-height: 1.2;
  transform-origin: left center;
  animation: abiturientPulse 1.1s ease-in-out 0.35s 4;
}
.abiturient-link span,
.abiturient-link strong {
  display: block;
  font-weight: 400;
}
@keyframes abiturientPulse {
  0%,100% { transform: scale(1); text-shadow: none; }
  50% { transform: scale(1.1); text-shadow: 0 0 18px rgba(90, 220, 255, .65); }
}

/* 1366 landscape tuning */
@media (max-width: 1366px) and (orientation: landscape) {
  .events-more-head,
  .events-master-head,
  .events-communication-head,
  .abiturient-head { left: 230px; }

  .event-block ul { font-size: .9rem; }
  .foreign-text p { font-size: .78rem; }
  .ruid-app { max-height: 190px; }

  .master-copy { top: 158px; font-size: .9rem; }
  .master-numbers { top: 305px; }
  .master-number strong { font-size: 4.8rem; }
  .asp-note { left: 330px; font-size: .9rem; }

  .communication-metrics { top: 165px; right: 335px; }
  .metric-number span,
  .metric-number strong { font-size: 4.2rem; }
  .parents-channel { top: 280px; left: 340px; }
  .communication-phone { width: 185px; }
  .metaverse-pill { bottom: calc(var(--nav-strip-h) + 185px); }
  .communication-blocks { right: 250px; gap: 10px; }
  .comm-block { font-size: .74rem; }

  .abiturient-list { top: 195px; font-size: .9rem; }
  .abiturient-phone { right: 310px; width: 245px; }
  .abiturient-link { top: 280px; right: 85px; }
}

/* Tablet / small laptop landscape */
@media (max-width: 1024px) and (orientation: landscape) {
  .events-more-logo,
  .events-master-logo,
  .events-communication-logo,
  .abiturient-logo { width: 150px; }

  .events-more-head,
  .events-master-head,
  .events-communication-head,
  .abiturient-head { left: 190px; }
  .events-more-head h2,
  .events-master-head h2,
  .events-communication-head h2,
  .abiturient-head h2 { font-size: 1.5rem; }

  .event-block-talents,
  .event-block-spo { top: 86px; }
  .event-block ul { font-size: .66rem; margin-top: 18px; }
  .event-block-foreign { top: 225px; }
  .foreign-grid { grid-template-columns: 1fr 100px; gap: 16px; }
  .foreign-text p { font-size: .55rem; }

  .master-pill, .communication-pill, .metaverse-pill, .site-pill, .asp-pill { min-height: 32px; font-size: .58rem; }
  .master-copy { top: 140px; font-size: .62rem; }
  .master-numbers { top: 260px; gap: 20px; }
  .master-number strong { font-size: 3.4rem; }
  .master-number span { font-size: 1rem; }
  .asp-note { left: 260px; font-size: .62rem; }

  .communication-metrics { top: 145px; left: 45px; right: 270px; gap: 20px; }
  .metric-number span,
  .metric-number strong { font-size: 3rem; }
  .comm-metric small { font-size: .58rem; }
  .parents-channel { top: 235px; left: 260px; font-size: .62rem; }
  .communication-phone { width: 145px; right: 60px; }
  .metaverse-pill { bottom: calc(var(--nav-strip-h) + 150px); }
  .communication-blocks { right: 210px; gap: 7px; }
  .comm-block { min-height: 28px; font-size: .52rem; }

  .site-pill { width: 430px; }
  .abiturient-list { top: 175px; font-size: .66rem; width: 52vw; }
  .abiturient-phone { right: 245px; width: 170px; }
  .abiturient-link { top: 240px; right: 55px; font-size: .72rem; }
}


/* ===== Slides 14-17 patch v2 ===== */

/* Generic phone mock */
.phone-mock {
  position: absolute;
  z-index: 8;
}
.phone-screen-wrap {
  position: absolute;
  overflow: hidden;
  border-radius: clamp(22px, 2.2vw, 34px);
  background: #050709;
}
.phone-screen {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}
.phone-frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: screen;
  pointer-events: none;
}

/* Slide 14 */
#slide-14 .event-pill {
  font-size: calc(clamp(.75rem, .94vw, 1.35rem) + 1px);
}
#slide-14 .event-block ul {
  font-size: calc(clamp(1rem, 1.16vw, 1.72rem) + 1px);
}
#slide-14 .foreign-text p {
  font-size: calc(clamp(.9rem, 1.05vw, 1.52rem) + 1px);
}
#slide-14 .event-block-foreign > .event-pill {
  width: clamp(250px, 22vw, 450px);
}

/* Slide 15 */
#slide-15 .master-copy {
  font-size: clamp(1rem, 1.14vw, 1.74rem);
}
#slide-15 .master-copy p:nth-of-type(1),
#slide-15 .master-copy p:nth-of-type(3) {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(1.16rem, 1.3vw, 2rem);
  margin-bottom: clamp(10px, 1.4svh, 18px);
}
#slide-15 .master-copy p:nth-of-type(2),
#slide-15 .master-copy p:nth-of-type(4) {
  font-size: clamp(1rem, 1.14vw, 1.78rem);
}
#slide-15 .master-copy .with-dot::before {
  margin-right: clamp(14px, 1.2vw, 26px);
}
#slide-15 .master-numbers {
  grid-template-columns: minmax(0,1.1fr) auto minmax(0,.82fr);
  gap: clamp(10px, 1.5vw, 26px);
  top: clamp(340px, 48.5svh, 505px);
}
#slide-15 .master-number.left span {
  font-size: clamp(1.8rem, 2.3vw, 3.7rem);
}
#slide-15 .master-number.right {
  justify-content: flex-start;
  margin-left: -14px;
}
#slide-15 .master-number.right strong {
  font-size: clamp(4.2rem, 5.7vw, 9rem);
}
#slide-15 .master-arrow {
  margin: 0 -6px;
}

/* Slide 16 */
#slide-16 .parents-channel {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-weight: 900;
  font-size: clamp(1.06rem, 1.28vw, 1.96rem);
}
#slide-16 .communication-phone-shell {
  right: clamp(70px, 6.2vw, 138px);
  top: clamp(38px, 5.6svh, 78px);
  width: clamp(210px, 16.8vw, 312px);
  height: auto;
  aspect-ratio: 346 / 696;
}
#slide-16 .comm-screen-wrap {
  left: 8.2%;
  right: 7.6%;
  top: 3.4%;
  bottom: 8.1%;
}
#slide-16 .communication-blocks {
  left: clamp(32px, 2.8vw, 72px);
  width: min(48vw, 690px);
  right: auto;
}
#slide-16 .comm-block {
  width: 100%;
}

/* Slide 17 */
#slide-17 .abiturient-phone-shell {
  right: clamp(280px, 23vw, 500px);
  top: clamp(98px, 13svh, 165px);
  width: clamp(220px, 17.8vw, 330px);
  aspect-ratio: 346 / 696;
}
#slide-17 .abiturient-screen-wrap {
  left: 8.2%;
  right: 7.6%;
  top: 3.4%;
  bottom: 8.1%;
}
#slide-17 .abiturient-link {
  right: clamp(60px, 5.6vw, 150px);
  top: clamp(340px, 46svh, 500px);
  padding: clamp(14px, 1.2vw, 22px) clamp(20px, 1.8vw, 34px);
  border-radius: 16px;
  background: rgba(12, 36, 51, 0.78);
  border: 1px solid rgba(116, 234, 255, 0.26);
  box-shadow: 0 12px 26px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.03);
  font-style: normal;
  font-size: clamp(1.12rem, 1.32vw, 2rem);
  line-height: 1.12;
}
#slide-17 .abiturient-link strong {
  font-weight: 700;
}
#slide-17 .abiturient-link span {
  display: none;
}
@keyframes abiturientPulse {
  0%,100% { transform: scale(1); text-shadow: none; }
  50% { transform: scale(1.08); text-shadow: 0 0 18px rgba(90, 220, 255, .65); }
}

/* 1366 landscape tuning */
@media (max-width: 1366px) and (orientation: landscape) {
  #slide-14 .event-block ul { font-size: calc(.9rem + 1px); }
  #slide-14 .foreign-text p { font-size: calc(.78rem + 1px); }

  #slide-15 .master-copy { top: 154px; font-size: 1rem; }
  #slide-15 .master-copy p:nth-of-type(1),
  #slide-15 .master-copy p:nth-of-type(3) { font-size: 1.06rem; }
  #slide-15 .master-copy p:nth-of-type(2),
  #slide-15 .master-copy p:nth-of-type(4) { font-size: .96rem; }
  #slide-15 .master-numbers { top: 300px; gap: 14px; }
  #slide-15 .master-number.left span { font-size: 2rem; }
  #slide-15 .master-number strong { font-size: 4.6rem; }
  #slide-15 .master-number.right strong { font-size: 4.9rem; }

  #slide-16 .parents-channel { top: 276px; left: 340px; font-size: 1rem; }
  #slide-16 .communication-phone-shell { width: 220px; }
  #slide-16 .communication-blocks { width: min(47vw, 620px); }
  #slide-16 .comm-block { font-size: .74rem; }

  #slide-17 .abiturient-phone-shell { width: 255px; right: 280px; }
  #slide-17 .abiturient-link { top: 285px; right: 70px; font-size: .96rem; }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-14 .event-block ul { font-size: calc(.66rem + 1px); }
  #slide-14 .foreign-text p { font-size: calc(.55rem + 1px); }

  #slide-15 .master-copy { top: 136px; font-size: .68rem; }
  #slide-15 .master-copy p:nth-of-type(1),
  #slide-15 .master-copy p:nth-of-type(3) { font-size: .78rem; }
  #slide-15 .master-copy p:nth-of-type(2),
  #slide-15 .master-copy p:nth-of-type(4) { font-size: .68rem; }
  #slide-15 .master-numbers { top: 250px; gap: 10px; }
  #slide-15 .master-number.left span { font-size: 1.2rem; }
  #slide-15 .master-number strong { font-size: 3.2rem; }
  #slide-15 .master-number.right strong { font-size: 3.4rem; }

  #slide-16 .parents-channel { top: 230px; left: 255px; font-size: .72rem; }
  #slide-16 .communication-phone-shell { width: 160px; right: 52px; }
  #slide-16 .communication-blocks { width: min(49vw, 470px); }

  #slide-17 .abiturient-phone-shell { width: 180px; right: 225px; }
  #slide-17 .abiturient-link { top: 238px; right: 40px; font-size: .72rem; padding: 10px 14px; }
}


/* ===== Requested patch: slide 14 blocks, slide 15 arrow/fonts, slide 16 blocks ===== */

/* Slide 14: верхние плашки такой же ширины, как 05. «ДАЛЬНЕЕ ЗАРУБЕЖЬЕ» */
#slide-14 .event-block-talents > .event-pill,
#slide-14 .event-block-spo > .event-pill,
#slide-14 .event-block-foreign > .event-pill {
  width: clamp(250px, 22vw, 450px) !important;
  box-sizing: border-box !important;
}

/* Slide 15: стрелка левее, 1255/МЕСТ по шрифту как 937/план выпуска */
#slide-15 .master-numbers {
  grid-template-columns: minmax(0, 1.04fr) auto minmax(0, .96fr) !important;
  gap: clamp(0px, .35vw, 10px) !important;
}

#slide-15 .master-arrow {
  justify-self: center !important;
  margin-left: clamp(-96px, -5vw, -52px) !important;
  margin-right: clamp(-24px, -1.4vw, -10px) !important;
}

#slide-15 .master-number.right {
  justify-content: flex-start !important;
  margin-left: clamp(-54px, -3vw, -28px) !important;
}

#slide-15 .master-number.right strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(4.4rem, 6.1vw, 10rem) !important;
  line-height: .9 !important;
  font-variant-numeric: tabular-nums !important;
  background: linear-gradient(90deg, #b176ff, #55c8ff) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

#slide-15 .master-number.right span {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-size: clamp(1.8rem, 2.3vw, 3.7rem) !important;
  font-weight: 900 !important;
  color: #5bdff2 !important;
  text-transform: uppercase !important;
}

/* Slide 16: цветные блоки +10% по ширине от предыдущей версии */
#slide-16 .communication-blocks {
  width: min(52.8vw, 760px) !important;
  right: auto !important;
}

#slide-16 .comm-block {
  width: 100% !important;
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-15 .master-arrow {
    margin-left: -62px !important;
    margin-right: -10px !important;
  }

  #slide-15 .master-number.right {
    margin-left: -32px !important;
  }

  #slide-15 .master-number.right strong {
    font-size: 4.8rem !important;
  }

  #slide-15 .master-number.right span {
    font-size: 2rem !important;
  }

  #slide-16 .communication-blocks {
    width: min(51.7vw, 682px) !important;
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-15 .master-arrow {
    margin-left: -38px !important;
    margin-right: -6px !important;
  }

  #slide-15 .master-number.right {
    margin-left: -20px !important;
  }

  #slide-15 .master-number.right strong {
    font-size: 3.2rem !important;
  }

  #slide-15 .master-number.right span {
    font-size: 1.2rem !important;
  }

  #slide-16 .communication-blocks {
    width: min(53.9vw, 517px) !important;
  }
}


/* ===== Slide 18: Позиционирование ===== */
#slide-18.slide-positioning-extended {
  position: relative;
  overflow: hidden;
  background: #041421;
}

#slide-18 .positioning-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#slide-18 .positioning-brand {
  position: absolute;
  left: clamp(24px, 2.55vw, 46px);
  top: clamp(18px, 2.3vh, 30px);
  width: clamp(170px, 18vw, 255px);
  height: auto;
  z-index: 3;
}

#slide-18 .positioning-head {
  position: absolute;
  left: clamp(290px, 21vw, 390px);
  top: clamp(24px, 3vh, 34px);
  z-index: 3;
}

#slide-18 .positioning-head h2 {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(2.05rem, 2.85vw, 3.1rem);
  line-height: .95;
  color: #fff;
  letter-spacing: -.02em;
}

#slide-18 .positioning-pill {
  position: absolute;
  left: 56%;
  top: clamp(20px, 2.6vh, 34px);
  transform: translateX(-50%);
  z-index: 3;
  min-width: clamp(255px, 20vw, 315px);
  padding: .82em 1.85em;
  border-radius: 12px;
  background: linear-gradient(90deg, #06dfa2 0%, #64b8ff 50%, #d978fb 100%);
  color: #fff;
  font-family: Verdana, sans-serif;
  font-size: clamp(.98rem, 1.02vw, 1.08rem);
  font-weight: 700;
  text-align: center;
  box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
}

#slide-18 .positioning-wordart {
  position: absolute;
  right: clamp(18px, 1.6vw, 34px);
  top: clamp(-4px, .5vh, 8px);
  width: clamp(245px, 22vw, 330px);
  height: auto;
  z-index: 2;
}

#slide-18 .positioning-person {
  position: absolute;
  left: 50%;
  bottom: clamp(-8px, -1.2vh, 0px);
  transform: translateX(-50%);
  width: clamp(290px, 30vw, 430px);
  height: auto;
  z-index: 4;
  filter: drop-shadow(0 26px 34px rgba(0,0,0,.28));
  opacity: 0;
}

#slide-18 .positioning-item {
  position: absolute;
  z-index: 5;
  display: grid;
  align-items: center;
  gap: clamp(10px, .8vw, 16px);
  opacity: 0;
}

#slide-18 .positioning-item.left {
  grid-template-columns: clamp(36px, 2.7vw, 50px) minmax(0, 1fr);
  text-align: left;
}

#slide-18 .positioning-item.right {
  grid-template-columns: minmax(0, 1fr) clamp(36px, 2.7vw, 50px);
  text-align: right;
}

#slide-18 .positioning-item p {
  margin: 0;
  color: #fff;
  font-family: "Aptos", Verdana, sans-serif;
  font-size: clamp(1.03rem, 1.12vw, 1.26rem);
  line-height: 1.18;
  text-wrap: balance;
}

#slide-18 .positioning-item span {
  font-size: .92em;
}

#slide-18 .positioning-arrow {
  width: clamp(34px, 2.8vw, 48px);
  height: auto;
  filter: drop-shadow(0 3px 5px rgba(0,0,0,.28));
}
#slide-18 .positioning-item.right .positioning-arrow {
  transform: scaleX(-1);
}


#slide-18 .pos-l1 { left: 2.3%; top: 16.7%; width: 38.3%; }
#slide-18 .pos-l2 { left: 2.2%; top: 29.3%; width: 39.8%; }
#slide-18 .pos-l3 { left: 2.2%; top: 44.0%; width: 40.9%; }
#slide-18 .pos-l4 { left: 2.2%; top: 56.2%; width: 38.0%; }
#slide-18 .pos-l5 { left: 2.2%; top: 69.2%; width: 37.8%; }
#slide-18 .pos-l6 { left: 2.0%; top: 78.0%; width: 40.0%; }

#slide-18 .pos-r1 { right: 1.1%; top: 22.2%; width: 39.4%; }
#slide-18 .pos-r2 { right: 1.1%; top: 42.0%; width: 31.7%; }
#slide-18 .pos-r3 { right: 1.1%; top: 53.0%; width: 32.8%; }
#slide-18 .pos-r4 { right: 1.1%; top: 66.0%; width: 33.8%; }

#slide-18.is-active .positioning-person {
  animation: positioning-person-in .56s cubic-bezier(.22,.85,.27,1) forwards;
}

#slide-18.is-active .positioning-item {
  animation: positioning-drop-in .52s cubic-bezier(.23,.89,.31,1) forwards;
  animation-delay: var(--delay, .75s);
}

@keyframes positioning-person-in {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(26px) scale(.93);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0) scale(1);
  }
}

@keyframes positioning-drop-in {
  from {
    opacity: 0;
    transform: translateY(-34px) scale(.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-18 .positioning-pill {
    min-width: 235px;
    padding: .76em 1.55em;
  }

  #slide-18 .positioning-item p {
    font-size: .98rem;
    line-height: 1.15;
  }

  #slide-18 .pos-l2, #slide-18 .pos-r1 {
    width: 40.8%;
  }

  #slide-18 .pos-r2, #slide-18 .pos-r3, #slide-18 .pos-r4 {
    width: 33.5%;
  }
}

@media (max-width: 1180px) and (orientation: landscape) {
  #slide-18 .positioning-brand {
    width: 150px;
  }

  #slide-18 .positioning-head {
    left: 210px;
  }

  #slide-18 .positioning-head h2 {
    font-size: 1.9rem;
  }

  #slide-18 .positioning-pill {
    font-size: .9rem;
    min-width: 220px;
  }

  #slide-18 .positioning-wordart {
    width: 220px;
  }

  #slide-18 .positioning-person {
    width: 310px;
  }

  #slide-18 .positioning-item p {
    font-size: .9rem;
  }

  #slide-18 .positioning-arrow {
    width: 32px;
  }
}


/* ===== Small patch: slide 15 arrow + slide 18 image32 spacing ===== */

/* slide-15: стрелку сильно левее */
#slide-15 .master-arrow {
  margin-left: clamp(-190px, -11vw, -125px) !important;
  margin-right: clamp(20px, 1.5vw, 36px) !important;
}

/* slide-18: image32 выше, правые тексты начинаются ниже */
#slide-18 .positioning-wordart {
  top: clamp(-18px, -1.4vh, -6px) !important;
}

#slide-18 .pos-r1 { top: 25.5% !important; }
#slide-18 .pos-r2 { top: 45.3% !important; }
#slide-18 .pos-r3 { top: 56.3% !important; }
#slide-18 .pos-r4 { top: 69.3% !important; }

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-15 .master-arrow {
    margin-left: -140px !important;
    margin-right: 24px !important;
  }

  #slide-18 .positioning-wordart {
    top: -14px !important;
  }

  #slide-18 .pos-r1 { top: 25.8% !important; }
  #slide-18 .pos-r2 { top: 45.5% !important; }
  #slide-18 .pos-r3 { top: 56.5% !important; }
  #slide-18 .pos-r4 { top: 69.5% !important; }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-15 .master-arrow {
    margin-left: -90px !important;
    margin-right: 16px !important;
  }

  #slide-18 .positioning-wordart {
    top: -10px !important;
  }

  #slide-18 .pos-r1 { top: 25% !important; }
  #slide-18 .pos-r2 { top: 44.8% !important; }
  #slide-18 .pos-r3 { top: 56% !important; }
  #slide-18 .pos-r4 { top: 68.5% !important; }
}


/* ===== Slides 19-21: final deck continuation ===== */
#slide-19, #slide-20, #slide-21 {
  font-family: "Aptos Display", "Aptos", Verdana, sans-serif;
}

#slide-19 .bg,
#slide-20 .bg,
#slide-21 .bg {
  opacity: .58;
}

/* Slide 19 — размещение ЕПК */
#slide-19 .epk-logo-main,
#slide-20 .risks-logo,
#slide-21 .tasks-logo {
  top: clamp(24px, 3.7svh, 48px);
  left: clamp(40px, 3.6vw, 78px);
  width: clamp(165px, 13vw, 285px);
}

#slide-19 .epk-ribbon,
#slide-20 .risks-ribbon-top,
#slide-21 .tasks-ribbon-top {
  position: absolute;
  z-index: 3;
  right: -5%;
  top: -10%;
  width: clamp(420px, 39vw, 820px);
  opacity: .58;
}

#slide-19 .epk-head,
#slide-20 .risks-head,
#slide-21 .tasks-head {
  position: absolute;
  z-index: 8;
  top: clamp(28px, 4svh, 54px);
  left: clamp(250px, 19vw, 455px);
}

#slide-19 .epk-head h2,
#slide-20 .risks-head h2,
#slide-21 .tasks-head h2 {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  color: #fff;
  font-weight: 900;
  font-size: clamp(1.75rem, 2.45vw, 4.4rem);
  line-height: .98;
  text-transform: uppercase;
}

#slide-19 .epk-zone-title {
  position: absolute;
  z-index: 8;
  left: clamp(56px, 4.3vw, 104px);
  top: clamp(103px, 13.8svh, 154px);
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(.92rem, 1.02vw, 1.42rem);
  font-weight: 900;
  text-transform: uppercase;
}

#slide-19 .epk-logo-strip {
  position: absolute;
  z-index: 8;
  left: clamp(98px, 8vw, 170px);
  right: clamp(78px, 7vw, 150px);
  border: 1px solid rgba(60, 151, 73, .42);
  background: rgba(5, 29, 33, .12);
  display: grid;
  align-items: center;
}

#slide-19 .epk-logo-strip-top {
  top: clamp(154px, 22svh, 245px);
  height: clamp(54px, 7svh, 88px);
  grid-template-columns: 1fr 1.45fr 1.45fr 1.35fr 1.28fr;
  gap: clamp(24px, 3vw, 66px);
  padding: 0 clamp(26px, 2.8vw, 60px);
}

#slide-19 .epk-logo-strip-bottom {
  top: clamp(405px, 58svh, 555px);
  height: clamp(58px, 7.5svh, 92px);
  grid-template-columns: .86fr 1.15fr 1.45fr 1.45fr 1.35fr 1.18fr;
  gap: clamp(18px, 2.2vw, 48px);
  padding: 0 clamp(14px, 1.8vw, 42px);
}

#slide-19 .epk-school-logo {
  max-width: 100%;
  max-height: clamp(34px, 5.2svh, 70px);
  object-fit: contain;
  justify-self: center;
  opacity: 0;
}

#slide-19 .epk-logo-tall {
  max-height: clamp(42px, 6svh, 78px);
}

#slide-19.is-active .epk-school-logo {
  animation: epkLogoIn .5s ease-out calc(.18s + var(--i) * .09s) forwards;
}

@keyframes epkLogoIn {
  from { opacity: 0; transform: translateY(16px) scale(.96); filter: blur(2px); }
  to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}

#slide-19 .epk-screen-label {
  position: absolute;
  z-index: 8;
  left: clamp(47px, 3.9vw, 86px);
  top: clamp(205px, 31svh, 290px);
  width: clamp(38px, 3vw, 58px);
  height: clamp(180px, 28svh, 275px);
  border: 1px solid rgba(60, 151, 73, .32);
  display: grid;
  place-items: center;
}

#slide-19 .epk-screen-label span {
  transform: rotate(-90deg);
  color: #fff;
  font-size: clamp(1rem, 1.18vw, 1.65rem);
  text-transform: uppercase;
}

#slide-19 .epk-capacity {
  position: absolute;
  z-index: 8;
  left: clamp(128px, 10.6vw, 230px);
  top: clamp(265px, 41svh, 385px);
  display: flex;
  align-items: baseline;
  gap: clamp(12px, 1vw, 22px);
}

#slide-19 .epk-capacity strong {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(4.4rem, 6.2vw, 10rem);
  line-height: .85;
  background: linear-gradient(90deg, #9c74ff, #62c7ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

#slide-19 .epk-capacity span {
  color: #5ef0e0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.35rem, 1.75vw, 3rem);
  font-weight: 900;
}

#slide-19 .epk-soft-zone {
  position: absolute;
  z-index: 8;
  left: clamp(315px, 27vw, 560px);
  top: clamp(285px, 43svh, 390px);
  width: min(58vw, 950px);
  height: clamp(38px, 5.3svh, 66px);
  border: 2px solid rgba(52, 185, 81, .7);
  display: grid;
  place-items: center;
  color: #fff;
  font-size: clamp(.86rem, 1vw, 1.45rem);
  text-transform: uppercase;
}

#slide-19 .epk-arrow {
  position: absolute;
  z-index: 8;
  right: clamp(18px, 1.8vw, 46px);
  top: clamp(246px, 37.5svh, 350px);
  color: #00dd8a;
  font-size: clamp(5rem, 7.5vw, 12rem);
  line-height: 1;
  animation: epkArrowPulse 1.35s ease-in-out infinite;
}

@keyframes epkArrowPulse {
  0%, 100% { transform: translateX(0); opacity: .8; }
  50% { transform: translateX(-16px); opacity: 1; }
}

#slide-19 .epk-aspirantura {
  justify-self: center;
  color: #fff;
  font-size: clamp(.86rem, 1vw, 1.42rem);
  text-transform: uppercase;
}

#slide-19 .epk-footer-zones {
  position: absolute;
  z-index: 8;
  left: clamp(78px, 6.4vw, 150px);
  right: clamp(78px, 6.4vw, 150px);
  bottom: calc(var(--nav-strip-h) + clamp(30px, 4.5svh, 78px));
  display: grid;
  grid-template-columns: 1fr 1.35fr 1.2fr;
  gap: clamp(34px, 5vw, 100px);
  color: #fff;
}

#slide-19 .epk-footer-zones h3 {
  margin: 0 0 clamp(18px, 2.2svh, 32px);
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(.85rem, .98vw, 1.32rem);
  text-transform: uppercase;
}

#slide-19 .epk-footer-zones p {
  margin: 0;
  font-size: clamp(.86rem, .98vw, 1.38rem);
  line-height: 1.25;
}

/* Slide 20 — риски */
#slide-20 .risks-facade {
  position: absolute;
  z-index: 7;
  top: clamp(92px, 13.5svh, 165px);
  right: clamp(130px, 11vw, 260px);
  width: clamp(390px, 31vw, 710px);
  opacity: .92;
}

#slide-20 .risks-ribbon-bottom {
  position: absolute;
  z-index: 3;
  left: -3%;
  bottom: 0;
  width: clamp(260px, 28vw, 570px);
  opacity: .55;
}

#slide-20 .risks-left {
  position: absolute;
  z-index: 8;
  left: clamp(38px, 3vw, 74px);
  top: clamp(150px, 22svh, 250px);
  width: min(43vw, 690px);
}

#slide-20 .risks-left h3 {
  margin: 0 0 clamp(35px, 6svh, 70px);
  color: #ff1e1e;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.55rem, 2.25vw, 4rem);
  font-weight: 900;
  text-transform: uppercase;
}

#slide-20 .risks-left ul,
#slide-20 .risks-right ul,
#slide-21 .tasks-copy ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

#slide-20 .risks-left li,
#slide-20 .risks-right li {
  color: #fff;
  font-size: clamp(.98rem, 1.18vw, 1.75rem);
  line-height: 1.42;
  margin: 0 0 clamp(16px, 2.2svh, 32px);
}

#slide-20 .risks-left li::before,
#slide-20 .risks-right li::before,
#slide-21 .tasks-copy li::before {
  content: "- ";
}

#slide-20 .risks-brace {
  position: absolute;
  z-index: 8;
  left: clamp(560px, 48vw, 930px);
  top: clamp(175px, 28svh, 280px);
  width: clamp(310px, 27svh, 520px);
  height: clamp(42px, 3.6vw, 76px);
  background: url("assets/ppt-media/brace-figure.png") center / 100% 100% no-repeat;
  transform: rotate(90deg) scaleX(-1);
  transform-origin: center;
  opacity: .9;
}

#slide-20 .risks-right {
  position: absolute;
  z-index: 8;
  right: clamp(54px, 4.6vw, 110px);
  top: clamp(205px, 29svh, 320px);
  width: min(45vw, 700px);
}

#slide-20 .risks-right li {
  margin-bottom: clamp(10px, 1.5svh, 22px);
  line-height: 1.34;
}

/* Slide 21 — задачи */
#slide-21 .tasks-ribbon-left {
  position: absolute;
  z-index: 3;
  left: -10%;
  bottom: -28%;
  width: clamp(300px, 34vw, 680px);
  opacity: .55;
}

#slide-21 .tasks-ribbon-bottom {
  position: absolute;
  z-index: 3;
  left: 36%;
  bottom: -40%;
  width: clamp(310px, 36vw, 720px);
  opacity: .55;
}

#slide-21 .tasks-pill-list {
  position: absolute;
  z-index: 8;
  left: clamp(50px, 4vw, 95px);
  top: clamp(230px, 36svh, 355px);
  display: grid;
  gap: clamp(14px, 1.8svh, 28px);
  width: clamp(320px, 25vw, 510px);
}

#slide-21 .task-pill {
  min-height: clamp(38px, 5.1svh, 64px);
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: linear-gradient(100deg, #b77bff, #62baff 48%, #00dc8a);
  color: #fff;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(.8rem, 1vw, 1.42rem);
  font-weight: 900;
  text-transform: uppercase;
}

#slide-21.is-active .task-pill {
  animation: taskPillIn .5s ease-out calc(.12s + var(--i) * .13s) both;
}

@keyframes taskPillIn {
  from { opacity: 0; transform: translateX(-30px); }
  to { opacity: 1; transform: translateX(0); }
}

#slide-21 .tasks-copy {
  position: absolute;
  z-index: 8;
  left: clamp(390px, 36vw, 690px);
  top: clamp(248px, 39svh, 382px);
  right: clamp(68px, 6vw, 130px);
  color: #fff;
}

#slide-21 .tasks-copy li {
  font-size: clamp(1rem, 1.15vw, 1.72rem);
  line-height: 1.4;
  margin-bottom: clamp(14px, 1.8svh, 28px);
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-19 .epk-logo-strip-top { gap: 34px; }
  #slide-19 .epk-logo-strip-bottom { gap: 24px; }
  #slide-19 .epk-capacity strong { font-size: 4.6rem; }
  #slide-19 .epk-footer-zones { bottom: calc(var(--nav-strip-h) + 22px); }
  #slide-19 .epk-footer-zones p, #slide-19 .epk-footer-zones h3 { font-size: .8rem; }

  #slide-20 .risks-left li, #slide-20 .risks-right li { font-size: .9rem; }
  #slide-20 .risks-brace { left: 47vw; top: 200px; width: 320px; }
  #slide-20 .risks-right { top: 175px; }

  #slide-21 .tasks-copy li { font-size: .9rem; }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-19 .epk-head, #slide-20 .risks-head, #slide-21 .tasks-head { left: 210px; }
  #slide-19 .epk-head h2, #slide-20 .risks-head h2, #slide-21 .tasks-head h2 { font-size: 1.45rem; }
  #slide-19 .epk-logo-main, #slide-20 .risks-logo, #slide-21 .tasks-logo { width: 145px; }
  #slide-19 .epk-logo-strip-top { top: 125px; height: 52px; gap: 18px; }
  #slide-19 .epk-logo-strip-bottom { top: 320px; height: 54px; gap: 12px; }
  #slide-19 .epk-capacity { top: 220px; left: 105px; }
  #slide-19 .epk-capacity strong { font-size: 3.3rem; }
  #slide-19 .epk-soft-zone { top: 228px; left: 270px; height: 36px; }
  #slide-19 .epk-screen-label { top: 180px; height: 150px; }
  #slide-19 .epk-footer-zones { bottom: calc(var(--nav-strip-h) + 18px); gap: 24px; }
  #slide-19 .epk-footer-zones p, #slide-19 .epk-footer-zones h3 { font-size: .55rem; }

  #slide-20 .risks-left { top: 115px; }
  #slide-20 .risks-left h3 { font-size: 1.2rem; margin-bottom: 28px; }
  #slide-20 .risks-left li, #slide-20 .risks-right li { font-size: .62rem; }
  #slide-20 .risks-brace { left: 47vw; top: 150px; width: 250px; height: 48px; }
  #slide-20 .risks-right { top: 150px; }

  #slide-21 .tasks-pill-list { top: 180px; width: 255px; }
  #slide-21 .tasks-copy { left: 330px; top: 205px; }
  #slide-21 .tasks-copy li { font-size: .62rem; }
}


#slide-20 .risks-plan-bracket {
  position: absolute;
  z-index: 8;
  left: clamp(532px, 46.3vw, 900px);
  top: clamp(168px, 25.5svh, 250px);
  width: clamp(18px, 1.4vw, 28px);
  height: clamp(430px, 48svh, 560px);
  opacity: .94;
  border-left: 2px solid rgba(0,180,255,.72);
  border-top: 2px solid rgba(0,180,255,.72);
  border-bottom: 2px solid rgba(0,180,255,.72);
  border-radius: 8px 0 0 8px;
}

@media (max-width: 1366px) {
  #slide-20 .risks-plan-bracket {
    left: 46.8vw;
    top: 160px;
    height: 360px;
  }
}


/* ===== Slide 22: Готовность – 2026 ===== */
.slide-readiness-2026 .bg,
.slide-readiness-2026 .bg-vignette {
  opacity: 1;
}

.readiness-logo {
  top: clamp(30px, 4.15svh, 48px);
  left: clamp(28px, 2.7vw, 54px);
  width: clamp(176px, 15vw, 250px);
}

.readiness-ribbon {
  position: absolute;
  right: 0;
  top: 0;
  width: clamp(320px, 30vw, 520px);
  opacity: .9;
  z-index: 1;
  pointer-events: none;
}

.readiness-head {
  position: absolute;
  top: clamp(24px, 3.1svh, 42px);
  left: clamp(236px, 22vw, 420px);
  z-index: 6;
}

.readiness-head h2 {
  margin: 0;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(2.05rem, 2.9vw, 3.45rem);
  line-height: .95;
  letter-spacing: -.02em;
}

.readiness-bars {
  position: absolute;
  left: clamp(34px, 3vw, 64px);
  top: clamp(128px, 21.5svh, 190px);
  width: clamp(400px, 39vw, 620px);
  display: grid;
  gap: clamp(10px, 1.15svh, 16px);
  z-index: 7;
}

.readiness-bar-card {
  position: relative;
  height: clamp(34px, 5svh, 54px);
  border-radius: clamp(10px, 1.1vw, 18px);
  overflow: hidden;
  background: rgba(255,255,255,.09);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 12px 24px rgba(0,0,0,.14);
}

.readiness-bar-track {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(116, 84, 214, .18), rgba(63, 215, 180, .18));
}

.readiness-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, #c77aff 0%, #74b8ff 50%, #12e1a4 100%);
  box-shadow: 0 0 24px rgba(68, 220, 178, .18);
}

.readiness-bar-copy {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 0 clamp(14px, 1.5vw, 22px);
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(.84rem, .98vw, 1.18rem);
  line-height: 1;
  letter-spacing: .01em;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 1px 3px rgba(0,0,0,.18);
}

.readiness-bar-label {
  max-width: 82%;
}

.readiness-bar-value {
  flex: 0 0 auto;
  min-width: 4ch;
  text-align: right;
}

.readiness-total {
  position: absolute;
  left: clamp(28px, 2.6vw, 52px);
  bottom: clamp(58px, 9.6svh, 110px);
  width: clamp(640px, 50vw, 820px);
  z-index: 8;
}

.readiness-total-card {
  position: relative;
  min-height: clamp(84px, 10.2svh, 128px);
  border-radius: clamp(22px, 1.8vw, 30px);
  overflow: hidden;
  background: rgba(255,255,255,.09);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.16);
}

.readiness-total-track {
  background: linear-gradient(90deg, rgba(36, 216, 200, .18), rgba(208, 117, 255, .16));
}

.readiness-total-fill {
  box-shadow: 0 0 28px rgba(68, 220, 178, .2);
}

.readiness-total-copy {
  position: relative;
  z-index: 1;
  min-height: inherit;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: clamp(18px, 2vw, 30px);
  padding: clamp(16px, 2.1svh, 24px) clamp(18px, 1.8vw, 28px);
}

.readiness-total-pill {
  min-width: clamp(320px, 32vw, 520px);
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.55rem, 2.18vw, 2.65rem);
  line-height: .95;
  text-shadow: 0 2px 6px rgba(0,0,0,.18);
}

.readiness-total-value {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(4.4rem, 5.9vw, 7.4rem);
  line-height: .82;
  letter-spacing: -.05em;
  color: #6fe1ff;
  text-shadow: 0 6px 18px rgba(0,0,0,.18);
  margin-bottom: clamp(2px, .4svh, 8px);
  flex: 0 0 auto;
}

.readiness-scene {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
}

.readiness-building-accent {
  position: absolute;
  right: clamp(-34px, -1vw, 0px);
  bottom: clamp(60px, 8.8svh, 112px);
  width: clamp(300px, 31vw, 600px);
  height: clamp(190px, 25svh, 400px);
  background: #49bd46;
  transform: rotate(-37deg);
  transform-origin: center center;
  clip-path: polygon(18% 0, 100% 18%, 82% 100%, 0 82%);
  z-index: 1;
}

.readiness-building {
  position: absolute;
  right: clamp(-88px, -3.2vw, -10px);
  bottom: 0;
  width: clamp(520px, 45vw, 900px);
  z-index: 3;
  filter: drop-shadow(0 20px 32px rgba(0,0,0,.24));
  opacity: 0;
  transform: translate3d(180px, 140px, 0) scale(.94);
}

.readiness-balloon-launcher {
  position: absolute;
  right: clamp(248px, 23vw, 390px);
  bottom: clamp(206px, 21.5svh, 276px);
  width: clamp(195px, 18vw, 335px);
  z-index: 2;
  opacity: 0;
  transform: translate3d(180px, 275px, 0) scale(.38);
}

.readiness-balloon {
  display: block;
  width: 100%;
  height: auto;
}


.slide-readiness-2026 .readiness-bar-label,
.slide-readiness-2026 .readiness-bar-value,
.slide-readiness-2026 .readiness-total-pill,
.slide-readiness-2026 .readiness-total-value {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
}

.slide-readiness-2026.is-active .readiness-building {
  animation: readinessBuildingIn 1.45s cubic-bezier(.18,.78,.22,1) .2s forwards;
}

.slide-readiness-2026.is-active .readiness-balloon-launcher {
  animation: readinessBalloonLaunch 2.5s cubic-bezier(.2,.8,.22,1) 1s forwards;
}

.slide-readiness-2026.is-active .readiness-balloon {
  animation: readinessBalloonBob 5.6s ease-in-out 3.55s infinite alternate;
}

@keyframes readinessBuildingIn {
  0% { opacity: 0; transform: translate3d(180px, 140px, 0) scale(.94); }
  100% { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }
}

@keyframes readinessBalloonLaunch {
  0% { opacity: 0; transform: translate3d(170px, 260px, 0) scale(.38) rotate(-3deg); }
  15% { opacity: .95; }
  100% { opacity: 1; transform: translate3d(0, 0, 0) scale(1) rotate(0); }
}

@keyframes readinessBalloonBob {
  0% { transform: translate3d(0, 0, 0) rotate(-1.6deg); }
  25% { transform: translate3d(10px, -14px, 0) rotate(.9deg); }
  50% { transform: translate3d(-8px, -24px, 0) rotate(-.6deg); }
  75% { transform: translate3d(12px, -16px, 0) rotate(1.2deg); }
  100% { transform: translate3d(-6px, -8px, 0) rotate(-1.1deg); }
}

@media (max-width: 1280px) and (orientation: landscape) {
  .readiness-bars { width: 38vw; }
  .readiness-total { width: 53vw; }
  .readiness-total-pill { font-size: clamp(1.2rem, 2vw, 2rem); }
  .readiness-total-value { font-size: clamp(3.5rem, 5.2vw, 5.8rem); }
}


/* ===== Slide 22 final tweak: total label + raise total progressbar ===== */

#slide-22 .readiness-total {
  bottom: clamp(104px, 15svh, 168px) !important;
}

#slide-22 .readiness-total-pill {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  letter-spacing: .01em !important;
}

#slide-22 .readiness-total-value {
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
}

@media (max-width: 1366px) and (orientation: landscape) {
  #slide-22 .readiness-total {
    bottom: calc(var(--nav-strip-h) + 84px) !important;
  }
}

@media (max-width: 1024px) and (orientation: landscape) {
  #slide-22 .readiness-total {
    bottom: calc(var(--nav-strip-h) + 54px) !important;
  }
}


/* ===== Final text tweak: slide 22 total label + white pill shadows ===== */

#slide-22 .readiness-total-pill {
  white-space: nowrap !important;
  min-width: auto !important;
  flex: 1 1 auto !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
}

#slide-22 .readiness-total-copy {
  align-items: center !important;
}

/* Белый текст в task-pill — с такой же тенью, как на последнем слайде */
.task-pill {
  color: #fff !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, .18) !important;
}


/* ===== White pill text shadow consistency ===== */
.communication-pill,
.master-pill,
.asp-pill,
.metaverse-pill,
.event-pill,
.events-pill,
.program-grid,
.program-grid a {
  color: #fff !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, .18) !important;
}


/* ===== Global fix: no right-edge artifact, keyboard-safe nav, preloader ===== */

html,
body {
  width: 100%;
  max-width: 100%;
  overflow: hidden !important;
}

.deck {
  width: 100%;
  max-width: 100%;
  height: 100svh;
  overflow: hidden !important;
  contain: size layout paint;
}

.slide {
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  transform: none !important;
  backface-visibility: hidden;
  will-change: opacity;
}

.slide.is-active {
  transform: none !important;
}

.bg {
  width: 100% !important;
  max-width: 100% !important;
}

/* Навигация всегда в одну строку */
.slide-nav {
  display: flex !important;
  flex-wrap: nowrap !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  gap: clamp(3px, .26vw, 7px) !important;
  padding: clamp(6px, .5vw, 10px) !important;
}

.slide-nav a {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  white-space: nowrap !important;
  font-size: clamp(.58rem, .72vw, 1rem) !important;
}

/* Прелоадер */
.page-preloader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: grid;
  place-items: center;
  align-content: center;
  gap: clamp(18px, 2.2svh, 30px);
  background:
    radial-gradient(circle at 50% 44%, rgba(0, 180, 210, .18), transparent 34%),
    linear-gradient(135deg, #07161d 0%, #052a34 48%, #111314 100%);
  transition: opacity .55s ease, visibility .55s ease;
  overflow: hidden;
}

.page-preloader::before,
.page-preloader::after {
  content: "";
  position: absolute;
  inset: -20%;
  opacity: .42;
  pointer-events: none;
}

.page-preloader::before {
  background:
    repeating-radial-gradient(ellipse at 68% 20%, rgba(0, 205, 229, .58) 0 1px, transparent 1px 7px);
  transform: rotate(-12deg);
  animation: preloaderWave 5.8s ease-in-out infinite alternate;
}

.page-preloader::after {
  background:
    radial-gradient(circle at 20% 86%, rgba(196, 95, 255, .24), transparent 24%),
    radial-gradient(circle at 78% 18%, rgba(0, 230, 143, .20), transparent 22%);
  animation: preloaderGlow 2.2s ease-in-out infinite alternate;
}

.page-preloader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.preloader-orb {
  position: absolute;
  width: clamp(250px, 26vw, 540px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 42% 38%, rgba(0, 225, 160, .26), transparent 32%),
    radial-gradient(circle at 68% 64%, rgba(112, 149, 255, .22), transparent 36%),
    radial-gradient(circle, rgba(255,255,255,.08), transparent 65%);
  filter: blur(.2px);
  animation: preloaderOrb 3.8s ease-in-out infinite;
}

.preloader-logo {
  position: relative;
  z-index: 2;
  width: clamp(210px, 18vw, 360px);
  height: auto;
  filter: drop-shadow(0 14px 28px rgba(0,0,0,.32)) drop-shadow(0 0 26px rgba(0, 230, 143, .14));
  animation: preloaderLogo 1.8s ease-in-out infinite alternate;
}

.preloader-title {
  position: relative;
  z-index: 2;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif;
  font-size: clamp(1.05rem, 1.35vw, 2rem);
  letter-spacing: .07em;
  text-transform: uppercase;
  color: #fff;
  opacity: .88;
  text-shadow: 0 2px 8px rgba(0,0,0,.28);
}

.preloader-progress {
  position: relative;
  z-index: 2;
  width: min(520px, 42vw);
  height: clamp(9px, .78vw, 15px);
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.10);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.10),
    0 12px 28px rgba(0,0,0,.24);
}

.preloader-progress-fill {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #c77aff 0%, #5fc6ff 45%, #00df90 100%);
  box-shadow: 0 0 24px rgba(0, 224, 150, .38);
  transition: width .18s ease;
}

.preloader-progress-fill::after {
  content: "";
  display: block;
  height: 100%;
  width: 34%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.42), transparent);
  animation: preloaderShine 1.2s linear infinite;
}

@keyframes preloaderWave {
  from { transform: translate3d(-2%, -1%, 0) rotate(-12deg) scale(1.02); }
  to { transform: translate3d(2%, 2%, 0) rotate(-8deg) scale(1.08); }
}

@keyframes preloaderGlow {
  from { opacity: .34; transform: scale(1); }
  to { opacity: .7; transform: scale(1.04); }
}

@keyframes preloaderOrb {
  0%, 100% { transform: translateY(0) scale(1); opacity: .75; }
  50% { transform: translateY(-10px) scale(1.04); opacity: 1; }
}

@keyframes preloaderLogo {
  from { transform: translateY(0) scale(1); }
  to { transform: translateY(-5px) scale(1.015); }
}

@keyframes preloaderShine {
  from { transform: translateX(-120%); }
  to { transform: translateX(340%); }
}

/* ===== Kept fixes from target archive: slide 20 and slide 22 ===== */
/* Slide 20: bracket must stay attached to the right text block */
#slide-20 .risks-right-wrap {
  position: absolute;
  z-index: 8;
  right: clamp(54px, 4.6vw, 110px);
  top: clamp(205px, 29svh, 320px);
  width: min(45vw, 700px);
  padding-left: clamp(34px, 2.2vw, 46px);
}
#slide-20 .risks-right {
  position: relative;
  right: auto;
  top: auto;
  width: 100%;
}
#slide-20 .risks-plan-bracket {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: clamp(18px, 1.4vw, 28px);
  height: auto;
  opacity: .94;
  border-left: 2px solid rgba(0,180,255,.72);
  border-top: 2px solid rgba(0,180,255,.72);
  border-bottom: 2px solid rgba(0,180,255,.72);
  border-radius: 8px 0 0 8px;
}
@media (max-width: 1366px) {
  #slide-20 .risks-right-wrap {
    top: 175px;
    width: min(46vw, 660px);
    padding-left: 32px;
  }
}
@media (max-width: 1024px) and (orientation: landscape) {
  #slide-20 .risks-right-wrap {
    top: 150px;
    padding-left: 28px;
  }
}

/* Slide 22: bigger/higher balloon, total % outside the progress bar */
#slide-22 .readiness-total {
  width: clamp(680px, 54vw, 900px);
}
#slide-22 .readiness-total-card {
  overflow: visible;
}
#slide-22 .readiness-total-copy {
  justify-content: flex-start;
  align-items: center !important;
  padding-right: clamp(126px, 10vw, 170px);
}
#slide-22 .readiness-total-value {
  position: absolute;
  right: clamp(-84px, -4.8vw, -46px);
  bottom: clamp(6px, .8svh, 14px);
  z-index: 4;
  white-space: nowrap;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
}
#slide-22 .readiness-balloon-launcher {
  right: clamp(250px, 23vw, 410px);
  bottom: clamp(280px, 29svh, 420px);
  width: clamp(235px, 21vw, 390px);
  transform: translate3d(210px, 340px, 0) scale(.32);
}
.slide-readiness-2026.is-active .readiness-balloon-launcher {
  animation: readinessBalloonLaunch 2.7s cubic-bezier(.2,.8,.22,1) 1s forwards;
}
@media (min-width: 1600px) {
  #slide-22 .readiness-balloon-launcher {
    bottom: clamp(330px, 34svh, 510px);
    width: clamp(280px, 20vw, 430px);
    right: clamp(280px, 23vw, 450px);
  }
  #slide-22 .readiness-total-value {
    right: clamp(-96px, -4.8vw, -60px);
  }
}

/* ===== Fixed slide 22: keep 98% outside the total progress bar ===== */
#slide-22 .readiness-total {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: clamp(20px, 2.2vw, 40px);
  width: clamp(760px, 62vw, 1060px) !important;
}

#slide-22 .readiness-total-card {
  grid-column: 1;
  grid-row: 1;
  overflow: hidden !important;
}

#slide-22 .readiness-total-copy {
  justify-content: flex-start !important;
  align-items: center !important;
  padding-right: clamp(18px, 1.8vw, 30px) !important;
}

#slide-22 .readiness-total-value {
  grid-column: 2;
  grid-row: 1;
  position: static !important;
  right: auto !important;
  bottom: auto !important;
  margin: 0 !important;
  align-self: center;
  white-space: nowrap;
  flex: 0 0 auto;
}

@media (max-width: 1180px) and (orientation: landscape) {
  #slide-22 .readiness-total {
    width: 70vw !important;
    column-gap: 18px;
  }
  #slide-22 .readiness-total-value {
    font-size: clamp(3.1rem, 5vw, 4.8rem) !important;
  }
}

/* ===== FINAL FIX: slide 3 blue arrows over the right-side blocks ===== */
#slide-3 .plan-arrows,
#slide-3 .plan-arrows span,
#slide-3 .plan-arrows .draw-arrow {
  display: none !important;
  visibility: hidden !important;
}

#slide-3::before,
#slide-3::after {
  position: absolute !important;
  z-index: 30 !important;
  pointer-events: none !important;
  display: block !important;
  color: #08b7ff !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(4.2rem, 5.6vw, 7.2rem) !important;
  line-height: 0.72 !important;
  text-shadow: 0 0 10px rgba(8, 183, 255, 0.35) !important;
  animation: slide11ArrowBounce 1.15s ease-in-out infinite !important;
  transform: translateX(-50%) !important;
}

#slide-3::before {
  content: "↓" !important;
  left: 73.5% !important;
  top: clamp(68px, 11.5svh, 132px) !important;
}

#slide-3::after {
  content: "↓" !important;
  left: 73.5% !important;
  top: clamp(496px, 66.5svh, 598px) !important;
  animation-delay: 0.18s !important;
}

@media (max-aspect-ratio: 4/3) {
  #slide-3::before,
  #slide-3::after {
    left: 74.5% !important;
    font-size: clamp(3.4rem, 5.2vw, 5.8rem) !important;
  }

  #slide-3::before {
    top: clamp(58px, 10svh, 104px) !important;
  }

  #slide-3::after {
    top: clamp(418px, 64svh, 520px) !important;
  }
}

/* ===== FINAL FIX: slide 3 like screenshot, all tied to .plan-list ===== */

/* Старые отдельные стрелки отключены */
#slide-3::before,
#slide-3::after,
#slide-3 .plan-arrows,
#slide-3 .plan-arrows span,
#slide-3 .plan-arrows .draw-arrow,
#slide-3 .plan-footer::before {
  content: none !important;
  display: none !important;
  visibility: hidden !important;
}

/* Главный правый блок — якорь для стрелок и нижнего заголовка */
#slide-3 .plan-list {
  overflow: visible !important;
  padding-bottom: 0 !important;
}

/* Верхняя стрелка: ровно над блоком списка */
#slide-3 .plan-list::before {
  content: "↓" !important;
  position: absolute !important;
  left: 50% !important;
  bottom: calc(100% + 15px) !important;
  transform: translateX(-50%) !important;
  z-index: 40 !important;
  pointer-events: none !important;
  display: block !important;
  visibility: visible !important;
  color: #08b7ff !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(4.0rem, 5.2vw, 6.8rem) !important;
  line-height: 0.72 !important;
  text-shadow: 0 0 10px rgba(8, 183, 255, 0.35) !important;
  animation: slide11ArrowBounce 1.15s ease-in-out infinite !important;
}

/* Нижняя стрелка: тот же якорь .plan-list, небольшой отступ вниз */
#slide-3 .plan-list::after {
  content: "↓" !important;
  position: absolute !important;
  left: 50% !important;
  top: calc(100% + 6px) !important;
  margin-top: 0 !important;
  transform: translateX(-50%) !important;
  z-index: 40 !important;
  pointer-events: none !important;
  display: block !important;
  visibility: visible !important;
  color: #08b7ff !important;
  font-family: "Aptos Black", "Aptos", Verdana, sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(4.0rem, 5.2vw, 6.8rem) !important;
  line-height: 0.72 !important;
  text-shadow: 0 0 10px rgba(8, 183, 255, 0.35) !important;
  animation: slide11ArrowBounce 1.15s ease-in-out infinite 0.18s !important;
}

/* Заголовок всегда ниже нижней стрелки на 15px и привязан к тому же блоку */
#slide-3 .plan-list .plan-footer,
#slide-3 .plan-footer {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  top: calc(100% + 6px + (clamp(4.0rem, 5.2vw, 6.8rem) * 0.72) + 15px) !important;
  bottom: auto !important;
  transform: translateX(-50%) !important;
  width: max-content !important;
  max-width: min(52vw, 980px) !important;
  margin: 0 !important;
  padding: 0 !important;
  z-index: 35 !important;
  display: block !important;
  visibility: visible !important;
  text-align: center !important;
  white-space: nowrap !important;
  font-size: clamp(1.55rem, 2.25vw, 3.8rem) !important;
  line-height: .98 !important;
}

/* ===== Auto 150% browser-like scaling for large desktop screens =====
   Для экранов типа Aspire S32-1856 и похожих больших мониторов.
   JS добавляет класс .auto-browser-zoom-150 только на desktop при большом viewport.
*/
html.auto-browser-zoom-150 {
  overflow: hidden !important;
}

html.auto-browser-zoom-150 body {
  width: 66.6667vw !important;
  height: 66.6667vh !important;
  min-width: 66.6667vw !important;
  min-height: 66.6667vh !important;
  transform: scale(1.5) !important;
  transform-origin: 0 0 !important;
  overflow: hidden !important;
}

html.auto-browser-zoom-150 .slide,
html.auto-browser-zoom-150 .slides,
html.auto-browser-zoom-150 main,
html.auto-browser-zoom-150 .deck,
html.auto-browser-zoom-150 #presentation,
html.auto-browser-zoom-150 #slides {
  width: 66.6667vw !important;
  height: 66.6667vh !important;
}

html.auto-browser-zoom-150 .slide {
  max-width: none !important;
  max-height: none !important;
}

