/**
 * Премиум-оболочка игрока: фон и логотип — только из настроек игры.
 * Палитра и формы — тёмный «gaming» UI без сторонних фоновых изображений.
 * Цвет акцента задаётся в админке (переменная --ym-player-accent на body / .ym-player-shell).
 */

:root {
  --ym-player-accent: #2579C8;
}

/* ——— Регистрация и стартовые экраны с игрой в контексте ——— */

.ym-player-shell {
  position: relative;
  min-height: 100vh;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1rem, 4vw, 2rem);
  overflow: hidden;
  box-sizing: border-box;
}

.ym-player-shell__backdrop {
  position: fixed;
  inset: 0;
  z-index: 0;
}

.ym-player-shell__scrim {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 95% 85% at 50% 18%, color-mix(in srgb, var(--ym-player-accent) 9%, transparent), transparent 52%),
    radial-gradient(ellipse 120% 70% at 50% 110%, rgba(0, 0, 0, 0.52), transparent 45%),
    linear-gradient(165deg, rgba(18, 6, 12, 0.78) 0%, rgba(12, 4, 10, 0.88) 50%, rgba(22, 8, 14, 0.82) 100%);
}

.ym-player-shell__grain {
  position: fixed;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0.38;
  background-image: radial-gradient(rgba(255, 255, 255, 0.07) 1px, transparent 1px);
  background-size: 14px 14px;
}

.ym-player-shell__frame {
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: min(440px, 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1rem, 3vh, 1.5rem);
}

.ym-player-shell__frame--wide {
  max-width: min(560px, 100%);
}

.ym-player-shell__logo {
  max-width: min(260px, 72vw);
  max-height: clamp(52px, 14vh, 120px);
  width: auto;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 12px 36px rgba(0, 0, 0, 0.55));
}

.ym-player-shell__card .ym-player-shell__logo {
  display: block;
  margin-inline: auto;
  margin-bottom: clamp(0.75rem, 2.5vw, 1.25rem);
}

.ym-player-shell__card {
  background: linear-gradient(180deg, rgba(47, 154, 255, 0.16) 0%, rgba(28, 92, 153, 0.16) 77.4%);
  backdrop-filter: blur(3.5px);
  border-radius: 25px;

  width: 100%;
  /* border-radius: clamp(22px, 5vw, 30px); */
  padding: clamp(1.25rem, 4vw, 1.75rem);
  /* background: linear-gradient(
    165deg,
    rgba(42, 12, 18, 0.78) 0%,
    rgba(28, 8, 14, 0.88) 100%
  ); */
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 22%, transparent);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.04) inset,
    0 24px 56px rgba(0, 0, 0, 0.45),
    0 0 80px color-mix(in srgb, var(--ym-player-accent) 6%, transparent);
  color: rgba(248, 242, 244, 0.96);
}

.ym-player-shell__card .text-muted {
  color: rgba(232, 220, 225, 0.62) !important;
}

.ym-player-shell__card .form-floating > label {
  color: rgba(232, 220, 225, 0.72);
}

.ym-player-shell__card .form-control {
  border-radius: 16px;
  background: rgba(10, 4, 8, 0.55);
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 18%, transparent);
  color: #fff;
  min-height: 52px;
}

.ym-player-shell__card .form-control:focus {
  border-color: color-mix(in srgb, var(--ym-player-accent) 45%, transparent);
  box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--ym-player-accent) 18%, transparent);
  background: rgba(12, 5, 10, 0.72);
  color: #fff;
}

