:root{
  --stroke: rgba(255,255,255,.12);
  --glow1: rgba(124,92,255,.35);
  --glow2: rgba(0,229,255,.22);
}
*{ box-sizing:border-box; }
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:#fff;
  background: radial-gradient(circle at 18% 18%, rgba(124,92,255,.20), transparent 38%),
              radial-gradient(circle at 82% 72%, rgba(0,229,255,.16), transparent 40%),
              radial-gradient(circle at 50% 110%, rgba(255,255,255,.06), transparent 55%),
              #070711;
  min-height:100vh;
}

/* Theme: soft (less glow) */
body[data-theme="soft"]{
  background: radial-gradient(circle at 18% 18%, rgba(124,92,255,.14), transparent 40%),
              radial-gradient(circle at 82% 72%, rgba(0,229,255,.10), transparent 42%),
              #070711;
}
body[data-theme="soft"] #bgGlow{ opacity:.55; filter: blur(26px); }
body[data-theme="soft"] .neon{ box-shadow: 0 0 8px rgba(124,92,255,.28), 0 0 18px rgba(0,229,255,.14); }
body[data-theme="sunset"]{
  background: radial-gradient(circle at 22% 18%, rgba(255,125,69,.24), transparent 38%),
              radial-gradient(circle at 78% 72%, rgba(255,60,136,.20), transparent 42%),
              #120711;
}
body[data-theme="sunset"] #bgGlow{
  background: radial-gradient(circle at 20% 30%, rgba(255,136,76,.24), transparent 45%),
              radial-gradient(circle at 80% 70%, rgba(255,77,157,.18), transparent 45%);
}
body[data-theme="sunset"] .neon{ box-shadow: 0 0 12px rgba(255,138,92,.28), 0 0 28px rgba(255,84,160,.18); }
body[data-theme="sunset"] .btnPrimary{
  background: linear-gradient(135deg, rgba(255,128,76,.96), rgba(255,67,150,.90));
  box-shadow: 0 0 22px rgba(255,112,81,.34), 0 0 48px rgba(255,81,154,.14);
}
body[data-theme="sunset"] .btnCyan{
  background: linear-gradient(135deg, rgba(255,199,90,.96), rgba(255,143,78,.88));
  box-shadow: 0 0 22px rgba(255,175,88,.30), 0 0 44px rgba(255,120,70,.12);
}
body[data-theme="ice"]{
  background: radial-gradient(circle at 18% 18%, rgba(107,229,255,.22), transparent 38%),
              radial-gradient(circle at 82% 72%, rgba(84,143,255,.18), transparent 42%),
              #05111c;
}
body[data-theme="ice"] #bgGlow{
  background: radial-gradient(circle at 20% 30%, rgba(111,236,255,.22), transparent 45%),
              radial-gradient(circle at 80% 70%, rgba(92,142,255,.18), transparent 45%);
}
body[data-theme="ice"] .neon{ box-shadow: 0 0 12px rgba(97,220,255,.32), 0 0 28px rgba(97,146,255,.18); }
body[data-theme="ice"] .btnPrimary{
  background: linear-gradient(135deg, rgba(76,201,255,.96), rgba(86,135,255,.90));
  box-shadow: 0 0 22px rgba(76,201,255,.30), 0 0 48px rgba(86,135,255,.14);
}
body[data-theme="ice"] .btnCyan{
  background: linear-gradient(135deg, rgba(151,248,255,.96), rgba(79,223,255,.86));
  box-shadow: 0 0 22px rgba(121,237,255,.32), 0 0 44px rgba(58,176,255,.14);
}
#bgGlow{
  position:fixed;
  inset:-40px;
  pointer-events:none;
  /* Always stay behind UI */
  z-index: 0;
  background: radial-gradient(circle at 20% 30%, rgba(124,92,255,.22), transparent 45%),
              radial-gradient(circle at 80% 70%, rgba(0,229,255,.18), transparent 45%);
  filter: blur(20px);
  opacity:.9;
}

/*
  UI SAFETY: keep interactive screens above any decorative layers.
  Some browsers create unexpected stacking contexts with blur/backdrop-filter.
*/
.screen{ position: relative; z-index: 5; }
#screenMenu{ z-index: 10; }
#screenMenu .screenInner{ position: relative; z-index: 11; }
#screenMenu .menuCard{ position: relative; z-index: 12; }
#btnGoPlay{ position: relative; z-index: 20; pointer-events: auto !important; }
.panel{
  background: linear-gradient(180deg, rgba(20,20,40,.78), rgba(10,10,25,.68));
  border: 1px solid var(--stroke);
  border-radius: 22px;
  box-shadow: 0 0 40px var(--glow1), inset 0 0 26px rgba(0,229,255,.08);
  backdrop-filter: blur(10px);
}

