/* PictoParty — Dark UI design system */
:root {
  --gap-xxs: .5rem;
  --gap-xs: .75rem;
  --gap-sm: 1rem;
  --gap-md: 1.5rem;
  --gap-lg: 2rem;

  --bg: #0f1220;
  --card: #171a2b;
  --border: rgba(255,255,255,0.08);
  --text: #e6e8ff;
  --muted: #a0a7c7;

  --accent: #6c5ce7;
  --accent-2: #a29bfe;
  --success: #00d4a6;
  --warning: #ffb86b;

  --radius-sm: .5rem;
  --radius-md: .75rem;
  --radius-lg: 1rem;

  --shadow-1: 0 6px 20px rgba(0,0,0,.35);
  --shadow-2: 0 2px 8px rgba(0,0,0,.25);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 18px;
}

a { color: inherit; text-decoration: none; }
#nameError.hidden, #scoresPanel.hidden, #gamePanel.hidden, #secret.hidden, #notDrawerHint.hidden, #modalNameError.hidden, #nameModal.hidden { display: none !important; }
.players-meta .small { font-size: .875rem; }
#gamePanel .muted.small { color: var(--muted); font-size: .875rem; }
#lobbyPanel .mode-desc.muted { color: var(--muted); }
#nameModal .muted { color: var(--muted); }
#nameModal .mt-sm { margin-top: var(--gap-sm); }
/* Удалены общие классы .maxw-640, .align-center, .mono - заменены на специфичные селекторы при необходимости */

/* Layout */
/* Комната/игра занимают ровно высоту экрана и НЕ скроллят body — внутренняя прокрутка
   только там, где нужно (список игроков, чат). Так контент всегда помещается на экран. */
.page-room { display: grid; grid-template-rows: auto 1fr; height: 100vh; height: 100dvh; min-height: 0; overflow: hidden; }
.site-header { padding: clamp(.5rem, 1.6vh, 1.2rem) 1.5rem; border-bottom: 1px solid var(--border); background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0)); }
.brand { margin: 0; font-size: clamp(1.4rem, 3.2vh, 2.2rem); letter-spacing: .5px; font-weight: 700; }
.site-footer { padding: .75rem 1rem; border-top: 1px solid var(--border); color: var(--muted); }
.container { padding: 1.5rem; }
.page-center { min-height: 100vh; display:flex; align-items:center; justify-content:center; padding: 32px; }
.card-landing {
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
}
/* Центрирование с учётом хедера на главной */
.page-index .page-center { min-height: calc(100vh - 64px); }

/* Логотип на главной и в комнате — одинаковый размер (масштабируется по высоте экрана) */
.page-index .brand { font-size: 2.2rem; font-weight: 700; }
.page-room .brand { font-size: clamp(1.4rem, 3.2vh, 2.2rem); font-weight: 700; }

/* Визуал карточки на лендинге */
.page-index .card-landing h2 { text-align: center; margin: 0; margin-bottom: 1rem; font-size: 1.8rem; }

/* Инпут на лендинге */
#displayName {
  padding: 1rem 1.2rem;
  margin: 0.7rem 0;
  font-size: 1.3rem;
  height: 55px;
  box-sizing: border-box;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: #12162a;
  color: var(--text);
}
/* Общие стили для всех кнопок */
button, .btn, #btnStart, #btnInvite, #btnStartGame, #btnToolToggle, #chatForm button, #btnEnterName {
  padding: 1rem 1.5rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: #1d2135;
  color: var(--text);
  cursor: pointer;
  transition: transform .06s ease, background .15s ease, box-shadow .15s ease, opacity .15s ease;
  height: 56px;
  box-sizing: border-box;
  font-weight: 600;
  font-size: 1.1rem;
  min-width: 200px;
  width: auto;
  align-self: center;
}

button:hover, .btn:hover, #btnStart:hover, #btnInvite:hover, #btnStartGame:hover, #btnToolToggle:hover, #chatForm button:hover, #btnEnterName:hover {
  background: #232844;
}