.ym-player-shell__card .btn-primary {
  /* border-radius: 18px; */
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.88rem;
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  border: none;
  /* background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--ym-player-accent) 84%, white) 0%,
    color-mix(in srgb, var(--ym-player-accent) 74%, black) 100%
  ); */
  box-shadow: 0 8px 28px color-mix(in srgb, var(--ym-player-accent) 35%, transparent);

  background: linear-gradient(180deg, #2F9AFF 0%, #2C90EE 47.12%, #2478C6 100%);
  border-radius: 50px;

}

.ym-player-shell__card .btn-primary:hover {
  filter: brightness(1.06);
  box-shadow: 0 10px 34px color-mix(in srgb, var(--ym-player-accent) 42%, transparent);
}

.ym-player-shell__card .btn-primary:focus-visible {
  outline: 2px solid rgba(255, 212, 120, 0.85);
  outline-offset: 2px;
}

.ym-player-shell__card .alert-danger {
  border-radius: 14px;
  border: 1px solid rgba(255, 120, 120, 0.35);
  background: rgba(80, 12, 24, 0.65);
  color: #fecaca;
}

.ym-player-shell__card .badge.bg-secondary {
  background: rgba(0, 0, 0, 0.35) !important;
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-weight: 600;
}

.ym-player-shell__card--wide {
  max-width: min(520px, 100%);
}

.ym-player-shell__card .form-select {
  border-radius: 16px;
  background: rgba(10, 4, 8, 0.55);
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 18%, transparent);
  color: #fff;
  min-height: 52px;
}

.ym-player-shell__card .form-select:focus {
  border-color: color-mix(in srgb, var(--ym-player-accent) 45%, transparent);
  box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--ym-player-accent) 18%, transparent);
}

.ym-player-shell__card .form-label {
  color: rgba(248, 238, 242, 0.85);
}

.ym-player-shell__card .alert-info {
  border-radius: 14px;
  background: rgba(8, 40, 55, 0.55);
  border: 1px solid rgba(120, 200, 255, 0.25);
  color: #e0f2fe;
}

/* ——— Экран вопроса игрока (квиз) ——— */

main.quiz-task-screen--player.ym-premium-player {
  position: relative;
  color: rgba(252, 246, 248, 0.94);
}

main.quiz-task-screen--player.ym-premium-player::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.42;
  background-image: radial-gradient(rgba(255, 255, 255, 0.065) 1px, transparent 1px);
  background-size: 16px 16px;
}

main.quiz-task-screen--player.ym-premium-player::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 90% 55% at 50% -5%, color-mix(in srgb, var(--ym-player-accent) 11%, transparent), transparent 48%),
    radial-gradient(ellipse 80% 55% at 50% 105%, rgba(0, 0, 0, 0.42), transparent 52%);
}

main.quiz-task-screen--player.ym-premium-player > * {
  position: relative;
  z-index: 1;
}

main.quiz-task-screen--player.ym-premium-player .hint-btn {
  z-index: 1000;
}