.panelSoft{ background: rgba(0,0,0,.14); border: 1px solid rgba(255,255,255,.08); }
.neon{ box-shadow: 0 0 12px rgba(124,92,255,.45), 0 0 28px rgba(0,229,255,.22); }
.topbar{
  margin:14px;
  padding:14px 16px;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.brand{ font-weight:900; letter-spacing:.12em; }
.roomline{ opacity:.85; font-weight:700; }
.layout{
  display:grid;
  grid-template-columns: 380px 1fr 380px;
  gap:14px;
  padding: 0 14px 14px;
}
.left,.mid,.right{ padding:16px; min-height: 520px; }
.right{ display:flex; flex-direction:column; }
.sectionTitle{
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  opacity:.85;
  margin-bottom:10px;
}
.wheelBox{
  position:relative;
  width: 320px;
  height: 320px;
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
}
.wheelNeedle{
  position:absolute;
  top:-6px;
  left:50%;
  transform: translateX(-50%);
  width:0;height:0;
  border-left:14px solid transparent;
  border-right:14px solid transparent;
  border-bottom:26px solid rgba(255,255,255,.92);
  filter: drop-shadow(0 0 10px rgba(0,229,255,.45)) drop-shadow(0 0 18px rgba(124,92,255,.55));
  z-index: 9999;
}
.wheelCenter{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  z-index: 9998;
}
.pill{
  padding:8px 12px;
  border-radius:999px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 0 18px rgba(0,229,255,.18);
  font-weight:900;
  text-align:center;
}
.tinyNote{ margin-top:10px; opacity:.7; font-size:12px; text-align:center; }
.categoryLine{ font-weight:800; margin-bottom:10px; opacity:.9; }
.hints .hint{
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  padding: 12px 14px;
  margin: 10px 0;
  box-shadow: 0 0 18px rgba(0,229,255,.14);
  animation: hintIn .22s ease-out;
}
@keyframes hintIn { from{ transform: translateY(6px); opacity:0; } to{ transform: translateY(0); opacity:1; } }
.timerWrap{ margin-top: 16px; text-align:center; }
.timerLabel{ opacity:.85; font-weight:900; letter-spacing:.08em; text-transform:uppercase; font-size:12px; margin-bottom:6px; }
.timerValue{
  font-size: 56px;
  font-weight: 900;
  text-shadow: 0 0 10px rgba(124,92,255,.8), 0 0 32px rgba(0,229,255,.35);
  animation: pulse 1.5s ease-in-out infinite;
}
@keyframes pulse{ 0%{transform:scale(1)} 50%{transform:scale(1.05)} 100%{transform:scale(1)} }
.timerWarn{
  text-shadow: 0 0 10px rgba(255,75,75,.9), 0 0 30px rgba(255,75,75,.45) !important;
  animation: pulseFast .7s ease-in-out infinite !important;
}
@keyframes pulseFast{ 0%{transform:scale(1)} 50%{transform:scale(1.08)} 100%{transform:scale(1)} }
.controls{ display:flex; flex-direction:column; gap:10px; }
.row{ display:flex; gap:10px; }
.input{
  flex:1;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  color:#fff;
  padding: 8px 10px;
  outline:none;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color:#fff;
  padding: 10px 14px;
  border-radius: 16px;
  font-weight: 900;
  cursor:pointer;
  user-select:none;
  -webkit-tap-highlight-color: transparent;
  box-shadow:
    0 0 0 1px rgba(0,229,255,.06),
    0 0 18px rgba(0,229,255,.12);
  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease, background .12s ease;
  position: relative;
  overflow: hidden;
}
.btn::after{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(circle at 20% 20%, rgba(255,255,255,.18), transparent 42%);
  opacity:.55;
  pointer-events:none;
}
.btn:hover{ filter: brightness(1.07); transform: translateY(-1px); }
.btn:active{ transform: translateY(0) scale(.98); }
.btn:focus{ outline: none; }
.btn:focus-visible{
  box-shadow:
    0 0 0 2px rgba(0,229,255,.22),
    0 0 0 6px rgba(124,92,255,.18),
    0 0 22px rgba(0,229,255,.20);
}
.btn:active{ transform: translateY(0) scale(.98); }
.btn:focus{ outline: none; }
.btn:focus-visible{
  box-shadow:
    0 0 0 2px rgba(0,229,255,.22),
    0 0 0 6px rgba(124,92,255,.18),
    0 0 22px rgba(0,229,255,.20);
}
.btnGreen{ background: linear-gradient(180deg,#2cff8a,#0ea65a); box-shadow:0 0 18px rgba(44,255,138,.35); }
.btnRed{ background: linear-gradient(180deg,#ff4b4b,#b31212); box-shadow:0 0 18px rgba(255,75,75,.35); }
.btnSpinRed{
  width: 100%;
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255, 80, 80, .65);
  background: linear-gradient(180deg, rgba(255,60,60,.95), rgba(140,0,0,.95));
  box-shadow:
    0 0 18px rgba(255, 60, 60, .35),
    0 0 40px rgba(255, 60, 60, .18);
  font-weight: 1000;
  text-transform: uppercase;
  letter-spacing: .6px;
}
.btnSpinRed:hover{ filter: brightness(1.10); }
.btnSpinRed:disabled{
  opacity: .55;
  cursor: not-allowed;
  filter: none;
}
.btnCyan{
  border: 1px solid rgba(0,229,255,.40);
  background: linear-gradient(135deg, rgba(0,229,255,.96), rgba(0,255,166,.84));
  color: #031418;
  text-shadow: none;
  box-shadow:
    0 0 0 1px rgba(0,229,255,.10),
    0 0 22px rgba(0,229,255,.34),
    0 0 44px rgba(0,255,166,.12);
}
.btnCyan:hover{ filter: brightness(1.05); box-shadow: 0 0 28px rgba(0,229,255,.50), 0 0 58px rgba(0,255,166,.14); }
.sep{ border:none; height:1px; background: rgba(255,255,255,.10); margin: 12px 0; }
.players{ display:flex; flex-direction:column; gap:8px; }
.player{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.20);
}
.player small{ opacity:.75; font-weight:700; }
@media (max-width: 1100px){
  .layout{ grid-template-columns: 1fr; }
  .left,.mid,.right{ min-height:auto; }
}

/* FIX: wheel svg must not block UI clicks */
.wheelBox { overflow: hidden; }
.wheelBox svg { position:absolute; inset:0; width:100%; height:100%; display:block; pointer-events:none; transform-box: fill-box; transform-origin: 50% 50%; }
.wheelNeedle { pointer-events:none; }

/* FIX: wheel svg must not block UI clicks */
.wheelBox { overflow: hidden; }
.wheelBox svg { position:absolute; inset:0; width:100%; height:100%; display:block; pointer-events:none; transform-box: fill-box; transform-origin: 50% 50%; }
.wheelNeedle { pointer-events:none; }

/* Tabs */
.tabs{ display:flex; gap:10px; margin-bottom:12px; }
.tabBtn{ flex:1; border:1px solid rgba(255,255,255,.14); background: rgba(0,0,0,.18); color:#fff; padding:10px 12px; border-radius:14px; font-weight:900; cursor:pointer; }
.tabBtn.active{ background: linear-gradient(180deg,#00e5ff,#0aa6b8); box-shadow:0 0 18px rgba(0,229,255,.30); }
.hidden{ display:none !important; }

/* -------- Screens (Main Menu / Play / Game) -------- */
.screen{ display:none; min-height:100vh; }
.screenActive{ display:block; }
.screenInner{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 22px 14px;
}
.menuCard{
  width: min(680px, 92vw);
  padding: 22px;
}
.brandBlock{ text-align:center; margin-bottom: 16px; }
.brandBlock.small{ margin-bottom: 12px; }
.brandBig{
  font-weight: 1000;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 42px;
  text-shadow: 0 0 18px rgba(124,92,255,.65), 0 0 40px rgba(0,229,255,.25);
  animation: logoGlow 2.2s ease-in-out infinite;
}
.brandBlock.small .brandBig{ font-size: 28px; animation: none; }
.brandSmall{ opacity:.78; font-weight:800; letter-spacing:.08em; text-transform:uppercase; font-size: 12px; }
@keyframes logoGlow{
  0%{ filter: brightness(1); }
  50%{ filter: brightness(1.15); }
  100%{ filter: brightness(1); }
}
.menuBtns{ display:flex; flex-direction:column; gap: 12px; margin-top: 14px; }

/* --- Main menu hero (Колесо ума) --- */
.menuHero{ margin-bottom: 10px; }
.menuLogoMark{
  width: 92px;
  height: 92px;
  margin: 0 auto 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 26px;
  background: radial-gradient(circle at 30% 30%, rgba(0,229,255,.22), rgba(0,0,0,.12));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 0 22px rgba(0,229,255,.22), 0 0 34px rgba(124,92,255,.28);
  font-size: 44px;
  line-height: 1;
  animation: markFloat 2.2s ease-in-out infinite;
}
@keyframes markFloat{
  0%{ transform: translateY(0); }
  50%{ transform: translateY(-4px); }
  100%{ transform: translateY(0); }
}
.menuBtnsCenter{ align-items:center; }

.btnPlayMega{
  width: min(420px, 86vw);
  padding: 16px 18px;
  font-size: 18px;
  position: relative;
  overflow: hidden;
  transform: translateZ(0);
}
.btnPlayMega::after{
  content: "";
  position:absolute;
  inset: -40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.22), transparent 45%),
              radial-gradient(circle at 70% 70%, rgba(0,229,255,.22), transparent 45%);
  opacity: .35;
  filter: blur(14px);
  transform: translateX(-18%);
  transition: opacity .22s ease, transform .22s ease;
  pointer-events:none;
}
.btnPlayMega:hover{
  transform: translateY(-2px) scale(1.01);
  box-shadow: 0 0 22px rgba(124,92,255,.55), 0 0 44px rgba(0,229,255,.22);
}
.btnPlayMega:hover::after{ opacity: .6; transform: translateX(8%); }

.footerCredit{
  margin-top: 14px;
  text-align:center;
  font-weight: 800;
  letter-spacing: .04em;
  opacity: .72;
  font-size: 12px;
}
.footerCreditSmall{ margin-top: 10px; }
.creditName{
  opacity: .95;
  text-shadow: 0 0 10px rgba(0,229,255,.22), 0 0 18px rgba(124,92,255,.25);
}

.center{ text-align:center; }

/* Menu button variants */
.btnPrimary{
  padding: 14px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(135deg, rgba(98,88,255,.96), rgba(171,64,255,.88));
  box-shadow:
    0 0 0 1px rgba(124,92,255,.10),
    0 0 22px rgba(124,92,255,.40),
    0 0 48px rgba(0,229,255,.12);
  text-transform: uppercase;
  letter-spacing: .10em;
}
.btnPrimary:hover{ filter: brightness(1.08); transform: translateY(-1px); }
.btnGlass{
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(0,229,255,.22);
  box-shadow: 0 0 18px rgba(0,229,255,.14);
  text-transform: uppercase;
  letter-spacing: .7px;
}
.btnDanger{
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255, 80, 80, .55);
  background: linear-gradient(180deg, rgba(255,60,60,.92), rgba(140,0,0,.92));
  box-shadow: 0 0 18px rgba(255, 60, 60, .30);
  text-transform: uppercase;
  letter-spacing: .7px;
}
.btnGhost{
  background: rgba(10,12,22,.55);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 0 14px rgba(0,229,255,.10);
}
.btnGhost:hover{ box-shadow: 0 0 24px rgba(0,229,255,.18); transform: translateY(-1px); }
.rowBetween{ display:flex; justify-content:space-between; align-items:center; gap: 12px; margin-top: 14px; }

.playGrid{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 12px; }
.panelMini{
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 14px;
}
@media (max-width: 760px){
  .playGrid{ grid-template-columns: 1fr; }
  .brandBig{ font-size: 34px; }
}

/* Settings modal */
.modal{
  position: fixed;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 22px 14px;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  z-index: 20000;
}
.modalCard{ width: min(520px, 92vw); padding: 18px; }
.settingRow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 12px 10px;
  border-radius: 14px;
  background: rgba(0,0,0,.20);
  border: 1px solid rgba(255,255,255,.10);
  margin: 10px 0;
}
.chip{
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 1000;
  letter-spacing: .6px;
  cursor:pointer;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color:#fff;
  box-shadow: 0 0 14px rgba(0,229,255,.14);
}
.themePicker{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0 16px;
}
.themeSwatch{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  color:#fff;
  border-radius: 16px;
  padding: 12px 14px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.themeSwatch:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 18px rgba(0,229,255,.12);
}
.themeSwatch.active{
  border-color: rgba(0,229,255,.35);
  box-shadow: 0 0 20px rgba(0,229,255,.16), inset 0 0 0 1px rgba(255,255,255,.06);
}
.themeSwatch[data-theme-value="sunset"].active{
  border-color: rgba(255,124,91,.45);
  box-shadow: 0 0 18px rgba(255,124,91,.18);
}
.themeSwatch[data-theme-value="ice"].active{
  border-color: rgba(116,223,255,.45);
  box-shadow: 0 0 18px rgba(116,223,255,.18);
}

/* FX off mode */
body.fxOff *{ animation: none !important; transition: none !important; }


/* Emoji select */
.emojiGrid{ display:flex; flex-wrap:wrap; gap:8px; }
.emojiPick{ width:42px; height:42px; display:flex; align-items:center; justify-content:center; border-radius:12px; border:1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.18); cursor:pointer; user-select:none; }
.emojiPick.active{ box-shadow:0 0 18px rgba(124,92,255,.45); border-color: rgba(0,229,255,.35); }

/* Bottom players bar */
.playersBarWrap{ margin: 0 14px 14px; padding: 12px 14px; }
.playersBarHeader{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px; }
.playersMiniHint{ opacity:.75; font-weight:800; font-size:12px; }

.playersBarLayout{ display:flex; gap:12px; align-items:stretch; }

.playersBar{
  flex: 1;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}

.playerCard{
  min-width: 0;
  padding: 10px 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.20);
  display:flex;
  align-items:center;
  gap:10px;
  height: 74px;
}
.playerCard.active{ box-shadow: 0 0 22px rgba(0,229,255,.22); border-color: rgba(0,229,255,.30); }

