:root {
  --bg: var(--tg-theme-bg-color, #0e1621);
  --fg: var(--tg-theme-text-color, #eaf0f6);
  --hint: var(--tg-theme-hint-color, #7d8b99);
  --btn: var(--tg-theme-button-color, #2ea6ff);
  --btn-fg: var(--tg-theme-button-text-color, #fff);
  --card-bg: #fafdff;
  --card-fg: #1a1a1a;
  --card-red: #d4283b;
  --felt: #14663f;
  --felt-edge: #0d4a2d;
  --panel: rgba(255, 255, 255, 0.06);
  --danger: #e0566b;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0; height: 100%;
  background: var(--bg); color: var(--fg);
  font-family: -apple-system, "Segoe UI", Roboto, sans-serif;
  -webkit-tap-highlight-color: transparent;
}
button {
  font: inherit; cursor: pointer; border: none; border-radius: 12px;
  padding: 12px 16px; background: var(--btn); color: var(--btn-fg); font-weight: 600;
}
button:disabled { opacity: 0.4; cursor: default; }
button.secondary { background: var(--panel); color: var(--fg); }
button.danger { background: var(--danger); }
.hidden { display: none !important; }

#app { min-height: 100%; display: flex; flex-direction: column; }
.screen { flex: 1; display: flex; flex-direction: column; padding: 16px; gap: 14px; }

/* ── Home ── */
.brand { text-align: center; margin-top: 8px; }
.brand h1 { margin: 4px 0; font-size: 26px; }
.brand p { margin: 0; color: var(--hint); font-size: 14px; }
.stack { display: flex; flex-direction: column; gap: 10px; }
.join-row { display: flex; gap: 8px; }
.join-row input {
  flex: 1; padding: 12px; border-radius: 12px; border: 1px solid var(--panel);
  background: var(--panel); color: var(--fg); font-size: 18px; letter-spacing: 2px;
  text-transform: uppercase; text-align: center;
}
.field { display: flex; flex-direction: column; gap: 4px; }
.field label { font-size: 13px; color: var(--hint); }
.field input {
  padding: 10px; border-radius: 10px; border: 1px solid var(--panel);
  background: var(--panel); color: var(--fg);
}
.settings-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }

/* ── Table ── */
.topbar { display: flex; align-items: center; gap: 8px; }
.topbar .code { font-weight: 700; letter-spacing: 2px; }
.topbar .spacer { flex: 1; }
.iconbtn { padding: 8px 12px; background: var(--panel); color: var(--fg); }

.felt {
  position: relative; flex: 1; min-height: 360px;
  background: radial-gradient(ellipse at center, var(--felt), var(--felt-edge));
  border-radius: 120px / 90px; border: 6px solid #0a3a23;
  margin: 4px 0; overflow: hidden;
}
.center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px; width: 90%;
}
.board { display: flex; gap: 6px; justify-content: center; min-height: 64px; }
.pot { font-size: 14px; color: #cdeede; background: rgba(0,0,0,0.25); padding: 4px 12px; border-radius: 20px; }

.seat {
  position: absolute; transform: translate(-50%, -50%);
  display: flex; flex-direction: column; align-items: center; gap: 3px; width: 96px;
}
.seat .name { font-size: 12px; font-weight: 600; max-width: 96px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.seat .stack { font-size: 12px; color: #bfe9d2; }
.seat .bet { font-size: 11px; color: #ffe08a; min-height: 14px; }
.seat .badges { display: flex; gap: 4px; min-height: 16px; }
.seat .pill { font-size: 9px; padding: 1px 5px; border-radius: 8px; background: rgba(0,0,0,0.35); }
.seat.acting { filter: drop-shadow(0 0 6px #ffe08a); }
.seat.folded { opacity: 0.4; }
.seat .cards { display: flex; gap: 2px; }
.dealer-btn {
  position: absolute; width: 22px; height: 22px; border-radius: 50%;
  background: #fff; color: #111; font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  transform: translate(-50%, -50%);
}

/* ── Cards ── */
.card-row { display: flex; gap: 4px; }
.card {
  width: 44px; height: 62px; border-radius: 7px; background: var(--card-bg);
  color: var(--card-fg); display: flex; flex-direction: column; align-items: center;
  justify-content: center; font-weight: 800; line-height: 1;
  box-shadow: 0 1px 3px rgba(0,0,0,0.4);
}
.card--sm { width: 30px; height: 42px; border-radius: 5px; }
.card--red { color: var(--card-red); }
.card__rank { font-size: 18px; }
.card--sm .card__rank { font-size: 13px; }
.card__suit { font-size: 16px; }
.card--sm .card__suit { font-size: 12px; }
.card--back {
  background: repeating-linear-gradient(45deg, #2a4a8a, #2a4a8a 6px, #1f3a6e 6px, #1f3a6e 12px);
  border: 2px solid #fff2;
}

/* ── Action bar ── */
.actionbar { display: flex; flex-direction: column; gap: 10px; }
.action-row { display: flex; gap: 8px; }
.action-row button { flex: 1; }
.raise-row { display: flex; align-items: center; gap: 10px; }
.raise-row input[type=range] { flex: 1; }
.raise-amount { min-width: 64px; text-align: right; font-weight: 700; }

.banner {
  background: var(--panel); border-radius: 12px; padding: 10px 14px; font-size: 14px;
}
.banner b { color: #ffe08a; }

/* ── Members list (lobby) ── */
.members { display: flex; flex-direction: column; gap: 6px; }
.member { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--panel); border-radius: 10px; }
.member .dot { width: 8px; height: 8px; border-radius: 50%; background: #3ad07a; }
.member .dot.off { background: var(--hint); }
.member .m-name { flex: 1; }
.member .m-stack { color: var(--hint); font-size: 13px; }

/* ── Combos ── */
.combo { background: var(--panel); border-radius: 12px; padding: 10px 12px; }
.combo h3 { margin: 0 0 2px; font-size: 16px; }
.combo .en { color: var(--hint); font-size: 12px; font-weight: 400; }
.combo p { margin: 6px 0 8px; font-size: 13px; color: var(--fg); }

/* Плавающая кнопка «на весь экран» — поверх всего, верхний левый угол
   (правый занимают системные кнопки Telegram в фуллскрине). */
.fsfab {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 8px);
  left: 8px;
  z-index: 60;
  padding: 6px 10px;
  background: var(--panel);
  color: var(--fg);
  border-radius: 10px;
  font-size: 16px;
  line-height: 1;
}

.toast {
  position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%);
  background: var(--danger); color: #fff; padding: 10px 16px; border-radius: 12px;
  font-size: 14px; z-index: 50; max-width: 90%;
}