button:active, .btn:active, #btnStart:active, #btnInvite:active, #btnStartGame:active, #btnToolToggle:active, #chatForm button:active, #btnEnterName:active {
  transform: translateY(1px);
}

/* Модификаторы кнопок */
button.primary, .btn.primary, #btnStart.primary, #btnStartGame.primary, #btnEnterName.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  box-shadow: 0 0 0 0 rgba(108,92,231,0);
}

button.primary:hover, .btn.primary:hover, #btnStart.primary:hover, #btnStartGame.primary:hover, #btnEnterName.primary:hover {
  box-shadow: 0 6px 18px rgba(108,92,231,.35);
}

button.secondary, .btn.secondary, #btnInvite.secondary {
  background: #222740;
  border-color: #2d3357;
}

button[disabled], .btn[disabled], #btnStartGame[disabled] {
  opacity: .55;
  cursor: not-allowed;
  box-shadow: none;
}

.room-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--gap-sm); padding: var(--gap-sm); }
/* В лобби центрируем рамку (через margin:auto — безопасно при переполнении, не режет верх) */
.room-grid.lobby-mode {
  display: flex;
  min-height: 0;
  height: 100%;
  overflow: hidden;
  padding: var(--gap-sm);
}

/* Скрываем таймер и чат в режиме лобби - исправленные селекторы */
.room-grid.lobby-mode .site-header .timer,
.room-grid.lobby-mode .site-header .timer.hidden { display: none !important; }
.room-grid.lobby-mode #chat { display: none !important; }
.stage { display: flex; flex-direction: column; gap: var(--gap-sm); grid-column: 1 / 3; }
.side { display: flex; flex-direction: column; gap: var(--gap-sm); }

/* Контейнер внешней рамки и грид раскладки лобби */
.lobby-frame {
  width: 100%;
  max-width: 1120px;
  max-height: 100%;
  margin: auto;
  padding: 0;
  border: none; /* убираем обводку */
  border-radius: 1.2rem;
  background: transparent;
  box-shadow: none; /* убираем тени */
  display: flex;
  min-height: 0;
}
.lobby-container {
  display: grid;
  grid-template-columns: minmax(0, 460px) 1fr;
  gap: 1.25rem;
  align-items: stretch;
  width: 100%;
  max-height: 100%;
  min-height: 0;
}

.lobby-container .lobby-left, .lobby-container .lobby-right {
  flex: 1;
  max-width: none;
}

.site-header .row { display: flex; align-items: center; }
.site-header .row.wrap { flex-wrap: wrap; }
.site-header .spacer { flex: 1 1 auto; }
#startForm.stack { display: flex; flex-direction: column; }
#nameModal .modal-dialog.stack { display: flex; flex-direction: column; }
.players-meta.row { display: flex; align-items: center; }
.players-meta.gap-sm { gap: var(--gap-sm); }
.select-wrap .row { display: flex; align-items: center; }
.select-wrap .gap-xs { gap: var(--gap-xs); }
#chatForm.row { display: flex; align-items: center; }
#chatForm.gap-xs { gap: var(--gap-xs); }
#nameModal .row { display: flex; align-items: center; }
#nameModal .gap-sm { gap: var(--gap-sm); }
#startForm.gap-sm { gap: var(--gap-sm); }
#startForm.gap-md { gap: var(--gap-md); }
.drawing-area .row { display: flex; align-items: center; }
.drawing-area .gap-sm { gap: var(--gap-sm); }
.drawing-area .wrap { flex-wrap: wrap; }
.drawing-area .spacer { flex: 1 1 auto; }
.drawing-area .gap-xs { gap: var(--gap-xs); }

/* Specific card selectors */
.page-index .card-landing {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 1.5rem;
  padding: 2.2rem;
  box-shadow: var(--shadow-2);
}

/* Переключатель видимости комнаты на лендинге */
.visibility-row {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  cursor: pointer;
  padding: .2rem 0 .4rem;
}
.visibility-row input[type="checkbox"] {
  width: 22px; height: 22px;
  margin-top: 2px;
  accent-color: var(--accent);
  flex: 0 0 auto;
  cursor: pointer;
}
.visibility-text { display: flex; flex-direction: column; gap: 2px; font-weight: 600; }
.visibility-text .muted { font-weight: 400; font-size: .85rem; color: var(--muted); }

