/* fleypo room-meta — стили для пароля + game-picker в лобби + модалка пароля. */

.fleypo-room-meta {
  margin: 14px auto 18px;
  max-width: 440px;
  text-align: center;
}
.fleypo-room-meta .frm-row {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
}
.fleypo-room-meta .frm-game-picker,
.fleypo-room-meta .frm-pass-form {
  margin-top: 10px;
  padding: 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  animation: frm-slide-down .25s ease-out;
}
.fleypo-room-meta .frm-game-list {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
}
.fleypo-room-meta .frm-game-option.current {
  border-color: oklch(60% 0.18 145);
  background: oklch(94% 0.08 145);
  color: oklch(25% 0.10 145);
  font-weight: 700;
}
html[data-theme="dark"] .fleypo-room-meta .frm-game-option.current {
  background: oklch(28% 0.10 145);
  color: white;
}
.fleypo-room-meta .frm-pass-form {
  display: flex;
  gap: 8px;
}
.fleypo-room-meta .frm-pass-input {
  flex: 1;
  font-family: var(--font-sans);
  font-size: 14px;
  padding: 8px 12px;
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  background: var(--bg);
  color: var(--ink);
  outline: none;
}
.fleypo-room-meta .frm-pass-input:focus { border-color: var(--purple, oklch(65% 0.19 291)); }

@keyframes frm-slide-down {
  from { opacity: 0; transform: translateY(-6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ─── Модалка ввода пароля ─── */
.frm-modal {
  position: fixed;
  inset: 0;
  background: oklch(0% 0 0 / 0.55);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  animation: frm-fade-in .2s ease-out;
}
.frm-modal-card {
  background: var(--bg);
  border: 2px solid var(--line);
  border-radius: 18px;
  padding: 32px 28px;
  text-align: center;
  max-width: 380px;
  width: 90%;
  box-shadow: 0 20px 60px oklch(0% 0 0 / 0.4);
  animation: frm-pop-in .3s cubic-bezier(.22,.8,.36,1);
}
.frm-modal-icon { font-size: 42px; margin-bottom: 8px; }
.frm-modal-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 22px;
  margin-bottom: 6px;
  text-transform: lowercase;
}
.frm-modal-sub {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 18px;
}
.frm-modal-input {
  width: 100%;
  font-family: var(--font-sans);
  font-size: 17px;
  padding: 12px 14px;
  border: 2px solid var(--line-strong);
  border-radius: 10px;
  background: var(--surface);
  color: var(--ink);
  outline: none;
  text-align: center;
  margin-bottom: 8px;
}
.frm-modal-input:focus { border-color: var(--purple, oklch(65% 0.19 291)); }
.frm-modal-err {
  color: oklch(55% 0.22 25);
  font-size: 13px;
  font-family: var(--font-mono);
  margin-bottom: 8px;
}
.frm-modal-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 14px;
}

@keyframes frm-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes frm-pop-in {
  from { opacity: 0; transform: scale(.9); }
  to { opacity: 1; transform: scale(1); }
}
