/* Проектор на весь вьюпорт (100vw × 100vh / 100dvh) */
html:has(.viewer-body) {
  height: 100%;
  margin: 0;
  overflow-x: hidden;
}

.viewer-body {
  margin: 0;
  padding: 0;
  width: 100vw;
  max-width: 100%;
  min-height: 100vh;
  min-height: 100dvh;
  height: 100vh;
  height: 100dvh;
  background: #0a0a0f;
  color: #fff;
  overflow-x: hidden;
  overflow-y: auto;
  box-sizing: border-box;
}

.viewer-root {
  width: 100vw;
  max-width: 100%;
  min-height: 100vh;
  min-height: 100dvh;
  height: 100vh;
  height: 100dvh;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.viewer-panel {
  min-height: 100vh;
  min-height: 100dvh;
  width: 100%;
  max-width: 100vw;
  box-sizing: border-box;
}

/* Лого «Октава-8» в верхнем левом углу (разметка как у svoi__navbar-brand) */
#viewer-root #viewer-panel-stats.viewer-panel--stats,
#viewer-root #viewer-panel-gallery.viewer-panel--gallery,
#viewer-root #viewer-panel-roulette.viewer-panel--roulette {
  position: relative;
}

/* Статистика: ТОП-10 без вертикальной прокрутки — кегль от (100dvh − отступы) / «высота» блока */
#viewer-root #viewer-panel-stats.viewer-panel--stats {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  height: 100vh;
  height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  --stats-fs: clamp(0.65rem, calc((100dvh - 6rem) / 33), 1.9rem);
}

.viewer-oktava8-corner {
  position: absolute;
  top: clamp(14px, 2.2vh, 36px);
  left: clamp(14px, 2.5vw, 40px);
  z-index: 6;
  pointer-events: none;
}

.viewer-oktava8-corner__brand {
  align-items: flex-start !important;
  color: var(--color-text, #1a1a1a);
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--game .viewer-oktava8-corner__brand,
#viewer-root #viewer-panel-gallery.viewer-panel--gallery--game .viewer-oktava8-corner__brand,
#viewer-root #viewer-panel-roulette.viewer-panel--roulette--game .viewer-oktava8-corner__brand {
  color: #fffef8;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
}

.viewer-oktava8-corner .svoi__navbar-brand-word {
  font-size: clamp(22px, 2.8vw, 40px) !important;
}

.viewer-oktava8-corner .svoi__navbar-brand-eight {
  font-size: clamp(30px, 3.6vw, 52px) !important;
}

.viewer-oktava8-corner .svoi__navbar-brand-subtitle {
  font-size: clamp(9px, 1vw, 12px) !important;
}

/* Обложка: без отступов .effect-start с главной, на весь экран */
#viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start {
  width: 100vw;
  max-width: 100%;
  min-height: 100vh;
  min-height: 100dvh;
  height: 100vh;
  height: 100dvh;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  position: relative;
  overflow: hidden;
  /* «Сцена» проектора: тёплый объём вместо плоского поля */
  background:
    radial-gradient(ellipse 95% 75% at 50% 38%, #fdf8ee 0%, #f5ecd8 42%, #ebe0c8 78%, #e0d4bc 100%);
  color: var(--color-text, #1a1a1a);
}

#viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(circle at 18% 22%, rgba(201, 162, 39, 0.14) 0%, transparent 42%),
    radial-gradient(circle at 88% 18%, rgba(139, 105, 20, 0.1) 0%, transparent 38%),
    radial-gradient(ellipse 70% 55% at 50% 100%, rgba(45, 42, 38, 0.06) 0%, transparent 55%);
  pointer-events: none;
  z-index: 0;
}

#viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 min(100px, 8vw) rgba(45, 42, 38, 0.07);
  pointer-events: none;
  z-index: 2;
}

/* Обложка с картинкой игры (не svoi): тёмная база, без кремового слоя */
#viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start:has(.viewer-game-cover) {
  background: #0a0a0f;
}

#viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start:has(.viewer-game-cover)::before,
#viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start:has(.viewer-game-cover)::after {
  display: none;
}