.playerAvatar{
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 26px;
  background: rgba(0,229,255,.10);
  border: 1px solid rgba(0,229,255,.22);
  box-shadow: 0 0 18px rgba(0,229,255,.14);
  flex: 0 0 auto;
}

.playerInfo{ min-width:0; flex:1; }
.playerName{
  font-weight: 900;
  font-size: 16px;
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.playerStatus{ opacity:.75; font-weight:800; font-size:12px; margin-top:6px; }

.playerScore{
  flex: 0 0 auto;
  min-width: 34px;
  height: 34px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 1000;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 0 18px rgba(0,229,255,.10);
}

.playerSide{
  width: 240px;
  padding: 10px 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.playerSideTitle{ font-weight: 900; margin-bottom: 10px; opacity:.9; }
.btnWide{ width:100%; justify-content:center; }

.volBlock{ margin-top: 10px; padding: 10px; border-radius: 14px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); }
.volRow{ display:flex; justify-content:space-between; align-items:center; gap:10px; margin-bottom:8px; }
.volLabel{ font-weight:900; opacity:.9; }
.volValue{ font-weight:900; opacity:.85; }
.volSlider{ width:100%; }
.volNote{ margin-top:8px; font-size:12px; opacity:.70; font-weight:800; }

/* Responsive: wrap to 2 rows and move side under if needed */
@media (max-width: 1200px){
  .playersBarLayout{ flex-direction: column; }
  .playerSide{ width: 100%; }
  .playersBar{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}


/* Category overlay (show after wheel stops) */
.categoryOverlay{
  position: fixed;
  left: 50%;
  top: 150px;
  transform: translateX(-50%);
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(0,0,0,.30);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 0 22px rgba(0,229,255,.22), 0 0 30px rgba(124,92,255,.30);
  font-weight: 900;
  font-size: 28px;
  letter-spacing: .02em;
  text-shadow: 0 0 14px rgba(0,229,255,.35), 0 0 22px rgba(124,92,255,.35);
  z-index: 99999;
  pointer-events: none;
  opacity: 0;
  transition: opacity .22s ease;
}
.categoryOverlay.show{ opacity: 1; }

/* --- Player log panel --- */
#playerLog{ flex: 1; display:flex; flex-direction:column; }
.logList{
  display:flex;
  flex-direction:column;
  gap:8px;
  flex: 1;
  max-height: none;
  overflow:auto;
  padding-right:6px;
}
.logEmpty{
  opacity:.75;
  font-size:12px;
  line-height:1.25;
  padding: 8px 4px;
}
.logItem{
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  box-shadow: inset 0 0 0 1px rgba(0,229,255,.06);
}

/* result colors */
.logItem.correct{
  border-color: rgba(76,255,167,.28);
  box-shadow: inset 0 0 0 1px rgba(76,255,167,.10), 0 0 16px rgba(76,255,167,.10);
}
.logItem.wrong{
  border-color: rgba(255,86,120,.28);
  box-shadow: inset 0 0 0 1px rgba(255,86,120,.10), 0 0 16px rgba(255,86,120,.10);
}
.logItem.pass{
  border-color: rgba(0,229,255,.22);
  box-shadow: inset 0 0 0 1px rgba(0,229,255,.08), 0 0 16px rgba(0,229,255,.08);
}

/* category badge */
.logCat{
  width: 22px;
  height: 22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  box-shadow: 0 0 14px rgba(124,92,255,.10);
  font-size: 14px; /* emoji */
  line-height: 1;
}
.logRes{ opacity:.95; }

/* appearance animation (soft slide + fade) */
@keyframes logIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.logItem.appear{
  animation: logIn 220ms cubic-bezier(.18,.88,.2,1) both;
}
.logTop{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:800;
}
.logPts{
  margin-left:auto;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(0,229,255,.28);
  background: rgba(0,229,255,.10);
  box-shadow: 0 0 18px rgba(0,229,255,.10);
  font-weight:900;
}
.logAns{
  margin-top:5px;
  opacity:.9;
  font-size:12px;
  line-height:1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}



/* --- Player action bar (under timer) --- */
.actionBar{
  margin-top: 14px;
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.actionBar .btn{
  padding: 12px 18px;
  border-radius: 18px;
  font-size: 14px;
}
.actionBar #btnPlyHint{
  min-width: min(760px, 100%);
  font-size: 15px;
  letter-spacing: .10em;
  text-transform: uppercase;
  animation: hintPulse 2.2s ease-in-out infinite;
}
@keyframes hintPulse{
  0%,100%{ box-shadow: 0 0 22px rgba(0,229,255,.30), 0 0 44px rgba(0,255,166,.10); }
  50%{ box-shadow: 0 0 36px rgba(0,229,255,.55), 0 0 64px rgba(0,255,166,.16); }
}
.actionBar #btnPlyAnswer{ min-width: 170px; }
.actionBar #btnPlyPass{ opacity: .88; }

/* If timer is in warning state, make the main hint button feel more urgent */
#timerValue.timerWarn ~ .actionBar #btnPlyHint{
  animation-duration: 1.2s;
  box-shadow: 0 0 36px rgba(255,75,75,.30), 0 0 70px rgba(255,75,75,.18);
}
.actionBar .btn{
  padding: 12px 18px;
  border-radius: 18px;
  font-size: 14px;
}
.actionBar #btnPlyHint{
  min-width: min(760px, 100%);
  font-size: 15px;
  letter-spacing: .10em;
  text-transform: uppercase;
  animation: hintPulse 2.2s ease-in-out infinite;
}
@keyframes hintPulse{
  0%,100%{ box-shadow: 0 0 22px rgba(0,229,255,.30), 0 0 44px rgba(0,255,166,.10); }
  50%{ box-shadow: 0 0 36px rgba(0,229,255,.55), 0 0 64px rgba(0,255,166,.16); }
}
.actionBar #btnPlyAnswer{ min-width: 170px; }
.actionBar #btnPlyPass{ opacity: .85; }

/* If timer is in warning state, make the main hint button feel more urgent */
#timerValue.timerWarn ~ .actionBar #btnPlyHint{
  animation-duration: 1.2s;
  box-shadow: 0 0 36px rgba(255,75,75,.30), 0 0 70px rgba(255,75,75,.18);
}

