:root {
  --bg: #111111;
  --bg-soft: #161d2a;
  --panel: #171f2c;
  --panel-2: #1c2534;
  --felt: #243246;
  --felt-2: #2d3d54;
  --line: rgba(255,255,255,0.08);
  --line-strong: rgba(255,255,255,0.14);
  --text: #eef3ff;
  --muted: #91a0bb;
  --accent: #c7a46a;
  --accent-2: #9e8358;
  --secondary: #6d86a8;
  --secondary-soft: rgba(109,134,168,.14);
  --danger: #ff7d7d;
  --ok: #53d18c;
  --shadow: 0 18px 42px rgba(0,0,0,.34);
  --tg-height: 100vh;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
html, body { margin: 0; overflow: hidden; }
body {
  font-family: "Manrope", sans-serif;
  font-optical-sizing: auto;
  color: var(--text);
  background: url("assets/background.png");
  background-size: 100%;

}

#app, .screen-home, #screen-game, .modal-card, .home-shell, .home-menu, .full-card {
  background: transparent;
}
#app {
  height: var(--tg-height);
  max-width: 1380px;
  margin: 0 auto;
  padding: max(4px, env(safe-area-inset-top)) 12px max(12px, env(safe-area-inset-bottom)) 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.tg-top-space { min-height: 0; }
.hidden { display: none !important; }
.active { display: block; }
h1,h2,h3,p { margin: 0; }
button, input, select { font: inherit; }

.panel {
  background: transparent;
  
  /* border: 1px solid var(--line); */
  /* border-radius: 24px;
  box-shadow: var(--shadow); */
}
.padded { padding: 16px; }
.eyebrow { color: var(--accent); font-size: 11px; text-transform: uppercase; letter-spacing: .18em; }
/* label { display: block; margin-top: 10px; color: var(--muted); font-weight: 600; } */
label { color: var(--accent); font-size: 11px; text-transform: uppercase; letter-spacing: .18em; margin-bottom: 10px;}

input, select, button {
  width: 100%;
  margin-top: 8px;
  border-radius: 16px;
  border: 1px solid var(--line);
  padding: 12px 14px;
}
input, select { background: rgba(255,255,255,.04); color: var(--text); }
button { cursor: pointer; transition: transform .15s ease, opacity .15s ease, border-color .15s ease; }
button:hover { transform: translateY(-1px); }
button:disabled { opacity: .55; cursor: not-allowed; }
.primary {
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  color: #121821;
  border: 0;
  font-weight: 800;
}
.ghost {
  background: rgba(255,255,255,.04);
  color: var(--text);
  border-color: var(--line-strong);
}
.small-btn { width: auto; min-width: 86px; margin-top: 0; padding: 10px 12px; border-radius: 14px; }
.icon-btn {
  width: 42px; min-width: 42px; height: 42px; padding: 0; border-radius: 12px; font-size: 28px; line-height: 1;
  background: rgba(255,255,255,.045); color: var(--text);
}

.screen-home { flex: 1; display: grid; place-items: center; }
.home-shell {
  width: min(920px, 100%);
  padding: clamp(10px, 1.5vw, 18px) clamp(16px, 2vw, 22px) clamp(16px, 2vw, 22px);
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(320px, 430px);
  gap: 18px;
  align-items: center;
  background-color: transparent;
}
.home-brand-block {
  display: grid;
  justify-items: center;
  align-self: start;
  gap: 10px;
}
.home-logo {
  width: min(100%, 300px);
  justify-self: center;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.25));
}
.home-card { width: 100%; }

.account-profile-card {
  width: min(100%, 340px);
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
}
.account-avatar {
  position: relative;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 900;
  color: #121821;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
}