/* Глобальный список открытых комнат */
.public-rooms { margin-top: 1.25rem; border-top: 1px solid var(--border); padding-top: 1rem; }
.public-rooms__title { margin: 0 0 .75rem; font-size: 1.1rem; text-align: center; }
.public-rooms__list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: .5rem;
  max-height: 320px; overflow-y: auto;
}
.public-rooms__empty { text-align: center; margin: .25rem 0 0; }
.public-rooms__empty.hidden { display: none; }
.public-room {
  display: flex; align-items: center; justify-content: space-between;
  gap: .75rem; padding: .6rem .8rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: .75rem;
}
.public-room__info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.public-room__code { font-weight: 700; letter-spacing: .5px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.public-room__count { color: var(--muted); font-size: .85rem; font-variant-numeric: tabular-nums; }
.public-room__join.btn {
  min-width: auto; width: auto; height: auto;
  padding: .5rem 1.2rem; font-size: 1rem; flex: 0 0 auto; margin: 0;
}

#scoresPanel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 1.5rem;
  padding: 2.2rem;
  box-shadow: var(--shadow-2);
}

.modal-dialog {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 1.5rem;
  padding: 2.2rem;
  box-shadow: var(--shadow-2);
}

/* Specific lobby card selectors */
#playersWrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 1.2rem;
  box-shadow: var(--shadow-2);
  display: flex;
  flex-direction: column;
  /* Высота под экран: до 702px на больших мониторах, меньше на низких — список прокручивается внутри */
  height: min(702px, calc(100dvh - 120px));
  max-height: calc(100dvh - 120px);
  min-height: 0;
  padding: 0;
}
#playersWrap h3 {
  margin: 0;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--border);
  font-size: 1.5rem;
  text-align: center;
  flex-shrink: 0;
}

#lobbyPanel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 1.2rem;
  box-shadow: var(--shadow-2);
  display: flex;
  flex-direction: column;
  /* Та же логика, что у окна игроков: фит по экрану + внутренняя прокрутка при нехватке высоты */
  height: min(702px, calc(100dvh - 120px));
  max-height: calc(100dvh - 120px);
  min-height: 0;
  overflow-y: auto;
  padding: 1.5rem;
  max-width: none;
  margin: 0;
}
#lobbyPanel h3 {
  margin: 0 -1.5rem 1.5rem -1.5rem;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--border);
  font-size: 1.5rem;
  text-align: center;
  flex-shrink: 0;
}
#modeGuess.mode-card {
  width: 100%;
  border: 2px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  border-radius: 1rem;
  padding: .9rem 1.1rem;
  transition: box-shadow .2s ease, border-color .2s ease;
  cursor: pointer;
}
#modeGuess.mode-card.selected {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(108,92,231,.18), 0 10px 26px rgba(0,0,0,.35);
  background: rgba(108,92,231,.06);
}
#modeGuess.mode-card:hover {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(108,92,231,.18);
}
#modeGuess .mode-title {
  text-align: center;
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: .5rem;
}
#modeGuess .mode-desc {
  font-size: 1rem;
  line-height: 1.4;
}

/* Убираем старый селектор */
#playersWrap .max-players-selector {
  display: none;
}


/* Переключатель видимости комнаты в лобби (только владелец) */
.lobby-visibility {
  display: flex; align-items: flex-start; gap: .6rem;
  margin: 1rem 0 0; padding: .6rem .8rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: .75rem;
  cursor: pointer;
  font-weight: 600;
}
.lobby-visibility input[type="checkbox"] {
  width: 22px; height: 22px; margin-top: 2px;
  accent-color: var(--accent); flex: 0 0 auto; cursor: pointer;
}
.lobby-visibility input:disabled { cursor: not-allowed; }
.lobby-visibility.is-readonly { opacity: .7; cursor: default; }
.lobby-visibility.is-readonly input { cursor: default; }