/* --- Hints as cards with entry animation --- */
.hintCard{
  position: relative;
  padding: 12px 14px 12px 44px;
  border-radius: 14px;
  background: rgba(10,12,22,.68);
  border: 1px solid rgba(0,229,255,.28);
  box-shadow:
    0 0 26px rgba(0,229,255,.18),
    0 0 18px rgba(124,92,255,.14),
    inset 0 0 18px rgba(0,229,255,.10);
  color: rgba(255,255,255,.92);
  overflow: hidden;
}
.hintCard::before{
  content: "💡";
  position: absolute;
  left: 14px;
  top: 10px;
  font-size: 20px;
  filter: drop-shadow(0 0 12px rgba(0,229,255,.45));
}
.hintMeta{
  font-size: 13px;
  opacity: .8;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.hintText{ font-size: 16px; line-height: 1.35; }

.hintEnter{
  animation: hintIn .35s ease-out both;
}
@keyframes hintIn{
  from{ opacity:0; transform: translateY(10px); filter: blur(2px); }
  to{ opacity:1; transform: translateY(0); filter: blur(0); }
}

/* --- "Hint soon" countdown (2s lock before first auto-hint) --- */
.hintSoon{
  margin-top: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(0,229,255,.22);
  background: rgba(10,12,22,.50);
  box-shadow: 0 0 22px rgba(0,229,255,.14), inset 0 0 16px rgba(124,92,255,.08);
  color: rgba(255,255,255,.92);
}
.hintSoonText{
  font-weight: 900;
  letter-spacing: .02em;
  text-shadow: 0 0 18px rgba(0,229,255,.22);
}
.hintSoonTimer{
  min-width: 56px;
  text-align:center;
  font-weight: 900;
  border-radius: 999px;
  padding: 6px 10px;
  border: 1px solid rgba(124,92,255,.26);
  background: rgba(124,92,255,.12);
  box-shadow: 0 0 18px rgba(124,92,255,.16);
}
.hintSoonPulse{
  animation: soonPulse 1.2s ease-in-out infinite;
}
@keyframes soonPulse{
  0%,100%{ transform: translateY(0); opacity:.90; }
  50%{ transform: translateY(-1px); opacity:1; }
}

.jokerBar{
  margin-top: 12px;
  display:flex;
  justify-content:center;
  gap: 10px;
  flex-wrap:wrap;
}
.jokerBtn{
  min-width: 116px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(10,12,22,.52);
  color:#fff;
  font-weight: 900;
  letter-spacing: .06em;
  cursor:pointer;
  box-shadow: 0 0 18px rgba(0,229,255,.08);
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease, border-color .12s ease;
}
.jokerBtn:hover{
  transform: translateY(-1px);
}
.jokerBtn:disabled{
  opacity: .45;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}
.jokerBtn.spent{
  text-transform:none;
  letter-spacing:.02em;
}
.jokerFirst{
  border-color: rgba(255,210,84,.28);
  box-shadow: 0 0 18px rgba(255,210,84,.10);
}
.jokerFifty{
  border-color: rgba(125,228,255,.28);
  box-shadow: 0 0 18px rgba(125,228,255,.10);
}
.jokerSkip{
  border-color: rgba(207,108,255,.28);
  box-shadow: 0 0 18px rgba(207,108,255,.10);
}

/* Host notification pill (only when someone pressed "Give answer") */
.pill.hidden{ display:none; }

/* --- Host: player admin panel --- */
.hostPlayersAdmin{
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height: 240px;
  overflow:auto;
  padding:8px;
  border-radius:14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 0 0 1px rgba(0,255,255,.08), 0 18px 40px rgba(0,0,0,.35);
}

/* --- Host: wheel categories admin --- */
.hostCatsAdmin{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:10px;
  border-radius:14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 0 0 1px rgba(0,255,255,.08), 0 18px 40px rgba(0,0,0,.35);
  max-height: 160px;
  overflow:auto;
}

.catsSectionTitle{
  width:100%;
  font-weight:900;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color: rgba(238,245,255,.75);
  margin: 2px 0 2px;
  padding-top: 2px;
}
.catChip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  background: rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.12);
}
.catChip.removed{
  opacity: .85;
  background: rgba(0,0,0,.16);
  border: 1px dashed rgba(255,255,255,.18);
}
.catChip .catEmoji{ filter: drop-shadow(0 0 10px rgba(0,255,255,.18)); }
.catChip .catName{ font-weight:800; font-size:13px; color: rgba(238,245,255,.95); }
.catChip .catRemove{
  width:26px;
  height:26px;
  border-radius:999px;
  border:1px solid rgba(255,90,90,.22);
  background: rgba(255,90,90,.10);
  color: rgba(255,220,220,.95);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  line-height:1;
}
.catChip .catRemove:hover{ box-shadow: 0 0 18px rgba(255,90,90,.20); }
.catChip .catRemove:disabled{
  opacity:.45;
  cursor:not-allowed;
  filter: grayscale(.2);
}

.catChip .catRestore{
  width:26px;
  height:26px;
  border-radius:999px;
  border:1px solid rgba(0,255,180,.22);
  background: rgba(0,255,180,.10);
  color: rgba(210,255,240,.95);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  line-height:1;
}
.catChip .catRestore:hover{ box-shadow: 0 0 18px rgba(0,255,180,.20); }
.catChip .catRestore:disabled{
  opacity:.45;
  cursor:not-allowed;
  filter: grayscale(.2);
}
.hostPlayerRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 10px;
  border-radius:12px;
  background: rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
}
.hostPlayerRow.active{
  box-shadow: 0 0 0 1px rgba(0,255,255,.22), 0 0 18px rgba(0,255,255,.10);
}
.hostPlayerLeft{
  display:flex;
  align-items:center;
  gap:10px;
  min-width: 0;
  flex: 1;
  overflow: hidden;
}
.hostPlayerAva{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(0,255,255,.18);
  box-shadow: 0 0 14px rgba(0,255,255,.10);
}
.hostPlayerName{
  font-weight:800;
  font-size:14px;
  color: rgba(238,245,255,.95);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width: 100%;
}
.hostPlayerRight{
  display:flex;
  align-items:center;
  gap:6px;
  flex-shrink: 0;
}
.scoreInput{
  width:64px;
  background: rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.14);
  border-radius:10px;
  padding:8px 10px;
  color: rgba(238,245,255,.95);
  font-weight:800;
}
.miniBtn{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(238,245,255,.95);
  border-radius:10px;
  padding:8px 10px;
  font-weight:900;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.miniBtn:hover{ transform: translateY(-1px); box-shadow: 0 0 18px rgba(0,255,255,.12); }
.miniBtn:active{ transform: translateY(0px) scale(.98); }
.miniBtnCyan{
  border-color: rgba(0,255,255,.28);
  box-shadow: 0 0 0 1px rgba(0,255,255,.08);
}
.miniBtnRed{
  border-color: rgba(255,80,110,.35);
  box-shadow: 0 0 0 1px rgba(255,80,110,.10);
}



/* FIX: allow clicks through decorative layers */
.background,
.bg,
.fx,
.overlay,
.neon-bg,
.page-bg,
.glow,
.bg-layer,
.container::before,
.container::after {
  pointer-events: none !important;
}

/* ensure play button is clickable */
button,
.play-btn,
.start-btn {
  position: relative;
  z-index: 5;
}

/* === V10 role split / cleaner setup screens === */
html, body { overflow-x: hidden; }
body { min-width: 320px; }
.screenInner{ width:min(1440px, calc(100vw - 32px)); margin-inline:auto; }
.layout{ grid-template-columns: minmax(280px, 320px) minmax(0, 1fr) minmax(300px, 360px); }
.layout > *{ min-width:0; }
.left,.mid,.right{ min-width:0; }
.right{ overflow:hidden; }
.playersBarLayout{ grid-template-columns: minmax(0,1fr) 260px; }
.playersBarLayout > *{ min-width:0; }

.roleShell{ max-width: 1180px; width:100%; padding: clamp(24px, 3vw, 38px); }
.roleTop{ margin-bottom: 18px; }
.roleChoiceGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 20px;
  margin-top: 22px;
}
.roleCard{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border-radius: 28px;
  padding: 26px;
  min-height: 240px;
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  gap: 14px;
  text-align:left;
  cursor:pointer;
  box-shadow: 0 14px 40px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.roleCard:hover{
  transform: translateY(-4px);
  border-color: rgba(0,229,255,.38);
  box-shadow: 0 20px 50px rgba(0,0,0,.38), 0 0 30px rgba(0,229,255,.18);
}
.roleIcon{ font-size: 40px; line-height:1; }
.roleTitle{ font-size: 28px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.roleDesc{ font-size: 15px; line-height:1.6; color: rgba(255,255,255,.78); max-width: 34ch; }
.roleHost{ background: linear-gradient(180deg, rgba(124,92,255,.22), rgba(255,255,255,.04)); }
.rolePlayer{ background: linear-gradient(180deg, rgba(0,229,255,.18), rgba(255,255,255,.04)); }
.roleFooterRow{ margin-top: 16px; gap:12px; flex-wrap:wrap; }

.setupShell{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 22px;
  width:min(1320px, 100%);
  margin-inline:auto;
}
.setupCard{ min-width:0; }
.setupMainCard, .playerSetupCard{ padding: clamp(22px, 3vw, 34px); }
.setupSideCard{
  padding: 26px;
  display:flex;
  flex-direction:column;
  gap: 16px;
  justify-content:flex-start;
}
.setupBadge{
  display:inline-flex;
  align-self:flex-start;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #92f7ff;
  border:1px solid rgba(0,229,255,.32);
  background: rgba(0,229,255,.10);
}
.previewTitle{ font-size: 24px; font-weight: 800; }
.previewList{ display:flex; flex-direction:column; gap: 12px; }
.previewItem{
  display:flex; flex-direction:column; gap:4px;
  padding:14px 16px; border-radius:18px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}
.previewItem strong{ font-size: 15px; }
.previewItem span{ font-size: 13px; color: rgba(255,255,255,.68); }
.setupFieldGrid{ display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; margin: 18px 0 18px; }
.fieldBlock{ display:flex; flex-direction:column; gap:8px; min-width:0; }
.fieldWide{ grid-column: span 2; }
.fieldLabel{ font-size: 13px; letter-spacing:.08em; text-transform: uppercase; color: rgba(255,255,255,.70); font-weight:700; }
.setupActionRow{ display:flex; gap:12px; margin: 8px 0 14px; }
.btnCreateMega, .btnJoinMega{ min-height: 56px; font-size: 16px; font-weight: 900; letter-spacing:.08em; }
.emojiGridBig{ gap: 10px; }
.emojiGridBig .emojiPick{ width: 52px; height:52px; font-size: 26px; }
.playerSetupLayout{ grid-template-columns: minmax(0, 760px); justify-content:center; }
.hostSetupLayout .setupMainCard{ overflow:hidden; }

@media (max-width: 1180px){
  .layout{ grid-template-columns: minmax(280px, 320px) minmax(0,1fr); }
  .right{ grid-column: 1 / -1; }
  .playersBarLayout{ grid-template-columns: 1fr; }
  .setupShell{ grid-template-columns: 1fr; }
  .setupSideCard{ order: 2; }
}

@media (max-width: 820px){
  .screenInner{ width:min(100vw - 20px, 100%); }
  .roleChoiceGrid{ grid-template-columns: 1fr; }
  .setupFieldGrid{ grid-template-columns: 1fr; }
  .fieldWide{ grid-column: auto; }
  .roleCard{ min-height: 210px; }
  .roleTitle{ font-size: 24px; }
}

/* ===== Main menu cinematic background update ===== */
#screenMenu{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(4,6,23,.18) 0%, rgba(4,6,23,.58) 100%),
    url('/assets/menu-bg.png') center center / cover no-repeat;
}
#screenMenu::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 28%, rgba(149,95,255,.18), transparent 28%),
    linear-gradient(180deg, rgba(2,5,18,.02) 0%, rgba(2,5,18,.45) 100%);
}
#screenMenu .screenInner{
  position:relative;
  z-index:1;
}
#screenMenu .menuCard{
  width:min(760px, calc(100vw - 48px));
  background: linear-gradient(180deg, rgba(9,11,34,.74), rgba(7,9,28,.82));
  border:1px solid rgba(103,131,255,.22);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03) inset,
    0 24px 60px rgba(3,7,28,.45),
    0 0 36px rgba(60,110,255,.16);
  backdrop-filter: blur(10px);
}
#screenMenu .menuHero{
  gap: 10px;
}
#screenMenu .menuLogoMark{
  width: 88px;
  height: 88px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(11,17,48,.88), rgba(9,16,43,.74));
  border: 1px solid rgba(64,221,255,.20);
  box-shadow: 0 0 26px rgba(59,129,255,.22), inset 0 0 0 1px rgba(255,255,255,.03);
  font-size: 42px;
}
#screenMenu .brandBig{
  font-size: clamp(40px, 5vw, 78px);
  line-height: .94;
  letter-spacing: .08em;
  text-shadow: 0 0 24px rgba(160,160,255,.22), 0 0 42px rgba(255,255,255,.18);
}
#screenMenu .brandSmall{
  text-transform: uppercase;
  letter-spacing: .20em;
  font-size: 13px;
  color: rgba(239,244,255,.72);
}
#screenMenu .menuBtnsCenter{
  gap: 14px;
}
#screenMenu .btnPlayMega{
  min-width: min(360px, 100%);
  background: linear-gradient(90deg, #755cff 0%, #a84fff 100%);
  box-shadow: 0 14px 30px rgba(103,70,255,.28), 0 0 26px rgba(155,85,255,.22);
}
#screenMenu .btnPlayMega:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(103,70,255,.35), 0 0 32px rgba(155,85,255,.30);
}
#screenMenu .btnGhost{
  background: rgba(10,15,36,.72);
  border-color: rgba(255,255,255,.10);
}
#screenMenu .tinyNote,
#screenMenu .footerCredit{
  color: rgba(232,238,255,.68);
}
@media (max-width: 760px){
  #screenMenu .menuCard{
    padding: 24px 18px;
    border-radius: 26px;
  }
  #screenMenu .menuLogoMark{
    width: 74px;
    height: 74px;
    font-size: 34px;
  }
  #screenMenu .brandBig{
    font-size: clamp(30px, 10vw, 54px);
  }
}