.account-profile-card {
  position: relative;
}
.account-logout-btn {
  position: absolute;
  top: 12px;
  right: 12px;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-weight: 800;
  cursor: pointer;
}
.account-logout-btn:hover { background: rgba(255,255,255,.08); }
.account-avatar {
  overflow: hidden;
  cursor: pointer;
  border: 2px solid rgba(255,255,255,.08);
}
.account-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.account-avatar::after {
  content: '\f030';
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  right: -2px;
  bottom: -2px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 10px;
  color: #fff;
  background: var(--accent);
  box-shadow: 0 4px 10px rgba(0,0,0,.35);
}
.account-profile-main {
  min-width: 0;
}
.account-display-name {
  font-size: 17px;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.account-username {
  margin-top: 4px;
  font-size: 13px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.account-stats {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.account-stat-pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 11px 12px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.account-stat-pill span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.account-stat-pill strong {
  font-size: 17px;
  font-weight: 900;
}

.home-head p { margin-top: 10px; color: var(--muted); line-height: 1.45; }
.home-form { display: grid; gap: 0; margin-top: 12px; }

.modal {
  position: fixed; inset: 0; z-index: 20; display: grid; place-items: center; padding: 12px;
}
.modal-backdrop { position: absolute; inset: 0; background: rgba(17, 17, 17, 0.82); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.modal-card { position: relative; z-index: 2; width: min(440px, 100%); }
.modal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 6px; }
.modal-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 14px; }
.modal-actions.single { grid-template-columns: 1fr; }
.info-modal-card { width: min(520px, 100%); }

.rules-fullscreen-modal { padding: 0; }
.rules-fullscreen-backdrop { background: rgba(10, 10, 14, 0.78); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.rules-fullscreen-sheet { position: relative; z-index: 2; width: 100%; height: calc(100dvh - 10px); margin-top: 10px; padding: max(24px, calc(env(safe-area-inset-top) + 16px)) 16px max(0px, env(safe-area-inset-bottom)) 16px; display: grid; align-content: start; background: transparent; box-sizing: border-box; }
.rules-fullscreen-sheet .modal-head { margin-bottom: 10px; }
.rules-fullscreen-sheet h2 { margin: 0; }
.rules-tutorial-body { padding-top: 0; height: calc(100dvh - 100px - env(safe-area-inset-top)); display: grid; min-height: 0; }
.rules-carousel-shell { display: grid; grid-template-rows: auto 1fr auto; gap: 10px; min-height: 0; height: 100%; }
.rules-carousel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.rules-slide-counter { min-width: 54px; padding: 8px 10px; border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.045); color: #fff; font-size: 12px; font-weight: 800; text-align: center; }
.rules-dots { display: flex; align-items: center; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }
.rules-dot { width: 8px; height: 8px; border-radius: 999px; background: rgba(255,255,255,.18); transition: transform .18s ease, background .18s ease, box-shadow .18s ease; }
.rules-dot.active { background: linear-gradient(135deg, #ffd76a, #ff8e63); transform: scale(1.18); box-shadow: 0 0 0 4px rgba(255, 183, 77, .12); }
.rules-carousel-viewport { overflow: hidden; min-height: 0; }
.rules-carousel-track { display: flex; width: 100%; height: 100%; transition: transform .28s ease; touch-action: pan-y; }
.rules-slide { min-width: 100%; display: grid; grid-template-rows: auto auto; gap: 8px; min-height: 0; height: 100%; align-content: start; }
.rules-slide-hero { position: relative; width: 100%; aspect-ratio: 5 / 4; min-height: 0; border-radius: 28px; border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.04); overflow: hidden; display: flex; align-items: stretch; justify-content: stretch; }
.rules-image-hero { position: absolute; inset: 0; padding: 0; display: flex; align-items: stretch; justify-content: stretch; }
.rules-tutorial-image { width: 100%; height: 100%; object-fit: contain; object-position: center; display: block; border-radius: 28px; box-shadow: none; background: transparent; }
.rules-slide-copy { display: grid; gap: 0; padding: 0 2px 2px; }
.rules-slide-copy h3 { margin: 0 0 8px; font-size: 22px; line-height: 1.2; }
.rules-slide-copy p { margin: 0; color: rgba(255,255,255,.82); line-height: 1.45; font-size: 15px; }
.rules-slide-copy strong { color: #fff; }
.rules-slide-copy p + p { margin-top: 2px; }
.rules-slide-copy ul { margin: 0; padding-left: 18px; color: var(--muted); line-height: 1.55; }
.rules-slide-copy li + li { margin-top: 6px; }
.rules-carousel-controls { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; align-items: center; padding-top: 2px; }
.rules-carousel-controls .ghost,
.rules-carousel-controls .primary { min-height: 50px; }
.rules-carousel-controls #rulesNextBtn,
.rules-carousel-controls #rulesPrevBtn { justify-self: stretch; }
.rules-summary-hero { display: grid; grid-template-columns: 1fr; gap: 12px; align-content: start; }
.rules-summary-card { width: 100%; box-sizing: border-box; border-radius: 22px; border: 1px solid rgba(255,255,255,.09); background: rgba(255,255,255,.045); padding: 16px 18px; display: grid; gap: 8px; min-height: 78px; box-shadow: 0 14px 30px rgba(0,0,0,.18); }
.rules-summary-card.wide { grid-column: auto; }
.rules-summary-top { display: flex; align-items: center; gap: 10px; }
.rules-summary-top.centered { justify-content: center; text-align: center; }
.rules-summary-top strong { font-size: 15px; line-height: 1.25; }
.rules-summary-card.note .rules-summary-top strong { max-width: 240px; }
.rules-summary-card p { margin: 0; color: rgba(255,255,255,.82); font-size: 14px; line-height: 1.35; }
.rules-summary-card p span { color: #fff; font-weight: 900; }
.rules-summary-icon { width: 36px; height: 36px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.08); color: #ffd76a; flex: 0 0 36px; }
.rules-summary-icon.bad { color: #ff9090; }
.rules-summary-icon.good { color: #74f0a0; }
.rules-summary-icon.goal { color: #8cc3ff; }
.rules-summary-notes { padding-top: 2px; }
.rules-summary-card.note { justify-items: center; align-items: center; }
.rules-summary-card.note.wide .rules-summary-top strong { max-width: 280px; }
.rules-seat-demo { position: absolute; inset: 14px; border-radius: 22px; border: 1px solid rgba(255,255,255,.06); background: radial-gradient(circle at center, rgba(78,98,150,.28), rgba(24,29,44,.08) 55%, rgba(24,29,44,0) 70%); }
.rules-seat { position: absolute; width: 116px; min-height: 58px; border-radius: 18px; border: 1px solid rgba(255,255,255,.1); background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05)); padding: 10px 12px; display: grid; align-content: center; gap: 3px; box-shadow: 0 14px 30px rgba(0,0,0,.18); }
.rules-seat span { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.rules-seat strong { font-size: 14px; }
.rules-seat.you { border-color: rgba(255, 215, 106, .55); box-shadow: 0 0 0 1px rgba(255, 215, 106, .18), 0 14px 30px rgba(0,0,0,.18); }
.rules-seat.top { top: 6px; left: 50%; transform: translateX(-50%); }
.rules-seat.left { left: 0; top: 50%; transform: translateY(-50%); }
.rules-seat.right { right: 0; top: 50%; transform: translateY(-50%); }
.rules-seat.bottom { bottom: 0; left: 50%; transform: translateX(-50%); }
.rules-seat-badge { position: absolute; top: -10px; right: 12px; padding: 4px 8px; border-radius: 999px; background: linear-gradient(135deg, #ffd76a, #ff9a62); color: #1a1220; font-size: 10px; font-weight: 900; letter-spacing: .08em; }
.rules-table-stack { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); display: flex; gap: 12px; }
.rules-card-demo { width: 58px; height: 84px; border-radius: 16px; background: linear-gradient(180deg, #fff, #f1f3ff); border: 1px solid rgba(255,255,255,.4); color: #17181d; display: grid; place-items: center; font-weight: 900; box-shadow: 0 12px 24px rgba(0,0,0,.22); }
.rules-card-demo.gold { background: linear-gradient(180deg, #ffe7a2, #ffbe6a); }
.rules-card-demo.blue { background: linear-gradient(180deg, #dce7ff, #a3c0ff); }
.rules-card-demo.red { background: linear-gradient(180deg, #ffd8d8, #ffaaa5); }
.rules-hand-row { position: absolute; left: 50%; bottom: 10px; transform: translateX(-50%); display: flex; gap: 8px; }
.rules-hand-card { width: 48px; height: 72px; border-radius: 14px; background: linear-gradient(180deg, #fff, #eff2ff); color: #17181d; border: 1px solid rgba(255,255,255,.5); display: grid; place-items: center; font-weight: 900; box-shadow: 0 12px 24px rgba(0,0,0,.18); }
.rules-bid-demo { position: absolute; inset: 22px; display: grid; align-content: center; justify-items: center; gap: 16px; }
.rules-bid-head { display: grid; gap: 4px; text-align: center; }
.rules-bid-head span { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .12em; }
.rules-bid-head strong { font-size: 26px; }
.rules-bid-pills { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; max-width: 280px; }
.rules-bid-pill { min-width: 44px; height: 44px; border-radius: 999px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.045); font-weight: 800; }
.rules-bid-pill.active { background: linear-gradient(135deg, #ffd76a, #ff975f); color: #1a1220; border-color: transparent; box-shadow: 0 10px 20px rgba(255,146,94,.28); }
.rules-score-grid { position: absolute; inset: 18px; display: grid; gap: 12px; align-content: center; }
.rules-score-row { display: grid; grid-template-columns: 1fr auto; gap: 12px; padding: 14px 16px; border-radius: 18px; border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.04); }
.rules-score-row strong { font-size: 15px; }
.rules-score-row span { color: var(--muted); font-size: 13px; }
.rules-score-points { display: inline-flex; align-items: center; justify-content: center; min-width: 66px; padding: 10px 14px; border-radius: 14px; font-weight: 900; }
.rules-score-points.good { background: rgba(92, 223, 139, .16); color: #74f0a0; }
.rules-score-points.bad { background: rgba(255, 109, 109, .16); color: #ff9090; }
@media (max-width: 560px) {
  .rules-fullscreen-sheet { height: calc(100dvh - 8px); margin-top: 8px; padding: max(18px, calc(env(safe-area-inset-top) + 12px)) 12px max(0px, env(safe-area-inset-bottom)) 12px; }
  .rules-tutorial-body { height: calc(100dvh - 92px - env(safe-area-inset-top)); }
  .rules-slide { grid-template-rows: auto auto; gap: 6px; }
  .rules-slide-copy h3 { font-size: 20px; }
  .rules-slide-copy p { font-size: 14px; line-height: 1.42; }
  .rules-summary-hero { gap: 8px; }
  .rules-summary-card { min-height: 72px; padding: 14px 16px; border-radius: 18px; gap: 6px; }
  .rules-summary-top strong { font-size: 14px; }
  .rules-summary-card p { font-size: 13px; }
}
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 8px; }
.info-grid > div, .info-player { padding: 10px 12px; border-radius: 16px; background: rgba(255,255,255,.04); border: 1px solid var(--line); }
.info-k { display: block; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 4px; }
.info-v { display: block; font-weight: 700; }
.info-list-wrap { margin-top: 12px; }
.info-player-list { display: grid; gap: 8px; margin-top: 8px; }
.info-player { display: flex; justify-content: space-between; align-items: center; }

#screen-game {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0,1fr);
  gap: 12px;
  padding: 14px;
}
.game-topbar {
  display: flex; justify-content: space-between; align-items: center; gap: 12px; min-height: 52px; margin-top: 0;
}
.room-topline { min-width: 0; text-align: center; margin: 0 auto; margin-top: -20px;}
.game-title { font-size: clamp(18px, 2.5vw, 24px); font-weight: 900; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.top-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.bottom-actions { display: flex; gap: 8px; justify-content: stretch; padding-top: 4px; }
.bottom-actions .small-btn { flex: 1; min-width: 0; }

.lobby-view, .table-view { min-height: 0; }
.lobby-view { display: block; min-height: 0; }
.full-card { height: 100%; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }
.section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.start-inline { width: auto; min-width: 130px; margin-top: 0; }
.lobby-meta { margin-top: 6px; color: var(--muted); font-size: 12px; font-weight: 600; }
.players-list, .log-box { display: grid; gap: 8px; margin-top: 10px; }
.players-list { flex: 1; min-height: 0; overflow: auto; padding-right: 4px; }
.players-list.lobby-seats { position: relative; overflow: hidden; padding: 0; margin-top: 14px; min-height: clamp(340px, 52vh, 520px); border-radius: 28px; border: 1px solid rgba(255,255,255,.08); background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.035), transparent 32%), linear-gradient(180deg, var(--felt-2), var(--felt)); }
.players-list.lobby-seats::before { content: ""; position: absolute; inset: 14px; border: 2px solid rgba(255,255,255,.08); border-radius: 50%; }
.log-box { overflow: auto; padding-right: 4px; }
.lobby-log { max-height: 200px; }

.lobby-section-head {
  align-items: flex-start;
}

.lobby-top-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.lobby-top-btn {
  margin-top: 0;
}

#startBtn.lobby-top-btn {
  min-width: 42px;
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 14px;
}

#startBtn.lobby-top-btn i {
  font-size: 15px;
}

.lobby-view {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
}

.lobby-full-card {
  flex: 1;
  min-height: 0;
}


#screen-game.is-lobby {
  gap: 8px;
  padding-top: 18px;
}

#screen-game.is-lobby .game-topbar {
  min-height: 18px;
}

#screen-game.is-lobby .lobby-full-card {
  padding-top: 14px;
}

#screen-game.is-lobby .lobby-view #playersList.players-list.lobby-slot-grid {
  margin-top: 6px;
}

#screen-game.is-lobby .lobby-updates-label {
  margin-top: 10px !important;
}

.lobby-log {
  flex: 1;
  min-height: 160px;
  max-height: none;
  padding-bottom: 4px;
  align-content: start;
  grid-auto-rows: max-content;
}

.player-item {
  padding: 10px; border-radius: 16px; border: 1px solid var(--line); background: rgba(255,255,255,.04);
}
.players-list.lobby-seats .player-item { position: absolute; width: min(220px, 42vw); background: rgba(20, 27, 41, .88); backdrop-filter: blur(6px); }
.compact-details { gap: 6px; margin-top: 6px; }
.compact-details .badge { margin-top: 0; }
.player-item.me { border: 1px solid rgba(199,164,106,.34); }
.player-head { display: flex; justify-content: space-between; gap: 10px; align-items: center; }
.player-head strong { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.head-tags { display: flex; gap: 6px; align-items: center; justify-content: flex-end; flex-shrink: 0; }
.badges { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.details-row { margin-top: 8px; }
.badge { font-size: 11px; padding: 5px 8px; border-radius: 999px; background: rgba(255,255,255,.06); border: 1px solid var(--line); line-height: 1; display: inline-flex; align-items: center; }
.badge.slim { padding: 4px 8px; min-height: 22px; }
.badge.ok { background: color-mix(in srgb, var(--accent) 18%, transparent); color: color-mix(in srgb, white 88%, var(--accent) 12%); border-color: color-mix(in srgb, var(--accent) 28%, transparent); }
.badge.bad { background: rgba(255,123,123,.12); color: #ffd1d1; }
.log-line { font-size: 12px; color: var(--muted); padding: 9px 11px; border-radius: 14px; background: rgba(255,255,255,.03); height: fit-content; min-height: 0; align-self: start; }
.label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.value { font-weight: 800; font-size: 18px; }
.mt { margin-top: 14px; }

.table-view {
  display: grid;
  grid-template-rows: auto minmax(0,1fr) auto;
  gap: 10px;
  min-height: 0;
}
.status-strip {
  display: flex; justify-content: space-between; gap: 10px; padding: 12px 16px; align-items: center; padding-top: 0; margin-top: -30px !important; margin-bottom: 0; padding-bottom: 0;
}
.status-round { min-width: 0; margin-top: 10px; margin-left: 15px; }
.status-actions { display: flex; gap: 8px; justify-content: center; margin-left: auto; margin-right: auto;}
.icon-only-btn { width: 42px; min-width: 42px; height: 42px; padding: 0; display: inline-flex; align-items: center; justify-content: center; border-radius: 14px; }
.icon-only-btn i { font-size: 16px; }
.table {
  display: grid; grid-template-rows: minmax(0,1fr) auto; min-height: 550px; padding: 10px; padding-top: 0px;
}
.table-felt {
  min-height: clamp(340px, 54vh, 620px); border-radius: 28px; border: 1px solid rgba(255,255,255,.08);
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.035), transparent 32%), linear-gradient(180deg, var(--felt-2), var(--felt));
  position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center;
}
.table-felt::before {
  content: ''; position: absolute; inset: 14px; border: 2px solid rgba(255,255,255,.08); border-radius: 50%;
}
.table-cards {
  position: absolute; inset: 0; z-index: 2; min-height: 100%; padding: 16px;
}
.table-center-status {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  z-index: 1;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(20, 27, 41, .88);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
  font-size: 13px;
  font-weight: 800;
  color: var(--text);
  text-align: center;
  max-width: min(72vw, 280px);
}
.table-seat {
  position: absolute;
  display: grid;
  justify-items: center;
  gap: 0;
  width: min(118px, 28vw);
  max-width: min(118px, 28vw);
}
.table-seat.me .table-player-name { color: var(--accent); }
.table-player-name {
  width: 100%;
  font-weight: 800;
  font-size: 12px;
  line-height: 1.15;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.table-player-card {
  width: 100%;
  display: grid;
  justify-items: center;
  gap: 6px;
  padding: 4px 4px 2px;
}
.table-player-avatar.table-player-avatar-main {
  width: clamp(48px, 12vw, 60px);
  height: clamp(48px, 12vw, 60px);
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(255,255,255,.22);
  box-shadow: 0 10px 18px rgba(0,0,0,.24);
  background: rgba(20, 27, 41, .92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 19px;
  font-weight: 900;
}
.table-player-avatar.table-player-avatar-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.table-player-bid-pill {
  min-width: 66px;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(20, 27, 41, .92);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 8px 16px rgba(0,0,0,.2);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}
.table-seat.turn .table-player-bid-pill {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 68%, transparent), 0 8px 16px rgba(0,0,0,.2);
}
.table-player-bid-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  min-width: 14px;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}
.table-player-bid-status i {
  font-size: 11px;
  line-height: 1;
}
.table-player-bid-pill.is-complete .table-player-bid-status i { color: #68e39b; }
.table-player-bid-pill.is-over .table-player-bid-status i { color: #ff7b7b; }
.table-player-bid-pill.is-waiting .table-player-bid-status i { color: rgba(255,255,255,.82); }
.table-player-bid-text {
  white-space: nowrap;
}
.table-player-bid-pill.is-complete { border-color: rgba(83,209,140,.34); }
.table-player-bid-pill.is-over { border-color: rgba(255,123,123,.36); }
.table-player-bid-pill.is-waiting { border-color: rgba(255,255,255,.12); }
.action-area { margin-top: 10px; display: grid; gap: 10px; }
.prompt { font-size: 15px; font-weight: 700; }
.option-row { display: flex; flex-wrap: wrap; gap: 8px; }
.option-row button { width: auto; min-width: 50px; padding: 10px 12px; }
.bottom-strip { display: grid; gap: 10px; }
.hand-panel { min-height: 0; overflow: visible; }
.hand-header { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.summary-box {
  padding: 10px; border-radius: 18px; background: rgba(255,255,255,.04); border: 1px solid var(--line); max-height: 160px; overflow: auto;
}
.summary-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.summary-table th,.summary-table td { padding: 8px; border-bottom: 1px solid rgba(255,255,255,.08); text-align: left; }
.my-hand {
  --hand-overlap: -12px;
  display: flex; flex-wrap: nowrap; justify-content: center; align-items: flex-end; gap: 0; margin-top: 8px; width: 100%; max-width: 100%; max-height: 170px; overflow: visible; padding: 14px 0 4px;
}
.my-hand .playing-card {
  flex: 0 0 auto;
  margin-left: var(--hand-overlap);
  transform-origin: center bottom;
}
.my-hand .playing-card:first-child {
  margin-left: 0;
}
.playing-card {
  width: clamp(60px, 7vw, 82px); min-height: clamp(90px, 11vw, 122px); border-radius: 16px; padding: 8px; color: #111827;
  background: linear-gradient(180deg, #ffffff, #edf2fb); border: 2px solid rgba(255,255,255,.8); box-shadow: 0 12px 20px rgba(0,0,0,.22);
  display: flex; flex-direction: column; justify-content: space-between; user-select: none;
}
.playing-card .rank { font-size: clamp(22px, 2.5vw, 28px); font-weight: 900; line-height: 1; }
.playing-card .suit { font-size: 13px; font-weight: 700; color: #5b6472; }
.playing-card .mini { align-self: flex-end; font-size: 11px; color: #4b5563; font-weight: 700; }
.playing-card.playable { cursor: pointer; transition: transform .15s ease, box-shadow .15s ease; }
.playing-card.inactive { opacity: 1; filter: none; cursor: default; position: relative; }
.playing-card.inactive::after { content: ""; position: absolute; inset: 0; border-radius: inherit; background: rgba(90, 98, 112, .42); pointer-events: none; }
.playing-card.table-card { transform: rotate(calc(var(--r) * 1deg)); }
.playing-card.draw,
.playing-card.win {
  outline: none;
}
.playing-card.draw::before,
.playing-card.win::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-sizing: border-box;
  z-index: 2;
}
.playing-card.draw::before {
  box-shadow: inset 0 0 0 3px var(--danger);
}
.playing-card.win::before {
  box-shadow: inset 0 0 0 3px var(--ok);
}

@media (max-width: 1100px) {
  .home-shell { grid-template-columns: 1fr; text-align: center; }
  .home-brand-block {
  display: grid;
  justify-items: center;
  align-self: start;
  gap: 10px;
}
.home-logo { width: min(100%, 300px); }
}
@media (max-width: 820px) {
  .tg-top-space { min-height: 0; }
  .game-topbar { align-items: flex-start; flex-direction: column; }
  .bottom-actions { width: 100%; justify-content: stretch; }
  .bottom-actions .small-btn { flex: 1; min-width: 0; }
  .status-strip { align-items: center; }
  .my-hand { max-height: 132px; }
  .info-grid { grid-template-columns: 1fr; }
  .players-list.lobby-seats .player-item, .table-seat { max-width: min(112px, 29vw); width: min(112px, 29vw); }
  .table-felt { min-height: clamp(320px, 48vh, 520px); }
}

.room-browser { margin-top: 14px; text-align: left; }
.rooms-list { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; max-height: 220px; overflow: auto; }
.room-row { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 12px; background: rgba(255,255,255,.04); border: 1px solid var(--line); border-radius: 16px; padding: 12px 14px; color: inherit; text-align: left; }
.room-row-title {   font-family: "Unbounded", sans-serif; font-optical-sizing: auto; font-weight: 800; }
.room-row-meta { font-size: 12px; color: var(--muted); margin-top: 4px; }
.room-row-action { font-size: 12px; font-weight: 800; color: var(--accent); }
.empty-room { justify-content: center; color: var(--muted); }
.disabled-room { opacity: .65; }
.compact-head { margin-bottom: 6px; }


.home-only-buttons {
  width: min(440px, 100%);
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.home-menu { width: 100%; display: grid; gap: 10px; }
.locked-btn { opacity: .82; position: relative; }
.locked-btn span { display: block; font-size: 11px; color: var(--muted); margin-top: 4px; }
.kick-btn {
  width: auto; min-width: 0; margin-top: 0; padding: 4px 8px; border-radius: 999px;
  border: 1px solid rgba(255,123,123,.34); background: rgba(255,123,123,.12); color: #ffd1d1; font-size: 11px; line-height: 1;
}


.locked-btn.telegram-style {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  background: linear-gradient(180deg, rgba(38,166,229,.24), rgba(38,166,229,.12));
  border: 1px solid rgba(92,187,255,.28);
  color: rgba(229,244,255,.78);
  opacity: .78;
}
.locked-btn.telegram-style .tg-icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: rgba(84,186,255,.22);
  color: #8fd3ff;
  font-size: 11px;
  flex: 0 0 18px;
}
.locked-btn.telegram-style .tg-main {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  line-height:1.05;
}
.locked-btn.telegram-style .tg-main strong {
  font-size: 14px;
  font-weight: 800;
  color: #d9f0ff;
}
.locked-btn.telegram-style .tg-main span {
  margin-top: 3px;
  color: rgba(223,237,247,.58);
}


.player-round-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
}
.player-round-chip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  min-width: 0;
}
.player-round-chip.me { border-color: rgba(199,164,106,.34); }
.player-round-chip.turn { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 60%, transparent); }
.player-round-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 700;
  font-size: 13px;
}
.player-round-score {
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 800;
  color: var(--text);
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--line);
}
.bid-modal-card {
  width: min(420px, calc(100vw - 24px));
  max-width: calc(100vw - 24px);
  margin: 0 auto;
  overflow-x: hidden;
}
.bid-hint { color: var(--muted); font-size: 13px; margin-top: 2px; }
.bid-picked-players {
  display: none;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  width: min(420px, calc(100vw - 24px));
  max-width: calc(100vw - 24px);
  margin: 10px auto 0;
  position: relative;
  z-index: 23;
}
.bid-picked-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.045);
}
.bid-picked-name {
  font-size: 12px;
  font-weight: 800;
  color: var(--text);
  line-height: 1;
}
.bid-picked-pill {
  min-width: 24px;
  height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--text);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}
.bid-cards {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 14px;
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  max-width: 100%;
  padding: 0 0 4px;
  -webkit-overflow-scrolling: touch;
}
.bid-cards::after {
  content: '';
  flex: 0 0 0;
}
.bid-preview-card {
  transform: scale(.88);
  transform-origin: top center;
  margin-right: -10px;
  flex: 0 0 auto;
}
.bid-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
  width: 100%;
  max-width: 100%;
}
.bid-option-row {
  display: grid;
  gap: 10px;
  width: 100%;
}
.bid-option-btn { min-width: 0; width: 100%; }
.bid-slider-wrap {
  display: grid;
  gap: 12px;
  width: 100%;
}
.bid-slider-value {
  min-width: 92px;
  margin: 0 auto;
  padding: 12px 20px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  box-shadow: 0 8px 22px rgba(0,0,0,.18);
  text-align: center;
  font-size: 34px;
  font-weight: 900;
  line-height: 1;
  transition: transform .18s ease, box-shadow .18s ease;
}
.bid-range-slider {
  --progress: 0%;
  width: calc(100% - 30px);
  margin: 0 15px;
  height: 18px;
  border-radius: 999px;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent) var(--progress), rgba(255,255,255,.14) var(--progress), rgba(255,255,255,.14) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 6px 18px rgba(0,0,0,.16);
  transition: background .16s ease;
}
.bid-range-slider:focus {
  outline: none;
}
.bid-range-slider::-webkit-slider-runnable-track {
  height: 18px;
  border-radius: 999px;
  background: transparent;
}
.bid-range-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 30px;
  height: 30px;
  margin-top: -6px;
  border-radius: 50%;
  border: 4px solid rgba(255,255,255,.96);
  background: var(--accent);
  box-shadow: 0 8px 18px rgba(0,0,0,.28);
  transition: transform .14s ease;
}
.bid-range-slider:active::-webkit-slider-thumb {
  transform: scale(1.06);
}
.bid-range-slider::-moz-range-track {
  height: 18px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
}
.bid-range-slider::-moz-range-progress {
  height: 18px;
  border-radius: 999px;
  background: var(--accent);
}
.bid-range-slider::-moz-range-thumb {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 4px solid rgba(255,255,255,.96);
  background: var(--accent);
  box-shadow: 0 8px 18px rgba(0,0,0,.28);
}
.bid-slider-ticks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  gap: 6px;
  align-items: start;
  padding: 0 15px;
  margin-top: -6px;
}
.bid-slider-tick {
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  min-height: 18px;
  padding: 8px 0 0;
  position: relative;
  line-height: 1;
  cursor: pointer;
  transition: color .16s ease, transform .16s ease;
}
.bid-slider-tick::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  width: 3px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.2);
  transform: translateX(-50%);
}
.bid-slider-tick.is-active {
  color: #fff;
  transform: translateY(-1px);
}
.bid-slider-tick.is-active::before {
  background: var(--accent);
  height: 9px;
}
.bid-confirm-btn {
  width: 100%;
  min-height: 48px;
  border-radius: 16px;
}


.player-round-strip { display:none; }
.bottom-actions.hidden { display:none; }

.seat-pos-bottom { left: 50%; bottom: 14px; transform: translateX(-50%); }
.seat-pos-top { left: 50%; top: 14px; transform: translateX(-50%); }
.seat-pos-left { left: 14px; top: 50%; transform: translateY(-50%); }
.seat-pos-right { right: 14px; top: 50%; transform: translateY(-50%); }
.seat-pos-bottom-left { left: 14px; bottom: 14px; }
.seat-pos-bottom-right { right: 14px; bottom: 14px; }
.seat-pos-top-left { left: 14px; top: 14px; }
.seat-pos-top-right { right: 14px; top: 14px; }

.table-seat .playing-card { width: clamp(48px, 5.4vw, 66px); min-height: clamp(72px, 8vw, 98px); }
.players-list.lobby-seats .player-item .player-head { align-items: flex-start; }


.round-summary-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.round-summary-table th, .round-summary-table td { padding: 10px 8px; border-bottom: 1px solid var(--line); text-align: left; }
.round-summary-table th:last-child, .round-summary-table td:last-child { text-align: right; }
.round-summary-xofy { font-weight: 700; }
.delta-neg { color: var(--danger); font-weight: 800; }
.delta-zero { color: var(--ok); font-weight: 800; }
#roundSummaryBody, #gameOverBody { max-height: min(58vh, 520px); overflow: auto; }
.game-over-actions-note { color: var(--muted); font-size: 13px; margin-top: 10px; }

/* table visual refresh */
.player-round-strip { display:none !important; }
.table {
  min-height: 620px;
  padding: 6px;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.table-felt {
  min-height: clamp(430px, 64vh, 760px);
  border-radius: 42px;
  border: 10px solid #15212d;
  background:
    radial-gradient(circle at 50% 45%, rgba(255,255,255,.08), transparent 34%),
    linear-gradient(180deg, #2aaf57 0%, #1f9747 48%, #16723a 100%);
}
.table-felt::before {
  inset: 14px;
  border-radius: 32px;
  border: 2px solid rgba(255,255,255,.13);
}
.table-felt::after {
  content:'';
  position:absolute;
  inset: 28px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
}
.table-cards { padding: 8px; }
.table-center-board {
  position:absolute;
  left:50%; top:50%; transform: translate(-50%, -50%);
  z-index: 2;
  display:grid; justify-items:center; gap:12px;
  min-width:min(64vw, 360px);
}
.table-center-label {
  font-size:12px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: rgba(255,255,255,.72);
  text-shadow: 0 2px 6px rgba(0,0,0,.22);
}
.table-center-cards {
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  min-height:140px;
  flex-wrap:wrap;
}
.table-center-card-wrap { display:flex; align-items:center; justify-content:center; }
.table-center-card-wrap .table-card { box-shadow: 0 14px 22px rgba(0,0,0,.28); }
.table-seat {
  max-width: min(190px, 36vw);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.table-seat.top,
.table-seat.seat-pos-top,
.table-seat.seat-pos-top-left,
.table-seat.seat-pos-top-right { flex-direction:column; }
.table-seat.me { z-index: 4; }
.table-player-avatar {
  width: 42px; height:42px; border-radius:50%;
  background: linear-gradient(180deg, #f5d18b, #c79d4d);
  color:#13202d; font-weight:900; font-size:14px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 18px rgba(0,0,0,.25);
  border:2px solid rgba(255,255,255,.22);
  flex:0 0 42px;
}
.table-player-stack {
  min-width:0;
  display:grid;
  gap:4px;
  justify-items:center;
}
.table-player-name {
  font-weight:900;
  font-size:13px;
  text-align:center;
  color:#fff;
  text-shadow:0 2px 8px rgba(0,0,0,.35);
}
.table-player-meta {
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:4px;
  justify-content:center;
  padding:4px 6px;
  border-radius:999px;
  background: rgba(16,25,35,.78);
  border:1px solid rgba(255,255,255,.12);
  white-space: nowrap;
}
.badge-rate { background: rgba(255,255,255,.1); }
.table-seat.turn .table-player-avatar {
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 58%, transparent), 0 8px 18px rgba(0,0,0,.25);
}
.table-seat.turn .table-player-meta { box-shadow:none; }
.seat-pos-bottom { left:50%; bottom:60px !important; transform:translateX(-50%); }
.seat-pos-top { left:50%; top:14px; transform:translateX(-50%); }
.seat-pos-left { left:16px; top:50%; transform:translateY(-50%); }
.seat-pos-right { right:16px; top:50%; transform:translateY(-50%); }
.seat-pos-bottom-left { left:18px; bottom:22px; }
.seat-pos-bottom-right { right:18px; bottom:22px; }
.seat-pos-top-left { left:18px; top:18px; }
.seat-pos-top-right { right:18px; top:18px; }
.table-center-status {
  top:50%;
  transform: translate(-50%, calc(-50% + 110px));
  background: rgba(16,25,35,.82);
}
@media (max-width: 820px) {
  .table { min-height: 560px; }
  .table-felt { min-height: clamp(420px, 60vh, 680px); border-width: 8px; }
  .table-player-avatar { width:36px; height:36px; font-size:12px; }
  .table-seat { max-width: min(150px, 38vw); gap:8px; }
  .table-player-name { font-size:12px; }
  .table-center-cards { min-height:120px; gap:8px; }
  .table-center-card-wrap .playing-card { width:58px; min-height:88px; }
  .seat-pos-bottom { bottom:8px; }
  .seat-pos-top { top:8px; }
  .seat-pos-left { left:8px; }
  .seat-pos-right { right:8px; }
  .seat-pos-bottom-left { left:10px; bottom:18px; }
  .seat-pos-bottom-right { right:10px; bottom:18px; }
  .seat-pos-top-left { left:10px; top:12px; }
  .seat-pos-top-right { right:10px; top:12px; }
}

@media (hover: hover) and (pointer: fine) {
  .playing-card.playable:hover { transform: translateY(-6px); box-shadow: 0 16px 24px rgba(0,0,0,.28); }
}

.table-player-avatar { display:none !important; }
.table-center-label { display:none !important; }


.bid-hint {
  margin-top: 6px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}
.last-trick-corner-btn {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 4;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(20, 27, 41, .86);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 18px rgba(0,0,0,.18);
}
.last-trick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 10px;
  margin-top: 8px;
}
.last-trick-entry {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  padding: 12px;
}
.last-trick-name {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.last-trick-card {
  font-size: 28px;
  font-weight: 900;
}
.muted-note { color: var(--muted); font-size: 14px; }

/* requested layout adjustments */

.table-view {
  position: relative;
  grid-template-rows: auto minmax(0,1fr);
  padding-bottom: 0;
}
.status-strip {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 0;
}
.status-meta-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  margin: 0;
}
.status-round {
  display: grid;
  gap: 2px;
  align-items: center;
  text-align: center;
  padding: 8px 12px;
  border-radius: 16px;
  background: rgba(16,25,35,.52);
  border: 1px solid rgba(255,255,255,.08);
  min-width: 84px;
  margin: 0 !important;
}

.table {
  height: auto;
  min-height: 0;
  padding: 0;
  overflow: visible;
  width: 100%;
}
.table-felt {
  min-height: 0;
  height: auto;
  align-items: stretch;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}
.table-felt::before,
.table-felt::after {
  content: none !important;
  display: none !important;
}
.table-cards {
  z-index: 2;
}
.bottom-strip {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100vw - max(12px, env(safe-area-inset-left)) - max(12px, env(safe-area-inset-right)));
  max-width: calc(100vw - max(12px, env(safe-area-inset-left)) - max(12px, env(safe-area-inset-right)));
  bottom: max(8px, env(safe-area-inset-bottom));
  z-index: 6;
  padding: 0 0 2px;
  display: grid;
  gap: 6px;
  pointer-events: none;
}
.hand-panel {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: visible;
  pointer-events: none;
}
#myHand,
#myHand .playing-card { pointer-events: auto; }
#myHand {
  width: min(95%, calc(100% - 50px));
  max-width: min(95%, calc(100% - 50px));
  margin: 0 auto;
  padding: 0 10px;
  box-sizing: border-box;
  overflow: visible;
}
.my-hand {
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  max-width: 100%;
  max-height: none;
  overflow: visible;
  padding: 18px 0 6px;
  box-sizing: border-box;
}
.my-hand .playing-card {
  position: relative;
  z-index: 1;
}
.my-hand .playing-card:hover,
.my-hand .playing-card.playable:hover {
  z-index: 2;
}
.table-seat.me {
  z-index: 8;
}
.seat-pos-bottom,
.seat-pos-bottom-left,
.seat-pos-bottom-right {
  bottom: 146px;
}
.table-player-stack {
  position: relative;
  z-index: 9;
}
.table-player-meta {
  flex-wrap: nowrap !important;
}
.last-trick-corner-btn {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid rgba(255,255,255,.10);
  outline: none;
}

@media (max-width: 820px) {
  .status-meta-row { gap: 8px; }
  .status-round { min-width: 78px; padding: 8px 10px; }
  .status-round .value { font-size: 15px; }
  .bottom-strip { padding: 0; }
  .my-hand { padding-top: 18px; }
  .seat-pos-bottom,
  .seat-pos-bottom-left,
  .seat-pos-bottom-right { bottom: 132px; }
}


@media (hover: none), (pointer: coarse) {
  .my-hand .playing-card:hover,
  .my-hand .playing-card.playable:hover,
  .my-hand .playing-card:active {
    transform: var(--hand-transform, none) !important;
    box-shadow: 0 12px 20px rgba(0,0,0,.22) !important;
  }
}


/* lobby players should be simple cards, not table seats */
.lobby-view #playersList.players-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  padding: 0;
  min-height: 0;
  background: transparent;
  border: 0;
}
.lobby-view #playersList.players-list::before { content: none; }
.lobby-view #playersList .player-item {
  position: relative;
  inset: auto;
  width: 100%;
  max-width: none;
  transform: none;
  background: rgba(20, 27, 41, .88);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
}


.reaction-modal-card { width: min(360px, 100%); background: var(--bg); border: 1px solid var(--line); border-radius: 24px; }
.reaction-options { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-top: 10px; }
.reaction-emoji-btn { margin-top: 0; font-size: 28px; line-height: 1; padding: 14px 0; border-radius: 18px; background: rgba(255,255,255,.045); color: var(--text); border: 1px solid var(--line); }
.table-reaction { position: absolute; top: -22px; right: -4px; min-width: 34px; height: 34px; padding: 0 8px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; font-size: 21px; background: rgba(20,27,41,.92); border: 1px solid rgba(255,255,255,.12); box-shadow: 0 8px 18px rgba(0,0,0,.28); animation: popReaction .22s ease; z-index: 5; }
@keyframes popReaction { from { transform: scale(.82) translateY(6px); opacity: 0; } to { transform: scale(1) translateY(0); opacity: 1; } }


.auth-shell {
  width: min(440px, 100%);
}
.account-badge {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.045);
  border: 1px solid var(--line);
  color: var(--text);
  font-weight: 700;
  font-size: 13px;
  text-align: center;
}
button:disabled {
  opacity: .6;
  cursor: not-allowed;
}


