:root {
  --bg: #0f1320;
  --panel: #171d30;
  --panel-2: #1f2840;
  --stroke: rgba(255,255,255,0.09);
  --text: #eef2ff;
  --muted: #b2bdd8;
  --accent: #8fb3ff;
  --accent-2: #c0d4ff;
  --success: #72d79b;
  --danger: #ff8f8f;
  --danger-bg: rgba(255, 143, 143, 0.08);
  --radius: 18px;
  --shadow: 0 20px 50px rgba(0,0,0,.35);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  min-height: 100vh;
  font-family: Inter, Arial, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(143,179,255,.18), transparent 28%),
    radial-gradient(circle at bottom right, rgba(192,212,255,.10), transparent 24%),
    var(--bg);
}
code { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.shell { width: min(1100px, calc(100% - 32px)); margin: 32px auto; }
.shell--centered { min-height: 100vh; display: grid; place-items: center; }
.card {
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01)), var(--panel);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.authCard { width: min(560px, 100%); padding: 28px; }
.authCard--wide { width: min(760px, 100%); }
.topbar { padding: 20px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.topbar__actions { display: flex; align-items: center; gap: 12px; }
.topbar__actions--wrap { flex-wrap: wrap; justify-content: end; }
.walletPill { border: 1px solid var(--stroke); background: var(--panel-2); padding: 10px 14px; border-radius: 999px; }
.gridTwo { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin: 16px 0; }
.gridTwo > .card { padding: 20px; }
.stackLayout { display: grid; gap: 16px; margin-top: 16px; }
.sectionCard { padding: 20px; }
.sectionHead { display: flex; justify-content: space-between; align-items: end; gap: 16px; margin-bottom: 18px; }
h1, h2, h3 { margin: 0 0 12px; }
h1 { font-size: clamp(1.9rem, 4vw, 2.8rem); }
h2 { font-size: 1.3rem; }
h3 { font-size: 1rem; }
p { margin: 0 0 12px; line-height: 1.6; color: var(--muted); }
a { color: var(--accent-2); }
.eyebrow { text-transform: uppercase; letter-spacing: .14em; font-size: .78rem; color: var(--accent-2); margin-bottom: 10px; }
.lead { font-size: 1rem; }
.form { display: grid; gap: 14px; margin: 22px 0 14px; }
.compactForm { margin-top: 10px; }
.formGrid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
label, .field { display: grid; gap: 8px; }
label span, .field span { color: var(--muted); font-size: .95rem; }
input, select, textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  background: #0f1527;
  color: var(--text);
  outline: none;
}
input:focus, select:focus, textarea:focus { border-color: var(--accent); }
.btn {
  appearance: none;
  border: 1px solid var(--stroke);
  border-radius: 14px;
  background: var(--panel-2);
  color: var(--text);
  padding: 12px 16px;
  cursor: pointer;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: linear-gradient(180deg, var(--accent), #6b93ff); color: #081122; border-color: transparent; }
.btn--danger { background: linear-gradient(180deg, #ffb0b0, #ff8f8f); color: #2a0505; border-color: transparent; }
.btn[disabled] { opacity: .55; cursor: not-allowed; transform: none; }
.tabs { display: inline-flex; gap: 8px; padding: 6px; background: #0f1527; border-radius: 16px; border: 1px solid var(--stroke); }
.tab { border: 0; background: transparent; color: var(--muted); padding: 10px 14px; border-radius: 12px; cursor: pointer; }
.tab.is-active { background: var(--panel-2); color: var(--text); }
.noteBox { margin-top: 18px; border: 1px solid var(--stroke); background: rgba(255,255,255,.02); padding: 16px; border-radius: 14px; }
.noteBox h2 { font-size: 1rem; margin-bottom: 8px; }
.message { min-height: 26px; color: var(--accent-2); margin-top: 12px; }
.message.is-error, .message.is-danger { color: var(--danger); }
.message.is-success { color: var(--success); }
.bulletList { margin: 0; padding-left: 18px; color: var(--muted); }
.bulletList li + li { margin-top: 8px; }
.gamesGrid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.gameCard { padding: 18px; display: grid; gap: 10px; }
.gameCard__head { display: flex; align-items: start; justify-content: space-between; gap: 12px; }
.status { font-size: .78rem; padding: 6px 10px; border-radius: 999px; background: rgba(143,179,255,.12); color: var(--accent-2); border: 1px solid rgba(143,179,255,.24); }
.status.is-planned { background: rgba(255,255,255,.06); color: var(--muted); border-color: var(--stroke); }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.small { font-size: .9rem; }
.gameCard__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.gameCard__actions .btn { flex: 1 1 180px; }
.authLinks { display: flex; justify-content: space-between; gap: 12px; align-items: center; margin-top: 6px; }
.is-hidden { display: none !important; }
.inlineForm { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.inlineForm input { flex: 1 1 260px; }
.adminList { display: grid; gap: 10px; }
.adminUserCard {
  text-align: left;
  background: #0f1527;
  border: 1px solid var(--stroke);
  border-radius: 14px;
  color: var(--text);
  padding: 14px;
  display: grid;
  gap: 6px;
  cursor: pointer;
}
.adminUserCard.is-selected { border-color: var(--accent); box-shadow: inset 0 0 0 1px rgba(143,179,255,.4); }
.detailPane { min-height: 160px; }
.detailActions { display: grid; gap: 12px; }
.buttonStack { display: flex; flex-wrap: wrap; gap: 10px; }
.dangerZone { border-color: rgba(255,143,143,.2); background: linear-gradient(180deg, rgba(255,143,143,.05), rgba(255,255,255,.01)), var(--panel); }
.adminGrid { align-items: start; }
@media (max-width: 860px) {
  .gridTwo, .gamesGrid, .formGrid { grid-template-columns: 1fr; }
  .topbar { align-items: start; flex-direction: column; }
}




/* ===== Hub / deskovková herna v1.9.0 ===== */
.arcadeBody--boardhall {
  background:
    radial-gradient(circle at top center, rgba(220, 188, 123, 0.18), transparent 26%),
    radial-gradient(circle at bottom right, rgba(113, 72, 31, 0.24), transparent 30%),
    linear-gradient(180deg, #2c190f 0%, #160f0c 55%, #0f0a09 100%);
}
.boardhallShell { width: min(1380px, calc(100% - 20px)); margin: 18px auto 42px; }
.boardhallHero {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  border-radius: 28px;
  padding: 24px;
  box-shadow: 0 30px 80px rgba(0,0,0,.45);
  background: linear-gradient(180deg, rgba(43,24,14,.9), rgba(22,14,11,.96));
}
.boardhallHero__image {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(18,11,8,.88) 0%, rgba(18,11,8,.62) 42%, rgba(18,11,8,.8) 100%),
    url('/games/sarvatky-build/assets/guide/cover.jpg') center/cover no-repeat;
  transform: scale(1.02);
}
.boardhallHero__veil {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 18% 20%, rgba(255,220,153,.16), transparent 18%),
    radial-gradient(circle at 84% 22%, rgba(255,228,180,.09), transparent 18%),
    linear-gradient(180deg, rgba(255,205,120,.06), rgba(0,0,0,0));
}
.boardhallTopbar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 10px 4px 0;
}
.boardhallBrand { display: inline-flex; align-items: center; gap: 14px; text-decoration: none; color: #fff5e7; }
.boardhallBrand strong { display: block; font-size: 1.08rem; }
.boardhallBrand small { display: block; color: #d9c8a5; text-transform: uppercase; letter-spacing: .12em; font-size: .68rem; }
.boardhallBrand__coin {
  width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center;
  background: linear-gradient(180deg, #f5d79f, #b9853b);
  color: #3c220a; font-weight: 900; box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 12px 28px rgba(0,0,0,.3);
}
.boardhallTopbar__nav { display: flex; gap: 10px; flex-wrap: wrap; justify-content: end; }
.boardhallTopbar .btn { background: rgba(52,31,20,.82); border-color: rgba(255,222,169,.18); color: #fff4df; }
.boardhallTopbar .btn--primary { background: linear-gradient(180deg, #edcf93, #b98237); color: #321b08; }
.boardhallHero__content {
  position: relative; z-index: 2; min-height: calc(100svh - 110px);
  display: grid; align-items: center; justify-items: center;
}
.boardhallProfileCard {
  width: min(920px, 100%);
  margin-inline: auto;
  display: grid; grid-template-columns: 180px 1fr; gap: 22px; align-items: center;
  padding: clamp(18px, 2.8vw, 28px);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(61,35,18,.74), rgba(29,18,13,.9));
  border: 1px solid rgba(255,221,167,.14);
  box-shadow: 0 20px 52px rgba(0,0,0,.32);
  backdrop-filter: blur(8px);
}
.boardhallProfileCard__body h1 { font-size: clamp(2.2rem, 4vw, 4rem); line-height: 1.03; color: #fff4e0; margin-bottom: 12px; }
.boardhallProfileCard__body .eyebrow { color: #f0d7a5; }
.boardhallLead { color: #eadcc1; max-width: 58ch; }
.boardhallProfileCard__avatarWrap { display: grid; place-items: center; }
.boardhallAvatar {
  width: 150px; height: 150px; border-radius: 34px; display: grid; place-items: center;
  font-size: 3.7rem; font-weight: 900; color: #3a210b;
  background: linear-gradient(180deg, #ffe5ba, #cb9446);
  border: 2px solid rgba(255,247,228,.25);
  box-shadow: inset 0 2px 0 rgba(255,255,255,.35), 0 18px 46px rgba(0,0,0,.38);
}
.boardhallStats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: 18px; }
.boardhallStat {
  padding: 14px 16px; border-radius: 18px;
  background: rgba(255,244,225,.06); border: 1px solid rgba(255,228,180,.12);
}
.boardhallStat--gold { background: linear-gradient(180deg, rgba(236,188,95,.18), rgba(255,244,225,.08)); }
.boardhallStat__label {
  display: block; margin-bottom: 8px; color: #d8c4a0; text-transform: uppercase; letter-spacing: .11em; font-size: .7rem;
}
.boardhallStat strong { color: #fff7ea; font-size: 1.12rem; }
.boardhallActions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 18px; }
.boardhallActions .btn { min-width: 210px; }
.boardhallActions .btn:not(.btn--primary) { background: rgba(31,18,12,.76); color: #fff0d2; border-color: rgba(255,227,174,.14); }
.boardhallScrollCue {
  position: absolute; left: 50%; bottom: 18px; z-index: 2; transform: translateX(-50%);
  display: inline-flex; flex-direction: column; align-items: center; gap: 4px; text-decoration: none;
  color: #ffe7b9; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; font-size: .72rem;
}
.boardhallScrollCue svg { width: 28px; height: 28px; fill: currentColor; }
.boardhallGamesSection { margin-top: 22px; display: grid; gap: 16px; }
.sectionHead--boardhall {
  padding: 0 4px; align-items: start;
}
.sectionHead--boardhall h2 { color: #fff0da; }
.sectionHead--boardhall .small { color: #d5c2a2; }
.boardhallGameGrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 18px; }
.boardhallGameCard {
  overflow: hidden; border-radius: 24px;
  background: linear-gradient(180deg, rgba(58,34,19,.95), rgba(26,17,12,.98));
  border: 1px solid rgba(255,223,172,.14);
}
.boardhallGameCard__art {
  height: 220px;
  background:
    linear-gradient(180deg, rgba(14,10,7,.06), rgba(14,10,7,.66)),
    url('/games/sarvatky-build/assets/sections/board.jpg') center/cover no-repeat;
}
.boardhallGameCard__body { padding: 22px; display: grid; gap: 12px; }
.boardhallGameCard__body h3 { color: #fff0dc; font-size: 1.65rem; }
.boardhallGameCard__body p { color: #e2d5bd; }
.boardhallGameMeta { display: flex; gap: 10px; flex-wrap: wrap; }
.boardhallGameCard__actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.boardhallGameCard__actions .btn { flex: 1 1 220px; }
.boardhallGameCard .btn:not(.btn--primary) { background: rgba(31,18,12,.7); color: #f4e2bf; border-color: rgba(255,227,174,.12); }
.arcadeTag {
  padding: 8px 12px; border-radius: 999px; border: 1px solid rgba(255,223,172,.14);
  background: rgba(255,243,223,.06); color: #f3e6cf; font-size: .84rem;
}
@media (max-width: 920px) {
  .boardhallProfileCard { grid-template-columns: 1fr; width: 100%; }
  .boardhallProfileCard__avatarWrap { justify-content: start; }
  .boardhallStats { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .boardhallShell { width: min(100%, calc(100% - 12px)); margin-top: 10px; }
  .boardhallHero { min-height: 100svh; padding: 16px; }
  .boardhallTopbar { align-items: start; flex-direction: column; }
  .boardhallTopbar__nav { justify-content: start; }
  .boardhallAvatar { width: 120px; height: 120px; font-size: 3rem; }
  .boardhallActions .btn { min-width: unset; flex: 1 1 220px; }
}


.boardhallStats--meta { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.boardhallMetaStrip {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: 12px;
  margin-top: 14px;
}
.boardhallXp,
.boardhallMultiplier {
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,244,225,.06);
  border: 1px solid rgba(255,228,180,.12);
}
.boardhallXp__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  color: #f7ebd6;
  margin-bottom: 10px;
}
.boardhallXp__head span { color: #d8c4a0; font-size: .84rem; text-transform: uppercase; letter-spacing: .08em; }
.boardhallMultiplier { display: grid; align-content: center; }
.boardhallMultiplier strong { color: #fff7ea; font-size: 1.35rem; }
.boardhallProgress,
.boardhallMiniProgress {
  position: relative;
  overflow: hidden;
  height: 14px;
  border-radius: 999px;
  background: rgba(15, 8, 6, .55);
  border: 1px solid rgba(255,228,180,.12);
}
.boardhallProgress__fill,
.boardhallMiniProgress__fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, #efcf94, #c48a39);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
}
.boardhallMiniProgress { height: 12px; margin-top: 2px; }
.boardhallGameMeta--stats { margin-bottom: 2px; }
@media (max-width: 920px) {
  .boardhallStats--meta { grid-template-columns: 1fr 1fr; }
  .boardhallMetaStrip { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .boardhallStats--meta { grid-template-columns: 1fr; }
}


.btn--muted {
  opacity: 0.72;
  cursor: not-allowed;
}

.boardhallStoreMeta {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(57, 35, 18, 0.48);
  border: 1px solid rgba(255, 215, 138, 0.22);
}

.boardhallStoreMeta__price {
  font-size: 1.08rem;
  font-weight: 800;
  color: #ffe7b8;
}

.boardhallStoreMeta__discount,
.boardhallStoreMeta__full,
.boardhallStoreHint {
  color: rgba(255, 240, 214, 0.84);
}

.boardhallStoreHint {
  margin: 12px 0 0;
  font-size: 0.95rem;
  line-height: 1.5;
}

.boardhallAvatar {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
.boardhallAvatar.has-image {
  color: transparent;
}
.boardhallProfileTools {
  margin-top: 22px;
  padding: 22px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(58,34,19,.95), rgba(26,17,12,.98));
  border: 1px solid rgba(255,223,172,.14);
}
.boardhallCustomizer {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.boardhallCustomizer__preview {
  display: grid;
  gap: 14px;
  justify-items: start;
  padding: 18px;
  border-radius: 20px;
  background: rgba(255,244,225,.06);
  border: 1px solid rgba(255,228,180,.12);
}
.boardhallAvatar--editor {
  width: 120px;
  height: 120px;
  border-radius: 28px;
  font-size: 2.8rem;
}
.boardhallCustomizer__controls {
  display: grid;
  gap: 14px;
}
.boardhallPresetGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.boardhallPresetGrid .btn.is-active {
  border-color: rgba(255,227,174,.58);
  box-shadow: inset 0 0 0 1px rgba(255,227,174,.28), 0 10px 24px rgba(0,0,0,.18);
}
.boardhallAvatarActions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.boardhallAvatarActions .btn,
.boardhallPresetGrid .btn {
  background: rgba(31,18,12,.7);
  color: #f4e2bf;
  border-color: rgba(255,227,174,.12);
}
@media (max-width: 920px) {
  .boardhallCustomizer {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 620px) {
  .boardhallProfileTools {
    padding: 16px;
  }
  .boardhallPresetGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .boardhallAvatarActions .btn,
  .boardhallPresetGrid .btn {
    width: 100%;
  }
}


.sectionCard--avatar {
  overflow: hidden;
}
.accountAvatarEditor {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  margin-top: 12px;
}
.accountAvatarEditor__previewWrap {
  display: grid;
  gap: 14px;
  justify-items: start;
  padding: 18px;
  border-radius: 20px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.accountAvatarEditor__preview {
  width: 120px;
  height: 120px;
  border-radius: 28px;
  font-size: 2.8rem;
}
.accountAvatarEditor__controls {
  display: grid;
  gap: 14px;
}
@media (max-width: 920px) {
  .accountAvatarEditor {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 620px) {
  .accountAvatarEditor__previewWrap {
    padding: 14px;
  }
}


.collectiblesGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}
.collectibleCard {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
}
.collectibleCard--empty { opacity: .78; border-style: dashed; }
.collectibleCard__icon {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-size: 30px;
  background: linear-gradient(135deg, rgba(233,205,146,.3), rgba(255,255,255,.08));
  border: 1px solid rgba(233,205,146,.28);
}
.boardhallProfileCard { grid-template-columns: minmax(92px, 116px) minmax(0, 1fr); }
.adminCollectibles { display: grid; gap: 12px; }
.adminCollectibleSlot {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,.03);
}
.adminCollectibleSlot select { min-width: 180px; }
@media (max-width: 980px) { .collectiblesGrid { grid-template-columns: 1fr; } }
@media (max-width: 640px) {
  .collectibleCard { grid-template-columns: 52px 1fr; padding: 12px; }
  .collectibleCard__icon { width: 52px; height: 52px; font-size: 24px; }
}

/* ===== Account refresh v1.8 ===== */
.accountStage {
  display: grid;
  grid-template-columns: minmax(340px, 520px) minmax(0, 1fr);
  gap: 24px;
  align-items: stretch;
  width: min(1200px, 100%);
  margin-inline: auto;
}
.accountStage__visual {
  min-height: 420px;
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(255,228,180,.14);
  background:
    radial-gradient(circle at 18% 18%, rgba(255,214,153,.2), transparent 22%),
    linear-gradient(180deg, rgba(61,35,18,.72), rgba(26,17,12,.96)),
    url('/games/sarvatky-build/assets/guide/cover.jpg') center/cover no-repeat;
  display: grid;
  place-items: center;
  position: relative;
}
.accountStage__preview {
  width: min(74%, 280px);
  height: min(74%, 280px);
  border-radius: 32px;
  font-size: clamp(3rem, 5vw, 5rem);
  box-shadow: 0 22px 46px rgba(0,0,0,.36);
}
.accountStage__caption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(18,11,8,.56);
  border: 1px solid rgba(255,228,180,.16);
  display: grid;
  gap: 4px;
  color: #fff0d8;
}
.accountStage__caption span { color: #dcc9a5; font-size: .9rem; }
.accountStage__content {
  display: grid;
  align-content: center;
  gap: 16px;
  max-width: 620px;
}
.accountStage__content h2 {
  margin: 0;
  font-size: clamp(2rem, 3vw, 3rem);
  color: #fff3df;
}
.accountInfoGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.accountInfoCard {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.05);
}
.accountInfoCard--gold {
  background: linear-gradient(180deg, rgba(236,188,95,.18), rgba(255,244,225,.08));
}
.accountInfoCard strong { color: #fff7ea; font-size: 1.1rem; }
.accountStage__xp { margin-top: 4px; }
.accountStackLayout { margin: 18px auto 0; width: min(1200px, 100%); }
.accountCollectibleSlots {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.accountCollectibleSlot {
  display: grid;
  gap: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  padding: 14px;
}
.accountCollectibleSlot--empty { border-style: dashed; opacity: .94; }
.accountCollectibleSlot__head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}
.accountCollectibleSlot__head span { font-size: .8rem; color: #d7c6a7; }
.accountCollectibleSlot__visual {
  min-height: 108px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
}
.accountCollectibleSlot__visual.is-card {
  background:
    linear-gradient(135deg, rgba(255,255,255,.08), rgba(233,205,146,.08)),
    repeating-linear-gradient(45deg, rgba(166,24,24,.18) 0 8px, rgba(255,255,255,.08) 8px 16px);
}
.accountCollectibleSlot__visual.is-dice {
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.22), transparent 24%), linear-gradient(180deg, rgba(255,255,255,.08), rgba(205,214,226,.05));
}
.accountCollectibleSlot__visual.is-coin {
  background: radial-gradient(circle at 30% 30%, rgba(255,231,164,.32), rgba(171,118,38,.14));
}
.accountCollectibleSlot__visual.is-empty {
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.accountCollectibleSlot__icon { font-size: 2.5rem; }

.accountCollectibleSlot--locked {
  border-style: dashed;
  background: rgba(255,255,255,.025);
  opacity: .9;
}
.accountCollectibleSlot__visual.is-locked {
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  border-style: dashed;
}
.accountCollectibleSlot__lock {
  font-size: 2rem;
  filter: saturate(.4);
}
.accountCollectibleSlot__actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.accountCollectibleSlot__actions .btn {
  min-width: 0;
  padding-inline: 8px;
}
@media (max-width: 1080px) {
  .accountStage { grid-template-columns: 1fr; }
  .accountInfoGrid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .accountCollectibleSlots { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .accountStage__visual { min-height: 260px; }
  .accountStage__preview { width: 180px; height: 180px; }
  .accountInfoGrid { grid-template-columns: 1fr; }
  .accountCollectibleSlot__actions { grid-template-columns: 1fr 1fr 1fr; }
}


/* ===== Room layout v2.6.0 ===== */
.roomPage {
  background:
    radial-gradient(circle at top left, rgba(244,214,151,.14), transparent 20%),
    radial-gradient(circle at bottom right, rgba(119,70,30,.24), transparent 26%),
    linear-gradient(180deg, #28180f 0%, #140d0a 58%, #0d0907 100%);
}
.roomShell {
  width: min(1560px, calc(100% - 18px));
  margin: 18px auto 34px;
  display: grid;
  gap: 16px;
}
.roomHud {
  display: grid;
  grid-template-columns: minmax(260px, 360px) minmax(0, 1fr) auto;
  gap: 16px;
  align-items: stretch;
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(51,30,19,.94), rgba(23,15,11,.98)),
    url('/static/assets/room/panel-texture.svg') right center / 320px auto no-repeat;
  border-color: rgba(255,227,174,.14);
}
.roomHud__controls {
  grid-column: 3;
  display: flex;
  gap: 10px;
  align-items: start;
  justify-content: end;
}
.roomHud__brand {
  display: grid;
  gap: 10px;
  align-content: start;
}
.roomHud__brandText { color: #d8c7a8; margin: 0; }
.roomHud__stats {
  grid-column: 2;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.roomHudStat {
  min-height: 92px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,227,174,.12);
  background: rgba(255,244,225,.06);
  display: grid;
  gap: 8px;
  align-content: start;
}
.roomHudStat span {
  color: #d8c4a0;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: .72rem;
}
.roomHudStat strong { color: #fff5e5; font-size: 1.18rem; }
.roomHudStat--interactive{cursor:pointer;transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease}
.roomHudStat--interactive:hover,.roomHudStat--interactive:focus-visible{transform:translateY(-1px);border-color:rgba(255,224,160,.45);box-shadow:0 12px 26px rgba(0,0,0,.16);outline:none}
.roomHudStat--gold {
  background: linear-gradient(180deg, rgba(236,188,95,.20), rgba(255,244,225,.08));
}
.roomHudStat--xp { grid-column: span 1; }
.roomHudStat__xpHead {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.roomHud__actions {
  grid-column: 2 / -1;
  display: none;
  flex-wrap: wrap;
  gap: 10px;
  align-content: start;
  justify-content: end;
  padding-top: 8px;
  border-top: 1px solid rgba(255,227,174,.12);
}
.roomHud.is-actions-open .roomHud__actions {
  display: flex;
}
.roomHud .btn:not(.btn--primary) {
  background: rgba(31,18,12,.76);
  color: #fff0d2;
  border-color: rgba(255,227,174,.14);
}

.roomLayout {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(340px, 2fr);
  gap: 16px;
  align-items: stretch;
}
.roomMain,
.roomSidebar {
  padding: 18px;
  border-color: rgba(255,227,174,.14);
}
.roomMain {
  display: grid;
  gap: 18px;
  background:
    linear-gradient(180deg, rgba(48,28,18,.96), rgba(19,13,10,.98)),
    url('/static/assets/room/panel-texture.svg') right top / 360px auto no-repeat;
}
.roomSidebar {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  min-width: 0;
  background:
    linear-gradient(180deg, rgba(45,27,18,.96), rgba(19,13,10,.98)),
    url('/static/assets/room/sidebar-pattern.svg') center / cover no-repeat;
}
.roomSectionHead {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}
.roomSectionHead h1 { margin-bottom: 8px; color: #fff3df; }
.roomSectionHead .small { color: #d8c7a8; }

.roomIdentity {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,244,225,.05);
  border: 1px solid rgba(255,227,174,.12);
}
.roomAvatar {
  width: 140px;
  height: 140px;
  border-radius: 30px;
  font-size: 3.4rem;
}
.roomIdentity__body {
  display: grid;
  gap: 8px;
}
.roomIdentity__body h2 {
  margin: 0;
  color: #fff4e2;
  font-size: clamp(1.8rem, 2.8vw, 2.6rem);
}

.roomRailSection {
  display: grid;
  gap: 12px;
}
.roomRailSection__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
}
.roomRailSection__head h2 {
  margin-bottom: 6px;
  color: #fff0dc;
}
.roomRailSection__head .small { color: #d8c7a8; }
.roomRailControls {
  display: inline-flex;
  gap: 8px;
}
.roomArrow {
  min-width: 52px;
  padding-inline: 12px;
}
.roomRailViewport {
  overflow: hidden;
}
.roomSlotTrack,
.gameTrack {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding-bottom: 4px;
}
.roomSlotTrack::-webkit-scrollbar,
.gameTrack::-webkit-scrollbar { display: none; }
.roomSlotCard {
  flex: 0 0 220px;
  min-height: 170px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(255,227,174,.12);
  background: rgba(255,244,225,.05);
  color: #fff4df;
  display: grid;
  gap: 8px;
  text-align: left;
}
.roomSlotCard:hover:not(:disabled) {
  transform: translateY(-2px);
}
.roomSlotCard:disabled {
  opacity: .74;
  cursor: not-allowed;
}
.roomSlotCard.is-muted,
.roomSlotCard.is-locked {
  border-style: dashed;
  background: rgba(255,255,255,.03);
}
.roomSlotCard.is-filled {
  background: linear-gradient(180deg, rgba(236,188,95,.12), rgba(255,244,225,.05));
}
.roomSlotCard__plus {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  background: rgba(255,244,225,.08);
  border: 1px solid rgba(255,227,174,.14);
}
.roomSlotCard__eyebrow {
  color: #d8c4a0;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: .72rem;
}
.roomSlotCard strong { font-size: 1.12rem; }
.roomSlotCard__desc {
  color: #d9ceb8;
  font-size: .92rem;
  line-height: 1.5;
}

.roomTableSection { margin-top: 2px; }
.roomTableVisual {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 18px;
  min-height: 420px;
  border-radius: 26px;
  border: 1px solid rgba(255,227,174,.14);
  background:
    linear-gradient(180deg, rgba(24,13,10,.26), rgba(20,11,8,.72)),
    url('/static/assets/room/table-frame.svg') center / cover no-repeat,
    url('/games/sarvatky-build/assets/board/backgrounds/kralovske_plane/bg.webp') center / cover no-repeat;
}
.roomTableVisual__head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
}
.roomTableVisual__head h2 { color: #fff3df; margin-bottom: 6px; }
.roomTableVisual__head .small { color: #ead9b4; }
.roomTableStats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.roomTableStat {
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,227,174,.14);
  background: rgba(18,11,8,.42);
  display: grid;
  gap: 6px;
}
.roomTableStat span {
  color: #d8c4a0;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-size: .72rem;
}
.roomTableStat strong { color: #fff8ee; font-size: 1.1rem; }
.roomRailViewport--games { margin-top: 2px; }
.roomGameCard {
  flex: 0 0 320px;
  border-radius: 22px;
  border: 1px solid rgba(255,227,174,.12);
  background: linear-gradient(180deg, rgba(54,31,20,.92), rgba(26,17,12,.98));
  overflow: hidden;
}
.roomGameCard.is-selected {
  border-color: rgba(255,227,174,.44);
  box-shadow: inset 0 0 0 1px rgba(255,227,174,.18), 0 16px 34px rgba(0,0,0,.22);
}
.roomGameCard__select {
  display: grid;
  gap: 10px;
  width: 100%;
  padding: 18px;
  background: transparent;
  border: 0;
  color: inherit;
  text-align: left;
  cursor: pointer;
}
.roomGameCard h3 {
  color: #fff2df;
  margin: 0;
  font-size: 1.4rem;
}
.roomGameCard__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.roomGameCard__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding: 0 18px 18px;
}
.roomGameCard__actions .btn { flex: 1 1 140px; }

.roomSidebar__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.roomTab {
  appearance: none;
  border: 1px solid rgba(255,227,174,.14);
  border-radius: 16px;
  background: rgba(31,18,12,.76);
  color: #f3e5cb;
  font-weight: 700;
  padding: 12px 14px;
  cursor: pointer;
}
.roomTab.is-active {
  background: linear-gradient(180deg, #edcf93, #b98237);
  color: #321b08;
  border-color: transparent;
}
.roomSidebar__body {
  flex: 1;
  overflow: auto;
  margin-top: 16px;
  padding-right: 4px;
}
.sidePane {
  display: none;
}
.sidePane.is-active {
  display: block;
}
.sidePane__list {
  display: grid;
  gap: 12px;
}
.sideCard {
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,227,174,.12);
  background: rgba(255,244,225,.05);
}
.sideCard__head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
}
.sideCard__head strong { color: #fff1dd; }
.sideCard__head span {
  color: #d8c4a0;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .68rem;
}
.sideCard p {
  margin-bottom: 0;
  color: #e3d7c1;
}
.sideCard--button {
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: border-color .18s ease, transform .18s ease, background .18s ease;
}
.sideCard--button:hover {
  transform: translateY(-1px);
  border-color: rgba(255,227,174,.28);
  background: rgba(255,244,225,.08);
}
.sideCard--button.is-active {
  border-color: rgba(226, 191, 109, .6);
  background: rgba(226, 191, 109, .12);
}
.sidePane__footer {
  padding: 14px 4px 4px;
}
.sidePane__footer .small { color: #d8c7a8; }

.roomModal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 18px;
}
.roomModal.is-hidden {
  display: none;
}
.roomModal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8,6,5,.66);
  backdrop-filter: blur(4px);
}
.roomModal__dialog {
  position: relative;
  z-index: 1;
  width: min(760px, 100%);
  max-height: min(92vh, 900px);
  overflow: auto;
  padding: 18px;
  background: linear-gradient(180deg, rgba(53,31,20,.98), rgba(22,14,11,.98));
  border-color: rgba(255,227,174,.14);
}
.roomModal__head {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
  margin-bottom: 14px;
}
.roomModal__head h2 { color: #fff4df; }
.roomModal__content {
  display: grid;
  gap: 16px;
}
.modalAvatarPreview {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(255,227,174,.12);
  background: rgba(255,244,225,.05);
}
.modalSection {
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(255,227,174,.12);
  background: rgba(255,255,255,.04);
}
.modalSection__label {
  margin-bottom: 10px;
  color: #e8d6b2;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.modalChoiceGrid,
.modalActionGrid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.walletTopupForm{display:grid;gap:16px}
.walletTopupPicker{display:grid;gap:12px;padding:14px;border-radius:18px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.walletTopupPreview{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.walletTopupPreview strong{font-size:1.15rem;color:#fff4df}
.walletTopupPreview span{color:#f3d38c;font-weight:800}
.walletTopupPicker input[type='range']{width:100%}
.walletTopupQuickGrid .btn{min-width:0}
.gameUnlockCard__preview{flex-wrap:wrap}
.gameUnlockCard__stats{width:100%}
.adminTabs{display:flex;flex-wrap:wrap;gap:10px}
.adminPane{display:grid;gap:20px}
.tableWrap{width:100%;overflow:auto;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(18,13,10,.45)}
.adminTable{width:100%;min-width:720px;border-collapse:collapse}
.adminTable th,.adminTable td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;vertical-align:middle;font-size:.92rem}
.adminTable th{color:#f7e5bf;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;background:rgba(255,255,255,.04)}
.adminTable tbody tr:hover{background:rgba(255,255,255,.03)}
.clanStatCard small{color:#d7c29c;font-size:.76rem}
.modalCollectibleState {
  display: grid;
  gap: 6px;
}
.accountPasswordOnly {
  width: min(760px, 100%);
  margin-inline: auto;
}
.accountPasswordCard {
  background: linear-gradient(180deg, rgba(53,31,20,.96), rgba(22,14,11,.98));
  border-color: rgba(255,227,174,.14);
}
.accountPasswordCard .small { color: #dac7a5; }

@media (max-width: 1240px) {
  .roomHud {
    grid-template-columns: 1fr;
  }
  .roomHud__actions {
    justify-content: start;
  }
  .roomHud__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .roomLayout {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 860px) {
  .roomShell {
    width: min(100%, calc(100% - 10px));
    margin-top: 10px;
  }
  .roomSectionHead,
  .roomRailSection__head,
  .roomTableVisual__head {
    flex-direction: column;
    align-items: start;
  }
  .roomIdentity {
    grid-template-columns: 1fr;
  }
  .roomAvatar {
    width: 120px;
    height: 120px;
    font-size: 3rem;
  }
  .roomTableStats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .modalAvatarPreview {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 620px) {
  .roomHud__stats,
  .roomTableStats {
    grid-template-columns: 1fr;
  }
  .roomSlotCard,
  .roomGameCard {
    flex-basis: 86vw;
  }
  .roomSidebar__head {
    grid-template-columns: 1fr;
  }
}

/* ===== Room layout v2.7.0 refinements ===== */
.roomContextSwitch {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.roomContextTab {
  appearance: none;
  border: 1px solid rgba(255,227,174,.14);
  border-radius: 18px;
  background: rgba(31,18,12,.76);
  color: #f3e5cb;
  font-weight: 700;
  padding: 14px 16px;
  cursor: pointer;
  text-align: center;
}
.roomContextTab.is-active {
  background: linear-gradient(180deg, #edcf93, #b98237);
  color: #321b08;
  border-color: transparent;
}
.roomContentPane {
  display: none;
  gap: 18px;
}
.roomContentPane.is-active {
  display: grid;
}
.roomSectionHead--stacked {
  align-items: start;
}
.roomRailSection--compact .roomRailSection__head h2 {
  margin: 0;
}
.roomProfileIdentitySlot {
  flex: 0 0 360px;
  min-height: 170px;
  grid-template-columns: 94px minmax(0, 1fr);
  align-items: center;
  background: linear-gradient(180deg, rgba(236,188,95,.15), rgba(255,244,225,.05));
}
.roomProfileIdentitySlot__avatar {
  width: 94px;
  height: 94px;
  border-radius: 24px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  border: 1px solid rgba(255,227,174,.18);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  display: grid;
  place-items: center;
  font-size: 2rem;
  color: transparent;
}
.roomProfileIdentitySlot__body {
  display: grid;
  gap: 10px;
  min-width: 0;
}
.roomProfileIdentitySlot__top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}
.roomProfileIdentitySlot__role,
.roomProfileIdentitySlot__hint {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.roomProfileIdentitySlot__role {
  background: rgba(255,244,225,.10);
  color: #fff0d5;
}
.roomProfileIdentitySlot__hint {
  background: rgba(31,18,12,.64);
  color: #dbc9a6;
}
.roomProfileIdentitySlot strong {
  font-size: 1.4rem;
  line-height: 1.2;
}
.roomTableStage {
  display: grid;
  min-height: 260px;
}
.roomTableStage__media {
  position: relative;
  min-height: 260px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,227,174,.14);
  box-shadow: 0 18px 36px rgba(0,0,0,.24);
}
.roomTableStage__mediaImage {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transform: scale(1.02);
}
.roomTableStage__overlay {
  position: relative;
  z-index: 1;
  min-height: 260px;
  display: grid;
  align-content: end;
  gap: 10px;
  padding: 22px;
  background: linear-gradient(180deg, rgba(14,10,7,.06), rgba(14,10,7,.84) 70%, rgba(14,10,7,.94));
}
.roomTableStage__status {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  min-height: 32px;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(255,244,225,.12);
  color: #fff0d5;
  font-size: .74rem;
  text-transform: uppercase;
  letter-spacing: .09em;
}
.roomTableStage__overlay h3 {
  margin: 0;
  color: #fff5e6;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
}
.roomTableStage__overlay p {
  max-width: 720px;
  margin: 0;
  color: #eadcc4;
}
.roomTableStage__play {
  width: fit-content;
  min-width: 140px;
}
.roomTableStage__play.is-disabled {
  pointer-events: none;
  opacity: .72;
}
.roomClanPlaceholder {
  min-height: 620px;
  padding: 28px;
  border-radius: 24px;
  border: 1px dashed rgba(255,227,174,.18);
  background: rgba(255,244,225,.05);
  display: grid;
  align-content: center;
  justify-items: start;
  gap: 10px;
}
.roomClanPlaceholder h2 {
  margin: 0;
  color: #fff3df;
}
.roomClanPlaceholder .small {
  color: #d8c7a8;
  max-width: 640px;
}

@media (max-width: 860px) {
  .roomContextSwitch {
    grid-template-columns: 1fr;
  }
  .roomProfileIdentitySlot {
    flex-basis: 92vw;
    grid-template-columns: 1fr;
  }
  .roomProfileIdentitySlot__avatar {
    width: 84px;
    height: 84px;
  }
  .roomProfileIdentitySlot__top {
    flex-wrap: wrap;
  }
}


/* ===== Room layout v2.8.0 compact fit ===== */
.roomShell {
  width: calc(100vw - 12px);
  max-width: none;
  margin: 6px auto 16px;
}
.roomHud {
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) auto;
  gap: 12px;
  padding: 14px;
}
.roomHud__toggle {
  display: none;
}
.roomHud__settingsBtn {
  white-space: nowrap;
}
.roomHud__brandText {
  font-size: .92rem;
}
.roomHud__stats {
  gap: 10px;
}
.roomHudStat {
  min-height: 78px;
  padding: 12px 14px;
}
.roomMain,
.roomSidebar {
  padding: 14px;
}
.roomRailSection {
  gap: 10px;
}
.roomRailViewport,
.roomSidebar__body {
  min-width: 0;
}
.roomSlotTrack {
  gap: 10px;
}
.roomSlotCard {
  flex-basis: 188px;
  min-height: 148px;
  padding: 14px;
}
.roomSlotCard__plus {
  width: 38px;
  height: 38px;
  font-size: 1.32rem;
}
.roomSlotCard strong {
  font-size: 1rem;
}
.roomSlotCard__desc {
  font-size: .88rem;
  line-height: 1.35;
}
.roomProfileIdentitySlot {
  flex-basis: 320px;
  min-height: 148px;
  grid-template-columns: 82px minmax(0, 1fr);
}
.roomProfileIdentitySlot__avatar {
  width: 82px;
  height: 82px;
  border-radius: 20px;
}
.roomProfileIdentitySlot strong {
  font-size: 1.22rem;
}
.roomTableVisual {
  padding: 14px;
  min-height: 380px;
}
.roomTableStats {
  gap: 10px;
}
.roomTableStat {
  padding: 10px 12px;
}
.roomTableStage,
.roomTableStage__media,
.roomTableStage__overlay {
  min-height: 236px;
}
.roomSidebar {
  min-height: 100%;
}
.roomSidebar__body {
  margin-top: 12px;
}
.roomSidebar__composer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,227,174,.12);
}
.roomSidebar__composer input {
  min-width: 0;
}
@media (max-width: 860px) {
  .roomShell {
    width: calc(100vw - 8px);
    margin-top: 4px;
  }
  .roomHud {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
  }
  .roomHud__controls {
    grid-column: 2;
    justify-self: end;
  }
  .roomHud__toggle {
    display: inline-flex;
    align-self: start;
    justify-self: end;
    min-width: 48px;
    min-height: 48px;
    padding-inline: 0;
    justify-content: center;
    font-size: 1.2rem;
  }
  .roomHud:not(.is-open) .roomHud__stats,
  .roomHud:not(.is-open) .roomHud__actions,
  .roomHud:not(.is-open) .roomHud__settingsBtn {
    display: none;
  }
  .roomHud.is-open .roomHud__stats,
  .roomHud.is-open .roomHud__actions {
    grid-column: 1 / -1;
  }
  .roomHud__stats {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
  }
  .roomHud__actions {
    width: 100%;
    justify-content: stretch;
  }
  .roomHud__actions .btn {
    flex: 1 1 auto;
  }
  .roomSlotCard {
    flex-basis: 180px;
  }
  .roomProfileIdentitySlot {
    flex-basis: 240px;
  }
  .roomSidebar__composer {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 620px) {
  .roomLayout {
    gap: 12px;
  }
  .roomMain,
  .roomSidebar {
    padding: 12px;
  }
  .roomSlotCard,
  .roomGameCard {
    flex-basis: 76vw;
  }
  .roomProfileIdentitySlot {
    flex-basis: 76vw;
    grid-template-columns: 1fr;
  }
}

/* ===== Room layout v2.9.0 refinements ===== */
.roomShell { width: min(calc(100vw - 12px), 1540px); }
.roomLayout { grid-template-columns: minmax(0, 3.2fr) minmax(320px, 1.8fr); }
.roomMain,
.roomSidebar,
.roomHud { padding: 16px; }
.roomContextSwitch { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.roomSidebar__head { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.roomRailSection--compact { gap: 10px; }
.roomSlotTrack { gap: 10px; }
.roomSlotCard { flex: 0 0 190px; min-height: 142px; padding: 14px; }
.roomSlotCard--compact { flex-basis: 136px; min-height: 118px; place-content: center; text-align: center; }
.roomSlotCard--compact .roomSlotCard__plus { margin-inline: auto; }
.roomSlotCard--compact .roomSlotCard__desc { display: none; }
.roomProfileIdentitySlot { flex: 0 0 300px; min-height: 138px; grid-template-columns: 78px minmax(0,1fr); gap: 12px; }
.roomProfileIdentitySlot__avatar { width: 78px; height: 78px; border-radius: 20px; }
.roomProfileIdentitySlot__body { gap: 8px; }
.roomProfileIdentitySlot strong { font-size: 1.2rem; }
.roomProfileIdentitySlot .roomSlotCard__desc { font-size: .84rem; line-height: 1.35; }
.roomProfileIdentitySlot__hint,
.roomProfileIdentitySlot__role { min-height: 28px; padding: 4px 9px; font-size: .68rem; }
.roomSlotCard--itemIcon { flex: 0 0 74px; min-height: 74px; width: 74px; padding: 0; place-items: center; border-radius: 18px; }
.roomSlotCard--itemIcon .roomSlotCard__iconOnly { display: grid; place-items: center; width: 100%; height: 100%; font-size: 1.9rem; border-radius: inherit; background: rgba(255,244,225,.06); }
.roomSlotCard--itemIcon.is-filled .roomSlotCard__iconOnly { background: linear-gradient(180deg, rgba(236,188,95,.18), rgba(255,244,225,.08)); }
.roomSlotCard--itemIcon .roomSlotCard__plus,
.roomSlotCard--itemIcon .roomSlotCard__eyebrow,
.roomSlotCard--itemIcon strong,
.roomSlotCard--itemIcon .roomSlotCard__desc { display: none; }
.roomTableVisual { min-height: 0; padding: 0; border: 0; background: transparent; }
.roomTableStage { min-height: 310px; }
.roomTableStage__media { min-height: 310px; border: 0; box-shadow: none; background: transparent; overflow: visible; }
.roomTableStage__mediaImage { inset: 0; border-radius: 26px; box-shadow: 0 16px 34px rgba(0,0,0,.24); }
.roomTableStage__overlay--floating { min-height: 0; position: absolute; inset: 18px 18px auto 18px; max-width: min(62%, 540px); padding: 0; gap: 8px; background: none; align-content: start; }
.roomTableStage__controls { position: absolute; inset: 50% auto auto 50%; transform: translate(-50%, -50%); z-index: 2; display: grid; place-items: center; }
.roomTableStage__controls--stacked { gap: 10px; }
.roomTableStage__play,
.roomTableStage__purchase { min-width: 188px; }
.roomTableStats { margin-top: 4px; }
.roomSidebar__actionbar { margin-top: 12px; display: flex; }
.roomSidebar__actionbar .btn { width: 100%; }
.roomClanPlaceholder--rooms { min-height: 620px; }
@media (max-width: 1240px) {
  .roomContextSwitch { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .roomProfileIdentitySlot { flex-basis: 88vw; grid-template-columns: 1fr; }
  .roomSlotCard--itemIcon { flex-basis: 72px; }
  .roomTableStage__overlay--floating { position: absolute; inset: 16px 16px auto 16px; max-width: calc(100% - 32px); }
}
@media (max-width: 620px) {
  .roomSlotCard--compact { flex-basis: 120px; }
  .roomSlotCard--itemIcon { flex-basis: 68px; min-height: 68px; width: 68px; }
  .roomTableStage__controls { inset: auto 16px 18px 16px; transform: none; }
  .roomTableStage__play { width: 100%; }
}


/* ===== Room layout v3.0.0 one-page polish ===== */
.roomShell {
  width: min(calc(100vw - 8px), 1540px);
  margin: 4px auto 8px;
  gap: 10px;
}
.roomLayout {
  gap: 12px;
  grid-template-columns: minmax(0, 3.35fr) minmax(300px, 1.65fr);
}
.roomHud,
.roomMain,
.roomSidebar {
  padding: 12px;
}
.roomHud {
  gap: 10px;
  grid-template-columns: minmax(200px, 280px) minmax(0, 1fr) auto;
}
.roomHud__brandText {
  display: none;
}
.roomHudStat {
  min-height: 72px;
  padding: 10px 12px;
}
.roomMain {
  gap: 12px;
}
.roomContextTab,
.roomTab {
  min-height: 54px;
}
.roomRailSection--compact {
  gap: 8px;
}
.roomRailSection__head h2,
.roomTableVisual__head h2 {
  margin: 0;
  font-size: 1.05rem;
}
.roomArrow {
  min-width: 46px;
  min-height: 40px;
  padding-inline: 0;
  background: linear-gradient(180deg, #edcf93, #b98237);
  color: #321b08;
  border-color: transparent;
}
.roomArrow:hover {
  filter: brightness(1.03);
}
.roomSlotTrack {
  gap: 8px;
}
.roomSlotCard {
  flex: 0 0 170px;
  min-height: 126px;
  padding: 12px;
}
.roomSlotCard--compact {
  flex-basis: 104px;
  min-height: 104px;
}
.roomProfileIdentitySlot {
  flex: 0 0 272px;
  min-height: 126px;
  grid-template-columns: 70px minmax(0, 1fr);
  gap: 10px;
}
.roomProfileIdentitySlot__avatar {
  width: 70px;
  height: 70px;
  border-radius: 18px;
}
.roomProfileIdentitySlot__body {
  gap: 6px;
}
.roomProfileIdentitySlot strong {
  font-size: 1.08rem;
}
.roomProfileIdentitySlot .roomSlotCard__desc {
  font-size: .8rem;
  line-height: 1.28;
}
.roomProfileIdentitySlot__hint,
.roomProfileIdentitySlot__role {
  min-height: 24px;
  padding: 3px 8px;
  font-size: .64rem;
}
.roomSlotCard--itemIcon {
  flex: 0 0 60px;
  width: 60px;
  min-height: 60px;
  border-radius: 16px;
}
.roomSlotCard--itemIcon .roomSlotCard__iconOnly {
  font-size: 1.55rem;
}
.roomTableVisual {
  gap: 8px;
}
.roomTableVisual__head {
  margin-bottom: 0;
}
.roomTableStage {
  min-height: 258px;
}
.roomTableStage__media {
  min-height: 258px;
}
.roomTableStage__mediaImage {
  box-shadow: 0 14px 28px rgba(0,0,0,.22);
}
.roomTableStage__overlay--floating {
  inset: 16px 16px auto 16px;
  max-width: min(58%, 460px);
  gap: 6px;
}
.roomTableStage__overlay h3 {
  font-size: clamp(1.4rem, 2.3vw, 1.9rem);
}
.roomTableStage__overlay p {
  font-size: .95rem;
  line-height: 1.34;
}
.roomTableStage__controls {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
}
.roomTableStage__controls--stacked {
  display: grid;
  gap: 10px;
  place-items: center;
}
.roomTableStage__purchase {
  background: rgba(18,11,8,.78);
  color: #fff1d2;
  border-color: rgba(255,227,174,.22);
}
.roomTableStage__purchase:hover:not(:disabled) {
  border-color: rgba(255,227,174,.38);
  background: rgba(28,18,12,.88);
}
.roomTableStage__purchase.is-disabled,
.roomTableStage__purchase:disabled {
  opacity: .72;
}
.roomTableStage__play,
.roomSidebar__composer .btn,
.roomSidebar__actionbar .btn {
  background: linear-gradient(180deg, #edcf93, #b98237);
  color: #321b08;
  border-color: transparent;
}
.roomTableStage__meta {
  position: absolute;
  left: 16px;
  bottom: 16px;
  z-index: 2;
  display: grid;
  gap: 8px;
  width: min(290px, calc(100% - 32px));
}
.roomTableStage__metaStat {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,227,174,.14);
  background: rgba(18,11,8,.68);
  backdrop-filter: blur(4px);
}
.roomTableStage__metaStat span {
  color: #d8c4a0;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .68rem;
}
.roomTableStage__metaStat strong {
  color: #fff8ee;
  font-size: 1rem;
}
.roomSidebar__body {
  margin-top: 12px;
  min-height: 0;
  flex: 1 1 auto;
  display: flex;
  overflow: hidden;
}
.sidePane {
  display: none;
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 6px;
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: rgba(237,207,147,.72) rgba(255,244,225,.06);
}
.sidePane.is-active {
  display: block;
}
.sidePane::-webkit-scrollbar {
  width: 10px;
}
.sidePane::-webkit-scrollbar-track {
  background: rgba(255,244,225,.06);
  border-radius: 999px;
}
.sidePane::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #edcf93, #b98237);
  border-radius: 999px;
  border: 2px solid rgba(31,18,12,.72);
}
.sidePane:not(.is-active) {
  overflow: hidden;
}
.sidePane__footer {
  display: none;
}
.roomSidebar__composer {
  margin-top: 10px;
  padding-top: 10px;
}
@media (max-width: 1360px) {
  .roomHud {
    grid-template-columns: minmax(180px, 240px) minmax(0, 1fr) auto;
  }
  .roomSlotCard {
    flex-basis: 160px;
  }
  .roomProfileIdentitySlot {
    flex-basis: 254px;
  }
  .roomTableStage__overlay--floating {
    max-width: min(56%, 420px);
  }
}
@media (max-width: 1100px) {
  .roomLayout {
    grid-template-columns: minmax(0, 1fr);
  }
  .roomSidebar {
    min-height: 420px;
  }
}
@media (max-width: 860px) {
  .roomShell {
    width: calc(100vw - 8px);
    margin-top: 4px;
  }
  .roomHud {
    grid-template-columns: minmax(0, 1fr) auto;
  }
  .roomProfileIdentitySlot {
    flex-basis: 84vw;
    grid-template-columns: 1fr;
  }
  .roomSlotCard--itemIcon {
    flex-basis: 58px;
    width: 58px;
    min-height: 58px;
  }
  .roomTableStage__overlay--floating {
    max-width: calc(100% - 32px);
  }
}
@media (max-width: 620px) {
  .roomTableStage {
    min-height: 320px;
  }
  .roomTableStage__media {
    min-height: 320px;
  }
  .roomTableStage__controls {
    inset: auto 16px 16px 16px;
    transform: none;
  }
  .roomTableStage__play {
    width: 100%;
  }
  .roomTableStage__meta {
    width: calc(100% - 32px);
  }
}

@media (min-width: 1101px) {
  .roomPage {
    overflow: hidden;
  }
  .roomShell {
    height: calc(100vh - 8px);
    min-height: calc(100vh - 8px);
  }
  .roomLayout {
    min-height: 0;
    height: 100%;
  }
  .roomMain,
  .roomSidebar {
    min-height: 0;
    height: 100%;
  }
  .roomSidebar {
    overflow: hidden;
  }
}

/* =========================
   SOCIAL PHASE 1.0
   ========================= */
.socialList {
  display: grid;
  gap: 14px;
}
.socialSection {
  display: grid;
  gap: 10px;
}
.socialSection__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.socialSection__head h3 {
  margin: 0;
  color: #fff1dd;
  font-size: .92rem;
}
.socialSection__head span,
.socialMeta,
.socialEmptyState {
  color: #d8c7a8;
}
.socialUserRow {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}
.socialUserRow--tight {
  gap: 10px;
}
.socialAvatar {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: rgba(255,240,210,.12);
  box-shadow: inset 0 0 0 1px rgba(255,227,174,.14);
}
.socialAvatar--lg {
  width: 52px;
  height: 52px;
  border-radius: 16px;
}
.socialActionRow {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.socialActionRow--split {
  align-items: center;
  justify-content: space-between;
}
.socialFriendCard,
.socialRequestCard,
.socialInfoCard {
  background: rgba(15,9,7,.68);
}
.socialFriendCard__bottom {
  margin-top: 10px;
  display: grid;
  gap: 10px;
}
.socialFriendCard__bottom p,
.socialRequestCard p,
.socialInfoCard p {
  margin: 0;
}
.socialBadge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 70px;
  min-height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,244,225,.08);
  border: 1px solid rgba(255,227,174,.14);
  color: #cdbb95;
  font-size: .8rem;
}
.socialBadge.is-active {
  background: rgba(237,207,147,.2);
  color: #fff3d6;
}
.chatThreadHead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,227,174,.12);
}
.chatMessageList {
  display: grid;
  gap: 10px;
  align-content: start;
}
.chatBubble {
  max-width: 92%;
  display: grid;
  gap: 6px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,227,174,.12);
}
.chatBubble p {
  margin: 0;
  color: #fff4e7;
  white-space: pre-wrap;
  word-break: break-word;
}
.chatBubble span {
  color: #cdbb95;
  font-size: .75rem;
}
.chatBubble--own {
  justify-self: end;
  background: rgba(237,207,147,.18);
}
.chatBubble--other {
  justify-self: start;
  background: rgba(25,16,12,.82);
}
.roomSidebar__composer input:disabled,
.roomSidebar__composer .btn:disabled {
  opacity: .6;
  cursor: not-allowed;
}
@media (max-width: 860px) {
  .chatThreadHead {
    grid-template-columns: 1fr;
    justify-items: start;
  }
  .socialActionRow--split {
    align-items: stretch;
    flex-direction: column;
  }
  .socialBadge {
    width: 100%;
  }
}
.socialActionRow .btn--primary,
.chatThreadHead .btn {
  background: linear-gradient(180deg, #edcf93, #b98237);
  color: #321b08;
  border-color: transparent;
}

/* =========================
   SOCIAL PHASE 2.0
   ========================= */
.socialSubtabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.socialSubtab {
  border: 1px solid rgba(255,227,174,.14);
  background: rgba(22,14,10,.68);
  color: #efd9b1;
  border-radius: 999px;
  min-height: 40px;
  font-weight: 700;
}
.socialSubtab.is-active {
  background: linear-gradient(180deg, #edcf93, #b98237);
  color: #321b08;
  border-color: transparent;
}
.roomPublicChatList {
  gap: 12px;
}
.roomPublicMessage {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}
.roomPublicMessage__body {
  background: rgba(24,16,12,.82);
  border: 1px solid rgba(255,227,174,.12);
  border-radius: 16px;
  padding: 10px 12px;
  display: grid;
  gap: 6px;
}
.roomPublicMessage.is-own .roomPublicMessage__body {
  background: rgba(237,207,147,.18);
}
.roomPublicMessage__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: #cdbb95;
  font-size: .76rem;
}
.roomPublicMessage__body p {
  margin: 0;
  color: #fff4e7;
  white-space: pre-wrap;
  word-break: break-word;
}
.clanPanel {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(17,11,8,.72);
  border: 1px solid rgba(255,227,174,.12);
}
.clanPanel + .clanPanel {
  margin-top: 16px;
}
.clanPanel--stack {
  align-content: start;
}
.clanPanel__hero {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.clanStatGrid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
}
.clanStatCard {
  display: grid;
  gap: 6px;
  background: rgba(15,9,7,.68);
}
.clanStatCard span {
  color: #d8c7a8;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.clanStatCard strong {
  color: #fff3da;
  font-size: 1.05rem;
}
.clanGameList {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
.clanGameCard {
  background: rgba(15,9,7,.68);
}
.modalMemberList {
  display: grid;
  gap: 8px;
}
.modalMemberList__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(17,11,8,.58);
  border: 1px solid rgba(255,227,174,.1);
}
.modalMemberList__item span {
  color: #d8c7a8;
  font-size: .84rem;
}
@media (max-width: 860px) {
  .socialSubtabs {
    grid-template-columns: 1fr;
  }
  .roomPublicMessage__meta {
    flex-direction: column;
    align-items: start;
  }
  .clanPanel__hero {
    grid-template-columns: 1fr;
  }
}


.roomClanPlaceholder--inline {
  min-height: 310px;
}

.clanShareCard {
  flex: 0 0 210px;
  min-height: 132px;
  justify-content: center;
}

.clanShareCard .roomSlotCard__eyebrow {
  margin-bottom: 8px;
}

.roomProfileIdentitySlot--clan {
  flex-basis: 360px;
}


.roomClanMemberSlot {
  flex: 0 0 150px;
  min-height: 118px;
  display: grid;
  justify-items: center;
  align-content: center;
  text-align: center;
  gap: 8px;
}

.roomClanMemberSlot__avatar {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}

.roomClanMemberSlot strong {
  font-size: .95rem;
  line-height: 1.15;
}

.roomClanMemberSlot .roomSlotCard__desc {
  display: block;
  font-size: .74rem;
  opacity: .78;
}


.roomTableStage__previewFrame {
  position: absolute;
  inset: 0;
  border-radius: 26px;
  overflow: hidden;
  box-shadow: 0 16px 34px rgba(0,0,0,.24);
  background: #140f0b;
}
.roomTableStage__previewFrame iframe,
.roomTableStage__previewFrame img {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}


.socialToastHost{position:fixed;right:18px;bottom:18px;z-index:14000;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.socialToastBubble{display:flex;gap:10px;align-items:flex-start;max-width:min(360px,calc(100vw - 36px));padding:12px 14px;border-radius:16px;background:rgba(248,241,224,.98);color:#2d2115;border:1px solid rgba(0,0,0,.12);box-shadow:0 18px 40px rgba(0,0,0,.26);opacity:1;transform:translateY(0);transition:opacity .18s ease, transform .18s ease}
.socialToastBubble.is-hide{opacity:0;transform:translateY(8px)}
.socialToastBubble__avatar{width:40px;height:40px;border-radius:12px;background:#c5a35a center/cover no-repeat;flex:0 0 40px;border:1px solid rgba(0,0,0,.08)}
.socialToastBubble__title{font-weight:800;font-size:13px;margin-bottom:2px}
.socialToastBubble__body{font-size:13px;line-height:1.35;color:#4b3622}
.betPanel{display:grid;gap:10px}
.betPanel__caps{display:grid;gap:8px}
.betPanel__caps > div{display:flex;justify-content:space-between;gap:12px;font-size:13px;color:#ead7b5}
.betPanel__caps span{color:rgba(249,240,223,.72)}
.betPanel__form{display:grid;gap:10px}
.betPanel__choices{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.betPlayerCard{display:flex;align-items:center;gap:10px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:#fff;padding:10px 12px;text-align:left;cursor:pointer}
.betPlayerCard.is-selected{border-color:rgba(197,163,90,.75);background:rgba(197,163,90,.14);box-shadow:0 0 0 1px rgba(197,163,90,.28) inset}
.betPlayerCard__avatar{width:42px;height:42px;border-radius:14px;background:#c5a35a center/cover no-repeat;flex:0 0 42px}
.betPlayerCard__body{display:grid;gap:2px}
.betPlayerCard__body small{color:rgba(249,240,223,.72)}
.betPanel__row{display:grid;grid-template-columns:1fr auto;gap:8px}
.betPanel__row input,.betPanel__form input{border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:#fff;padding:10px 12px}
@media (max-width: 720px){.betPanel__choices,.betPanel__row{grid-template-columns:1fr}.socialToastHost{right:12px;left:12px;bottom:12px}.socialToastBubble{max-width:none}}
.tournamentBracket{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:16px}
.tournamentBracket__round{display:grid;gap:10px}
.tournamentBracket__round h4{margin:0;color:#f3e2bc;font-size:15px}
.tournamentMatchCard{border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);padding:10px 12px;color:#fff}
.tournamentMatchCard__time{font-size:12px;color:rgba(249,240,223,.72);margin-bottom:6px}
.tournamentMatchCard__row{display:flex;justify-content:space-between;gap:10px;align-items:center}
.tournamentParticipants{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:16px}
.tournamentParticipantCard{padding:10px 12px}
.checkChoice{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:#fff}
.checkChoice input{margin-top:2px}
.checkChoice.is-required{opacity:.88}
.modalChoiceGrid--stacked{grid-template-columns:1fr}

.roomTableVisual--tournament{display:grid;gap:16px}
.roomTableVisual__head--wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start}
.roomRailControls--wrap{display:flex;gap:10px;flex-wrap:wrap}
.tournamentRoomLead{margin:8px 0 0;color:rgba(249,240,223,.8)}
.tournamentRoomHero{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:16px 18px;background:linear-gradient(180deg, rgba(237,207,147,.14), rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.12)}
.tournamentRoomHero__statusWrap{display:grid;gap:8px}
.tournamentRoomHero__statusWrap strong{font-size:1.02rem;color:#fff8ee}
.tournamentRoomHero__chips{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.tournamentCountdownCard{display:grid;gap:4px;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);max-width:340px}
.tournamentCountdownCard.is-upcoming{background:linear-gradient(180deg, rgba(84,153,255,.16), rgba(255,255,255,.04));border-color:rgba(84,153,255,.28)}
.tournamentCountdownCard__label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#d8c4a0}
.tournamentSummaryCard{display:grid;gap:10px}
.tournamentSummaryCard__meta{display:flex;gap:8px;flex-wrap:wrap}
.tournamentSummaryCard__actions{margin-top:4px}
.tournamentJoinGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:8px}
.tournamentJoinCard{display:grid;gap:12px;padding:16px;border-radius:18px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg, rgba(84,153,255,.12), rgba(255,255,255,.03));box-shadow:0 16px 34px rgba(0,0,0,.18)}
.tournamentJoinCard__head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}
.tournamentJoinCard__head span{font-size:.82rem;color:#d8c4a0}
.tournamentJoinCard__body{display:grid;gap:10px}
.tournamentJoinCard__player{display:flex;gap:12px;align-items:center;padding:12px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04)}
.tournamentJoinCard__target{padding:10px 12px;border-radius:14px;border:1px dashed rgba(255,255,255,.18);background:rgba(255,255,255,.03);color:#f5ead3;font-size:.92rem}
.tournamentJoinCard__actions{display:flex;justify-content:flex-end}
.tournamentRoomLayout{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:16px;align-items:start}
.tournamentRoomPanel{display:grid;gap:14px;padding:16px 18px}
.tournamentRoomPanel--wide,.tournamentRoomPanel--full{min-width:0}
.tournamentRoomPanel--full{margin-top:16px}
.tournamentRewardList{display:grid;gap:10px}
.tournamentRewardCard{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:#fff}
.tournamentRewardCard span{color:#d8c4a0;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}
.tournamentRewardCard strong{font-size:1rem;color:#fff8ee}
.roomTableSection--tournament .roomTableStage{padding:20px}
@media (max-width: 980px){
  .tournamentRoomLayout{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .tournamentRoomHero{flex-direction:column;align-items:flex-start}
}
.sidePane__group{display:grid;gap:10px;margin-bottom:18px}
.tournamentCreateForm{display:grid;gap:18px;min-width:0}
.tournamentCreateGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.tournamentCreateGrid--top{align-items:end}
.tournamentCreateGrid label{display:grid;gap:8px;min-width:0}
.tournamentCreateDateCard{display:grid;gap:10px;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.tournamentScheduleCard{display:grid;gap:12px;padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.tournamentScheduleCard.is-custom{background:linear-gradient(180deg, rgba(84,153,255,.12), rgba(255,255,255,.04));border-color:rgba(84,153,255,.22)}
.tournamentScheduleCard__head{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}
.tournamentScheduleSwitch{display:flex;gap:8px;flex-wrap:wrap}
.tournamentDateTimeGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.tournamentDateTimeGrid label{display:grid;gap:6px}
.tournamentDateTimeGrid.is-hidden{display:none}
.tournamentCreateForm__checkbox{align-self:stretch;min-height:46px;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.tournamentCreateForm__actions{position:sticky;bottom:0;background:linear-gradient(180deg, rgba(13,11,10,0), rgba(13,11,10,.95) 35%);padding-top:8px}
.tournamentCreateIntro{display:grid;gap:8px;padding:16px 18px;border-radius:18px;background:linear-gradient(180deg, rgba(84,153,255,.15), rgba(255,255,255,.04));border:1px solid rgba(140,186,255,.18)}
.tournamentCreateIntro p{margin:0;color:rgba(255,248,238,.82)}
.tournamentCreateFeedback{display:grid;gap:6px;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);font-size:.92rem}
.tournamentCreateFeedback.is-valid{border-color:rgba(107,214,145,.38);background:rgba(107,214,145,.10);color:#d7ffe4}
.tournamentCreateFeedback.is-invalid{border-color:rgba(255,123,123,.32);background:rgba(255,123,123,.09);color:#ffd8d8}
.tournamentMatchPlanner,.tournamentPairGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.tournament-match-editor,.tournamentPairCard{display:grid;gap:12px;padding:16px;border-radius:20px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));min-width:0;box-shadow:0 14px 34px rgba(0,0,0,.18)}
.tournament-match-editor__head,.tournamentPairCard__head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}
.tournament-match-editor__head span,.tournamentPairCard__head span{font-size:.8rem;color:#d8c4a0}
.tournament-match-editor__vs,.tournamentPairCard__vs{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:12px;align-items:center}
.tournament-match-editor__center,.tournamentPairCard__separator{width:44px;height:44px;display:grid;place-items:center;border-radius:999px;background:rgba(84,153,255,.14);border:1px solid rgba(84,153,255,.28);font-weight:800;letter-spacing:.08em;color:#dff1ff}
.tournamentParticipantPick{display:grid;gap:8px;min-width:0}
.tournamentParticipantPick__label{font-size:.78rem;color:#d8c4a0}
.tournamentParticipantPick__card,.tournamentPairCard__side{display:flex;gap:12px;align-items:center;padding:12px 13px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);min-width:0}
.tournamentParticipantPick__card.is-open,.tournamentPairCard__side.is-empty{border-style:dashed;opacity:.82}
.tournamentParticipantPick__avatar{width:46px;height:46px;border-radius:999px;display:grid;place-items:center;background:linear-gradient(135deg, rgba(84,153,255,.46), rgba(45,109,214,.2));border:1px solid rgba(131,181,255,.3);font-weight:800;color:#fff}
.tournamentParticipantPick__avatar.is-opponent{background:linear-gradient(135deg, rgba(244,184,90,.35), rgba(171,97,46,.18));border-color:rgba(244,184,90,.28)}
.tournament-match-editor__invite-hint{min-height:20px;font-size:.82rem;color:#d8c4a0;margin-top:2px}
.tournament-match-editor__invite-hint.is-success{color:#9de0b6}
.tournament-match-editor__invite-hint.is-error{color:#ff9a9a}
.tournament-match-editor__invite-hint.is-pending{color:#d8c4a0}
.tournament-match-editor select,.tournament-match-editor input,.tournament-future-round-card input{min-width:0;width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:#fff;padding:10px 12px}
.tournament-match-editor__invite-input.is-hidden{display:none}
.tournament-match-editor__timeWrap.is-hidden{display:none}
.tournamentFutureGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.tournament-future-round-card{display:grid;gap:12px;padding:16px;border-radius:18px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.tournament-future-round-card__head{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:flex-start}
.tournament-round-editor{display:grid;gap:8px}
.tournament-round-editor.is-disabled{opacity:.7}
.tournamentSlotGrid{display:grid;grid-template-columns:1fr;gap:12px}
.tournamentParticipants{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.roomTableVisual--tournament,.tournamentRoomLayout,.tournamentRoomPanel,.tournamentBracket,.tournamentSlotGrid,.tournamentMatchPlanner,.tournamentFutureGrid,.tournamentParticipants,.tournamentPairGrid{min-width:0}
@media (max-width: 980px){
  .tournamentCreateGrid,.tournamentMatchPlanner,.tournamentFutureGrid,.tournamentPairGrid,.tournamentJoinGrid{grid-template-columns:1fr}
  .roomTableSection--tournament .roomTableStage{padding:14px}
}
@media (max-width: 720px){
  .modalSection{padding:12px}
  .tournamentRoomHero{padding:14px}
  .tournamentRoomPanel{padding:14px}
  .tournamentBracket{grid-template-columns:1fr}
  .tournamentMatchCard__row{display:grid;grid-template-columns:1fr;justify-items:flex-start}
}


.tournamentTypeSwitch{display:flex;gap:8px;flex-wrap:wrap}
.tournamentTypeChip{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:#f5ead3;font-size:.84rem;cursor:pointer;transition:.18s ease}
.tournamentTypeChip input{position:absolute;inset:0;opacity:0;cursor:pointer}
.tournamentTypeChip.is-active{background:linear-gradient(180deg, rgba(84,153,255,.18), rgba(255,255,255,.05));border-color:rgba(84,153,255,.35);box-shadow:0 10px 20px rgba(18,31,66,.18)}
.tournament-match-editor__opponent-select.is-hidden{display:none}
.tournamentRewardCard{grid-template-columns:auto auto;display:grid}
.tournamentRewardCard small{grid-column:1 / -1;color:#9fc4ff;font-size:.8rem;margin-top:4px}
.tournamentSummaryCard__queue{padding:10px 12px;border-radius:14px;background:rgba(84,153,255,.10);border:1px solid rgba(84,153,255,.22);color:#e6f1ff;font-size:.9rem}
.tournamentQueueBanner{display:grid;gap:6px;padding:14px 16px;background:linear-gradient(180deg, rgba(84,153,255,.14), rgba(255,255,255,.03));border:1px solid rgba(84,153,255,.26)}
.tournamentQueueBanner p{margin:0;color:rgba(245,234,211,.88)}
.tournamentCurrentMatch{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:12px;align-items:center}
.tournamentCurrentMatch__player{display:grid;gap:4px;padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05)}
.tournamentCurrentMatch__player span{color:#d8c4a0;font-size:.85rem}
.tournamentCurrentMatch__vs{width:54px;height:54px;border-radius:999px;display:grid;place-items:center;background:rgba(84,153,255,.14);border:1px solid rgba(84,153,255,.26);font-weight:800;color:#dff1ff}
@media (max-width: 1500px){
  .tournamentMatchPlanner,.tournamentFutureGrid,.tournamentPairGrid,.tournamentJoinGrid,.tournamentParticipants,.tournamentBracket{display:flex;overflow-x:auto;gap:14px;scroll-snap-type:x proximity;padding-bottom:10px}
  .tournamentMatchPlanner > *, .tournamentFutureGrid > *, .tournamentPairGrid > *, .tournamentJoinGrid > *, .tournamentParticipants > *, .tournamentBracket > *{min-width:min(78vw,420px);scroll-snap-align:start;flex:0 0 auto}
}
@media (max-width: 780px){
  .tournamentCurrentMatch{grid-template-columns:1fr;justify-items:stretch}
  .tournamentCurrentMatch__vs{margin:0 auto}
  .tournamentCreateGrid{grid-template-columns:1fr}
  .tournamentDateTimeGrid{grid-template-columns:1fr}
  .tournamentRoomHero__chips{overflow-x:auto;white-space:nowrap;flex-wrap:nowrap;padding-bottom:6px}
}


.tournamentCreateGrid--single{grid-template-columns:1fr !important;}
.tournamentCreateGrid--single > *{width:100%;}
.tournamentDateTimeGrid--modern label{padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));}
.tournamentDateTimeGrid--modern input{margin-top:4px;font-size:1rem;}
@media (max-width: 1500px){
  .tournamentMatchPlanner > *, .tournamentFutureGrid > *, .tournamentPairGrid > *, .tournamentJoinGrid > *, .tournamentParticipants > *, .tournamentBracket > *{min-width:min(82vw,460px);scroll-snap-align:start;flex:0 0 auto;}
}


.tournamentFixedStartBadge{padding:12px 14px;border-radius:14px;border:1px solid rgba(140,186,255,.24);background:linear-gradient(180deg, rgba(84,153,255,.16), rgba(255,255,255,.04));color:#eef6ff}
.tournamentRangeValue{display:grid;gap:4px;margin-top:8px;color:#f5ead3}
.tournamentRangeValue strong{font-size:1rem;color:#fff8ee}
.tournamentDateTimeGrid--modern select,.tournamentDateTimeGrid--modern input{margin-top:4px;font-size:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:#fff;padding:10px 12px}
.tournamentRoomPanel--wide{overflow:hidden}
.tournamentPairGrid,.tournamentMatchPlanner,.tournamentFutureGrid,.tournamentParticipants,.tournamentBracket,.tournamentJoinGrid{align-items:stretch}
.tournamentPairGrid::-webkit-scrollbar,.tournamentMatchPlanner::-webkit-scrollbar,.tournamentFutureGrid::-webkit-scrollbar,.tournamentParticipants::-webkit-scrollbar,.tournamentBracket::-webkit-scrollbar,.tournamentJoinGrid::-webkit-scrollbar{height:10px}
.tournamentPairGrid::-webkit-scrollbar-thumb,.tournamentMatchPlanner::-webkit-scrollbar-thumb,.tournamentFutureGrid::-webkit-scrollbar-thumb,.tournamentParticipants::-webkit-scrollbar-thumb,.tournamentBracket::-webkit-scrollbar-thumb,.tournamentJoinGrid::-webkit-scrollbar-thumb{background:rgba(237,207,147,.28);border-radius:999px}


.tournamentMatchPlanner,.tournamentFutureGrid,.tournamentParticipants,.tournamentBracket,.tournamentPairGrid,.tournamentJoinGrid{
  display:flex;
  overflow-x:auto;
  gap:14px;
  scroll-snap-type:x proximity;
  padding-bottom:10px;
  align-items:stretch;
}
.tournamentMatchPlanner > *, .tournamentFutureGrid > *, .tournamentParticipants > *, .tournamentBracket > *, .tournamentPairGrid > *, .tournamentJoinGrid > *{
  min-width:min(86vw,460px);
  flex:0 0 auto;
  scroll-snap-align:start;
}
.tournamentRoomPanel,.roomTableStage,.roomTableVisual--tournament{min-width:0;overflow:hidden;}
.tournamentDateTimeGrid--modern input[type="date"], .tournamentDateTimeGrid--modern input[type="time"], .tournamentDateTimeGrid--modern select{
  appearance:none;
  -webkit-appearance:none;
  background:linear-gradient(180deg, rgba(24,26,38,.92), rgba(11,14,25,.92));
  border:1px solid rgba(170,196,255,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 10px 24px rgba(0,0,0,.18);
}
.tournamentDateTimeGrid--modern label{
  backdrop-filter: blur(8px);
}
@media (min-width: 1200px){
  .tournamentMatchPlanner > *, .tournamentFutureGrid > *, .tournamentParticipants > *, .tournamentBracket > *, .tournamentPairGrid > *, .tournamentJoinGrid > *{min-width:420px;}
}

.konryGuideCard{
  margin-bottom:18px;
  border:1px solid rgba(237,207,147,.18);
  background:linear-gradient(180deg, rgba(38,27,20,.96), rgba(19,14,12,.98));
  box-shadow:0 20px 42px rgba(0,0,0,.28);
}
.konryGuideCard__inner{
  display:grid;
  grid-template-columns:120px minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.konryGuideCard__mascot{
  position:relative;
  min-height:120px;
  display:grid;
  place-items:center;
}
.konryGuideCard__mascotHalo{
  position:absolute;
  inset:18px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(237,207,147,.34), rgba(237,207,147,0));
  filter:blur(2px);
}
.konryGuideCard__mascotFace{
  position:relative;
  width:78px;
  height:78px;
  border-radius:24px;
  display:grid;
  place-items:center;
  font-size:2rem;
  font-weight:800;
  color:#2b1d0e;
  background:linear-gradient(180deg, #f1d798, #c99a49);
  box-shadow:0 12px 26px rgba(0,0,0,.22), inset 0 2px 0 rgba(255,255,255,.5);
}
.konryGuideCard__body{display:grid;gap:14px;min-width:0;}
.konryGuideCard__meta{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,180px));
  gap:12px;
}
.konryGuideStat{
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  display:grid;
  gap:4px;
}
.konryGuideStat span{font-size:.78rem;color:#d3bea0;text-transform:uppercase;letter-spacing:.06em;}
.konryGuideStat strong{font-size:1.05rem;color:#fff7e7;}
.konryGuideSections{display:grid;gap:14px;}
.konryGuideSection{
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  display:grid;
  gap:12px;
}
.konryGuideSection__head{display:flex;justify-content:space-between;gap:14px;align-items:start;}
.konryGuideSection__head h3{margin:0;font-size:1.05rem;color:#fff4df;}
.konrySectionBadge,
.konryStepBadge,
.konryStepReward{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(237,207,147,.12);
  border:1px solid rgba(237,207,147,.18);
  color:#ffe9bd;
  font-size:.82rem;
  white-space:nowrap;
}
.konryStepBadge.is-done{
  background:rgba(82,171,120,.16);
  border-color:rgba(82,171,120,.26);
  color:#d6ffe0;
}
.konryStepList{display:grid;gap:12px;}
.konryStepCard{
  padding:14px;
  border-radius:16px;
  background:rgba(10,10,10,.18);
  border:1px solid rgba(255,255,255,.08);
  display:grid;
  gap:10px;
}
.konryStepCard.is-complete{
  border-color:rgba(82,171,120,.28);
  box-shadow:inset 0 0 0 1px rgba(82,171,120,.14);
}
.konryStepCard__top,
.konryStepCard__actions{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}
.konryStepCard strong{display:block;color:#fff8e9;margin-bottom:4px;}
.konryStepHint{
  margin:0;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(237,207,147,.08);
  color:#f5e4c1;
  font-size:.92rem;
}
.konryWelcomeBox{
  display:grid;
  grid-template-columns:72px minmax(0,1fr);
  gap:14px;
  margin:18px 0;
  padding:16px;
  border-radius:20px;
  border:1px solid rgba(237,207,147,.16);
  background:linear-gradient(180deg, rgba(43,31,22,.92), rgba(24,17,13,.96));
}
.konryWelcomeBox__badge{
  width:72px;
  height:72px;
  border-radius:22px;
  display:grid;
  place-items:center;
  font-size:1.8rem;
  font-weight:800;
  color:#2b1d0e;
  background:linear-gradient(180deg, #f1d798, #c99a49);
  box-shadow:0 10px 24px rgba(0,0,0,.2);
}
@media (max-width: 980px){
  .konryGuideCard__inner,
  .konryWelcomeBox{
    grid-template-columns:1fr;
  }
  .konryGuideCard__mascot{min-height:0;justify-content:start;}
  .konryGuideCard__meta{grid-template-columns:1fr 1fr;}
  .konryStepCard__top,
  .konryStepCard__actions,
  .konryGuideSection__head{flex-direction:column;align-items:stretch;}
}
@media (max-width: 640px){
  .konryGuideCard__meta{grid-template-columns:1fr;}
}


/* ===== Beta feedback + Konry drawer v3.12.0 ===== */
.authLinks--stacked{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.roomDrawer{position:fixed;inset:0;z-index:80;display:grid;grid-template-columns:minmax(0,1fr);pointer-events:auto}
.roomDrawer.is-hidden{display:none}
.roomDrawer__backdrop{position:absolute;inset:0;background:rgba(4,5,10,.6);backdrop-filter:blur(2px)}
.roomDrawer__panel{position:relative;margin:14px 14px 14px auto;width:min(620px,calc(100vw - 20px));height:calc(100vh - 28px);overflow:auto;z-index:1;border-radius:28px;border:1px solid rgba(237,207,147,.18);box-shadow:0 28px 60px rgba(0,0,0,.42)}
.roomDrawer__head{display:flex;justify-content:space-between;gap:16px;align-items:start;padding:18px 18px 0}
.roomDrawer__head h2{margin:0;color:#fff4df}
.roomDrawer .konryGuideCard{margin:0;border:0;background:transparent;box-shadow:none}
.feedbackForm__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.feedbackForm .field--full{grid-column:1 / -1}
.feedbackForm textarea{min-height:88px;resize:vertical}
.roomModal__foot{display:flex;justify-content:flex-end;gap:10px;padding-top:8px}
.feedbackReportCard{display:grid;gap:12px;padding:14px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.feedbackReportCard__top{display:flex;justify-content:space-between;gap:12px;align-items:start}
.feedbackReportCard__meta{display:flex;flex-wrap:wrap;gap:8px}
.feedbackReportCard__pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:rgba(237,207,147,.12);border:1px solid rgba(237,207,147,.18);color:#ffe9bd;font-size:.76rem}
.feedbackReportCard__pill.is-read{background:rgba(102,165,255,.14);border-color:rgba(102,165,255,.22);color:#dfeeff}
.feedbackReportCard__pill.is-resolved{background:rgba(82,171,120,.16);border-color:rgba(82,171,120,.26);color:#d6ffe0}
.feedbackReportCard__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.feedbackReportCard__box{padding:10px 12px;border-radius:14px;background:rgba(0,0,0,.18)}
.feedbackReportCard__box strong{display:block;color:#fff1d8;margin-bottom:4px}
.feedbackReportCard__actions{display:flex;flex-wrap:wrap;gap:10px}
@media (max-width: 860px){
  .roomDrawer__panel{width:calc(100vw - 12px);height:calc(100vh - 12px);margin:6px}
  .feedbackForm__grid,.feedbackReportCard__grid{grid-template-columns:1fr}
  .roomDrawer__head{flex-direction:column;align-items:stretch}
}


/* ===== v3.12.2 Zapařníček + feedback refinement ===== */
.roomHud__stats {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
.roomHudStat--guide {
  padding: 10px;
  background: linear-gradient(180deg, rgba(236,188,95,.20), rgba(255,244,225,.08));
}
.roomMascotButton {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 72px;
  border: 0;
  border-radius: 14px;
  padding: 10px 12px;
  display: grid;
  gap: 4px;
  align-content: center;
  justify-items: start;
  background: transparent;
  color: #fff6e5;
  text-align: left;
  cursor: pointer;
}
.roomMascotButton strong { font-size: 1.08rem; }
.roomMascotButton small { color: #f4dcb0; font-size: .8rem; line-height: 1.3; }
.roomMascotButton__label {
  color: #d8c4a0;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: .7rem;
}
.roomMascotButton.has-pending {
  animation: zaparnicekPulse 1.8s ease-in-out infinite;
}
.roomMascotButton.has-pending::after {
  content: '';
  position: absolute;
  inset: 6px;
  border-radius: 12px;
  border: 1px solid rgba(255,227,174,.32);
  pointer-events: none;
}
@keyframes zaparnicekPulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 0 0 rgba(236,188,95,0); }
  50% { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(236,188,95,.18); }
}
.feedbackChoiceField {
  border: 0;
  margin: 0;
  padding: 0;
}
.feedbackSentimentToggle {
  display: flex;
  gap: 12px;
}
.feedbackSentimentBtn {
  min-width: 72px;
  min-height: 56px;
  border-radius: 16px;
  border: 1px solid rgba(255,227,174,.18);
  background: rgba(31,18,12,.76);
  color: #fff3dc;
  font-size: 2rem;
  font-weight: 800;
  cursor: pointer;
}
.feedbackSentimentBtn.is-active {
  background: linear-gradient(180deg, #edcf93, #b98237);
  color: #321b08;
}
.feedbackScoreWrap {
  display: grid;
  gap: 8px;
}
.feedbackScoreWrap input[type="range"] {
  width: 100%;
}
.feedbackForm__grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 1240px) {
  .roomHud__stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
  .roomHud__stats { grid-template-columns: 1fr; }
}


/* ===== Safe auth trust UI v3.12.7 ===== */
.authViewport {
  width: min(100%, 100vw);
  padding-block: 36px;
}
.authSurface {
  width: min(440px, 100%);
  padding: 0;
  overflow: hidden;
}
.authSurface--wide {
  width: min(480px, 100%);
}
.authSurface__header {
  padding: 26px 28px 18px;
  border-bottom: 1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
}
.authSurface__body {
  padding: 22px 28px 26px;
}
.authBrandRow {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.authBrandMark {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #ecf2ff, #9fb9ff);
  color: #081122;
  font-weight: 900;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5);
}
.authBrandText strong {
  display: block;
  font-size: 1rem;
  color: var(--text);
}
.authBrandText span {
  display: block;
  font-size: .82rem;
  color: var(--muted);
  margin-top: 2px;
}
.authTitle {
  font-size: clamp(1.6rem, 3.2vw, 2.2rem);
  margin-bottom: 10px;
}
.authLead {
  max-width: 46ch;
  margin-bottom: 0;
}
.authTabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: 100%;
}
.authFormGrid {
  grid-template-columns: 1fr;
}
.authPrimaryAction {
  width: 100%;
  min-height: 48px;
}
.authActionsRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 2px;
}
.authActionsRow a,
.authSubtleLink {
  color: var(--accent-2);
  text-decoration: none;
  font-size: .95rem;
}
.authActionsRow a:hover,
.authSubtleLink:hover {
  text-decoration: underline;
}
.authGhostButton {
  background: transparent;
  border: 0;
  padding: 0;
  color: var(--accent-2);
  font: inherit;
  cursor: pointer;
}
.authGhostButton:hover {
  text-decoration: underline;
}
.authMessage {
  min-height: 24px;
  margin-top: 10px;
}
.authTrustPanel {
  margin-top: 18px;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,.02);
}
.authTrustPanel h2 {
  font-size: 1rem;
  margin-bottom: 10px;
}
.authTrustList {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.authTrustList li {
  position: relative;
  padding-left: 18px;
  color: var(--muted);
}
.authTrustList li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent-2);
}
.authStatusNote {
  margin-top: 12px;
  font-size: .92rem;
  color: var(--muted);
}
.authFooter {
  margin-top: 18px;
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  font-size: .88rem;
  color: var(--muted);
}
.authFooter a {
  color: var(--muted);
  text-decoration: none;
}
.authFooter a:hover {
  color: var(--accent-2);
}
.authInlineInfo {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  color: var(--muted);
  font-size: .92rem;
}
.authInlineInfo strong {
  color: var(--text);
}
@media (max-width: 680px) {
  .authViewport {
    padding-block: 16px;
  }
  .authSurface__header,
  .authSurface__body {
    padding-left: 18px;
    padding-right: 18px;
  }
  .authActionsRow {
    align-items: start;
    flex-direction: column;
  }
}


/* ===== Admin login minimal UI v3.13.1 ===== */
.adminLoginViewport {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding-inline: 16px;
}
.adminLoginCard {
  width: min(100%, 420px);
}
.adminLoginHeader {
  padding-bottom: 22px;
}
.adminLoginBrandRow {
  margin-bottom: 22px;
}
.adminLoginTitle {
  margin-bottom: 0;
  letter-spacing: -.02em;
}
.adminLoginBody {
  display: grid;
  gap: 12px;
  padding-top: 24px;
}
.adminLoginForm {
  display: block;
}
.adminLoginAction {
  min-height: 50px;
  font-size: 1rem;
}
.adminLoginMessage {
  min-height: 22px;
  margin-top: 0;
  text-align: center;
}
@media (max-width: 560px) {
  .adminLoginHeader,
  .adminLoginBody {
    padding-left: 22px;
    padding-right: 22px;
  }
}


.authRateLimitHint {
  margin-top: 6px;
  margin-bottom: 0;
  font-size: .92rem;
  color: var(--muted);
}
.authRateLimitHint[data-blocked="1"] { color: #ffd08f; }
.securityPageCard { width: min(920px, 100%); }
.securityPageBody { display: grid; gap: 14px; }
.securityPageBody .authTrustPanel { margin-top: 0; }
.adminLoginFooter { margin-top: 18px; }

/* ===== Clean trust-first auth + admin UI v3.17 ===== */
.authBody--minimal {
  background:
    radial-gradient(circle at top, rgba(143,179,255,.12), transparent 28%),
    linear-gradient(180deg, #0b1020 0%, #090d18 100%);
}
.minimalAuth {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}
.minimalAuth__card {
  width: min(460px, 100%);
  padding: 28px 28px 22px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(10,14,24,.88);
  box-shadow: 0 28px 60px rgba(0,0,0,.45);
  display: grid;
  gap: 18px;
}
.minimalAuth__card--admin { width: min(420px, 100%); }
.minimalAuth__brand {
  text-align: center;
  font-size: .85rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(238,242,255,.68);
}
.minimalAuth__tabs {
  width: fit-content;
  justify-self: center;
}
.minimalAuth__header {
  display: grid;
  gap: 6px;
  text-align: center;
}
.minimalAuth__title {
  margin: 0;
  font-size: clamp(1.6rem, 3vw, 2rem);
}
.minimalAuth__lead {
  margin: 0;
  color: rgba(238,242,255,.62);
  font-size: .96rem;
}
.minimalAuth__form {
  margin: 0;
}
.minimalAuth__grid {
  grid-template-columns: 1fr;
}
.minimalAuth__submit {
  width: 100%;
  min-height: 48px;
}
.minimalAuth__links {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: .92rem;
}
.minimalAuth__linkButton,
.authGhostButton.minimalAuth__linkButton {
  border: 0;
  background: none;
  color: var(--accent-2);
  padding: 0;
}
.minimalAuth__message,
.minimalAuth__hint {
  margin: 0;
  text-align: center;
  min-height: 22px;
}
.minimalAuth__footer {
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 14px;
  text-align: center;
  font-size: .9rem;
}
.adminBody {
  background:
    radial-gradient(circle at top left, rgba(143,179,255,.10), transparent 18%),
    linear-gradient(180deg, #0a0f19 0%, #0d1321 100%);
}
.adminWorkspace {
  width: min(1440px, calc(100% - 32px));
  margin: 24px auto 40px;
  display: grid;
  gap: 18px;
}
.adminShellTop {
  padding: 24px 28px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
}
.adminShellTop__intro {
  display: grid;
  gap: 6px;
}
.adminShellTop__intro p:last-child {
  margin: 0;
  max-width: 760px;
}
.adminGlobalMessage {
  margin: 0;
  min-height: 24px;
}
.adminOverviewGrid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
}
.adminOverviewCard,
.adminPanel,
.adminSectionNav {
  padding: 20px;
}
.adminOverviewCard__head,
.adminPanel__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 18px;
}
.adminPanel__head--stack {
  display: grid;
  gap: 14px;
}
.adminMetricGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.adminMetricCard {
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  display: grid;
  gap: 8px;
}
.adminMetricCard span,
.adminFactBox span {
  color: rgba(238,242,255,.58);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.adminMetricCard strong,
.adminFactBox strong {
  font-size: 1.2rem;
  color: #fff;
}
.adminMetricCard small,
.adminFactBox small {
  color: rgba(238,242,255,.58);
}
.adminServerFacts {
  display: grid;
  gap: 16px;
}
.adminServerFacts__grid,
.adminTimelineGrid,
.adminMetaGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.adminMetaGrid--wide { grid-template-columns: 1fr; }
.adminFactBox,
.adminTimelinePanel {
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  display: grid;
  gap: 8px;
}
.adminTimelinePanel h3 {
  margin: 0;
  font-size: 1rem;
}
.adminTimelineList {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.adminTimelineList li {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(0,0,0,.18);
  display: grid;
  gap: 4px;
}
.adminStatusPill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .74rem;
  border: 1px solid rgba(255,255,255,.08);
  margin-right: 6px;
}
.adminStatusPill.is-ok {
  background: rgba(114,215,155,.14);
  color: #aef0c7;
}
.adminStatusPill.is-off {
  background: rgba(255,143,143,.12);
  color: #ffc0c0;
}
.adminTabs--clean {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0;
  background: none;
  border: 0;
}
.adminTabs--clean .tab {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 12px 16px;
}
.adminTabs--clean .tab.is-active {
  background: rgba(143,179,255,.15);
  color: #fff;
  border-color: rgba(143,179,255,.38);
}
.adminUsersLayout {
  display: grid;
  grid-template-columns: 340px minmax(0, 1fr);
  gap: 18px;
}
.adminUsersMain {
  display: grid;
  gap: 18px;
}
.adminList--compact {
  max-height: 720px;
  overflow: auto;
  padding-right: 4px;
}
.adminPanel--usersList { min-height: 0; }
.adminSearchForm { margin: 0; }
.adminFormGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.adminFormGrid__actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
}
.buttonStack--responsive {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
@media (max-width: 1080px) {
  .adminOverviewGrid,
  .adminUsersLayout,
  .adminServerFacts__grid,
  .adminTimelineGrid,
  .adminMetaGrid,
  .adminFormGrid,
  .adminMetricGrid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 640px) {
  .minimalAuth { padding: 16px; }
  .minimalAuth__card { padding: 22px 18px 18px; }
  .minimalAuth__links { flex-direction: column; }
  .adminWorkspace { width: min(100%, calc(100% - 20px)); margin: 16px auto 28px; }
  .adminShellTop,
  .adminOverviewCard,
  .adminPanel,
  .adminSectionNav { padding: 16px; }
  .adminShellTop { flex-direction: column; }
}


/* ===== Auth/admin refinement v3.18 ===== */
.srOnly {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.minimalAuth--loginRefined .minimalAuth__card,
.minimalAuth__card--loginRefined {
  width: min(520px, 100%);
  gap: 14px;
}
.minimalAuth__header--compact {
  display: none;
}
.field--authMinimal input,
.minimalAuth__grid input {
  min-height: 56px;
  box-sizing: border-box;
}
.minimalAuth__grid input::placeholder {
  color: rgba(238,242,255,.52);
}
.minimalAuth__links--centered {
  justify-content: space-between;
  gap: 16px;
}
.minimalAuth__message:empty,
.minimalAuth__hint:empty {
  display: none;
}
.minimalAuth__hint {
  min-height: 0;
  font-size: .9rem;
  color: rgba(238,242,255,.6);
}
.minimalAuth__message {
  min-height: 0;
}
.adminWorkspace--refined {
  width: min(1540px, calc(100% - 32px));
  gap: 16px;
}
.adminTopbar {
  padding: 18px 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
}
.adminTopbar__brand {
  display: grid;
  gap: 4px;
}
.adminTopbar__brand h1 { margin: 0; font-size: 1.45rem; }
.adminTopbar__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}
.adminCommandDeck {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  padding: 16px;
}
.adminCommandDeck__item {
  appearance: none;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 18px;
  text-align: left;
  display: grid;
  gap: 6px;
  cursor: pointer;
}
.adminCommandDeck__item strong { font-size: 1rem; }
.adminCommandDeck__item span { color: rgba(238,242,255,.62); }
.adminCommandDeck__item:hover { border-color: rgba(143,179,255,.32); background: rgba(143,179,255,.08); }
.adminDashboardGrid {
  display: grid;
  grid-template-columns: 1.6fr .9fr;
  gap: 16px;
}
.adminDashboardPanel { padding: 18px; }
.adminDashboardPanel--span2 { min-width: 0; }
.adminDashboardPanel__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 16px;
}
.adminMainLayout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.adminSidebar {
  padding: 18px;
  position: sticky;
  top: 18px;
  display: grid;
  gap: 22px;
}
.adminSidebar__group {
  display: grid;
  gap: 12px;
}
.adminSidebar__group h2 {
  margin: 0;
  font-size: .98rem;
}
.adminTabs--sidebar {
  display: grid;
  gap: 8px;
  background: none;
  border: 0;
  padding: 0;
}
.adminTabs--sidebar .tab {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 12px 14px;
}
.adminTabs--sidebar .tab.is-active {
  background: rgba(143,179,255,.14);
  border-color: rgba(143,179,255,.38);
}
.buttonStack--vertical { display: grid; gap: 10px; }
.adminContentStack { display: grid; gap: 16px; }
.adminUsersLayout--refined {
  grid-template-columns: 360px minmax(0, 1fr);
}
.adminMetaGrid--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.adminPanel,
.adminDashboardPanel,
.adminSidebar,
.adminTopbar,
.adminCommandDeck {
  border-radius: 22px;
  background: rgba(10,14,24,.88);
  border: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 22px 60px rgba(0,0,0,.26);
}
.adminPanel__head h2,
.adminDashboardPanel__head h2,
.adminSidebar__group h2 { margin-bottom: 4px; }
.adminPanel__head p,
.adminDashboardPanel__head p { margin: 0; }
@media (max-width: 1180px) {
  .adminCommandDeck,
  .adminDashboardGrid,
  .adminMainLayout,
  .adminUsersLayout--refined,
  .adminMetaGrid--three {
    grid-template-columns: 1fr;
  }
  .adminSidebar { position: static; }
}
@media (max-width: 640px) {
  .minimalAuth__card--loginRefined { width: min(100%, 100%); }
  .minimalAuth__links--centered { flex-direction: column; align-items: stretch; }
  .adminTopbar { flex-direction: column; align-items: stretch; }
  .adminTopbar__actions { justify-content: stretch; }
}

/* ===== Admin studio refinement v3.19 ===== */
.adminBody--studio {
  background:
    radial-gradient(circle at top left, rgba(90,140,255,.12), transparent 20%),
    radial-gradient(circle at right top, rgba(255,255,255,.04), transparent 22%),
    linear-gradient(180deg, #0b0d12 0%, #10131a 100%);
  min-height: 100vh;
}
.adminStudioShell {
  width: min(1700px, calc(100% - 32px));
  margin: 18px auto 28px;
  display: grid;
  grid-template-columns: 270px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.adminRail,
.adminCanvasHeader,
.adminSectionStrip,
.adminHeroPanel,
.adminStagePanel {
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(15, 18, 24, .86);
  box-shadow: 0 22px 60px rgba(0,0,0,.24);
  backdrop-filter: blur(10px);
}
.adminRail {
  position: sticky;
  top: 18px;
  min-height: calc(100vh - 36px);
  padding: 22px 18px;
  display: grid;
  gap: 22px;
  align-content: start;
}
.adminRail__brand {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.adminRail__coin {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #8fb3ff, #6d93ff);
  color: #081122;
  font-weight: 800;
  font-size: 1.1rem;
}
.adminRail__brand h1 { margin: 0; font-size: 1.25rem; }
.adminRail__group { display: grid; gap: 12px; }
.adminRail__group--danger {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.adminRail__label {
  margin: 0;
  color: rgba(238,242,255,.55);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .74rem;
}
.adminTabs--rail {
  display: grid;
  gap: 8px;
  padding: 0;
  background: transparent;
  border: 0;
}
.adminTabs--rail .tab {
  text-align: left;
  width: 100%;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  background: rgba(255,255,255,.03);
  color: rgba(238,242,255,.78);
}
.adminTabs--rail .tab.is-active {
  background: rgba(143,179,255,.14);
  border-color: rgba(143,179,255,.32);
  color: #fff;
}
.adminRailLinks { display: grid; gap: 8px; }
.adminRailLink {
  appearance: none;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: rgba(238,242,255,.76);
  padding: 8px 2px;
  text-align: left;
  cursor: pointer;
}
.adminRailLink:hover { color: #fff; }
.adminCanvas {
  display: grid;
  gap: 16px;
  min-width: 0;
}
.adminCanvasHeader {
  padding: 22px 24px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
}
.adminCanvasHeader__main {
  display: grid;
  gap: 14px;
}
.adminCanvasHeader__row {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(238,242,255,.72);
}
.adminCanvasHeader__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #8fb3ff;
  box-shadow: 0 0 0 4px rgba(143,179,255,.12);
}
.adminCanvasHeader__crumb { font-weight: 600; }
.adminCanvasHeader h2 { margin: 0; font-size: 1.7rem; }
.adminCanvasHeader__copy {
  margin: 6px 0 0;
  max-width: 58ch;
  color: rgba(238,242,255,.64);
}
.adminCanvasHeader__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}
.adminSectionStrip {
  padding: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.adminSectionStrip__item {
  appearance: none;
  border: 1px solid transparent;
  border-radius: 18px;
  background: rgba(255,255,255,.02);
  color: var(--text);
  padding: 16px 18px;
  text-align: left;
  display: grid;
  gap: 4px;
  cursor: pointer;
}
.adminSectionStrip__item strong { font-size: 1rem; }
.adminSectionStrip__item span { color: rgba(238,242,255,.58); font-size: .92rem; }
.adminSectionStrip__item:hover {
  background: rgba(143,179,255,.08);
  border-color: rgba(143,179,255,.22);
}
.adminHeroGrid {
  display: grid;
  grid-template-columns: 1.35fr .95fr;
  gap: 16px;
}
.adminHeroPanel { padding: 20px; min-width: 0; }
.adminHeroPanel__head { margin-bottom: 16px; }
.adminHeroPanel__head h3 { margin: 2px 0 0; font-size: 1.2rem; }
.adminPaneStack { display: grid; gap: 16px; }
.adminAccountsLayout {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.adminAccountsContent { display: grid; gap: 16px; min-width: 0; }
.adminSupportGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.adminStagePanel { padding: 20px; min-width: 0; }
.adminStagePanel--full { grid-column: 1 / -1; }
.adminStagePanel--fullHeight { min-height: 70vh; }
.adminStagePanel__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 16px;
}
.adminStagePanel__head h3 { margin: 2px 0 0; font-size: 1.18rem; }
.adminStagePanel__head p { margin: 6px 0 0; color: rgba(238,242,255,.62); }
.adminStagePanel__head--stack { display: grid; gap: 14px; }
.adminSingleColumn { display: grid; gap: 16px; }
.adminMetricGrid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.adminMetricCard,
.adminFactBox,
.adminTimelinePanel,
.adminTimelineList li,
.adminUserCard {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.adminMetricCard,
.adminFactBox,
.adminTimelinePanel {
  border-radius: 18px;
}
.adminTimelineList li,
.adminUserCard { border-radius: 14px; }
.adminList--compact {
  max-height: min(72vh, 980px);
  overflow: auto;
  padding-right: 4px;
}
.adminServerFacts,
.adminUsersMain,
.adminContentStack { min-width: 0; }
.adminServerFacts__grid,
.adminTimelineGrid,
.adminMetaGrid,
.adminMetaGrid--three {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.adminMetaGrid--three { gap: 16px; }
.adminGlobalMessage {
  margin: 0;
  min-height: 22px;
  padding-inline: 4px;
}
@media (max-width: 1380px) {
  .adminStudioShell { grid-template-columns: 240px minmax(0, 1fr); }
  .adminMetricGrid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1160px) {
  .adminStudioShell,
  .adminHeroGrid,
  .adminAccountsLayout,
  .adminSupportGrid,
  .adminSectionStrip,
  .adminServerFacts__grid,
  .adminTimelineGrid,
  .adminMetaGrid,
  .adminMetaGrid--three,
  .adminMetricGrid {
    grid-template-columns: 1fr;
  }
  .adminRail {
    position: static;
    min-height: auto;
  }
}
@media (max-width: 760px) {
  .adminStudioShell { width: min(100%, calc(100% - 20px)); margin: 12px auto 24px; }
  .adminCanvasHeader,
  .adminStagePanel,
  .adminHeroPanel,
  .adminSectionStrip,
  .adminRail { padding: 16px; }
  .adminCanvasHeader { flex-direction: column; }
  .adminCanvasHeader__actions { width: 100%; justify-content: stretch; }
  .adminCanvasHeader__actions .btn { flex: 1 1 100%; }
}

/* --- Step 8.3 professional one-column admin workspace --- */
.adminBody--workspace {
  background:
    radial-gradient(circle at top, rgba(59,130,246,.12), transparent 26%),
    linear-gradient(180deg, #07111f 0%, #09101b 42%, #0b111b 100%);
}
.adminWorkspace {
  width: min(1120px, calc(100% - 28px));
  margin: 18px auto 32px;
  display: grid;
  gap: 14px;
}
.adminWorkspaceTop {
  position: relative;
  z-index: 20;
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 26px;
  background: rgba(7, 14, 26, .9);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 50px rgba(0,0,0,.34);
}
.adminWorkspaceTop__main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.adminWorkspaceTop__brand {
  display: flex;
  align-items: center;
  gap: 14px;
}
.adminWorkspaceTop__brand h1 {
  margin: 2px 0 0;
  font-size: 1.38rem;
}
.adminWorkspaceTop__coin {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-weight: 800;
  color: #08111d;
  background: linear-gradient(180deg, #f7d69a, #dca85a);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.45);
}
.adminWorkspaceTop__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}
.adminWorkspaceStickyNav {
  position: sticky;
  top: 12px;
  z-index: 40;
  display: grid;
  gap: 10px;
  padding: 10px;
  border-radius: 22px;
  background: rgba(8, 14, 25, .88);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 50px rgba(0,0,0,.24);
}
.adminStickyServerBar {
  display: grid;
  gap: 10px;
}
.adminStickyServerBar__label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(226,232,240,.78);
  font-size: .92rem;
  font-weight: 600;
}
.adminTopMetrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.adminTopMetrics .adminMetricCard {
  min-height: 102px;
  padding: 14px 16px;
  display: grid;
  gap: 6px;
  border-radius: 18px;
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.07);
}
.adminTopMetrics .adminMetricCard span {
  color: rgba(226,232,240,.7);
  font-size: .84rem;
}
.adminTopMetrics .adminMetricCard strong {
  font-size: 1.35rem;
}
.adminTopMetrics .adminMetricCard small {
  color: rgba(226,232,240,.62);
}
.adminTopStatus .adminServerFacts__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.adminTopStatus .adminFactBox {
  min-height: 84px;
  padding: 12px 14px;
  display: grid;
  gap: 6px;
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.adminTopStatus .adminTimelineGrid {
  display: none;
}
.adminWorkspaceTabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}
.adminWorkspaceTabs .tab {
  min-height: 50px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  color: rgba(241,245,249,.82);
  font-weight: 700;
}
.adminWorkspaceTabs .tab.is-active {
  background: linear-gradient(180deg, rgba(126, 169, 255, .35), rgba(78, 120, 210, .22));
  color: #fff;
  border-color: rgba(126,169,255,.3);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}
.adminStatsToggle {
  width: 100%;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: rgba(241,245,249,.86);
  font-weight: 700;
}
.adminStatsToggle:hover { background: rgba(255,255,255,.05); }
.adminStatsToggle__icon { transition: transform .18s ease; }
.adminStatsToggle.is-open .adminStatsToggle__icon { transform: rotate(180deg); }
.adminStatsPanel {
  display: grid;
  gap: 12px;
  padding: 6px 2px 4px;
}
.adminPane--workspace {
  min-width: 0;
}
.adminSingleColumn--workspace {
  gap: 14px;
}
.adminStagePanel {
  padding: 18px;
  border-radius: 22px;
  background: rgba(8, 13, 24, .88);
  border: 1px solid rgba(255,255,255,.075);
  box-shadow: 0 14px 36px rgba(0,0,0,.26);
}
.adminStagePanel__head {
  margin-bottom: 14px;
}
.adminSearchForm {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
}
.adminSearchForm input {
  min-width: 0;
}
.adminList--workspace {
  max-height: 36vh;
  overflow: auto;
  padding-right: 4px;
}
.adminUserCard {
  width: 100%;
  padding: 14px 16px;
  display: grid;
  gap: 4px;
  text-align: left;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
}
.adminUserCard.is-selected {
  border-color: rgba(126,169,255,.36);
  background: rgba(126,169,255,.09);
}
.adminEmergencyButtons {
  grid-template-columns: 1fr 1fr 1fr;
}
.adminGlobalMessage {
  margin: 0;
  min-height: 22px;
  padding-inline: 2px;
}
.adminTopStatus .adminStatusPill {
  justify-self: start;
}
@media (max-width: 1180px) {
  .adminTopMetrics,
  .adminTopStatus .adminServerFacts__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 860px) {
  .adminWorkspace {
    width: min(100%, calc(100% - 20px));
    margin: 12px auto 24px;
  }
  .adminWorkspaceTop__main,
  .adminWorkspaceTop__actions {
    flex-direction: column;
    align-items: stretch;
  }
  .adminWorkspaceStickyNav {
    top: 12px;
  }
  .adminWorkspaceTabs {
    grid-template-columns: 1fr 1fr;
  }
  .adminTopMetrics,
  .adminTopStatus .adminServerFacts__grid,
  .adminEmergencyButtons,
  .adminSearchForm {
    grid-template-columns: 1fr;
  }
}