/* ===== Main menu reference-style rebuild ===== */
#screenMenu{
  position: relative;
  overflow: hidden;
  min-height: 100dvh;
  height: 100dvh;
  background:
    radial-gradient(circle at 50% 20%, rgba(121, 71, 255, .22), transparent 24%),
    linear-gradient(180deg, rgba(2, 4, 14, .18) 0%, rgba(2, 4, 14, .60) 100%),
    url('/assets/menu-bg.png') center center / cover no-repeat;
}
#screenMenu::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(121, 34, 255, .18) 0%, transparent 24%, transparent 76%, rgba(0, 153, 255, .16) 100%),
    radial-gradient(circle at 50% 88%, rgba(136, 56, 255, .28), transparent 26%),
    linear-gradient(180deg, rgba(0, 0, 0, .06) 0%, rgba(0, 0, 0, .22) 100%);
}
#screenMenu::after{
  content:"";
  position:absolute;
  left:50%;
  bottom: 11%;
  width:min(980px, 82vw);
  height: 180px;
  transform:translateX(-50%);
  pointer-events:none;
  border-radius:50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(121, 58, 255, .22), rgba(0, 177, 255, .12) 42%, transparent 72%);
  filter: blur(18px);
  opacity:.9;
}
#screenMenu .menuScreenInner{
  position:relative;
  z-index:2;
  min-height:100dvh;
  height:100dvh;
  padding: clamp(14px, 2vh, 24px) clamp(18px, 2vw, 32px) clamp(14px, 2vh, 24px);
  align-items:stretch;
  justify-content:center;
  overflow:hidden;
}
.menuScene{
  position:relative;
  width:min(1420px, 100%);
  min-height: 100%;
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.menuCenterStack{
  width:min(1200px, 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: clamp(12px, 1.8vh, 24px);
  padding-top: clamp(8px, 1vh, 18px);
  padding-bottom: clamp(4px, .8vh, 10px);
}
.menuUtilityBtn,
.menuOnlineBadge{
  position:absolute;
  top: 12px;
  min-height: 54px;
  border-radius: 20px;
  border: 1px solid rgba(110, 136, 255, .24);
  background: rgba(8, 14, 36, .66);
  backdrop-filter: blur(12px);
  box-shadow: 0 12px 28px rgba(2, 8, 24, .28), inset 0 0 0 1px rgba(255,255,255,.02);
}
.menuUtilityBtn{
  left: 0;
  appearance:none;
  padding: 0 22px;
  display:inline-flex;
  align-items:center;
  gap: 12px;
  color:#f3f6ff;
  font: inherit;
  font-size: 16px;
  font-weight: 800;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.menuPacksBtn{
  top: 76px;
  border-color: rgba(183, 107, 255, .26);
  background: rgba(17, 10, 42, .74);
  box-shadow:
    0 12px 28px rgba(2, 8, 24, .28),
    0 0 20px rgba(165, 88, 255, .10),
    inset 0 0 0 1px rgba(255,255,255,.02);
}
.menuPacksBtn .menuUtilityIcon{
  color: rgba(255, 214, 255, .9);
}
.menuUtilityBtn:hover{
  transform: translateY(-2px);
  border-color: rgba(175, 109, 255, .42);
  box-shadow: 0 18px 34px rgba(2, 8, 24, .36), 0 0 22px rgba(130, 82, 255, .16);
}
.menuUtilityIcon{
  width: 20px;
  height: 20px;
  color: rgba(220, 227, 255, .88);
  display:inline-flex;
}
.menuUtilityIcon svg{
  width:100%;
  height:100%;
}
.menuOnlineBadge{
  right: 0;
  padding: 0 24px;
  display:inline-flex;
  align-items:center;
  gap: 12px;
  color:#eef5ff;
  font-size: 16px;
  font-weight: 800;
}
.menuOnlineBadge strong{ font-weight: 900; }
.menuOnlineDot{
  width: 12px;
  height: 12px;
  border-radius:50%;
  background: #00ea95;
  box-shadow: 0 0 0 6px rgba(0, 234, 149, .10), 0 0 16px rgba(0, 234, 149, .55);
}
.menuTitleBlock{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: clamp(6px, .9vh, 10px);
  text-align:center;
}
.menuWheelCrest{
  width: min(220px, 26vh, 30vw);
  margin-bottom: clamp(-12px, -1vh, -4px);
  filter: drop-shadow(0 0 18px rgba(184, 84, 255, .30)) drop-shadow(0 0 24px rgba(56, 164, 255, .20));
  opacity:.96;
}
.menuWheelCrest svg{
  width:100%;
  height:auto;
  display:block;
}
.menuWheelCrest .wheelRim,
.menuWheelCrest .wheelCore,
.menuWheelCrest .wheelSpokes,
.menuWheelCrest .wheelStand,
.menuWheelCrest .wheelBase{
  stroke-linecap:round;
  stroke-linejoin:round;
}
.menuWheelCrest .wheelRim{
  stroke:url(#wheelRimGradient);
  stroke: rgba(190, 96, 255, .95);
  stroke-width: 6;
}
.menuWheelCrest .wheelCore{
  stroke: rgba(98, 141, 255, .82);
  stroke-width: 5;
}
.menuWheelCrest .wheelSpokes{
  stroke: rgba(188, 121, 255, .78);
  stroke-width: 4.5;
}
.menuWheelCrest .wheelHub{
  fill: #ffbe59;
}
.menuWheelCrest .wheelStand,
.menuWheelCrest .wheelBase{
  stroke: rgba(116, 138, 255, .82);
  stroke-width: 6;
}
.menuWheelCrest .wheelCabins circle:nth-child(odd){
  fill: #ff69b4;
}
.menuWheelCrest .wheelCabins circle:nth-child(even){
  fill: #ffb55e;
}
.menuBrandBig{
  font-size: clamp(46px, 9vh, 110px);
  line-height: .92;
  letter-spacing: .02em;
  font-weight: 1000;
  text-transform: uppercase;
  background: linear-gradient(180deg, #fffdfd 10%, #f0a6ff 48%, #9dd4ff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 8px 26px rgba(63, 93, 255, .10);
}
.menuBrandSmall{
  color: rgba(245, 247, 255, .92);
  font-size: clamp(13px, 1.8vh, 19px);
  font-weight: 800;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.menuBrandUnderline{
  width: clamp(80px, 9vw, 104px);
  height: 5px;
  border-radius:999px;
  background: linear-gradient(90deg, #7a4cff 0%, #d04dff 100%);
  box-shadow: 0 0 20px rgba(178, 74, 255, .55);
}
.menuModeGrid{
  width:min(900px, 100%);
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 34px);
  margin-top: clamp(2px, .5vh, 10px);
}
.menuModeCard{
  appearance:none;
  position:relative;
  min-height: clamp(300px, 38vh, 390px);
  padding: clamp(18px, 2vh, 28px) clamp(18px, 1.6vw, 26px) clamp(18px, 2vh, 26px);
  border-radius: 34px;
  border: 2px solid rgba(133, 120, 255, .55);
  background:
    linear-gradient(180deg, rgba(26, 16, 57, .88), rgba(18, 14, 41, .94));
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03) inset,
    0 24px 56px rgba(1, 5, 19, .42);
  color:#fff;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, filter .18s ease;
}
.menuModeCard:hover{
  transform: translateY(-4px);
  filter: brightness(1.04);
}
.menuModeHost{
  border-color: rgba(194, 87, 255, .78);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03) inset,
    0 24px 56px rgba(1, 5, 19, .42),
    0 0 30px rgba(191, 77, 255, .18);
}
.menuModePlayer{
  border-color: rgba(21, 195, 255, .78);
  background:
    linear-gradient(180deg, rgba(6, 24, 53, .92), rgba(7, 18, 40, .96));
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03) inset,
    0 24px 56px rgba(1, 5, 19, .42),
    0 0 30px rgba(21, 195, 255, .18);
}
.menuModeBadge{
  position:absolute;
  top: 18px;
  left: 20px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(188, 73, 255, .18);
  color: #ff81ff;
  border: 1px solid rgba(208, 112, 255, .28);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.menuModeIcon{
  width: clamp(92px, 11vh, 124px);
  height: clamp(92px, 11vh, 124px);
  margin-top: 4px;
  margin-bottom: clamp(14px, 1.8vh, 24px);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color: #ffbe58;
  border: 4px solid rgba(201, 79, 255, .88);
  box-shadow: 0 0 28px rgba(178, 67, 255, .22), inset 0 0 32px rgba(255,255,255,.03);
  background: radial-gradient(circle at 50% 35%, rgba(94, 48, 162, .45), rgba(20, 12, 53, .86));
}
.menuModePlayer .menuModeIcon{
  color:#5f96ff;
  border-color: rgba(19, 199, 255, .92);
  box-shadow: 0 0 28px rgba(19, 199, 255, .22), inset 0 0 32px rgba(255,255,255,.03);
  background: radial-gradient(circle at 50% 35%, rgba(21, 122, 210, .34), rgba(7, 18, 46, .88));
}
.menuModeIcon svg{
  width: clamp(54px, 6.5vh, 70px);
  height: clamp(54px, 6.5vh, 70px);
}
.menuModeTitle{
  font-size: clamp(28px, 4.2vh, 44px);
  line-height: 1;
  font-weight: 1000;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.menuModeAccent{
  margin-top: clamp(6px, .8vh, 10px);
  font-size: clamp(15px, 1.8vh, 18px);
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.menuModeHost .menuModeAccent{ color:#b85cff; }
.menuModePlayer .menuModeAccent{ color:#14c7ff; }
.menuModeText{
  max-width: 290px;
  margin-top: clamp(12px, 1.4vh, 22px);
  color: rgba(235, 240, 255, .88);
  font-size: clamp(15px, 1.8vh, 18px);
  line-height: 1.4;
}
.menuFeaturesStrip{
  width:min(1410px, 100%);
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  padding: clamp(6px, .8vh, 10px) clamp(14px, 1.4vw, 24px);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(13, 18, 48, .88), rgba(8, 14, 36, .82));
  border: 1px solid rgba(95, 124, 255, .22);
  box-shadow: 0 22px 46px rgba(0, 6, 20, .28), 0 0 36px rgba(38, 108, 255, .10);
}
.menuFeatureItem{
  position:relative;
  min-width:0;
  display:flex;
  align-items:center;
  gap: 14px;
  padding: clamp(10px, 1vh, 14px) clamp(10px, 1vw, 18px);
}
.menuFeatureItem:not(:last-child)::after{
  content:"";
  position:absolute;
  top: 18px;
  right: 0;
  width: 1px;
  height: calc(100% - 36px);
  background: rgba(255,255,255,.12);
}
.menuFeatureIcon{
  flex:0 0 auto;
  width: clamp(32px, 4vh, 42px);
  height: clamp(32px, 4vh, 42px);
  line-height:1;
  filter: drop-shadow(0 0 16px currentColor);
}
.menuFeatureIcon svg{
  width:100%;
  height:100%;
  display:block;
}
.menuFeaturePurple{ color:#c153ff; }
.menuFeatureGold{ color:#ffb440; }
.menuFeatureBlue{ color:#4d71ff; }
.menuFeatureMint{ color:#19e5d4; }
.menuFeatureText{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap: 7px;
}
.menuFeatureText strong{
  font-size: clamp(15px, 1.8vh, 18px);
  font-weight: 900;
  line-height:1.1;
  text-transform: uppercase;
}
.menuFeatureText span{
  color: rgba(228, 234, 250, .82);
  font-size: clamp(13px, 1.5vh, 15px);
  line-height: 1.3;
}
.menuFooterLine,
.menuHint{
  text-align:center;
  color: rgba(220, 228, 247, .78);
  font-size: clamp(12px, 1.5vh, 15px);
}
.menuFooterLine span{ color:#ff5370; }
.menuHint{
  min-height: 20px;
  color: rgba(255, 222, 121, .92);
}

@media (max-width: 1260px){
  .menuModeGrid{
    gap: 24px;
  }
  .menuModeCard{
    min-height: clamp(290px, 36vh, 360px);
  }
  .menuFeaturesStrip{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .menuFeatureItem:nth-child(2)::after{
    display:none;
  }
}

@media (max-width: 900px){
  #screenMenu .menuScreenInner{
    padding: 18px 16px 22px;
  }
  .menuScene{
    min-height: 100%;
    padding-top: 68px;
  }
  .menuUtilityBtn,
  .menuOnlineBadge{
    top: 0;
    min-height: 48px;
    font-size: 14px;
  }
  .menuUtilityBtn{
    left: 0;
    padding: 0 16px;
  }
  .menuPacksBtn{
    top: 56px;
  }
  .menuOnlineBadge{
    right: 0;
    padding: 0 16px;
  }
  .menuCenterStack{
    gap: 18px;
    padding-top: 18px;
  }
  .menuModeGrid{
    grid-template-columns: 1fr;
    width:min(560px, 100%);
  }
  .menuModeCard{
    min-height: 340px;
    padding-inline: 20px;
  }
  .menuModeTitle{
    font-size: clamp(26px, 7vw, 38px);
  }
  .menuModeText{
    font-size: 16px;
    margin-top: 16px;
  }
  .menuModeAction{
    font-size: 20px;
    padding-block: 18px;
  }
  .menuFeaturesStrip{
    grid-template-columns: 1fr;
    padding: 8px 14px;
  }
  .menuFeatureItem{
    padding: 14px 10px;
  }
  .menuFeatureItem::after{
    display:none;
  }
  .menuFeatureText strong{
    font-size: 16px;
  }
  .menuFeatureText span{
    font-size: 14px;
  }
}

@media (max-width: 640px){
  .menuScene{
    padding-top: 174px;
  }
  .menuUtilityBtn,
  .menuOnlineBadge{
    position:absolute;
    left: 0;
    right: 0;
    width: fit-content;
    margin-inline:auto;
  }
  .menuSettingsBtn{
    top: 0;
  }
  .menuPacksBtn{
    top: 56px;
  }
  .menuOnlineBadge{
    top: 112px;
  }
  .menuWheelCrest{
    width: min(190px, 46vw);
  }
  .menuBrandBig{
    font-size: clamp(42px, 13vw, 68px);
  }
  .menuBrandSmall{
    letter-spacing: .18em;
    font-size: 12px;
  }
  .menuModeIcon{
    width: 108px;
    height: 108px;
    margin-bottom: 18px;
  }
  .menuModeIcon svg{
    width: 62px;
    height: 62px;
  }
  .menuModeBadge{
    top: 14px;
    left: 14px;
    font-size: 12px;
    padding: 7px 12px;
  }
  .menuFooterLine,
  .menuHint{
    font-size: 13px;
    line-height: 1.45;
  }
}

.showMoment,
.gameOverOverlay{
  position: fixed;
  inset: 0;
  z-index: 30000;
}
.showMoment{
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 24px;
  opacity: 0;
  transition: opacity .22s ease;
}
.showMoment.show{
  opacity: 1;
}
.showMomentGlow{
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 50% 50%, rgba(128, 84, 255, .18), transparent 30%);
  filter: blur(22px);
}
.showMomentCard{
  position:relative;
  min-width: min(620px, 92vw);
  max-width: 92vw;
  padding: 26px 28px;
  border-radius: 30px;
  text-align:center;
  background: linear-gradient(180deg, rgba(12,18,46,.92), rgba(8,12,32,.94));
  border: 1px solid rgba(123,129,255,.24);
  box-shadow: 0 26px 60px rgba(0,0,0,.38), 0 0 34px rgba(122,90,255,.18);
  animation: momentPop .3s cubic-bezier(.18,.88,.24,1) both;
}
.showMoment[data-variant="joker"] .showMomentCard{
  border-color: rgba(255,214,98,.26);
  box-shadow: 0 26px 60px rgba(0,0,0,.38), 0 0 34px rgba(255,214,98,.16);
}
.showMoment[data-variant="skip"] .showMomentCard{
  border-color: rgba(205,111,255,.30);
  box-shadow: 0 26px 60px rgba(0,0,0,.38), 0 0 34px rgba(205,111,255,.18);
}
.showMoment[data-variant="final"] .showMomentCard{
  border-color: rgba(255,118,186,.32);
  box-shadow: 0 26px 60px rgba(0,0,0,.38), 0 0 40px rgba(255,118,186,.20);
}
.showMomentKicker{
  font-size: 13px;
  font-weight: 1000;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(174, 193, 255, .78);
}
.showMomentTitle{
  margin-top: 10px;
  font-size: clamp(30px, 5vw, 54px);
  font-weight: 1000;
  line-height: .96;
  text-transform: uppercase;
}
.showMomentText{
  margin-top: 10px;
  font-size: 17px;
  color: rgba(228,234,250,.82);
}
@keyframes momentPop{
  from{ transform: scale(.92) translateY(10px); opacity:0; }
  to{ transform: scale(1) translateY(0); opacity:1; }
}

.gameOverOverlay{
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 24px;
  opacity: 0;
  pointer-events:none;
  transition: opacity .22s ease;
}
.gameOverOverlay.show{
  opacity:1;
  pointer-events:auto;
}
.gameOverBackdrop{
  position:absolute;
  inset:0;
  background: rgba(2,4,14,.68);
  backdrop-filter: blur(10px);
}
.gameOverCard{
  position:relative;
  width:min(620px, 92vw);
  padding: 30px 28px;
  text-align:center;
  border-radius: 30px;
  animation: momentPop .3s cubic-bezier(.18,.88,.24,1) both;
}
.gameOverKicker{
  font-size: 13px;
  font-weight: 1000;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(255,188,119,.82);
}
.gameOverTitle{
  margin-top: 10px;
  font-size: clamp(30px, 5vw, 52px);
  font-weight: 1000;
  text-transform: uppercase;
}
.gameOverWinner{
  margin-top: 14px;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.35;
}
.gameOverSummary{
  margin: 14px auto 22px;
  max-width: 46ch;
  color: rgba(230,236,250,.84);
  font-size: 16px;
  line-height: 1.45;
}

/* ===== Setup screens cinematic redesign ===== */
#screenHostSetup,
#screenPlayerSetup{
  position: relative;
  overflow: hidden;
  min-height: 100dvh;
}

#screenHostSetup{
  background:
    radial-gradient(circle at 16% 10%, rgba(255, 130, 84, .36), transparent 34%),
    radial-gradient(circle at 82% 72%, rgba(255, 52, 146, .24), transparent 36%),
    linear-gradient(135deg, #3b1b1a 0%, #250b1f 54%, #180511 100%);
}

#screenHostSetup::after{
  content:"";
  position:absolute;
  inset: 0;
  pointer-events:none;
  background:
    radial-gradient(circle at 28% 46%, rgba(255, 138, 92, .16), transparent 22%),
    radial-gradient(circle at 72% 56%, rgba(255, 73, 163, .14), transparent 18%);
  filter: blur(18px);
}

#screenPlayerSetup{
  background:
    radial-gradient(circle at 14% 10%, rgba(86, 210, 255, .22), transparent 34%),
    radial-gradient(circle at 84% 72%, rgba(92, 106, 255, .20), transparent 36%),
    linear-gradient(135deg, #0a1930 0%, #0b1026 54%, #090511 100%);
}

#screenHostSetup::before,
#screenPlayerSetup::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 55%, rgba(255,255,255,.04), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.16));
}

#screenHostSetup .screenInner,
#screenPlayerSetup .screenInner{
  position: relative;
  z-index: 2;
  align-items: center;
  padding-block: clamp(20px, 4vh, 36px);
}

#screenHostSetup .setupShell,
#screenPlayerSetup .setupShell{
  width: min(1320px, 100%);
  gap: 22px;
}

#screenHostSetup .setupShell{
  grid-template-columns: minmax(0, 940px) 330px;
  justify-content: center;
  align-items: stretch;
}

#screenHostSetup .setupMainCard,
#screenHostSetup .setupSideCard,
#screenPlayerSetup .playerSetupCard{
  background: linear-gradient(180deg, rgba(31, 20, 41, .94), rgba(23, 13, 28, .96));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03) inset,
    0 0 34px rgba(255, 92, 160, .14),
    0 22px 50px rgba(7, 3, 15, .38);
  backdrop-filter: blur(18px);
}

#screenHostSetup .setupMainCard::before,
#screenHostSetup .setupSideCard::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent 26%);
}

#screenPlayerSetup .playerSetupCard{
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03) inset,
    0 0 34px rgba(76, 166, 255, .14),
    0 22px 50px rgba(7, 3, 15, .38);
}