.auth-panel {
  text-align: left;
}
.auth-copy {
  text-align: center;
  margin-bottom: 6px;
}

.auth-input-wrap {
  position: relative;
}
.auth-input-wrap input {
  padding-right: 52px;
}
.auth-status-icon {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-35%);
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  border: 1px solid transparent;
  background: rgba(255,255,255,.045);
  pointer-events: none;
}
.auth-status-icon.muted,
.auth-status-icon.loading {
  color: transparent;
  border-color: var(--line);
}
.auth-status-icon.success {
  color: #59d18c;
  border-color: rgba(89,209,140,.35);
  background: rgba(89,209,140,.12);
}
.auth-status-icon.error {
  color: #ff7d7d;
  border-color: rgba(255,125,125,.35);
  background: rgba(255,125,125,.12);
}

.password-strength-bar {
  margin: 3px 2px 0;
  height: 5px;
  border-radius: 999px;
  margin-top: -10px !important;
  overflow: hidden;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--line);
}
.password-strength-bar span {
  display: block;
  height: 100%;
  width: 0%;
  border-radius: inherit;
  transition: width .2s ease, background .2s ease;
}
.password-strength-bar.too-short span,
.password-strength-bar.weak span {
  width: 33%;
  background: #ff7d7d;
}
.password-strength-bar.medium span {
  width: 66%;
  background: #ffcd70;
}
.password-strength-bar.strong span {
  width: 100%;
  background: #59d18c;
}