/* Ряд действий лобби — кнопки равной ширины и центрированы */
#lobbyPanel .lobby-actions {
  display: flex;
  justify-content: center;
  gap: 2.5rem; /* еще больше отступ между кнопками */
  margin-top: auto;
}

/* Specific toast selectors */
#toast {
  position: fixed; left: 50%; transform: translateX(-50%);
  bottom: 1rem; background: rgba(12,14,24,.95);
  color: #fff; padding: .6rem .85rem; border-radius: .6rem;
  box-shadow: var(--shadow-1); opacity: 0; pointer-events: none;
  transition: opacity .2s ease; z-index: 1000;
}
#toast.show { opacity: 1; }

/* Панель метаинформации игроков */
#playersWrap .players-meta {
  padding: .6rem .85rem;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
#playersCounter.badge {
  background: rgba(255,255,255,.08);
  border: 1px solid var(--border);
  padding: .25rem .5rem;
  border-radius: .65rem;
  font-weight: 700;
  color: #8cf5e6;
  letter-spacing: .5px;
}
.players-meta .select-wrap { position: relative; z-index: 2; }
.players-meta .select-wrap select {
  appearance: none;
  background: #12162a;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: .5rem;
  padding: .35rem .55rem;
}
#playersWrap .players-list-container {
  flex: 1;
  overflow-y: auto;
  padding: 0;
}
details#playersWrap > summary { cursor: pointer; padding: 1rem 1.2rem; border-bottom: 1px solid var(--border); user-select: none; font-size: 1.1rem; }
#playersList.players-list { list-style: none; margin: 0; padding: 0; }
#playersList.players-list li {
  display: grid; grid-template-columns: auto 1fr auto; gap: 1rem; align-items: center;
  padding: 1rem 1.2rem; border-top: 1px solid var(--border);
  min-height: 60px;
}
#playersList.players-list li:first-child { border-top: 0; }
#playersList.players-list li.empty-slot { opacity: .5; }
#playersList .player-avatar { width: 57px; height: 57px; border-radius: 50%; display: grid; place-items: center; background: #222744; border: 1px solid var(--border); font-size: 1.2rem; }
#playersList .player-name { font-weight: 600; font-size: 1.1rem; }
#playersList .player-extra { font-variant-numeric: tabular-nums; color: var(--accent-2); font-size: 1.1rem; }
#playersList .crown { margin-left: .5rem; }

/* Модальное окно для выбора игроков */
#playerCountModal.player-count-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
#playerCountModal.player-count-modal.hidden {
  display: none;
}
#playerCountModal .player-count-dialog {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 1rem;
  padding: 2rem;
  min-width: 300px;
}
#playerCountModal .player-count-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin: 1rem 0;
}
#playerCountModal .player-count-option {
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: #1d2135;
  color: var(--text);
  cursor: pointer;
  text-align: center;
  transition: all 0.2s ease;
}
#playerCountModal .player-count-option:hover {
  border-color: var(--accent);
  background: rgba(108,92,231,0.1);
}
#playerCountModal .player-count-option.selected {
  border-color: var(--accent);
  background: rgba(108,92,231,0.2);
}

/* Scores */
#scores.scores { display: grid; grid-template-columns: 1fr; gap: .35rem; }
#scores.scores .score-row { display: grid; grid-template-columns: auto 1fr auto; gap: .6rem; align-items: center; }

/* Drawing area — холст масштабируется под доступную ширину И высоту экрана (4:3),
   но не больше 800px. Внутренний буфер остаётся 800x600, координаты считаются
   относительно реального размера (getBoundingClientRect), поэтому рисование точное. */
.camera-canvas-container {
  position: relative;
  width: min(800px, 100%, calc((100dvh - 250px) * 4 / 3));
  aspect-ratio: 4 / 3;
  height: auto;
  min-width: 0;
  max-width: 100%;
  margin: 0 auto var(--gap-sm);
  flex-shrink: 1;
}

