/* webapp-v2.css — стили для WebApp v2 (screen-based design).
 * Все классы префиксированы `.v2-` чтобы не пересекаться с легасным
 * рендером webapp.css. Палитру переиспользуем из webapp.css (--bg, --primary, …).
 *
 * Ширина mobile-фрейма. На десктопе вся аппа отображается как
 * мобильный фрейм 480px по центру (как Telegram Web / MAX desktop).
 * Если когда-нибудь нужно будет менять — точка для tweaks одна, тут.
 */
:root {
  --v2-frame-width: 480px;
}

/* Body фон отделим от фрейма, чтобы было видно, что центральный блок —
 * это «телефон» поверх. На мобильных (<=480px) фон совпадает с фреймом. */
@media (min-width: 481px) {
  html, body {
    background: #1a1a2e;
  }
}

/* На десктопе обрамляем #app как мобильный фрейм: фиксированная ширина,
 * центр, тень по бокам. Bottom-nav внутри этого же фрейма (см. ниже). */
@media (min-width: 481px) {
  #app {
    max-width: var(--v2-frame-width);
    margin: 0 auto;
    min-height: 100vh;
    background: var(--bg);
    box-shadow: 0 0 24px rgba(0, 0, 0, 0.35);
    position: relative; /* контекст для position:fixed → position:absolute трюка ниже */
  }
}

/* Override-правила для v2-режима: легасный #app + .content имеют
 * padding:0 16px и justify-content:center (заточено под welcome/spinner).
 * В v2 экраны должны прилегать сверху и идти на всю ширину фрейма. */
/* В v2 скролл идёт по body/#app, а не по .v2-content (она внутри flex'а).
 * Поэтому padding-bottom ставим на сам #app — он гарантирует, что после
 * последнего блока остаётся пустое место, и bottom-nav не закрывает его. */
#app.v2-active {
  padding: 0 0 calc(56px + 24px + 24px + env(safe-area-inset-bottom)) 0;
}

#app.v2-active .content {
  justify-content: flex-start;
  padding: 0;
  gap: 0;
}

.v2-content {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  width: 100%;
  max-width: var(--v2-frame-width);
  margin: 0 auto;
}

.v2-screen {
  display: flex;
  flex-direction: column;
  padding: 16px;
  gap: 14px;
}

.v2-screen-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
/* Иконка хедера прячем — на скетче заголовок просто крупный и жирный,
 * без эмодзи слева. Оставляем разметку в DOM, чтобы можно было включать
 * на специальных экранах через .v2-screen.with-header-icon. */
.v2-screen-header-icon {
  display: none;
}
.v2-screen-title {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
  margin: 0;
}

.v2-blocks {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.v2-block {
  background: var(--surface);
  border: none;
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
.v2-block-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.v2-block-hidden { display: none !important; }

/* --- install_hint (PWA «Добавить на главный экран») --- */
.v2-block-install-hint {
  background: var(--surface);
  border-radius: 12px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.v2-install-hint-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.v2-install-hint-text {
  font-size: 13px;
  line-height: 1.4;
  color: var(--text-muted);
}
.v2-install-hint-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 4px;
}
.v2-install-hint-cta {
  width: auto !important;
  padding: 8px 14px !important;
  font-size: 13px !important;
}
.v2-install-hint-dismiss {
  background: transparent;
  border: 0;
  color: var(--text-muted);
  font-size: 13px;
  cursor: pointer;
  padding: 8px 0;
}

.v2-empty {
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
  padding: 16px;
}
.v2-block-unknown {
  border-style: dashed;
  color: var(--text-muted);
  font-family: monospace;
  font-size: 12px;
}

/* --- profile_card --- */
/* На скетче «Диди» приветствие — это просто крупный заголовок без
 * фиолетового бэкграунда: иллюстрация уточки выше, текст ниже.
 * Поэтому profile_card делаем "плоской": белая карточка с очень крупным
 * заголовком. Цвет акцента используется только в CTA-кнопках и активной
 * навигации, не в фоне hero. */
.v2-profile-card {
  background: transparent;
  box-shadow: none;
  padding: 0 4px;
  color: var(--text);
}
.v2-profile-card-hello {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.v2-profile-card-xp-stub {
  margin-top: 8px;
  opacity: 0.55;
  font-size: 12px;
}

/* --- image --- */
.v2-block-image {
  background: transparent;
  box-shadow: none;
  padding: 0;
}
.v2-block-image img {
  width: 100%;
  max-height: 280px;
  object-fit: contain;
  border-radius: 8px;
  display: block;
}

/* --- text --- */
.v2-block-text p {
  font-size: 15px;
  line-height: 1.4;
  white-space: pre-wrap;
}

/* --- cta_button --- */
.v2-cta-btn {
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 18px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
  transition: background 0.15s ease;
}
.v2-cta-btn:hover {
  background: var(--primary-hover);
}
.v2-cta-btn:active {
  transform: scale(0.98);
}

/* Sticky CTA-блок (директива 2026-05-22) — закреплён над bottom-nav,
 * чтобы primary-кнопка («Заполнить анкету», «К результату», «В печать»)
 * не пряталась за нижним меню. Активируется при params.sticky === true
 * в cta_button JSON. На экранах без bottom-nav прижимается к самому низу
 * фрейма (расчёт учитывает env(safe-area-inset-bottom)). */
.v2-block-cta-sticky {
  position: sticky;
  /* 56 (nav icon+padding) + 24 (зазор между nav и CTA) + safe-area */
  bottom: calc(56px + 24px + env(safe-area-inset-bottom));
  z-index: 60;
  /* Тень над контентом, чтобы видно где CTA начинается при скролле. */
  box-shadow: 0 -8px 16px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
}
/* На экранах без bottom-nav (bottom_nav: false) меню не рендерится →
 * прижимаемся ближе к низу. Detect через отсутствие .v2-bottom-nav в DOM
 * нельзя из CSS, поэтому добавляем модификатор на сам #app: когда
 * bottom-nav скрыт через JS — body.no-bottom-nav. */
body.v2-no-bottom-nav .v2-block-cta-sticky {
  bottom: calc(16px + env(safe-area-inset-bottom));
}

/* --- quest_list --- */
.v2-quest-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.v2-quest-row {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--surface);
  border: none;
  border-radius: 12px;
  padding: 12px 14px;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  width: 100%;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
.v2-quest-row:hover { background: var(--surface-hover); }
.v2-quest-row-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--surface-hover);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.v2-quest-row-icon-img {
  background: #fff !important;
  padding: 4px;
}
.v2-quest-row-icon-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.v2-quest-row-title {
  flex: 1 1 auto;
  font-size: 14px;
  line-height: 1.3;
  font-weight: 600;
}
.v2-quest-row-reward {
  font-size: 12px;
  color: var(--success);
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}

/* --- quest_list: wrapper для row + опциональной мини-CTA --- */
.v2-quest-row-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.v2-quest-row-cta {
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  align-self: flex-start;
}
.v2-quest-row-cta:hover { background: var(--primary-hover); }

/* --- quest_card: полноценная карточка с лого, описанием и CTA --- */
.v2-block-quest-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.v2-quest-card-logo {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  background: var(--surface-hover);
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 16px;
  letter-spacing: -0.02em;
}
.v2-quest-card-title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--text);
}
.v2-quest-card-desc {
  font-size: 13px;
  line-height: 1.4;
  color: var(--text-muted);
}
.v2-quest-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 12px;
}
.v2-quest-card-progress {
  color: var(--text-muted);
  font-weight: 600;
}
.v2-quest-card-reward {
  color: var(--success);
  font-weight: 700;
}
.v2-quest-card-cta {
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
}
.v2-quest-card-cta:hover { background: var(--primary-hover); }

/* --- tabs: горизонтальный ряд табов с подсветкой активного --- */
.v2-block-tabs {
  background: transparent;
  box-shadow: none;
  padding: 0;
}
.v2-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
}
.v2-tab {
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  margin-bottom: -1px; /* перекрывает border-bottom родителя у активного */
}
.v2-tab.is-active {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

/* --- filter_bar: chips-style с опциональным счётчиком --- */
.v2-block-filter-bar {
  background: transparent;
  box-shadow: none;
  padding: 0;
}
.v2-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.v2-filter-chip {
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.v2-filter-chip.is-active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}
.v2-filter-chip-count {
  background: rgba(0, 0, 0, 0.1);
  border-radius: 999px;
  padding: 1px 6px;
  font-size: 11px;
  font-weight: 700;
}
.v2-filter-chip.is-active .v2-filter-chip-count {
  background: rgba(255, 255, 255, 0.25);
}

/* --- chat_header: карточка собеседника наверху диалога --- */
.v2-block-chat-header {
  display: flex;
  align-items: center;
  gap: 12px;
}
.v2-chat-header-avatar {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}
.v2-chat-header-avatar-img {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
}
.v2-chat-header-avatar-fallback {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 20px;
}
.v2-chat-header-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1 1 auto;
  min-width: 0;
}
.v2-chat-header-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.v2-chat-header-role {
  font-size: 12px;
  color: var(--text-muted);
}
.v2-chat-header-online {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--success);
  font-weight: 600;
  margin-top: 2px;
}
.v2-chat-header-online-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--success);
}