.auth-input-hint {
  min-height: 0;
  margin: 0;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .01em;
}
.auth-input-hint:empty {
  display: none;
}
.auth-input-hint.muted {
  color: var(--muted);
}
.auth-input-hint.success {
  color: #59d18c;
}
.auth-input-hint.error {
  color: #ff7d7d;
}
.auth-input-hint.warning {
  color: #ffcd70;
}

.auth-panel h2 {
  margin: 2px 0 0;
  font-size: 22px;
}

h2 {
  font-family: "Unbounded", sans-serif !important;
  font-optical-sizing: auto !important;
}



input:focus,
select:focus,
.auth-switch-btn:focus,
.auth-switch-btn:focus-visible,
.telegram-auth-btn:focus,
.telegram-auth-btn:focus-visible,
.primary:focus,
.primary:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}

.auth-or {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 8px 0 10px;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: .16em;
}
.auth-or span {
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,.14);
}
.auth-or strong {
  font-size: 11px;
  font-weight: 800;
  color: var(--muted);
}
.auth-switch-line {
  text-align: center;
  font-size: 13px;
  color: var(--muted);
  margin-top: 10px;
}
.auth-switch-btn {
  margin: 0;
  padding: 0;
  width: auto;
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--accent);
  font-weight: 800;
  display: inline;
  border-radius: 8px;
}
.telegram-auth-btn {
  width: 100%;
  min-width: 0;
  margin-top: 8px;
  min-height: 48px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  background: linear-gradient(180deg, #2aabee, #229ed9);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  box-shadow: 0 10px 24px rgba(34,158,217,.22);
}
.telegram-auth-btn .tg-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.18);
  color: #fff;
  font-size: 18px;
  flex: 0 0 30px;
}
.telegram-auth-btn .tg-main {
  display:flex;
  flex-direction:row;
  align-items:center;
  line-height:1;
}
.telegram-auth-btn .tg-main strong {
  font-size: 14px;
  font-weight: 800;
  color: #fff;
}

.telegram-auth-btn:disabled {
  opacity: .6;
}


.account-profile-card {
  width: min(100%, 340px);
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  align-items: stretch;
}
.account-profile-top {
  display: grid;
  grid-template-columns: 42px minmax(0,1fr) 42px 42px;
  gap: 12px;
  align-items: center;
}
.account-profile-main {
  min-width: 0;
  order: 0;
}
.account-logout-btn {
  position: static;
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.account-logout-btn i { font-size: 16px; }
.home-action-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.home-action-row > button { min-width: 0; }
.home-find-block {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}
.home-find-head {
  margin-bottom: 10px;
}
.home-rooms-list {
  max-height: 240px;
  overflow: auto;
  padding-right: 4px;
}


.home-shell-topbar-layout {
  width: min(520px, 100%);
  align-items: stretch;
}
.home-topbar {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 2px;
}
.home-logo-top {
  width: min(100%, 112px);
  margin-top: -6px;
  justify-self: start;
  align-self: flex-start;
}
.home-top-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.top-icon-btn {
  width: 42px;
  min-width: 42px;
  height: 42px;
  margin-top: 0;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.045);
  border: 1px solid var(--line);
}
.top-icon-btn i {
  font-size: 16px;
  color: var(--text);
}
.profile-icon-btn {
  position: relative;
  overflow: visible;
}
.top-profile-avatar {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  font-weight: 900;
  color: #121821;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  overflow: hidden;
}
.top-profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.profile-notification-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ff4d67;
  color: #fff;
  border: 2px solid var(--bg);
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  z-index: 2;
}
.room-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.rooms-head-title {
  font-size: 18px;
  font-weight: 800;
}
.rooms-sort-wrap {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.rooms-sort-wrap select.rooms-sort-select {
  margin: 0;
  width: auto;
  min-width: 112px;
  padding: 8px 28px 8px 10px;
  border-radius: 12px;
  font-size: 12px;
}
.home-find-block {
  text-align: left;
}


.home-logo-top {
  width: 112px;
  justify-self: start;
}
.home-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.home-top-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}
.top-icon-btn {
  width: 42px;
  height: 42px;
  min-width: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.top-profile-avatar {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  font-weight: 800;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  color: #121821;
}
.top-profile-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.profile-modal-card {
  width: min(380px, 100%);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 18px;
}
.account-profile-card {
  width: 100%;
  grid-template-columns: 1fr;
  gap: 14px;
}
.account-profile-top {
  display: grid;
  gap: 14px;
}
.account-profile-main-wrap {
  display: grid;
  grid-template-columns: minmax(0,1fr) 62px;
  gap: 12px;
  align-items: center;
}
.account-logout-btn {
  position: static;
  width: 42px;
  min-width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.rooms-head-title {
  font-weight: 800;
}
.rooms-sort-wrap {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
}
.rooms-sort-select {
  margin-top: 0;
  width: auto;
  min-width: 116px;
  padding: 10px 12px;
}


/* main-menu top alignment update */
#screen-home {
  place-items: start center;
  align-content: start;
  padding-top: 50px;
}
#screen-home .home-shell-topbar-layout {
  margin-top: 0;
  padding-top: 0;
}
#screen-home .home-topbar {
  align-items: flex-start;
  margin-bottom: 6px;
}
#screen-home .home-logo-top {
  width: auto;
  height: 42px;
  max-width: 180px;
  margin-top: 0;
  object-fit: contain;
  object-position: left center;
  display: block;
}


/* profile overlay cleanup + main menu spacing update */
.home-shell-topbar-layout {
  grid-template-columns: 1fr;
  gap: 8px;
}
#screen-home {
  padding-top: 58px;
}
#screen-home .home-topbar {
  margin-bottom: 0;
}
#screen-home .home-menu {
  padding-top: 10px;
}
.profile-modal-card {
  width: min(380px, 100%);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 0;
  box-shadow: none;
}
#screen-profile .account-profile-card {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  padding: 16px;
  border-radius: 24px;
  border: 0;
  background: transparent;
}
#screen-profile .account-profile-top {
  display: grid;
  grid-template-columns: 62px minmax(0,1fr) 42px 42px;
  gap: 12px;
  align-items: center;
}
#screen-profile .account-profile-main {
  min-width: 0;
}
#screen-profile .account-avatar {
  width: 62px;
  height: 62px;
}
#screen-profile .account-logout-btn {
  position: static;
  width: 42px;
  min-width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.profile-close-hint {
  text-align: center;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}