main.quiz-task-screen--player.ym-premium-player {
  --quiz-player-header-bg: rgba(28, 92, 153, 0.8);
  --quiz-player-header-border: color-mix(in srgb, var(--ym-player-accent) 26%, transparent);
  --quiz-player-timer-fill: var(--ym-player-accent);
  --quiz-player-timer-track: rgba(12, 5, 10, 0.88);
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-premium-headrow {
  display: flex;
  align-items: center;
  gap: clamp(0.25rem, 1.5vw, 0.55rem);
  width: 100%;
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-premium-headrow__badges {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-premium-headrow__badges .quiz-task-meta {
  flex-wrap: wrap;
  gap: 0.35rem 0.45rem;
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-premium-headrow__logo {
  flex: 0 0 auto;
  max-width: min(46vw, 200px);
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-premium-headrow__timer {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

main.quiz-task-screen--player.ym-premium-player .ym-premium-brand-logo {
  width: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 0;
}

main.quiz-task-screen--player.ym-premium-player .ym-premium-brand-logo__img {
  max-height: clamp(36px, 9vh, 72px);
  width: auto;
  max-width: min(200px, 46vw);
  object-fit: contain;
  filter: drop-shadow(0 10px 28px rgba(0, 0, 0, 0.45));
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-premium-headrow__timer #progressBar.quiz-progress-bar {
  width: min(200px, 52vw);
  min-width: 118px;
}

@media (max-width: 768px) {
  main.quiz-task-screen--player.ym-premium-player
    .quiz-task-premium-headrow:has(.ym-premium-brand-logo__img)
    .quiz-task-qnum {
    display: none !important;
  }

  main.quiz-task-screen--player.ym-premium-player
    .quiz-task-premium-headrow:has(.ym-premium-brand-logo__img)
    .quiz-task-premium-headrow__logo {
    order: -1;
    max-width: min(40vw, 132px);
  }

  main.quiz-task-screen--player.ym-premium-player
    .quiz-task-premium-headrow:has(.ym-premium-brand-logo__img)
    .ym-premium-brand-logo__img {
    max-height: clamp(30px, 7.5vh, 52px);
    max-width: min(132px, 40vw);
  }

  main.quiz-task-screen--player.ym-premium-player
    .quiz-task-premium-headrow:has(.ym-premium-brand-logo__img)
    .quiz-task-premium-headrow__timer
    #progressBar.quiz-progress-bar {
    width: min(168px, 46vw);
    min-width: 104px;
  }

  /* Высота видимой области (JS --ym-visible-height + Visual Viewport), отступ снизу под safe-area и панель браузера */
  main.quiz-task-screen--player.ym-premium-player.h-100 {
    height: auto !important;
  }

  main.quiz-task-screen--player.ym-premium-player {
    box-sizing: border-box !important;
    min-height: 100svh !important;
    min-height: var(--ym-visible-height, 100dvh) !important;
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + clamp(10px, 3vmin, 24px));
  }

  main.quiz-task-screen--player.ym-premium-player > form.quiz-player-form {
    margin-bottom: calc(
      0.75rem + env(safe-area-inset-bottom, 0px) + clamp(8px, 2.8vmin, 20px)
    ) !important;
  }

  main.quiz-task-screen--player.ym-premium-player > form.quiz-player-form.quiz-player-form--answered {
    margin-bottom: calc(0.45rem + env(safe-area-inset-bottom, 0px)) !important;
  }
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-header__inner {
  border-radius: clamp(18px, 3vw, 26px);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.05) inset,
    0 18px 48px rgba(0, 0, 0, 0.35);
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-badge {
  border-color: color-mix(in srgb, var(--ym-player-accent) 35%, transparent);
  background: color-mix(in srgb, var(--ym-player-accent) 12%, transparent);
  color: color-mix(in srgb, var(--ym-player-accent) 16%, #ffffff);
}

main.quiz-task-screen--player.ym-premium-player .quiz-task-badge--reveal {
  background: rgba(40, 167, 69, 0.2);
  border-color: rgba(72, 219, 129, 0.45);
  color: #c8ffd8;
}

main.quiz-task-screen--player.ym-premium-player #progressBar.quiz-progress-bar {
  border-color: color-mix(in srgb, var(--ym-player-accent) 28%, transparent) !important;
  box-shadow: 0 0 24px color-mix(in srgb, var(--ym-player-accent) 12%, transparent);
}

main.quiz-task-screen--player.ym-premium-player #progressBar.quiz-progress-bar #progressTime.quiz-progress-time {
  color: color-mix(in srgb, var(--ym-player-accent) 62%, white) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--ym-player-accent) 62%, white) !important;
  text-shadow: 0 0 22px color-mix(in srgb, var(--ym-player-accent) 35%, transparent);
  font-weight: 800;
  letter-spacing: 0.06em;
}

main.quiz-task-screen--player.ym-premium-player #progressBar.quiz-progress-bar .quiz-progress-sep {
  opacity: 0.65;
  color: color-mix(in srgb, var(--ym-player-accent) 42%, #ffffff) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--ym-player-accent) 42%, #ffffff) !important;
}

main.quiz-task-screen--player.ym-premium-player #progressBar.quiz-progress-bar .quiz-progress-fill {
  background: linear-gradient(
    90deg,
    var(--ym-player-accent),
    color-mix(in srgb, var(--ym-player-accent) 42%, white)
  ) !important;
}

main.quiz-task-screen--player.ym-premium-player #textContent.quiz-question-card {
  background: linear-gradient(180deg, rgba(28, 92, 153, 0.75) 1.92%, rgba(6, 61, 114, 0.75) 100%);
  backdrop-filter: blur(3.5px);
  border-radius: 15px;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.04) inset,
    0 20px 50px rgba(0, 0, 0, 0.38) !important;
  color: rgba(252, 246, 248, 0.98) !important;
}

main.quiz-task-screen--player.ym-premium-player .quiz-player-attention-screen {
  border-radius: clamp(20px, 3vw, 28px) !important;
  border-color: color-mix(in srgb, var(--ym-player-accent) 28%, transparent) !important;
  background: rgba(42, 12, 18, 0.55) !important;
}