#screenHostSetup .setupMainCard{
  position: relative;
  border-radius: 28px;
  padding: 34px 34px 28px;
  min-height: 438px;
}

#screenHostSetup .setupSideCard{
  position: relative;
  border-radius: 26px;
  padding: 26px 24px 24px;
}

#screenPlayerSetup .playerSetupCard{
  border-radius: 28px;
  padding: clamp(28px, 4vw, 40px) clamp(28px, 4vw, 38px);
}

#screenHostSetup .brandBlock.small,
#screenPlayerSetup .brandBlock.small{
  margin-bottom: 20px;
}

#screenHostSetup .brandBlock.small{
  text-align: center;
}

#screenHostSetup .brandBig,
#screenPlayerSetup .brandBig{
  font-size: clamp(34px, 4vw, 56px);
  line-height: .96;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff8fe;
  text-shadow: 0 0 18px rgba(255,255,255,.12);
}

#screenHostSetup .brandBig{
  font-size: clamp(30px, 2.5vw, 44px);
  letter-spacing: .14em;
}

#screenHostSetup .brandSmall,
#screenPlayerSetup .brandSmall{
  margin-top: 6px;
  font-size: 14px;
  letter-spacing: .05em;
  color: rgba(255,255,255,.72);
}

#screenHostSetup .brandSmall{
  font-size: 12px;
  letter-spacing: .06em;
  font-weight: 800;
}