/* --- tags_chip_row: ряд маленьких чипов-тегов (≤24px) --- */
.v2-block-tags-chip-row {
  background: transparent;
  box-shadow: none;
  padding: 0;
}
.v2-tags-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.v2-tag-chip {
  background: var(--surface-hover);
  color: var(--text-muted);
  border-radius: 6px;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 500;
  line-height: 18px;
  max-height: 24px;
}

/* --- people: теги под именем (мини-чипы) --- */
.v2-people-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.v2-people-tag {
  background: var(--surface-hover);
  color: var(--text-muted);
  border-radius: 6px;
  padding: 1px 6px;
  font-size: 10px;
  font-weight: 500;
  line-height: 16px;
}

/* --- nav_section: active state (например, выбранный match_type в SMC) --- */
.v2-nav-row.is-active .v2-nav-row-label {
  color: var(--primary);
  font-weight: 700;
}
.v2-nav-row.is-active .v2-nav-row-icon {
  color: var(--primary);
}

/* --- smc_picker --- */
.v2-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}
.v2-chip {
  background: var(--surface-hover);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
  cursor: pointer;
}
.v2-chip.is-active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

/* --- chat --- */
.v2-block-chat {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.v2-chat-history {
  min-height: 240px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.v2-chat-msg {
  max-width: 80%;
  padding: 8px 12px;
  border-radius: 12px;
  font-size: 14px;
  word-wrap: break-word;
}
.v2-chat-msg-in { align-self: flex-start; background: var(--surface-hover); }
.v2-chat-msg-out { align-self: flex-end; background: var(--primary); color: #fff; }
.v2-chat-composer {
  display: flex;
  gap: 6px;
}
.v2-chat-composer input {
  flex: 1 1 auto;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
}
.v2-chat-composer .v2-cta-btn { width: auto; padding: 10px 14px; }

/* --- people_list --- */
.v2-people-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.v2-people-card {
  display: flex;
  align-items: center;
  gap: 12px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
  width: 100%;
  text-align: left;
  cursor: pointer;
  color: var(--text);
}
.v2-people-card:hover { background: var(--surface-hover); }
.v2-people-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  flex-shrink: 0;
}
.v2-people-info { display: flex; flex-direction: column; gap: 2px; }
.v2-people-name { font-size: 14px; font-weight: 600; }
.v2-people-meta { font-size: 12px; color: var(--text-muted); }

/* --- nav_section --- */
.v2-nav-section {
  display: flex;
  flex-direction: column;
}
.v2-nav-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 4px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-size: 15px;
}
.v2-nav-row:last-child { border-bottom: none; }
.v2-nav-row-icon { color: var(--text-muted); }
.v2-nav-row-icon-svg {
  /* SVG-иконка использует currentColor — наследует цвет от родителя
     (is-active → primary, is-danger → red, обычная → text-muted),
     поэтому в тёмной теме читается одинаково хорошо. */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  text-align: center;
}
.v2-nav-row-label { flex: 1 1 auto; }

/* --- bottom navigation ---
 * На mobile (≤480px) — фиксирована к низу viewport во всю ширину экрана.
 * На desktop (>480px) — фиксирована к низу того же mobile-фрейма (центр
 * экрана) через left:50% + translateX(-50%), ширина = --v2-frame-width. */
.v2-bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-around;
  align-items: flex-end;
  background: var(--surface);
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  padding: 10px 0 calc(10px + env(safe-area-inset-bottom));
  z-index: 50;
  box-shadow: 0 -1px 6px rgba(0, 0, 0, 0.04);
}
@media (min-width: 481px) {
  .v2-bottom-nav {
    left: 50%;
    right: auto;
    width: var(--v2-frame-width);
    transform: translateX(-50%);
    box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.25);
  }
}
.v2-bottom-nav-item {
  background: transparent;
  border: none;
  color: var(--text-muted);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: 11px;
  cursor: pointer;
  padding: 4px 8px;
}
.v2-bottom-nav-item.is-active {
  color: var(--primary);
}
.v2-bottom-nav-icon {
  font-size: 22px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.v2-bottom-nav-icon svg {
  width: 24px;
  height: 24px;
}
.v2-bottom-nav-item.is-active .v2-bottom-nav-icon { color: var(--primary); }
.v2-bottom-nav-item .v2-bottom-nav-icon { color: var(--text-muted); }
.v2-bottom-nav-label {
  font-weight: 500;
}

/* Центральная QR-кнопка bottom-nav (как на скетче «Диди»).
 * Выпуклый круг 56px, цвет primary, парит над линией навигации. */
.v2-bottom-nav-center {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: none;
  background: var(--primary);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: -24px 8px 0; /* приподнимаем выше bottom-nav */
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.45);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  flex-shrink: 0;
}
.v2-bottom-nav-center:hover {
  background: var(--primary-hover);
  transform: translateY(-2px);
}
.v2-bottom-nav-center:active {
  transform: translateY(0);
}
.v2-bottom-nav-center-icon {
  font-size: 24px;
  line-height: 1;
}

/* Логотип партнёра в quest_card как картинка (img) внутри плашки. */
.v2-quest-card-logo-img {
  background: #fff !important;
  padding: 4px;
}
.v2-quest-card-logo-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Bell badge — красный кружок с числом непрочитанных. */
.v2-app-header-bell {
  position: relative;
}
.v2-app-header-bell-badge {
  position: absolute;
  top: 2px;
  right: 2px;
  background: #ef4444;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: 10px;
  padding: 2px 5px;
  min-width: 16px;
  text-align: center;
  line-height: 1.2;
}

/* =============================================================
 * Phase 6.9 — блоки точно по скетчу «Диди»
 * ============================================================= */

/* app_header: брендовый хедер главной */
.v2-app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  background: transparent;
  box-shadow: none;
}
.v2-app-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
}
.v2-app-header-emoji {
  font-size: 24px;
  line-height: 1;
}
.v2-app-header-brand {
  font-size: 18px;
  font-weight: 800;
  color: var(--primary);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.v2-app-header-bell {
  background: transparent;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--text-muted);
  padding: 4px 8px;
}

/* screen_header_back: ← Заголовок [⇆/иконка] */
.v2-screen-back-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 4px;
  background: transparent;
  box-shadow: none;
}
.v2-back-btn {
  background: transparent;
  border: none;
  font-size: 22px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  padding: 6px 8px;
  line-height: 1;
}
.v2-screen-back-title {
  flex: 1 1 auto;
  font-size: 18px;
  font-weight: 700;
  margin: 0;
}
.v2-back-trailing {
  background: transparent;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--text);
  padding: 6px 8px;
}

/* level_progress: «Уровень 4 / 480 ⭐» + xp-bar */
.v2-level {
  background: var(--surface);
}
.v2-level-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.v2-level-title {
  font-size: 14px;
  font-weight: 700;
}
.v2-level-xp {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}
.v2-level-stars {
  display: flex;
  align-items: center;
  gap: 4px;
  background: var(--surface-hover);
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 700;
}
.v2-level-star-icon {
  font-size: 14px;
}
.v2-level-star-value {
  font-size: 13px;
  color: var(--text);
}
.v2-level-bar {
  height: 6px;
  background: var(--surface-hover);
  border-radius: 3px;
  overflow: hidden;
}
.v2-level-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--primary), var(--primary-hover));
  border-radius: 3px;
  transition: width 0.3s ease;
}

/* xp_ledger: «За что я получил баллы» — список карточек с иконкой/описанием/датой */
.v2-ledger {
  background: var(--surface);
}
.v2-ledger-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
}
.v2-ledger-empty {
  font-size: 13px;
  color: var(--text-muted);
  padding: 8px 0;
}
.v2-ledger-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.v2-ledger-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: var(--surface-hover);
  border-radius: 12px;
}
.v2-ledger-icon {
  font-size: 22px;
  width: 32px;
  text-align: center;
  flex-shrink: 0;
}
.v2-ledger-body {
  flex: 1;
  min-width: 0;
}
.v2-ledger-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.v2-ledger-date {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}
.v2-ledger-amount {
  font-size: 14px;
  font-weight: 700;
  color: var(--primary);
  flex-shrink: 0;
}

/* draw_card: жёлтая плашка розыгрыша */
.v2-draw-card {
  background: #fef3c7;
  color: #78350f;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px;
}
.v2-draw-card-icon {
  font-size: 28px;
  flex-shrink: 0;
}
.v2-draw-card-title {
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 4px;
}
.v2-draw-card-text {
  font-size: 12px;
  opacity: 0.8;
  line-height: 1.4;
}