main.quiz-task-screen--player.ym-premium-player #textContent.quiz-answer-reveal-plaque {
  border-color: rgba(72, 219, 129, 0.42) !important;
  background: rgba(16, 52, 32, 0.55) !important;
}

main.quiz-task-screen--player.ym-premium-player form.quiz-player-form .quiz-player-input-group {
  border-radius: clamp(18px, 2.8vw, 24px);
  background: rgba(28, 10, 16, 0.72);
  border-color: color-mix(in srgb, var(--ym-player-accent) 22%, transparent);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.28);
}

main.quiz-task-screen--player.ym-premium-player .quiz-player-answer-field.form-control {
  border-radius: 14px;
  background: rgba(8, 4, 10, 0.65);
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 15%, transparent);
  color: #fff;
}

main.quiz-task-screen--player.ym-premium-player .quiz-player-submit-btn.btn {
  border-radius: 14px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--ym-player-accent) 84%, white), color-mix(in srgb, var(--ym-player-accent) 68%, black));
  border: none;
  color: #fff;
  box-shadow: 0 6px 22px color-mix(in srgb, var(--ym-player-accent) 35%, transparent);
}

main.quiz-task-screen--player.ym-premium-player .btn-answer--quiz {
  background: linear-gradient(180deg, rgba(47, 154, 255, 0.65) 0%, rgba(28, 92, 153, 0.65) 77.4%) !important;
  backdrop-filter: blur(3.5px);
  border-radius: 50px;  
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 22%, transparent) !important;
  color: rgba(252, 246, 248, 0.96) !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
}

main.quiz-task-screen--player.ym-premium-player .btn-answer--quiz:hover,
main.quiz-task-screen--player.ym-premium-player .btn-answer--quiz:focus-visible {
  border-color: color-mix(in srgb, var(--ym-player-accent) 45%, transparent) !important;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--ym-player-accent) 15%, transparent), 0 14px 36px rgba(0, 0, 0, 0.35);
}

main.quiz-task-screen--player.ym-premium-player .btn-answer--quiz .quiz-choice-letter {
  background: linear-gradient(0deg, rgba(47, 154, 255, 0.5), rgba(47, 154, 255, 0.5)) !important;
  backdrop-filter: blur(3.5px);
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 28%, transparent);
  color: color-mix(in srgb, var(--ym-player-accent) 78%, white) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--ym-player-accent) 78%, white) !important;
}

main.quiz-task-screen--player.ym-premium-player .btn-answer--quiz .quiz-choice-text {
  color: rgba(252, 246, 248, 0.96) !important;
  -webkit-text-fill-color: rgba(252, 246, 248, 0.96) !important;
}

/* Свободная игра: прогресс по вопросам */
main.quiz-task-screen--player.ym-premium-player .ym-free-play-progress {
  width: 100%;
  max-width: var(--quiz-content-max-width);
  margin: 0 auto 0.35rem;
  padding: 0 clamp(0.25rem, 1.5vw, 0.35rem);
  flex-shrink: 0;
  box-sizing: border-box;
}

main.quiz-task-screen--player.ym-premium-player .ym-free-play-progress__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}

main.quiz-task-screen--player.ym-premium-player .ym-free-play-progress__caption {
  font-family: "Montserrat", "Circe", sans-serif;
  font-size: clamp(0.62rem, 2.2vw, 0.72rem);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(232, 218, 225, 0.72);
}

main.quiz-task-screen--player.ym-premium-player .ym-free-play-progress__fraction {
  font-family: "Roboto Condensed", "Montserrat", monospace;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  font-size: clamp(0.78rem, 2.6vw, 0.88rem);
  color: color-mix(in srgb, var(--ym-player-accent) 52%, #ffffff);
  letter-spacing: 0.04em;
}

main.quiz-task-screen--player.ym-premium-player .ym-free-play-progress__track {
  height: 5px;
  border-radius: 999px;
  background: #474747;
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 20%, transparent);
  overflow: hidden;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.35);
}

main.quiz-task-screen--player.ym-premium-player .ym-free-play-progress__fill {
  height: 100%;
  border-radius: inherit;
  max-width: 100%;
  background: #2F9AFF;
  box-shadow: 0 0 12px color-mix(in srgb, var(--ym-player-accent) 35%, transparent);
  transition: width 0.35s ease;
}