#gamePanel .drawing-area {
  background: transparent;
  border: none;
  border-radius: var(--radius-lg);
  touch-action: none; /* блокируем нативный жестовый скролл/зуум вокруг холста */
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2; /* холст поверх камеры */
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 0 !important;
  max-height: none !important;
}
#drawCanvas {
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 0 !important;
  max-height: none !important;
  background: transparent; /* прозрачный фон, чтобы destination-out пробивал до камеры */
  touch-action: none; cursor: crosshair;
  border-radius: var(--radius-lg);
  /* opacity на холсте НЕ задаём: иначе чёрная линия становится полупрозрачной.
     Камера затемняется отдельным белым оверлеем .camera-preview::after. */
}
#gamePanel .camera-preview {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 0 !important;
  max-height: none !important;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
#cameraPreview {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scaleX(-1);
}
/* White semi-transparent overlay over camera (does not affect canvas drawing/erasing) */
#gamePanel .camera-preview::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.5);
  border-radius: inherit;
  pointer-events: none;
}

/* Chat */
#chat.chat { display: flex; flex-direction: column; border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden; min-height: 260px; background: var(--card); }
#messages.messages { flex: 1 1 auto; overflow: auto; padding: .6rem; display: flex; flex-direction: column; gap: .5rem; }
#messages .msg { display: grid; grid-template-columns: auto 1fr; gap: .5rem; }
#messages .msg .avatar { width: 47px; height: 47px; border-radius: 50%; display: grid; place-items: center; background: #222744; border: 1px solid var(--border); }
#messages .msg .bubble { background: rgba(255,255,255,0.04); border: 1px solid var(--border); border-radius: .6rem; padding: .35rem .55rem; }
#messages .msg .meta { font-size: .8rem; color: var(--muted); margin-bottom: .1rem; }
#chatForm { border-top: 1px solid var(--border); padding: .5rem; display: flex; gap: .5rem; background: rgba(0,0,0,.1); }
#chatInput { flex: 1 1 auto; padding: .55rem .6rem; border: 1px solid var(--border); border-radius: var(--radius-sm); background: #12162a; color: var(--text); }
#chatForm button { flex: 0 0 auto; }

/* Стиль для кнопки "Отправить" с классом primary */
#chatForm button.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

#chatForm button.primary:hover {
  box-shadow: 0 6px 18px rgba(108,92,231,.35);
}

/* Сетка guess-страницы: холст (гибкая колонка) + правая панель (очки + чат).
   Высота — ровно экран, колонки ужимаются, ничего не вылезает. */
#guessPage .room-grid {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: var(--gap-md);
  justify-content: center;
  align-items: stretch;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}
#guessPage .stage {
  grid-column: 1; /* холст в первой колонке */
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}
#guessPage .side {
  min-height: 0;
  overflow: hidden;
}

/* Таблица очков на guess-странице - компактная версия над чатом */
#guessPage #scoresPanel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 0.8rem;
  box-shadow: var(--shadow-2);
  flex-shrink: 0;
  height: 150px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

#guessPage #scoresPanel h3 {
  margin: 0 0 0.5rem 0;
  font-size: 1rem;
  text-align: center;
  flex-shrink: 0;
}

/* Компактные очки для guess-страницы */
#guessPage #scores.scores {
  display: grid;
  grid-template-columns: 1fr;
  gap: .2rem;
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  align-content: start;
}

#guessPage #scores.scores .score-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: .4rem;
  align-items: center;
  padding: .15rem 0;
}

#guessPage #scores .player-avatar {
  width: 37px;
  height: 37px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #222744;
  border: 1px solid var(--border);
  font-size: 0.8rem;
}

#guessPage #scores .player-name {
  font-weight: 600;
  font-size: 0.85rem;
}

#guessPage #scores .player-extra {
  font-variant-numeric: tabular-nums;
  color: var(--accent-2);
  font-size: 0.85rem;
  font-weight: 600;
}

/* Чат на guess-странице: занимает оставшуюся высоту колонки (под таблицей очков) */
#guessPage #chat.chat {
  flex: 1 1 auto;
  min-height: 120px;
  height: auto;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--card);
  margin-top: 8px; /* Небольшой отступ для точного выравнивания с холстом */
}

/* Сообщения чата: прокрутка + тёмный скроллбар как в лобби */
#guessPage #messages.messages {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: .6rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