/* table seats with avatars on border */
.table {
  overflow: visible;
}
.table-felt,
.table-cards {
  overflow: visible;
}
.table-cards {
  z-index: 3;
}
.table-seat {
  z-index: 6;
  max-width: min(154px, 34vw);
}
.table-player-stack {
  gap: 6px;
}
.table-player-avatar {
  display: flex !important;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  overflow: hidden;
  background: linear-gradient(180deg, #f5d18b, #c79d4d);
  color: #13202d;
  font-weight: 900;
  font-size: 15px;
  align-items: center;
  justify-content: center;
  border: 2px solid rgba(255,255,255,.26);
  box-shadow: 0 10px 22px rgba(0,0,0,.28);
  flex: 0 0 48px;
}
.table-player-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.table-player-name {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.table-player-meta {
  min-height: 28px;
}
.table-seat.turn .table-player-avatar {
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 56%, transparent), 0 10px 22px rgba(0,0,0,.28);
}
.seat-pos-bottom { left: 50%; bottom: 8px !important; transform: translateX(-50%); }
.seat-pos-top { left: 50%; top: 8px; transform: translateX(-50%); }
.seat-pos-left { left: 3.5%; top: 50%; transform: translateY(-50%); }
.seat-pos-right { right: 3.5%; top: 50%; transform: translateY(-50%); }
.seat-pos-bottom-left { left: 22%; bottom: 8px; }
.seat-pos-bottom-right { right: 22%; bottom: 8px; }
.seat-pos-top-left { left: 22%; top: 8px; }
.seat-pos-top-right { right: 22%; top: 8px; }
@media (max-width: 820px) {
  .table-player-avatar { width: 42px; height: 42px; font-size: 13px; }
  .table-seat { max-width: min(132px, 36vw); }
  .seat-pos-bottom { bottom: 6px !important; }
  .seat-pos-top { top: 6px; }
  .seat-pos-left { left: 3%; }
  .seat-pos-right { right: 3%; }
  .seat-pos-bottom-left { left: 18%; bottom: 6px; }
  .seat-pos-bottom-right { right: 18%; bottom: 6px; }
  .seat-pos-top-left { left: 18%; top: 6px; }
  .seat-pos-top-right { right: 18%; top: 6px; }
  .table {
    min-height: clamp(640px, calc(100vh - 188px), 860px);
  }
  .table-felt {
    width: min(calc(100vw - 96px), 100%);
    max-width: calc(100vw - 96px);
    height: clamp(360px, calc(100vh - 360px), 600px);
    margin-top: 34px;
  }
}


/* seats around table border, table stays mainly for cards */
.table {
  overflow: visible;
}
.table-felt,
.table-cards {
  overflow: visible;
}
.table-cards {
  position: relative;
}
.table-seat {
  z-index: 7;
}
.table-player-card {
  align-items: center;
}
.seat-pos-bottom {
  left: 50%;
  bottom: 0 !important;
  transform: translate(-50%, 42%);
}
.seat-pos-top {
  left: 50%;
  top: 0;
  transform: translate(-50%, -42%);
}
.seat-pos-left {
  left: 0;
  top: 50%;
  transform: translate(-42%, -50%);
}
.seat-pos-right {
  right: 0;
  top: 50%;
  transform: translate(42%, -50%);
}
.seat-pos-bottom-left {
  left: 18%;
  bottom: 0;
  transform: translate(-28%, 42%);
}
.seat-pos-bottom-right {
  right: 18%;
  bottom: 0;
  transform: translate(28%, 42%);
}
.seat-pos-top-left {
  left: 18%;
  top: 0;
  transform: translate(-28%, -42%);
}
.seat-pos-top-right {
  right: 18%;
  top: 0;
  transform: translate(28%, -42%);
}
@media (max-width: 820px) {
  .seat-pos-bottom { transform: translate(-50%, 38%); }
  .seat-pos-top { transform: translate(-50%, -38%); }
  .seat-pos-left { transform: translate(-36%, -50%); }
  .seat-pos-right { transform: translate(36%, -50%); }
  .seat-pos-bottom-left { left: 16%; transform: translate(-22%, 38%); }
  .seat-pos-bottom-right { right: 16%; transform: translate(22%, 38%); }
  .seat-pos-top-left { left: 16%; transform: translate(-22%, -38%); }
  .seat-pos-top-right { right: 16%; transform: translate(22%, -38%); }
}


/* final table layout remake: table only for cards, seats around border */
.table {
  position: relative;
  display: grid;
  grid-template-rows: minmax(0,1fr) auto;
  min-height: clamp(620px, calc(100vh - 210px), 840px);
  padding: 0;
  overflow: visible;
}
.table-felt {
  position: relative;
  width: min(calc(100vw - 118px), 980px);
  max-width: calc(100vw - 118px);
  height: clamp(340px, calc(100vh - 380px), 560px);
  min-height: 0;
  margin: 26px auto 0;
  align-self: start;
  justify-self: center;
  border-radius: 40px;
  border: 10px solid #15212d;
  background:
    radial-gradient(circle at 50% 46%, rgba(255,255,255,.08), transparent 36%),
    linear-gradient(180deg, #2aaf57 0%, #1f9747 48%, #16723a 100%);
  overflow: visible;
}
.table-felt::before {
  content: '';
  position: absolute;
  inset: 14px;
  border-radius: 30px;
  border: 2px solid rgba(255,255,255,.13);
}
.table-felt::after {
  content: '';
  position: absolute;
  inset: 28px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
}
.table-cards {
  position: absolute;
  inset: 0;
  padding: 10px;
  overflow: visible;
}
.table-center-board {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  min-width: min(58vw, 320px);
}
.table-center-cards {
  gap: 10px;
  min-height: 112px;
}
.table-center-card-wrap .playing-card {
  width: clamp(56px, 7vw, 74px);
}
.table-seat {
  position: absolute;
  width: min(124px, 30vw);
  max-width: min(124px, 30vw);
  z-index: 8;
}
.table-player-card {
  width: 100%;
  align-items: center;
}
.seat-pos-bottom {
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 48%);
}
.seat-pos-top {
  left: 50%;
  top: 0;
  transform: translate(-50%, -48%);
}
.seat-pos-left {
  left: 0;
  top: 50%;
  transform: translate(-48%, -50%);
}
.seat-pos-right {
  right: 0;
  top: 50%;
  transform: translate(48%, -50%);
}
.seat-pos-bottom-left {
  left: 16%;
  bottom: 0;
  transform: translate(-18%, 48%);
}
.seat-pos-bottom-right {
  right: 16%;
  bottom: 0;
  transform: translate(18%, 48%);
}
.seat-pos-top-left {
  left: 16%;
  top: 0;
  transform: translate(-18%, -48%);
}
.seat-pos-top-right {
  right: 16%;
  top: 0;
  transform: translate(18%, -48%);
}
.playing-card {
  width: clamp(62px, 7.2vw, 82px);
  min-height: auto;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 10px;
  box-shadow: 0 10px 18px rgba(0,0,0,.22);
  overflow: hidden;
  position: relative;
  display: block;
  line-height: 0;
}
.playing-card .rank,
.playing-card .suit,
.playing-card .mini {
  display: none;
}
.playing-card-img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: inherit;
  pointer-events: none;
  user-select: none;
}
.playing-card.inactive::after {
  border-radius: inherit;
}
.action-area {
  position: relative;
  z-index: 3;
  margin-top: 16px;
}
@media (max-width: 820px) {
  .table {
    min-height: clamp(520px, calc(100vh - 210px), 640px);
  }
  .table-felt {
    width: min(88vw, 680px);
    height: clamp(248px, 36vh, 332px);
    margin-top: 14px;
    border-width: 8px;
    border-radius: 32px;
  }
  .table-felt::before {
    inset: 11px;
    border-radius: 24px;
  }
  .table-felt::after {
    inset: 22px;
    border-radius: 18px;
  }
  .table-seat {
    width: min(112px, 31vw);
    max-width: min(112px, 31vw);
  }
  .seat-pos-bottom { transform: translate(-50%, 44%); }
  .seat-pos-top { transform: translate(-50%, -44%); }
  .seat-pos-left { transform: translate(-44%, -50%); }
  .seat-pos-right { transform: translate(44%, -50%); }
  .seat-pos-bottom-left { left: 13%; transform: translate(-14%, 44%); }
  .seat-pos-bottom-right { right: 13%; transform: translate(14%, 44%); }
  .seat-pos-top-left { left: 13%; transform: translate(-14%, -44%); }
  .seat-pos-top-right { right: 13%; transform: translate(14%, -44%); }
  .table-center-cards {
    min-height: 96px;
    gap: 8px;
  }
  .table-center-card-wrap .playing-card {
    width: clamp(50px, 13vw, 64px);
  }
}

/* latest table sizing fix: narrower table, taller table area, more top/bottom space for border seats */
.table-view {
  padding-bottom: 0;
}
.table {
  min-height: clamp(600px, 72vh, 760px);
  padding-top: clamp(54px, 7vh, 88px);
  padding-bottom: clamp(150px, 20vh, 210px);
  overflow: visible;
}
.table-felt {
  width: min(72vw, 700px);
  height: clamp(300px, 42vh, 420px);
  margin: 0 auto;
}
.table-seat {
  width: min(122px, 28vw);
  max-width: min(122px, 28vw);
}
.seat-pos-left { transform: translate(-42%, -50%); }
.seat-pos-right { transform: translate(42%, -50%); }
.seat-pos-top { transform: translate(-50%, -42%); }
.seat-pos-bottom { transform: translate(-50%, 42%); }
.seat-pos-bottom-left { left: 15%; transform: translate(-12%, 42%); }
.seat-pos-bottom-right { right: 15%; transform: translate(12%, 42%); }
.seat-pos-top-left { left: 15%; transform: translate(-12%, -42%); }
.seat-pos-top-right { right: 15%; transform: translate(12%, -42%); }

@media (max-width: 820px) {
  .table {
    min-height: clamp(620px, 74vh, 760px);
    padding-top: clamp(66px, 8vh, 96px);
    padding-bottom: clamp(156px, 22vh, 220px);
  }
  .table-felt {
    width: min(66vw, 520px);
    height: clamp(310px, 40vh, 420px);
    border-width: 8px;
  }
  .table-seat {
    width: min(108px, 27vw);
    max-width: min(108px, 27vw);
  }
  .seat-pos-left { left: 0; transform: translate(-36%, -50%); }
  .seat-pos-right { right: 0; transform: translate(36%, -50%); }
  .seat-pos-top { top: 0; transform: translate(-50%, -38%); }
  .seat-pos-bottom { bottom: 0; transform: translate(-50%, 38%); }
  .seat-pos-bottom-left { left: 14%; transform: translate(-8%, 38%); }
  .seat-pos-bottom-right { right: 14%; transform: translate(8%, 38%); }
  .seat-pos-top-left { left: 14%; transform: translate(-8%, -38%); }
  .seat-pos-top-right { right: 14%; transform: translate(8%, -38%); }
}


/* keep table card highlight and shadow matched to image size on all devices */
.table-center-card-wrap .playing-card,
.playing-card.table-card {
  box-sizing: border-box;
  background: transparent;
}
.table-center-card-wrap .playing-card::before,
.playing-card.table-card::before {
  border-radius: inherit;
}

/* row layout instead of table */
.table {
  min-height: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.table-felt {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}
.table-cards {
  position: relative;
  width: 100%;
  min-height: 0 !important;
  padding: 6px 0 0 !important;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}
.table-player-row {
  --seat-cols: 3;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(var(--seat-cols), minmax(0, 108px));
  justify-content: center;
  align-items: start;
  justify-items: center;
  column-gap: clamp(8px, 1.8vw, 18px);
  row-gap: 16px;
  padding: 0 clamp(6px, 2vw, 18px);
  box-sizing: border-box;
}
.table-seat,
.table-seat-row-item {
  position: static !important;
  inset: auto !important;
  transform: none !important;
}
.table-seat-row-item {
  width: 100%;
  min-width: 0;
  max-width: 108px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.table-seat-row-item .table-player-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.table-seat-row-item .table-player-avatar {
  width: clamp(52px, 11vw, 66px);
  height: clamp(52px, 11vw, 66px);
  border-radius: 50% !important;
  overflow: hidden;
}
.table-seat-row-item .table-player-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50% !important;
}
.table-play-slot {
  width: min(100%, 76px);
  min-height: 108px;
  border-radius: 18px;
  border: 1px dashed rgba(255,255,255,.18);
  background: rgba(255,255,255,.03);
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
.table-play-slot.has-card {
  border-style: solid;
  border-color: transparent;
  background: transparent;
}
.table-card-inline {
  width: 100% !important;
  min-height: 0 !important;
}
.table-row-status {
  position: static !important;
  margin-top: 2px;
}
@media (max-width: 820px) {
  .table-cards {
    padding: 4px 0 0 !important;
    gap: 10px;
  }
  .table-player-row {
    grid-template-columns: repeat(var(--seat-cols), minmax(0, 92px));
    column-gap: 6px;
    row-gap: 12px;
    padding: 0 4px;
  }
  .table-seat-row-item {
    max-width: 92px;
    gap: 8px;
  }
  .table-seat-row-item .table-player-avatar {
    width: clamp(40px, 10vw, 54px);
    height: clamp(40px, 10vw, 54px);
  }
  .table-seat-row-item .table-player-name {
    font-size: 11px;
  }
  .table-seat-row-item .table-player-bid-pill {
    font-size: 11px;
    padding: 5px 8px;
  }
  .table-play-slot {
    width: min(100%, 62px);
    min-height: 90px;
    border-radius: 15px;
  }
}

/* latest fix: remove remaining container feel and force true circular avatars */
.table-view {
  overflow-x: hidden;
}
.table {
  width: calc(100% + 24px) !important;
  margin-left: -12px !important;
  margin-right: -12px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.table-felt,
.table-cards {
  width: 100% !important;
  max-width: 100% !important;
}
.table-cards {
  padding: 8px max(8px, env(safe-area-inset-left)) 0 max(8px, env(safe-area-inset-right)) !important;
}
.table-player-row {
  width: 100% !important;
  padding: 0 !important;
  column-gap: clamp(6px, 1.4vw, 14px) !important;
  row-gap: 16px !important;
}
.table-seat-row-item {
  max-width: none !important;
  gap: 12px !important;
}
.table-seat-row-item .table-player-card {
  width: auto !important;
  min-width: 0;
}
.table-seat-row-item .table-player-avatar,
.table-player-avatar,
.table-player-avatar.table-player-avatar-main {
  aspect-ratio: 1 / 1 !important;
  width: clamp(54px, 10vw, 72px) !important;
  height: clamp(54px, 10vw, 72px) !important;
  min-width: clamp(54px, 10vw, 72px) !important;
  min-height: clamp(54px, 10vw, 72px) !important;
  max-width: clamp(54px, 10vw, 72px) !important;
  max-height: clamp(54px, 10vw, 72px) !important;
  flex: 0 0 clamp(54px, 10vw, 72px) !important;
  border-radius: 9999px !important;
  overflow: hidden !important;
}
.table-seat-row-item .table-player-avatar img,
.table-player-avatar img,
.table-player-avatar.table-player-avatar-main img {
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 9999px !important;
}

@media (max-width: 820px) {
  .table {
    width: calc(100% + 24px) !important;
    margin-left: -12px !important;
    margin-right: -12px !important;
  }
  .table-cards {
    padding: 8px max(6px, env(safe-area-inset-left)) 0 max(6px, env(safe-area-inset-right)) !important;
  }
  .table-player-row {
    grid-template-columns: repeat(var(--seat-cols), minmax(0, 92px)) !important;
    column-gap: 4px !important;
    row-gap: 12px !important;
  }
  .table-seat-row-item {
    gap: 10px !important;
  }
  .table-seat-row-item .table-player-avatar,
  .table-player-avatar,
  .table-player-avatar.table-player-avatar-main {
    aspect-ratio: 1 / 1 !important;
    width: clamp(44px, 10.5vw, 58px) !important;
    height: clamp(44px, 10.5vw, 58px) !important;
    min-width: clamp(44px, 10.5vw, 58px) !important;
    min-height: clamp(44px, 10.5vw, 58px) !important;
    max-width: clamp(44px, 10.5vw, 58px) !important;
    max-height: clamp(44px, 10.5vw, 58px) !important;
    flex: 0 0 clamp(44px, 10.5vw, 58px) !important;
    border-radius: 9999px !important;
  }
}

/* fix cropped top/bottom controls after full-width table row layout */
.status-strip,
.player-round-strip,
.bottom-actions {
  position: relative;
  z-index: 40 !important;
}

.status-actions,
.status-meta-row,
#reactionBtn,
#tableInfoBtn,
#tableLeaveBtn,
#copyCodeBtn,
#leaveBtn {
  position: relative;
  z-index: 41 !important;
}

.table {
  position: relative;
  z-index: 1 !important;
}

.table-felt,
.table-cards,
.table-player-row {
  position: relative;
  z-index: 2;
}

.bottom-actions {
  margin-top: 8px;
}

/* top controls overlay fix */
#screen-game,
.table-view {
  position: relative;
  isolation: isolate;
  overflow: visible;
}

.game-topbar,
.status-strip,
.status-actions,
.status-meta-row,
.bottom-actions {
  position: relative;
  z-index: 60 !important;
}

.status-strip {
  margin-top: 0 !important;
}

.table,
.table-felt,
.table-cards,
.table-player-row {
  position: relative;
  z-index: 1 !important;
}


/* top controls arrangement update */
.status-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  flex-wrap: nowrap;
}
.status-actions > .icon-only-btn {
  flex: 0 0 auto;
}
.status-meta-row {
  flex: 1 1 auto;
  justify-content: center;
}
#tableInfoBtn {
  order: 10;
}
#tableLeaveBtn {
  order: 11;
}
#lastTrickBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* move players/cards row slightly down to leave space for reactions */
.table-cards {
  padding-top: 34px !important;
}
.table-player-row {
  margin-top: 6px;
}