/* section_title: «Список заданий квеста / 0/3 выполнено» */
.v2-section-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  background: transparent;
  box-shadow: none;
  padding: 0 4px;
  margin-top: 4px;
}
.v2-section-title-text {
  font-size: 16px;
  font-weight: 700;
  margin: 0;
}
.v2-section-title-sub {
  font-size: 12px;
  color: var(--text-muted);
}

/* radio_group: ◉/◯ список выбора */
.v2-block-radio {
  padding: 4px;
}
.v2-radio-group {
  display: flex;
  flex-direction: column;
}
.v2-radio-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 10px;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  color: var(--text);
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-size: 14px;
}
.v2-radio-row:last-child { border-bottom: none; }
.v2-radio-row.is-selected .v2-radio-label { font-weight: 700; }
.v2-radio-icon {
  font-size: 18px;
  width: 24px;
  text-align: center;
}
.v2-radio-label { flex: 1 1 auto; }
.v2-radio-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid var(--border);
  background: transparent;
  display: inline-block;
  flex-shrink: 0;
  position: relative;
}
.v2-radio-dot.is-on {
  border-color: var(--primary);
}
.v2-radio-dot.is-on::after {
  content: '';
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  background: var(--primary);
}

/* search_bar: поле поиска */
.v2-search-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--surface-hover);
  border-radius: 999px;
}
.v2-search-icon {
  color: var(--text-muted);
}
.v2-search-input {
  flex: 1 1 auto;
  background: transparent;
  border: none;
  outline: none;
  font-size: 14px;
  color: var(--text);
}
.v2-search-input::placeholder {
  color: var(--text-muted);
}

/* nav_section расширения: chevron, danger, active */
.v2-nav-row-chevron {
  color: var(--text-muted);
  margin-left: auto;
  padding-left: 8px;
  font-size: 18px;
}
.v2-nav-row.is-active {
  color: var(--primary);
  font-weight: 700;
}
.v2-nav-row.is-active .v2-nav-row-icon {
  color: var(--primary);
}
.v2-nav-row.is-danger {
  color: #ef4444;
}
.v2-nav-row.is-danger .v2-nav-row-icon {
  color: #ef4444;
}

/* chat_header расширения: back, menu */
.v2-block-chat-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
}
.v2-chat-header-menu {
  background: transparent;
  border: none;
  font-size: 22px;
  color: var(--text-muted);
  cursor: pointer;
  padding: 6px 8px;
  margin-left: auto;
}

/* =============================================================
 * Pull-to-refresh: круглый бейдж со стрелкой/спиннером
 * ============================================================= */
#v2-ptr {
  position: fixed;
  top: 0;
  left: 50%;
  width: 40px;
  height: 40px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9998;
  pointer-events: none;
  transform: translate(-50%, -40px);
  opacity: 0;
  /* transition только когда не тянем (см. .is-loading и hidePTR). */
}
.v2-ptr-arrow {
  transition: transform 0.2s ease;
}
#v2-ptr.is-ready .v2-ptr-arrow {
  /* Стрелка вверх «готов отпустить». */
  transform: rotate(180deg);
}
#v2-ptr.is-loading .v2-ptr-arrow {
  /* Спиннер: бесконечное вращение, стрелка скрыта, рисуем кольцо. */
  display: none;
}
#v2-ptr.is-loading::after {
  content: '';
  width: 20px;
  height: 20px;
  border: 2.2px solid rgba(124, 58, 237, 0.25);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: v2-ptr-spin 0.7s linear infinite;
}
@keyframes v2-ptr-spin {
  to { transform: rotate(360deg); }
}
#v2-ptr.is-success {
  background: #22c55e;
  color: #fff;
  box-shadow: 0 4px 16px rgba(34, 197, 94, 0.45);
  transition: transform 0.25s ease, opacity 0.25s ease, background 0.2s ease;
}
#v2-ptr.is-success .v2-ptr-arrow { display: none; }
#v2-ptr.is-success::after {
  content: '';
  width: 22px;
  height: 11px;
  border-left: 3px solid #fff;
  border-bottom: 3px solid #fff;
  transform: rotate(-45deg) translate(2px, -3px);
  animation: none;
  border-radius: 0;
}