/* Системная центрированная надпись в чате */
#guessPage #messages .notice {
  text-align: center;
  color: var(--muted);
  padding: .2rem 0;
}

/* Форма чата: фиксированная внизу */
#guessPage #chatForm {
  border-top: 1px solid var(--border);
  padding: .5rem;
  display: flex;
  gap: .5rem;
  background: rgba(0,0,0,.1);
  flex-shrink: 0;
}

#guessPage #chatInput {
  flex: 1;
  padding: .55rem .6rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: #12162a;
  color: var(--text);
}

#guessPage #chatForm button {
  flex-shrink: 0;
}

/* Компактная кнопка отправки в чате */
#chatForm button.chat-send-btn {
  min-width: auto;
  width: 56px;
  padding: 0.55rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  font-weight: 400;
}

/* Secret word */
#secret.secret { position: sticky; top: 0; background: rgba(255, 251, 235, .1); color: #ffe8a3; border: 1px solid rgba(252, 211, 77, .35); padding: .5rem .7rem; margin: .25rem 0; border-radius: var(--radius-md); z-index: 2; }

/* Inputs */
#modalName, #chatInput {
  padding: 1rem 1.2rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: #12162a;
  color: var(--text);
  height: 56px;
  box-sizing: border-box;
  font-size: 1.1rem;
}
.players-meta .muted.small { color: var(--muted); font-size: .9rem; }
#nameError.error-text, #modalNameError.error-text { color: #ff6b6b; }

/* Misc */
.site-header .timer { font-variant-numeric: tabular-nums; }
#notDrawerHint, #handsHint { padding: .2rem 0; color: var(--muted); }

/* Таймер рядом с кнопками инструментов на guess-странице */
#guessPage .pp-tools-row .timer {
  font-variant-numeric: tabular-nums;
  font-size: 1.3rem; /* Уменьшен в 1.5 раза от 2rem */
  font-weight: 600;
  color: var(--text);
  background: rgba(255,255,255,.05);
  padding: 0.5rem 0.8rem; /* Уменьшен в 1.5 раза от .8rem 1.2rem */
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  margin-left: auto; /* Прижимаем к правому краю */
}

/* Modal */
#nameModal.modal { position: fixed; inset: 0; display: grid; place-items: center; z-index: 1200; }
#nameModal.modal.hidden { display: none; }
#nameModal .modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.5); backdrop-filter: blur(2px); }
#nameModal .modal-dialog { position: relative; width: min(520px, calc(100% - 2rem)); box-shadow: var(--shadow-1); }

/* Общие стили для всех скроллбаров */
.scrollable,
#playersList.players-list,
.lobby-frame,
#modeGuess.mode-card,
#guessPage #messages.messages,
#guessPage #scores.scores {
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.25) transparent;
}

.scrollable::-webkit-scrollbar,
#playersList.players-list::-webkit-scrollbar,
.lobby-frame::-webkit-scrollbar,
#modeGuess.mode-card::-webkit-scrollbar,
#guessPage #messages.messages::-webkit-scrollbar,
#guessPage #scores.scores::-webkit-scrollbar {
  width: 6px;
}

.scrollable::-webkit-scrollbar-thumb,
#playersList.players-list::-webkit-scrollbar-thumb,
.lobby-frame::-webkit-scrollbar-thumb,
#modeGuess.mode-card::-webkit-scrollbar-thumb,
#guessPage #messages.messages::-webkit-scrollbar-thumb,
#guessPage #scores.scores::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.25);
  border-radius: 6px;
}