/* ——— Модальные окна игрока (free-play «время вышло» и др.) ——— */

.modal.ym-premium-modal .modal-dialog {
  max-width: min(400px, calc(100% - 1.5rem));
}

.modal.ym-premium-modal .modal-content {
  overflow: hidden;
  background: linear-gradient(180deg, rgba(47, 154, 255, 0.16) 0%, rgba(28, 92, 153, 0.16) 77.4%);
  backdrop-filter: blur(3.5px);
  border-radius: 25px;
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 26%, transparent);  
  color: rgba(248, 242, 244, 0.96);
}

.modal.ym-premium-modal .modal-header {
  border-bottom: 1px solid color-mix(in srgb, var(--ym-player-accent) 22%, transparent);
  padding: clamp(0.95rem, 3vw, 1.15rem) clamp(1.1rem, 3.5vw, 1.35rem);
  background: rgba(12, 4, 10, 0.35);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.modal.ym-premium-modal .modal-title {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-family: "Montserrat", "Circe", sans-serif;
  font-weight: 800;
  font-size: clamp(0.82rem, 2.8vw, 0.95rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ym-player-accent) 62%, white);
  text-shadow: 0 0 22px color-mix(in srgb, var(--ym-player-accent) 30%, transparent);
}

.modal.ym-premium-modal .modal-body {
  padding: clamp(1rem, 3.2vw, 1.25rem) clamp(1.1rem, 3.5vw, 1.35rem);
}

.modal.ym-premium-modal .modal-body p {
  margin: 0;
  color: rgba(232, 220, 225, 0.88);
  line-height: 1.55;
  font-size: 0.95rem;
}

.modal.ym-premium-modal .modal-footer {
  border-top: 1px solid color-mix(in srgb, var(--ym-player-accent) 18%, transparent);
  padding: clamp(0.85rem, 2.8vw, 1.15rem) clamp(1.1rem, 3.5vw, 1.35rem)
    clamp(1.1rem, 3.5vw, 1.35rem);
  background: rgba(8, 3, 8, 0.28);
}

.modal.ym-premium-modal .btn-primary {
  border-radius: 50px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.88rem;
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  border: none;
  background: linear-gradient(180deg, #2F9AFF 0%, #2C90EE 47.12%, #2478C6 100%);
  box-shadow: 0 8px 28px color-mix(in srgb, var(--ym-player-accent) 35%, transparent);
}

.modal.ym-premium-modal .btn-primary:hover {
  filter: brightness(1.06);
  box-shadow: 0 10px 34px color-mix(in srgb, var(--ym-player-accent) 42%, transparent);
}

.modal.ym-premium-modal .btn-primary:focus-visible {
  outline: 2px solid rgba(255, 212, 120, 0.85);
  outline-offset: 2px;
}

.modal.ym-premium-modal .btn-secondary {
  border-radius: 18px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.88rem;
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  border: 1px solid color-mix(in srgb, var(--ym-player-accent) 38%, transparent);
  background: rgba(14, 6, 12, 0.72);
  color: rgba(248, 238, 242, 0.94) !important;
  box-shadow: none;
}

.modal.ym-premium-modal .btn-secondary:hover {
  background: color-mix(in srgb, var(--ym-player-accent) 14%, transparent);
  border-color: color-mix(in srgb, var(--ym-player-accent) 52%, transparent);
  color: #fff !important;
}

.modal.ym-premium-modal .btn-secondary:focus-visible {
  outline: 2px solid rgba(255, 212, 120, 0.85);
  outline-offset: 2px;
}

.modal.ym-premium-modal .btn-close {
  flex-shrink: 0;
  margin-top: 0.1rem;
  opacity: 0.82;
}

body:has(main.quiz-task-screen--player.ym-premium-player) .modal-backdrop.show {
  --bs-backdrop-opacity: 1;
  opacity: 1 !important;
  background-color: rgba(4, 1, 8, 0.94) !important;
}

body:has(.modal.ym-premium-modal.show) .modal-backdrop.show {
  background-color: rgba(3, 1, 6, 0.96) !important;
}
