@layer app {
/* ============================================================
   Lobby
   ============================================================ */
.lobby {
  max-width: 480px;
  margin: 0 auto;
  width: 100%;
  position: relative;
  overflow: hidden;
  min-height: calc(100dvh - 48px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.lobby > .sf-background {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  user-select: none;
  pointer-events: none;
}

.lobby-content {
  padding: 16px 16px 32px;
  position: relative;
  z-index: 2;
}

.lobby-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.lobby-header .logo-tile {
  width: 28px;
  height: 34px;
  font-size: 19px;
}

.player-name {
  color: var(--orange);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-family: var(--font-flap);
  font-weight: 700;
}

.lobby-actions {
  margin-bottom: 10px;
}

.lobby-actions .btn {
  width: 100%;
  text-align: center;
}

.lobby-actions-row {
  display: flex;
  gap: 10px;
  margin-bottom: 24px;
}

.lobby-actions-row .btn,
.lobby-actions-row form {
  flex: 1;
}

.lobby-actions-row .btn {
  width: 100%;
  text-align: center;
}

.lobby-new-game {
  margin-bottom: 20px;
  padding-top: 4px;
}

.new-game-form {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.line-picker {
  display: flex;
  gap: 0;
  border: 1px solid var(--cell-brd);
  border-radius: 6px;
  overflow: hidden;
  flex: 1;
}

.line-picker-radio {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.line-picker-option {
  flex: 1;
  cursor: pointer;
}

.line-picker-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  padding: 8px 6px;
  background: var(--board-bg);
  border-right: 1px solid var(--cell-brd);
  transition: background 0.12s, color 0.12s;
}

.line-picker-option:last-child .line-picker-label {
  border-right: none;
}

.line-picker-option:hover .line-picker-label {
  background: var(--row-hover);
}

.line-picker-radio:checked + .line-picker-label {
  background: var(--row-act-bg);
  box-shadow: inset 0 -2px 0 var(--orange);
}

.line-picker-num {
  font-size: 20px;
  font-weight: 900;
  font-family: var(--font-flap);
  color: var(--page-sub);
  line-height: 1;
}

.line-picker-radio:checked + .line-picker-label .line-picker-num {
  color: var(--orange);
}

.line-picker-text {
  font-size: 9px;
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--label-col);
  line-height: 1;
}

.new-game-btn {
  flex-shrink: 0;
}

.new-game-sub {
  font-size: 12px;
  color: var(--page-sub);
  text-align: center;
  margin-top: 4px;
}

.new-game-sub a {
  color: var(--orange);
  text-decoration: underline;
}

/* Mode switcher (Classic / Theme toggle) */
.mode-switcher {
  display: flex;
  gap: 0;
  border: 1px solid var(--cell-brd);
  border-radius: 6px;
  overflow: hidden;
  width: 100%;
  margin-bottom: 10px;
}

.mode-option {
  flex: 1;
  cursor: pointer;
}

.mode-radio {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.mode-label {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 8px;
  font-size: 13px;
  font-family: var(--font-flap);
  text-transform: uppercase;
  letter-spacing: 1px;
  background: var(--board-bg);
  border-right: 1px solid var(--cell-brd);
  transition: background 0.12s, color 0.12s;
  color: var(--page-sub);
}

.mode-option:last-child .mode-label {
  border-right: none;
}

.mode-option:hover .mode-label {
  background: var(--row-hover);
}

.mode-radio:checked + .mode-label {
  background: var(--row-act-bg);
  box-shadow: inset 0 -2px 0 var(--orange);
  color: var(--orange);
}

/* Theme preview in lobby */
.theme-preview {
  width: 100%;
  margin-bottom: 10px;
}

.theme-preview-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  background: var(--board-bg);
  border: 1px solid var(--cell-brd);
  border-radius: 6px;
}

.theme-preview-name {
  font-family: var(--font-flap);
  font-size: 16px;
  color: var(--orange);
}

.theme-preview-desc {
  font-size: 12px;
  color: var(--page-sub);
}

.theme-preview-badge {
  font-size: 10px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 1px;
  background: var(--orange);
  color: #fff;
  padding: 2px 6px;
  border-radius: 3px;
}

.theme-preview-link {
  font-size: 11px;
  color: var(--orange);
  margin-left: auto;
}

/* Theme badge on game cards */
.theme-badge {
  font-size: 10px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: var(--orange);
  color: #fff;
  padding: 1px 5px;
  border-radius: 3px;
}

/* Theme show page */
.theme-show {
  max-width: 600px;
  margin: 0 auto;
  padding: 16px 16px 32px;
}

.theme-show-header {
  text-align: center;
  margin-bottom: 20px;
}

.theme-show-name {
  font-family: var(--font-flap);
  font-size: 28px;
  color: var(--orange);
  margin: 0 0 4px;
}

.theme-show-desc {
  font-size: 14px;
  color: var(--page-sub);
  margin: 0 0 8px;
}

.theme-show-count {
  font-size: 12px;
  font-family: var(--font-mono);
  color: var(--page-sub);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.theme-word-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 12px;
  background: var(--board-bg);
  border: 1px solid var(--cell-brd);
  border-radius: 6px;
  margin-bottom: 20px;
}

.theme-word-chip {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px;
  padding: 3px 8px;
  background: var(--screen-bg);
  border: 1px solid var(--cell-brd);
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.theme-show-actions {
  text-align: center;
}

.theme-4x-badge {
  font-size: 9px;
  font-family: var(--font-mono);
  font-weight: 700;
  background: var(--orange);
  color: #fff;
  padding: 1px 4px;
  border-radius: 3px;
  vertical-align: super;
  margin-left: 2px;
}

.game-list { margin-top: 24px; }

.game-list-heading {
  font-size: 10px;
  font-family: var(--font-body);
  color: var(--label-col);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 10px;
}

.game-card {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--board-bg);
  border: 1px solid var(--row-brd);
  border-radius: 6px;
  padding: 12px 14px;
  margin-bottom: 8px;
  text-decoration: none;
  color: var(--page-text);
  transition: background 0.12s;
}

.game-card:hover { background: var(--row-hover); }

.challenge-card {
  border-color: var(--orange);
  border-width: 2px;
}

.challenge-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.avatar-link {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

.game-card-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--cell-bg);
  border: 1px solid var(--cell-brd);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--flap-dim);
  flex-shrink: 0;
  font-family: var(--font-flap);
}

.game-card-info {
  flex: 1;
  min-width: 0;
}

.game-card-opponent {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.5px;
}

.game-card-meta {
  font-size: 11px;
  font-family: var(--font-body);
  color: var(--page-sub);
  margin-top: 2px;
}

.game-card-date {
  font-size: 11px;
  font-family: var(--font-body);
  color: var(--page-sub);
  opacity: 0.7;
  margin-top: 1px;
}

.game-card-pips {
  display: flex;
  gap: 5px;
  align-items: center;
}

.game-status {
  font-size: 11px;
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 2px 8px;
  border-radius: 3px;
}

.badge-waiting { color: var(--orange); }
.badge-active { color: var(--green); }
.badge-finished { color: var(--page-sub); }

.game-result-won { color: var(--green); font-weight: 700; }
.game-result-lost { color: var(--red); font-weight: 700; }
.game-result-draw { color: var(--page-sub); font-weight: 700; }

.btn-load-more {
  width: 100%;
  margin-top: 8px;
  text-align: center;
}

}