/* Drawing tools UI */
.pp-tools-row { display:flex; align-items:center; gap: var(--gap-sm); }
.pp-tools { display:flex; gap: 12px; margin-bottom: 8px; }
.pp-tool {
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background:#1d2135;
  color: var(--text);
  cursor: pointer;
  user-select: none;
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease, transform .06s ease;
}
.pp-tool:hover { background:#232844; }
.pp-tool:active { transform: translateY(1px); }
.pp-tool--active {
  border-color: var(--accent);
  background: rgba(108,92,231,.12);
  box-shadow: 0 0 0 2px rgba(108,92,231,0.18) inset;
}

/* Toggle (iOS-style) */
.pp-toggle { display: inline-flex; align-items:center; gap:8px; }
.pp-toggle input { display:none; }
.pp-toggle__label { display:inline-flex; align-items:center; gap:8px; cursor:pointer; }
.pp-toggle__slider {
  position: relative;
  width: 46px; height: 26px;
  background: #2d3357;
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: background .2s ease, border-color .2s ease;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.35);
}
.pp-toggle__slider::after {
  content: "";
  position: absolute;
  top: 2px; left: 2px;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.35);
  transition: transform .2s ease;
}
.pp-toggle input:checked + .pp-toggle__label .pp-toggle__slider {
  background: var(--accent);
  border-color: var(--accent);
}
.pp-toggle input:checked + .pp-toggle__label .pp-toggle__slider::after {
  transform: translateX(20px);
}
.pp-toggle__text { color: var(--text); font-size: .95rem; opacity: .9; }

/* Canvas gestures hardening */
#drawCanvas {
  touch-action: none;
  -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none;
  cursor: crosshair;
}

/* Responsive styles moved to mobile.css */
/* Disable text selection during draw */
.page-room #drawCanvas, .page-room #cameraPreview {
  -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none;
}
/* PP Modal — имя игрока */
.pp-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 9998;
  backdrop-filter: blur(1.5px);
}

.pp-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 9999;
  background: var(--card);
  color: var(--text);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
  width: min(420px, 90vw);
  max-width: 420px;
}

.pp-modal__content {
  padding: 20px 20px 16px;
  display: grid;
  gap: 12px;
}

.pp-modal__title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 2px 0;
}

.pp-modal__hint {
  color: #4a5277;
  font-size: 0.95rem;
  margin: 0 0 4px 0;
}

.pp-modal input[type="text"] {
  padding: 0.9rem 1rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #12162a;
  color: var(--text);
  font-size: 1.05rem;
  outline: none;
}

.pp-modal input[type="text"]::placeholder {
  color: var(--muted);
}

.pp-modal input[type="text"]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(108,92,231,0.18);
  background: #12162a;
}

.pp-modal__actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 8px;
}

.pp-modal__actions .primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.pp-modal__actions button[disabled] {
  opacity: .55;
  cursor: not-allowed;
}

/* Опционально: плавающая кнопка «Сменить имя» (по умолчанию скрыта) */
.pp-name-btn {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 9997;
  display: none;          /* включить через JS при необходимости */
  padding: .6rem .8rem;
  font-size: .95rem;
  border-radius: 999px;
}
/* === PictoParty: Countdown Overlay & Results Modal === */
.pp-overlay {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: var(--bg);
  z-index: 12000; /* выше основного UI */
  pointer-events: auto; /* блокирует взаимодействия под оверлеем */
  opacity: 1;
  transition: opacity 320ms ease;
}
.pp-overlay.hidden { display: none; }
.pp-overlay.fading { opacity: 0; }

.pp-countdown-digit {
  font-size: clamp(96px, 20vw, 240px);
  font-weight: 900;
  line-height: 1;
  color: #fff;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  animation: ppScale 800ms ease both;
  will-change: transform, opacity;
}

@keyframes ppScale {
  0% { opacity: 0; transform: scale(0.6); }
  60% { opacity: 1; transform: scale(1.05); }
  100% { opacity: 1; transform: scale(1.0); }
}


/* Results modal */
.pp-modal-results {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(0, 0, 0, 0.55);
  z-index: 12001; /* поверх оверлея */
}
.pp-modal-results.hidden { display: none; }

.pp-modal-results__dialog {
  width: min(520px, 92vw);
  max-height: min(80vh, 680px);
  overflow: auto;
  background: var(--card, #1e1e1e);
  color: inherit;
  border: 1px solid var(--border, rgba(255, 255, 255, 0.12));
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
}

.pp-modal-results__dialog h3 {
  text-align: center;
  margin: 0 0 16px 0;
  font-size: 1.5rem;
  font-weight: 700;
}

#ppWinnerLine {
  text-align: center;
  font-size: 1.2rem;
  font-weight: 600;
  margin-bottom: 20px;
  color: var(--success);
}