#screenHostSetup .fieldLabel,
#screenPlayerSetup .fieldLabel{
  font-size: 14px;
  letter-spacing: .05em;
  color: rgba(255,255,255,.70);
  font-weight: 800;
}

#screenHostSetup .input,
#screenPlayerSetup .input{
  min-height: 42px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(14, 9, 20, .72);
  color: #fff;
  padding: 11px 16px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
}

#screenHostSetup select.input{
  appearance: auto;
}

#screenHostSetup .input::placeholder,
#screenPlayerSetup .input::placeholder{
  color: rgba(255,255,255,.34);
}

#screenHostSetup .input:focus,
#screenPlayerSetup .input:focus{
  border-color: rgba(255, 126, 166, .34);
  box-shadow: 0 0 0 3px rgba(255, 126, 166, .10);
}

#screenHostSetup .setupFieldGrid,
#screenPlayerSetup .setupFieldGrid{
  gap: 18px;
  margin: 22px 0 18px;
}

#screenHostSetup .setupFieldGrid{
  margin: 18px 0 18px;
}

#screenHostSetup .setupActionRow,
#screenPlayerSetup .setupActionRow{
  margin: 12px 0 12px;
}

#screenHostSetup .btnCreateMega{
  width: 100%;
  min-height: 54px;
  border: none;
  border-radius: 18px;
  background: linear-gradient(90deg, #ff7d52 0%, #f04f72 52%, #dd3b93 100%);
  color: #fff;
  font-size: 17px;
  font-weight: 1000;
  letter-spacing: .06em;
  box-shadow: 0 14px 30px rgba(242, 81, 111, .22), 0 0 24px rgba(255, 126, 82, .16);
}

#screenHostSetup .btnCreateMega:hover{
  transform: translateY(-1px);
  filter: brightness(1.04);
}