@media (max-width: 820px) {
  .status-actions {
    gap: 8px;
  }
  .table-cards {
    padding-top: 30px !important;
  }
}


/* center top controls and keep them from shifting the whole page */
.status-strip {
  overflow: visible !important;
}
.status-actions {
  width: 100% !important;
  max-width: 100% !important;
  display: grid !important;
  grid-template-columns: auto auto auto auto auto;
  align-items: center !important;
  justify-content: center !important;
  justify-items: center !important;
  column-gap: 10px !important;
  row-gap: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.status-meta-row {
  flex: none !important;
  width: auto !important;
  min-width: max-content !important;
  justify-content: center !important;
}

/* reactions above avatar */
.table-player-card,
.table-seat-row-item,
.table-player-avatar-wrap {
  overflow: visible !important;
}
.table-player-avatar-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.table-reaction {
  top: -14px !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  z-index: 12 !important;
}

@media (max-width: 820px) {
  .status-actions {
    column-gap: 8px !important;
  }
  .status-meta-row {
    gap: 8px !important;
    min-width: auto !important;
  }
  .status-round {
    min-width: 74px !important;
    padding: 7px 10px !important;
  }
  .table-reaction {
    top: -12px !important;
    min-width: 30px;
    height: 30px;
    font-size: 18px;
  }
}

/* final fix: center top controls and shift slightly left so page no longer feels pushed right */
.status-strip {
  display: flex !important;
  justify-content: center !important;
  overflow: visible !important;
}

.status-actions {
  width: max-content !important;
  max-width: calc(100vw - 24px) !important;
  display: grid !important;
  grid-template-columns: repeat(5, max-content) !important;
  align-items: center !important;
  justify-content: center !important;
  justify-items: center !important;
  column-gap: 10px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  position: relative !important;
  left: -10px !important;
}

.status-meta-row {
  flex: none !important;
  width: max-content !important;
  min-width: 0 !important;
  justify-content: center !important;
}

@media (max-width: 820px) {
  .status-actions {
    max-width: calc(100vw - 16px) !important;
    column-gap: 8px !important;
    left: -8px !important;
  }
}


/* final centering fix: remove any horizontal push from top controls and keep whole page centered */
html, body {
  overflow-x: hidden !important;
}

#screen-game,
.table-view {
  overflow-x: clip !important;
}

.status-strip {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.status-actions {
  width: fit-content !important;
  max-width: 100% !important;
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: max-content !important;
  grid-template-columns: none !important;
  align-items: center !important;
  justify-content: center !important;
  justify-items: center !important;
  column-gap: 10px !important;
  row-gap: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  left: 0 !important;
  right: 0 !important;
  transform: none !important;
}

.status-meta-row {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: 100% !important;
  min-width: 0 !important;
  justify-content: center !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

@media (max-width: 820px) {
  .status-actions {
    column-gap: 8px !important;
  }
}


/* keep player seats fitting on screen for 2-6 players */
.table-player-row.players-1 { --seat-cols: 1; }
.table-player-row.players-2 { --seat-cols: 2; }
.table-player-row.players-3 { --seat-cols: 3; }
.table-player-row.players-4 { --seat-cols: 2; }
.table-player-row.players-5 { --seat-cols: 3; }
.table-player-row.players-6 { --seat-cols: 3; }

#lastTrickBtn:disabled {
  opacity: .5;
  pointer-events: none;
}

#lobbySectionValue{
  font-family: "Unbounded", sans-serif;
  font-optical-sizing: auto;
}

/* waiting room placeholders */
.lobby-view #playersList.players-list.lobby-slot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  padding: 4px 0 0;
  width: 100%;
  overflow: visible;
}

.lobby-slot-card {
  min-height: 148px;
  padding: 14px 10px 12px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(20,27,41,.58);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  text-align: center;
}

.lobby-slot-card.empty {
  background: rgba(255,255,255,.035);
  border-style: dashed;
  justify-content: center;
}

.lobby-slot-avatar-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lobby-slot-avatar,
.lobby-slot-avatar.table-player-avatar,
.lobby-slot-avatar.table-player-avatar-main {
  width: 68px;
  height: 68px;
  min-width: 68px;
  min-height: 68px;
  border-radius: 50%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

.lobby-slot-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

.lobby-slot-avatar.is-placeholder {
  background: rgba(255,255,255,.08);
  border: 1px dashed rgba(255,255,255,.16);
  color: rgba(255,255,255,.82);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 24px;
}

.lobby-slot-card.empty .lobby-slot-avatar-wrap,
.lobby-slot-card.empty .lobby-slot-name {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.lobby-slot-name-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
}

.lobby-slot-name {
  font-weight: 700;
  font-size: 14px;
  line-height: 1.2;
  color: var(--text);
  text-align: center;
}

.lobby-slot-subrow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
}

.host-inline-badge {
  min-width: 28px;
  padding-inline: 8px;
}

.host-inline-badge i {
  font-size: 11px;
}

.lobby-slot-card.last-wide {
  grid-column: span 2;
}

@media (max-width: 640px) {
  .lobby-section-head {
    gap: 10px;
  }

  .lobby-top-actions {
    gap: 6px;
  }

  .lobby-view #playersList.players-list.lobby-slot-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .lobby-slot-card {
    min-height: 136px;
    padding: 12px 8px 10px;
    border-radius: 18px;
  }

  .lobby-slot-avatar,
  .lobby-slot-avatar.table-player-avatar,
  .lobby-slot-avatar.table-player-avatar-main {
    width: 60px;
    height: 60px;
    min-width: 60px;
    min-height: 60px;
  }

  .lobby-slot-name { font-size: 13px; }
}


#screen-game {
  min-height: 0;
}


/* lobby text + spacing fixes */
#gameBrandLabel,
#gameRoomTopline {
  display: none !important;
}

.room-topline {
  min-height: 0 !important;
  margin-top: 0 !important;
}

.lobby-full-card {
  overflow: hidden;
}

.lobby-view .section-head.lobby-section-head {
  flex: 0 0 auto;
}

.lobby-view #playersList.players-list.lobby-slot-grid {
  flex: 0 0 auto;
  overflow: visible;
  padding-bottom: 0;
}

.lobby-updates-label {
  flex: 0 0 auto;
  margin-top: 14px !important;
}

.lobby-log {
  flex: 1 1 auto;
  min-height: 0;
  margin-top: 8px;
}

.kick-btn.icon-only-kick {
  width: 24px;
  min-width: 24px;
  height: 24px;
  padding: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

.kick-btn.icon-only-kick i {
  font-size: 11px;
  line-height: 1;
}

.lobby-slot-subrow .kick-btn.icon-only-kick {
  margin-left: 2px;
}


/* bid overlay: keep hand visible while choosing bids */
#bidModal {
  place-items: center;
  align-content: center;
  justify-items: center;
  row-gap: 12px;
  padding-top: max(12px, env(safe-area-inset-top, 0px) + 12px);
  padding-bottom: max(146px, env(safe-area-inset-bottom, 0px) + 126px);
}
#bidModal .modal-backdrop {
  top: 0;
  left: 0;
  right: 0;
  bottom: max(148px, env(safe-area-inset-bottom, 0px) + 122px);
  background: linear-gradient(180deg, rgba(17,17,17,.84) 0%, rgba(17,17,17,.76) 58%, rgba(17,17,17,.14) 100%);
}
#bidModal .bid-modal-card {
  max-height: min(54vh, 440px);
  overflow-y: auto;
  margin-bottom: 0;
}
@media (max-width: 640px) {
  #bidModal {
    padding-bottom: max(156px, env(safe-area-inset-bottom, 0px) + 128px);
  }
  #bidModal .modal-backdrop {
    bottom: max(156px, env(safe-area-inset-bottom, 0px) + 128px);
  }
  #bidModal .bid-modal-card {
    max-height: min(50vh, 400px);
  }
}


/* bid modal: keep hand fully visible, not greyed, but still inactive */
body.bid-modal-open .hand-panel,
body.bid-modal-open #myHand {
  position: relative;
  z-index: 21;
}
body.bid-modal-open #myHand,
body.bid-modal-open #myHand .playing-card {
  pointer-events: none !important;
}
body.bid-modal-open #myHand .playing-card.inactive::after {
  display: none !important;
}
body.bid-modal-open #myHand .playing-card,
body.bid-modal-open #myHand .playing-card.inactive,
body.bid-modal-open #myHand .playing-card img,
body.bid-modal-open #myHand .playing-card .playing-card-img {
  opacity: 1 !important;
  filter: none !important;
}
body.bid-modal-open #bidModal .modal-backdrop {
  z-index: 0;
}
body.bid-modal-open #bidModal .bid-modal-card {
  position: relative;
  z-index: 22;
}
body.bid-modal-open #bidModal .bid-picked-players {
  z-index: 23;
}
body.bid-modal-open #bidCards {
  display: none !important;
}


/* turn indicator + outside highest-card outline */
.table-seat-row-item.turn .table-player-avatar-wrap {
  filter: drop-shadow(0 0 0.45rem color-mix(in srgb, var(--accent) 42%, transparent));
}
.table-seat-row-item.turn .table-player-avatar,
.table-seat-row-item.turn .table-player-avatar.table-player-avatar-main {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 94%, white 6%), 0 10px 20px rgba(0,0,0,.28) !important;
}
.player-item.turn .badge.ok,
.table-seat-row-item.turn .badge.ok {
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  color: #111;
  border-color: transparent;
}
.table-turn-indicator {
  position: absolute;
  top: calc(100% - 4px);
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  color: #111;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 8px 18px rgba(0,0,0,.22);
  white-space: nowrap;
  z-index: 13;
}
.table-turn-indicator i {
  font-size: 9px;
}
.table-play-slot .playing-card {
  overflow: visible !important;
}
.playing-card.draw::before,
.playing-card.win::before {
  inset: -4px !important;
}
.playing-card.draw::before {
  box-shadow: 0 0 0 3px var(--danger) !important;
}
.playing-card.win::before {
  box-shadow: 0 0 0 3px var(--ok) !important;
}
@media (max-width: 820px) {
  .table-turn-indicator {
    font-size: 9px;
    padding: 3px 7px;
    gap: 4px;
  }
}


.friends-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.friends-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.friends-head strong {
  color: var(--text);
  font-size: 14px;
}
.friends-add-row {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 8px;
}
.friends-add-row .primary {
  min-width: 78px;
}
.friends-status {
  min-height: 0;
  font-size: 12px;
  font-weight: 700;
}
.friends-status.success { color: #4dd08a; }
.friends-status.error { color: #ff6b6b; }
.friends-status.muted { color: var(--muted); }

.friends-status:empty {
  display: none;
}

.friend-block {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.025);
}
.friend-block-main {
  margin-top: -2px;
}
.friend-block-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.friend-block-title-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.friend-block-icon {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
  flex: 0 0 auto;
}
.friend-block-icon.warning {
  color: #f4c65d;
  background: rgba(244,198,93,.12);
  border-color: rgba(244,198,93,.2);
}
.friend-block-icon.muted {
  color: var(--muted);
}
.friend-block-title {
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .02em;
  color: var(--text);
}
.friend-block-subtitle {
  margin-top: 2px;
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
}
.friend-block-count {
  min-width: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  color: var(--text);
  text-align: center;
  font-size: 12px;
}
.friends-list {
  display: grid;
  gap: 8px;
  max-height: 220px;
  overflow: auto;
}
.friend-item {
  display: grid;
  grid-template-columns: 42px minmax(0,1fr);
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.05);
  background: rgba(255,255,255,.025);
}
.friend-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  color: #121821;
  font-size: 14px;
  font-weight: 900;
}
.friend-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.friend-main {
  min-width: 0;
}
.friend-name,
.friend-username {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.friend-name {
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
}
.friend-username {
  margin-top: 3px;
  font-size: 12px;
  color: var(--muted);
}
.friend-empty {
  padding: 12px;
  border-radius: 14px;
  border: 1px dashed rgba(255,255,255,.08);
  text-align: center;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.friend-side {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}
.friend-live-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.friend-live-status.online { color: #4dd08a; }
.friend-live-status.offline { color: var(--muted); }
.friend-live-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 8px currentColor;
}
.icon-btn,
.friend-request-badge {
  width: 36px;
  min-width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.045);
  box-shadow: 0 8px 18px rgba(0,0,0,.16);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
}
.icon-btn i,
.friend-request-badge i {
  font-size: 15px;
  line-height: 1;
}
.icon-btn.success {
  color: #4dd08a;
  background: rgba(77,208,138,.12);
  border-color: rgba(77,208,138,.24);
}
.icon-btn.danger {
  color: #ff7a7a;
  background: rgba(255,122,122,.12);
  border-color: rgba(255,122,122,.24);
}
.icon-btn.ghost,
.friend-request-badge {
  color: var(--muted);
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.09);
}
.friend-request-actions .icon-btn,
.friend-side .icon-btn {
  flex: 0 0 auto;
}
.friend-request-badge {
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
}