.pp-leaderboard {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 12px auto 8px auto;
  max-width: 300px;
  text-align: center;
}

.pp-leaderboard__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 16px;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  border: 1px solid var(--border);
}

.pp-results-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 12px;
}

/* При отключении инструментов на период отсчета */
.pp-tool[disabled],
button[disabled],
input[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Убедиться, что toasts/другие оверлеи не перекрывают модалку итогов */
.toast-container { z-index: 11000; }

/* === PictoParty: Cross-page Transition Cover === */
.pp-transition-cover {
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: 11999;               /* ниже оверлея отсчета (12000), но выше всего остального */
  opacity: 0;
  pointer-events: none;
  transition: opacity 240ms ease;
}
.pp-transition-cover.show {
  opacity: 1;
  pointer-events: auto;
}

/* ===== Кик игроков (меню «троеточие» у владельца) ===== */
/* В режиме владельца у строк появляется 4-я колонка под кнопку кика/заглушку */
#playersList.players-list.is-owner li { grid-template-columns: auto 1fr auto auto; }
.player-kick, .player-kick-spacer { width: 40px; display: flex; justify-content: center; position: relative; }
.player-kick__btn {
  width: 34px; height: 34px; min-width: 0; padding: 0; margin: 0;
  border-radius: 50%; border: 1px solid var(--border); background: transparent;
  color: var(--muted); font-size: 1.3rem; line-height: 1; cursor: pointer;
  display: grid; place-items: center;
}
.player-kick__btn:hover { background: rgba(255,255,255,.08); color: var(--text); }
.player-kick__menu {
  position: absolute; right: 0; top: calc(100% + 4px);
  background: var(--card); border: 1px solid var(--border); border-radius: .6rem;
  box-shadow: var(--shadow-1); z-index: 60; overflow: hidden; min-width: 180px;
}
.player-kick__menu.hidden { display: none; }
.player-kick__action {
  display: block; width: 100%; min-width: 0; height: auto; text-align: left;
  padding: .65rem .85rem; background: transparent; border: none; color: #ff6b6b;
  cursor: pointer; font-size: .95rem; font-weight: 600;
}
.player-kick__action:hover { background: rgba(255,107,107,.12); }

/* ===== Переключатель языка (фиксирован справа вверху, на любой странице) ===== */
.lang-switcher { position: fixed; top: 10px; right: 14px; z-index: 1500; }
.lang-switcher__btn {
  display: inline-flex; align-items: center; gap: 6px;
  height: auto; min-width: 0; width: auto; padding: .35rem .6rem; margin: 0;
  border-radius: 999px; border: 1px solid var(--border);
  background: rgba(23,26,43,.85); color: var(--text); cursor: pointer;
  font-size: .9rem; font-weight: 700; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.lang-switcher__btn:hover { background: rgba(35,40,68,.95); }
.lang-switcher__globe { font-size: 1rem; line-height: 1; }
.lang-switcher__menu {
  position: absolute; right: 0; top: calc(100% + 6px);
  background: var(--card); border: 1px solid var(--border); border-radius: .6rem;
  box-shadow: var(--shadow-1); overflow: hidden; min-width: 140px;
}
.lang-switcher__menu.hidden { display: none; }
.lang-switcher__item {
  display: block; width: 100%; min-width: 0; height: auto; text-align: left;
  padding: .55rem .85rem; background: transparent; border: none; color: var(--text);
  cursor: pointer; font-size: .95rem;
}
.lang-switcher__item:hover { background: rgba(255,255,255,.06); }
.lang-switcher__item.is-active { color: var(--accent-2); font-weight: 700; }

/* All mobile styles moved to mobile.css */
/* A11y: focus-visible outlines (клавиатурная навигация) */
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
button:focus-visible, .btn:focus-visible, .pp-tool:focus-visible, .mode-card:focus-visible {
  box-shadow: 0 0 0 3px rgba(108,92,231,.35);
}