/* --- collapsible_section --- */
.v2-block-collapsible { margin: 4px 0; }
.v2-collapsible {
  background: var(--surface, #fff);
  color: var(--text);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.v2-collapsible-header {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  background: transparent;
  border: 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
}
.v2-collapsible-icon { font-size: 18px; flex: 0 0 auto; }
.v2-collapsible-title { flex: 1 1 auto; font-weight: 600; }
.v2-collapsible-sub { color: var(--text-muted, #8a8a8a); font-size: 13px; }
.v2-collapsible-chevron {
  font-size: 18px;
  color: var(--text-muted, #8a8a8a);
  transition: transform 0.18s ease;
}
.v2-collapsible.is-open .v2-collapsible-chevron { transform: rotate(90deg); }
.v2-collapsible-body { display: none; padding: 0; }
.v2-collapsible.is-open .v2-collapsible-body { display: block; }
.v2-collapsible-body .v2-quest-row {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  border-top: 1px solid var(--surface-hover);
  padding: 12px 16px;
}
.v2-collapsible-body .v2-quest-row:hover { background: var(--surface-hover); }

/* --- feedback_form --- */
.v2-block-feedback { margin: 8px 0; }
.v2-feedback-form {
  background: var(--surface, #fff);
  border-radius: 12px;
  padding: 12px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.v2-feedback-textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--border, #e4e4e7);
  border-radius: 10px;
  padding: 10px 12px;
  font: inherit;
  color: inherit;
  background: var(--bg, #fff);
  resize: vertical;
  min-height: 88px;
}
.v2-feedback-textarea:focus { outline: none; border-color: var(--primary, #6366f1); }
.v2-feedback-options { margin: 10px 0 6px; }
.v2-feedback-cb-label { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 14px; }
.v2-feedback-checkbox { width: 18px; height: 18px; accent-color: var(--primary, #6366f1); }
.v2-feedback-submit { margin-top: 10px; width: 100%; }
.v2-feedback-submit:disabled { opacity: 0.5; cursor: default; }
.v2-feedback-thanks { color: #16a34a; font-size: 14px; margin-top: 6px; min-height: 18px; }

/* --- lead_form --- */
/* 2026-05-23: компактный layout (Bug 6) — анкета помещается на iPhone SE
 * 375×667 без скролла. Padding-и сжаты, поля 44px (touch-минимум),
 * birthday/gender идут в одну строку через grid. */
.v2-lead-form {
  background: var(--surface, #fff);
  border-radius: 12px;
  padding: 12px 12px 12px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  margin: 6px 0;
}
.v2-lead-form-title { margin: 0 0 4px; font-size: 17px; font-weight: 700; color: inherit; }
.v2-lead-form-subtitle { color: #6b7280; font-size: 13px; margin-bottom: 10px; line-height: 1.35; }
.v2-lead-form-fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-bottom: 4px;
}
.v2-lead-form-row { margin-bottom: 0; }
.v2-lead-form-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 3px;
  color: #374151;
}
.v2-lead-form-required { color: #dc2626; }
.v2-lead-form-input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--border, #e4e4e7);
  border-radius: 10px;
  padding: 9px 12px;
  min-height: 44px;
  font: inherit;
  color: inherit;
  background: var(--bg, #fff);
  -webkit-appearance: none;
  appearance: none;
}
/* Bug 6: birthday + gender в одну строку на iPhone (390px+) для экономии
 * вертикали. На очень узких экранах (<360px) — fallback в столбец. */
@media (min-width: 360px) {
  .v2-lead-form-row-birthdate,
  .v2-lead-form-row-gender {
    grid-column: span 1;
  }
}
@media (min-width: 380px) {
  .v2-lead-form-fields {
    grid-template-columns: 1fr 1fr;
  }
  /* Имя, телефон, email — full width (по 1 строке). */
  .v2-lead-form-fields > .v2-lead-form-row:not(.v2-lead-form-row-birthdate):not(.v2-lead-form-row-gender) {
    grid-column: 1 / -1;
  }
}
/* Bug 2: 3-input birthday — dd / mm / yyyy с разделителями.
 * В узкой колонке (gender row) ужимаемся до ~160px суммы трёх инпутов. */
.v2-lead-form-bday-group {
  display: flex;
  align-items: center;
  gap: 2px;
}
.v2-lead-form-bday-input {
  text-align: center;
  padding: 9px 2px;
  letter-spacing: 0.01em;
  font-size: 14px;
}
.v2-lead-form-bday-dd,
.v2-lead-form-bday-mm { width: 36px; flex: 0 0 36px; }
.v2-lead-form-bday-yyyy { width: 54px; flex: 0 0 54px; }
.v2-lead-form-bday-sep {
  color: #9ca3af;
  font-weight: 600;
  font-size: 14px;
  user-select: none;
}
/* Bug 5: radio group male/female. Используем стандартный radio с большой
 * tap-area через label-wrapper (минимум 44×44). */
.v2-lead-form-radio-group {
  display: flex;
  gap: 6px;
  align-items: stretch;
}
.v2-lead-form-radio-group.is-invalid {
  outline: 1px solid #dc2626;
  border-radius: 10px;
  padding: 2px;
}
.v2-lead-form-radio-label {
  flex: 1 1 0;
  min-width: 0; /* позволяет flex item ужиматься меньше intrinsic size */
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 8px 6px;
  min-height: 44px;
  border: 1px solid var(--border, #e4e4e7);
  border-radius: 10px;
  cursor: pointer;
  font-size: 13px;
  background: var(--bg, #fff);
  user-select: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.v2-lead-form-radio-label:has(input:checked) {
  border-color: var(--primary, #6366f1);
  background: rgba(99, 102, 241, 0.08);
  font-weight: 600;
}
.v2-lead-form-radio { width: 18px; height: 18px; accent-color: var(--primary, #6366f1); }
.v2-lead-form-radio:disabled { opacity: 0.6; cursor: not-allowed; }
.v2-lead-form-input:focus { outline: none; border-color: var(--primary, #6366f1); }
.v2-lead-form-input.is-invalid { border-color: #dc2626; background: #fef2f2; }

/* gender select (Sprint 1 T-5) — native <select> с тем же visual,
 * только chevron-arrow и cursor:pointer чтобы поведение совпадало с input. */
.v2-lead-form-select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236b7280'%3E%3Cpath d='M5.5 8l4.5 4.5L14.5 8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 18px 18px;
  padding-right: 36px;
}

/* dev-mode warning (Sprint 1 T-4) — мягкий inline-баннер, не модал.
 * Появляется в lead_form под кодом когда backend ответил dev_mode=true. */
.v2-lead-form-devmode {
  background: #fef3c7;
  color: #92400e;
  border: 1px solid #fde68a;
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.4;
  margin: 8px 0;
}
/* ─── one-button stateful flow (2026-05-22) ──────────────────────────
 * Stage 2: блок ввода кода. Колонка: label → input → resend-link.
 * Никаких primary-кнопок внутри — она ОДНА внизу формы (ctaBtn). */
.v2-lead-form-code-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}
.v2-lead-form-code-input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--border, #e4e4e7);
  border-radius: 10px;
  padding: 10px 12px;
  font: inherit;
  font-size: 20px;
  letter-spacing: 0.3em;
  text-align: center;
  background: var(--bg, #fff);
}
.v2-lead-form-code-input:focus { outline: none; border-color: var(--primary, #6366f1); }
.v2-lead-form-code-input.is-invalid { border-color: #dc2626; background: #fef2f2; }

/* Resend = text-link (не primary CTA). Юзер видит подсказку без
 * визуальной конкуренции с главной кнопкой. */
.v2-lead-form-resend-link {
  align-self: flex-start;
  background: transparent;
  color: var(--primary, #6366f1);
  border: 0;
  padding: 4px 0;
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.v2-lead-form-resend-link:disabled {
  color: #9ca3af;
  cursor: default;
  text-decoration: none;
}

/* Stage 2: locked-state визуал для readonly полей. Юзер видит
 * данные, но визуально понимает, что они «зафиксированы». */
.v2-lead-form-input.is-locked,
.v2-lead-form-select.is-locked {
  background: #f3f4f6;
  color: #4b5563;
  cursor: not-allowed;
}
.v2-lead-form-input.is-locked:focus {
  border-color: var(--border, #e4e4e7);
}

/* ─── legacy (до 2026-05-22, two-CTA design) ─────────────────────────
 * Оставлены на случай если другой код / preview / sponsor lead_form
 * ещё рендерят эти классы. Безопасно убрать после grep подтвердит,
 * что в проде нет ссылок. */
.v2-lead-form-verify-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.v2-lead-form-verify-btn {
  background: var(--primary, #6366f1);
  color: #fff;
  border: 0;
  border-radius: 10px;
  padding: 8px 14px;
  font: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  min-height: 36px;
}
.v2-lead-form-verify-btn:disabled { opacity: 0.55; cursor: default; }
.v2-lead-form-verified-mark {
  color: #16a34a;
  font-weight: 600;
  font-size: 14px;
}
.v2-lead-form-submit {
  width: 100%;
  margin-top: 6px;
}
.v2-lead-form-submit:disabled { opacity: 0.5; cursor: default; }
.v2-lead-form-snackbar {
  font-size: 14px;
  min-height: 18px;
  margin: 4px 0 8px;
  color: #16a34a;
  transition: opacity 200ms ease;
  opacity: 0;
}
.v2-lead-form-snackbar.is-visible { opacity: 1; }
.v2-lead-form-snackbar.is-error { color: #dc2626; }
.v2-lead-form-thanks {
  background: var(--surface, #fff);
  border-radius: 12px;
  padding: 18px 16px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  color: #16a34a;
  font-weight: 600;
  text-align: center;
  margin: 8px 0;
}

/* --- star_rating --- */
.v2-block-star-rating { margin: 8px 0; }
.v2-star-rating {
  background: var(--surface, #fff);
  border-radius: 12px;
  padding: 12px 14px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.v2-star-rating-label { font-weight: 600; margin-bottom: 8px; }
.v2-star-rating-row { display: flex; gap: 4px; }
.v2-star {
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 4px 6px;
  font-size: 28px;
  line-height: 1;
  color: #d4d4d8;
  transition: transform 0.08s ease;
}
.v2-star.is-on { color: #facc15; }
.v2-star:active { transform: scale(0.9); }
.v2-star-rating-note { color: #16a34a; font-size: 13px; min-height: 18px; margin-top: 6px; }

/* --- app_header burger menu --- */
.v2-app-header-menu {
  margin-left: auto;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  background: transparent;
  border: 0;
  padding: 8px;
  cursor: pointer;
}
.v2-app-header-menu-bar {
  display: block;
  width: 20px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
}

/* Per-project palette теперь живёт в setups:{project}:webapp_theme и
 * приходит через <style id="webapp-theme-vars"> в head (см. landing.go).
 * Любой хардкод по hash здесь забивает динамическую тему — не добавлять. */

/* ============================================================
 * Map (#184) — карта мероприятия с zoom/pan и POI-оверлеями.
 *
 * Контейнер v2-map-canvas хранит inline SVG или <img> с PNG.
 * Поверх лежат div'ы .v2-map-poi (абсолютные координаты в процентах
 * относительно холста). pinch-zoom и pan реализованы через CSS
 * transform (см. handler в webapp-v2.js applyMapZoom).
 * ============================================================ */

.v2-screen-map {
  /* Карта занимает всю доступную область экрана: убираем нижний
   * padding и выставляем 100dvh, чтобы pan-зона была максимальной. */
  padding-bottom: 0;
}

.v2-map-wrap {
  position: relative;
  width: 100%;
  height: calc(100dvh - 180px); /* минус хедер + bottom-nav */
  min-height: 320px;
  overflow: hidden;
  background: #f3f4f6;
  border-radius: 12px;
  touch-action: none; /* мы сами рулим pan/zoom через JS */
}

.v2-map-canvas {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  transform-origin: 0 0;
  transition: transform 0.06s linear;
  user-select: none;
}

.v2-map-canvas img, .v2-map-canvas svg {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
}

.v2-map-poi {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(59, 130, 246, 0.18);
  border: 1.5px solid #3b82f6;
  border-radius: 6px;
  color: #1e40af;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  pointer-events: auto;
  box-shadow: 0 2px 6px rgba(30, 64, 175, 0.18);
  text-align: center;
  padding: 2px 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-map-poi.is-hall   { background: rgba(59, 130, 246, 0.18); border-color: #3b82f6; color: #1e40af; }
.v2-map-poi.is-booth  { background: rgba(168, 85, 247, 0.18); border-color: #a855f7; color: #6b21a8; }
.v2-map-poi.is-coffee { background: rgba(245, 158, 11, 0.22); border-color: #f59e0b; color: #92400e; }
.v2-map-poi.is-wc     { background: rgba(20, 184, 166, 0.20); border-color: #14b8a6; color: #115e59; }
.v2-map-poi.is-entry  { background: rgba(34, 197, 94, 0.20); border-color: #22c55e; color: #15803d; }
.v2-map-poi.is-other  { background: rgba(100, 116, 139, 0.18); border-color: #64748b; color: #334155; }

.v2-map-poi.is-highlight {
  /* Подсветка зала после клика по доклаsdу в расписании / последний чекпоинт.
   * Анимация — pulsating border (cssанимация cssAnim ниже). */
  animation: v2-map-poi-pulse 1.4s ease-in-out infinite;
  z-index: 2;
}

@keyframes v2-map-poi-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.55), 0 2px 6px rgba(30, 64, 175, 0.18); border-color: #ef4444; }
  50% { box-shadow: 0 0 0 12px rgba(239, 68, 68, 0); border-color: #ef4444; }
}

.v2-map-empty {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  color: #6b7280; font-size: 14px; text-align: center; padding: 24px;
}

.v2-map-plan-picker {
  display: flex; gap: 6px; overflow-x: auto;
  padding: 8px 12px; margin-bottom: 8px;
  border-bottom: 1px solid #e5e7eb;
}
.v2-map-plan-picker button {
  background: #f3f4f6; border: 1px solid #e5e7eb; border-radius: 999px;
  padding: 6px 12px; font-size: 13px; color: #374151; cursor: pointer;
  white-space: nowrap;
}
.v2-map-plan-picker button.is-active {
  background: #1e40af; border-color: #1e40af; color: #fff;
}

.v2-map-poi-modal {
  position: fixed;
  left: 50%; transform: translateX(-50%);
  bottom: 80px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.2);
  padding: 16px 18px;
  min-width: 280px;
  max-width: 92vw;
  z-index: 100;
}
.v2-map-poi-modal-title { font-size: 16px; font-weight: 700; margin-bottom: 4px; color: #111; }
.v2-map-poi-modal-type  { font-size: 12px; color: #6b7280; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.04em; }
.v2-map-poi-modal-talks { display: flex; flex-direction: column; gap: 6px; max-height: 200px; overflow-y: auto; }
.v2-map-poi-modal-talk  { padding: 8px 10px; background: #f3f4f6; border-radius: 8px; cursor: pointer; }
.v2-map-poi-modal-talk:hover { background: #e5e7eb; }
.v2-map-poi-modal-talk-title { font-size: 14px; font-weight: 600; color: #111; }
.v2-map-poi-modal-talk-meta  { font-size: 12px; color: #6b7280; margin-top: 2px; }
.v2-map-poi-modal-close {
  position: absolute; top: 6px; right: 6px;
  width: 30px; height: 30px;
  background: transparent; border: 0; cursor: pointer;
  font-size: 20px; line-height: 1;
}

/* ============================================================
 * AI Photo studio (issue #183)
 * ============================================================ */
.v2-ai-photo-studio { padding: 16px; }
.v2-ai-photo-upload { display: flex; flex-direction: column; align-items: center; gap: 12px;
                       padding: 32px 16px; border: 2px dashed var(--v2-border, #ccc);
                       border-radius: 16px; background: var(--v2-bg-soft, #f7f8fa); }
.v2-ai-photo-upload-icon { font-size: 48px; line-height: 1; }
.v2-ai-photo-upload-hint { text-align: center; color: var(--v2-fg-muted, #666); max-width: 320px; }
.v2-ai-photo-consent { display: flex; align-items: flex-start; gap: 8px; font-size: 14px;
                       color: var(--v2-fg-muted, #555); cursor: pointer; }
.v2-ai-photo-consent input { margin-top: 3px; }
.v2-ai-photo-upload-btn { padding: 12px 24px; border-radius: 999px; border: none;
                          background: var(--v2-accent, #007aff); color: #fff;
                          font-weight: 600; cursor: pointer; }
.v2-ai-photo-upload-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.v2-ai-photo-status { font-size: 14px; color: var(--v2-fg-muted, #666); min-height: 20px; }

.v2-ai-photo-progress { padding: 32px 16px; text-align: center; }
.v2-ai-photo-progress-bar { width: 100%; max-width: 320px; margin: 0 auto;
                             height: 8px; background: var(--v2-border, #e5e5e5);
                             border-radius: 999px; overflow: hidden; }
.v2-ai-photo-progress-fill { height: 100%; background: var(--v2-accent, #007aff);
                              transition: width 600ms ease; }
.v2-ai-photo-progress-label { margin-top: 12px; font-weight: 600; }

.v2-ai-photo-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
                    padding: 8px 0; }
.v2-ai-photo-card { display: flex; flex-direction: column; gap: 6px;
                    background: var(--v2-bg-card, #fff); padding: 8px;
                    border-radius: 12px; box-shadow: 0 1px 4px rgba(0,0,0,.05); }
.v2-ai-photo-card-img { width: 100%; aspect-ratio: 1/1; object-fit: cover;
                        border-radius: 8px; background: #f0f0f0; }
.v2-ai-photo-card-pending,
.v2-ai-photo-card-failed { width: 100%; aspect-ratio: 1/1; display: flex;
                            align-items: center; justify-content: center;
                            border-radius: 8px; font-size: 14px; color: var(--v2-fg-muted, #888);
                            background: #f5f5f5; text-align: center; padding: 8px; }
.v2-ai-photo-card-failed { color: #c00; }
.v2-ai-photo-card-title { font-size: 13px; font-weight: 600; color: var(--v2-fg, #222);
                           text-align: center; }
.v2-ai-photo-card-share { padding: 6px 12px; border-radius: 999px; border: none;
                          background: var(--v2-accent, #007aff); color: #fff;
                          font-size: 12px; font-weight: 600; cursor: pointer; }

/* ============================================================
 * Chat rooms (Track C / #185) — list, badges, spam markers.
 * ============================================================ */
.v2-chat-room-tabs { display: flex; gap: 8px; padding: 8px 12px; overflow-x: auto;
                      border-bottom: 1px solid #e5e7eb; }
.v2-chat-room-tab { background: #f3f4f6; border: 1px solid #e5e7eb; border-radius: 999px;
                     padding: 6px 14px; font-size: 13px; color: #374151; cursor: pointer;
                     white-space: nowrap; }
.v2-chat-room-tab.v2-chat-room-tab-active { background: #1e40af; border-color: #1e40af; color: #fff; }
.v2-chat-room-list { display: flex; flex-direction: column; padding: 4px 0; }
.v2-chat-room-card { display: flex; align-items: center; gap: 12px; padding: 12px 14px;
                      border-bottom: 1px solid #f3f4f6; cursor: pointer; background: #fff; }
.v2-chat-room-card:active { background: #f9fafb; }
.v2-chat-room-icon { width: 44px; height: 44px; border-radius: 50%; background: #e5e7eb;
                      display: flex; align-items: center; justify-content: center;
                      font-size: 20px; flex-shrink: 0; }
.v2-chat-room-info { flex: 1; min-width: 0; }
.v2-chat-room-title { font-size: 15px; font-weight: 600; color: #111; overflow: hidden;
                       text-overflow: ellipsis; white-space: nowrap; }
.v2-chat-room-preview { font-size: 13px; color: #6b7280; margin-top: 2px;
                         overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.v2-chat-room-badge { background: #ef4444; color: #fff; font-size: 11px; font-weight: 700;
                       border-radius: 999px; padding: 2px 8px; min-width: 18px;
                       text-align: center; flex-shrink: 0; }
.v2-chat-room-header-icon { width: 36px; height: 36px; border-radius: 50%; background: #e5e7eb;
                             display: flex; align-items: center; justify-content: center;
                             font-size: 18px; }
.v2-chat-room-header-info { flex: 1; min-width: 0; }
.v2-chat-room-header-title { font-size: 16px; font-weight: 700; color: #111; }
.v2-chat-room-header-members { font-size: 12px; color: #6b7280; margin-top: 1px; }
.v2-chat-banner { padding: 12px 16px; background: #fef3c7; color: #92400e;
                   border-left: 4px solid #f59e0b; font-size: 13px; margin: 8px 12px;
                   border-radius: 6px; }
.v2-chat-moderation-banner { background: #eef2ff; color: #3730a3;
                              border-left-color: #6366f1; }
.v2-chat-empty { padding: 32px 16px; text-align: center; color: #9ca3af; font-size: 14px; }
.v2-chat-msg-text { font-size: 14px; line-height: 1.4; word-wrap: break-word; }
.v2-chat-msg-hidden { opacity: 0.45; font-style: italic; }
.v2-chat-spam-badge { display: inline-block; background: #fecaca; color: #991b1b;
                       border-radius: 4px; padding: 1px 6px; font-size: 11px;
                       font-weight: 600; margin-left: 6px; vertical-align: middle; }
.v2-chat-unread-badge { display: inline-flex; align-items: center; justify-content: center;
                         background: #ef4444; color: #fff; border-radius: 999px;
                         min-width: 20px; height: 20px; padding: 0 6px; font-size: 11px;
                         font-weight: 700; }

/* ----- Sponsor blocks (#187) ----- */
.v2-sponsor-card { background: #fff; border-radius: 12px; overflow: hidden;
                    margin: 12px; box-shadow: 0 1px 3px rgba(0,0,0,0.06);
                    border-top: 3px solid #1f2937; }
.v2-sponsor-card-banner img { display: block; width: 100%; height: 120px; object-fit: cover; }
.v2-sponsor-card-body { display: flex; align-items: center; gap: 12px; padding: 12px 14px; }
.v2-sponsor-card-logo { width: 44px; height: 44px; border-radius: 8px; object-fit: contain; background: #f3f4f6; }
.v2-sponsor-card-text { flex: 1; min-width: 0; }
.v2-sponsor-card-name { font-weight: 600; font-size: 15px; color: #111827; }
.v2-sponsor-card-tagline { font-size: 13px; color: #6b7280; margin-top: 2px; }
.v2-sponsor-card-cta { display: block; width: calc(100% - 28px); margin: 0 14px 14px;
                        padding: 10px 16px; border: none; border-radius: 8px;
                        background: #1f2937; color: #fff; font-size: 14px; font-weight: 500;
                        cursor: pointer; }
.v2-sponsor-card-cta:hover { filter: brightness(1.08); }

.v2-sponsor-quiz-intro { display: flex; flex-direction: column; align-items: center;
                          gap: 12px; padding: 24px 16px; margin: 12px;
                          background: #fff; border-radius: 12px; border: 2px solid #1f2937;
                          text-align: center; }
.v2-sponsor-quiz-intro-logo img { width: 80px; height: 80px; object-fit: contain; }
.v2-sponsor-quiz-intro-name { font-size: 18px; font-weight: 700; color: #111827; }
.v2-sponsor-quiz-intro-text { font-size: 14px; color: #4b5563; max-width: 320px; line-height: 1.4; }
.v2-sponsor-quiz-intro-cta { padding: 12px 32px; border: none; border-radius: 8px;
                              background: #1f2937; color: #fff; font-size: 15px;
                              font-weight: 600; cursor: pointer; }

/* ===== Track D (#186) — адресная книга + карточка контакта ===== */

.v2-address-book { display: flex; flex-direction: column; gap: 12px; padding: 12px 0; }
.v2-address-book-search { padding: 0 12px; }
.v2-address-book-search-input {
  width: 100%; padding: 10px 14px; border: 1px solid #e5e7eb; border-radius: 8px;
  font-size: 14px; background: #fff; color: #111827;
  -webkit-appearance: none;
}
.v2-address-book-search-input:focus { outline: none; border-color: #1f2937; }
.v2-address-book-chips {
  display: flex; gap: 8px; padding: 0 12px; overflow-x: auto;
  scrollbar-width: thin;
}
.v2-address-book-chip {
  flex: 0 0 auto; padding: 6px 14px; border: 1px solid #e5e7eb; border-radius: 999px;
  background: #fff; color: #4b5563; font-size: 13px; cursor: pointer;
  white-space: nowrap;
}
.v2-address-book-chip.is-active { background: #1f2937; color: #fff; border-color: #1f2937; }
.v2-address-book-export {
  display: flex; gap: 8px; padding: 0 12px;
}
.v2-address-book-export-btn {
  flex: 1 1 0; padding: 8px 12px; border: 1px solid #1f2937; border-radius: 8px;
  background: #fff; color: #1f2937; font-size: 13px; font-weight: 500; cursor: pointer;
}
.v2-address-book-export-btn:hover { background: #f3f4f6; }
.v2-address-book-empty { padding: 32px 24px; text-align: center; color: #6b7280; font-size: 14px; }
.v2-address-book-list { display: flex; flex-direction: column; gap: 8px; padding: 0 12px; }
.v2-address-book-card {
  display: flex; align-items: center; gap: 12px; padding: 12px;
  background: #fff; border: 1px solid #e5e7eb; border-radius: 12px;
  cursor: pointer; width: 100%; text-align: left;
}
.v2-address-book-card:hover { border-color: #1f2937; }
.v2-address-book-card.is-hidden { opacity: 0.6; }
.v2-address-book-avatar {
  width: 44px; height: 44px; border-radius: 50%; object-fit: cover;
  background: #f3f4f6; flex: 0 0 44px;
}
.v2-address-book-avatar-stub {
  display: flex; align-items: center; justify-content: center;
  color: #6b7280; font-weight: 600; font-size: 16px;
}
.v2-address-book-info { flex: 1; min-width: 0; }
.v2-address-book-name { font-weight: 600; font-size: 15px; color: #111827; }
.v2-address-book-meta { font-size: 13px; color: #6b7280; margin-top: 2px; }
.v2-address-book-event {
  display: inline-block; margin-top: 4px; padding: 2px 8px;
  background: #eef2ff; color: #4338ca; border-radius: 999px; font-size: 11px;
}
.v2-address-book-hidden { margin-top: 4px; font-size: 12px; color: #9ca3af; font-style: italic; }

.v2-screen-address-book .v2-blocks { padding-bottom: 24px; }

/* network_profile (full-screen) */
.v2-network-profile { display: flex; flex-direction: column; gap: 14px; padding: 20px 16px; }
.v2-network-profile-head { display: flex; align-items: center; gap: 14px; }
.v2-network-profile-avatar {
  width: 72px; height: 72px; border-radius: 50%; object-fit: cover;
  background: #f3f4f6; flex: 0 0 72px;
}
.v2-network-profile-avatar-stub {
  display: flex; align-items: center; justify-content: center;
  color: #6b7280; font-weight: 600; font-size: 24px;
}
.v2-network-profile-head-info { flex: 1; min-width: 0; }
.v2-network-profile-name { font-weight: 700; font-size: 20px; color: #111827; }
.v2-network-profile-role { font-size: 14px; color: #6b7280; margin-top: 4px; }
.v2-network-profile-event {
  display: inline-block; margin-top: 6px; padding: 3px 10px;
  background: #eef2ff; color: #4338ca; border-radius: 999px; font-size: 12px;
}
.v2-network-profile-about { font-size: 14px; color: #1f2937; line-height: 1.5; white-space: pre-wrap; }
.v2-network-profile-note { font-size: 13px; color: #4b5563; font-style: italic; }
.v2-network-profile-channels { display: flex; flex-direction: column; gap: 6px; }
.v2-network-profile-channel { font-size: 13px; color: #1f2937; padding: 6px 10px; background: #f9fafb; border-radius: 6px; }
.v2-network-profile-actions { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.v2-network-profile-btn {
  display: inline-block; padding: 12px 16px; border: 1px solid #1f2937; border-radius: 8px;
  background: #fff; color: #1f2937; font-size: 14px; font-weight: 500;
  text-align: center; text-decoration: none; cursor: pointer;
}
.v2-network-profile-btn-tg { background: #1f2937; color: #fff; }
.v2-network-profile-btn:hover { background: #f3f4f6; }
.v2-network-profile-btn-tg:hover { background: #111827; color: #fff; }


/* ============================================================
 * text_to_image_studio + tag_picker (imagegen Track A refactor)
 * ============================================================ */
.v2-tig-studio { display: flex; flex-direction: column; gap: 10px; padding: 12px; }
.v2-tig-input {
  width: 100%; box-sizing: border-box; padding: 10px;
  border: 1px solid #d1d5db; border-radius: 8px; font-size: 14px;
  font-family: inherit; resize: vertical; min-height: 80px;
}
.v2-tig-input:focus { outline: none; border-color: #4338ca; }
.v2-tig-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.v2-tig-btn {
  padding: 10px 16px; border: 1px solid #1f2937; border-radius: 8px;
  background: #fff; color: #1f2937; font-size: 14px; font-weight: 500;
  cursor: pointer;
}
.v2-tig-btn-submit { background: #1f2937; color: #fff; }
.v2-tig-btn-submit:hover { background: #111827; }
.v2-tig-btn-regen { background: #fff; color: #1f2937; }
.v2-tig-btn-share { background: #4338ca; color: #fff; border-color: #4338ca; }
.v2-tig-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.v2-tig-status { font-size: 13px; color: #4b5563; min-height: 18px; }
.v2-tig-status.is-error { color: #b91c1c; }
.v2-tig-preview { display: grid; grid-template-columns: 1fr; gap: 8px; margin-top: 8px; }
.v2-tig-card { border-radius: 8px; overflow: hidden; background: #f3f4f6; position: relative; }
.v2-tig-card-img { width: 100%; height: auto; display: block; }

/* Loader: прогрессивный bar + ротация stage-сообщений. Показывается во время
 * генерации (0-12с) — даёт ощущение что что-то происходит, даже если бэк
 * упал и мы покажем placeholder. */
.v2-tig-loader { padding: 24px 12px; display: flex; flex-direction: column; gap: 12px; align-items: stretch; }
.v2-tig-loader-bar {
  width: 100%; height: 6px; background: #e5e7eb;
  border-radius: 999px; overflow: hidden;
}
.v2-tig-loader-fill {
  height: 100%; background: linear-gradient(90deg, #4338ca, #6366f1);
  width: 0%; transition: width 200ms linear;
}
.v2-tig-loader-stage {
  font-size: 13px; color: #6b7280; text-align: center;
  font-weight: 500;
}

/* Ready state — inline-показ готовой картинки на ai_generation_pending
 * (Сбер EKB 2026-05-23). Юзер ждал на pending screen, пришёл text_to_image_ready,
 * картинка появилась прямо здесь + текст «также отправили на email».
 * НЕ навигируем на result_view — не сбиваем юзера с pending-flow. */
.v2-tig-ready { display: flex; flex-direction: column; gap: 12px; padding: 8px 0; }
.v2-tig-ready-title { font-size: 18px; font-weight: 600; color: #111827; text-align: center; }
.v2-tig-ready-img { border-radius: 8px; }
.v2-tig-ready-text { font-size: 14px; color: #4b5563; text-align: center; line-height: 1.4; }

/* Delayed notice — graceful state когда backend не успел вернуть картинку
 * (timeout / router error). НЕ показываем «недоступен» / «ошибка», только
 * дружелюбное «придёт на email чуть позже». Backend retry доставит. */
.v2-tig-delayed {
  display: flex; flex-direction: column; gap: 10px;
  padding: 22px 18px; border-radius: 12px;
  background: #f3f4f6; color: #1f2937; text-align: center;
}
.v2-tig-delayed-title {
  font-size: 18px; font-weight: 600;
}
.v2-tig-delayed-text {
  font-size: 14px; line-height: 1.4; color: #4b5563;
}

/* GDPR consent — БЛОКИРУЮЩИЙ overlay-gate (стандарт #2 для webapp v2,
 * директива тимлида 2026-05-22). Юзер не может взаимодействовать со
 * страницей пока не accept-нет. body.overflow=hidden в JS, overlay
 * перехватывает все click'и. Modal по центру с z-index 9999. */
.v2-gdpr-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(15, 23, 42, 0.65);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  -webkit-tap-highlight-color: transparent;
}
.v2-gdpr-modal {
  background: #fff; border-radius: 16px;
  width: 100%; max-width: 440px;
  padding: 22px;
  display: flex; flex-direction: column; gap: 12px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.25);
  max-height: 90vh; overflow-y: auto;
}
.v2-gdpr-title { font-size: 18px; font-weight: 700; color: #111827; }
.v2-gdpr-text { font-size: 14px; line-height: 1.5; color: #4b5563; }
.v2-gdpr-link { font-size: 14px; color: #4338ca; text-decoration: underline; }
.v2-gdpr-checkbox {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 14px; color: #1f2937; cursor: pointer; line-height: 1.4;
}
.v2-gdpr-checkbox input { margin-top: 3px; flex-shrink: 0; width: 18px; height: 18px; }
.v2-gdpr-accept { padding: 12px 18px !important; font-size: 15px !important; font-weight: 600 !important; }
.v2-gdpr-accept[disabled] { opacity: 0.45; cursor: not-allowed; }

/* Marketing consent block — опциональный (не блокирующий) inline-блок
 * для согласия на рассылки. В отличие от .v2-gdpr-overlay не перекрывает
 * страницу. Юзер может «Пропустить» — это не нарушает 152-ФЗ (рекламные
 * рассылки требуют отдельного opt-in, отказ не блокирует основной сервис). */
.v2-marketing-consent {
  background: #fff7ed; border: 1px solid #fed7aa;
  border-radius: 12px; padding: 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.v2-marketing-consent-title { font-size: 16px; font-weight: 600; color: #9a3412; }
.v2-marketing-consent-text { font-size: 14px; line-height: 1.5; color: #7c2d12; }
.v2-marketing-consent-link {
  font-size: 13px; color: #c2410c; text-decoration: underline;
  align-self: flex-start;
}
.v2-marketing-consent-checkbox {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 13px; color: #7c2d12; cursor: pointer; line-height: 1.4;
}
.v2-marketing-consent-checkbox input { margin-top: 3px; flex-shrink: 0; width: 18px; height: 18px; }
.v2-marketing-consent-buttons {
  display: flex; gap: 8px; margin-top: 4px; flex-wrap: wrap;
}
.v2-marketing-consent-accept {
  padding: 10px 16px !important; font-size: 14px !important;
  font-weight: 600 !important; flex: 1; min-width: 120px;
}
.v2-marketing-consent-dismiss {
  padding: 10px 16px; font-size: 14px; font-weight: 500;
  background: transparent; color: #7c2d12;
  border: 1px solid #fed7aa; border-radius: 8px; cursor: pointer;
  flex: 1; min-width: 120px;
}
.v2-marketing-consent-dismiss:hover { background: #fff1e0; }

/* Push permission block — стандартный паттерн опт-ин для push. */
.v2-block-push {
  background: #eef2ff; border: 1px solid #c7d2fe;
  border-radius: 12px; padding: 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.v2-push-title { font-size: 15px; font-weight: 700; color: #3730a3; }
.v2-push-text { font-size: 13px; line-height: 1.45; color: #4338ca; }
.v2-push-actions { display: flex; align-items: center; gap: 12px; }
.v2-push-accept { width: auto !important; padding: 8px 14px !important; font-size: 13px !important; }

/* photo_capture — селфи / загрузка фото юзера для face-preserve flow. */
.v2-photo-capture {
  display: flex; flex-direction: column; gap: 12px; padding: 16px;
  background: #fff; border-radius: 12px; border: 1px solid #e5e7eb;
}
.v2-photo-capture-title { font-size: 16px; font-weight: 700; color: #111827; }
.v2-photo-capture-hint { font-size: 13px; color: #6b7280; line-height: 1.4; }
.v2-photo-capture-preview {
  width: 100%; aspect-ratio: 1; max-height: 360px;
  background: #f3f4f6; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; position: relative;
}
.v2-photo-capture-img { width: 100%; height: 100%; object-fit: cover; }
.v2-photo-capture-empty { font-size: 64px; opacity: 0.4; }
.v2-photo-capture-status { font-size: 13px; color: #4338ca; min-height: 18px; text-align: center; }
.v2-photo-capture-actions { display: flex; flex-direction: column; gap: 10px; }
.v2-photo-capture-btn { flex: 1 1 0; min-width: 140px; padding: 10px 14px; font-size: 14px; }
.v2-photo-capture-btn-primary {
  padding: 18px 24px !important; font-size: 18px !important; font-weight: 700 !important;
  background: #21A038 !important; border-radius: 14px !important;
  animation: v2-camera-pulse 2s ease-in-out infinite;
}
.v2-photo-capture-btn-primary:hover { background: #1a8a2e !important; animation: none; }
.v2-photo-capture-btn-primary:active { transform: scale(0.97); animation: none; }
.v2-photo-capture-btn-primary:disabled { animation: none; opacity: 0.7; }
@keyframes v2-camera-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(33, 160, 56, 0.4); }
  50% { box-shadow: 0 0 0 10px rgba(33, 160, 56, 0); }
}
.v2-photo-capture-tap-hint {
  text-align: center; font-size: 13px; color: #6b7280; padding: 4px 0 2px;
}
.v2-cta-btn-secondary { background: #fff !important; color: #1f2937 !important; border: 1px solid #d1d5db !important; }
.v2-photo-capture-confirm { padding: 12px 18px; font-size: 15px; }
.v2-photo-capture-confirm[disabled] { opacity: 0.5; cursor: not-allowed; }

/* Sprint E1: inline progress bar над CTA (вариант A из research). */
.v2-photo-capture-progress {
  display: flex; flex-direction: column; gap: 6px;
  padding: 8px 4px;
}
.v2-photo-capture-progress-bar {
  width: 100%; height: 8px; background: #e5e7eb; border-radius: 4px; overflow: hidden;
}
.v2-photo-capture-progress-fill {
  height: 100%; background: #21A038; transition: width 0.3s ease-out, background 0.3s ease;
  border-radius: 4px;
}
.v2-photo-capture-progress-label {
  font-size: 13px; color: #374151; text-align: center; min-height: 18px;
}

/* Spinner overlay на preview во время upload. */
@keyframes v2spin { to { transform: rotate(360deg); } }
.v2-photo-capture-spinner { pointer-events: none; }
.v2-photo-capture-preview { cursor: pointer; }

/* Fallback «Без фото» — link-style кнопка, появляется через 30с (fade-in). */
.v2-cta-btn-link {
  background: transparent !important; color: #6b7280 !important;
  border: none !important; padding: 8px 14px !important;
  font-size: 13px !important; text-decoration: underline; cursor: pointer;
}
.v2-photo-capture-fallback {
  align-self: center; margin-top: 4px;
}

.v2-tagpicker { display: flex; flex-direction: column; gap: 14px; padding: 12px; }
.v2-tagpicker-group { display: flex; flex-direction: column; gap: 6px; }
.v2-tagpicker-group-label {
  font-size: 12px; color: #6b7280; text-transform: uppercase; letter-spacing: 0.04em;
}
.v2-tagpicker-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.v2-tagpicker-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border: 1px solid #d1d5db; border-radius: 999px;
  background: #fff; color: #1f2937; font-size: 14px; cursor: pointer;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.v2-tagpicker-chip:hover { background: #f3f4f6; }
.v2-tagpicker-chip.is-selected {
  background: var(--primary, #1f2937);
  color: #fff;
  border-color: var(--primary, #1f2937);
}
.v2-tagpicker-chip.is-selected .v2-tagpicker-chip-icon { color: #fff; }
.v2-tagpicker-chip-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; color: #374151;
  flex: 0 0 22px;
}
.v2-tagpicker-chip-icon-emoji { font-size: 18px; line-height: 1; }
.v2-tagpicker-chip-swatch {
  display: inline-block; width: 18px; height: 18px; border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.15);
  flex: 0 0 18px;
}
.v2-tagpicker-chip-label { line-height: 1.2; }
.v2-tagpicker-submit {
  align-self: flex-start; margin-top: 8px;
  padding: 12px 22px; border: none; border-radius: 10px;
  background: var(--primary, #4338ca);
  color: #fff; font-size: 15px; font-weight: 600;
  cursor: pointer;
  transition: background 0.12s, opacity 0.12s;
}
.v2-tagpicker-submit:hover { background: var(--primary-hover, #3730a3); }
.v2-tagpicker-submit.is-disabled,
.v2-tagpicker-submit[disabled] {
  opacity: 0.5; cursor: not-allowed;
}
.v2-tagpicker-hint {
  font-size: 12px; color: #6b7280; margin-top: 4px;
}
.v2-tagpicker-snackbar {
  position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%);
  background: #1f2937; color: #fff; padding: 10px 16px; border-radius: 8px;
  font-size: 14px; z-index: 9999; box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

/* ----- param_select (Сбер-Движение motorcycle_params / sticker_design) ----- */
.v2-block-param-select {
  display: flex; flex-direction: column; gap: 10px;
  background: #fff; border-radius: 12px; padding: 14px;
}
.v2-param-label {
  font-size: 13px; font-weight: 600; color: #374151;
}
.v2-param-options {
  display: flex; flex-direction: column; gap: 8px;
}
.v2-param-style-chips .v2-param-options {
  flex-direction: row; flex-wrap: wrap;
}
.v2-param-option {
  appearance: none; border: 1px solid #d1d5db; background: #fff;
  border-radius: 10px; padding: 10px 14px;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  font-size: 14px; color: #111827; cursor: pointer;
  text-align: left;
}
.v2-param-style-chips .v2-param-option {
  border-radius: 999px; padding: 8px 14px; flex: 0 0 auto;
}
.v2-param-option:hover { background: #f9fafb; }
.v2-param-option.is-selected {
  background: #ecfdf5; border-color: #10b981; color: #064e3b;
}
.v2-param-option-dot {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid #d1d5db; flex: 0 0 18px;
}
.v2-param-option-dot.is-on {
  background: #10b981; border-color: #10b981;
  box-shadow: inset 0 0 0 3px #fff;
}
.v2-param-text-input {
  width: 100%; box-sizing: border-box;
  padding: 10px 12px; border: 1px solid #d1d5db; border-radius: 8px;
  font-size: 15px; background: #fff; color: #111827;
}
.v2-param-text-input:focus {
  outline: none; border-color: #10b981; box-shadow: 0 0 0 3px rgba(16,185,129,0.2);
}
.v2-param-text-input.is-invalid {
  border-color: #dc2626; background: #fef2f2;
}
.v2-param-text-input.is-invalid:focus {
  border-color: #dc2626; box-shadow: 0 0 0 3px rgba(220,38,38,0.2);
}
.v2-param-text-counter {
  margin-top: 6px; font-size: 12px; color: #6b7280; text-align: right;
}
.v2-param-text-counter.is-invalid {
  color: #dc2626; font-weight: 600;
}

/* ----- KIOSK-MODE (Сбер-Движение, тач-панель в шатре) -----
 *
 * Активируется через body.v2-kiosk (см. detectKioskMode в webapp-v2.js).
 * Делает UI пригодным для пальца на стационарной тач-панели:
 *   - tap-target ≥ 80px;
 *   - шрифт +50%;
 *   - install_hint скрыт (на стационарном устройстве установка не нужна);
 *   - bottom-nav центральная QR-кнопка крупнее (но обычно kiosk скрывает QR).
 */
body.v2-kiosk {
  font-size: 22px;
}
body.v2-kiosk .v2-screen { padding: 24px; gap: 20px; }
body.v2-kiosk .v2-screen-title { font-size: 32px; }
body.v2-kiosk .v2-block { padding: 22px; }
body.v2-kiosk .v2-cta-btn,
body.v2-kiosk .v2-cta-btn-secondary,
body.v2-kiosk .v2-back-btn,
body.v2-kiosk .v2-bottom-nav-item,
body.v2-kiosk .v2-param-option,
body.v2-kiosk .v2-sticker-tile,
body.v2-kiosk .v2-radio-row {
  min-height: 80px; min-width: 80px;
  font-size: 20px; padding: 18px 22px;
}
body.v2-kiosk .v2-param-text-input {
  font-size: 22px; padding: 16px 18px;
}
body.v2-kiosk .v2-param-label,
body.v2-kiosk .v2-block-text p,
body.v2-kiosk .v2-section-title-text {
  font-size: 22px;
}
body.v2-kiosk .v2-section-title-text { font-size: 26px; }
body.v2-kiosk .v2-install-hint-title,
body.v2-kiosk .v2-block-install-hint { display: none !important; }
body.v2-kiosk .v2-app-header-bell,
body.v2-kiosk .v2-app-header-menu { min-width: 56px; min-height: 56px; }
body.v2-kiosk .v2-bottom-nav-center { width: 80px; height: 80px; }
body.v2-kiosk .v2-photo-capture-preview { max-height: 480px; }
body.v2-kiosk .v2-sticker-grid { gap: 14px; }
/* Десктоп-фрейм в kiosk не нужен: тач-панель занимает весь экран целиком. */
@media (min-width: 481px) {
  body.v2-kiosk #app {
    max-width: none; box-shadow: none;
  }
  body.v2-kiosk .v2-content { max-width: none; }
}

/* ----- big_text — блок с крупным номером участника (sticker_preview) ----- */
.v2-big-text {
  display: flex; flex-direction: column; align-items: center;
  gap: 4px; padding: 20px 16px 12px;
  background: #fff; border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.v2-big-text__label {
  font-size: 14px; font-weight: 500; color: #6b7280; text-align: center;
}
.v2-big-text__value {
  font-size: 64px; font-weight: 700; text-align: center;
  display: block; line-height: 1.1; color: #111827;
  letter-spacing: -1px;
}
/* Kiosk override — чуть крупнее для тач-экрана */
body.v2-kiosk .v2-big-text__value {
  font-size: 80px;
}
/* sticker_preview_image */
.v2-sticker-preview-image img {
  max-width: 100%; border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
}
.v2-sticker-preview-loading .v2-sticker-preview-placeholder {
  display: flex; align-items: center; justify-content: center;
  min-height: 200px; font-size: 14px; color: #9ca3af;
  background: #f9fafb; border-radius: 12px;
}

/* ----- swatch_picker — sticker color step (ITER 8) ----- */
.v2-swatch-picker { padding: 0; }
.v2-swatch-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.v2-swatch {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 14px 8px; border: 2px solid #e5e7eb; border-radius: 12px;
  background: #fff; cursor: pointer; transition: border-color 0.15s, transform 0.1s;
  font: inherit; color: inherit;
}
.v2-swatch:hover { border-color: #9ca3af; }
.v2-swatch--selected {
  border-color: #1A9F29; background: #f0fdf4;
  transform: scale(0.97);
}
.v2-swatch-circle {
  display: block; width: 40px; height: 40px;
  border-radius: 50%; border: 1px solid rgba(0,0,0,0.12);
  flex-shrink: 0;
}
.v2-swatch-label {
  font-size: 13px; font-weight: 500; color: #374151; text-align: center;
  line-height: 1.2;
}
/* Kiosk overrides */
body.v2-kiosk .v2-swatch { padding: 18px 10px; }
body.v2-kiosk .v2-swatch-circle { width: 52px; height: 52px; }
body.v2-kiosk .v2-swatch-label { font-size: 16px; }

/* ----- style_picker — sticker style step (ITER 8) ----- */
.v2-style-picker { padding: 0; }
.v2-style-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 10px;
}
.v2-style-card {
  display: flex; flex-direction: column; align-items: flex-start;
  padding: 14px 16px; border: 2px solid #e5e7eb; border-radius: 12px;
  background: #fff; cursor: pointer; transition: border-color 0.15s, transform 0.1s;
  font: inherit; color: inherit; text-align: left; width: 100%;
}
.v2-style-card:hover { border-color: #9ca3af; }
.v2-style-card--selected {
  border-color: #1A9F29; background: #f0fdf4;
  transform: scale(0.99);
}
.v2-style-card__label {
  font-size: 15px; font-weight: 600; color: #111827;
}
.v2-style-card__desc {
  font-size: 13px; color: #6b7280; margin-top: 2px;
}
/* Kiosk overrides */
body.v2-kiosk .v2-style-card { padding: 18px 20px; }
body.v2-kiosk .v2-style-card__label { font-size: 20px; }
body.v2-kiosk .v2-style-card__desc { font-size: 16px; }
