/* ==========================================================================
   НЕЙРО-ШОУ · День 3 · МЦ «Волга»
   Общая дизайн-система для всех станций (викторина, своя игра, мини-игры...).
   Тёмная «аркадная» тема — читается на проекторе, вайб как в Kahoot/игровом шоу.
   В одной семье со стилем лагеря (красный Roblox + голубой акцент).

   Всё работает ОФЛАЙН: шрифты берём системные (если нет интернета — всё равно
   красиво). Меняешь переменные вверху — меняется везде.
   ========================================================================== */

/* Пытаемся подтянуть весёлый шрифт, но не ломаемся без интернета */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700;800;900&family=Nunito:wght@600;700;800;900&display=swap');

:root {
  /* --- фирменные цвета (семья лагеря) --- */
  --red:      #E2231A;   /* красный Roblox */
  --red-dk:   #A6120C;
  --blue:     #00A2FF;   /* голубой акцент */
  --blue-dk:  #0072C6;
  --yellow:   #FFC400;
  --yellow-dk:#C98A00;
  --green:    #22C55E;
  --green-dk: #15803D;
  --purple:   #A855F7;
  --pink:     #FF4D9D;

  /* --- фон (тёмная аркада) --- */
  --bg-0:  #0B0F1E;      /* самый тёмный */
  --bg-1:  #121933;      /* панели */
  --bg-2:  #1B2447;      /* карточки */
  --line:  rgba(255,255,255,.10);

  /* --- текст --- */
  --ink:   #F4F7FF;      /* основной светлый текст */
  --muted: #9AA6CC;      /* приглушённый */

  --radius:   26px;
  --radius-sm:16px;
  --shadow:   0 20px 50px rgba(0,0,0,.45);
  --glow-blue:  0 0 40px rgba(0,162,255,.55);
  --glow-green: 0 0 45px rgba(34,197,94,.6);

  --font-head: 'Montserrat', system-ui, 'Segoe UI', Roboto, sans-serif;
  --font-body: 'Nunito', system-ui, 'Segoe UI', Roboto, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html, body { height: 100%; }

body {
  font-family: var(--font-body);
  color: var(--ink);
  background:
    radial-gradient(1200px 800px at 15% -10%, rgba(0,162,255,.20), transparent 60%),
    radial-gradient(1100px 700px at 100% 0%, rgba(226,35,26,.18), transparent 55%),
    radial-gradient(900px 900px at 50% 120%, rgba(168,85,247,.18), transparent 60%),
    var(--bg-0);
  min-height: 100%;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Мягко «дышащий» фон — лёгкое движение, чтобы экран не был мёртвым */
body::before {
  content: "";
  position: fixed; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(circle at 50% 40%, #000, transparent 85%);
  pointer-events: none;
  z-index: 0;
}

h1,h2,h3,.h { font-family: var(--font-head); font-weight: 900; line-height: 1.02; letter-spacing: -.02em; }
a { color: inherit; text-decoration: none; }
button, input { font-family: inherit; }

/* ==========================================================================
   СЦЕНА — полноэкранный контейнер одного «слайда»
   ========================================================================== */
.stage {
  position: relative; z-index: 1;
  min-height: 100vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: clamp(20px, 4vw, 60px);
  /* нижний отступ, чтобы контент не прятался за плавающим HUD снизу */
  padding-bottom: clamp(104px, 14vh, 150px);
  text-align: center;
}

/* Крупная типографика под проектор */
.kicker {
  display: inline-block;
  font-family: var(--font-head); font-weight: 800;
  font-size: clamp(14px, 1.5vw, 20px);
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--blue);
  background: rgba(0,162,255,.12);
  border: 1px solid rgba(0,162,255,.35);
  padding: 8px 18px; border-radius: 999px;
  margin-bottom: 22px;
}
.title-xl { font-size: clamp(38px, 7vw, 104px); text-wrap: balance; }
.title-lg { font-size: clamp(30px, 5.2vw, 72px); text-wrap: balance; }
.title-md { font-size: clamp(24px, 3.6vw, 48px); text-wrap: balance; }
.lead     { font-size: clamp(18px, 2.4vw, 30px); color: var(--muted); max-width: 60ch; margin: 18px auto 0; }

.grad-red  { background: linear-gradient(100deg,#FF6A5E,var(--red));   -webkit-background-clip:text; background-clip:text; color:transparent; }
.grad-blue { background: linear-gradient(100deg,#7FE0FF,var(--blue));  -webkit-background-clip:text; background-clip:text; color:transparent; }
.grad-rainbow { background: linear-gradient(100deg,#FF6A5E,var(--yellow),var(--green),var(--blue),var(--purple)); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ==========================================================================
   КНОПКИ — объёмные «геймерские» (низ с толщиной, как в игре)
   ========================================================================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5em;
  font-family: var(--font-head); font-weight: 800;
  font-size: clamp(16px, 1.8vw, 22px);
  padding: 16px 30px; border-radius: 999px;
  border: none; cursor: pointer; color: #fff;
  background: var(--blue);
  box-shadow: 0 6px 0 var(--blue-dk), var(--shadow);
  transition: transform .1s ease, box-shadow .1s ease, filter .2s ease;
  user-select: none;
}
.btn:hover  { transform: translateY(-2px); filter: brightness(1.06); box-shadow: 0 8px 0 var(--blue-dk), var(--shadow); }
.btn:active { transform: translateY(4px); box-shadow: 0 2px 0 var(--blue-dk); }
.btn.red    { background: var(--red);    box-shadow: 0 6px 0 var(--red-dk), var(--shadow); }
.btn.red:active{ box-shadow: 0 2px 0 var(--red-dk); }
.btn.green  { background: var(--green);  box-shadow: 0 6px 0 var(--green-dk), var(--shadow); }
.btn.green:active{ box-shadow: 0 2px 0 var(--green-dk); }
.btn.yellow { background: var(--yellow); color:#1a1400; box-shadow: 0 6px 0 var(--yellow-dk), var(--shadow); }
.btn.ghost  { background: rgba(255,255,255,.07); box-shadow: none; border: 2px solid var(--line); }
.btn.lg     { font-size: clamp(20px, 2.4vw, 30px); padding: 20px 44px; }
.btn.sm     { font-size: 15px; padding: 10px 18px; }
.btn:disabled { opacity: .4; cursor: not-allowed; transform: none; }

/* ==========================================================================
   ПЛИТКИ-ОТВЕТЫ — классика Kahoot: 4 цвета × 4 фигуры
   ========================================================================== */
.answers {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(12px, 1.6vw, 22px);
  width: min(1100px, 94vw); margin-top: clamp(20px, 3vh, 40px);
}
.answers.one-col { grid-template-columns: 1fr; }

.tile {
  --c: var(--blue); --cd: var(--blue-dk);
  position: relative; display: flex; align-items: center; gap: 18px;
  text-align: left;
  font-family: var(--font-head); font-weight: 800;
  font-size: clamp(18px, 2.2vw, 30px); color: #fff;
  padding: clamp(18px, 2.4vw, 30px) clamp(20px, 2.4vw, 32px);
  border-radius: var(--radius-sm);
  background: var(--c);
  box-shadow: 0 8px 0 var(--cd), var(--shadow);
  cursor: pointer; border: none;
  transition: transform .12s ease, box-shadow .12s ease, opacity .25s ease, filter .25s ease;
  min-height: 92px;
}
.tile:hover  { transform: translateY(-3px); box-shadow: 0 11px 0 var(--cd), var(--shadow); }
.tile:active { transform: translateY(5px); box-shadow: 0 3px 0 var(--cd); }
.tile .shape { font-size: 1.15em; line-height: 1; flex: 0 0 auto; filter: drop-shadow(0 2px 0 rgba(0,0,0,.25)); }
.tile .txt   { flex: 1 1 auto; }

.tile.c-red    { --c:var(--red);    --cd:var(--red-dk); }
.tile.c-blue   { --c:var(--blue);   --cd:var(--blue-dk); }
.tile.c-yellow { --c:var(--yellow); --cd:var(--yellow-dk); color:#1a1400; }
.tile.c-green  { --c:var(--green);  --cd:var(--green-dk); }

/* Состояния после reveal */
.answers.revealed .tile { cursor: default; }
.answers.revealed .tile:not(.correct) { opacity: .28; filter: grayscale(.6); transform: none; box-shadow: 0 4px 0 var(--cd); }
.tile.correct {
  animation: tile-correct .5s ease both;
  box-shadow: 0 8px 0 var(--cd), var(--glow-green);
  outline: 4px solid #fff;
}
.tile.correct::after {
  content: "✓"; position: absolute; top: -14px; right: -12px;
  width: 46px; height: 46px; border-radius: 50%;
  background: #fff; color: var(--green-dk);
  display: grid; place-items: center; font-size: 26px; font-weight: 900;
  box-shadow: var(--shadow);
}
.tile.wrong-pick { animation: shake .4s ease both; }
.tile.wrong-pick::after {
  content: "✕"; position: absolute; top: -14px; right: -12px;
  width: 46px; height: 46px; border-radius: 50%;
  background: #fff; color: var(--red); display: grid; place-items: center;
  font-size: 24px; font-weight: 900; box-shadow: var(--shadow);
}

/* ==========================================================================
   ПАНЕЛЬ ВОПРОСА / КАРТОЧКА
   ========================================================================== */
.qcard {
  width: min(1100px, 94vw);
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(24px, 4vw, 54px);
}
.panel {
  background: rgba(255,255,255,.05);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(18px, 2.5vw, 32px);
}

/* «Плашка» / бейдж */
.pill {
  display: inline-flex; align-items: center; gap: .5em;
  font-family: var(--font-head); font-weight: 800; font-size: clamp(13px,1.4vw,17px);
  padding: 8px 16px; border-radius: 999px;
  background: rgba(255,255,255,.08); border: 1px solid var(--line);
}
.pill.blue  { background: rgba(0,162,255,.16);  border-color: rgba(0,162,255,.4);  color:#8fd8ff; }
.pill.green { background: rgba(34,197,94,.16);  border-color: rgba(34,197,94,.4);  color:#8ff0b4; }
.pill.red   { background: rgba(226,35,26,.16);  border-color: rgba(226,35,26,.4);  color:#ff9a94; }
.pill.yellow{ background: rgba(255,196,0,.16);  border-color: rgba(255,196,0,.45); color:#ffd85e; }

/* ==========================================================================
   ТАЙМЕР-ПОЛОСА
   ========================================================================== */
.timerbar {
  width: min(1100px, 94vw); height: 16px; border-radius: 999px;
  background: rgba(255,255,255,.1); overflow: hidden; margin: 18px auto 0;
  border: 1px solid var(--line);
}
.timerbar > i {
  display: block; height: 100%; width: 100%;
  background: linear-gradient(90deg, var(--green), var(--yellow), var(--red));
  transform-origin: left center;
  transition: transform .1s linear;
}
.timer-num {
  font-family: var(--font-head); font-weight: 900;
  font-size: clamp(40px, 8vw, 120px); line-height: 1;
  font-variant-numeric: tabular-nums;
}
.timer-num.danger { color: var(--red); animation: pulse .5s ease infinite; }

/* ==========================================================================
   ТАБЛО КОМАНД (мини, в углу)
   ========================================================================== */
.scorebar {
  position: fixed; top: 14px; right: 14px; z-index: 30;
  display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end;
  max-width: 60vw;
}
.team-chip {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-1); border: 1px solid var(--line);
  border-radius: 999px; padding: 8px 14px 8px 10px;
  font-family: var(--font-head); font-weight: 800; font-size: clamp(13px,1.4vw,18px);
  box-shadow: var(--shadow);
}
.team-chip .dot { width: 16px; height: 16px; border-radius: 50%; flex: 0 0 auto; }
.team-chip .sc  { min-width: 1.8em; text-align: right; font-variant-numeric: tabular-nums; }

/* ==========================================================================
   ВЕРХНЯЯ/НИЖНЯЯ СЛУЖЕБНАЯ ПАНЕЛЬ
   ========================================================================== */
.topbar {
  position: fixed; top: 14px; left: 14px; z-index: 30;
  display: flex; align-items: center; gap: 10px;
}
.hud {
  position: fixed; bottom: 14px; left: 50%; transform: translateX(-50%);
  z-index: 30; display: flex; align-items: center; gap: 10px;
  background: rgba(11,15,30,.72); backdrop-filter: blur(8px);
  border: 1px solid var(--line); border-radius: 999px; padding: 8px 12px;
}
.hud .counter { font-family: var(--font-head); font-weight: 800; color: var(--muted); padding: 0 8px; }
.icon-btn {
  width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center;
  background: var(--bg-1); border: 1px solid var(--line); color: var(--ink);
  cursor: pointer; font-size: 20px; transition: transform .1s, background .2s;
}
.icon-btn:hover { background: var(--bg-2); transform: translateY(-2px); }
.icon-btn.big { width: 64px; height: 64px; font-size: 26px; }

/* Прогресс-точки */
.dots { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.dots i { width: 12px; height: 12px; border-radius: 50%; background: rgba(255,255,255,.18); }
.dots i.done { background: var(--blue); }
.dots i.now  { background: #fff; transform: scale(1.35); box-shadow: var(--glow-blue); }

/* ==========================================================================
   МЕМ-РЕАКЦИЯ (всплывашка снизу)
   ========================================================================== */
.reaction {
  position: fixed; left: 50%; bottom: 108px; transform: translateX(-50%) translateY(30px);
  z-index: 60; opacity: 0; pointer-events: none;
  font-family: var(--font-head); font-weight: 900; font-size: clamp(22px, 3vw, 40px);
  padding: 16px 30px; border-radius: 999px;
  background: linear-gradient(100deg, var(--purple), var(--pink));
  box-shadow: var(--shadow), 0 0 40px rgba(255,77,157,.5);
  transition: opacity .25s ease, transform .35s cubic-bezier(.2,1.4,.4,1);
  white-space: nowrap;
}
.reaction.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.reaction.aura-plus  { background: linear-gradient(100deg, var(--green), #7CF5A6); }
.reaction.aura-minus { background: linear-gradient(100deg, var(--red), #FF8A80); }

/* ==========================================================================
   АНИМАЦИИ
   ========================================================================== */
@keyframes pop-in   { 0%{opacity:0; transform: translateY(24px) scale(.96);} 100%{opacity:1; transform:none;} }
@keyframes tile-correct { 0%{transform:scale(1);} 40%{transform:scale(1.06);} 100%{transform:scale(1.03);} }
@keyframes shake    { 0%,100%{transform:translateX(0);} 20%{transform:translateX(-10px);} 40%{transform:translateX(9px);} 60%{transform:translateX(-7px);} 80%{transform:translateX(5px);} }
@keyframes pulse    { 0%,100%{transform:scale(1);} 50%{transform:scale(1.08);} }
@keyframes floaty   { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-14px);} }
@keyframes spin     { to { transform: rotate(360deg); } }
@keyframes glow-ring{ 0%,100%{box-shadow:0 0 0 0 rgba(0,162,255,.5);} 50%{box-shadow:0 0 0 18px rgba(0,162,255,0);} }

.animate-in  { animation: pop-in .5s ease both; }
.d1{animation-delay:.06s}.d2{animation-delay:.12s}.d3{animation-delay:.18s}.d4{animation-delay:.24s}.d5{animation-delay:.3s}
.floaty { animation: floaty 4s ease-in-out infinite; }
.hidden { display: none !important; }

/* Конфетти-канвас (общий) */
#confetti { position: fixed; inset: 0; pointer-events: none; z-index: 80; }

/* Большая эмодзи-иллюстрация вместо картинок (работает офлайн) */
.big-emoji { font-size: clamp(70px, 16vw, 220px); line-height: 1; filter: drop-shadow(0 12px 30px rgba(0,0,0,.5)); }

/* Клавиша-подсказка */
kbd {
  font-family: var(--font-head); font-weight: 800; font-size: .85em;
  background: rgba(255,255,255,.1); border: 1px solid var(--line);
  border-bottom-width: 3px; border-radius: 8px; padding: 3px 9px; color: var(--ink);
}

/* Прячем HUD, если ведущий хочет чистый экран (класс на body) */
body.clean .topbar, body.clean .hud, body.clean .scorebar { opacity: 0; pointer-events: none; }

/* Уважаем «уменьшить движение» */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