/* Фестивальная обложка (svoi): центр экрана, крупная типографика */
.viewer-festival-hero {
  position: relative;
  z-index: 1;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 0;
  padding: clamp(16px, 3vh, 48px) clamp(20px, 4vw, 64px);
  box-sizing: border-box;
}

/* Главная в <main> (не проектор): герой только по содержимому — кнопки сразу под лого */
main.effect-start > .viewer-festival-hero {
  flex: 0 1 auto;
  justify-content: flex-start;
  padding-top: clamp(8px, 1.2vh, 28px);
  padding-bottom: clamp(10px, 1.8vh, 32px);
}

.viewer-festival-hero .effect-start__header {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: min(1600px, 96vw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.viewer-festival-hero__intro {
  margin-bottom: clamp(28px, 5vh, 72px) !important;
  max-width: 38em;
  margin-left: auto !important;
  margin-right: auto !important;
  align-items: center !important;
  text-align: center;
  font-size: clamp(13px, 1.65vw, 22px) !important;
  line-height: 1.4 !important;
  letter-spacing: 0.11em !important;
  color: var(--color-text-muted, #5c574f) !important;
}

.viewer-festival-hero__intro-line {
  display: block;
}

.viewer-festival-hero__intro-line--accent {
  margin-top: 0.35em;
  color: var(--color-accent, #8b6914) !important;
  font-weight: 600;
  letter-spacing: 0.1em !important;
}

.viewer-festival-hero__intro-line--accent::after {
  content: "";
  display: block;
  width: min(120px, 18vw);
  height: 3px;
  margin: 0.85em auto 0;
  border-radius: 2px;
  background: linear-gradient(90deg, transparent, var(--color-accent, #8b6914), transparent);
  opacity: 0.55;
}

.viewer-festival-hero__logo {
  width: 100% !important;
  max-width: min(1320px, 94vw) !important;
  margin: 0 auto !important;
  margin-bottom: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap;
  justify-content: center !important;
  align-items: center !important;
  gap: clamp(20px, 3.5vw, 56px) !important;
  text-align: center;
}

.viewer-festival-hero__logo .effect-start__logo-text {
  flex: 0 1 44% !important;
  max-width: 520px;
  min-width: 0;
}

/* Колонка с name.png не должна сжиматься до «полоски» на десктопе проектора */
.viewer-festival-hero__logo:has(.effect-start__logo-wordmark-img) .effect-start__logo-text {
  flex: 1 1 44% !important;
  min-width: clamp(140px, min(36vw, 34vmin), 420px);
  overflow: visible;
}

.viewer-festival-hero__logo .effect-start__logo-wordmark {
  min-height: clamp(96px, min(18vh, 34vw), 240px) !important;
  margin-bottom: 0 !important;
}

.viewer-festival-hero__logo .effect-start__logo-wordmark:has(.effect-start__logo-wordmark-img) {
  width: min(100%, clamp(200px, min(38vw, 36vmin), 400px)) !important;
  min-width: min(100%, 168px) !important;
  max-width: min(400px, 100%) !important;
  min-height: unset !important;
}

.viewer-festival-hero__logo .effect-start__logo-wordmark-img {
  filter: drop-shadow(0 10px 32px rgba(26, 26, 26, 0.1));
}

.viewer-festival-hero__logo .effect-start__logo-visual {
  flex: 0 1 52% !important;
  max-width: 680px;
  min-height: clamp(120px, min(22vh, 46vw), 300px) !important;
}

.viewer-festival-hero__logo .effect-start__logo-num {
  filter: none;
}

/* Главная /start (svoi): num.png («дерево») — крупнее и по центру колонки визуала на десктопе */
@media (min-width: 721px) {
  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-visual {
    transform: none !important;
    flex: 0 1 58% !important;
    max-width: min(960px, 62vw) !important;
    min-height: clamp(200px, 34vh, 460px) !important;
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-num {
    left: 50%;
    right: auto;
    top: 5%;
    width: min(100%, clamp(440px, 50vw, 720px));
    height: auto;
    max-height: 92%;
    transform: translateX(-50%);
    object-fit: contain;
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__hero-decor--cloud-trio {
    width: clamp(7.5rem, min(58%, min(56vw, 50vmin)), 19rem);
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__hero-decor--cloud-duo {
    width: clamp(6.5rem, min(50%, min(46vw, 42vmin)), 15.5rem);
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__hero-decor--bf-orange {
    width: clamp(1.85rem, min(17%, min(15vw, 12vmin)), 5.5rem);
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__hero-decor--bf-teal {
    width: clamp(1.7rem, min(15%, min(14vw, 11vmin)), 4.75rem);
  }
}

/* Главная /start: десктоп — сетка header «лого | третий столбец». Flex из .viewer-festival-hero перебивал grid из effect-start и растягивал aside на всю ширину. */
@media (min-width: 992px) {
  main.effect-start > .viewer-festival-hero {
    padding-bottom: clamp(48px, 7.5vh, 112px);
  }

  main.effect-start .viewer-festival-hero .effect-start__header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 320px);
    align-items: start;
    column-gap: clamp(20px, 2.5vw, 36px);
    text-align: left;
    width: 100%;
    max-width: min(1440px, 94vw);
    margin-left: auto;
    margin-right: auto;
  }

  main.effect-start .viewer-festival-hero .effect-start__header > .viewer-festival-hero__logo {
    grid-column: 1;
    width: 100% !important;
    max-width: min(980px, 100%) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    justify-self: start;
  }

  main.effect-start .viewer-festival-hero .effect-start__header > .effect-start__desktop-extra {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0 !important;
    text-align: left;
  }
}

@media (min-width: 1200px) {
  main.effect-start > .viewer-festival-hero {
    padding-bottom: clamp(64px, 8.5vh, 132px);
  }

  main.effect-start .viewer-festival-hero .effect-start__header {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 400px);
    column-gap: 34px;
  }
}

@media (max-width: 720px) {
  .viewer-festival-hero__logo {
    flex-direction: column !important;
  }

  .viewer-festival-hero__logo .effect-start__logo-text,
  .viewer-festival-hero__logo .effect-start__logo-visual {
    flex: 1 1 auto !important;
    max-width: 100%;
  }

  /* Svoi /start: меньше вертикальный «воздух» между датой/вордмарком и num (~вдвое) */
  .viewer-festival-hero__logo.effect-start__logo--svoi-editorial {
    gap: clamp(10px, 1.75vw, 28px) !important;
  }

  .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-text,
  .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-visual {
    flex: 0 1 auto !important;
  }

  .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-date--svoi {
    margin-bottom: clamp(6px, 1.2vw, 11px) !important;
  }

  /* /start: крупнее вордмарк name.png, num.png — сдвиг вправо */
  .viewer-festival-hero__logo .effect-start__logo-wordmark:has(.effect-start__logo-wordmark-img) {
    width: min(100%, clamp(200px, 88vw, 400px)) !important;
    min-width: min(100%, 190px) !important;
    max-width: min(100%, 400px) !important;
  }

  .viewer-festival-hero__logo .effect-start__logo-wordmark-img {
    width: 100%;
    max-width: none;
  }

  .viewer-festival-hero__logo .effect-start__logo-num {
    transform: translateX(clamp(12px, 6vw, 36px));
  }

  .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-visual {
    min-height: clamp(52px, 19vw, 100px) !important;
  }

  /* Svoi /start: на мобильном без облаков и декора-бабочек (num.png остаётся) */
  .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__visual-decor {
    display: none !important;
  }

  /* Svoi /start мобильный: дата и name.png — одна вертикальная линия (общая колонка + сброс margin у p/img) */
  main.effect-start .viewer-festival-hero .effect-start__header {
    align-items: stretch !important;
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial {
    align-items: stretch !important;
    text-align: left !important;
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-text--svoi-column {
    --svoi-hero-text-col: min(100%, clamp(200px, 88vw, 400px));
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    box-sizing: border-box;
    text-align: left;
    padding-inline: clamp(2px, 1.5vw, 12px);
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-date--svoi {
    align-self: stretch;
    width: var(--svoi-hero-text-col);
    max-width: 100%;
    box-sizing: border-box;
    margin: 0 0 clamp(6px, 1.2vw, 11px) !important;
    padding: 0 0 0 15px;
    text-align: left;
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-wordmark:has(.effect-start__logo-wordmark-img) {
    align-self: flex-start;
    width: var(--svoi-hero-text-col) !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
    box-sizing: border-box;
  }

  main.effect-start .viewer-festival-hero__logo.effect-start__logo--svoi-editorial .effect-start__logo-wordmark-img {
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
  }
}

/* Планшетная вёрстка главной ограничивает .effect-start — на проекторе на всю ширину */
@media (min-width: 768px) {
  #viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start {
    max-width: none !important;
    width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* Сброс desktop-правил главной (992px+): сетка, max-width 1440px, nowrap у интро */
@media (min-width: 992px) {
  #viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start {
    width: 100vw !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    align-items: stretch !important;
    text-align: center !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero .effect-start__header {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    grid-template-columns: none !important;
    column-gap: 0 !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
    text-align: center !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__intro {
    grid-column: unset !important;
    white-space: normal !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__logo {
    grid-column: unset !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__logo .effect-start__logo-visual {
    transform: none !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__logo .effect-start__logo-wordmark {
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__logo .effect-start__logo-wordmark:has(.effect-start__logo-wordmark-img) {
    width: min(100%, clamp(200px, min(38vw, 36vmin), 400px)) !important;
    min-width: min(100%, 168px) !important;
    max-width: min(400px, 100%) !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__logo:has(.effect-start__logo-wordmark-img) .effect-start__logo-text {
    min-width: clamp(140px, min(36vw, 34vmin), 420px) !important;
    overflow: visible !important;
  }
}

@media (min-width: 1200px) {
  #viewer-root #viewer-panel-cover.viewer-panel--cover.effect-start {
    width: 100vw !important;
    max-width: none !important;
    padding: 0 !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero .effect-start__header {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    grid-template-columns: none !important;
    column-gap: 0 !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__logo .effect-start__logo-visual {
    transform: none !important;
  }

  #viewer-root #viewer-panel-cover .viewer-festival-hero__logo {
    max-width: min(1320px, 94vw) !important;
  }
}

/* Обложка не-svoi: та же «сцена» на весь кадр */
#viewer-root #viewer-panel-cover .viewer-game-cover {
  min-height: 100%;
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-size: cover;
  background-position: center;
}

#viewer-root #viewer-panel-cover .viewer-game-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    165deg,
    rgba(10, 10, 15, 0.45) 0%,
    rgba(10, 10, 15, 0.25) 40%,
    rgba(10, 10, 15, 0.55) 100%
  );
  pointer-events: none;
}

#viewer-root #viewer-panel-cover .viewer-game-cover__inner {
  position: relative;
  z-index: 1;
  padding: clamp(24px, 4vh, 56px);
}

#viewer-root #viewer-panel-cover .viewer-game-cover__logo {
  max-width: min(55vw, 520px);
  max-height: min(38vh, 420px);
  filter: drop-shadow(0 12px 40px rgba(0, 0, 0, 0.35));
}

#viewer-root #viewer-panel-cover .viewer-game-cover__title {
  font-size: clamp(2rem, 5vw, 3.75rem);
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.4);
}

/* Статистика (не фестиваль): как раньше — тёмный экран */
#viewer-root #viewer-panel-stats.viewer-panel--stats--game {
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(55, 48, 40, 0.35) 0%, transparent 55%),
    linear-gradient(180deg, #12121a 0%, #0a0a0f 45%, #08080c 100%);
  color: #f2f2f4;
  padding-top: clamp(10px, 1.8vh, 28px);
  padding-bottom: clamp(10px, 1.8vh, 28px);
}

/* Статистика (svoi): тот же тёплый фон, что у обложки проектора */
#viewer-root #viewer-panel-stats.viewer-panel--stats--festival {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse 95% 75% at 50% 38%, #fdf8ee 0%, #f5ecd8 42%, #ebe0c8 78%, #e0d4bc 100%);
  color: var(--color-text, #1a1a1a);
  padding-top: clamp(10px, 1.8vh, 28px);
  padding-bottom: clamp(10px, 1.8vh, 28px);
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--festival::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(circle at 18% 22%, rgba(201, 162, 39, 0.14) 0%, transparent 42%),
    radial-gradient(circle at 88% 18%, rgba(139, 105, 20, 0.1) 0%, transparent 38%),
    radial-gradient(ellipse 70% 55% at 50% 100%, rgba(45, 42, 38, 0.06) 0%, transparent 55%);
  pointer-events: none;
  z-index: 0;
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--festival::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 min(100px, 8vw) rgba(45, 42, 38, 0.07);
  pointer-events: none;
  z-index: 2;
}

#viewer-root #viewer-panel-stats .viewer-stats-wrap {
  position: relative;
  z-index: 1;
  flex: 1 1 auto;
  min-height: 0;
  max-width: min(1400px, 96vw);
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 0.35rem 0.65rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: var(--stats-fs);
}

#viewer-root #viewer-panel-stats .viewer-stats-heading {
  font-size: clamp(1rem, calc(var(--stats-fs) * 2.05), 2.85rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 0.35em !important;
  flex-shrink: 0;
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--festival .viewer-stats-heading {
  color: var(--color-accent, #8b6914);
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--game .viewer-stats-heading {
  color: #f8f9fa;
}

.viewer-top10-team {
  color: var(--color-text-muted, #6b6560);
  font-weight: 500;
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--game .viewer-top10-team {
  color: rgba(255, 255, 255, 0.55);
}

.viewer-top10-badge--score {
  font-weight: 600;
}

.viewer-top10-badge--time {
  font-weight: 500;
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--festival .viewer-top10-badge--score {
  background: var(--color-btn-bg, #2d2a26) !important;
  color: var(--color-btn-text, #fffef8) !important;
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--festival .viewer-top10-badge--time {
  background: rgba(139, 105, 20, 0.2) !important;
  color: var(--color-accent, #6b5210) !important;
  border: 1px solid rgba(139, 105, 20, 0.35);
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--game .viewer-top10-badge--score {
  background: #0d6efd !important;
  color: #fff !important;
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--game .viewer-top10-badge--time {
  background: rgba(255, 255, 255, 0.12) !important;
  color: #e9ecef !important;
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.viewer-leader-list .viewer-leader-item {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
  color: #fff;
}

#viewer-root #viewer-panel-stats .viewer-leader-list .viewer-leader-item {
  padding: 0.28em 0.55em !important;
  line-height: 1.2;
  flex-shrink: 0;
  flex-wrap: nowrap !important;
}

#viewer-root #viewer-panel-stats .viewer-top10-main {
  min-width: 0;
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#viewer-root #viewer-panel-stats .viewer-top10-meta {
  flex-shrink: 0;
}

#viewer-root #viewer-panel-stats.viewer-panel--stats--festival .viewer-leader-list .viewer-leader-item {
  background: rgba(255, 254, 248, 0.72);
  border: 1px solid rgba(45, 42, 38, 0.1);
  color: var(--color-text, #1a1a1a);
  box-shadow: 0 4px 20px rgba(42, 40, 36, 0.06);
}

#viewer-root #viewer-panel-stats .viewer-leader-list {
  display: flex;
  flex-direction: column;
  gap: 0.15em;
  flex: 0 1 auto;
  min-height: 0;
  overflow: hidden;
}

#viewer-root #viewer-panel-stats .viewer-top10-badge {
  font-size: 0.82em !important;
  padding: 0.28em 0.55em !important;
}

.viewer-leader-rank {
  font-weight: 700;
  margin-right: 0.35rem;
}

#viewer-root #viewer-panel-stats .viewer-leader-rank {
  font-size: 1.05em;
  margin-right: 0.45rem;
}

.viewer-game-cover {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background-size: cover;
  background-position: center;
}

.viewer-game-cover__inner {
  text-align: center;
  padding: 2rem;
}

.viewer-game-cover__logo {
  max-width: min(50vw, 420px);
  max-height: 40vh;
  object-fit: contain;
  margin-bottom: 1.5rem;
}

.viewer-game-cover__title {
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 700;
}

.viewer-player-card {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #fff;
}

.viewer-projector-toolbar {
  min-width: 220px;
}

/* ——— Фотогалерея (MVP: цветные плитки) ——— */
#viewer-root #viewer-panel-gallery.viewer-panel--gallery {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
  height: 100vh;
  height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  padding-top: clamp(8px, 1.2vh, 22px);
  padding-bottom: clamp(8px, 1vh, 20px);
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

#viewer-root #viewer-panel-gallery.viewer-panel--gallery--game {
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(55, 48, 40, 0.35) 0%, transparent 55%),
    linear-gradient(180deg, #12121a 0%, #0a0a0f 45%, #08080c 100%);
  color: #f2f2f4;
}

#viewer-root #viewer-panel-gallery.viewer-panel--gallery--festival {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse 95% 75% at 50% 38%, #fdf8ee 0%, #f5ecd8 42%, #ebe0c8 78%, #e0d4bc 100%);
  color: var(--color-text, #1a1a1a);
}

#viewer-root #viewer-panel-gallery.viewer-panel--gallery--festival::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(circle at 18% 22%, rgba(201, 162, 39, 0.14) 0%, transparent 42%),
    radial-gradient(circle at 88% 18%, rgba(139, 105, 20, 0.1) 0%, transparent 38%),
    radial-gradient(ellipse 70% 55% at 50% 100%, rgba(45, 42, 38, 0.06) 0%, transparent 55%);
  pointer-events: none;
  z-index: 0;
}

#viewer-root #viewer-panel-gallery.viewer-panel--gallery--festival::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 min(100px, 8vw) rgba(45, 42, 38, 0.07);
  pointer-events: none;
  z-index: 2;
}

#viewer-root #viewer-panel-gallery .viewer-gallery-stage {
  position: relative;
  z-index: 1;
  flex: 1;
  min-height: 0;
  width: 100%;
  overflow: hidden;
}

.viewer-gallery-tile {
  position: absolute;
  box-sizing: border-box;
  /* Рамка через тень: не съедает внутреннюю область (в отличие от border) */
  border: none;
  border-radius: 6px;
  box-shadow:
    0 0 0 2px rgba(255, 255, 255, 0.95),
    0 10px 28px rgba(0, 0, 0, 0.3);
  opacity: 0;
  overflow: hidden;
  /* width/height задаёт скрипт в % сцены — без aspect-ratio на abspos (иначе высота 0) */
  will-change: opacity, transform;
  animation: viewer-gallery-tile-cycle 7.6s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: var(--gallery-delay, 0s);
}

.viewer-gallery-tile > img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* ~0.75s появление, ~5s удержание, ~0.85s исчезновение; остальное — пауза до следующего цикла */
@keyframes viewer-gallery-tile-cycle {
  0% {
    opacity: 0;
    transform: scale(0.9);
    filter: blur(3px);
  }
  10% {
    opacity: 1;
    transform: scale(1);
    filter: blur(0);
  }
  76% {
    opacity: 1;
    transform: scale(1);
    filter: blur(0);
  }
  88% {
    opacity: 0;
    transform: scale(0.94);
    filter: blur(2px);
  }
  100% {
    opacity: 0;
    transform: scale(0.9);
    filter: blur(3px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .viewer-gallery-tile {
    animation: viewer-gallery-tile-static 12s ease-in-out infinite;
    animation-delay: var(--gallery-delay, 0s);
  }

  @keyframes viewer-gallery-tile-static {
    0%,
    100% {
      opacity: 0.35;
    }
    50% {
      opacity: 0.85;
    }
  }
}

/* ——— Рулетка (лотерея имён) ——— */
#viewer-root #viewer-panel-roulette.viewer-panel--roulette {
  display: flex;
  flex-direction: column;
  padding-left: 0;
  padding-right: 0;
  padding-top: clamp(24px, 4vh, 48px);
  padding-bottom: clamp(32px, 5vh, 64px);
}

/* Рулетка (не svoi): тёмный фон, как обложка игры на проекторе */
#viewer-root #viewer-panel-roulette.viewer-panel--roulette--game {
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(55, 48, 40, 0.35) 0%, transparent 55%),
    linear-gradient(180deg, #12121a 0%, #0a0a0f 45%, #08080c 100%);
  color: #f2f2f4;
}

/* Рулетка (svoi): тот же тёплый фон, что у обложки и статистики */
#viewer-root #viewer-panel-roulette.viewer-panel--roulette--festival {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse 95% 75% at 50% 38%, #fdf8ee 0%, #f5ecd8 42%, #ebe0c8 78%, #e0d4bc 100%);
  color: var(--color-text, #1a1a1a);
}

#viewer-root #viewer-panel-roulette.viewer-panel--roulette--festival::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(circle at 18% 22%, rgba(201, 162, 39, 0.14) 0%, transparent 42%),
    radial-gradient(circle at 88% 18%, rgba(139, 105, 20, 0.1) 0%, transparent 38%),
    radial-gradient(ellipse 70% 55% at 50% 100%, rgba(45, 42, 38, 0.06) 0%, transparent 55%);
  pointer-events: none;
  z-index: 0;
}

#viewer-root #viewer-panel-roulette.viewer-panel--roulette--festival::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 min(100px, 8vw) rgba(45, 42, 38, 0.07);
  pointer-events: none;
  z-index: 2;
}

#viewer-root #viewer-panel-roulette.viewer-panel--roulette--festival .viewer-roulette-stage {
  position: relative;
  z-index: 1;
}

.viewer-roulette-stage {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: min(70vh, 640px);
  width: 100%;
  position: relative;
}

.viewer-roulette-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  flex: 1;
  min-height: clamp(200px, 32vh, 420px);
  display: flex;
  align-items: center;
}

.viewer-roulette-selector {
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 3px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(201, 162, 39, 0.2), #c9a227, rgba(201, 162, 39, 0.2));
  z-index: 2;
  box-shadow: 0 0 12px rgba(201, 162, 39, 0.45);
  border-radius: 2px;
}

.viewer-roulette-wheel {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0;
  will-change: transform;
}

.viewer-roulette-row {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
}

.viewer-roulette-card {
  flex: 0 0 auto;
  width: 400px;
  margin: 0 10px;
  min-height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 20px;
  border-radius: 14px;
  font-size: clamp(1.1rem, 2.2vw, 1.65rem);
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
  writing-mode: horizontal-tb;
  text-orientation: mixed;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
  border: 2px solid rgba(255, 255, 255, 0.12);
  color: #fff;
}

.viewer-roulette-card--red {
  background: linear-gradient(145deg, #8b2942, #5c1a2a);
}

.viewer-roulette-card--black {
  background: linear-gradient(145deg, #2a2a32, #12121a);
}

.viewer-roulette-card--green {
  background: linear-gradient(145deg, #1f4d3a, #0f2d22);
}

/* Модалка победителя — в духе спека + тёплый акцент Октавы */
.viewer-winner-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.82);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.45s ease, visibility 0.45s ease;
}

.viewer-winner-modal.show {
  opacity: 1;
  visibility: visible;
}

.viewer-winner-modal__content {
  position: relative;
  max-width: min(92vw, 560px);
  padding: 40px 56px;
  border-radius: 20px;
  border: 3px solid rgba(255, 255, 255, 0.95);
  background: linear-gradient(145deg, #a67c52 0%, #8b6914 45%, #6b4f0f 100%);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
  transform: scale(0.72);
  transition: transform 0.5s ease;
  overflow: hidden;
}

.viewer-winner-modal.show .viewer-winner-modal__content {
  transform: scale(1);
}

.viewer-winner-modal__content::before {
  content: "";
  position: absolute;
  top: -120%;
  left: -80%;
  width: 60%;
  height: 280%;
  background: linear-gradient(
    105deg,
    transparent 0%,
    rgba(255, 255, 255, 0.12) 45%,
    rgba(255, 255, 255, 0.28) 50%,
    rgba(255, 255, 255, 0.12) 55%,
    transparent 100%
  );
  animation: viewer-winner-shine 3s ease-in-out infinite;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .viewer-winner-modal__content::before {
    animation: none;
  }
}

@keyframes viewer-winner-shine {
  0% {
    transform: translateX(-20%) rotate(12deg);
  }
  100% {
    transform: translateX(220%) rotate(12deg);
  }
}

.viewer-winner-modal__name {
  margin: 0;
  padding: 0.5rem 2rem 0;
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 800;
  color: #fff;
  text-align: center;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.45);
  animation: viewer-winner-pulse 2s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  .viewer-winner-modal__name {
    animation: none;
  }
}

@keyframes viewer-winner-pulse {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.04);
  }
}

.viewer-winner-modal__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}

.viewer-winner-modal__close:hover {
  background: rgba(255, 255, 255, 0.35);
  transform: scale(1.08);
}