.screen-profile {
  flex: 1;
  min-height: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 40px 0 18px;
  overflow: auto;
}
.profile-page-shell {
  width: min(560px, 100%);
  display: grid;
  gap: 12px;
  margin-top: 12px;
}
.profile-page-topbar {
  display: grid;
  grid-template-columns: 44px 1fr 44px;
  align-items: center;
  gap: 10px;
}
.profile-page-title {
  text-align: center;
  font-size: 20px;
  font-weight: 900;
}
.profile-page-spacer { width: 44px; height: 44px; }
.profile-page-card {
  width: 100%;
  display: grid !important;
  gap: 14px;
  padding: 14px;
}
.friend-requests-wrap {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}
.friend-requests-section {
  display: grid;
  gap: 8px;
}
.friend-section-title {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.friend-requests-list {
  display: grid;
  gap: 8px;
}
.friend-request-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.friend-request-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.friend-request-badge {
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.friend-item {
  grid-template-columns: 42px minmax(0, 1fr) auto;
}
@media (max-width: 640px) {
  .friend-request-item,
  .friend-item {
    grid-template-columns: 42px minmax(0, 1fr) auto;
  }
  .friend-request-actions {
    gap: 6px;
    flex-wrap: nowrap;
  }
  .friend-side {
    gap: 6px;
  }
  .friend-live-status {
    padding-inline: 8px;
    font-size: 10px;
  }
}

/* live invites + home rooms bottom */
#screen-home {
  place-items: start center;
  align-content: stretch;
}
#screen-home .home-shell-topbar-layout {
  min-height: calc(var(--tg-height) - 82px);
  display: flex;
  flex-direction: column;
}
#screen-home .home-menu {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}
#screen-home .home-find-block {
  margin-top: auto;
  padding-top: 12px;
}

.invite-modal-card {
  width: min(520px, 100%);
}
.invite-telegram-btn {
  margin-top: 4px;
}
.invite-online-head {
  margin-top: 12px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.invite-players-status {
  min-height: 0;
  margin-top: 6px;
  font-size: 12px;
  font-weight: 700;
}
.invite-players-status:empty {
  display: none;
}
.invite-players-status.success { color: #4dd08a; }
.invite-players-status.error { color: #ff6b6b; }
.invite-players-status.muted { color: var(--muted); }
.invite-players-list {
  margin-top: 10px;
  max-height: 280px;
}
.room-invite-popup {
  z-index: 34;
}
.room-invite-popup-card {
  width: min(420px, calc(100vw - 24px));
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
}
.room-invite-popup-head {
  margin-bottom: 10px;
}
.room-invite-popup-body {
  display: grid;
  gap: 8px;
}
.room-invite-popup-line {
  font-size: 15px;
  color: var(--text);
}
.room-invite-popup-meta {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}


.home-shell-topbar-layout {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.home-shell-topbar-layout > .home-menu.panel.padded {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.home-find-block {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.home-rooms-list,
.rooms-list.home-rooms-list {
  flex: 1;
  min-height: 0;
  max-height: none;
  overflow: auto;
  margin-top: 0;
}


.profile-style-card {
  margin-top: 14px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.profile-style-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 2px;
}
.profile-style-save-row { margin-top: 10px; }
.profile-style-button-card .primary { width: 100%; }

.profile-admin-inline-card {
  margin-top: 0;
}

.friends-section-toggle {
  width: 100%;
  padding: 0;
  background: transparent;
  border: 0;
}

.friends-toggle-meta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.friends-toggle-meta strong {
  min-width: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  color: var(--text);
  text-align: center;
  font-size: 12px;
}

.friends-section-body {
  display: grid;
  gap: 8px;
}
.lobby-style-modal-card {
  max-width: 430px;
}
.lobby-style-preview-wrap {
  display: flex;
  justify-content: center;
  margin: 8px 0 14px;
}
.lobby-style-preview-card {
  width: min(100%, 280px);
  min-height: 170px;
}
.lobby-style-form {
  display: grid;
  gap: 12px;
}
.lobby-style-row {
  display: grid;
  gap: 8px;
}
.lobby-style-inline-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.lobby-style-inline-control input[type="color"] {
  width: 100%;
  height: 46px;
  padding: 4px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.lobby-style-inline-control input[type="text"],
.lobby-style-inline-control input:not([type]) {
  width: 100%;
}
.lobby-style-inline-btn {
  min-width: 92px;
  white-space: nowrap;
}
.lobby-style-actions {
  grid-template-columns: 1fr 1fr;
  margin-top: 16px;
}
.lobby-style-reset-link {
  display: block;
  width: 100%;
  margin-top: 10px;
  border: 0;
  background: transparent;
  color: var(--muted);
  text-align: center;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.lobby-style-reset-link:active,
.lobby-style-reset-link:hover {
  color: #fff1d0;
}

.lobby-slot-card {
  --lobby-accent: transparent;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, color-mix(in srgb, var(--lobby-accent) 24%, transparent), rgba(16,18,30,.22) 88%), rgba(255,255,255,.02);
}
.lobby-slot-card.filled::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .32;
}
.lobby-slot-card.lobby-pattern-dots::before { background-image: radial-gradient(circle at 6px 6px, rgba(255,255,255,.7) 0 1.2px, transparent 1.3px); background-size: 18px 18px; }
.lobby-slot-card.lobby-pattern-stripes::before { background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.28) 0 6px, transparent 6px 14px); }
.lobby-slot-card.lobby-pattern-grid::before { background-image: linear-gradient(rgba(255,255,255,.18) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px); background-size: 18px 18px; }
.lobby-slot-card.lobby-pattern-stars::before { background-image: radial-gradient(circle at 18% 24%, rgba(255,255,255,.88) 0 1.2px, transparent 1.3px), radial-gradient(circle at 68% 38%, rgba(255,255,255,.74) 0 1.2px, transparent 1.3px), radial-gradient(circle at 42% 76%, rgba(255,255,255,.78) 0 1.2px, transparent 1.3px), radial-gradient(circle at 84% 64%, rgba(255,255,255,.68) 0 1.2px, transparent 1.3px), radial-gradient(circle at 34% 48%, rgba(255,255,255,.82) 0 1.2px, transparent 1.3px), radial-gradient(circle at 76% 16%, rgba(255,255,255,.7) 0 1.2px, transparent 1.3px), radial-gradient(circle at 12% 78%, rgba(255,255,255,.65) 0 1.2px, transparent 1.3px); background-size: 100% 100%; }
.lobby-slot-card.lobby-pattern-hearts::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 48 48'%3E%3Cpath fill='rgba(255,255,255,0.22)' d='M24 40s-12.5-7.8-16.7-15.1C4.7 20.3 6.5 13 13 11.6c4-.9 7.5 1.1 9 4 1.5-2.9 5-4.9 9-4 6.5 1.4 8.3 8.7 5.7 13.3C36.5 32.2 24 40 24 40z'/%3E%3C/svg%3E"); background-size: 42px 42px; background-position: center; }
.lobby-slot-pin {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(17,17,17,.52);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 8px 16px rgba(0,0,0,.18);
  font-size: 14px;
}
.lobby-slot-avatar-wrap, .lobby-slot-name-row, .lobby-slot-subrow { position: relative; z-index: 1; }

.lobby-slot-card.lobby-style-default { --lobby-accent: transparent; }
.lobby-slot-card.lobby-style-default::before { opacity: 0; background-image: none; }

.admin-page-shell {
  max-width: 980px;
}
.admin-page-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.admin-analytics-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.admin-stat-card {
  position: relative;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
  border-radius: 22px;
  padding: 18px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  min-height: 118px;
  box-shadow: 0 12px 28px rgba(0,0,0,.18);
}
.admin-stat-card.is-live {
  border-color: rgba(88,235,159,.22);
}
.admin-stat-icon {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: rgba(255,255,255,.07);
}
.admin-live-dot {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #4ade80;
  box-shadow: 0 0 0 4px rgba(74,222,128,.15);
}
.admin-stat-value {
  font-size: 26px;
  font-weight: 800;
  line-height: 1;
}
.admin-stat-label {
  font-size: 12px;
  color: var(--muted);
}
.admin-actions-row {
  display: flex;
  justify-content: center;
}
.admin-filter-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
}
.admin-filter-btn.active {
  border-color: rgba(255,120,120,.35);
  background: rgba(255,80,80,.12);
  color: #ffd1d1;
}
.admin-section-block {
  overflow: hidden;
}
.admin-section-toggle {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0;
  text-align: left;
}
.admin-section-chevron {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: rgba(255,255,255,.045);
  transition: transform .18s ease;
}
.admin-section-toggle[aria-expanded="false"] .admin-section-chevron {
  transform: rotate(-90deg);
}
.admin-section-body.hidden {
  display: none;
}
.admin-users-list, .admin-rooms-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 12px;
}
.admin-user-card, .admin-room-card {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  border-radius: 18px;
  padding: 12px;
}
.admin-user-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 72px;
}
.admin-user-head-left, .admin-room-head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.admin-user-main {
  min-width: 0;
}
.admin-user-subrow {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.admin-room-meta, .admin-user-meta {
  font-size: 12px;
  color: var(--muted);
}
.admin-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  font-size: 11px;
}
.admin-badge.danger {
  color: #ffb1b1;
  border-color: rgba(255,120,120,.35);
  background: rgba(255,80,80,.12);
}
.admin-room-players {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.admin-room-player-chip {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  font-size: 12px;
}
.admin-room-player-chip.online {
  border-color: rgba(88,235,159,.32);
  background: rgba(34,197,94,.12);
}

.admin-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 0 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .02em;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.05);
}
.admin-status-pill.online {
  color: #c8ffe0;
  border-color: rgba(88,235,159,.28);
  background: rgba(34,197,94,.12);
}
.admin-status-pill.offline {
  color: rgba(255,255,255,.72);
}
.admin-edit-modal-card {
  width: min(92vw, 460px);
  border-radius: 28px;
}
.admin-edit-grid {
  margin-top: 4px;
}
.admin-edit-grid label {
  gap: 7px;
}
.admin-edit-actions-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.admin-edit-ban-toggle {
  min-height: 44px;
  width: 100%;
  justify-content: flex-start;
  padding: 0 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
}
.admin-edit-ban-toggle input {
  accent-color: #8b5cf6;
}

.admin-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.admin-edit-grid label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
}
.admin-input {
  width: 100%;
}
.admin-ban-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
}
.admin-edit-ban-toggle {
  margin-top: 12px;
}
.empty-state.small {
  padding: 12px 2px;
  font-size: 13px;
  color: var(--muted);
  text-align: center;
}
@media (max-width: 720px) {
  .admin-analytics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .admin-edit-grid {
    grid-template-columns: 1fr;
  }
  .admin-edit-actions-grid {
    grid-template-columns: 1fr;
  }
  .admin-stat-card {
    width: 100%;
    min-width: 0;
  }
  .admin-user-card {
    align-items: flex-start;
    flex-direction: column;
  }
}


.account-admin-btn {
  background: rgba(255,255,255,.04);
}
.account-admin-btn:hover { background: rgba(255,255,255,.08); }


/* lobby start button pinned to bottom */
.lobby-start-bottom-btn {
  width: 100%;
  margin-top: 12px;
  min-height: 52px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex: 0 0 auto;
}

.lobby-start-bottom-btn i {
  font-size: 15px;
  line-height: 1;
}

.lobby-start-bottom-btn.hidden {
  display: none !important;
}


.toast-viewport {
  position: fixed;
  top: max(56px, env(safe-area-inset-top, 0px) + 56px);
  left: 50%;
  transform: translateX(-50%);
  width: min(420px, calc(100vw - 24px));
  display: grid;
  gap: 10px;
  z-index: 100000;
  pointer-events: none;
}
.toast {
  pointer-events: auto;
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 50px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(18,22,30,.58), rgba(12,14,20,.42));
  backdrop-filter: blur(20px) saturate(135%);
  -webkit-backdrop-filter: blur(20px) saturate(135%);
  box-shadow: 0 14px 30px rgba(0,0,0,.20);
  color: var(--text);
  opacity: 0;
  transform: translateY(-10px) scale(.98);
  transition: opacity .18s ease, transform .18s ease;
  user-select: none;
  touch-action: pan-x pan-y;
}
.toast.show {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.toast.hide {
  opacity: 0;
  transform: translateY(-18px) scale(.97);
}
.toast-icon, .toast-close {
  width: 30px;
  height: 30px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.045);
}
.toast-message {
  min-width: 0;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.25;
}
.toast-close {
  color: rgba(255,255,255,.72);
  cursor: pointer;
}
.toast.success .toast-icon {
  color: #4dd08a;
  background: rgba(77,208,138,.12);
  border-color: rgba(77,208,138,.24);
}
.toast.error .toast-icon {
  color: #ff7a7a;
  background: rgba(255,122,122,.12);
  border-color: rgba(255,122,122,.24);
}
.toast.warning .toast-icon {
  color: #f4c65d;
  background: rgba(244,198,93,.12);
  border-color: rgba(244,198,93,.24);
}
.toast.muted .toast-icon {
  color: var(--muted);
}