#screenPlayerSetup .btnJoinMega{
  width: 100%;
  min-height: 56px;
  border: none;
  border-radius: 20px;
  background: linear-gradient(90deg, #39bfff 0%, #4b89ff 100%);
  color: #fff;
  font-size: 19px;
  font-weight: 1000;
  letter-spacing: .06em;
  box-shadow: 0 16px 36px rgba(70, 145, 255, .24), 0 0 32px rgba(57, 191, 255, .18);
}

#screenHostSetup .tinyNote,
#screenPlayerSetup .tinyNote{
  color: rgba(255,255,255,.62);
  font-size: 13px;
  line-height: 1.5;
}

#screenHostSetup > .screenInner .tinyNote{
  text-align: center;
}

#screenHostSetup .rowBetween.roleFooterRow,
#screenPlayerSetup .rowBetween.roleFooterRow{
  margin-top: 16px;
  align-items: center;
}

#screenHostSetup .rowBetween.roleFooterRow{
  justify-content: space-between;
  gap: 16px;
}

#screenHostSetup .rowBetween.roleFooterRow .tinyNote{
  max-width: 420px;
  margin-top: 0;
  text-align: right;
}

#screenHostSetup .btnGhost,
#screenPlayerSetup .btnGhost{
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(18, 23, 36, .92), rgba(12, 15, 27, .92));
  border: 1px solid rgba(122, 149, 197, .22);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03), 0 10px 20px rgba(0,0,0,.18);
}

#screenHostSetup .btnGhost{
  padding: 11px 18px;
  font-size: 14px;
}

#screenHostSetup .setupBadge{
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(89, 220, 255, .36);
  background: rgba(24, 70, 92, .24);
  color: #88ebff;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .18em;
}

#screenHostSetup .previewTitle{
  font-size: 22px;
  font-weight: 1000;
  color: #fff;
  margin-top: 8px;
}

#screenHostSetup .previewList{
  gap: 14px;
}

#screenHostSetup .previewItem{
  padding: 16px 16px 14px;
  border-radius: 20px;
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.01);
}

#screenHostSetup .previewItem strong{
  font-size: 16px;
  color: #fff;
}

#screenHostSetup .previewItem span{
  margin-top: 4px;
  font-size: 14px;
  color: rgba(255,255,255,.66);
  line-height: 1.4;
}

@media (max-width: 1180px){
  #screenHostSetup .setupShell{
    grid-template-columns: 1fr;
  }

  #screenHostSetup .rowBetween.roleFooterRow .tinyNote{
    max-width: none;
    text-align: center;
  }
}

@media (max-width: 820px){
  #screenHostSetup .setupMainCard,
  #screenPlayerSetup .playerSetupCard{
    padding: 24px 20px;
  }

  #screenHostSetup .setupSideCard{
    padding: 22px 18px;
  }

  #screenHostSetup .brandBig,
  #screenPlayerSetup .brandBig{
    font-size: clamp(28px, 9vw, 40px);
  }

  #screenHostSetup .rowBetween.roleFooterRow,
  #screenPlayerSetup .rowBetween.roleFooterRow{
    flex-direction: column;
    align-items: stretch;
  }
}

/* ===== Host screen hard override ===== */
#screenHostSetup{
  background:
    radial-gradient(circle at 12% 8%, rgba(255, 143, 88, .42), transparent 28%),
    radial-gradient(circle at 78% 68%, rgba(233, 55, 137, .24), transparent 32%),
    linear-gradient(135deg, #4a241e 0%, #2c1122 46%, #18050f 100%) !important;
}

#screenHostSetup .screenInner{
  width: min(1360px, calc(100vw - 48px)) !important;
  min-height: 100dvh;
  justify-content: center;
  align-items: center;
}

#screenHostSetup .hostSetupLayout{
  display: grid !important;
  grid-template-columns: minmax(0, 930px) 330px !important;
  gap: 22px !important;
  width: min(1280px, 100%) !important;
  align-items: stretch !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard{
  background: linear-gradient(180deg, rgba(35, 24, 42, .98), rgba(25, 14, 29, .98)) !important;
  border: 1px solid rgba(255,255,255,.07) !important;
  border-radius: 28px !important;
  padding: 34px 34px 26px !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03) inset,
    0 0 28px rgba(255, 93, 152, .18),
    0 24px 56px rgba(10, 4, 16, .42) !important;
}

#screenHostSetup .hostSetupLayout > .setupSideCard{
  background: linear-gradient(180deg, rgba(35, 24, 42, .98), rgba(28, 15, 36, .98)) !important;
  border: 1px solid rgba(255,255,255,.07) !important;
  border-radius: 26px !important;
  padding: 26px 24px !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.02) inset,
    0 0 26px rgba(255, 93, 152, .16),
    0 24px 56px rgba(10, 4, 16, .38) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .brandBlock.small{
  text-align: center !important;
  margin-bottom: 18px !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .brandBig{
  font-size: clamp(28px, 2.4vw, 42px) !important;
  letter-spacing: .16em !important;
  line-height: 1 !important;
  color: #fffaf9 !important;
  text-shadow: 0 0 16px rgba(255,255,255,.08) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .brandSmall{
  margin-top: 6px !important;
  font-size: 12px !important;
  letter-spacing: .04em !important;
  color: rgba(255,255,255,.74) !important;
  font-weight: 800 !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .setupFieldGrid{
  margin: 20px 0 18px !important;
  gap: 18px !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .fieldLabel{
  font-size: 13px !important;
  font-weight: 900 !important;
  letter-spacing: .05em !important;
  color: rgba(255,255,255,.72) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .input{
  min-height: 36px !important;
  padding: 10px 16px !important;
  border-radius: 15px !important;
  background: rgba(20, 13, 24, .92) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  color: #ffffff !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.015) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .input::placeholder{
  color: rgba(255,255,255,.32) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .input:focus{
  border-color: rgba(255, 121, 160, .34) !important;
  box-shadow: 0 0 0 3px rgba(255, 121, 160, .10) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .setupActionRow{
  margin: 16px 0 12px !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .btnCreateMega{
  width: 100% !important;
  min-height: 56px !important;
  border: 0 !important;
  border-radius: 18px !important;
  background: linear-gradient(90deg, #ff8252 0%, #f4566d 50%, #e23c93 100%) !important;
  color: #fff !important;
  font-size: 17px !important;
  font-weight: 1000 !important;
  letter-spacing: .06em !important;
  box-shadow:
    0 14px 34px rgba(244, 87, 110, .24),
    0 0 24px rgba(255, 131, 82, .18) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .btnCreateMega:hover{
  filter: brightness(1.04) !important;
  transform: translateY(-1px) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard > .tinyNote{
  margin-top: 6px !important;
  text-align: center !important;
  font-size: 13px !important;
  color: rgba(255,255,255,.64) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .roleFooterRow{
  margin-top: 18px !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 16px !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .roleFooterRow .btnGhost{
  padding: 11px 18px !important;
  border-radius: 18px !important;
  background: linear-gradient(180deg, rgba(24, 28, 41, .96), rgba(13, 15, 28, .96)) !important;
  border: 1px solid rgba(127, 149, 192, .20) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03), 0 8px 18px rgba(0,0,0,.18) !important;
}

#screenHostSetup .hostSetupLayout > .setupMainCard .roleFooterRow .tinyNote{
  max-width: 430px !important;
  margin-top: 0 !important;
  text-align: right !important;
  font-size: 13px !important;
  color: rgba(255,255,255,.58) !important;
}

#screenHostSetup .hostSetupLayout > .setupSideCard .setupBadge{
  display: inline-flex !important;
  align-self: flex-start !important;
  padding: 9px 16px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  letter-spacing: .18em !important;
  color: #83eaff !important;
  background: rgba(17, 84, 108, .20) !important;
  border: 1px solid rgba(79, 214, 255, .34) !important;
}

#screenHostSetup .hostSetupLayout > .setupSideCard .previewTitle{
  margin-top: 18px !important;
  font-size: 24px !important;
  font-weight: 1000 !important;
  color: #ffffff !important;
}

#screenHostSetup .hostSetupLayout > .setupSideCard .previewList{
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  margin-top: 12px !important;
}

#screenHostSetup .hostSetupLayout > .setupSideCard .previewItem{
  padding: 16px 16px 14px !important;
  border-radius: 19px !important;
  background: rgba(255,255,255,.04) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.01) !important;
}

#screenHostSetup .hostSetupLayout > .setupSideCard .previewItem strong{
  display: block !important;
  font-size: 16px !important;
  color: #ffffff !important;
}

#screenHostSetup .hostSetupLayout > .setupSideCard .previewItem span{
  display: block !important;
  margin-top: 6px !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  color: rgba(255,255,255,.66) !important;
}

@media (max-width: 1180px){
  #screenHostSetup .hostSetupLayout{
    grid-template-columns: 1fr !important;
  }

  #screenHostSetup .hostSetupLayout > .setupMainCard .roleFooterRow{
    flex-direction: column !important;
    align-items: stretch !important;
  }

  #screenHostSetup .hostSetupLayout > .setupMainCard .roleFooterRow .tinyNote{
    max-width: none !important;
    text-align: center !important;
  }
}