/* dynamic in-game seat sizing by player count; lobby unchanged */
.game-view .table-cards {
  min-height: clamp(320px, 48vh, 520px) !important;
  justify-content: center;
}
.game-view .table-player-row {
  align-content: center;
}
.game-view .table-player-row.players-2 {
  --seat-cols: 2;
  grid-template-columns: repeat(2, minmax(0, 132px));
  column-gap: clamp(16px, 5vw, 36px);
  row-gap: 18px;
  min-height: clamp(300px, 44vh, 420px);
}
.game-view .table-player-row.players-2 .table-seat-row-item {
  max-width: 132px;
  gap: 12px;
}
.game-view .table-player-row.players-2 .table-player-avatar {
  width: clamp(62px, 13vw, 74px);
  height: clamp(62px, 13vw, 74px);
}
.game-view .table-player-row.players-2 .table-play-slot {
  width: min(100%, 84px);
  min-height: 118px;
}

.game-view .table-player-row.players-3 {
  --seat-cols: 3;
  grid-template-columns: repeat(3, minmax(0, 124px));
  column-gap: clamp(10px, 2.4vw, 22px);
  row-gap: 18px;
  min-height: clamp(290px, 42vh, 400px);
}
.game-view .table-player-row.players-3 .table-seat-row-item {
  max-width: 124px;
  gap: 12px;
}
.game-view .table-player-row.players-3 .table-player-avatar {
  width: clamp(60px, 12vw, 72px);
  height: clamp(60px, 12vw, 72px);
}
.game-view .table-player-row.players-3 .table-play-slot {
  width: min(100%, 82px);
  min-height: 116px;
}

.game-view .table-player-row.players-4 {
  --seat-cols: 2;
  grid-template-columns: repeat(2, minmax(0, 126px));
  column-gap: clamp(16px, 4vw, 28px);
  row-gap: 18px;
  min-height: clamp(300px, 44vh, 430px);
}
.game-view .table-player-row.players-4 .table-seat-row-item {
  max-width: 126px;
  gap: 11px;
}
.game-view .table-player-row.players-4 .table-player-avatar {
  width: clamp(60px, 12vw, 72px);
  height: clamp(60px, 12vw, 72px);
}
.game-view .table-player-row.players-4 .table-play-slot {
  width: min(100%, 82px);
  min-height: 116px;
}

.game-view .table-player-row.players-5,
.game-view .table-player-row.players-6 {
  min-height: clamp(286px, 41vh, 390px);
}
.game-view .table-player-row.players-5 .table-seat-row-item,
.game-view .table-player-row.players-6 .table-seat-row-item {
  max-width: 116px;
}
.game-view .table-player-row.players-5 .table-player-avatar,
.game-view .table-player-row.players-6 .table-player-avatar {
  width: clamp(56px, 11vw, 68px);
  height: clamp(56px, 11vw, 68px);
}

@media (max-width: 820px) {
  .game-view .table-cards {
    min-height: clamp(300px, 46vh, 460px) !important;
  }
  .game-view .table-player-row.players-2 {
    grid-template-columns: repeat(2, minmax(0, 122px));
    min-height: clamp(280px, 40vh, 360px);
  }
  .game-view .table-player-row.players-2 .table-seat-row-item { max-width: 122px; }
  .game-view .table-player-row.players-3 {
    grid-template-columns: repeat(3, minmax(0, 112px));
    min-height: clamp(270px, 39vh, 340px);
  }
  .game-view .table-player-row.players-3 .table-seat-row-item { max-width: 112px; }
  .game-view .table-player-row.players-4 {
    grid-template-columns: repeat(2, minmax(0, 116px));
    min-height: clamp(286px, 41vh, 360px);
  }
  .game-view .table-player-row.players-4 .table-seat-row-item { max-width: 116px; }
}

/* in-game only: bigger player seats by player count + stronger vertical centering */
.table-view:not(.hidden) .table-cards {
  min-height: clamp(390px, 57vh, 660px) !important;
  justify-content: center !important;
  align-items: stretch !important;
  padding-top: 22px !important;
  padding-bottom: clamp(136px, 18vh, 190px) !important;
  box-sizing: border-box !important;
}
.table-view:not(.hidden) .table-player-row {
  align-content: center !important;
  justify-content: center !important;
  justify-items: center !important;
  row-gap: 22px !important;
}
.table-view:not(.hidden) .table-seat-row-item {
  gap: 14px !important;
}
.table-view:not(.hidden) .table-seat-row-item .table-player-card {
  gap: 10px !important;
}
.table-view:not(.hidden) .table-seat-row-item .table-player-name {
  font-size: 13px !important;
}
.table-view:not(.hidden) .table-player-row.players-2 {
  --seat-cols: 2;
  grid-template-columns: repeat(2, minmax(0, 154px)) !important;
  column-gap: clamp(22px, 6vw, 48px) !important;
  min-height: clamp(340px, 50vh, 500px) !important;
}
.table-view:not(.hidden) .table-player-row.players-2 .table-seat-row-item {
  max-width: 154px !important;
}
.table-view:not(.hidden) .table-player-row.players-2 .table-player-avatar,
.table-view:not(.hidden) .table-player-row.players-2 .table-player-avatar.table-player-avatar-main {
  width: clamp(74px, 14vw, 88px) !important;
  height: clamp(74px, 14vw, 88px) !important;
  min-width: clamp(74px, 14vw, 88px) !important;
  min-height: clamp(74px, 14vw, 88px) !important;
  max-width: clamp(74px, 14vw, 88px) !important;
  max-height: clamp(74px, 14vw, 88px) !important;
  flex-basis: clamp(74px, 14vw, 88px) !important;
}
.table-view:not(.hidden) .table-player-row.players-2 .table-play-slot {
  width: min(100%, 92px) !important;
  min-height: 128px !important;
}
.table-view:not(.hidden) .table-player-row.players-3 {
  --seat-cols: 3;
  grid-template-columns: repeat(3, minmax(0, 138px)) !important;
  column-gap: clamp(14px, 3vw, 28px) !important;
  min-height: clamp(328px, 48vh, 470px) !important;
}
.table-view:not(.hidden) .table-player-row.players-3 .table-seat-row-item {
  max-width: 138px !important;
}
.table-view:not(.hidden) .table-player-row.players-3 .table-player-avatar,
.table-view:not(.hidden) .table-player-row.players-3 .table-player-avatar.table-player-avatar-main {
  width: clamp(68px, 12.6vw, 82px) !important;
  height: clamp(68px, 12.6vw, 82px) !important;
  min-width: clamp(68px, 12.6vw, 82px) !important;
  min-height: clamp(68px, 12.6vw, 82px) !important;
  max-width: clamp(68px, 12.6vw, 82px) !important;
  max-height: clamp(68px, 12.6vw, 82px) !important;
  flex-basis: clamp(68px, 12.6vw, 82px) !important;
}
.table-view:not(.hidden) .table-player-row.players-3 .table-play-slot {
  width: min(100%, 88px) !important;
  min-height: 122px !important;
}
.table-view:not(.hidden) .table-player-row.players-4 {
  --seat-cols: 2;
  grid-template-columns: repeat(2, minmax(0, 132px)) !important;
  column-gap: clamp(16px, 4vw, 28px) !important;
  min-height: clamp(300px, 44vh, 428px) !important;
}
.table-view:not(.hidden) .table-player-row.players-4 .table-seat-row-item {
  max-width: 132px !important;
}
.table-view:not(.hidden) .table-player-row.players-4 .table-player-avatar,
.table-view:not(.hidden) .table-player-row.players-4 .table-player-avatar.table-player-avatar-main {
  width: clamp(66px, 11.8vw, 78px) !important;
  height: clamp(66px, 11.8vw, 78px) !important;
  min-width: clamp(66px, 11.8vw, 78px) !important;
  min-height: clamp(66px, 11.8vw, 78px) !important;
  max-width: clamp(66px, 11.8vw, 78px) !important;
  max-height: clamp(66px, 11.8vw, 78px) !important;
  flex-basis: clamp(66px, 11.8vw, 78px) !important;
}
.table-view:not(.hidden) .table-player-row.players-4 .table-play-slot {
  width: min(100%, 82px) !important;
  min-height: 112px !important;
}
.table-view:not(.hidden) .table-player-row.players-5,
.table-view:not(.hidden) .table-player-row.players-6 {
  grid-template-columns: repeat(3, minmax(0, 114px)) !important;
  column-gap: clamp(8px, 2vw, 16px) !important;
  min-height: clamp(282px, 40vh, 382px) !important;
}
.table-view:not(.hidden) .table-player-row.players-5 .table-seat-row-item,
.table-view:not(.hidden) .table-player-row.players-6 .table-seat-row-item {
  max-width: 114px !important;
}
.table-view:not(.hidden) .table-player-row.players-5 .table-player-avatar,
.table-view:not(.hidden) .table-player-row.players-6 .table-player-avatar,
.table-view:not(.hidden) .table-player-row.players-5 .table-player-avatar.table-player-avatar-main,
.table-view:not(.hidden) .table-player-row.players-6 .table-player-avatar.table-player-avatar-main {
  width: clamp(58px, 10.6vw, 68px) !important;
  height: clamp(58px, 10.6vw, 68px) !important;
  min-width: clamp(58px, 10.6vw, 68px) !important;
  min-height: clamp(58px, 10.6vw, 68px) !important;
  max-width: clamp(58px, 10.6vw, 68px) !important;
  max-height: clamp(58px, 10.6vw, 68px) !important;
  flex-basis: clamp(58px, 10.6vw, 68px) !important;
}
.table-view:not(.hidden) .table-player-row.players-5 .table-play-slot,
.table-view:not(.hidden) .table-player-row.players-6 .table-play-slot {
  width: min(100%, 74px) !important;
  min-height: 102px !important;
}

@media (max-width: 820px) {
  .table-view:not(.hidden) .table-cards {
    min-height: clamp(360px, 50vh, 560px) !important;
    padding-top: 18px !important;
    padding-bottom: clamp(126px, 17vh, 170px) !important;
    box-sizing: border-box !important;
  }
  .table-view:not(.hidden) .table-player-row {
    row-gap: 18px !important;
  }
  .table-view:not(.hidden) .table-player-row.players-2 {
    grid-template-columns: repeat(2, minmax(0, 136px)) !important;
    min-height: clamp(316px, 44vh, 420px) !important;
  }
  .table-view:not(.hidden) .table-player-row.players-2 .table-seat-row-item { max-width: 136px !important; }
  .table-view:not(.hidden) .table-player-row.players-2 .table-player-avatar,
  .table-view:not(.hidden) .table-player-row.players-2 .table-player-avatar.table-player-avatar-main {
    width: 78px !important;
    height: 78px !important;
    min-width: 78px !important;
    min-height: 78px !important;
    max-width: 78px !important;
    max-height: 78px !important;
    flex-basis: 78px !important;
  }
  .table-view:not(.hidden) .table-player-row.players-3 {
    grid-template-columns: repeat(3, minmax(0, 116px)) !important;
    min-height: clamp(304px, 42vh, 404px) !important;
  }
  .table-view:not(.hidden) .table-player-row.players-3 .table-seat-row-item { max-width: 116px !important; }
  .table-view:not(.hidden) .table-player-row.players-3 .table-player-avatar,
  .table-view:not(.hidden) .table-player-row.players-3 .table-player-avatar.table-player-avatar-main {
    width: 68px !important;
    height: 68px !important;
    min-width: 68px !important;
    min-height: 68px !important;
    max-width: 68px !important;
    max-height: 68px !important;
    flex-basis: 68px !important;
  }
  .table-view:not(.hidden) .table-player-row.players-4 {
    grid-template-columns: repeat(2, minmax(0, 116px)) !important;
    min-height: clamp(284px, 40vh, 372px) !important;
  }
  .table-view:not(.hidden) .table-player-row.players-4 .table-seat-row-item { max-width: 116px !important; }
  .table-view:not(.hidden) .table-player-row.players-4 .table-player-avatar,
  .table-view:not(.hidden) .table-player-row.players-4 .table-player-avatar.table-player-avatar-main {
    width: 64px !important;
    height: 64px !important;
    min-width: 64px !important;
    min-height: 64px !important;
    max-width: 64px !important;
    max-height: 64px !important;
    flex-basis: 64px !important;
  }
  .table-view:not(.hidden) .table-player-row.players-5,
  .table-view:not(.hidden) .table-player-row.players-6 {
    grid-template-columns: repeat(3, minmax(0, 98px)) !important;
    min-height: clamp(264px, 37vh, 340px) !important;
  }
  .table-view:not(.hidden) .table-player-row.players-5 .table-seat-row-item,
  .table-view:not(.hidden) .table-player-row.players-6 .table-seat-row-item { max-width: 98px !important; }
  .table-view:not(.hidden) .table-player-row.players-5 .table-player-avatar,
  .table-view:not(.hidden) .table-player-row.players-6 .table-player-avatar,
  .table-view:not(.hidden) .table-player-row.players-5 .table-player-avatar.table-player-avatar-main,
  .table-view:not(.hidden) .table-player-row.players-6 .table-player-avatar.table-player-avatar-main {
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
    flex-basis: 56px !important;
  }
}


/* fix 4+ player rows staying above hand zone */
.table-view:not(.hidden) .table-player-row.players-4 .table-play-slot {
  width: min(100%, 78px) !important;
  min-height: 104px !important;
}
.table-view:not(.hidden) .table-player-row.players-5 .table-play-slot,
.table-view:not(.hidden) .table-player-row.players-6 .table-play-slot {
  width: min(100%, 70px) !important;
  min-height: 96px !important;
}
@media (max-width: 820px) {
  .table-view:not(.hidden) .table-cards {
    padding-bottom: clamp(138px, 19vh, 178px) !important;
  }
  .table-view:not(.hidden) .table-player-row.players-4 .table-play-slot {
    width: min(100%, 72px) !important;
    min-height: 96px !important;
  }
  .table-view:not(.hidden) .table-player-row.players-5 .table-play-slot,
  .table-view:not(.hidden) .table-player-row.players-6 .table-play-slot {
    width: min(100%, 64px) !important;
    min-height: 88px !important;
  }
}
