/*
 * LottaCash — single stylesheet (all fragments merged).
 * Rebuild: node scripts/merge-styles.mjs
 * See merge-styles.mjs header for cascade / conflict rules.
 */


@import url("https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=DM+Sans:ital,wght@0,400;0,500;0,700;1,400&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow:wght@400;500;600;700&display=swap");

/* Layer order: legacy < misc < games (later layers win over earlier on tie) */
@layer lc-legacy-pages, lc-misc, lc-games;


/*
  LottaCash v2 design tokens — single source for the rebuilt UI.
  Palette: deep space + electric lime accent (fresh but on-brand).
*/
:root {
  --lc-bg-deep: #030406;
  --lc-bg: #07090f;
  --lc-surface: #0c0f18;
  --lc-elevated: #141824;
  --lc-elevated2: #1a1f2e;
  --lc-accent: #c8ff4a;
  --lc-accent-soft: rgba(200, 255, 74, 0.14);
  --lc-accent-warm: #f0e05a;
  --lc-danger: #f87171;
  --lc-success: #4ade80;
  --lc-text: #f4f5f9;
  --lc-muted: #949ab8;
  --lc-line: rgba(255, 255, 255, 0.065);
  --lc-line-strong: rgba(255, 255, 255, 0.12);
  --lc-shadow: 0 18px 50px rgba(0, 0, 0, 0.55);
  --lc-radius-sm: 10px;
  --lc-radius: 14px;
  --lc-radius-lg: 22px;
  --lc-sidebar-w: 240px;
  --lc-nav-h: 48px;
  --lc-font-ui: 'DM Sans', system-ui, sans-serif;
  --lc-font-display: 'Syne', sans-serif;

  /* Aliases used across legacy skins + shell */
  --bg: var(--lc-bg);
  --bg2: var(--lc-surface);
  --bg3: var(--lc-elevated);
  --bg4: var(--lc-elevated2);
  --gold: var(--lc-accent);
  --gold2: var(--lc-accent-warm);
  --red: var(--lc-danger);
  --green: var(--lc-success);
  --text: var(--lc-text);
  --muted: var(--lc-muted);
  --border: var(--lc-line);
  --border2: var(--lc-line-strong);
  --radius: var(--lc-radius);
  --sidebar-w: var(--lc-sidebar-w);
  --nav-h: var(--lc-nav-h);
}

/* Global base: scrollbar, form selects, box model */
/* === scrollbar.css === */
/*
  Dark-theme scrollbars site-wide (Firefox scrollbar-* + WebKit pseudo-elements).
  Linked from pages that do not load play/play-shell.css (which imports this file).
*/
html {
  color-scheme: dark;
  margin: 0;
}

*,
*::before,
*::after {
  scrollbar-width: thin;
  scrollbar-color: #4a5168 #141821;
}

*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

*::-webkit-scrollbar-track {
  background: #141821;
  border-radius: 999px;
}

*::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #5c6478 0%, #3d4458 100%);
  border-radius: 999px;
  border: 2px solid #141821;
  min-height: 32px;
}

*::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #6a7288 0%, #4d5468 100%);
}

*::-webkit-scrollbar-thumb:active {
  background: #c6f13533;
  border-color: rgba(198, 241, 53, 0.35);
}

*::-webkit-scrollbar-corner {
  background: #141821;
}


/* === theme-selects.css === */
/* Themed native <select> — matches casino dark panels (~#343049) */
select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  color-scheme: dark;
  background-color: #343049;
  color: #f0f0f0;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: 0.5rem 2.35rem 0.5rem 0.85rem;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  min-height: 40px;
  line-height: 1.25;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23c6f135' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.72rem center;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}
select:hover {
  border-color: rgba(198, 241, 53, 0.35);
}
select:focus {
  outline: none;
  border-color: rgba(198, 241, 53, 0.5);
  box-shadow: 0 0 0 3px rgba(198, 241, 53, 0.12);
}
select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; }

/* Scrollbars, selects, box model — shared chrome */
html {
  color-scheme: dark;
  margin: 0;
}

*,
*::before,
*::after {
  scrollbar-width: thin;
  scrollbar-color: #5a6278 #0d1018;
}

*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

*::-webkit-scrollbar-track {
  background: #0d1018;
  border-radius: 999px;
}

*::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #5d657c 0%, #3e4558 100%);
  border-radius: 999px;
  border: 2px solid #0d1018;
  min-height: 32px;
}

*::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #6d758c 0%, #505870 100%);
}

*::-webkit-scrollbar-thumb:active {
  background: rgba(200, 255, 74, 0.25);
  border-color: rgba(200, 255, 74, 0.35);
}

*::-webkit-scrollbar-corner {
  background: #0d1018;
}

select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  color-scheme: dark;
  background-color: var(--lc-elevated);
  color: var(--lc-text);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  padding: 0.5rem 2.35rem 0.5rem 0.85rem;
  font-family: var(--lc-font-ui);
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  min-height: 40px;
  line-height: 1.25;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23c8ff4a' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.72rem center;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

select:hover {
  border-color: rgba(200, 255, 74, 0.35);
}

select:focus {
  outline: none;
  border-color: rgba(200, 255, 74, 0.55);
  box-shadow: 0 0 0 3px rgba(200, 255, 74, 0.12);
}

select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Hide native steppers on number fields (wager boxes on games, dashboard amounts, etc.) */
input[type='number']::-webkit-outer-spin-button,
input[type='number']::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type='number'] {
  appearance: textfield;
  -moz-appearance: textfield;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
}

/* === play-shell.css (no nested imports) === */

/* Tokens: see css/v2/tokens.css (--bg, --gold, --sidebar-w, …) */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CASINO-POST BUSY STATE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.lotta-casino-post-busy.with-play-shell button:not(:disabled),
body.lotta-casino-post-busy.with-play-shell .btn:not(:disabled) {
  cursor: progress !important;
  opacity: 0.92 !important;
}
body.lotta-casino-post-busy.with-play-shell nav .balance-pill {
  animation: lottaCasinoPulse 0.9s ease-in-out infinite;
}
@keyframes lottaCasinoPulse {
  0%,100% { opacity: 1 }
  50%      { opacity: 0.72 }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SIDEBAR — fixed left nav
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sidebar.site-nav-sidebar {
  position: fixed !important;
  left: 0; top: 0;
  width: var(--sidebar-w);
  height: 100vh;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex !important;
  flex-direction: column;
  padding: 1.5rem 0.85rem;
  overflow-y: auto;
  z-index: 9999;
  visibility: visible !important;
  opacity: 1 !important;
}
.sidebar.site-nav-sidebar .logo {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 1.32rem;
  color: var(--text);
  text-decoration: none;
  padding: 0 0.5rem;
  margin-bottom: 1.75rem;
  display: block;
  letter-spacing: -0.01em;
}
.sidebar.site-nav-sidebar .logo span { color: var(--gold); }
.sidebar.site-nav-sidebar .nav-section {
  font-size: 0.62rem;
  font-weight: 800;
  color: var(--muted);
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 0 0.5rem;
  margin: 1.1rem 0 0.35rem;
}
.sidebar.site-nav-sidebar .nav-item {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.58rem 0.75rem;
  border-radius: 9px;
  text-decoration: none;
  color: var(--muted);
  font-size: 0.875rem;
  font-weight: 600;
  transition: background 0.13s, color 0.13s;
  cursor: pointer;
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
}
.sidebar.site-nav-sidebar .nav-item:hover {
  background: rgba(255,255,255,0.04);
  color: var(--text);
}
.sidebar.site-nav-sidebar .nav-item.active,
.sidebar.site-nav-sidebar .nav-item.game-link.active {
  background: rgba(198,241,53,0.1);
  color: var(--gold);
}
.sidebar.site-nav-sidebar .nav-item.game-link { color: var(--muted); }
.sidebar.site-nav-sidebar .nav-item.game-link:hover {
  background: rgba(198,241,53,0.05);
  color: var(--gold);
}
.sidebar.site-nav-sidebar .nav-item.nav-muted {
  opacity: 0.4; cursor: default; pointer-events: none;
}
.sidebar.site-nav-sidebar .sidebar-bottom {
  margin-top: auto;
  border-top: 1px solid var(--border);
  padding-top: 0.9rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.sidebar.site-nav-sidebar .play-shell-auth-link { color: #fc8181; }
.sidebar.site-nav-sidebar .play-shell-auth-link:hover {
  color: #ffdfe2;
  background: rgba(229,62,62,0.08);
}
.sidebar.site-nav-sidebar .user-pill {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.75rem;
  border-radius: 9px;
}
.sidebar.site-nav-sidebar .avatar {
  width: 34px; height: 34px;
  border-radius: 50%;
  background: rgba(198,241,53,0.1);
  border: 1px solid rgba(198,241,53,0.22);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; font-weight: 800; color: var(--gold);
  flex-shrink: 0;
}

/* Dashboard-style shell sidebar (matches body.page-dashboard nav treatment) */
body.with-play-shell .sidebar.lc-dash-sidebar {
  background: linear-gradient(165deg, rgba(20, 24, 36, 0.97), rgba(10, 12, 18, 0.99));
  border-right-color: rgba(255, 255, 255, 0.08);
  box-shadow: 12px 0 40px rgba(0, 0, 0, 0.35);
  padding: 1.35rem 1rem 1rem;
}
body.with-play-shell .sidebar.lc-dash-sidebar .logo {
  font-family: var(--lc-font-display, 'Syne', sans-serif);
  font-size: 1.42rem;
  letter-spacing: -0.03em;
}
body.with-play-shell .sidebar.lc-dash-sidebar .logo span {
  color: var(--lc-accent, #c8ff4a);
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-section {
  letter-spacing: 0.22em;
  margin: 1rem 0 0.45rem;
  opacity: 0.85;
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-item {
  padding: 0.52rem 0.72rem;
  border-radius: 11px;
  border: 1px solid transparent;
  font-size: 0.84rem;
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-item svg {
  flex-shrink: 0;
  opacity: 0.88;
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-item:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--lc-text, #f0f0f0);
  border-color: rgba(255, 255, 255, 0.06);
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-item.active {
  background: linear-gradient(135deg, rgba(200, 255, 74, 0.16), rgba(200, 255, 74, 0.06));
  border-color: rgba(200, 255, 74, 0.22);
  color: var(--lc-accent, #c8ff4a);
  box-shadow: 0 4px 20px rgba(200, 255, 74, 0.08);
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-item.game-link:hover {
  background: rgba(200, 255, 74, 0.07);
  color: var(--lc-accent, #c8ff4a);
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-item.nav-item-logout {
  margin-top: 0.35rem;
  color: var(--lc-danger, #f87171) !important;
}
body.with-play-shell .sidebar.lc-dash-sidebar .nav-item.nav-item-logout:hover {
  background: rgba(248, 113, 113, 0.1);
  border-color: rgba(248, 113, 113, 0.2);
  color: #fca5a5 !important;
}
body.with-play-shell .sidebar.lc-dash-sidebar .user-pill {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
}
body.with-play-shell .sidebar.lc-dash-sidebar .sidebar-name {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--lc-text, #f0f0f0);
}
body.with-play-shell .sidebar.lc-dash-sidebar .sidebar-email {
  font-size: 0.72rem;
  color: var(--lc-muted, #8b8fa8);
}
body.with-play-shell .sidebar.lc-dash-sidebar .avatar {
  width: 36px;
  height: 36px;
  background: linear-gradient(145deg, rgba(200, 255, 74, 0.18), rgba(124, 92, 255, 0.12));
  border-color: rgba(200, 255, 74, 0.25);
  color: var(--lc-accent, #c8ff4a);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SHELL BODY LAYOUT
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell {
  --bg:#0b0d14; --bg2:#13151f; --bg3:#171a26; --bg4:#1e2130;
  --gold:#c6f135; --gold2:#f5d96a; --red:#e24b4a; --green:#41c77a;
  --text:#f0f0f0; --muted:#8b8fa8;
  --border:rgba(255,255,255,0.07); --border2:rgba(255,255,255,0.12);
  --radius:14px;
  margin: 0 !important;
  min-height: 100vh;
  overflow: hidden;
  padding-left: var(--sidebar-w);
  font-family: 'DM Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
}
body.with-play-shell.play-shell-lobby {
  overflow: auto;
  height: auto;
  padding-left: var(--sidebar-w) !important;
  overflow-x: hidden;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   TOP NAVBAR — consistent across ALL pages
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* Wrapper for landmark semantics only — bar layout unchanged */
body.with-play-shell header.game-header {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
}

body.with-play-shell header.game-header[data-lc-has-br-strip] {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

body.with-play-shell .lc-br-shell-strip {
  box-sizing: border-box;
  width: 100%;
  padding: env(safe-area-inset-top, 0) max(0.75rem, env(safe-area-inset-right)) 0 max(0.85rem, env(safe-area-inset-left));
  background: rgba(12, 15, 24, 0.82);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 10002;
  backdrop-filter: blur(18px);
}

body.with-play-shell nav {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 0.75rem !important;
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  min-height: var(--nav-h) !important;
  /* Tight right edge; slight inset from main column start */
  padding: env(safe-area-inset-top, 0) max(0.35rem, env(safe-area-inset-right)) 0 max(0.65rem, env(safe-area-inset-left)) !important;
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--border) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 10001 !important;
  left: auto !important;
  right: auto !important;
}

body.with-play-shell header.game-header[data-lc-has-br-strip] nav.br-top {
  top: 0;
  position: relative;
  z-index: 10001;
}

/* Dashboard-style top row (title + cashier + balance) */
body.with-play-shell nav .lc-app-topbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 0.75rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
body.with-play-shell nav .lc-app-topbar .page-title {
  font-family: var(--lc-font-display, 'Syne', sans-serif) !important;
  font-size: clamp(1.05rem, 2.2vw, 1.35rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  color: var(--lc-text, #f0f0f0) !important;
  margin: 0 !important;
  line-height: 1.15 !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-right {
  display: inline-flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 0.55rem !important;
  margin-left: auto !important;
  justify-content: flex-end !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-cashier-links {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.45rem !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-cashier-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0.38rem 0.85rem !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  color: var(--lc-text, #f0f0f0) !important;
  text-decoration: none !important;
  font-size: 0.74rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-cashier-link:hover {
  border-color: rgba(200, 255, 74, 0.45) !important;
  background: rgba(200, 255, 74, 0.1) !important;
  color: var(--lc-accent, #c8ff4a) !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-balance-pill {
  display: inline-flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 0.35rem !important;
  max-width: min(100%, 52vw) !important;
  padding: 0.38rem 0.95rem !important;
  background: linear-gradient(135deg, rgba(200, 255, 74, 0.12), rgba(255, 255, 255, 0.04)) !important;
  border: 1px solid rgba(200, 255, 74, 0.22) !important;
  border-radius: 999px !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-balance-pill .lbl {
  font-size: 0.76rem !important;
  color: var(--lc-muted, #8b8fa8) !important;
  font-weight: 600 !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-balance-pill #balanceDisplay {
  display: inline-flex !important;
  flex-wrap: wrap !important;
  align-items: baseline !important;
  gap: 0.12rem !important;
  font-size: clamp(0.72rem, 1.4vw, 0.95rem) !important;
  font-weight: 600 !important;
  line-height: 1.25 !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-balance-pill #balanceDisplay .lotta-bal-main {
  font-family: var(--lc-font-display, 'Syne', sans-serif) !important;
  font-weight: 800 !important;
  color: var(--lc-accent, #c8ff4a) !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-balance-pill #balanceDisplay .lotta-bal-sep {
  color: var(--lc-muted, #8b8fa8) !important;
  font-weight: 600 !important;
}
body.with-play-shell nav .lc-app-topbar .topbar-balance-pill #balanceDisplay .lotta-bal-fiat {
  color: var(--lc-muted, #8b8fa8) !important;
  font-weight: 600 !important;
  padding-left: 0 !important;
  border-left: none !important;
  margin-left: 0 !important;
}

body.page-lobby.with-play-shell .site-header nav {
  max-width: none !important;
  margin: 0 auto !important;
  padding-left: max(0.75rem, env(safe-area-inset-left)) !important;
  padding-right: max(0.75rem, env(safe-area-inset-right)) !important;
}

body.page-auth.with-play-shell .auth-header .auth-nav {
  max-width: none !important;
  margin: 0 !important;
  width: 100% !important;
}

body.page-legal.with-play-shell .legal-header .legal-nav {
  max-width: none !important;
  margin: 0 !important;
  width: 100% !important;
}

body.with-play-shell nav .logo,
body.with-play-shell nav .topbar-dashboard-link {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.84rem !important;
  color: var(--muted) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0.38rem 0.85rem !important;
  border-radius: 999px !important;
  border: 1px solid var(--border2) !important;
  background: rgba(255,255,255,0.04) !important;
  letter-spacing: 0 !important;
  transition: color 0.15s, border-color 0.15s, background 0.15s !important;
  white-space: nowrap !important;
}
body.with-play-shell nav .logo:hover,
body.with-play-shell nav .topbar-dashboard-link:hover,
body.with-play-shell nav .topbar-dashboard-link.active {
  color: var(--gold) !important;
  border-color: rgba(198,241,53,0.35) !important;
  background: rgba(198,241,53,0.08) !important;
}
body.with-play-shell nav .nav-back {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  color: var(--muted) !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  pointer-events: none !important;
}
body.with-play-shell nav .lotta-nav-right {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.45rem !important;
  margin-left: auto !important;
}
body.with-play-shell nav .lotta-cashier-links {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
}
body.with-play-shell nav .lotta-cashier-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 32px !important;
  padding: 0.3rem 0.72rem !important;
  border-radius: 999px !important;
  border: 1px solid var(--border2) !important;
  background: rgba(255,255,255,0.04) !important;
  color: var(--muted) !important;
  text-decoration: none !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  transition: background 0.15s, border-color 0.15s, color 0.15s !important;
}
body.with-play-shell nav .lotta-cashier-link:hover {
  border-color: rgba(198,241,53,0.35) !important;
  background: rgba(198,241,53,0.08) !important;
  color: var(--gold) !important;
}
body.with-play-shell nav .balance-pill {
  background: var(--bg3) !important;
  border: 1px solid var(--border2) !important;
  color: var(--gold) !important;
  border-radius: 999px !important;
  font-family: 'Syne', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  padding: 0.36rem 0.9rem !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  white-space: nowrap !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2) !important;
  line-height: 1 !important;
}
body.with-play-shell nav .balance-pill .lotta-bal-main {
  display: inline !important;
  font-size: 0.86rem !important;
  color: var(--gold) !important;
  font-weight: 700 !important;
}
body.with-play-shell nav .balance-pill .lotta-bal-fiat {
  display: inline !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  color: var(--muted) !important;
  padding-left: 0.45rem !important;
  border-left: 1px solid var(--border2) !important;
  margin-left: 0.1rem !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PAGE CONTENT AREAS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell .wrap,
body.with-play-shell .game-wrap,
body.with-play-shell .page,
body.with-play-shell .cb-page {
  height: calc(100vh - var(--nav-h));
  overflow: auto;
  padding: 1rem 1.5rem 1.25rem;
  box-sizing: border-box;
  justify-content: flex-start !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
/* game-wrap uses flex column — stretch children, no dead vertical centering */
body.with-play-shell .game-wrap {
  align-items: stretch !important;
}
/* inner game layout (controls + board) fills remaining height */
body.with-play-shell .game-layout,
body.with-play-shell .game-main {
  flex: 1 1 0 !important;
  min-height: 0 !important;
}
/* board column always stretches */
body.with-play-shell .board-col,
body.with-play-shell .table-col {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
}
body.with-play-shell .board-col > .panel,
body.with-play-shell .board-col > .board,
body.with-play-shell .table-col > .felt,
body.with-play-shell .table-col > .panel {
  flex: 1 1 0 !important;
  min-height: 0 !important;
}
/* felt (blackjack table) fills its column */
body.with-play-shell .felt {
  flex: 1 1 0 !important;
  min-height: 0 !important;
}
/* Blackjack result overlay: keep board visible behind result text. */
body.page-blackjack .felt .result-banner {
  position: absolute !important;
  inset: 0 !important;
  z-index: 4 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 16px !important;
  background: rgba(0, 0, 0, 0.42) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.3s !important;
}
body.page-blackjack .felt .result-banner.show {
  opacity: 1 !important;
}
body.page-blackjack .felt .result-text {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 4rem !important;
  letter-spacing: 4px !important;
}
body.page-blackjack .felt .result-sub {
  color: var(--muted) !important;
}

/* Plinko: avoid global overflow clipping from other games (e.g. crash). */
body.page-plinko .board-col {
  overflow: visible !important;
}
body.page-plinko .board {
  overflow: visible !important;
}
/* fx-panel (dice/limbo/crash visual area) fills its column */
body.with-play-shell .fx-panel {
  flex: 1 1 0 !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
}
body.with-play-shell .dice-scene,
body.with-play-shell .limbo-scene,
body.with-play-shell .crash-scene {
  flex: 1 1 0 !important;
  min-height: 0 !important;
}
/* controls column — wider on large screens */
body.with-play-shell .controls-col,
body.with-play-shell .controls {
  flex: 0 0 280px !important;
  width: 280px !important;
  max-width: 280px !important;
}
/* keno side panel */
body.with-play-shell .side {
  flex: 0 0 300px !important;
  width: 300px !important;
  max-width: 300px !important;
}
/* keno layout: stretch the whole grid */
body.with-play-shell .layout {
  flex: 1 1 0 !important;
  min-height: 0 !important;
}
body.with-play-shell .board-wrap {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 0 !important;
  min-height: 0 !important;
}
/* mines */
body.with-play-shell .game-body {
  flex: 1 1 0 !important;
  align-items: stretch !important;
  min-height: 0 !important;
}
body.with-play-shell .game-controls {
  flex: 0 0 280px !important;
  max-width: 280px !important;
}
body.with-play-shell .mines-play-col {
  flex: 1 1 0 !important;
  min-height: 0 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 1rem !important;
}
/* Cap grid by vmin so the 5×5 square fits without vertical overflow; keep tiles 1:1 via .mtile */
body.with-play-shell .mines-board {
  flex: 0 0 auto !important;
  width: min(560px, calc(100vmin - 5.5rem)) !important;
  max-width: min(560px, calc(100vmin - 5.5rem), 100%) !important;
}
/* plinko board fills its column */
body.with-play-shell .board {
  flex: 1 1 0 !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   TYPOGRAPHY RHYTHM
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell h1,
body.with-play-shell .game-title {
  font-family: 'Syne', sans-serif !important;
  font-size: 1.8rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.25px !important;
  line-height: 1.08 !important;
  margin: 0 !important;
  text-align: center !important;
}
body.with-play-shell .disclaimer,
body.with-play-shell .rules-strip,
body.with-play-shell .wrap > .disclaimer,
body.with-play-shell .game-wrap .rules-strip,
body.with-play-shell .page .keno-head p {
  margin-top: 0.4rem !important;
  margin-bottom: 1rem !important;
  color: var(--muted) !important;
  font-size: 0.73rem !important;
  line-height: 1.5 !important;
}
body.with-play-shell .disclaimer,
body.with-play-shell .rules-strip,
body.with-play-shell .wrap > .disclaimer,
body.with-play-shell .game-wrap .rules-strip {
  text-align: center !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PANELS & CARDS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell .panel,
body.with-play-shell .board,
body.with-play-shell .board-wrap,
body.with-play-shell .bj-panel {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.2) !important;
}
body.with-play-shell .panel h3,
body.with-play-shell .panel .panel-title,
body.with-play-shell .bj-panel-title,
body.with-play-shell .panel-title {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.63rem !important;
  font-weight: 700 !important;
  letter-spacing: 1.8px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  margin-bottom: 0.7rem !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FORM INPUTS & LABELS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell input[type=number],
body.with-play-shell input[type=text] {
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid var(--border2) !important;
  color: var(--text) !important;
  border-radius: 10px !important;
  font-family: 'DM Sans', sans-serif !important;
  outline: none !important;
  transition: border-color 0.15s !important;
}
body.with-play-shell input[type=number]:focus,
body.with-play-shell input[type=text]:focus {
  border-color: rgba(198,241,53,0.4) !important;
}
body.with-play-shell label,
body.with-play-shell .area-label,
body.with-play-shell .bet-input label {
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  color: var(--muted) !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   BUTTONS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell .btn,
body.with-play-shell .btn-action,
body.with-play-shell .btn-primary,
body.with-play-shell .btn-cashout {
  border-radius: 999px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 700 !important;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.13s !important;
}
body.with-play-shell .btn:disabled,
body.with-play-shell .btn-action:disabled,
body.with-play-shell .btn-primary:disabled {
  opacity: 0.3 !important; cursor: not-allowed !important; transform: none !important;
}
body.with-play-shell .btn-start,
body.with-play-shell .btn-deal,
body.with-play-shell .btn-play,
body.with-play-shell .btn-primary,
body.with-play-shell .btn-accent {
  background: var(--gold) !important;
  color: #0b0d14 !important;
  border: none !important;
}
body.with-play-shell .btn-start:not(:disabled):hover,
body.with-play-shell .btn-deal:not(:disabled):hover,
body.with-play-shell .btn-play:not(:disabled):hover,
body.with-play-shell .btn-primary:not(:disabled):hover { opacity: 0.9 !important; transform: translateY(-1px) !important; }

body.with-play-shell .btn-hit,
body.with-play-shell .btn-cash,
body.with-play-shell .btn-cashout {
  background: #163f2a !important; color: #9effd4 !important;
  border: 1px solid rgba(65,199,122,0.4) !important;
}
body.with-play-shell .btn-stand,
body.with-play-shell .btn-surrender {
  background: #2e1316 !important; color: #ffc2c2 !important;
  border: 1px solid rgba(226,75,74,0.35) !important;
}
body.with-play-shell .btn-double,
body.with-play-shell .btn-split,
body.with-play-shell .btn-insure {
  background: #1a2240 !important; color: #bbc8f8 !important;
  border: 1px solid rgba(100,130,240,0.3) !important;
}
body.with-play-shell .btn-ghost,
body.with-play-shell .cb-mini,
body.with-play-shell .br-tool-btn,
body.with-play-shell .exit {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid var(--border2) !important;
  color: var(--muted) !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  font-family: 'DM Sans', sans-serif !important;
}
body.with-play-shell .btn-ghost:hover,
body.with-play-shell .cb-mini:hover,
body.with-play-shell .br-tool-btn:hover {
  border-color: rgba(198,241,53,0.35) !important;
  color: var(--gold) !important;
  background: rgba(198,241,53,0.06) !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WAGER ROW
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell .wager-row,
body.with-play-shell .lotta-wager-bar {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 0.4rem !important;
  width: 100% !important;
}
body.with-play-shell .wager-row #betInput,
body.with-play-shell .lotta-wager-bar #betInput {
  flex: 0 0 auto !important;
  width: 5.4rem !important;
  min-width: 5.4rem !important;
  height: 40px !important;
  margin: 0 !important;
  text-align: center !important;
  font-variant-numeric: tabular-nums;
}
body.with-play-shell .wager-row .btn-bet-adjust,
body.with-play-shell .lotta-wager-bar .btn-bet-adjust {
  flex: 1 1 0 !important;
  height: 40px !important;
  min-width: 2.6rem !important;
  max-width: 5rem !important;
  padding: 0 0.5rem !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 9px !important;
  border: 1px solid rgba(198,241,53,0.25) !important;
  background: rgba(198,241,53,0.07) !important;
  color: var(--gold) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: background 0.13s, border-color 0.13s !important;
}
body.with-play-shell .wager-row .btn-bet-adjust:hover,
body.with-play-shell .lotta-wager-bar .btn-bet-adjust:hover {
  background: rgba(198,241,53,0.15) !important;
  border-color: rgba(198,241,53,0.5) !important;
}

/* Auto-injected shortcuts */
body.with-play-shell .lotta-bet-shortcuts {
  display: flex; flex-wrap: wrap; gap: 0.4rem;
  width: 100%; justify-content: center; margin-top: 0.35rem;
}
body.with-play-shell .lotta-bet-chip {
  flex: 1 1 0; min-width: 58px;
  padding: 0.48rem 0.62rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.09);
  background: rgba(255,255,255,0.04);
  color: var(--muted);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.75rem; font-weight: 700;
  cursor: pointer;
  transition: background 0.13s, border-color 0.13s, color 0.13s, transform 0.1s;
}
body.with-play-shell .lotta-bet-chip:hover {
  border-color: rgba(198,241,53,0.35);
  background: rgba(198,241,53,0.08);
  color: var(--gold);
  transform: translateY(-1px);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   TOGGLE / RISK / TAB BUTTONS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell .risk-btn.active,
body.with-play-shell .tabs button.on,
body.with-play-shell .cb-filter.on,
body.with-play-shell .mode.on {
  border-color: rgba(198,241,53,0.45) !important;
  background: rgba(198,241,53,0.1) !important;
  color: var(--gold) !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DISPLAY VALUES
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell .mult,
body.with-play-shell .mult-big,
body.with-play-shell .out,
body.with-play-shell .roll-big,
body.with-play-shell .stat-pill-val,
body.with-play-shell #playerScore,
body.with-play-shell #dealerScore {
  color: var(--gold) !important;
  font-family: 'Syne', sans-serif !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   GAME-SPECIFIC GLOBAL OVERRIDES
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.with-play-shell .knum.selected:not(.hit) {
  background: rgba(198,241,53,0.15) !important;
  border-color: rgba(198,241,53,0.55) !important;
  color: var(--gold) !important;
}
body.with-play-shell .mtile.gem {
  background: rgba(65,199,122,0.15) !important;
  border-color: rgba(65,199,122,0.5) !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SESSION TRACKER FAB + PANEL
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.lotta-session-fab {
  position: fixed; z-index: 10002;
  left: calc(var(--sidebar-w) + 12px); bottom: 14px;
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid rgba(198,241,53,0.4);
  background: rgba(19,21,31,0.97);
  color: var(--gold); font-family: 'Syne', sans-serif;
  font-weight: 800; font-size: 0.95rem; cursor: pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
  transition: transform 0.15s, border-color 0.15s;
  display: flex; align-items: center; justify-content: center;
}
.lotta-session-fab:hover { transform: translateY(-2px); border-color: var(--gold); }
.lotta-session-panel {
  position: fixed; z-index: 10003; display: none; flex-direction: column; gap: 0.4rem;
  width: 215px; max-width: calc(100vw - 24px);
  padding: 0.55rem 0.65rem 0.65rem;
  border-radius: 12px; border: 1px solid rgba(255,255,255,0.1);
  background: rgba(11,13,20,0.97);
  box-shadow: 0 12px 40px rgba(0,0,0,0.55);
  font-family: 'DM Sans', sans-serif; font-size: 0.72rem; color: var(--text);
  user-select: none;
}
.lotta-session-panel.is-open { display: flex; }
.lotta-session-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  cursor: grab; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--muted); font-size: 0.62rem;
  padding-bottom: 0.15rem; border-bottom: 1px solid rgba(255,255,255,0.06);
}
.lotta-session-panel-head.is-dragging { cursor: grabbing; }
.lotta-session-close { border: none; background: transparent; color: var(--muted); font-size: 1.1rem; line-height: 1; cursor: pointer; padding: 0 0.2rem; }
.lotta-session-close:hover { color: var(--text); }
.lotta-session-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0.3rem; text-align: center; }
.lotta-session-cell span { display: block; font-size: 0.58rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.lotta-session-cell b { display: block; font-size: 0.9rem; font-weight: 800; color: var(--text); }
.lotta-session-net { display: flex; flex-direction: column; gap: 0.1rem; padding: 0.3rem 0.25rem; border-radius: 8px; background: rgba(255,255,255,0.03); }
.lotta-session-net span { font-size: 0.58rem; color: var(--muted); text-transform: uppercase; }
.lotta-session-net b   { font-size: 0.78rem; font-weight: 700; }
.lotta-session-reset { width: 100%; padding: 0.36rem 0.5rem; border-radius: 8px; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.67rem; font-weight: 700; cursor: pointer; }
.lotta-session-reset:hover { border-color: rgba(198,241,53,0.35); color: var(--gold); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE — Tablet (≤980px)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 980px) {
  :root { --sidebar-w: 200px; }
  body.with-play-shell { overflow: auto; }
  body.with-play-shell .wrap,
  body.with-play-shell .game-wrap,
  body.with-play-shell .page { height: auto; overflow: visible; }
  .sidebar.site-nav-sidebar { width: 200px; }
  body.with-play-shell .controls-col,
  body.with-play-shell .controls {
    flex: 0 0 260px !important;
    width: 260px !important;
    max-width: 260px !important;
  }
  body.with-play-shell .side {
    flex: 0 0 260px !important;
    width: 260px !important;
    max-width: 260px !important;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE — Mobile (≤760px)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 760px) {
  :root { --sidebar-w: 0px; --nav-h: 52px; }
  .sidebar.site-nav-sidebar {
    position: fixed !important; left: 0; right: 0; top: 0;
    width: 100% !important; height: auto !important; min-height: 52px;
    border-right: none; border-bottom: 1px solid var(--border);
    padding: 0.4rem 0.6rem;
    flex-direction: row !important; align-items: center; gap: 0.3rem;
    overflow-x: auto; overflow-y: hidden; white-space: nowrap;
  }
  .sidebar.site-nav-sidebar .logo { margin: 0 0.3rem 0 0; padding: 0 0.3rem; font-size: 0.95rem; flex: 0 0 auto; margin-bottom: 0; }
  .sidebar.site-nav-sidebar .nav-section { display: none; }
  .sidebar.site-nav-sidebar .nav-item { width: auto; padding: 0.4rem 0.6rem; font-size: 0.78rem; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.02); flex: 0 0 auto; border-radius: 8px; }
  .sidebar.site-nav-sidebar .sidebar-bottom { margin-top: 0; padding-top: 0; border-top: none; flex-direction: row; gap: 0.3rem; flex: 0 0 auto; }
  .sidebar.site-nav-sidebar .user-pill { padding: 0.15rem 0.3rem; }
  .sidebar.site-nav-sidebar .user-pill > div div:last-child { display: none; }
  .sidebar.site-nav-sidebar .avatar { width: 24px; height: 24px; font-size: 0.65rem; }
  body.with-play-shell { padding-left: 0 !important; padding-top: 52px; overflow: auto; }
  body.with-play-shell .wrap,
  body.with-play-shell .game-wrap,
  body.with-play-shell .page,
  body.with-play-shell .cb-page { height: auto !important; overflow: visible !important; padding: 0.8rem !important; justify-content: flex-start !important; }
  body.with-play-shell .game-wrap { align-items: stretch !important; }
  body.with-play-shell .game-layout,
  body.with-play-shell .game-main { flex: 0 0 auto !important; }
  body.with-play-shell .board-col,
  body.with-play-shell .table-col { flex: 0 0 auto !important; }
  body.with-play-shell .fx-panel { flex: 0 0 auto !important; }
  body.with-play-shell .felt { flex: 0 0 auto !important; min-height: 340px !important; }
  body.with-play-shell .controls-col,
  body.with-play-shell .controls,
  body.with-play-shell .side,
  body.with-play-shell .game-controls { flex: 0 0 auto !important; width: 100% !important; max-width: 100% !important; }
  body.with-play-shell nav .nav-back { display: none !important; }
  .lotta-session-fab { left: 12px; bottom: 12px; }
  body.with-play-shell h1,
  body.with-play-shell .game-title { font-size: 1.5rem !important; }
  body.with-play-shell .controls-col,
  body.with-play-shell .controls,
  body.with-play-shell .side { width: 100% !important; max-width: 100% !important; }
  body.with-play-shell .felt { padding: 1rem !important; }
  body.with-play-shell .card { width: 56px !important; height: 82px !important; }
  body.with-play-shell .result-text { font-size: 2.4rem !important; }
  body.with-play-shell #kenoGrid { grid-template-columns: repeat(5,minmax(0,1fr)) !important; gap: 5px !important; }
  body.with-play-shell .action-row { gap: 0.5rem !important; }
  body.with-play-shell .btn-action { flex: 1 1 calc(50% - 0.5rem); min-width: 0; padding: 0.7rem 0.9rem !important; font-size: 0.88rem !important; }
}
@media (max-width: 520px) {
  body.with-play-shell .wrap,
  body.with-play-shell .game-wrap,
  body.with-play-shell .page,
  body.with-play-shell .cb-page { padding: 0.65rem !important; }
  body.with-play-shell h1,
  body.with-play-shell .game-title { font-size: 1.38rem !important; }
  body.with-play-shell .panel,
  body.with-play-shell .board-wrap,
  body.with-play-shell .felt,
  body.with-play-shell .board { padding: 0.85rem !important; border-radius: 12px !important; }
  body.with-play-shell .card { width: 48px !important; height: 70px !important; font-size: 1.05rem !important; }
  body.with-play-shell .card-corner { font-size: 0.62rem !important; }
  body.with-play-shell .card-suit { font-size: 1.25rem !important; }
  body.with-play-shell #kenoGrid { grid-template-columns: repeat(4,minmax(0,1fr)) !important; gap: 4px !important; }
  body.with-play-shell input[type=number],
  body.with-play-shell select { font-size: 16px !important; }
  body.with-play-shell .btn-action { flex-basis: 100%; }
}
@media (max-width: 480px) {
  .sidebar.site-nav-sidebar { padding: 0.3rem 0.4rem; min-height: 48px; gap: 0.22rem; }
  .sidebar.site-nav-sidebar .logo { font-size: 0.88rem; }
  .sidebar.site-nav-sidebar .nav-item { padding: 0.32rem 0.48rem; font-size: 0.72rem; }
  .sidebar.site-nav-sidebar .avatar { width: 22px; height: 22px; font-size: 0.6rem; }
  body.with-play-shell { padding-top: 48px; }
}

/*
  Marketing & auth — rebuilt from scratch, scoped by body.page-*.
  Does not touch game or dashboard layouts.
*/

/* ─── Lobby (index) ─── */
body.page-lobby {
  background: radial-gradient(1200px 600px at 50% -15%, rgba(80, 120, 255, 0.08), transparent 55%), var(--lc-bg-deep);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
  overflow-x: hidden;
}

body.page-lobby .site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(18px);
  background: rgba(12, 15, 24, 0.82);
  border-bottom: 1px solid var(--lc-line);
}

body.page-lobby .site-header nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: 1rem clamp(1rem, 3vw, 2rem);
}

body.page-lobby .logo {
  font-family: var(--lc-font-display);
  font-weight: 800;
  font-size: 1.35rem;
  color: var(--lc-text);
  text-decoration: none;
  letter-spacing: -0.02em;
}

body.page-lobby .logo span {
  color: var(--lc-accent);
}

body.page-lobby .nav-links {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 3vw, 2rem);
  list-style: none;
  margin: 0;
  padding: 0;
}

body.page-lobby .nav-links a {
  color: var(--lc-muted);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: color 0.15s;
}

body.page-lobby .nav-links a:hover {
  color: var(--lc-accent);
}

body.page-lobby .nav-cta {
  display: flex;
  gap: 0.65rem;
  align-items: center;
  margin-left: auto;
}

body.page-lobby .btn-outline {
  padding: 0.48rem 1.1rem;
  border-radius: var(--lc-radius-sm);
  border: 1px solid var(--lc-line-strong);
  background: transparent;
  color: var(--lc-text);
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}

body.page-lobby .btn-outline:hover {
  border-color: rgba(200, 255, 74, 0.45);
  color: var(--lc-accent);
}

body.page-lobby .btn-gold {
  padding: 0.48rem 1.2rem;
  border-radius: var(--lc-radius-sm);
  border: none;
  background: linear-gradient(135deg, var(--lc-accent), #a8e020);
  color: #0a0c10;
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.12s, filter 0.15s;
}

body.page-lobby .btn-gold:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

body.page-lobby .marquee-wrap {
  background: var(--lc-surface);
  border-block: 1px solid var(--lc-line);
  padding: 0.75rem 0;
  overflow: hidden;
}

body.page-lobby .marquee-track {
  display: flex;
  gap: 3rem;
  white-space: nowrap;
  animation: lc-marquee 28s linear infinite;
}

@keyframes lc-marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

body.page-lobby .marquee-item {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--lc-muted);
  letter-spacing: 0.04em;
}

body.page-lobby .marquee-item .win {
  color: var(--lc-accent);
}

body.page-lobby .hero {
  position: relative;
  min-height: min(88vh, 920px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(3rem, 8vw, 6rem) clamp(1rem, 4vw, 2rem);
}

body.page-lobby .hero-glow {
  position: absolute;
  inset: -20% -10% auto;
  height: 70vh;
  background: radial-gradient(ellipse, rgba(200, 255, 74, 0.06) 0%, transparent 62%);
  pointer-events: none;
}

body.page-lobby .live-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0.35rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(248, 113, 113, 0.35);
  background: rgba(248, 113, 113, 0.08);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fca5a5;
  margin-bottom: 1.5rem;
}

body.page-lobby .live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #f87171;
  animation: lc-blink 1.2s infinite;
}

@keyframes lc-blink {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.35;
  }
}

body.page-lobby .hero h1 {
  font-family: 'Bebas Neue', var(--lc-font-display), sans-serif;
  font-size: clamp(3.2rem, 11vw, 8.5rem);
  letter-spacing: 0.06em;
  line-height: 0.94;
  margin: 0;
}

body.page-lobby .hero h1 .gold-line {
  display: block;
  color: var(--lc-accent);
  text-shadow: 0 0 80px rgba(200, 255, 74, 0.35);
}

body.page-lobby .hero-sub {
  margin-top: 1.35rem;
  font-size: clamp(0.92rem, 2vw, 1.08rem);
  color: var(--lc-muted);
  max-width: 34rem;
  line-height: 1.65;
}

body.page-lobby .hero-actions {
  margin-top: 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  justify-content: center;
}

body.page-lobby .btn-hero {
  padding: 0.95rem 2.5rem;
  border-radius: var(--lc-radius-sm);
  border: none;
  background: linear-gradient(135deg, var(--lc-accent), #9fd620);
  color: #06080d;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  box-shadow: 0 12px 40px rgba(200, 255, 74, 0.22);
  transition: transform 0.12s, box-shadow 0.15s;
}

body.page-lobby .btn-hero:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 50px rgba(200, 255, 74, 0.3);
}

body.page-lobby .btn-hero-ghost {
  padding: 0.95rem 2rem;
  border-radius: var(--lc-radius-sm);
  border: 1px solid var(--lc-line-strong);
  background: rgba(255, 255, 255, 0.02);
  color: var(--lc-text);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  transition: border-color 0.15s, color 0.15s;
}

body.page-lobby .btn-hero-ghost:hover {
  border-color: rgba(200, 255, 74, 0.4);
  color: var(--lc-accent);
}

body.page-lobby .hero-stats {
  margin-top: 3rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  border-radius: var(--lc-radius);
  border: 1px solid var(--lc-line);
  background: rgba(255, 255, 255, 0.02);
  overflow: hidden;
}

body.page-lobby .hero-stat {
  padding: 1.15rem clamp(1.2rem, 3vw, 2.2rem);
  text-align: center;
  border-right: 1px solid var(--lc-line);
}

body.page-lobby .hero-stat:last-child {
  border-right: none;
}

body.page-lobby .hero-stat-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(1.6rem, 4vw, 2.1rem);
  letter-spacing: 0.06em;
  color: var(--lc-accent);
}

body.page-lobby .hero-stat-label {
  font-size: 0.68rem;
  color: var(--lc-muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-top: 0.35rem;
}

body.page-lobby .gold-line-div {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200, 255, 74, 0.35), transparent);
  opacity: 0.5;
}

body.page-lobby .sec {
  padding: clamp(3rem, 6vw, 5rem) clamp(1.25rem, 4vw, 2.5rem);
  max-width: 1200px;
  margin: 0 auto;
}

body.page-lobby .sec-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--lc-accent);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 0.45rem;
}

body.page-lobby .sec-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  letter-spacing: 0.06em;
  margin: 0 0 1rem;
}

body.page-lobby .games-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.15rem;
}

@media (max-width: 1200px) {
  body.page-lobby .games-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

body.page-lobby .game-card {
  border-radius: var(--lc-radius);
  border: 1px solid var(--lc-line);
  background: var(--lc-surface);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.18s, border-color 0.18s, box-shadow 0.18s;
}

body.page-lobby .game-card:hover {
  transform: translateY(-5px);
  border-color: rgba(200, 255, 74, 0.35);
  box-shadow: var(--lc-shadow);
}

body.page-lobby .game-thumb {
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5rem;
  position: relative;
}

body.page-lobby .game-thumb-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 42%, var(--lc-surface));
}

body.page-lobby .game-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  padding: 3px 9px;
  border-radius: 6px;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--lc-accent);
  border: 1px solid rgba(200, 255, 74, 0.35);
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(8px);
}

body.page-lobby .game-info {
  padding: 1rem 1.15rem 1.2rem;
}

body.page-lobby .game-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

body.page-lobby .game-meta {
  font-size: 0.8rem;
  color: var(--lc-muted);
  margin-top: 0.25rem;
}

body.page-lobby .game-edge {
  font-size: 0.74rem;
  margin-top: 0.45rem;
  display: flex;
  align-items: center;
  gap: 6px;
}

body.page-lobby .rtp {
  color: var(--lc-success);
  font-weight: 600;
}

body.page-lobby .wins-table {
  border-radius: var(--lc-radius);
  border: 1px solid var(--lc-line);
  background: var(--lc-surface);
  overflow: hidden;
}

body.page-lobby .wins-row {
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr 1fr;
  padding: 0.85rem 1.35rem;
  align-items: center;
  font-size: 0.88rem;
  border-bottom: 1px solid var(--lc-line);
  transition: background 0.12s;
}

body.page-lobby .wins-row:last-child {
  border-bottom: none;
}

body.page-lobby .wins-row:hover {
  background: rgba(255, 255, 255, 0.02);
}

body.page-lobby .wins-header {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--lc-muted);
  font-weight: 700;
}

body.page-lobby .wins-amount {
  font-weight: 700;
  color: var(--lc-accent);
}

body.page-lobby .wins-mult {
  color: var(--lc-success);
  font-weight: 700;
}

body.page-lobby .wins-user {
  color: var(--lc-muted);
  font-size: 0.82rem;
}

body.page-lobby footer {
  border-top: 1px solid var(--lc-line);
  padding: clamp(1.5rem, 4vw, 2.25rem);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

body.page-lobby .footer-links {
  display: flex;
  gap: 1.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

body.page-lobby .footer-links a {
  color: var(--lc-muted);
  font-size: 0.78rem;
  text-decoration: none;
  transition: color 0.15s;
}

body.page-lobby .footer-links a:hover {
  color: var(--lc-accent);
}

body.page-lobby .footer-copy {
  font-size: 0.76rem;
  color: var(--lc-muted);
}

body.page-lobby .reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

body.page-lobby .reveal.visible {
  opacity: 1;
  transform: none;
}

body.page-lobby .chip {
  position: absolute;
  font-size: 2rem;
  opacity: 0.06;
  animation: lc-float 18s linear infinite;
}

@keyframes lc-float {
  from {
    transform: translateY(100vh) rotate(0);
  }
  to {
    transform: translateY(-160px) rotate(360deg);
  }
}

/* Lobby + shell: extra padding when sidebar present */
body.page-lobby.with-play-shell .site-header nav {
  padding-left: clamp(1rem, 3vw, 2rem);
  padding-right: clamp(1rem, 3vw, 2rem);
}

@media (max-width: 900px) {
  body.page-lobby .nav-links {
    gap: 0.9rem;
  }

  body.page-lobby .games-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.page-lobby .hero {
    min-height: auto;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }

  body.page-lobby .wins-row {
    grid-template-columns: 1fr;
    gap: 0.2rem;
  }

  body.page-lobby .wins-header {
    display: none;
  }
}

@media (max-width: 560px) {
  body.page-lobby .nav-links {
    display: none;
  }

  body.page-lobby .games-grid {
    grid-template-columns: 1fr;
  }

  body.page-lobby .hero-stat {
    flex: 1 1 45%;
    border-right: none;
    border-bottom: 1px solid var(--lc-line);
  }

  body.page-lobby .hero-stats {
    flex-direction: column;
  }
}

/* ─── Auth (login / signup / forgot) ─── */
body.page-auth {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: radial-gradient(800px 400px at 80% -10%, rgba(120, 200, 255, 0.06), transparent), var(--lc-bg-deep);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
}

body.page-auth .auth-header {
  border-bottom: 1px solid var(--lc-line);
  background: rgba(8, 10, 16, 0.92);
  backdrop-filter: blur(14px);
}

body.page-auth .auth-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 520px;
  margin: 0 auto;
  padding: 1.1rem clamp(1rem, 4vw, 1.75rem);
}

body.page-auth .auth-nav .logo {
  font-family: var(--lc-font-display);
  font-weight: 800;
  font-size: 1.35rem;
  color: var(--lc-text);
  text-decoration: none;
}

body.page-auth .auth-nav .logo span {
  color: var(--lc-accent);
}

body.page-auth .nav-link {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--lc-muted);
  text-decoration: none;
  transition: color 0.15s;
}

body.page-auth .nav-link:hover {
  color: var(--lc-accent);
}

body.page-auth .auth-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1.5rem, 5vw, 3rem) 1.25rem;
}

body.page-auth .auth-card {
  width: 100%;
  max-width: 420px;
  padding: clamp(1.75rem, 4vw, 2.5rem);
  border-radius: var(--lc-radius-lg);
  border: 1px solid var(--lc-line);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
  box-shadow: var(--lc-shadow);
}

body.page-auth .auth-title {
  font-family: var(--lc-font-display);
  font-size: 1.65rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 0.35rem;
}

body.page-auth .auth-sub {
  font-size: 0.88rem;
  color: var(--lc-muted);
  margin-bottom: 1.75rem;
  line-height: 1.55;
}

body.page-auth .auth-sub a {
  color: var(--lc-accent);
  font-weight: 600;
  text-decoration: none;
}

body.page-auth .form-group {
  margin-bottom: 1rem;
}

body.page-auth label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--lc-muted);
  margin-bottom: 0.35rem;
}

body.page-auth input[type='email'],
body.page-auth input[type='password'],
body.page-auth input[type='text'] {
  width: 100%;
  padding: 0.72rem 1rem;
  border-radius: var(--lc-radius-sm);
  border: 1px solid var(--lc-line-strong);
  background: rgba(255, 255, 255, 0.04);
  color: var(--lc-text);
  font-family: inherit;
  font-size: 0.92rem;
  outline: none;
  transition: border-color 0.15s;
}

body.page-auth input:focus {
  border-color: rgba(200, 255, 74, 0.45);
}

body.page-auth .btn-submit {
  width: 100%;
  margin-top: 0.35rem;
  padding: 0.82rem;
  border: none;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--lc-accent), #9ad015);
  color: #050608;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 800;
  cursor: pointer;
  transition: filter 0.15s, transform 0.1s;
}

body.page-auth .btn-submit:hover:not(:disabled) {
  filter: brightness(1.06);
  transform: translateY(-1px);
}

body.page-auth .btn-submit:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

body.page-auth .divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.25rem 0;
  color: var(--lc-muted);
  font-size: 0.75rem;
}

body.page-auth .divider::before,
body.page-auth .divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--lc-line);
}

body.page-auth .btn-google {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 0.72rem;
  border-radius: 999px;
  border: 1px solid var(--lc-line-strong);
  background: transparent;
  color: var(--lc-text);
  font-family: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

body.page-auth .btn-google:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.18);
}

body.page-auth .forgot {
  display: inline-block;
  margin-top: 0.45rem;
  font-size: 0.78rem;
  color: var(--lc-muted);
  text-decoration: none;
}

body.page-auth .forgot:hover {
  color: var(--lc-accent);
}

body.page-auth .alert {
  display: none;
  padding: 0.65rem 0.85rem;
  border-radius: var(--lc-radius-sm);
  font-size: 0.82rem;
  margin-bottom: 1rem;
}

body.page-auth .alert.show {
  display: block;
}

body.page-auth .alert-error {
  background: rgba(248, 113, 113, 0.1);
  border: 1px solid rgba(248, 113, 113, 0.35);
  color: #fecaca;
}

body.page-auth .alert-success {
  background: rgba(74, 222, 128, 0.1);
  border: 1px solid rgba(74, 222, 128, 0.35);
  color: #bbf7d0;
}

/* ─── Legal ─── */
body.page-legal {
  background: var(--lc-bg-deep);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
  line-height: 1.75;
}

body.page-legal .legal-header {
  border-bottom: 1px solid var(--lc-line);
  background: rgba(8, 10, 16, 0.95);
  backdrop-filter: blur(12px);
}

body.page-legal .legal-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 800px;
  margin: 0 auto;
  padding: 1rem clamp(1rem, 4vw, 2rem);
}

body.page-legal .legal-nav .logo {
  font-family: var(--lc-font-display);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--lc-text);
  text-decoration: none;
}

body.page-legal .legal-nav .logo span {
  color: var(--lc-accent);
}

body.page-legal .nav-back {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--lc-muted);
  text-decoration: none;
}

body.page-legal .nav-back:hover {
  color: var(--lc-accent);
}

body.page-legal .legal-main {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(2.5rem, 6vw, 4rem) clamp(1.25rem, 4vw, 2rem) 5rem;
}

body.page-legal .legal-main h1 {
  font-family: var(--lc-font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 0.35rem;
}

body.page-legal .updated {
  font-size: 0.85rem;
  color: var(--lc-muted);
  margin-bottom: 2rem;
}

body.page-legal .legal-main h2 {
  font-family: var(--lc-font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--lc-accent);
  margin: 2.25rem 0 0.65rem;
}

body.page-legal .legal-main p,
body.page-legal .legal-main li {
  color: #c8cad8;
  font-size: 0.95rem;
}

body.page-legal .legal-main ul {
  padding-left: 1.35rem;
}

body.page-legal .legal-main a {
  color: var(--lc-accent);
}

/* Sign-up extras */
body.page-auth .error-msg {
  display: none;
  font-size: 0.72rem;
  color: #fca5a5;
  margin-top: 0.35rem;
}

body.page-auth .error-msg.show {
  display: block;
}

body.page-auth .opt-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.35rem 0 1rem;
  color: var(--lc-muted);
  font-size: 0.82rem;
}

body.page-auth .opt-row input[type='checkbox'] {
  width: auto;
  accent-color: var(--lc-accent);
}

body.page-auth .terms {
  font-size: 0.74rem;
  color: var(--lc-muted);
  text-align: center;
  margin-top: 1.25rem;
  line-height: 1.5;
}

body.page-auth .terms a {
  color: var(--lc-accent);
  font-weight: 600;
}

body.page-auth .spinner {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(5, 8, 12, 0.35);
  border-top-color: #06080d;
  border-radius: 50%;
  animation: lc-spin 0.65s linear infinite;
  vertical-align: middle;
}

@keyframes lc-spin {
  to {
    transform: rotate(360deg);
  }
}

/*
  Dashboard — scoped to body.page-dashboard only.
  Shell uses CSS Grid (not flex-basis hacks) so the main column cannot collapse to width 0.
*/

body.page-dashboard {
  margin: 0;
  box-sizing: border-box;
  min-height: 100vh;
  height: 100vh;
  height: 100dvh;
  display: grid;
  grid-template-columns: var(--lc-sidebar-w) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr);
  overflow: hidden;
  background:
    radial-gradient(1200px 800px at 100% -10%, rgba(124, 92, 255, 0.06), transparent 55%),
    radial-gradient(900px 600px at -5% 40%, rgba(200, 255, 74, 0.045), transparent 50%),
    linear-gradient(180deg, var(--lc-bg-deep) 0%, var(--lc-bg) 28%, var(--lc-bg) 100%);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
}

body.page-dashboard *,
body.page-dashboard *::before,
body.page-dashboard *::after {
  box-sizing: border-box;
}

body.page-dashboard > .sidebar {
  grid-column: 1;
  grid-row: 1;
  width: var(--lc-sidebar-w);
  min-width: 0;
  min-height: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: 1.35rem 1rem 1rem;
  overflow-x: hidden;
  overflow-y: auto;
  background: linear-gradient(165deg, rgba(20, 24, 36, 0.97), rgba(10, 12, 18, 0.99));
  border-right: 1px solid var(--lc-line);
  box-shadow: 12px 0 40px rgba(0, 0, 0, 0.35);
}

body.page-dashboard > .sidebar .logo {
  font-family: var(--lc-font-display), sans-serif;
  font-weight: 800;
  font-size: 1.42rem;
  letter-spacing: -0.03em;
  color: var(--lc-text);
  text-decoration: none;
  padding: 0.35rem 0.55rem;
  margin-bottom: 1.75rem;
  display: block;
  border-radius: var(--lc-radius-sm);
  transition: background 0.15s ease;
}

body.page-dashboard > .sidebar .logo:hover {
  background: var(--lc-accent-soft);
}

body.page-dashboard > .sidebar .logo span {
  color: var(--lc-accent);
}

body.page-dashboard .nav-section {
  font-size: 0.62rem;
  font-weight: 800;
  color: var(--lc-muted);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0 0.55rem;
  margin: 1rem 0 0.45rem;
  opacity: 0.85;
}

body.page-dashboard .nav-section:first-of-type {
  margin-top: 0;
}

body.page-dashboard .nav-item {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.52rem 0.72rem;
  border-radius: 11px;
  text-decoration: none;
  color: var(--lc-muted);
  font-size: 0.84rem;
  font-weight: 600;
  transition: background 0.14s ease, color 0.14s ease, box-shadow 0.14s ease;
  cursor: pointer;
  border: 1px solid transparent;
  background: transparent;
  width: 100%;
  text-align: left;
}

body.page-dashboard .nav-item svg {
  flex-shrink: 0;
  opacity: 0.88;
}

body.page-dashboard .nav-item:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--lc-text);
  border-color: rgba(255, 255, 255, 0.06);
}

body.page-dashboard .nav-item.active {
  background: linear-gradient(
    135deg,
    rgba(200, 255, 74, 0.16),
    rgba(200, 255, 74, 0.06)
  );
  border-color: rgba(200, 255, 74, 0.22);
  color: var(--lc-accent);
  box-shadow: 0 4px 20px rgba(200, 255, 74, 0.08);
}

body.page-dashboard .nav-item.game-link:hover {
  background: rgba(200, 255, 74, 0.07);
  color: var(--lc-accent);
}

body.page-dashboard .nav-item.nav-muted {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

body.page-dashboard .nav-item.nav-item-logout {
  margin-top: 0.35rem;
  color: var(--lc-danger) !important;
}

body.page-dashboard .nav-item.nav-item-logout:hover {
  background: rgba(248, 113, 113, 0.1);
  border-color: rgba(248, 113, 113, 0.2);
  color: #fca5a5 !important;
}

body.page-dashboard .lotta-only {
  display: none;
}

body.page-dashboard .sidebar-bottom {
  margin-top: auto;
  border-top: 1px solid var(--lc-line);
  padding-top: 1rem;
}

body.page-dashboard .user-pill {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.65rem;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

body.page-dashboard .sidebar-name {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--lc-text);
}

body.page-dashboard .sidebar-email {
  font-size: 0.72rem;
  color: var(--lc-muted);
}

body.page-dashboard .avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(145deg, rgba(200, 255, 74, 0.18), rgba(124, 92, 255, 0.12));
  border: 1px solid rgba(200, 255, 74, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--lc-accent);
  flex-shrink: 0;
}

body.page-dashboard > .main {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr);
  align-content: stretch;
  overflow: hidden;
  background: var(--lc-bg);
  color: var(--lc-text);
}

body.page-dashboard .topbar {
  grid-row: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 0.95rem 1.35rem;
  border-bottom: 1px solid var(--lc-line);
  background: rgba(12, 15, 24, 0.82);
  backdrop-filter: blur(18px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

body.page-dashboard .page-title {
  font-family: var(--lc-font-display), sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--lc-text);
}

body.page-dashboard .topbar-right {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

body.page-dashboard .topbar-cashier-links {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

body.page-dashboard .topbar-cashier-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.38rem 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--lc-line-strong);
  background: rgba(255, 255, 255, 0.03);
  color: var(--lc-text);
  text-decoration: none;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

body.page-dashboard .topbar-cashier-link:hover {
  border-color: rgba(200, 255, 74, 0.45);
  background: rgba(200, 255, 74, 0.1);
  color: var(--lc-accent);
}

body.page-dashboard .topbar-balance-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
  justify-content: flex-end;
  max-width: min(100%, 52vw);
  padding: 0.38rem 0.95rem;
  background: linear-gradient(
    135deg,
    rgba(200, 255, 74, 0.12),
    rgba(255, 255, 255, 0.04)
  );
  border: 1px solid rgba(200, 255, 74, 0.22);
  border-radius: 999px;
}

body.page-dashboard .topbar-balance-pill .lbl {
  font-size: 0.76rem;
  color: var(--lc-muted);
  font-weight: 600;
}

body.page-dashboard #topbarBalance {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.12rem;
  font-family: var(--lc-font-ui), sans-serif;
  font-size: clamp(0.72rem, 1.35vw, 0.95rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--lc-text);
  overflow-wrap: anywhere;
  word-break: break-word;
  text-align: right;
  line-height: 1.3;
}

body.page-dashboard #topbarBalance .lotta-bal-main {
  font-family: var(--lc-font-display), sans-serif;
  font-weight: 800;
  color: var(--lc-accent);
}

body.page-dashboard #topbarBalance .lotta-bal-sep {
  color: var(--lc-muted);
  font-weight: 600;
}

body.page-dashboard #topbarBalance .lotta-bal-fiat {
  color: var(--lc-muted);
  font-weight: 600;
}

body.page-dashboard > .main > .content {
  grid-row: 2;
  min-height: 0;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 1.5rem clamp(1rem, 3vw, 2rem) 2.5rem;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

body.page-dashboard .stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(190px, 100%), 1fr));
  gap: 1rem;
  margin-bottom: 1.75rem;
  width: 100%;
}

body.page-dashboard .stat-card {
  position: relative;
  background: linear-gradient(155deg, rgba(20, 24, 36, 0.92), rgba(12, 15, 22, 0.98));
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.15rem 1.2rem;
  box-shadow: var(--lc-shadow);
  overflow: hidden;
}

body.page-dashboard .stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 1.25rem;
  right: 1.25rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(200, 255, 74, 0.45), transparent);
  opacity: 0.75;
}

body.page-dashboard .stat-label {
  font-size: 0.68rem;
  color: var(--lc-muted);
  font-weight: 700;
  margin-bottom: 0.45rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

body.page-dashboard .stat-value {
  font-family: var(--lc-font-display), sans-serif;
  font-size: clamp(1rem, 2.8vw, 1.65rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  overflow-wrap: anywhere;
  word-break: break-all;
}

body.page-dashboard .stat-value.gold {
  color: var(--lc-accent);
}

body.page-dashboard .stat-value.purple {
  color: #a78bfa;
}

body.page-dashboard #statJoined {
  font-size: 1.12rem !important;
}

body.page-dashboard .stat-sub {
  font-size: 0.74rem;
  color: var(--lc-muted);
  margin-top: 0.45rem;
  line-height: 1.45;
}

body.page-dashboard .tab-content {
  display: none;
}

body.page-dashboard .tab-content.active {
  display: block;
}

body.page-dashboard .dash-intro {
  background: linear-gradient(
    155deg,
    rgba(200, 255, 74, 0.07),
    rgba(124, 92, 255, 0.05),
    rgba(12, 15, 22, 0.95)
  );
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.45rem 1.5rem;
  width: 100%;
  max-width: none;
  box-shadow: var(--lc-shadow);
}

body.page-dashboard .dash-intro h3 {
  font-family: var(--lc-font-display), sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 0.45rem;
  color: var(--lc-accent);
}

body.page-dashboard .dash-intro p {
  margin: 0;
  color: var(--lc-muted);
  font-size: 0.9rem;
  line-height: 1.6;
}

body.page-dashboard .dash-intro strong {
  color: var(--lc-text);
}

body.page-dashboard .tab-content > h3:first-of-type {
  font-family: var(--lc-font-display), sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 1rem;
  color: var(--lc-text);
}

body.page-dashboard .btn-sm {
  min-height: 38px;
  padding: 0.48rem 1.05rem;
  border-radius: 999px;
  font-family: var(--lc-font-ui);
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.12s ease, opacity 0.15s ease, box-shadow 0.15s ease;
  border: 1px solid transparent;
}

body.page-dashboard .btn-sm:hover {
  transform: translateY(-1px);
}

body.page-dashboard .btn-accent {
  background: linear-gradient(135deg, var(--lc-accent), #9fe020);
  color: #080a0e;
  border: none;
  box-shadow: 0 8px 28px rgba(200, 255, 74, 0.22);
}

body.page-dashboard .btn-accent:hover:not(:disabled) {
  filter: brightness(1.05);
}

body.page-dashboard .btn-ghost {
  background: rgba(255, 255, 255, 0.03);
  border-color: var(--lc-line-strong);
  color: var(--lc-text);
}

body.page-dashboard .btn-ghost:hover {
  border-color: rgba(200, 255, 74, 0.35);
  background: rgba(200, 255, 74, 0.06);
}

body.page-dashboard .btn-sm.btn-danger {
  background: transparent;
  border: 1px solid rgba(248, 113, 113, 0.48);
  color: #fca5a5;
}

body.page-dashboard .btn-sm.btn-danger:hover {
  background: rgba(248, 113, 113, 0.12);
}

/* Plain icon/text actions (Search, Refresh) — not ghost/accent/danger */
body.page-dashboard .btn-sm:not(.btn-ghost):not(.btn-accent):not(.btn-danger) {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--lc-line-strong);
  color: var(--lc-text);
}

body.page-dashboard .btn-sm:not(.btn-ghost):not(.btn-accent):not(.btn-danger):hover {
  border-color: rgba(200, 255, 74, 0.35);
  background: rgba(200, 255, 74, 0.08);
}

body.page-dashboard .tx-list {
  background: linear-gradient(180deg, rgba(20, 24, 36, 0.55), rgba(10, 12, 18, 0.9));
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  overflow: hidden;
  box-shadow: var(--lc-shadow);
}

body.page-dashboard .tx-header {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  padding: 0.78rem 1.25rem;
  font-size: 0.66rem;
  font-weight: 800;
  color: var(--lc-muted);
  border-bottom: 1px solid var(--lc-line);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  background: rgba(0, 0, 0, 0.25);
}

body.page-dashboard .tx-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  padding: 0.95rem 1.25rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  align-items: center;
  gap: 0.5rem;
  transition: background 0.14s ease;
}

body.page-dashboard .tx-row:last-child {
  border-bottom: none;
}

body.page-dashboard .tx-row:hover {
  background: rgba(200, 255, 74, 0.04);
}

body.page-dashboard .tx-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--lc-text);
}

body.page-dashboard .tx-type {
  font-size: 0.74rem;
  color: var(--lc-muted);
  margin-top: 0.2rem;
}

body.page-dashboard .tx-amount {
  font-family: var(--lc-font-ui);
  font-weight: 700;
  font-size: 0.92rem;
  font-variant-numeric: tabular-nums;
}

body.page-dashboard .tx-amount.earn {
  color: var(--lc-accent);
}

body.page-dashboard .tx-amount.spend {
  color: var(--lc-danger);
}

body.page-dashboard .tx-date {
  font-size: 0.78rem;
  color: var(--lc-muted);
}

body.page-dashboard .badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.65rem;
  border-radius: 999px;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.page-dashboard .badge-success {
  background: rgba(74, 222, 128, 0.14);
  color: #86efac;
  border: 1px solid rgba(74, 222, 128, 0.25);
}

body.page-dashboard .badge-pending {
  background: rgba(251, 191, 36, 0.12);
  color: #fcd34d;
  border: 1px solid rgba(251, 191, 36, 0.28);
}

body.page-dashboard .badge-failed {
  background: rgba(248, 113, 113, 0.12);
  color: #fca5a5;
  border: 1px solid rgba(248, 113, 113, 0.28);
}

body.page-dashboard .withdraw-grid,
body.page-dashboard .deposit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 0.85rem;
  margin-bottom: 1.35rem;
}

body.page-dashboard .method-card {
  background: rgba(12, 15, 22, 0.85);
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius-sm);
  padding: 1.05rem 0.85rem;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.18s ease, transform 0.12s ease, box-shadow 0.18s ease;
}

body.page-dashboard .method-card:hover {
  border-color: rgba(200, 255, 74, 0.28);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
}

body.page-dashboard .method-card.selected {
  border-color: rgba(200, 255, 74, 0.55);
  background: linear-gradient(
    155deg,
    rgba(200, 255, 74, 0.12),
    rgba(12, 15, 22, 0.95)
  );
  box-shadow: 0 0 0 1px rgba(200, 255, 74, 0.15), 0 16px 40px rgba(200, 255, 74, 0.08);
}

body.page-dashboard .method-icon {
  font-size: 1.85rem;
  margin-bottom: 0.35rem;
  line-height: 1;
}

body.page-dashboard .method-name {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--lc-text);
}

body.page-dashboard .method-min {
  font-size: 0.72rem;
  color: var(--lc-muted);
  margin-top: 0.25rem;
}

body.page-dashboard .withdraw-split {
  display: flex;
  flex-wrap: wrap;
  gap: 1.15rem;
  align-items: flex-start;
}

body.page-dashboard .withdraw-form {
  flex: 1 1 320px;
  min-width: 0;
  max-width: none;
  background: rgba(12, 15, 22, 0.88);
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.45rem 1.35rem;
  box-shadow: var(--lc-shadow);
}

body.page-dashboard .withdraw-form label,
body.page-dashboard .deposit-form label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--lc-muted);
  margin-bottom: 0.4rem;
}

body.page-dashboard .withdraw-form input {
  width: 100%;
  padding: 0.72rem 1rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
  font-size: 0.9rem;
  outline: none;
  margin-bottom: 1rem;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

body.page-dashboard .withdraw-form input:focus {
  border-color: rgba(200, 255, 74, 0.45);
  box-shadow: 0 0 0 3px rgba(200, 255, 74, 0.1);
}

body.page-dashboard .balance-hint {
  font-size: 0.82rem;
  color: var(--lc-muted);
  margin-bottom: 1rem;
}

body.page-dashboard .balance-hint span {
  color: var(--lc-accent);
  font-weight: 700;
}

body.page-dashboard .withdraw-history {
  flex: 1;
  min-width: 280px;
  background: rgba(12, 15, 22, 0.75);
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.1rem 1.15rem;
  max-height: 440px;
  overflow: auto;
}

body.page-dashboard .withdraw-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

body.page-dashboard .withdraw-head h4 {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--lc-muted);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin: 0;
}

body.page-dashboard .withdraw-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

body.page-dashboard .withdraw-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.5rem;
  align-items: start;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius-sm);
  padding: 0.65rem 0.75rem;
}

body.page-dashboard .withdraw-item .w-meta {
  font-size: 0.74rem;
  color: var(--lc-muted);
  line-height: 1.45;
}

body.page-dashboard .withdraw-item .w-amt {
  font-weight: 800;
  color: var(--lc-accent);
  font-size: 0.88rem;
  white-space: nowrap;
}

body.page-dashboard .withdraw-empty {
  color: var(--lc-muted);
  font-size: 0.84rem;
  padding: 0.85rem 0;
}

body.page-dashboard .deposit-hd-block {
  background: rgba(12, 15, 22, 0.88);
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.15rem 1.25rem;
  width: 100%;
  max-width: none;
  margin-bottom: 1rem;
  box-shadow: var(--lc-shadow);
}

body.page-dashboard .deposit-hd-row {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

body.page-dashboard .deposit-hd-row input {
  flex: 1;
  width: 100%;
  padding: 0.72rem 1rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
  font-size: 0.9rem;
  outline: none;
}

body.page-dashboard .deposit-form {
  background: rgba(12, 15, 22, 0.88);
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.35rem 1.25rem;
  width: 100%;
  max-width: none;
  box-shadow: var(--lc-shadow);
}

body.page-dashboard .deposit-form input {
  width: 100%;
  padding: 0.72rem 1rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
  font-size: 0.9rem;
  outline: none;
  margin-bottom: 0.95rem;
  transition: border-color 0.15s ease;
}

body.page-dashboard .deposit-form input:focus {
  border-color: rgba(200, 255, 74, 0.45);
}

body.page-dashboard .dash-card {
  background: linear-gradient(
    155deg,
    rgba(200, 255, 74, 0.06),
    rgba(124, 92, 255, 0.04),
    rgba(12, 15, 22, 0.95)
  );
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.75rem 1.6rem;
  width: 100%;
  max-width: none;
  box-shadow: var(--lc-shadow);
}

body.page-dashboard .dash-card h3 {
  font-family: var(--lc-font-display), sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 0.5rem;
  color: var(--lc-accent);
}

body.page-dashboard .dash-card p {
  color: var(--lc-muted);
  font-size: 0.88rem;
  line-height: 1.55;
  margin: 0 0 1.35rem;
}

body.page-dashboard .dash-card p strong {
  color: var(--lc-accent);
  font-weight: 700;
}

body.page-dashboard .dash-ref-count {
  font-size: 0.75rem;
  color: var(--lc-muted);
  margin-top: 1rem;
  margin-bottom: 0;
}

body.page-dashboard .dash-ref-count strong {
  color: var(--lc-text);
  font-weight: 700;
}

body.page-dashboard .dash-card label {
  font-size: 0.76rem;
  color: var(--lc-muted);
  display: block;
  margin-bottom: 0.4rem;
  font-weight: 600;
}

body.page-dashboard .dash-card input[type='text'] {
  flex: 1;
  min-width: 0;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  padding: 0.72rem 1rem;
  color: var(--lc-accent);
  font-size: 0.86rem;
  outline: none;
}

body.page-dashboard .dash-card .ref-copy-row {
  display: flex;
  gap: 0.55rem;
  align-items: stretch;
  flex-wrap: wrap;
}

body.page-dashboard .dash-card .ref-copy-row .btn-sm {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body.page-dashboard .settings-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  align-items: stretch;
}

body.page-dashboard .settings-col {
  min-width: 0;
}

body.page-dashboard .settings-paired-card {
  min-height: 380px;
}

body.page-dashboard .testing-col {
  grid-column: 2;
  grid-row: 1;
}

body.page-dashboard .tip-col {
  grid-column: 3;
  grid-row: 1;
}

body.page-dashboard .users-col {
  grid-column: 1;
  grid-row: 2;
}

body.page-dashboard .refunds-col {
  grid-column: 3;
  grid-row: 2;
}

body.page-dashboard .users-detail-col {
  grid-column: 2;
  grid-row: 2;
}

body.page-dashboard .toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

body.page-dashboard .toggle-row:last-of-type {
  border-bottom: none;
}

body.page-dashboard .toggle-row .toggle-label {
  color: var(--lc-text);
  font-size: 0.92rem;
  font-weight: 600;
}

body.page-dashboard .toggle {
  position: relative;
  display: inline-block;
  width: 48px;
  height: 28px;
  flex: 0 0 auto;
}

body.page-dashboard .toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

body.page-dashboard .toggle-slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background: rgba(255, 255, 255, 0.1);
  transition: 0.2s;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
}

body.page-dashboard .toggle-slider::before {
  position: absolute;
  content: '';
  height: 22px;
  width: 22px;
  left: 3px;
  top: 50%;
  transform: translateY(-50%);
  background: #fff;
  border-radius: 50%;
  transition: 0.2s;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.35);
}

body.page-dashboard .toggle input:checked + .toggle-slider {
  background: rgba(200, 255, 74, 0.22);
  border-color: rgba(200, 255, 74, 0.38);
}

body.page-dashboard .toggle input:checked + .toggle-slider::before {
  transform: translate(22px, -50%);
}

body.page-dashboard .toggle input:disabled + .toggle-slider {
  opacity: 0.45;
  cursor: not-allowed;
}

body.page-dashboard .admin-panel {
  background: rgba(12, 15, 22, 0.88);
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  padding: 1.35rem 1.35rem;
  margin-bottom: 1.35rem;
  width: 100%;
  max-width: none;
  box-shadow: var(--lc-shadow);
}

body.page-dashboard .settings-card {
  height: 100%;
  margin-top: 0;
  max-width: none;
}

body.page-dashboard .admin-panel h3 {
  font-family: var(--lc-font-display), sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 0.85rem;
  color: var(--lc-accent);
}

body.page-dashboard .admin-panel label {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--lc-muted);
  margin-bottom: 0.38rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

body.page-dashboard .admin-panel input[type='text'],
body.page-dashboard .admin-panel input[type='password'],
body.page-dashboard .admin-panel input[type='url'],
body.page-dashboard .admin-panel input[type='email'],
body.page-dashboard .admin-panel input[type='number'] {
  width: 100%;
  max-width: none;
  padding: 0.68rem 0.88rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  color: var(--lc-text);
  font-family: var(--lc-font-ui);
  font-size: 0.88rem;
  margin-bottom: 0.75rem;
  outline: none;
  transition: border-color 0.15s ease;
}

body.page-dashboard .admin-panel input:focus {
  border-color: rgba(200, 255, 74, 0.4);
}

body.page-dashboard .admin-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: flex-end;
  margin-bottom: 0.85rem;
}

body.page-dashboard .pending-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  margin-top: 0.85rem;
}

body.page-dashboard .pending-table th {
  text-align: left;
  padding: 0.65rem 0.5rem;
  border-bottom: 1px solid var(--lc-line);
  color: var(--lc-muted);
  font-size: 0.66rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

body.page-dashboard .pending-table td {
  padding: 0.72rem 0.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  vertical-align: top;
}

body.page-dashboard .pending-table .mono {
  font-family: ui-monospace, monospace;
  font-size: 0.76rem;
  word-break: break-all;
}

body.page-dashboard .pending-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

body.page-dashboard .btn-done {
  padding: 0.42rem 0.78rem;
  border-radius: var(--lc-radius-sm);
  border: none;
  background: var(--lc-success);
  color: #052e16;
  font-weight: 800;
  font-size: 0.76rem;
  cursor: pointer;
}

body.page-dashboard .btn-refund {
  padding: 0.42rem 0.78rem;
  border-radius: var(--lc-radius-sm);
  border: 1px solid rgba(248, 113, 113, 0.45);
  background: transparent;
  color: #fca5a5;
  font-weight: 800;
  font-size: 0.76rem;
  cursor: pointer;
}

body.page-dashboard #casesJsonEditor {
  width: 100%;
  min-height: 340px;
  padding: 0.95rem;
  background: rgba(5, 7, 11, 0.95);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  color: var(--lc-text);
  font-family: ui-monospace, monospace;
  font-size: 0.78rem;
  line-height: 1.45;
  resize: vertical;
}

body.page-dashboard .notif {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  max-width: min(420px, calc(100vw - 2rem));
  background: rgba(12, 15, 22, 0.96);
  border: 1px solid var(--lc-line-strong);
  border-radius: var(--lc-radius-sm);
  padding: 0.95rem 1.3rem;
  font-size: 0.88rem;
  font-weight: 600;
  display: none;
  z-index: 99999;
  box-shadow: var(--lc-shadow);
  backdrop-filter: blur(12px);
}

body.page-dashboard .notif.show {
  display: block;
  animation: dash-notif-in 0.35s ease;
}

@keyframes dash-notif-in {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

body.page-dashboard .notif.success {
  border-color: rgba(74, 222, 128, 0.45);
  color: #86efac;
}

body.page-dashboard .notif.error {
  border-color: rgba(248, 113, 113, 0.45);
  color: #fca5a5;
}

@media (max-width: 1100px) {
  body.page-dashboard .settings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  body.page-dashboard .testing-col,
  body.page-dashboard .tip-col,
  body.page-dashboard .users-col,
  body.page-dashboard .refunds-col {
    grid-column: auto;
  }
  body.page-dashboard .users-detail-col {
    grid-column: 1 / -1;
    grid-row: auto;
  }
}

@media (max-width: 900px) {
  body.page-dashboard {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr);
    height: 100vh;
    height: 100dvh;
  }

  body.page-dashboard > .sidebar {
    grid-column: 1;
    grid-row: 1;
    width: 100%;
    height: auto;
    max-height: none;
    padding: 0.65rem 0.75rem;
    border-right: none;
    border-bottom: 1px solid var(--lc-line);
    flex-direction: row;
    align-items: center;
    gap: 0.4rem;
    overflow-x: auto;
    overflow-y: hidden;
    z-index: 60;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
  }

  body.page-dashboard > .main {
    grid-column: 1;
    grid-row: 2;
    height: 100%;
    min-height: 0;
  }

  body.page-dashboard .sidebar .logo {
    margin: 0 0.4rem 0 0;
    padding: 0.25rem 0.4rem;
    font-size: 1.05rem;
    flex: 0 0 auto;
  }

  body.page-dashboard .sidebar .nav-section {
    display: none;
  }

  body.page-dashboard .sidebar .nav-item {
    width: auto;
    flex: 0 0 auto;
    padding: 0.45rem 0.65rem;
    font-size: 0.76rem;
    white-space: nowrap;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.02);
  }

  body.page-dashboard .sidebar-bottom {
    margin-top: 0;
    border-top: none;
    padding-top: 0;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex: 0 0 auto;
  }

  body.page-dashboard #sidebarEmail {
    display: none;
  }

  body.page-dashboard .user-pill {
    padding: 0.25rem 0.4rem;
  }

  body.page-dashboard .avatar {
    width: 28px;
    height: 28px;
    font-size: 0.68rem;
  }

  body.page-dashboard .topbar {
    padding: 0.75rem 0.95rem;
  }

  body.page-dashboard .topbar-right {
    width: 100%;
    justify-content: flex-end;
  }

  body.page-dashboard .page-title {
    font-size: 1.08rem;
  }

  body.page-dashboard > .main > .content {
    padding: 1rem 0.9rem 2rem;
    max-width: none;
  }

  body.page-dashboard .tx-header {
    display: none;
  }

  body.page-dashboard .tx-row {
    grid-template-columns: 1fr;
    gap: 0.35rem;
    padding: 0.85rem 1rem;
  }

  body.page-dashboard .withdraw-history {
    min-width: 0;
    max-height: none;
  }

  body.page-dashboard .notif {
    left: 0.9rem;
    right: 0.9rem;
    bottom: 1rem;
  }
}

@media (max-width: 780px) {
  body.page-dashboard .settings-grid {
    grid-template-columns: 1fr;
  }
  body.page-dashboard .testing-col,
  body.page-dashboard .tip-col,
  body.page-dashboard .users-col,
  body.page-dashboard .refunds-col {
    grid-column: auto;
  }
  body.page-dashboard .users-detail-col {
    grid-column: 1;
    grid-row: auto;
  }
}

@media (max-width: 480px) {
  body.page-dashboard .sidebar {
    padding: 0.45rem 0.55rem;
  }

  body.page-dashboard .sidebar .logo {
    font-size: 0.92rem;
  }

  body.page-dashboard .sidebar .nav-item {
    padding: 0.38rem 0.52rem;
    font-size: 0.72rem;
  }

  body.page-dashboard .avatar {
    width: 24px;
    height: 24px;
    font-size: 0.62rem;
  }

  body.page-dashboard .topbar-balance-pill .lbl {
    display: none;
  }

  body.page-dashboard .page-title {
    font-size: 1rem;
  }

  body.page-dashboard > .main > .content {
    padding: 0.75rem 0.65rem 1.75rem;
  }

  body.page-dashboard .stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.65rem;
    margin-bottom: 1.25rem;
  }

  body.page-dashboard .stat-card {
    padding: 0.9rem 0.95rem;
  }

  body.page-dashboard .stat-value {
    font-size: 1.32rem;
  }

  body.page-dashboard .withdraw-split {
    flex-direction: column;
  }
}

/* Unlayered polish — layout helpers for scoped page bodies (works with layered legacy pages.css) */

.page-auth {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg, #0b0d14);
  color: var(--text, #f0f0f0);
}

.page-auth main,
.page-auth .auth-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1.5rem, 4vw, 3rem) 1.25rem;
  width: 100%;
}

.page-legal main,
.page-legal .legal-main {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 4rem) clamp(1.25rem, 4vw, 2rem) 5rem;
}

.page-legal .legal-doc h1 {
  margin-bottom: 0.35rem;
}

.page-maintenance main {
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}

body.page-queue {
  min-height: 100vh;
}

.page-queue .queue-main {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(1.25rem, 3vw, 2rem);
}

.page-lobby .hero {
  position: relative;
}

/* Lobby: header wraps nav — keep bar layout identical to legacy `nav` rules */
.page-lobby .site-header {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
}

.page-legal .legal-header {
  display: block;
  width: 100%;
}

.page-auth .auth-header {
  display: block;
  width: 100%;
}

/* Generated by scripts/html_inline_to_classes.py — do not merge-edit; re-run script */

.i-91a5cbaf1c { --br-slots:6;--br-min-slot:160px }
.i-5894a1e2cb { background:linear-gradient(135deg,#0d0a1f,#2a1f4a) }
.i-c79651b463 { background:linear-gradient(135deg,#0d2e1f,#1a5c3a) }
.i-2da75d926c { background:linear-gradient(135deg,#0f1520,#1a2a4a) }
.i-fe6c535509 { background:linear-gradient(135deg,#0f1a2e,#1e3a5f) }
.i-422a21dd36 { background:linear-gradient(135deg,#1a0a0a,#3d0f0f) }
.i-d2fdafdcd8 { background:linear-gradient(135deg,#1a0f2e,#4a1a6e) }
.i-402df9af69 { background:linear-gradient(135deg,#1a1200,#3d2d00) }
.i-46e94cb768 { background:linear-gradient(135deg,#2a1810,#4a2a14) }
.i-9e9247f046 { background:linear-gradient(135deg,#2e0f0f,#5c1a1a) }
.i-892d693228 { background:rgba(0,0,0,0.3);padding:0.12rem 0.35rem;border-radius:4px }
.i-b1a7e9f2f2 { background:rgba(240,180,41,0.08);padding:0.12rem 0.35rem;border-radius:4px }
.i-2bb675eee6 { border-color:rgba(229,62,62,0.4);color:#fc8181 }
.i-a56af0c580 { color:#fc8181 }
.i-e39ebac6eb { color:var(--gold) }
.i-08473580f8 { color:var(--gold2) }
.i-8e1177c112 { color:var(--muted);font-size:0.88rem;max-width:560px;margin-bottom:1.25rem;line-height:1.5 }
.i-f045bbed50 { color:var(--text) }
.i-9a0b45aa65 { display:flex;align-items:center;gap:0.75rem;flex-wrap:wrap;margin-left:auto }
.i-799f31e6b3 { display:flex;align-items:center;justify-content:flex-end;gap:0.45rem;margin-top:0.75rem }
.i-ca92fc1162 { display:flex;flex-wrap:wrap;gap:0.4rem;margin-bottom:0.75rem }
.i-291bb5f6ad { display:flex;gap:.45rem }
.i-081393c9fa { display:flex;gap:0.5rem;flex-wrap:wrap }
.i-61e38e0f4a { display:grid;gap:0.45rem;margin-top:0.75rem;max-height:320px;overflow:auto }
.i-42998616be { display:grid;gap:0.45rem;max-height:220px;overflow:auto }
.i-6d84594c9c { display:grid;gap:0.4rem;max-height:245px;overflow:auto }
.i-d86595e36a { display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.45rem }
.i-6b99de8b69 { display:none }
.i-281af7e49e { display:none;font-size:0.72rem;color:var(--br-muted);max-width:920px;margin:0 auto 0.35rem;line-height:1.4 }
.i-16e5bd1413 { display:none;font-size:0.82rem;color:#f6ad55;line-height:1.45;margin-bottom:0.85rem;max-width:720px;border:1px solid rgba(246,173,85,0.35);border-radius:8px;padding:0.65rem 0.75rem;background:rgba(246,173,85,0.08) }
.i-6071f33077 { display:none;font-size:0.82rem;color:var(--muted);line-height:1.5;margin-bottom:0.85rem;max-width:640px }
.i-19a8fd96c1 { display:none;overflow-x:auto }
.i-ca231f4995 { flex:1;max-width:220px }
.i-273f8907b7 { flex:1;min-width:170px;padding:0.7rem 1rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Barlow',sans-serif;outline:none }
.i-3587efd8b5 { font-family:'Bebas Neue',sans-serif;font-size:1.15rem;letter-spacing:1px;margin-bottom:0.55rem;color:var(--gold) }
.i-e6c90c079c { font-family:'Bebas Neue',sans-serif;font-size:1.35rem;letter-spacing:1px;margin-bottom:0.75rem;color:var(--gold) }
.i-d0f9d85206 { font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:1px;margin-bottom:1.5rem }
.i-b2c264a8a3 { font-family:'Syne',sans-serif;font-size:1.35rem;letter-spacing:-0.2px;margin-bottom:1rem }
.i-e444924a18 { font-family:'Syne',sans-serif;font-weight:800;font-size:0.95rem }
.i-16c228d626 { font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:0.65rem }
.i-6378123625 { font-size:0.72rem;color:var(--muted);margin-top:0.75rem;line-height:1.5 }
.i-e33a3af7fc { font-size:0.72rem;color:var(--muted);margin:0.35rem 0 0.5rem;line-height:1.45 }
.i-4d38d513a2 { font-size:0.72rem;color:var(--muted);margin:0.45rem 0 0 }
.i-a4afad7bf5 { font-size:0.75rem;color:var(--muted);margin-top:0.25rem }
.i-0c3086e4a6 { font-size:0.75rem;color:var(--muted);margin-top:0.75rem;line-height:1.5 }
.i-33114242f9 { font-size:0.75rem;color:var(--muted);min-width:120px }
.i-ec44a44d80 { font-size:0.78rem;color:var(--muted);margin:0 0 0.7rem;line-height:1.45 }
.i-c2814b5a6c { font-size:0.78rem;color:var(--muted);min-width:120px;text-align:center }
.i-8e87b75325 { font-size:0.7rem }
.i-cb44d9dfb7 { font-size:0.82rem;color:var(--muted);display:block;margin-bottom:0.4rem }
.i-3ed71b064b { font-size:0.82rem;color:var(--muted);line-height:1.6 }
.i-66947e7f1d { font-size:0.82rem;color:var(--muted);margin-bottom:0.75rem }
.i-79232a2b23 { font-size:0.82rem;color:var(--muted);margin-bottom:0.75rem;line-height:1.5 }
.i-ec91937a0b { font-size:0.82rem;color:var(--muted);margin-bottom:0.8rem;line-height:1.45 }
.i-ee1b794cdb { font-size:0.82rem;color:var(--muted);margin-bottom:1rem;line-height:1.5 }
.i-fedabd888f { font-size:0.82rem;margin:0.55rem 0 0.45rem;min-height:1rem }
.i-d13abf04d3 { font-size:0.85rem;margin-top:0.75rem;min-height:1.25rem }
.i-9ee74f7856 { font-size:0.85rem;margin:0.5rem 0;min-height:1.25rem }
.i-03f8c15957 { font-size:0.85rem;margin:0.6rem 0 0;min-height:1.25rem }
.i-29b2fe9287 { font-size:0.9rem;color:var(--text);font-weight:700;margin-bottom:0.65rem }
.i-27e46985ca { font-size:1.3rem }
.i-20f182b1d5 { font-weight:600;color:var(--muted) }
.i-73cf5f14b5 { height:0.5rem }
.i-1f541e69d6 { left:20%;animation-duration:22s;animation-delay:4s }
.i-4f00db3b62 { left:40%;animation-duration:16s;animation-delay:8s }
.i-4484c12bb4 { left:5%;animation-duration:18s }
.i-2cb79659f0 { left:60%;animation-duration:24s;animation-delay:2s }
.i-1ca0c815f5 { left:80%;animation-duration:19s;animation-delay:12s }
.i-668bed8509 { left:92%;animation-duration:21s;animation-delay:6s }
.i-bc7edc626e { margin-bottom:0.65rem }
.i-5410028c07 { margin-bottom:0.85rem }
.i-e58c3257dd { margin-bottom:0.9rem;padding:0.75rem;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:10px }
.i-3ffdc92604 { margin-bottom:1.25rem }
.i-363cdaa22c { margin-bottom:1rem }
.i-42aa51fabf { margin-bottom:1rem;max-height:260px }
.i-91d27cbb8a { margin-left:auto;color:#f5d96a;font-weight:800;font-size:.82rem }
.i-3dc98b5eb8 { margin-top:0.5rem }
.i-4749d738e6 { margin-top:0.65rem }
.i-7e2a773104 { margin-top:0.65rem;padding:0.25rem 0 0 }
.i-11cbe0e778 { margin-top:0.65rem;width:100%;display:none;border-color:rgba(245,217,106,0.35) }
.i-43cfd34939 { margin-top:0.75rem }
.i-cb74bd5c57 { margin-top:0.75rem;width:100% }
.i-192f9783a1 { margin-top:1rem;max-height:360px }
.i-50dff9d048 { margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border) }
.i-1169661891 { margin:0 }
.i-d62fff69d1 { margin:0.75rem 0 0.85rem }
.i-3c7d34e84e { padding-top:0.2rem }
.i-42aa6d9c6f { padding:2rem }
.i-a4177c35d9 { padding:2rem;text-align:center;color:var(--muted);font-size:0.875rem }
.i-c9c3d9476a { position:relative;height:58px;box-sizing:border-box;overflow:hidden }
.i-808987e663 { text-transform:none;letter-spacing:0;font-size:0.78rem }
.i-b5f0c7b9e1 { width:100%;padding:0.65rem 0.85rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:0.85rem }
.i-fda0806e73 { width:100%;padding:0.75rem;font-size:0.9rem }
.i-a4e2a94374 { width:100%;padding:0.75rem;font-size:0.9rem;margin-top:0.5rem }
.i-ed07787581 { width:100%;padding:0.7rem 1rem;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:8px;color:var(--gold);font-family:'Barlow',sans-serif;outline:none }
.i-7e928856e7 { width:100%;padding:0.7rem 1rem;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-family:'Barlow',sans-serif;outline:none }
.i-cbe813484a { width:100%;padding:0.7rem 1rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Barlow',sans-serif;outline:none }

/* Remaining literals moved out of *.html scripts (dashboard, games, play-shell, etc.) */

.dash-soft-note { font-size: 0.8rem; color: var(--muted); }
.dash-refund-card { border: 1px solid var(--border); border-radius: 8px; padding: 0.55rem 0.6rem; background: rgba(255, 255, 255, 0.02); }
.dash-refund-row { display: flex; justify-content: space-between; gap: 0.5rem; align-items: center; }
.dash-refund-amt { font-size: 0.8rem; color: var(--text); font-weight: 700; }
.dash-refund-actions { display: flex; gap: 0.4rem; }
.dash-micro-muted-mt { font-size: 0.72rem; color: var(--muted); margin-top: 0.3rem; line-height: 1.35; }
.dash-micro-muted { font-size: 0.72rem; color: var(--muted); line-height: 1.35; }
.dash-mini-stat-grid { border: 1px solid var(--border); border-radius: 8px; padding: 0.42rem 0.5rem; background: rgba(255,255,255,0.02); }
.dash-stat-lbl-muted { font-size: 0.67rem; text-transform: uppercase; letter-spacing: 0.45px; color: var(--muted); }
.dash-stat-lbl-warn { font-size: 0.67rem; text-transform: uppercase; letter-spacing: 0.45px; color: #f6ad55; }
.dash-stat-val { font-size: 0.81rem; color: var(--text); font-weight: 700; line-height: 1.25; }
.dash-user-btn { text-align: left; padding: 0.52rem 0.6rem; border: 1px solid var(--border); background: rgba(255,255,255,0.02); border-radius: 8px; color: var(--text); cursor: pointer; }
.dash-user-name { font-size: 0.81rem; font-weight: 700; }
.dash-user-sub { font-size: 0.7rem; color: var(--muted); }
.dash-tx-line { display: flex; justify-content: space-between; gap: 0.4rem; font-size: 0.71rem; border-top: 1px dashed rgba(255,255,255,0.07); padding-top: 0.35rem; margin-top: 0.35rem; }
.dash-tx-line-left { color: var(--muted); min-width: 0; }
.dash-tx-line-title { color: var(--text); }
.dash-tx-amt { white-space: nowrap; font-weight: 700; }
.dash-tx-amt-pos { color: #68d391; }
.dash-tx-amt-neg { color: #fc8181; }
.dash-bucket-card { border: 1px solid var(--border); border-radius: 8px; padding: 0.5rem 0.55rem; background: rgba(255,255,255,0.02); }
.dash-bucket-head { display: flex; justify-content: space-between; gap: 0.4rem; align-items: center; }
.dash-bucket-title { font-size: 0.78rem; color: var(--text); font-weight: 700; }
.dash-bucket-meta { font-size: 0.72rem; color: var(--muted); }
.dash-bucket-empty { font-size: 0.72rem; color: var(--muted); margin-top: 0.3rem; }
.dash-td-empty { text-align: center; color: var(--muted); padding: 2rem; }
.dash-deposit-amt { color: var(--gold); font-weight: 700; }
.dash-withdraw-amt { color: var(--gold); font-weight: 700; }
.dash-link-open { color: var(--gold); }
.dash-history-err { padding: 2rem; text-align: center; color: #fc8181; font-size: 0.875rem; }

.keno-pay-placeholder { flex-basis: 100%; min-width: 100%; font-size: 0.72rem; color: var(--muted); padding: 0.4rem 0.65rem; flex-direction: row; justify-content: center; border: none; background: transparent; }

.cases-grid-empty { color: #8b8fa8; font-size: 0.9rem; }
.cases-card-art {
  background: linear-gradient(145deg, #334155 0%, #0f172a 100%);
}

.cb-case-bg { background: var(--cb-case-bg); }

.br-reel-item { min-height: 52px; height: 52px; box-sizing: border-box; }
.br-jp-item { min-width: 92px; flex-basis: 92px; box-sizing: border-box; }
.br-grid.br-grid-2 { grid-template-columns: 1fr 1fr; }
.br-grid-2 { grid-template-columns: 1fr 1fr; }

.cb-slot-preview {
  flex: 1;
  width: 100%;
  min-height: 120px;
  border-radius: 12px;
}
.cb-picker-mini { padding: 0.35rem; }
.cb-picker-rm { margin: 0.25rem; padding: 0.25rem 0.5rem; border-radius: 8px; border: 1px solid var(--line); background: transparent; color: var(--text); cursor: pointer; font-size: 0.7rem; }

.play-shell-name { font-size: 0.85rem; font-weight: 600; }
.play-shell-email { font-size: 0.72rem; color: var(--muted); }

.live-wins-empty { grid-column: 1 / -1; text-align: center; color: var(--muted); padding: 2rem; }

.bj-card-back-inner { font-size: 2rem; color: rgba(240, 180, 41, 0.3); }

.dash-deposit-hd-hint {
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 0.85rem;
  max-width: 640px;
}
.dash-deposit-legacy-banner {
  font-size: 0.82rem;
  color: #f6ad55;
  line-height: 1.45;
  margin-bottom: 0.85rem;
  max-width: 720px;
  border: 1px solid rgba(246, 173, 85, 0.35);
  border-radius: 8px;
  padding: 0.65rem 0.75rem;
  background: rgba(246, 173, 85, 0.08);
}
.dash-admin-table-wrap { overflow-x: auto; }

.card-back-delay { animation-delay: 0.15s; }

.sess-net-pos { color: #c6f135; }
.sess-net-neg { color: #e24b4a; }
.sess-net-zero { color: #8b8fa8; }

#profitDisplay.profit-tone-muted { color: var(--muted); }
#profitDisplay.profit-tone-green { color: var(--green); }
#profitDisplay.profit-tone-gold { color: var(--gold); }
#profitDisplay.profit-tone-red { color: var(--red); }
.page-mines .mtile.mtile-faint { opacity: 0.3; }

.page-keno.keno-play-lock .board-wrap,
.page-keno.keno-play-lock #btnPlay {
  pointer-events: none;
  user-select: none;
}


.cases-err { color: var(--danger); }
.cases-ok { color: var(--muted); }

/* Plinko / crash: board column stack (was <style> in page) */
.page-plinko .game-layout .board-col > .board,
.page-crash .game-layout .board-col > .board {
  display: flex !important;
  flex-direction: column !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  min-height: 0 !important;
}
.page-plinko .game-layout .board-col,
.page-crash .game-layout .board-col {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
}
.page-plinko .game-layout .board-col > .board > .pegboard,
.page-crash .game-layout .board-col > .board > .pegboard {
  flex-shrink: 0 !important;
}
#dropHistory {
  flex-shrink: 0 !important;
}

.drop-history-item-pos {
  position: absolute;
  top: 4px;
  bottom: 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  padding: 0 4px;
  box-sizing: border-box;
  overflow: hidden;
  will-change: left;
}
.drop-history-item-mult { font-weight: 700; color: #c8f000; font-size: 0.8rem; overflow: hidden; text-overflow: ellipsis; max-width: 100%; white-space: nowrap; }
.drop-history-item-profit { opacity: 0.65; font-size: 0.65rem; overflow: hidden; text-overflow: ellipsis; max-width: 100%; white-space: nowrap; }

@layer lc-legacy-pages {
/* Per-page rules (formerly inline). Loaded in @layer legacy-pages — shell/base win on conflicts. */

/* === dashboard.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex}

  .sidebar{width:240px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.5rem 1rem;position:sticky;top:0;height:100vh}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.38rem;letter-spacing:0;color:var(--text);text-decoration:none;padding:0 0.5rem;margin-bottom:2rem;display:block}
  .logo span{color:var(--gold)}
  .nav-section{font-size:0.68rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase;padding:0 0.5rem;margin:1rem 0 0.4rem}
  .nav-item{display:flex;align-items:center;gap:0.6rem;padding:0.6rem 0.75rem;border-radius:8px;text-decoration:none;color:var(--muted);font-size:0.88rem;font-weight:600;transition:all 0.15s;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}
  .nav-item:hover{background:rgba(255,255,255,0.04);color:var(--text)}
  .nav-item.active{background:rgba(240,180,41,0.1);color:var(--gold)}
  .nav-item.game-link{color:var(--muted)}
  .nav-item.game-link:hover{background:rgba(240,180,41,0.06);color:var(--gold)}
  .nav-item.nav-muted{opacity:0.45;cursor:default;pointer-events:none}
  .lotta-only{display:none}
  .settings-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem;align-items:stretch}
  .settings-col{min-width:0}
  .settings-paired-card{min-height:360px}
  .testing-col{grid-column:2;grid-row:1}
  .tip-col{grid-column:3;grid-row:1}
  .users-col{grid-column:1;grid-row:2}
  .refunds-col{grid-column:3;grid-row:2}
  .users-detail-col{grid-column:2;grid-row:2}
  @media (max-width: 1100px){
    .settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .testing-col,.tip-col,.users-col,.refunds-col{grid-column:auto}
    .users-detail-col{grid-column:1 / -1;grid-row:auto}
  }
  @media (max-width: 780px){
    .settings-grid{grid-template-columns:1fr}
    .testing-col,.tip-col,.users-col,.refunds-col{grid-column:auto}
    .users-detail-col{grid-column:1;grid-row:auto}
  }
  .toggle-row{display:flex;align-items:center;justify-content:space-between;gap:0.9rem;padding:0.6rem 0;border-bottom:1px solid rgba(255,255,255,0.06)}
  .toggle-row:last-of-type{border-bottom:none}
  .toggle-row .toggle-label{color:var(--text);font-size:0.95rem}
  .toggle{position:relative;display:inline-block;width:46px;height:26px;flex:0 0 auto}
  .toggle input{opacity:0;width:0;height:0}
  .toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,0.12);transition:0.2s;border-radius:999px;border:1px solid rgba(255,255,255,0.14)}
  .toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;top:50%;transform:translateY(-50%);background:#fff;border-radius:50%;transition:0.2s;box-shadow:0 6px 14px rgba(0,0,0,0.35)}
  .toggle input:checked + .toggle-slider{background:rgba(198,241,53,0.22);border-color:rgba(198,241,53,0.35)}
  .toggle input:checked + .toggle-slider:before{transform:translate(20px,-50%)}
  .toggle input:disabled + .toggle-slider{opacity:0.5;cursor:not-allowed}
  .admin-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem;max-width:920px}
  .settings-card{height:100%;margin-top:0;max-width:none}
  .admin-panel label{display:block;font-size:0.72rem;color:var(--muted);margin-bottom:0.35rem;text-transform:uppercase;letter-spacing:0.5px}
  .admin-panel input[type=text],.admin-panel input[type=password],.admin-panel input[type=url]{width:100%;max-width:440px;padding:0.65rem 0.85rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:0.88rem;margin-bottom:0.75rem}
  .admin-row{display:flex;flex-wrap:wrap;gap:0.75rem;align-items:flex-end;margin-bottom:0.75rem}
  .pending-table{width:100%;border-collapse:collapse;font-size:0.82rem;margin-top:0.75rem}
  .pending-table th{text-align:left;padding:0.6rem 0.45rem;border-bottom:1px solid var(--border);color:var(--muted);font-size:0.68rem;text-transform:uppercase;letter-spacing:0.5px}
  .pending-table td{padding:0.65rem 0.45rem;border-bottom:1px solid rgba(255,255,255,0.06);vertical-align:top}
  .pending-table .mono{font-family:ui-monospace,monospace;font-size:0.76rem;word-break:break-all}
  .pending-actions{display:flex;flex-wrap:wrap;gap:0.35rem}
  .btn-done{padding:0.4rem 0.75rem;border-radius:6px;border:none;background:var(--green);color:#fff;font-weight:700;font-size:0.78rem;cursor:pointer}
  .btn-refund{padding:0.4rem 0.75rem;border-radius:6px;border:1px solid var(--red);background:transparent;color:#fc8181;font-weight:700;font-size:0.78rem;cursor:pointer}
  #casesJsonEditor{width:100%;min-height:320px;padding:0.85rem;background:#0d0d12;border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:ui-monospace,monospace;font-size:0.78rem;line-height:1.45;resize:vertical}
  .sidebar-bottom{margin-top:auto;border-top:1px solid var(--border);padding-top:1rem}
  .user-pill{display:flex;align-items:center;gap:0.6rem;padding:0.6rem 0.75rem;border-radius:8px}
  .avatar{width:34px;height:34px;border-radius:50%;background:rgba(240,180,41,0.1);border:1px solid rgba(240,180,41,0.2);display:flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:700;color:var(--gold);flex-shrink:0}

  .main{flex:1;display:flex;flex-direction:column;overflow:hidden;align-items:stretch}
  .topbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg2);box-shadow:0 8px 22px rgba(0,0,0,0.22)}
  .topbar-right{display:inline-flex;align-items:center;gap:0.5rem}
  .topbar-cashier-links{display:inline-flex;align-items:center;gap:0.45rem}
  .topbar-cashier-link{display:inline-flex;align-items:center;justify-content:center;padding:0.34rem 0.72rem;border-radius:999px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.03);color:#f0f0f0;text-decoration:none;font-size:0.74rem;font-weight:700}
  .topbar-cashier-link:hover{border-color:rgba(198,241,53,0.35);background:rgba(198,241,53,0.09);color:#c6f135}
  .topbar-balance-pill{display:inline-flex;align-items:center;gap:0.45rem;padding:0.32rem 0.82rem;background:#171a26;border:1px solid rgba(255,255,255,0.07);border-radius:999px}
  .topbar-balance-pill .lbl{font-size:0.78rem;color:var(--muted)}
  .page-title{font-family:'Syne',sans-serif;font-size:1.25rem;letter-spacing:-0.2px}
  .btn-sm{min-height:36px;padding:0.45rem 1rem;border-radius:999px;font-family:'DM Sans',sans-serif;font-size:0.8rem;font-weight:700;letter-spacing:0;text-transform:none;cursor:pointer;transition:opacity 0.2s,transform 0.12s}
  .btn-sm:hover{transform:translateY(-1px)}
  .btn-accent{background:var(--gold);color:#0a0a0f;border:none}
  .btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}
  .btn-ghost:hover{border-color:rgba(240,180,41,0.3)}
  .content{padding:2rem;overflow-y:auto;flex:1}
  .content{padding:1.5rem 1.75rem;max-width:1200px;width:100%;margin:0 auto}
  .content h3{font-family:'Syne',sans-serif !important;letter-spacing:-0.2px !important}

  .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}
  .stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;box-shadow:0 8px 22px rgba(0,0,0,0.2)}
  #topbarBalance{font-family:'Syne',sans-serif !important;font-size:1.05rem !important;letter-spacing:0 !important;color:var(--gold) !important}
  .stat-label{font-size:0.72rem;color:var(--muted);font-weight:600;margin-bottom:0.4rem;text-transform:uppercase;letter-spacing:0.5px}
  .stat-value{font-family:'Syne',sans-serif;font-size:1.6rem;letter-spacing:-0.3px}
  .stat-value.gold{color:var(--gold)}
  .stat-value.purple{color:#9f7aea}
  .stat-sub{font-size:0.75rem;color:var(--muted);margin-top:0.3rem}

  .tabs{display:flex;gap:0.3rem;margin-bottom:1.5rem;background:var(--bg2);padding:4px;border-radius:10px;width:fit-content;border:1px solid var(--border)}
  .tab{min-height:34px;padding:0.45rem 1.05rem;border-radius:8px;font-size:0.8rem;font-weight:700;cursor:pointer;border:none;background:transparent;color:var(--muted);transition:all 0.15s;text-transform:uppercase;letter-spacing:0.5px}
  .tab.active{background:var(--bg3);color:var(--text)}

  .tab-content{display:none}
  .tab-content.active{display:block}
  .tab-content{content-visibility:auto;contain-intrinsic-size:600px}

  .tx-list{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
  .tx-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:0.75rem 1.25rem;font-size:0.7rem;font-weight:700;color:var(--muted);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:0.5px}
  .tx-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:0.9rem 1.25rem;border-bottom:1px solid var(--border);align-items:center;transition:background 0.15s}
  .tx-row:last-child{border-bottom:none}
  .tx-row:hover{background:rgba(255,255,255,0.02)}
  .tx-name{font-size:0.875rem;font-weight:600}
  .tx-type{font-size:0.75rem;color:var(--muted);margin-top:2px}
  .tx-amount{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.95rem}
  .tx-amount.earn{color:var(--gold)}
  .tx-amount.spend{color:var(--red)}
  .tx-date{font-size:0.78rem;color:var(--muted)}
  .badge{display:inline-block;padding:2px 10px;border-radius:4px;font-size:0.68rem;font-weight:700;letter-spacing:0.5px;text-transform:uppercase}
  .badge-success{background:rgba(56,161,105,0.12);color:#68d391}
  .badge-pending{background:rgba(239,159,39,0.12);color:#ef9f27}
  .badge-failed{background:rgba(229,62,62,0.12);color:#fc8181}

  .withdraw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0.75rem;margin-bottom:1.5rem}
  .deposit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:0.75rem;margin-bottom:1rem}
  .deposit-hd-block{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;max-width:560px;margin-bottom:1rem}
  .deposit-hd-row{display:flex;gap:0.45rem;align-items:center}
  .deposit-hd-row input{flex:1;width:100%;padding:0.7rem 1rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Barlow',sans-serif;font-size:0.9rem;outline:none}
  .deposit-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;max-width:560px}
  .deposit-form input{width:100%;padding:0.7rem 1rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Barlow',sans-serif;font-size:0.9rem;outline:none;margin-bottom:0.9rem}
  .deposit-form label{display:block;font-size:0.82rem;color:var(--muted);margin-bottom:0.4rem}
  .method-card{background:var(--bg2);border:2px solid var(--border);border-radius:12px;padding:1rem;text-align:center;cursor:pointer;transition:border-color 0.2s,transform 0.12s}
  .method-card.selected{border-color:var(--gold)}
  .method-card:hover{border-color:rgba(240,180,41,0.3);transform:translateY(-1px)}
  .method-icon{font-size:1.75rem;margin-bottom:0.4rem}
  .method-name{font-size:0.82rem;font-weight:600}
  .method-min{font-size:0.72rem;color:var(--muted)}
  .withdraw-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;max-width:480px}
  .withdraw-split{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start}
  .withdraw-history{flex:1;min-width:300px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;max-height:420px;overflow:auto}
  .withdraw-head{display:flex;align-items:center;justify-content:space-between;gap:0.75rem;margin-bottom:0.65rem}
  .withdraw-head h4{font-size:0.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
  .withdraw-list{display:flex;flex-direction:column;gap:0.45rem}
  .withdraw-item{display:grid;grid-template-columns:1fr auto;gap:0.5rem;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:8px;padding:0.55rem 0.65rem}
  .withdraw-item .w-meta{font-size:0.74rem;color:var(--muted)}
  .withdraw-item .w-amt{font-weight:700;color:var(--gold);font-size:0.85rem}
  .withdraw-empty{color:var(--muted);font-size:0.82rem;padding:0.75rem 0}
  .withdraw-form label{display:block;font-size:0.82rem;color:var(--muted);margin-bottom:0.4rem}
  .withdraw-form input{width:100%;padding:0.7rem 1rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Barlow',sans-serif;font-size:0.9rem;outline:none;margin-bottom:1rem}
  .withdraw-form input:focus{border-color:rgba(240,180,41,0.4)}
  .balance-hint{font-size:0.8rem;color:var(--muted);margin-bottom:1rem}
  .balance-hint span{color:var(--gold);font-weight:700}

  .notif{position:fixed;bottom:2rem;right:2rem;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:0.85rem 1.25rem;font-size:0.875rem;display:none;z-index:999}
  .notif.show{display:block;animation:slideUp 0.3s ease}
  .notif.success{border-color:rgba(56,161,105,0.4);color:#68d391}
  .notif.error{border-color:rgba(229,62,62,0.4);color:#fc8181}
  @keyframes slideUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
  @media(max-width:900px){
    body{display:block}
    .sidebar{
      position:sticky;
      top:0;
      width:100%;
      height:auto;
      padding:0.6rem 0.7rem;
      border-right:none;
      border-bottom:1px solid var(--border);
      z-index:60;
      overflow-x:auto;
      white-space:nowrap;
      flex-direction:row;
      align-items:center;
      gap:0.35rem;
    }
    .sidebar .logo{margin:0 0.35rem 0 0;padding:0 0.35rem;font-size:1.04rem;flex:0 0 auto}
    .sidebar .nav-section{display:none}
    .sidebar .nav-item{width:auto;flex:0 0 auto;padding:0.45rem 0.65rem;font-size:0.78rem;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.02)}
    .sidebar-bottom{margin-top:0;border-top:none;padding-top:0;display:flex;align-items:center;gap:0.35rem;flex:0 0 auto}
    .user-pill{padding:0.2rem 0.35rem}
    #sidebarEmail{display:none}
    .avatar{width:26px;height:26px;font-size:0.68rem}
    .main{overflow:visible}
    .topbar{padding:0.72rem 0.9rem;flex-wrap:wrap;gap:0.5rem}
    .topbar-right{width:100%;justify-content:flex-end;gap:0.4rem}
    .topbar-cashier-link{padding:0.32rem 0.62rem;font-size:0.7rem}
    .topbar-balance-pill{padding:0.28rem 0.7rem}
    .topbar-balance-pill .lbl{font-size:0.72rem}
    .page-title{font-size:1.05rem}
    .content{padding:1rem 0.85rem;max-width:none}
    .tx-header{display:none}
    .tx-row{grid-template-columns:1fr;gap:0.25rem;padding:0.75rem 0.9rem}
    .withdraw-history{min-width:0;max-height:none}
    .notif{left:0.9rem;right:0.9rem;bottom:1rem}
  }
  @media(max-width:480px){
    .sidebar{padding:0.4rem 0.5rem}
    .sidebar .logo{font-size:0.9rem}
    .sidebar .nav-item{padding:0.35rem 0.5rem;font-size:0.72rem}
    .sidebar .avatar{width:22px;height:22px;font-size:0.6rem}
    .topbar{padding:0.58rem 0.7rem}
    .topbar-right{gap:0.3rem}
    .topbar-cashier-links{gap:0.3rem}
    .topbar-cashier-link{padding:0.26rem 0.5rem;font-size:0.66rem}
    .topbar-balance-pill{padding:0.24rem 0.56rem}
    .topbar-balance-pill .lbl{display:none}
    .page-title{font-size:0.95rem}
    .content{padding:0.75rem 0.6rem}
    .stats-grid{grid-template-columns:repeat(2,1fr);gap:0.65rem;margin-bottom:1.25rem}
    .stat-card{padding:0.85rem}
    .stat-value{font-size:1.3rem}
    .settings-grid{grid-template-columns:1fr}
    .withdraw-split{flex-direction:column}
    .tabs{width:100%;overflow-x:auto}
    .tx-row{padding:0.65rem 0.75rem}
  }

/* === extras/nav.html (inline) === */
/* ── Shared design tokens ─────────────────────────────────── */
:root {
  --navbar-height:    56px;
  --color-bg-deep:    #0b0d14;
  --color-bg-mid:     #0e1324;
  --color-bg-nav:     #13151f;
  --color-bg-pill:    #171a26;
  --color-border:     rgba(255, 255, 255, 0.07);
  --color-border-soft:rgba(255, 255, 255, 0.05);
  --color-text:       #f0f0f0;
  --color-text-muted: #8b8fa8;
  --color-text-light: #cfd3ff;
  --color-accent:     #c6f135;
  --color-accent-dim: rgba(198, 241, 53, 0.2);
  --color-danger:     #ff6b6b;
  --font-display:     'Syne', sans-serif;
  --font-body:        'DM Sans', sans-serif;
}

/* ── SIDEBAR ──────────────────────────────────────────────── */
.lotta-sidebar {
  width: 220px;
  height: calc(100vh - var(--navbar-height));
  background: linear-gradient(180deg, var(--color-bg-deep) 0%, var(--color-bg-mid) 100%);
  border-right: 1px solid var(--color-border-soft);
  display: flex;
  flex-direction: column;
  padding: 1.2rem 1rem;
  font-family: var(--font-body);
}

/* Logo */
.sidebar-logo {
  margin-bottom: 1.5rem;
}

.logo-main {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.4rem;
  color: var(--color-text);
}

.logo-main span {
  color: var(--color-accent);
}

/* Section label */
.sidebar-label {
  font-size: 0.7rem;
  letter-spacing: 2px;
  color: #6f7590;
  margin-bottom: 0.75rem;
}

/* Nav items */
.sidebar-item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.65rem 0.7rem;
  border-radius: 10px;
  color: var(--color-text-light);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 600;
  transition: all 0.2s;
}

.sidebar-item:hover {
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
}

.sidebar-item.active {
  background: linear-gradient(90deg, var(--color-accent-dim), rgba(198, 241, 53, 0.05));
  color: var(--color-accent);
}

/* Bottom section */
.sidebar-bottom {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border-soft);
}

.sidebar-help {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(198, 241, 53, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
  font-weight: 700;
}

.sidebar-loading {
  color: var(--color-text-light);
  font-size: 0.9rem;
}

.sidebar-login {
  color: var(--color-danger);
  text-decoration: none;
  font-weight: 700;
  font-size: 0.95rem;
}

.sidebar-login:hover {
  text-decoration: underline;
}

/* ── NAVBAR ───────────────────────────────────────────────── */
.lotta-navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.85rem 1.5rem;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-nav);
}

/* Logo */
.logo {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--color-text);
  text-decoration: none;
}

.logo span {
  color: var(--color-accent);
}

/* Back button */
.nav-back {
  color: var(--color-text-muted);
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 600;
  transition: color 0.2s;
}

.nav-back:hover {
  color: var(--color-accent);
}

/* Balance pill */
.balance-pill {
  background: var(--color-bg-pill);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.4rem 1rem;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-accent);
}

.balance-pill .lotta-bal-main {
  display: block;
  font-size: 0.88rem;
  line-height: 1.2;
}

.balance-pill .lotta-bal-fiat {
  display: block;
  font-size: 0.72rem;
  color: var(--color-text-muted);
  font-weight: 600;
  margin-top: 0.12rem;
}

/* === extras/navbar.html (inline) === */
.lotta-navbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0.85rem 1.5rem;
  border-bottom:1px solid rgba(255,255,255,0.07);
  background:#13151f;
}

/* Logo */
.logo{
  font-family:'Syne',sans-serif;
  font-weight:800;
  font-size:1.2rem;
  color:#f0f0f0;
  text-decoration:none;
}
.logo span{color:#c6f135}

/* Back button */
.nav-back{
  color:#8b8fa8;
  text-decoration:none;
  font-size:0.85rem;
  font-weight:600;
  transition:color 0.2s;
}
.nav-back:hover{color:#c6f135}

/* Balance pill */
.balance-pill{
  background:#171a26;
  border:1px solid rgba(255,255,255,0.07);
  border-radius:999px;
  padding:0.4rem 1rem;
  font-family:'Syne',sans-serif;
  font-size:0.95rem;
  font-weight:700;
  color:#c6f135;
}

.balance-pill .lotta-bal-main{
  display:block;
  font-size:0.88rem;
  line-height:1.2;
}
.balance-pill .lotta-bal-fiat{
  display:block;
  font-size:0.72rem;
  color:#8b8fa8;
  font-weight:600;
  margin-top:0.12rem;
}

/* === extras/sidebar.html (inline) === */
.lotta-sidebar{
  width:220px;
  height:100vh;
  background:linear-gradient(180deg,#0b0d14 0%, #0e1324 100%);
  border-right:1px solid rgba(255,255,255,0.05);
  display:flex;
  flex-direction:column;
  padding:1.2rem 1rem;
  font-family:'DM Sans',sans-serif;
}

/* Logo */
.sidebar-logo{
  margin-bottom:1.5rem;
}

.logo-main{
  font-family:'Syne',sans-serif;
  font-weight:800;
  font-size:1.4rem;
  color:#f0f0f0;
}
.logo-main span{
  color:#c6f135;
}

/* Section */
.sidebar-label{
  font-size:0.7rem;
  letter-spacing:2px;
  color:#6f7590;
  margin-bottom:0.75rem;
}

/* Items */
.sidebar-item{
  display:flex;
  align-items:center;
  gap:0.6rem;
  padding:0.65rem 0.7rem;
  border-radius:10px;
  color:#cfd3ff;
  text-decoration:none;
  font-size:0.95rem;
  font-weight:600;
  transition:all 0.2s;
}

.sidebar-item:hover{
  background:rgba(255,255,255,0.05);
  color:#fff;
}

.sidebar-item.active{
  background:linear-gradient(90deg, rgba(198,241,53,0.2), rgba(198,241,53,0.05));
  color:#c6f135;
}

/* Bottom */
.sidebar-bottom{
  margin-top:auto;
  display:flex;
  flex-direction:column;
  gap:0.8rem;
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,0.05);
}

.sidebar-help{
  width:32px;
  height:32px;
  border-radius:50%;
  border:1px solid rgba(198,241,53,0.4);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#c6f135;
  font-weight:700;
}

.sidebar-loading{
  color:#cfd3ff;
  font-size:0.9rem;
}

.sidebar-login{
  color:#ff6b6b;
  text-decoration:none;
  font-weight:700;
  font-size:0.95rem;
}

.sidebar-login:hover{
  text-decoration:underline;
}

/* === forgot.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  :root { --bg: #0b0d14; --bg2: #13151f; --accent: #c6f135; --text: #f0f0f0; --muted: #8b8fa8; --card-border: rgba(255,255,255,0.07); --danger: #e24b4a; }
  body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; min-height: 100vh; display: flex; flex-direction: column; }
  nav { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 2.5rem; border-bottom: 1px solid var(--card-border); }
  .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.4rem; text-decoration: none; color: var(--text); }
  .logo span { color: var(--accent); }
  .nav-link { font-size: 0.875rem; color: var(--muted); text-decoration: none; }
  .nav-link:hover { color: var(--text); }
  main { flex: 1; display: flex; align-items: center; justify-content: center; padding: 3rem 1.5rem; }
  .auth-card { background: var(--bg2); border: 1px solid var(--card-border); border-radius: 24px; padding: 2.5rem; width: 100%; max-width: 420px; }
  .auth-title { font-family: 'Syne', sans-serif; font-size: 1.75rem; font-weight: 800; letter-spacing: -0.5px; margin-bottom: 0.4rem; }
  .auth-sub { color: var(--muted); font-size: 0.9rem; margin-bottom: 2rem; line-height: 1.5; }
  .auth-sub a { color: var(--accent); text-decoration: none; }
  .form-group { margin-bottom: 1rem; }
  label { display: block; font-size: 0.85rem; font-weight: 500; color: var(--muted); margin-bottom: 0.4rem; }
  input { width: 100%; padding: 0.75rem 1rem; background: rgba(255,255,255,0.05); border: 1px solid var(--card-border); border-radius: 10px; color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; outline: none; transition: border-color 0.2s; }
  input:focus { border-color: rgba(198,241,53,0.4); }
  .btn-submit { width: 100%; padding: 0.85rem; border: none; border-radius: 50px; background: var(--accent); color: #0b0d14; font-family: 'DM Sans', sans-serif; font-size: 1rem; font-weight: 700; cursor: pointer; margin-top: 0.5rem; transition: opacity 0.2s; }
  .btn-submit:hover { opacity: 0.9; }
  .btn-submit:disabled { opacity: 0.5; cursor: not-allowed; }
  .alert { padding: 0.75rem 1rem; border-radius: 10px; font-size: 0.875rem; margin-bottom: 1rem; display: none; }
  .alert.show { display: block; }
  .alert-error { background: rgba(226,75,74,0.1); border: 1px solid rgba(226,75,74,0.3); color: #f09595; }
  .alert-success { background: rgba(198,241,53,0.1); border: 1px solid rgba(198,241,53,0.3); color: var(--accent); }
  .spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid rgba(11,13,20,0.3); border-top-color: #0b0d14; border-radius: 50%; animation: spin 0.7s linear infinite; vertical-align: middle; }
  @keyframes spin { to { transform: rotate(360deg); } }

/* === index.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  :root {
    --bg: #0b0d14; --bg2: #13151f; --bg3: #171a26;
    --gold: #c6f135; --gold2: #c6f135;
    --red: #e24b4a; --green: #41c77a;
    --text: #f0f0f0; --muted: #8b8fa8;
    --border: rgba(255,255,255,0.07); --radius: 16px;
  }
  body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; overflow-x: hidden; }
  nav { display: flex; align-items: center; justify-content: space-between; padding: 1rem 2.5rem; border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 100; background: var(--bg2); backdrop-filter: blur(16px); }
  .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.35rem; letter-spacing: 0; color: var(--text); text-decoration: none; }
  .logo span { color: var(--gold); }
  .nav-links { display: flex; align-items: center; gap: 2rem; list-style: none; }
  .nav-links a { text-decoration: none; color: var(--muted); font-weight: 600; font-size: 0.85rem; letter-spacing: 0.5px; text-transform: uppercase; transition: color 0.2s; }
  .nav-links a:hover { color: var(--gold); }
  .nav-cta { display: flex; gap: 0.75rem; align-items: center; }
  .btn-outline { padding: 0.5rem 1.25rem; border: 1px solid var(--border); border-radius: 6px; background: transparent; color: var(--text); font-family: 'Barlow', sans-serif; font-size: 0.85rem; font-weight: 600; cursor: pointer; text-decoration: none; transition: border-color 0.2s; text-transform: uppercase; letter-spacing: 0.5px; }
  .btn-outline:hover { border-color: var(--gold); color: var(--gold); }
  .btn-gold { padding: 0.5rem 1.4rem; border: none; border-radius: 6px; background: var(--gold); color: #0a0a0f; font-family: 'Barlow', sans-serif; font-size: 0.85rem; font-weight: 700; cursor: pointer; text-decoration: none; transition: opacity 0.2s, transform 0.15s; text-transform: uppercase; letter-spacing: 0.5px; display: inline-block; }
  .btn-gold:hover { opacity: 0.9; transform: scale(1.02); }
  .nav-cta button.btn-gold { border: none; cursor: pointer; font-family: 'Barlow', sans-serif; }
  .hero { position: relative; min-height: 88vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 5rem 2rem; overflow: hidden; }
  .hero-glow { position: absolute; top: -200px; left: 50%; transform: translateX(-50%); width: 900px; height: 900px; background: radial-gradient(ellipse, rgba(240,180,41,0.07) 0%, transparent 65%); pointer-events: none; }
  .chip { position: absolute; font-size: 2rem; opacity: 0.05; animation: float linear infinite; }
  @keyframes float { 0% { transform: translateY(100vh) rotate(0deg); } 100% { transform: translateY(-200px) rotate(360deg); } }
  .live-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(229,62,62,0.12); border: 1px solid rgba(229,62,62,0.35); border-radius: 4px; padding: 0.3rem 0.9rem; font-size: 0.75rem; font-weight: 700; color: #fc8181; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 1.5rem; }
  .live-dot { width: 6px; height: 6px; border-radius: 50%; background: #fc8181; animation: blink 1.2s infinite; }
  @keyframes blink { 0%,100% { opacity:1; } 50% { opacity: 0.3; } }
  .hero h1 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(4rem, 10vw, 9rem); letter-spacing: 4px; line-height: 0.95; color: var(--text); }
  .hero h1 .gold-line { display: block; color: var(--gold); text-shadow: 0 0 60px rgba(240,180,41,0.5), 0 0 120px rgba(240,180,41,0.2); }
  .hero-sub { margin-top: 1.5rem; font-size: 1.05rem; color: var(--muted); max-width: 480px; font-weight: 500; line-height: 1.6; }
  .hero-actions { margin-top: 2.5rem; display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }
  .btn-hero { padding: 1rem 2.75rem; border: none; border-radius: 6px; background: var(--gold); color: #0a0a0f; font-family: 'Barlow Condensed', sans-serif; font-size: 1.1rem; font-weight: 800; cursor: pointer; text-decoration: none; letter-spacing: 1px; text-transform: uppercase; box-shadow: 0 0 40px rgba(240,180,41,0.35); transition: transform 0.15s, box-shadow 0.15s; display: inline-block; }
  .btn-hero:hover { transform: translateY(-2px); box-shadow: 0 0 60px rgba(240,180,41,0.5); }
  .btn-hero-ghost { padding: 1rem 2.25rem; border-radius: 6px; border: 1px solid var(--border); background: transparent; color: var(--text); font-family: 'Barlow Condensed', sans-serif; font-size: 1.1rem; font-weight: 700; cursor: pointer; text-decoration: none; letter-spacing: 1px; text-transform: uppercase; transition: border-color 0.2s; display: inline-block; }
  .btn-hero-ghost:hover { border-color: rgba(240,180,41,0.4); color: var(--gold); }
  .hero-stats { margin-top: 4rem; display: flex; flex-wrap: wrap; justify-content: center; background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
  .hero-stat { padding: 1.25rem 2.5rem; text-align: center; border-right: 1px solid var(--border); }
  .hero-stat:last-child { border-right: none; }
  .hero-stat-num { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; letter-spacing: 1px; color: var(--gold); }
  .hero-stat-label { font-size: 0.72rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; }
  .marquee-wrap { background: var(--bg2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0.8rem 0; overflow: hidden; }
  .marquee-track { display: flex; gap: 3rem; white-space: nowrap; animation: marquee 25s linear infinite; }
  @keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
  .marquee-item { font-size: 0.8rem; font-weight: 600; color: var(--muted); letter-spacing: 0.5px; flex-shrink: 0; }
  .marquee-item .win { color: var(--gold); font-weight: 700; }
  .sec { padding: 5rem 2.5rem; max-width: 1200px; margin: 0 auto; }
  .sec { content-visibility: auto; contain-intrinsic-size: 700px; }
  .sec-label { font-size: 0.72rem; font-weight: 700; color: var(--gold); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 0.5rem; }
  .sec-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(2.5rem, 5vw, 4rem); letter-spacing: 2px; line-height: 1; margin-bottom: 1rem; }
  .games-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(215px, 1fr)); gap: 1.25rem; margin-top: 2.5rem; }
  .game-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; cursor: pointer; transition: transform 0.2s, border-color 0.2s, box-shadow 0.2s; text-decoration: none; color: inherit; display: block; }
  .game-card:hover { transform: translateY(-6px); border-color: rgba(240,180,41,0.4); box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 30px rgba(240,180,41,0.08); }
  .game-card.disabled { cursor: not-allowed; opacity: 0.45; pointer-events: none; }
  .game-thumb { height: 155px; display: flex; align-items: center; justify-content: center; font-size: 4rem; position: relative; }
  .game-thumb-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 40%, var(--bg2)); }
  .game-info { padding: 1rem 1.1rem 1.25rem; }
  .game-name { font-family: 'Barlow Condensed', sans-serif; font-size: 1.2rem; font-weight: 700; letter-spacing: 0.5px; margin-bottom: 4px; }
  .game-meta { font-size: 0.8rem; color: var(--muted); }
  .game-badge { position: absolute; top: 10px; left: 10px; background: rgba(0,0,0,0.6); border: 1px solid rgba(240,180,41,0.3); border-radius: 4px; padding: 2px 8px; font-size: 0.65rem; font-weight: 700; color: var(--gold); letter-spacing: 1px; text-transform: uppercase; backdrop-filter: blur(4px); z-index: 2; }
  .game-edge { font-size: 0.75rem; margin-top: 0.3rem; display: flex; align-items: center; gap: 4px; }
  .rtp { color: var(--green); font-weight: 600; }
  .gold-line-div { height: 1px; background: linear-gradient(to right, transparent, var(--gold), transparent); opacity: 0.15; }
  .wins-table { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
  .wins-row { display: grid; grid-template-columns: 1fr 1.2fr 1fr 1fr; padding: 0.85rem 1.5rem; border-bottom: 1px solid rgba(240,180,41,0.06); align-items: center; font-size: 0.875rem; transition: background 0.15s; }
  .wins-row:last-child { border-bottom: none; }
  .wins-row:hover { background: rgba(255,255,255,0.02); }
  .wins-header { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--muted); font-weight: 700; }
  .wins-amount { font-family: 'Barlow Condensed', sans-serif; font-size: 1rem; font-weight: 700; color: var(--gold); }
  .wins-mult { color: var(--green); font-weight: 700; font-size: 0.85rem; }
  .wins-user { color: var(--muted); font-size: 0.82rem; }
  footer { border-top: 1px solid var(--border); padding: 2rem 2.5rem; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
  .footer-links { display: flex; gap: 1.5rem; list-style: none; }
  .footer-links a { text-decoration: none; font-size: 0.78rem; color: var(--muted); transition: color 0.2s; }
  .footer-links a:hover { color: var(--gold); }
  .footer-copy { font-size: 0.78rem; color: var(--muted); }
  .reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.55s ease, transform 0.55s ease; }
  .reveal.visible { opacity: 1; transform: translateY(0); }

  body.with-play-shell nav { padding-left: 2rem; padding-right: 2rem; }
  @media (max-width: 900px) {
    nav { padding: 0.85rem 1rem; }
    .nav-links { gap: 0.9rem; }
    .nav-links a { font-size: 0.75rem; }
    .hero { min-height: auto; padding: 3.2rem 1rem 2.4rem; }
    .hero-sub { font-size: 0.93rem; }
    .hero-actions { margin-top: 1.4rem; }
    .btn-hero, .btn-hero-ghost { padding: 0.8rem 1.1rem; font-size: 0.95rem; }
    .hero-stat { padding: 0.9rem 1rem; }
    .sec { padding: 2.2rem 1rem; }
    .wins-row { grid-template-columns: 1fr; gap: 0.18rem; padding: 0.75rem 0.9rem; }
    .wins-header { display: none; }
    footer { padding: 1.2rem 1rem; }
  }
  @media (max-width: 560px) {
    .nav-links { display: none; }
    .nav-cta { gap: 0.45rem; }
    .btn-outline, .btn-gold { padding: 0.45rem 0.8rem; font-size: 0.76rem; }
    .hero h1 { letter-spacing: 1px; }
    .games-grid { grid-template-columns: 1fr; gap: 0.9rem; }
    .game-thumb { height: 120px; font-size: 3rem; }
  }
  @media (max-width: 480px) {
    nav { padding: 0.7rem 0.75rem; }
    .hero { padding: 2.5rem 0.75rem 2rem; }
    .hero-sub { font-size: 0.88rem; }
    .hero-actions { gap: 0.65rem; }
    .btn-hero { padding: 0.75rem 1.5rem; font-size: 0.9rem; }
    .btn-hero-ghost { padding: 0.75rem 1.25rem; font-size: 0.9rem; }
    .hero-stats { margin-top: 2rem; }
    .hero-stat { padding: 0.75rem 0.85rem; flex: 1 1 calc(50% - 1px); }
    .hero-stat-num { font-size: 1.6rem; }
    .sec { padding: 1.75rem 0.75rem; }
    .games-grid { grid-template-columns: repeat(2, 1fr); gap: 0.65rem; }
    .game-thumb { height: 100px; font-size: 2.5rem; }
    .game-info { padding: 0.75rem 0.85rem 0.9rem; }
    .game-name { font-size: 1rem; }
    footer { padding: 1rem 0.75rem; flex-direction: column; align-items: flex-start; }
    .footer-links { gap: 1rem; flex-wrap: wrap; }
  }

/* === login.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  :root { --bg: #0b0d14; --bg2: #13151f; --accent: #c6f135; --text: #f0f0f0; --muted: #8b8fa8; --card-border: rgba(255,255,255,0.07); --danger: #e24b4a; }
  body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; min-height: 100vh; display: flex; flex-direction: column; }
  nav { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 2.5rem; border-bottom: 1px solid var(--card-border); }
  .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.4rem; text-decoration: none; color: var(--text); }
  .logo span { color: var(--accent); }
  .nav-link { font-size: 0.875rem; color: var(--muted); text-decoration: none; }
  .nav-link:hover { color: var(--text); }
  main { flex: 1; display: flex; align-items: center; justify-content: center; padding: 3rem 1.5rem; }
  .auth-card { background: var(--bg2); border: 1px solid var(--card-border); border-radius: 24px; padding: 2.5rem; width: 100%; max-width: 420px; }
  .auth-title { font-family: 'Syne', sans-serif; font-size: 1.75rem; font-weight: 800; letter-spacing: -0.5px; margin-bottom: 0.4rem; }
  .auth-sub { color: var(--muted); font-size: 0.9rem; margin-bottom: 2rem; }
  .auth-sub a { color: var(--accent); text-decoration: none; }
  .form-group { margin-bottom: 1rem; }
  label { display: block; font-size: 0.85rem; font-weight: 500; color: var(--muted); margin-bottom: 0.4rem; }
  input { width: 100%; padding: 0.75rem 1rem; background: rgba(255,255,255,0.05); border: 1px solid var(--card-border); border-radius: 10px; color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; outline: none; transition: border-color 0.2s; }
  input:focus { border-color: rgba(198,241,53,0.4); }
  a:focus-visible, button:focus-visible, input:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
  input::placeholder { color: var(--muted); }
  .forgot { display: block; text-align: right; font-size: 0.8rem; color: var(--muted); text-decoration: none; margin-top: 0.35rem; }
  .forgot:hover { color: var(--text); }
  .btn-submit { width: 100%; padding: 0.85rem; border: none; border-radius: 50px; background: var(--accent); color: #0b0d14; font-family: 'DM Sans', sans-serif; font-size: 1rem; font-weight: 700; cursor: pointer; margin-top: 0.5rem; transition: opacity 0.2s, transform 0.15s; }
  .btn-submit:hover { opacity: 0.9; }
  .btn-submit:active { transform: scale(0.98); }
  .btn-submit:disabled { opacity: 0.5; cursor: not-allowed; }
  .divider { display: flex; align-items: center; gap: 1rem; margin: 1.25rem 0; color: var(--muted); font-size: 0.8rem; }
  .divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: var(--card-border); }
  .btn-google { width: 100%; padding: 0.75rem; border: 1px solid var(--card-border); border-radius: 50px; background: transparent; color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; font-weight: 500; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 0.6rem; transition: border-color 0.2s, background 0.2s; }
  .btn-google:hover { border-color: rgba(255,255,255,0.25); background: rgba(255,255,255,0.04); }
  .alert { padding: 0.75rem 1rem; border-radius: 10px; font-size: 0.875rem; margin-bottom: 1rem; display: none; }
  .alert.show { display: block; }
  .alert-error { background: rgba(226,75,74,0.1); border: 1px solid rgba(226,75,74,0.3); color: #f09595; }
  .spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid rgba(11,13,20,0.3); border-top-color: #0b0d14; border-radius: 50%; animation: spin 0.7s linear infinite; vertical-align: middle; }
  @keyframes spin { to { transform: rotate(360deg); } }
  @media(max-width:480px){
    nav{padding:0.75rem 1rem}
    main{padding:1.5rem 0.75rem}
    .auth-card{padding:1.75rem 1.25rem;border-radius:16px}
    .auth-title{font-size:1.5rem}
  }

/* === lotta-queue.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0a0a0f;--bg2:#111118;--gold:#f0b429;--text:#f0ebe0;--muted:#7a7570;--border:rgba(240,180,41,0.15);--red:#e53e3e;--green:#38a169}
  body{background:var(--bg);color:var(--text);font-family:'Barlow',sans-serif;min-height:100vh;padding:1.5rem;line-height:1.5}
  h1{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:3px;color:var(--gold)}
  .sub{color:var(--muted);font-size:0.88rem;max-width:720px;margin:0.5rem 0 1.25rem}
  .warn{background:rgba(229,62,62,0.1);border:1px solid rgba(229,62,62,0.35);border-radius:10px;padding:0.85rem 1rem;font-size:0.82rem;margin-bottom:1.25rem;max-width:720px}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.25rem;max-width:960px;margin-bottom:1.5rem}
  label{display:block;font-size:0.75rem;color:var(--muted);margin-bottom:0.35rem;text-transform:uppercase;letter-spacing:0.5px}
  input{width:100%;max-width:440px;padding:0.65rem 0.85rem;border-radius:8px;border:1px solid var(--border);background:#18181f;color:var(--text);font-family:inherit;margin-bottom:0.75rem}
  input:focus{outline:none;border-color:rgba(240,180,41,0.45)}
  .row{display:flex;flex-wrap:wrap;gap:0.75rem;align-items:flex-end;margin-bottom:1rem}
  button{padding:0.55rem 1.1rem;border-radius:8px;font-family:inherit;font-weight:700;cursor:pointer;border:none;font-size:0.85rem}
  .btn-load{background:var(--gold);color:#0a0a0f}
  .btn-load:disabled{opacity:0.5;cursor:not-allowed}
  .btn-done{background:var(--green);color:#fff}
  .btn-fail{background:transparent;border:1px solid var(--red);color:#fc8181}
  table{width:100%;border-collapse:collapse;font-size:0.82rem}
  th{text-align:left;padding:0.65rem 0.5rem;border-bottom:1px solid var(--border);color:var(--muted);font-size:0.7rem;text-transform:uppercase;letter-spacing:0.5px}
  td{padding:0.75rem 0.5rem;border-bottom:1px solid rgba(255,255,255,0.05);vertical-align:top}
  tr:hover{background:rgba(255,255,255,0.02)}
  .mono{font-family:ui-monospace,monospace;font-size:0.78rem;word-break:break-all}
  .amt{color:var(--gold);font-weight:700}
  #status{font-size:0.85rem;margin-top:0.75rem}
  #status.err{color:#fc8181}
  #status.ok{color:var(--green)}
  .empty{color:var(--muted);padding:2rem;text-align:center}
  a{color:var(--gold)}

/* === maintenance.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root { --bg: #0b0d14; --bg2: #13151f; --text: #f0f0f0; --muted: #8b8fa8; --accent: #c6f135; --border: rgba(255,255,255,0.10); }
    body { background: radial-gradient(1100px 700px at 20% 0%, rgba(198,241,53,0.08), transparent 60%),
                   radial-gradient(900px 600px at 90% 40%, rgba(127,90,240,0.10), transparent 60%),
                   var(--bg);
           color: var(--text); font-family: 'DM Sans', sans-serif; min-height: 100vh; display: flex; }
    .wrap { width: 100%; max-width: 720px; margin: auto; padding: 3rem 1.5rem; }
    .card { background: rgba(19,21,31,0.9); border: 1px solid var(--border); border-radius: 22px; padding: 2.25rem; }
    .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.5rem; letter-spacing: -0.5px; margin-bottom: 0.6rem; }
    .logo span { color: var(--accent); }
    h1 { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 2.0rem; margin: 0.2rem 0 0.75rem; }
    p { color: var(--muted); line-height: 1.6; font-size: 1rem; }
    .msg { margin-top: 0.9rem; padding: 0.9rem 1rem; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 14px; color: var(--text); }
    .row { display:flex; align-items:center; gap: 0.75rem; margin-top: 1.2rem; flex-wrap: wrap; }
    .pill { font-size: 0.85rem; color: var(--muted); border: 1px solid rgba(255,255,255,0.12); padding: 0.45rem 0.7rem; border-radius: 999px; }
    .btn { display:inline-flex; align-items:center; justify-content:center; gap:0.5rem; border-radius:999px; padding:0.65rem 0.95rem; border:1px solid rgba(255,255,255,0.16); background: rgba(255,255,255,0.04); color: var(--text); text-decoration:none; cursor:pointer; font-weight:600; }
    .btn:hover { background: rgba(255,255,255,0.06); }
    .btn-primary { border-color: rgba(198,241,53,0.35); background: rgba(198,241,53,0.12); }
    .btn-primary:hover { background: rgba(198,241,53,0.18); }
    .small { font-size: 0.85rem; color: var(--muted); margin-top: 1.1rem; }

/* === play/blackjack.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.4rem 1rem;font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;color:var(--gold)}

  .game-wrap{flex:1;display:flex;flex-direction:column;align-items:stretch;padding:1rem 1.5rem 1.25rem;gap:0.75rem;width:100%}
  .game-title{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  
  .felt{
    width:100%;
    display:flex;
    flex-direction:column;
    position:relative;
    overflow:hidden;
    flex:1;
    min-height:340px;
    padding:2rem;
    border-radius:20px;
    border:3px solid rgba(198,241,53,0.22);
    box-shadow:0 0 80px rgba(0,0,0,0.75), inset 0 0 100px rgba(0,0,0,0.45);
    background-color:#0c2418;
    background-image:
      radial-gradient(ellipse 130% 55% at 50% -5%, rgba(65,199,122,0.22) 0%, transparent 52%),
      radial-gradient(ellipse 90% 70% at 50% 100%, rgba(0,0,0,0.35) 0%, transparent 45%),
      repeating-linear-gradient(92deg, rgba(0,0,0,0.04) 0 1px, transparent 1px 3px),
      repeating-linear-gradient(2deg, rgba(255,255,255,0.018) 0 1px, transparent 1px 4px),
      linear-gradient(168deg, #143a28 0%, #0d2619 42%, #071910 100%);
  }
  .felt::before{
    content:'';
    position:absolute;
    inset:10px;
    border:1px solid rgba(198,241,53,0.1);
    border-radius:14px;
    pointer-events:none;
    z-index:0;
  }
  /* Padded felt “rail” across the top of the table */
  .felt-dealer-rail{
    position:relative;
    z-index:1;
    flex-shrink:0;
    height:50px;
    margin-bottom:1.1rem;
    border-radius:12px;
    border:1px solid rgba(198,241,53,0.16);
    background-image:
      linear-gradient(180deg, rgba(255,255,255,0.07) 0%, transparent 42%),
      repeating-linear-gradient(88deg, rgba(0,0,0,0.06) 0 1px, transparent 1px 2px),
      linear-gradient(180deg, #1a4d34 0%, #0f3022 55%, #0a2418 100%);
    box-shadow:inset 0 -10px 22px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.05);
  }

  .dealer-area, .player-area{display:flex;flex-direction:column;align-items:center;gap:0.75rem;position:relative;z-index:1}
  .area-label{font-family:'Barlow Condensed',sans-serif;font-size:0.8rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(198,241,53,0.78)}
  .cards{display:flex;gap:0.75rem;flex-wrap:wrap;justify-content:center;min-height:100px;align-items:center}
  .hand-group{display:flex;flex-direction:column;align-items:center;gap:0.45rem;padding:0.75rem 0.9rem;border-radius:12px;border:1px solid rgba(198,241,53,0.1);background:rgba(0,0,0,0.14)}
  .hand-group.active{border-color:rgba(198,241,53,0.38);box-shadow:0 0 0 2px rgba(198,241,53,0.1)}
  .hand-label{font-size:0.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
  
  .card{width:70px;height:100px;border-radius:8px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.6rem;font-weight:900;box-shadow:0 4px 16px rgba(0,0,0,0.6);position:relative;cursor:default;animation:dealCard 0.3s ease both;flex-shrink:0}
  @keyframes dealCard{from{opacity:0;transform:translateY(-20px) scale(0.8)}to{opacity:1;transform:translateY(0) scale(1)}}
  .card.red{color:#d32f2f}
  .card.black{color:#1a1a1a}
  .card.back{background:linear-gradient(135deg,#1a3a6a,#0d2045);border:2px solid rgba(198,241,53,0.35)}
  .card-corner{position:absolute;top:4px;left:6px;font-size:0.8rem;font-weight:700;line-height:1}
  .card-corner.bot{top:auto;bottom:4px;left:auto;right:6px;transform:rotate(180deg)}
  .card-suit{font-size:1.8rem}

  .score-badge{background:rgba(0,0,0,0.5);border:1px solid var(--border);border-radius:4px;padding:2px 10px;font-family:'Barlow Condensed',sans-serif;font-size:0.9rem;font-weight:700;color:var(--gold)}

  .vs-divider{display:flex;align-items:center;gap:1rem;padding:0.5rem 0;position:relative;z-index:1}
  .vs-line{flex:1;height:1px;background:rgba(198,241,53,0.22)}
  .vs-text{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:rgba(198,241,53,0.45);letter-spacing:2px}

  .result-banner{position:absolute;inset:0;z-index:4;background:rgba(0,0,0,0.8);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.5rem;border-radius:16px;opacity:0;pointer-events:none;transition:opacity 0.3s}
  .result-banner.show{opacity:1;pointer-events:all}
  .result-text{font-family:'Bebas Neue',sans-serif;font-size:4rem;letter-spacing:4px}
  .result-text.win{color:var(--gold);text-shadow:0 0 36px rgba(198,241,53,0.55)}
  .result-text.lose{color:var(--red)}
  .result-text.push{color:var(--muted)}
  .result-sub{color:var(--muted);font-size:0.9rem;font-weight:600}

  .game-main{display:flex;gap:1.1rem;align-items:stretch;width:100%;flex:1;min-height:0}
  .controls{flex:0 0 280px;display:flex;flex-direction:column;align-items:stretch;gap:0.85rem}
  .table-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem}
  .bj-panel{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1rem;box-shadow:0 10px 26px rgba(0,0,0,0.22)}
  .bj-panel-title{font-size:0.68rem;font-weight:700;color:var(--muted);letter-spacing:1.6px;text-transform:uppercase;margin-bottom:0.7rem}
  .bet-input{width:100%;display:flex;flex-direction:column;gap:0.45rem;align-items:stretch;margin-bottom:0}
  .bet-input label{font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase}
  .bet-input input[type=number]{width:100%;padding:0.65rem 0.85rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;align-items:stretch}
  .wager-row #betInput{flex:1;width:auto;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
  }
  .action-row{display:flex;gap:0.6rem;flex-wrap:wrap;justify-content:center}
  .btn-action{padding:0.72rem 1.05rem;border-radius:999px;font-family:'Barlow Condensed',sans-serif;font-size:0.95rem;font-weight:900;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:none;transition:transform 0.15s,opacity 0.2s}
  .btn-action:disabled{opacity:0.3;cursor:not-allowed}
  .btn-deal{background:var(--gold);color:#0a0a0f}
  .btn-deal:not(:disabled):hover{transform:scale(1.05)}
  .btn-hit{background:#2d7a4a;color:#fff}
  .btn-hit:not(:disabled):hover{transform:scale(1.05)}
  .btn-stand{background:#7a2d2d;color:#fff}
  .btn-stand:not(:disabled):hover{transform:scale(1.05)}
  .btn-double{background:#1a3d7a;color:#fff}
  .btn-double:not(:disabled):hover{transform:scale(1.05)}
  .btn-split{background:#5a2d7a;color:#fff}
  .btn-split:not(:disabled):hover{transform:scale(1.05)}
  .btn-insure{background:#7a5c1a;color:#fff}
  .btn-insure:not(:disabled):hover{transform:scale(1.05)}
  .btn-surrender{background:#555;color:#fff}
  .btn-surrender:not(:disabled):hover{transform:scale(1.05)}

  .rules-strip{font-size:0.72rem;color:var(--muted);text-align:center;max-width:700px;line-height:1.45;margin:0.5rem 0 1.25rem}
  .rules-strip strong{color:var(--gold);font-weight:800}
  /* Play shell uses !important on .area-label — keep table chrome on-brand */
  body.with-play-shell .area-label{color:rgba(198,241,53,0.82)!important}
  body.with-play-shell .vs-line{background:rgba(198,241,53,0.24)!important}
  body.with-play-shell .vs-text{color:rgba(198,241,53,0.48)!important}
  .balance-pill .lotta-bal-main{display:block;font-size:0.88rem;line-height:1.2}
  .balance-pill .lotta-bal-fiat{display:block;font-size:0.72rem;color:var(--muted);font-weight:600;margin-top:0.12rem}
  @media(max-width:980px){
    .game-main{flex-direction:column}
    .controls{flex:0 0 auto;max-width:560px;width:100%;margin:0 auto}
  }
  @media(max-width:760px){
    .game-main{flex-direction:column}
    .game-wrap{padding:0.8rem 0.8rem 1.5rem;gap:0.75rem}
    .controls{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .table-col{flex:0 0 auto;width:100%}
    .felt{padding:1.25rem;min-height:340px}
    .card{width:58px;height:84px;font-size:1.35rem}
    .card-suit{font-size:1.5rem}
    .card-corner{font-size:0.7rem}
    .result-text{font-size:3rem}
    .action-row{gap:0.5rem}
    .btn-action{padding:0.65rem 1.25rem;font-size:0.9rem}
  }
  @media(max-width:480px){
    .game-wrap{padding:0.65rem 0.55rem 1.25rem;gap:0.6rem}
    .game-title{font-size:1.4rem}
    .rules-strip{font-size:0.68rem;margin:0.25rem 0 0.75rem}
    .felt{padding:1rem;min-height:300px;border-radius:14px}
    .card{width:48px;height:70px;font-size:1.1rem}
    .card-suit{font-size:1.25rem}
    .card-corner{font-size:0.62rem;top:3px;left:4px}
    .cards{gap:0.4rem;min-height:80px}
    .result-text{font-size:2.5rem;letter-spacing:2px}
    .result-sub{font-size:0.8rem}
    .action-row{gap:0.4rem}
    .btn-action{padding:0.55rem 0.85rem;font-size:0.82rem}
  }

/* === play/casebattle-create.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0a0b12;--panel:#121428;--line:rgba(255,255,255,0.09);--gold:#f5d96a;--gold2:#c6f135;--muted:#959ab7;--text:#f0f0f0}
  body{background:radial-gradient(800px 480px at 50% -100px,#1a1e3a 0%,transparent 55%),var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  /* Allow full page scroll with play-shell (sidebar) */
  body.with-play-shell{overflow-y:auto;height:auto;min-height:100vh}
  body.with-play-shell .page{flex:1 1 auto;height:auto!important;min-height:0!important;max-height:none!important;overflow:visible!important;padding-bottom:2.5rem}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.65rem 1rem;border-bottom:1px solid var(--line);background:rgba(18,20,40,0.95)}
  .exit{padding:0.4rem 0.85rem;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,0.04);color:var(--text);font-weight:800;font-size:0.78rem;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center}
  .cb-top{display:flex;align-items:center;justify-content:center;gap:0.5rem;padding:0.75rem 1rem;font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;border-bottom:1px solid var(--line);background:rgba(18,20,40,0.6)}
  .cb-top .mark{color:var(--gold2)}
  .page{flex:1;width:100%;padding:1rem 1.5rem 2rem}
  /* Two-column layout on wide screens: rules left, cases right */
  .page-cols{display:grid;grid-template-columns:360px 1fr;gap:1rem;align-items:start}
  @media(max-width:860px){.page-cols{grid-template-columns:1fr}}
  .page-cols .panel{margin-bottom:0}

  .rule-row{display:flex;flex-wrap:wrap;gap:0.5rem;align-items:center;margin-bottom:0.75rem}
  .rule-row label{font-size:0.72rem;color:var(--muted);font-weight:700}
  input[type=range]{font-family:'DM Sans',sans-serif}
  .toggle{display:inline-flex;align-items:center;gap:0.4rem;padding:0.45rem 0.65rem;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,0.03);cursor:pointer;font-size:0.78rem;font-weight:800}
  .toggle input{accent-color:var(--gold2)}
  .modes{display:flex;flex-wrap:wrap;gap:0.45rem;margin:0.75rem 0}
  .mode{padding:0.5rem 0.85rem;border-radius:12px;border:1px solid var(--line);background:transparent;color:var(--muted);font-weight:900;font-size:0.78rem;cursor:pointer;display:inline-flex;align-items:center;gap:0.35rem}
  .mode.on{border-color:rgba(245,217,106,0.55);color:var(--gold);background:rgba(245,217,106,0.1)}
  hr{border:none;border-top:1px dashed var(--line);margin:0.85rem 0}

  .panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:1rem;margin-bottom:1rem;box-shadow:0 10px 28px rgba(0,0,0,0.35)}
  .panel h3{font-size:0.68rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:0.65rem}
  .case-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0.65rem}
  .case-slot{min-height:160px;border-radius:14px;border:1px dashed var(--line);display:flex;align-items:center;justify-content:center;padding:0.5rem;background:rgba(0,0,0,0.15)}
  .case-slot.filled{border-style:solid;flex-direction:column;justify-content:flex-end;padding:0}
  .add-cases{width:100%;height:100%;min-height:140px;border:none;border-radius:12px;background:rgba(245,217,106,0.12);color:var(--gold);font-weight:900;cursor:pointer;font-size:0.85rem}
  .mini{font-size:0.72rem;color:var(--muted);margin-top:0.35rem;text-align:center}
  .case-slot.filled{position:relative}
  .slot-qty-badge{position:absolute;bottom:0.4rem;right:0.4rem;background:var(--gold2);color:#0a0b12;font-size:0.65rem;font-weight:900;border-radius:999px;padding:0.15rem 0.42rem;line-height:1.3;pointer-events:none;z-index:2;box-shadow:0 1px 4px rgba(0,0,0,0.5)}
  .btn-create{width:100%;padding:0.85rem;border:none;border-radius:999px;background:linear-gradient(180deg,#f1cf65,#c6a443);color:#1d1a12;font-weight:900;font-size:0.9rem;cursor:pointer}
  .btn-create:disabled{opacity:0.45;cursor:not-allowed}
  .err{color:#f26c6c;font-size:0.82rem;margin-top:0.5rem}

  .add-cases-overlay{position:fixed;inset:0;z-index:10050;background:rgba(6,8,18,0.94);backdrop-filter:blur(10px);display:none;align-items:stretch;justify-content:center;padding:0.75rem;box-sizing:border-box}
  .add-cases-overlay.open{display:flex}
  .add-cases-panel{flex:1;max-width:min(1040px,100%);display:flex;flex-direction:column;background:linear-gradient(180deg,#1e1a32 0%,#14122a 100%);border:1px solid rgba(255,255,255,0.1);border-radius:18px;box-shadow:0 24px 60px rgba(0,0,0,0.55);overflow:hidden}
  .add-cases-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:0.75rem;padding:1rem 1.1rem;border-bottom:1px solid var(--line);background:rgba(0,0,0,0.2)}
  .add-cases-title-wrap{display:flex;align-items:center;gap:0.5rem;font-family:'Syne',sans-serif;font-weight:800;font-size:1.15rem;letter-spacing:0.5px;text-transform:uppercase}
  .add-cases-title-wrap .mark{font-size:1.35rem;line-height:1}
  .add-cases-title-wrap h2{margin:0;font-size:inherit;background:linear-gradient(90deg,transparent 0%,transparent 28%,rgba(245,217,106,0.35) 28%,rgba(245,217,106,0.35) 42%,transparent 42%);padding-bottom:2px}
  .add-cases-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:0.5rem}
  .add-cases-toolbar select{min-width:140px}

  /* ── Unified select styling ───────────────────────────── */
  select{
    appearance:none;-webkit-appearance:none;
    font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:700;
    color:var(--text);
    background:rgba(255,255,255,0.04)
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23959ab7' d='M6 8L1 3h10z'/%3E%3C/svg%3E")
      no-repeat right 0.7rem center;
    border:1px solid rgba(255,255,255,0.12);
    border-radius:12px;
    padding:0.52rem 2.1rem 0.52rem 0.85rem;
    cursor:pointer;
    transition:border-color 0.15s,box-shadow 0.15s,background-color 0.15s;
    outline:none;
  }
  select:hover{
    border-color:rgba(255,255,255,0.22);
    background-color:rgba(255,255,255,0.07);
  }
  select:focus{
    border-color:rgba(198,241,53,0.5);
    box-shadow:0 0 0 3px rgba(198,241,53,0.1);
    background-color:rgba(198,241,53,0.04);
  }
  select option{
    background:#1a1830;
    color:var(--text);
  }
  /* Teams select in rule-row — slightly wider feel */
  .rule-row select{min-width:160px}
  .add-cases-search{flex:1;min-width:160px;max-width:280px;padding:0.52rem 0.85rem 0.52rem 2.35rem;border-radius:12px;border:1px solid rgba(255,255,255,0.1);background:rgba(0,0,0,0.35) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%238b8fa8' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 10-1.397 1.398h-.001l3.85 3.85a1 1 0 001.415-1.414l-3.85-3.85zm-5.242.656a5 5 0 110-10 5 5 0 010 10z'/%3E%3C/svg%3E") no-repeat 0.65rem 50%;color:var(--text);font-family:'DM Sans',sans-serif;font-size:0.88rem}
  .add-cases-search::placeholder{color:#6b7088}
  .add-cases-search:focus{outline:none;border-color:rgba(198,241,53,0.45);box-shadow:0 0 0 3px rgba(198,241,53,0.1)}
  .add-cases-grid{flex:1;overflow:auto;padding:1rem;display:grid;grid-template-columns:repeat(4,1fr);gap:0.75rem}
  @media (max-width:900px){.add-cases-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:480px){.add-cases-grid{grid-template-columns:1fr}}
  .picker-card{border-radius:14px;border:1px solid rgba(255,255,255,0.08);background:rgba(40,36,68,0.55);padding:0.5rem;display:flex;flex-direction:column;align-items:center;transition:border-color 0.15s,box-shadow 0.15s}
  .picker-card.picked{border-color:rgba(198,241,53,0.45);box-shadow:0 0 0 1px rgba(198,241,53,0.2)}
  .picker-card-art{width:100%;aspect-ratio:1;max-height:120px;border-radius:12px;background-size:cover;background-position:center}
  .picker-card-name{font-size:0.72rem;font-weight:800;text-transform:uppercase;text-align:center;margin:0.45rem 0 0.35rem;line-height:1.25;min-height:2.2em;display:flex;align-items:center;justify-content:center}
  .picker-card-add{width:100%;border:none;border-radius:999px;padding:0.45rem 0.5rem;font-size:0.78rem;font-weight:800;cursor:pointer;background:linear-gradient(180deg,#4a4428,#2e2a18);color:#f0e6c8;border:1px solid rgba(245,217,106,0.25);display:inline-flex;align-items:center;justify-content:center;gap:0.25rem}
  .picker-card-add:hover{filter:brightness(1.08)}
  .picker-card-add:disabled{opacity:0.45;cursor:not-allowed;filter:none}
  .picker-card-count{font-size:0.68rem;font-weight:800;color:var(--gold2);margin-top:0.25rem}
  .add-cases-foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:0.75rem;padding:0.85rem 1.1rem;border-top:1px solid var(--line);background:rgba(0,0,0,0.35)}
  .add-cases-summary{font-size:0.88rem;font-weight:700;display:flex;align-items:center;gap:0.35rem}
  .add-cases-actions{display:flex;gap:0.5rem}
  .btn-picker-cancel{padding:0.65rem 1.4rem;border-radius:12px;border:none;font-weight:800;font-size:0.82rem;cursor:pointer;background:#6b3d38;color:#fde8e6}
  .btn-picker-cancel:hover{filter:brightness(1.06)}
  .btn-picker-confirm{padding:0.65rem 1.5rem;border-radius:12px;border:none;font-weight:800;font-size:0.82rem;cursor:pointer;background:#3a3848;color:#c9c9d4}
  .btn-picker-confirm:not(:disabled){background:linear-gradient(180deg,#5c5a6e,#3d3b4d);color:#f0f0f0;border:1px solid rgba(255,255,255,0.12)}
  .btn-picker-confirm:not(:disabled):hover{filter:brightness(1.08)}
  .btn-picker-confirm:disabled{opacity:0.45;cursor:not-allowed}

/* === play/casebattle-room.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --br-bg:#0a0b12;--br-panel:#1e1b2e;--br-line:rgba(255,255,255,0.09);--br-gold:#f5d96a;--br-gold2:#c6f135;
    --br-muted:#959ab7;--br-text:#f0f0f0;
  }
  body{background:radial-gradient(900px 500px at 50% -120px,#1a1e3a 0%,transparent 55%),var(--br-bg);color:var(--br-text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  body.with-play-shell{overflow-y:auto;height:auto;min-height:100vh}
  .br-top{display:flex;align-items:center;justify-content:space-between;gap:0.75rem;flex-wrap:wrap;padding:0.65rem 1rem;border-bottom:1px solid var(--br-line);background:rgba(18,20,40,0.95);backdrop-filter:blur(8px);overflow:visible}
  .br-back{padding:0.45rem 0.9rem;border-radius:12px;border:1px solid var(--br-line);background:rgba(255,255,255,0.04);color:var(--br-text);font-weight:800;font-size:0.75rem;cursor:pointer;text-decoration:none;text-transform:uppercase;letter-spacing:0.04em}
  .br-back:hover{border-color:rgba(245,217,106,0.35);color:var(--br-gold)}
  .br-mode{display:flex;align-items:center;gap:0.35rem;font-family:'Syne',sans-serif;font-weight:800;font-size:0.68rem;letter-spacing:0.02em;color:var(--br-gold2);line-height:1.2;max-width:min(42vw,300px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .br-center{display:flex;align-items:center;gap:0.65rem;flex:1;justify-content:center;min-width:200px;flex-wrap:wrap}
  .br-case-mini{width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,0.12);flex-shrink:0;background-size:cover;background-position:center}
  .br-case-mini--current{box-shadow:0 0 0 2px rgba(198,241,53,0.55);border-color:rgba(198,241,53,0.45)}
  .br-case-mini--empty{opacity:0.25;background:rgba(255,255,255,0.06)!important;border-style:dashed}
  .br-coin{display:inline-flex;align-items:center;justify-content:center;font-size:1.05em;line-height:1;flex-shrink:0;padding:2px 0;transform:translateY(0.5px)}
  .br-pill{display:flex;align-items:center;gap:0.35rem;font-size:0.72rem;font-weight:800;color:var(--br-muted);text-transform:uppercase;letter-spacing:0.06em;line-height:1.25;overflow:visible}
  .br-pill strong{display:inline-flex;align-items:center;gap:0.28rem;color:var(--br-gold2);font-size:0.85rem;font-weight:800;line-height:1.25}
  .br-tools{display:flex;align-items:center;gap:0.45rem}
  .br-tool-btn{padding:0.4rem 0.65rem;border-radius:10px;border:1px solid var(--br-line);background:rgba(255,255,255,0.04);color:var(--br-text);font-size:0.72rem;font-weight:800;cursor:pointer}
  .br-tool-btn:hover{border-color:rgba(245,217,106,0.35)}

  .br-main{flex:1;padding:0.75rem 1rem 1.25rem;width:100%;max-width:1280px;margin:0 auto;min-height:0}
  .br-battle-head{max-width:920px;margin:0 auto 0.55rem;text-align:center}
  .br-battle-pot{font-family:'Syne',sans-serif;font-weight:800;font-size:2rem;color:var(--br-gold);letter-spacing:0.01em}
  .br-battle-sub{margin-top:0.2rem;font-size:0.8rem;color:var(--br-muted);font-weight:800;text-transform:uppercase;letter-spacing:0.06em}
  .br-battle-case-line{margin-top:0.4rem;font-size:1rem;font-weight:800;color:var(--br-gold2);min-height:1.35em}
  .br-battle-chips-wrap{margin:0.55rem auto 0;max-width:360px;overflow:hidden;border-radius:12px;border:1px solid var(--br-line);background:rgba(0,0,0,0.24);padding:0.35rem}
  .br-battle-chips-track{display:flex;align-items:center;gap:0.35rem;will-change:transform;transition:transform 420ms cubic-bezier(0.2,0.75,0.2,1)}
  .br-battle-chips-track .br-case-mini{width:34px;height:34px}
  .br-cols-shell{display:flex;flex-direction:column;min-height:min(65vh,680px);border:1px solid var(--br-line);border-radius:16px;overflow:hidden;background:rgba(20,18,38,0.65)}
  .br-cols{display:grid;gap:0;flex:0 0 auto;min-height:0}
  .br-cols-upper{min-height:min(38vh,420px)}
  .br-col{display:flex;flex-direction:column;border-left:1px solid var(--br-line);min-width:0;min-height:0}
  .br-col:first-child{border-left:none}
  .br-anim{flex:1;min-height:220px;background:linear-gradient(180deg,rgba(30,27,46,0.9),rgba(12,10,22,0.95));display:flex;align-items:stretch;justify-content:center;position:relative;padding:0.5rem}
  .br-anim-inner{width:100%;max-width:220px;min-height:200px;border-radius:14px;border:1px dashed rgba(255,255,255,0.12);background:rgba(0,0,0,0.35);display:flex;flex-direction:column;align-items:stretch;overflow:hidden}
  .br-anim-inner--reel{border:1px solid rgba(198,241,53,0.18);background:linear-gradient(180deg,#1a1830 0%,#0f0e1a 100%);padding:0.35rem 0.3rem 0.45rem}
  .br-reel-meta{font-size:0.58rem;font-weight:800;color:var(--br-muted);text-transform:uppercase;letter-spacing:0.06em;text-align:center;margin-bottom:0.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .br-reel-viewport{position:relative;flex:1;min-height:156px;max-height:168px;overflow:hidden;border-radius:10px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.45)}
  .br-reel-viewport::before,.br-reel-viewport::after{content:'';position:absolute;left:0;right:0;height:28px;z-index:2;pointer-events:none}
  .br-reel-viewport::before{top:0;background:linear-gradient(180deg,rgba(12,10,22,0.97),transparent)}
  .br-reel-viewport::after{bottom:0;background:linear-gradient(0deg,rgba(12,10,22,0.97),transparent)}
  .br-reel-pointer{position:absolute;left:6px;right:6px;top:50%;height:2px;margin-top:-1px;transform:translateZ(0);background:linear-gradient(90deg,transparent,rgba(198,241,53,0.95),transparent);z-index:3;opacity:0.95;box-shadow:0 0 12px rgba(198,241,53,0.35)}
  .br-reel-track{will-change:transform;transform:translate3d(0,0,0);backface-visibility:hidden}
  .br-reel-item{
    display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
    padding:0.28rem 0.35rem;border-bottom:none;position:relative;
    color:#e8e9f4;font-size:0.62rem;font-weight:700;line-height:1.15;
  }
  .br-reel-item::after{
    content:'';position:absolute;left:10%;right:10%;bottom:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);
    opacity:0.7;
  }
  .br-reel-item:last-child::after{display:none}
  .br-reel-item[data-win="1"]{background:rgba(198,241,53,0.08);border-bottom-color:rgba(198,241,53,0.2)}
  .br-reel-ico{font-size:1.1rem;line-height:1;min-height:1.2rem;display:flex;align-items:center;justify-content:center}
  .br-reel-ico-img{width:20px;height:20px;object-fit:contain;display:block}
  .br-reel-nm{margin-top:0.12rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:0.58rem}
  .br-reel-v{font-size:0.55rem;color:var(--br-gold2);font-weight:800;margin-top:0.08rem}
  .br-reel-eos-foot{font-size:0.52rem;font-weight:600;color:var(--br-muted);font-family:ui-monospace,monospace;text-align:center;margin-top:0.35rem;overflow:hidden;text-overflow:ellipsis}
  .br-reel-stage{width:100%;padding:0.45rem 0.35rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.35rem;text-align:center;min-height:160px}
  .br-reel-val{font-size:0.72rem;font-weight:800;color:var(--br-gold)}
  .br-reel-payout{margin-top:0.2rem;font-size:0.76rem;font-weight:900;color:var(--br-gold2);letter-spacing:0.02em;line-height:1.2}
  .br-reel-stage.is-locked{border:1px solid rgba(255,255,255,0.1);border-radius:12px;background:rgba(0,0,0,0.25)}
  .br-reel-idle{opacity:0.45;font-size:1.25rem}
  .br-anim .spin{font-size:2rem;opacity:0.35}
  .br-bar{padding:0.55rem 0.65rem;border-top:1px solid var(--br-line);background:rgba(0,0,0,0.25)}
  .br-bar-final{display:flex;flex-direction:column;gap:0.35rem}
  .br-net-pill{
    align-self:flex-start;padding:0.18rem 0.48rem;border-radius:999px;border:1px solid var(--br-line);
    font-size:0.64rem;font-weight:900;letter-spacing:0.03em;background:rgba(255,255,255,0.04)
  }
  .br-net-pill.pos{color:var(--br-gold2);border-color:rgba(198,241,53,0.45);background:rgba(198,241,53,0.08)}
  .br-net-pill.neg{color:#f6a8a6;border-color:rgba(226,75,74,0.45);background:rgba(226,75,74,0.1)}
  .br-net-pill.neu{color:var(--br-muted)}
  .br-player{display:flex;align-items:center;gap:0.45rem}
  .br-av{width:40px;height:40px;border-radius:12px;background:linear-gradient(145deg,#4a3f7a,#2a2548);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:1rem;color:var(--br-gold2)}
  .br-meta{flex:1;min-width:0}
  .br-name{font-weight:800;font-size:0.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:0.25rem}
  .br-player-stats{margin-top:0.1rem;font-size:0.66rem;color:var(--br-muted);font-weight:800;letter-spacing:0.01em}
  .br-bot{font-size:0.85rem;opacity:0.85}
  .br-join-wrap{display:flex;align-items:stretch;gap:0.35rem}
  .br-join{flex:1;display:flex;align-items:center;justify-content:center;gap:0.35rem;padding:0.55rem 0.5rem;border-radius:12px;border:1px solid rgba(245,217,106,0.35);background:rgba(245,217,106,0.1);color:var(--br-gold);font-weight:900;font-size:0.72rem;cursor:pointer;font-family:'DM Sans',sans-serif}
  .br-join:hover{filter:brightness(1.08)}
  .br-join:disabled{opacity:0.45;cursor:not-allowed}
  .br-bot-call{width:40px;min-width:40px;border-radius:10px;border:1px solid var(--br-line);background:rgba(255,255,255,0.06);cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}
  .br-bot-call:hover{border-color:rgba(245,217,106,0.4)}
  .br-bot-call:disabled{opacity:0.35;cursor:not-allowed}
  .br-pulls-scroll{flex:1 1 auto;min-height:120px;max-height:min(52vh,520px);overflow-y:auto;overflow-x:hidden;border-top:1px solid var(--br-line);background:rgba(0,0,0,0.18);scrollbar-width:thin;scrollbar-color:rgba(198,241,53,0.35) rgba(0,0,0,0.2)}
  .br-pulls-scroll::-webkit-scrollbar{width:6px}
  .br-pulls-scroll::-webkit-scrollbar-thumb{background:rgba(198,241,53,0.28);border-radius:6px}
  .br-pulls-row{display:grid;gap:0;align-items:start}
  .br-pulls-row .br-grid{border-left:1px solid var(--br-line)}
  .br-pulls-row .br-grid:first-child{border-left:none}
  .br-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.42rem;padding:0.58rem}
  .br-cell{
    aspect-ratio:1;border-radius:12px;border:1px solid rgba(255,255,255,0.12);
    background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.02));
    display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem;color:var(--br-muted);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.04), 0 6px 18px rgba(0,0,0,0.18);
  }
  .br-cell.reveal{
    font-size:0.62rem;font-weight:700;color:var(--br-text);text-align:center;padding:0.34rem 0.3rem;
    line-height:1.2;flex-direction:column;gap:0.24rem;justify-content:center;
  }
  .br-cell-name{
    font-size:0.74rem;font-weight:800;line-height:1.16;max-width:100%;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  }
  .br-cell-val{
    font-size:0.8rem;font-weight:900;color:var(--br-gold2);letter-spacing:0.01em;
  }
  @keyframes br-pulse{from{opacity:0.88}to{opacity:1}}
  .br-cell.won{border-color:rgba(198,241,53,0.55);box-shadow:0 0 0 1px rgba(198,241,53,0.15)}
  .br-status{font-size:0.78rem;color:var(--br-muted);text-align:center;padding:0.5rem}
  .br-toast{text-align:center;font-size:0.82rem;color:var(--br-muted);margin:0.35rem 0;min-height:1.25em}
  .br-fail{background:rgba(226,75,74,0.12);border:1px solid rgba(226,75,74,0.35);color:#f5a8a7;padding:0.65rem;border-radius:12px;margin:0.5rem 0;font-size:0.85rem}

  .br-modal{position:fixed;inset:0;background:rgba(0,0,0,0.72);display:none;align-items:center;justify-content:center;padding:1rem;z-index:10020}
  .br-modal.show{display:flex}
  .br-modal-inner{max-width:520px;width:100%;background:#121428;border:1px solid var(--br-line);border-radius:16px;padding:1.1rem;max-height:85vh;overflow:auto}
  .br-modal-inner h3{font-family:'Syne',sans-serif;margin-bottom:0.5rem}
  .br-modal-inner pre{font-size:0.68rem;color:var(--br-muted);white-space:pre-wrap;word-break:break-word}

  .br-jackpot-stage{width:100%;max-width:1280px;margin:0 auto;padding:0.35rem 1rem 1rem;display:none}
  .br-jackpot-stage.is-on{display:block}
  .br-jp-head{text-align:center;font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;color:var(--br-gold2);margin-bottom:0.45rem;letter-spacing:0.02em}
  .br-jp-viewport{position:relative;height:132px;overflow:hidden;border-radius:16px;border:1px solid rgba(198,241,53,0.22);background:rgba(0,0,0,0.55)}
  .br-jp-viewport::before,.br-jp-viewport::after{content:'';position:absolute;top:0;bottom:0;width:48px;z-index:2;pointer-events:none}
  .br-jp-viewport::before{left:0;background:linear-gradient(90deg,rgba(12,10,22,0.98),transparent)}
  .br-jp-viewport::after{right:0;background:linear-gradient(270deg,rgba(12,10,22,0.98),transparent)}
  .br-jp-pointer{position:absolute;left:50%;top:6px;bottom:6px;width:3px;margin-left:-1.5px;transform:translateZ(0);background:linear-gradient(180deg,transparent,rgba(198,241,53,0.95),transparent);z-index:3;box-shadow:0 0 14px rgba(198,241,53,0.4)}
  .br-jp-track{display:flex;flex-direction:row;height:100%;align-items:stretch;will-change:transform;transform:translate3d(0,0,0);backface-visibility:hidden}
  .br-jp-item{flex:0 0 92px;width:92px;min-width:92px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid rgba(255,255,255,0.07);padding:0.3rem;background:rgba(255,255,255,0.03)}
  .br-jp-item[data-win="1"]{background:rgba(198,241,53,0.11);border-right-color:rgba(198,241,53,0.2)}
  .br-jp-av{width:58px;height:58px;border-radius:16px;background:linear-gradient(145deg,#4a3f7a,#2a2548);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:1.4rem;color:var(--br-gold2);flex-shrink:0}
  .br-jp-nm{font-size:0.58rem;font-weight:700;margin-top:0.22rem;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--br-text)}
  .br-jp-bot{font-size:0.55rem;color:var(--br-muted);margin-top:0.08rem}
  .br-jp-eos{margin-top:0.45rem;font-size:0.62rem;color:var(--br-muted);text-align:center;font-family:ui-monospace,monospace}

  @media(max-width:900px){
    .br-cols-shell{overflow-x:auto;-webkit-overflow-scrolling:touch;overflow-y:hidden}
    .br-cols-upper,.br-pulls-row{width:max(100%, calc(var(--br-min-slot, 160px) * var(--br-slots, 6)))}
  }

  /* ── Rematch banner ─────────────────────────────────────── */
  .br-rematch{
    max-width:920px;margin:1.1rem auto 0.5rem;
    border:1px solid rgba(198,241,53,0.28);border-radius:18px;
    background:linear-gradient(135deg,rgba(198,241,53,0.07) 0%,rgba(30,27,46,0.85) 100%);
    padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
    animation:br-rematch-in 0.45s cubic-bezier(0.2,0.8,0.3,1) both;
  }
  @keyframes br-rematch-in{
    from{opacity:0;transform:translateY(14px)}
    to{opacity:1;transform:translateY(0)}
  }
  .br-rematch-icon{font-size:2rem;line-height:1;flex-shrink:0}
  .br-rematch-body{flex:1;min-width:180px}
  .br-rematch-title{font-family:'Syne',sans-serif;font-weight:800;font-size:0.95rem;color:var(--br-gold2);letter-spacing:0.02em}
  .br-rematch-sub{margin-top:0.2rem;font-size:0.72rem;color:var(--br-muted);font-weight:700;line-height:1.4}
  .br-rematch-actions{display:flex;gap:0.55rem;flex-wrap:wrap;align-items:center}
  .br-rematch-btn{
    display:inline-flex;align-items:center;gap:0.35rem;
    padding:0.55rem 1.1rem;border-radius:12px;font-weight:900;font-size:0.8rem;font-family:'DM Sans',sans-serif;
    cursor:pointer;text-decoration:none;letter-spacing:0.02em;border:none;
    background:linear-gradient(135deg,#c6f135,#a8d422);color:#0a0b12;
    box-shadow:0 4px 14px rgba(198,241,53,0.25);transition:filter 0.15s,transform 0.12s;
  }
  .br-rematch-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
  .br-rematch-btn:active{transform:translateY(0);filter:brightness(0.97)}
  .br-rematch-dismiss{
    padding:0.5rem 0.75rem;border-radius:10px;border:1px solid var(--br-line);
    background:transparent;color:var(--br-muted);font-size:0.75rem;font-weight:700;
    cursor:pointer;font-family:'DM Sans',sans-serif;transition:border-color 0.15s,color 0.15s;
  }
  .br-rematch-dismiss:hover{border-color:rgba(255,255,255,0.25);color:var(--br-text)}

/* === play/casebattle.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --cb-bg:#0a0b12;--cb-panel:#121428;--cb-line:rgba(255,255,255,0.09);--cb-gold:#f5d96a;--cb-gold2:#c6f135;
    --cb-muted:#959ab7;--cb-text:#f0f0f0;
  }
  body{background:radial-gradient(900px 500px at 50% -120px,#1a1e3a 0%,transparent 55%),var(--cb-bg);color:var(--cb-text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  body.with-play-shell{overflow-y:auto;height:auto;min-height:100vh}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.4rem 1rem;font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;color:var(--gold)}

  .cb-page{flex:1;width:100%;padding:1rem 1.5rem 1.25rem}
  .cb-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}
  .cb-title{display:flex;align-items:center;gap:0.5rem;font-family:'Syne',sans-serif;font-weight:800;font-size:1.45rem;letter-spacing:-0.3px}
  .cb-title .ico{font-size:1.35rem}
  .cb-filters{display:inline-flex;align-items:center;gap:0.4rem}
  .cb-filter{border:1px solid var(--cb-line);background:rgba(255,255,255,0.03);color:var(--cb-muted);padding:0.38rem 0.85rem;border-radius:999px;font-size:0.72rem;font-weight:800;cursor:pointer;letter-spacing:0.06em}
  .cb-filter.on{border-color:rgba(245,217,106,0.55);color:var(--cb-gold);background:rgba(245,217,106,0.08)}
  .cb-create{display:inline-flex;align-items:center;gap:0.45rem;padding:0.45rem 1rem;border-radius:999px;border:1px solid rgba(245,217,106,0.55);background:rgba(245,217,106,0.1);color:var(--cb-gold);font-weight:900;font-size:0.78rem;text-decoration:none;letter-spacing:0.04em}
  .cb-create:hover{background:rgba(245,217,106,0.16)}

  .cb-list{display:flex;flex-direction:column;gap:0.65rem}
  .cb-row{
    display:grid;grid-template-columns:minmax(120px,150px) 1fr minmax(140px,1.2fr) auto;
    align-items:center;gap:0.75rem;padding:0.75rem 0.9rem;border-radius:14px;
    background:linear-gradient(180deg,#1a1c33 0%,#121428 100%);border:1px solid var(--cb-line);
    box-shadow:0 8px 28px rgba(0,0,0,0.35);
  }
  @media(max-width:860px){
    .cb-row{grid-template-columns:1fr;justify-items:stretch}
  }
  .cb-price{display:flex;flex-direction:column;gap:0.15rem}
  .cb-price .amt{font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;color:var(--cb-gold);display:flex;align-items:center;gap:0.35rem}
  .cb-mode{font-size:0.62rem;font-weight:800;color:var(--cb-muted);letter-spacing:0.06em;line-height:1.35;max-width:220px}
  .cb-teams{display:flex;align-items:center;justify-content:center;gap:0.35rem;flex-wrap:wrap}
  .cb-slot{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,0.12);background:rgba(0,0,0,0.25);display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:900;color:var(--cb-muted)}
  .cb-slot.filled{background:rgba(245,217,106,0.12);border-color:rgba(245,217,106,0.25);color:var(--cb-text)}
  .cb-vs{font-size:0.62rem;font-weight:900;color:var(--cb-gold);opacity:0.85;padding:0 0.15rem}
  .cb-cases{display:flex;align-items:center;gap:0.35rem;flex-wrap:wrap;justify-content:flex-end}
  .cb-case{width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,0.12);flex-shrink:0}
  .cb-more{font-size:0.65rem;font-weight:800;color:var(--cb-muted);padding:0.2rem 0.45rem;border-radius:999px;border:1px solid var(--cb-line)}
  .cb-eye{width:40px;height:40px;border-radius:10px;border:1px solid var(--cb-line);background:rgba(255,255,255,0.04);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem}
  .cb-eye:hover{border-color:rgba(245,217,106,0.4)}
  .cb-actions{display:flex;align-items:center;gap:0.45rem;justify-content:flex-end;flex-wrap:wrap}
  .cb-mini{padding:0.35rem 0.65rem;border-radius:10px;border:1px solid var(--cb-line);background:rgba(255,255,255,0.04);color:var(--cb-text);font-size:0.72rem;font-weight:800;cursor:pointer}
  .cb-mini:hover{border-color:rgba(245,217,106,0.35)}
  .cb-empty{text-align:center;color:var(--cb-muted);padding:2rem 1rem;font-size:0.9rem}
  .cb-toast{font-size:0.78rem;color:var(--cb-muted);margin-bottom:0.75rem}

/* === play/cases.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --bg:#090b12;--bg2:#121428;--bg3:#1a1d33;--bg4:#212446;
    --gold:#c6f135;--gold2:#f5d96a;--text:#f0f0f0;--muted:#959ab7;
    --line:rgba(255,255,255,0.09);--green:#3ecf8e;--danger:#f26c6c;
  }
  body{min-height:100vh;background:radial-gradient(1200px 600px at 50% -200px,#1a1e3a 0%,transparent 65%),var(--bg);color:var(--text);font-family:'DM Sans',sans-serif}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.4rem 1rem;font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;color:var(--gold)} 
  .page{width:100%;padding:1rem 1.5rem 1.25rem}
  .head{text-align:center;margin-bottom:1rem}
  .head h1{font-family:'Syne',sans-serif;font-size:2rem;letter-spacing:-0.2px}
  .head p{color:var(--muted);font-size:.8rem;margin-top:.3rem}

  .view{display:none}
  .view.active{display:block}

  .cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.95rem}
  .case-card{
    background:linear-gradient(180deg,#26284a 0%,#1a1c33 55%,#14172a 100%);
    border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;
    transition:transform .14s,border-color .14s,box-shadow .14s;
  }
  .case-card:hover{transform:translateY(-3px);border-color:rgba(198,241,53,.45);box-shadow:0 12px 34px rgba(0,0,0,.35)}
  .card-art{
    height:170px;display:flex;align-items:center;justify-content:center;position:relative;
    background:radial-gradient(420px 170px at 50% 0%,rgba(255,255,255,.08) 0%,transparent 65%);
  }
  .card-art img{width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(0,0,0,.45))}
  .new-pill{position:absolute;top:.55rem;right:.55rem;background:#f1cf65;color:#3b3420;border-radius:6px;padding:0 .42rem;font-size:.66rem;font-weight:800}
  .card-body{padding:.78rem .85rem .9rem}
  .case-title{font-family:'Syne',sans-serif;font-size:1rem}
  .case-cost{margin-top:.35rem;color:var(--gold2);font-weight:800;font-size:.88rem}
  .card-open{margin-top:.65rem;width:100%;padding:.6rem;border-radius:9px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);color:#edf0ff;font-weight:700;cursor:pointer}
  .card-open:hover{border-color:rgba(198,241,53,.45);color:var(--gold)}

  .detail-head{
    display:flex;align-items:center;justify-content:space-between;gap:.6rem;
    margin-bottom:.75rem;padding:.65rem .75rem;border:1px solid var(--line);border-radius:12px;
    background:linear-gradient(180deg,rgba(26,28,51,0.96),rgba(18,20,40,0.96));
    box-shadow:0 10px 28px rgba(0,0,0,.28)
  }
  .detail-left{display:flex;align-items:center;gap:.6rem}
  .detail-left img{width:42px;height:42px;object-fit:contain}
  .detail-name{font-family:'Syne',sans-serif;font-size:1.08rem}
  .btn-mini{padding:.45rem .65rem;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);font-weight:700;cursor:pointer}

  .reel-wrap{
    border:1px solid rgba(198,241,53,.22);border-radius:14px;background:linear-gradient(180deg,#1a1830 0%,#0f0e1a 100%);
    padding:.6rem;overflow:hidden;position:relative;min-height:118px;
    box-shadow:0 12px 30px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.04);
  }
  .reel-wrap::before,.reel-wrap::after{
    content:'';position:absolute;top:0;bottom:0;width:42px;z-index:2;pointer-events:none
  }
  .reel-wrap::before{left:0;background:linear-gradient(90deg,rgba(12,10,22,.98) 0%,transparent 100%)}
  .reel-wrap::after{right:0;background:linear-gradient(270deg,rgba(12,10,22,.98) 0%,transparent 100%)}
  .reel-pointer{
    position:absolute;top:8px;bottom:8px;left:50%;transform:translateX(-50%);width:2px;
    background:linear-gradient(180deg,transparent,#d9ff6d 25%,#d9ff6d 75%,transparent);z-index:3;opacity:.95;
    box-shadow:0 0 14px rgba(198,241,53,.4)
  }
  .reel-wrap.vertical{min-height:290px}
  .reel-wrap.vertical .reel-pointer{
    left:8px;right:8px;top:50%;bottom:auto;height:2px;width:auto;transform:translateY(-50%);
    background:linear-gradient(90deg,transparent,#d9ff6d 25%,#d9ff6d 75%,transparent);
  }
  .reel-track{display:flex;gap:.45rem;will-change:transform;transform:translateX(0)}
  .reel-track.vertical{display:flex;flex-direction:column;gap:.55rem;align-items:center;transform:translateY(0)}
  .reel-item{
    width:140px;min-width:140px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);border-radius:12px;
    padding:.55rem .5rem;text-align:center;color:#d8dced;height:96px;display:flex;flex-direction:column;align-items:center;justify-content:center;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.04)
  }
  .reel-item .ico{font-size:1.25rem;line-height:1.2;min-height:1.35rem;display:flex;align-items:center;justify-content:center}
  .reel-item .ico-img,.chance .ico-img{width:26px;height:26px;object-fit:contain;display:block}
  .chance .ico{min-width:32px;display:flex;align-items:center;justify-content:center}
  .reel-item .nm{font-size:.68rem;margin-top:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
  .reel-item .val{font-size:.68rem;color:var(--gold2);font-weight:800;margin-top:.2rem;white-space:nowrap;width:100%}
  .reel-lanes{display:grid;grid-template-columns:1fr;gap:.5rem;margin-top:.7rem}
  .reel-lanes.multi{grid-template-columns:repeat(var(--case-columns,2),minmax(0,1fr));align-items:stretch}
  .lane-col{overflow:hidden;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(0,0,0,.16);height:248px;padding:.3rem;display:flex;align-items:flex-start;justify-content:center}
  .lane-col.single{height:auto;border:none;background:transparent;padding:0}

  .detail-controls{
    margin-top:.75rem;padding:.75rem;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.02);
    display:flex;flex-wrap:wrap;gap:.55rem;align-items:center
  }
  .detail-controls{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01))}
  .count-row{display:flex;gap:.35rem}
  .count-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);font-weight:800;cursor:pointer}
  .count-btn.on{border-color:rgba(245,217,106,.6);color:#f5d96a;background:rgba(245,217,106,.12)}
  .btn-open{padding:.68rem 1rem;border-radius:10px;border:none;background:linear-gradient(180deg,#f1cf65 0%,#c6a443 100%);color:#1d1a12;font-weight:900;cursor:pointer}
  .btn-demo{padding:.68rem 1rem;border-radius:10px;border:1px solid var(--line);background:#6b6797;color:#f2f1ff;font-weight:800;cursor:pointer}
  .btn-open:disabled,.btn-demo:disabled{opacity:.55;cursor:not-allowed}
  .status{
    margin-top:.55rem;font-size:.82rem;color:var(--muted);min-height:1.2rem;
    border:1px solid var(--line);border-radius:10px;padding:.55rem .65rem;background:rgba(0,0,0,.2)
  }

  .chances{margin-top:1rem}
  .chances h3{font-family:'Syne',sans-serif;font-size:1.08rem;margin-bottom:.55rem;color:var(--gold2)}
  .chance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.55rem}
  .chance{
    display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.45rem;
    background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
    border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.55rem .6rem
  }
  .chance .ico{font-size:1.1rem}
  .chance .nm{font-size:.79rem;color:#e5e8f7}
  .chance .pct{font-size:.73rem;color:var(--muted)}
  .chance .val{font-size:.77rem;color:var(--gold2);font-weight:800}

  .lobby-controls{
    display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;
    margin-bottom:1rem;
  }
  .search-wrap{
    flex:1;min-width:180px;position:relative;
  }
  .search-wrap svg{
    position:absolute;left:.7rem;top:50%;transform:translateY(-50%);
    opacity:.45;pointer-events:none;
  }
  #caseSearch{
    width:100%;padding:.58rem .75rem .58rem 2.15rem;
    border-radius:10px;border:1px solid var(--line);
    background:rgba(255,255,255,.04);color:var(--text);
    font-family:'DM Sans',sans-serif;font-size:.85rem;outline:none;
  }
  #caseSearch::placeholder{color:var(--muted)}
  #caseSearch:focus{border-color:rgba(198,241,53,.4);background:rgba(255,255,255,.06)}
  .sort-btn{
    display:flex;align-items:center;gap:.4rem;
    padding:.55rem .85rem;border-radius:10px;
    border:1px solid var(--line);background:rgba(255,255,255,.04);
    color:var(--muted);font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:700;
    cursor:pointer;white-space:nowrap;transition:border-color .13s,color .13s;
  }
  .sort-btn:hover{border-color:rgba(198,241,53,.35);color:var(--text)}
  .sort-arrow{display:inline-block;font-size:.9rem;line-height:1}
  .no-results{color:var(--muted);font-size:.88rem;padding:.5rem 0}

  @media(max-width:900px){
    .cards-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
    .reel-item{width:125px;min-width:125px;height:92px}
    .lane-col{height:230px}
  }
  @media(max-width:760px){
    .page{padding:0.8rem}
    .cards-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:0.75rem}
    .card-art{height:140px}
    .card-art img{width:95px;height:95px}
    .detail-head{flex-wrap:wrap;gap:0.5rem}
    .reel-item{width:115px;min-width:115px;height:88px}
    .lane-col{height:210px}
    .chance-grid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:480px){
    .page{padding:0.65rem 0.55rem}
    .cards-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0.6rem}
    .card-art{height:120px}
    .card-art img{width:80px;height:80px}
    .head h1{font-size:1.5rem}
    .reel-item{width:100px;min-width:100px;height:80px;padding:0.4rem 0.35rem}
    .reel-item .ico{font-size:1rem}
    .reel-item .nm,.reel-item .val{font-size:0.62rem}
    .lane-col{height:190px}
    .detail-controls{flex-direction:column;align-items:flex-start}
    .chance-grid{grid-template-columns:1fr}
    .reel-wrap.vertical{min-height:240px}
  }

/* === play/crash.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  html:has(#crashScene),body:has(#crashScene){overflow-x:hidden;max-width:100%}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;margin:0.5rem 0 1.25rem;line-height:1.45}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.8rem}
  .board-col{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .fx-panel{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column}
  .fx-panel > *{position:relative;z-index:1}
  .crash-scene{
    position:relative;
    z-index:1;
    flex:1;
    min-height:480px;
    overflow:hidden;
    padding:1.25rem 0 6.75rem;
    --cashout-spin-ms:2.8s;
    /* Shared with landing keyframes: moon disk geometry */
    --moon-top-pct:52%;
    --moon-w:min(200px,28%);
  }
  /* Wrapper owns position; inner SVG only rotates — avoids transform-chain interpolation “dips”. */
  .rocket-mount{
    position:absolute;
    z-index:2;
    left:10%;
    top:50%;
    transform:translateY(-50%);
    width:min(220px,32%);
    max-width:240px;
    pointer-events:none;
  }
  .rocket{
    display:block;
    width:100%;
    height:auto;
    transform-origin:50% 92%;
    filter:drop-shadow(0 12px 28px rgba(0,0,0,0.5)) drop-shadow(0 4px 8px rgba(198,241,53,0.08));
  }
  .rocket-body{
    fill:url(#rocketBodyGrad);
    stroke:rgba(0,0,0,0.22);
    stroke-width:1.1;
  }
  .rocket-window{
    fill:#0d1018;
    stroke:rgba(198,241,53,0.7);
    stroke-width:2;
  }
  .limbo-cockpit{fill:#1a2230}
  .limbo-pilot{fill:#050608}
  .limbo-eye{fill:#f0f2ea}
  .rocket-fin{fill:url(#finGrad)}
  .rocket-accent{fill:url(#accentGrad)}
  .rcs-pod{fill:url(#rcsPodGrad);stroke:rgba(0,0,0,0.35);stroke-width:0.45}
  .rcs-port{fill:#2a3344;stroke:rgba(255,255,255,0.18);stroke-width:0.35}
  .rcs-flame{opacity:0;pointer-events:none}
  .rcs-flame path:not(.rcs-flame-glow){fill:url(#rcsFlameGrad)}
  .rcs-flame path.rcs-flame-glow{fill:url(#rcsFlameGlowGrad);opacity:0.75}
  /*
    RCS: left jet for first ~26% of spin; right jet ~26–62% (counter-thrust); main engine from ~62%.
    Main engine hidden until cashout-brake — no dim plume over the hull during RCS.
  */
  .crash-scene.cashout:not(.cashout-brake):not(.cashout-rcs-dual) .rcs-flame.rcs-left{
    opacity:1;
    animation:rcsPlume 0.14s ease-in-out infinite alternate;
  }
  .crash-scene.cashout:not(.cashout-brake):not(.cashout-rcs-dual) .rcs-flame.rcs-right{opacity:0;animation:none}
  .crash-scene.cashout:not(.cashout-brake).cashout-rcs-dual .rcs-flame.rcs-left{opacity:0;animation:none}
  .crash-scene.cashout:not(.cashout-brake).cashout-rcs-dual .rcs-flame.rcs-right{
    opacity:1;
    animation:rcsPlume 0.14s ease-in-out infinite alternate;
  }
  .thruster{
    transform-origin:0 0;
    opacity:0;
    visibility:visible;
  }
  .thrust-glow{fill:url(#thrustGlowGrad);opacity:0.55;filter:url(#thrustSoftBlur)}
  .thrust-outer{fill:url(#thrustOuterGrad);opacity:0.88}
  .thrust-mid{fill:url(#thrustMidGrad);opacity:0.95}
  .thrust-core{fill:url(#thrustCoreGrad)}
  .thrust-lobe{fill:url(#thrustLobeGrad);opacity:0.82}
  .crash-scene.running .rocket{
    animation:rocketBob 1.35s ease-in-out infinite;
  }
  .crash-scene.running .thruster{
    opacity:1;
    animation:thrustFlicker 0.12s linear infinite;
  }
  .crash-scene.cashout:not(.cashout-brake) .thruster{opacity:0;animation:none;visibility:hidden}
  .crash-scene.cashout.cashout-brake .rcs-flame{opacity:0;animation:none}
  .crash-scene.cashout.cashout-brake .thruster{
    opacity:1;
    visibility:visible;
    animation:thrustBrake 0.09s ease-in-out infinite;
  }
  @keyframes rocketBob{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-12px)}
  }
  @keyframes thrustFlicker{
    0%{transform:scaleY(0.85);filter:blur(0px)}
    50%{transform:scaleY(1.1);filter:blur(0.2px)}
    100%{transform:scaleY(0.9);filter:blur(0px)}
  }
  @keyframes thrustBrake{
    0%,100%{transform:scaleY(1.18) scaleX(1.06);filter:brightness(1.08)}
    50%{transform:scaleY(1.35) scaleX(1.1);filter:brightness(1.18)}
  }
  @keyframes rcsPlume{
    0%{opacity:0.55;filter:brightness(0.9)}
    100%{opacity:1;filter:brightness(1.25)}
  }
  .moon{
    position:absolute;
    z-index:1;
    right:-40%;
    top:var(--moon-top-pct);
    width:var(--moon-w);
    aspect-ratio:1;
    border-radius:50%;
    background:
      radial-gradient(ellipse 95% 90% at 32% 28%, rgba(255,255,255,0.38) 0%, rgba(255,255,255,0.0) 42%),
      radial-gradient(circle at 22% 78%, rgba(45,48,58,0.55) 0%, rgba(45,48,58,0.0) 28%),
      radial-gradient(circle at 78% 42%, rgba(38,40,52,0.5) 0%, rgba(38,40,52,0.0) 22%),
      radial-gradient(circle at 55% 68%, rgba(52,54,64,0.45) 0%, rgba(52,54,64,0.0) 25%),
      radial-gradient(circle at 48% 50%, #c5cad6 0%, #8f96a8 38%, #5a6274 72%, #353b48 100%);
    border:1px solid rgba(255,255,255,0.12);
    box-shadow:
      0 3px 12px rgba(0,0,0,0.45),
      0 14px 32px rgba(0,0,0,0.3),
      0 0 24px rgba(100,120,150,0.08),
      inset 0 3px 14px rgba(255,255,255,0.18),
      inset 0 -12px 32px rgba(8,10,16,0.45);
    opacity:0;
    transform:translate3d(0,0,0);
  }
  .moon::before{
    content:'';
    position:absolute;
    inset:0;
    border-radius:50%;
    background:
      radial-gradient(ellipse 28% 22% at 28% 38%, rgba(30,32,42,0.5) 0%, transparent 72%),
      radial-gradient(ellipse 22% 18% at 72% 32%, rgba(28,30,40,0.45) 0%, transparent 70%),
      radial-gradient(ellipse 35% 30% at 48% 72%, rgba(25,27,36,0.42) 0%, transparent 68%),
      radial-gradient(circle at 62% 18%, rgba(22,24,32,0.35) 0%, transparent 45%),
      radial-gradient(circle at 18% 62%, rgba(24,26,34,0.38) 0%, transparent 40%);
    opacity:0.85;
    mix-blend-mode:multiply;
  }
  .moon::after{
    content:'';
    position:absolute;
    inset:0;
    border-radius:50%;
    background:
      radial-gradient(circle at 78% 22%, rgba(255,248,230,0.14) 0%, rgba(255,248,230,0.0) 38%),
      radial-gradient(circle at 18% 88%, rgba(255,200,120,0.06) 0%, rgba(255,200,120,0.0) 35%),
      radial-gradient(circle at 70% 55%, rgba(6,8,14,0.55) 0%, rgba(6,8,14,0.0) 48%);
    opacity:0.9;
    pointer-events:none;
  }
  .crash-scene.cashout .moon{
    opacity:1;
    animation:moonIn 1.05s cubic-bezier(.2,.9,.2,1) both;
  }
  @keyframes moonIn{
    from{right:-40%}
    to{right:11%}
  }
  /*
    Turn + approach together: same duration/easing so the rocket rotates while translating toward the moon.
  */
  .crash-scene.cashout .rocket{
    animation:rocketCashoutFlip var(--cashout-spin-ms,2.8s) cubic-bezier(.14,.62,.12,1) forwards;
  }
  .crash-scene.cashout .rocket-mount{
    animation:rocketMountGlide var(--cashout-spin-ms,2.8s) cubic-bezier(.14,.62,.12,1) forwards;
  }
  @keyframes rocketCashoutFlip{
    from{transform:rotate(0deg)}
    to{transform:rotate(330deg)}
  }
  .crash-scene.cashout.landed .rocket{transform:rotate(330deg);animation:none}
  .crash-scene.cashout.landed .thruster{opacity:0;animation:none;visibility:hidden}
  @keyframes rocketMountGlide{
    0%{left:10%;top:50%;transform:translateY(-50%)}
    100%{
      /*
        11 o’clock rim on moon; tuned so nose/engine line sits on surface after 330° roll (not floating high-left).
      */
      left:calc(100% - 11% - var(--moon-w) * 0.52 - min(64px,8%) - min(40px,5.5%));
      top:calc(var(--moon-top-pct) + var(--moon-w) * 0.11 - min(16px,2.5%));
      transform:translateY(calc(-50% - min(52px,8.5%)));
    }
  }
  .boom{
    position:absolute;
    z-index:0;
    left:10%;
    top:50%;
    transform:translateY(-50%) scale(0.2);
    width:min(260px,38%);
    aspect-ratio:1;
    border-radius:50%;
    background:radial-gradient(circle at 50% 50%, rgba(255,255,255,0.95) 0%, rgba(255,181,71,0.75) 18%, rgba(226,75,74,0.28) 42%, rgba(226,75,74,0.0) 70%);
    opacity:0;
    pointer-events:none;
    filter:blur(0.2px);
  }
  .crash-scene.crashed .rocket-mount{opacity:0}
  .crash-scene.crashed .boom{
    opacity:1;
    animation:boomStay 1.1s ease-out both;
  }
  @keyframes boomStay{
    0%{transform:translateY(-50%) scale(0.2);opacity:0}
    30%{opacity:1}
    100%{transform:translateY(-50%) scale(1.05);opacity:1}
  }
  .mult{font-family:'Syne',sans-serif;font-weight:800;font-size:3.5rem;text-align:center;line-height:1;margin:1rem 0;min-height:5rem;color:var(--gold);text-shadow:0 0 40px rgba(198,241,53,0.2)}
  .mult.crashed{color:var(--red);text-shadow:none}
  label{font-size:0.78rem;color:var(--muted);display:block;margin-bottom:0.35rem}
  input[type=number]{width:100%;padding:0.65rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;margin-bottom:0.75rem}
  .row{display:grid;grid-template-columns:1fr 1fr;gap:0.5rem}
  .btn{padding:0.8rem;border:none;border-radius:999px;font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:700;cursor:pointer}
  .btn-start{background:var(--gold);color:#0b0d14}
  .btn-cash{background:var(--green);color:#fff}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  .status{font-size:0.82rem;color:var(--muted);text-align:center;margin-top:0.75rem;min-height:1.25rem}
  .odds{font-size:0.74rem;color:var(--muted);text-align:center;margin-top:0.45rem;line-height:1.45}
  .odds b{color:var(--gold)}
  @media(max-width:900px){
    .game-layout{flex-direction:column}
    .controls-col{flex:1;max-width:340px;margin:0 auto}
  }
  @media(max-width:760px){
    .wrap{padding:0.8rem 0.8rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .crash-scene{min-height:340px;padding:1rem 0 5rem}
    .mult{font-size:2.5rem;min-height:3.5rem}
  }
  @media(max-width:480px){
    .wrap{padding:0.65rem 0.55rem 1.25rem}
    h1{font-size:1.4rem}
    .crash-scene{min-height:300px;padding:0.75rem 0 4rem}
    .mult{font-size:2rem;min-height:3rem;margin:0.65rem 0}
    .panel{padding:1rem}
    .row{grid-template-columns:1fr 1fr;gap:0.4rem}
    .btn{padding:0.7rem}
    .disclaimer{font-size:0.68rem;margin:0.35rem 0 0.9rem}
  }

/* === play/dice.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;line-height:1.45;margin:0.5rem 0 1.25rem}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.8rem}
  .board-col{flex:1;min-width:0;display:flex;flex-direction:column}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .fx-panel{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column}
  .fx-panel > *{position:relative;z-index:1}
  .dice-scene{position:relative;flex:1;min-height:220px;display:flex;align-items:center;justify-content:center}
  .die{
    width:min(180px,55%);
    aspect-ratio:1;
    border-radius:22px;
    background:linear-gradient(180deg,#ffffff,#d7dde6);
    box-shadow:0 26px 70px rgba(0,0,0,0.55);
    border:1px solid rgba(0,0,0,0.18);
    position:relative;
    transform:rotate(8deg);
  }
  .die::before{
    content:'';
    position:absolute;
    inset:14%;
    border-radius:16px;
    box-shadow:inset 0 0 0 1px rgba(0,0,0,0.08);
    background:linear-gradient(180deg,rgba(0,0,0,0.03),rgba(0,0,0,0));
  }
  .pip{position:absolute;width:14px;height:14px;border-radius:50%;background:#111827;box-shadow:0 2px 0 rgba(255,255,255,0.28),0 8px 18px rgba(0,0,0,0.35)}
  .p1{left:22%;top:22%}
  .p2{right:22%;top:22%}
  .p3{left:22%;top:50%;transform:translateY(-50%)}
  .p4{left:50%;top:50%;transform:translate(-50%,-50%)}
  .p5{right:22%;top:50%;transform:translateY(-50%)}
  .p6{left:22%;bottom:22%}
  .p7{right:22%;bottom:22%}
  .dice-scene.rolling .die{
    animation:dieRoll 0.22s linear infinite;
    filter:blur(0.25px);
  }
  .dice-scene.rolling{
    animation:dieDrift 0.9s ease-in-out infinite;
  }
  @keyframes dieDrift{
    0%{transform:translate(0,0)}
    16%{transform:translate(-18px,-10px)}
    32%{transform:translate(16px,-18px)}
    48%{transform:translate(20px,10px)}
    64%{transform:translate(-16px,16px)}
    80%{transform:translate(10px,-6px)}
    100%{transform:translate(0,0)}
  }
  @keyframes dieRoll{
    0%{transform:translateY(0) rotate(8deg) rotateZ(0deg) scale(1)}
    25%{transform:translateY(-6px) rotate(18deg) rotateZ(90deg) scale(1.02)}
    50%{transform:translateY(0) rotate(-10deg) rotateZ(180deg) scale(1)}
    75%{transform:translateY(6px) rotate(14deg) rotateZ(270deg) scale(1.01)}
    100%{transform:translateY(0) rotate(8deg) rotateZ(360deg) scale(1)}
  }
  .dice-caption{margin-top:0.65rem;text-align:center;font-size:0.78rem;color:var(--muted)}
  .roll-big{font-family:'Syne',sans-serif;font-weight:800;font-size:3.25rem;text-align:center;letter-spacing:-1px;margin:0.75rem 0;min-height:4.5rem;display:flex;align-items:center;justify-content:center}
  .roll-big.win{color:var(--green)}.roll-big.lose{color:var(--red)}
  @keyframes rollRolling{0%{transform:scale(1)}50%{transform:scale(1.08) rotate(-2deg)}100%{transform:scale(1)}}
  .roll-big.rolling{color:var(--muted);animation:rollRolling 0.16s ease-in-out infinite}
  .tabs{display:flex;gap:0.35rem;margin-bottom:0.75rem}
  .tabs button{flex:1;padding:0.5rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-weight:700;cursor:pointer;font-size:0.78rem}
  .tabs button.on{background:rgba(198,241,53,0.1);border-color:rgba(198,241,53,0.35);color:var(--gold)}
  label{font-size:0.78rem;color:var(--muted);display:block;margin-bottom:0.35rem}
  input[type=number]{width:100%;padding:0.65rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;margin-bottom:0.75rem}
  input[type=range]{width:100%;accent-color:var(--gold);margin:0.5rem 0 0.25rem}
  /* Custom slider fill: under = left win zone, over = right win zone */
  input[type=range].lotta-slider{
    -webkit-appearance:none;appearance:none;height:10px;border-radius:999px;outline:none;
    background:linear-gradient(to right, rgba(65,199,122,0.9) 0%, rgba(65,199,122,0.9) var(--fill,50%), rgba(255,255,255,0.10) var(--fill,50%), rgba(255,255,255,0.10) 100%);
  }
  input[type=range].lotta-slider.over{
    background:linear-gradient(to right, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.10) var(--fill,50%), rgba(65,199,122,0.9) var(--fill,50%), rgba(65,199,122,0.9) 100%);
  }
  input[type=range].lotta-slider::-webkit-slider-thumb{
    -webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;
    background:var(--gold);border:2px solid rgba(0,0,0,0.25);box-shadow:0 6px 18px rgba(0,0,0,0.45);
  }
  input[type=range].lotta-slider::-moz-range-thumb{
    width:18px;height:18px;border-radius:50%;
    background:var(--gold);border:2px solid rgba(0,0,0,0.25);box-shadow:0 6px 18px rgba(0,0,0,0.45);
  }
  .stat-row{display:flex;justify-content:space-between;font-size:0.85rem;margin-bottom:0.35rem}.stat-row span{color:var(--gold);font-family:'Syne',sans-serif;font-weight:700}
  .btn{width:100%;padding:0.85rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;margin-top:0.5rem}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  @media(max-width:900px){
    .game-layout{flex-direction:column}
    .controls-col{flex:1;max-width:340px;margin:0 auto}
  }
  @media(max-width:760px){
    .wrap{padding:0.8rem 0.8rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .dice-scene{min-height:280px}
    .roll-big{font-size:2.5rem;min-height:3.5rem}
  }
  @media(max-width:480px){
    .wrap{padding:0.65rem 0.55rem 1.25rem}
    h1{font-size:1.4rem}
    .dice-scene{min-height:240px}
    .roll-big{font-size:2rem;min-height:3rem;margin:0.5rem 0}
    .panel{padding:1rem}
    .disclaimer{font-size:0.68rem;margin:0.35rem 0 0.9rem}
    .stat-row{font-size:0.8rem}
  }

/* === play/keno.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px;--cell:#171a26;--line:#2a3142}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2);backdrop-filter:blur(12px)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-size:0.9rem;font-weight:700;color:var(--gold)}

  .page{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  .keno-head{text-align:center;margin-bottom:1rem}
  .keno-head h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);margin:0}
  .keno-head p{font-size:0.72rem;color:var(--muted);margin:0.5rem auto 1.25rem;max-width:700px;line-height:1.45}

  .layout{display:grid;grid-template-columns:300px 1fr;gap:1.25rem;align-items:start;flex:1;min-height:0}
  @media(max-width:900px){.layout{display:flex;flex-direction:column}}
  @media(max-width:900px){.side{order:2;width:100%}}
  @media(max-width:900px){.board-wrap{order:1;width:100%;min-height:300px}}

  .board-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:1rem;min-width:0}
  .grid{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;width:100%}
  .knum{
    height:125px;border-radius:7px;border:1px solid var(--line);
    background:linear-gradient(180deg,var(--cell) 0%,#0d0f14 100%);
    display:flex;align-items:center;justify-content:center;
    font-family:'Barlow Condensed',sans-serif;font-size:0.88rem;font-weight:700;
    cursor:pointer;transition:all 0.12s;user-select:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
  }
  .knum:hover{border-color:rgba(198,241,53,0.35);color:var(--gold)}
  .knum.selected{background:rgba(198,241,53,0.14);border-color:var(--gold);color:var(--gold)}
  .knum.hit{background:var(--gold)!important;border-color:var(--gold)!important;color:#141210!important;animation:hitPop 0.45s ease both}
  .knum.miss{background:rgba(229,62,62,0.12)!important;border-color:rgba(229,62,62,0.35)!important;color:#fca5a5!important;opacity:0.85}
  @keyframes hitPop{0%{transform:scale(1.15)}50%{transform:scale(0.92)}100%{transform:scale(1)}}
  @keyframes drawPop{0%{transform:scale(1)}50%{transform:scale(1.12)}100%{transform:scale(1)}}
  .knum.drawing{animation:drawPop 0.12s ease both}

  .side{display:flex;flex-direction:column;gap:1rem;max-width:300px}
  @media(max-width:900px){.side{max-width:100%}}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:1rem}
  .panel h3{font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:0.65rem}

  .pay-rows{display:flex;flex-direction:row;flex-wrap:wrap;gap:5px}
  .pay-item{
    background:var(--bg3);border:1px solid var(--line);border-radius:8px;
    padding:0.45rem 0.5rem 0.4rem;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;min-width:64px;flex:1;text-align:center;
  }
  .pay-item .pi-mult{color:var(--text);font-family:'Barlow Condensed',sans-serif;font-size:0.92rem;font-weight:800;line-height:1}
  .pay-item .pi-hits{color:var(--muted);font-size:0.62rem;font-weight:600;letter-spacing:0.5px;line-height:1;margin-top:2px}
  .pay-item.active-pay{border-color:rgba(198,241,53,0.5);background:rgba(198,241,53,0.1)}
  .pay-item.active-pay .pi-mult{color:var(--gold)}
  .pay-item.active-pay .pi-hits{color:rgba(198,241,53,0.7)}
  .risk-row{display:flex;gap:6px;margin-bottom:0.75rem}
  .risk-btn{flex:1;padding:0.5rem 0.6rem;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--muted);font-family:'Barlow Condensed',sans-serif;font-size:0.78rem;font-weight:800;cursor:pointer;text-transform:uppercase;letter-spacing:0.5px}
  .risk-btn.active{border-color:rgba(240,180,41,0.45);background:rgba(240,180,41,0.08);color:var(--gold)}

  .bet-input{display:flex;flex-direction:column;gap:0.45rem;align-items:stretch;margin-bottom:0.65rem}
  .bet-input label{font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase}
  .bet-input .lotta-wager-bar input#betInput{padding:0.45rem 0.35rem;background:rgba(255,255,255,0.05);border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:0.92rem}

  .row-btns{display:flex;flex-wrap:wrap;gap:8px}
  .btn{padding:0.65rem 1rem;border-radius:8px;font-family:'Barlow Condensed',sans-serif;font-size:0.82rem;font-weight:800;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;border:none;transition:opacity 0.15s,transform 0.12s}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-play{background:linear-gradient(180deg,#ffd54a,#f0b429);color:#141210}
  .btn-play:not(:disabled):hover{transform:translateY(-1px)}
  .btn-ghost{background:transparent;border:1px solid var(--line);color:var(--muted)}
  .btn-ghost:not(:disabled):hover{border-color:var(--gold);color:var(--gold)}

  .pick-line{font-size:0.8rem;color:var(--muted);text-align:center}
  .pick-line b{color:var(--text)}

  .result-banner{display:none;margin-top:0.75rem;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:0.85rem 1rem;text-align:center;flex-direction:column;align-items:center;justify-content:center}
  .result-banner.show{display:flex}
  .result-banner h3{font-family:'Bebas Neue',sans-serif;font-size:1.65rem;letter-spacing:2px}
  .result-banner.win h3{color:var(--gold)}
  .result-banner.lose h3{color:var(--red)}
  .result-sub{color:var(--muted);font-size:0.85rem;margin-top:0.25rem}

  .stats-row{display:flex;gap:0.75rem;flex-wrap:wrap;margin-bottom:1rem}
  .stat-pill{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:0.45rem 1rem;text-align:center}
  .stat-pill-label{font-size:0.65rem;color:var(--muted);text-transform:uppercase}
  .stat-pill-val{font-family:'Barlow Condensed',sans-serif;font-weight:700}
  .balance-pill .lotta-bal-main{display:block;font-size:0.88rem;line-height:1.2}
  .balance-pill .lotta-bal-fiat{display:block;font-size:0.72rem;color:var(--muted);font-weight:600;margin-top:0.12rem}
  @media(max-width:760px){
    .page{padding:0.8rem 0.8rem 1.5rem}
    .layout{gap:1rem}
    .knum{font-size:0.78rem;border-radius:5px}
    .grid{gap:4px}
    .side{max-width:100%}
    .stats-row{gap:0.5rem}
    .stat-pill{padding:0.4rem 0.75rem}
  }
  @media(max-width:480px){
    .page{padding:0.65rem 0.55rem 1.25rem}
    .keno-head h1{font-size:1.4rem}
    .keno-head p{font-size:0.68rem;margin:0.35rem auto 0.9rem}
    .knum{font-size:0.68rem;border-radius:4px}
    .grid{gap:3px}
    .panel{padding:0.85rem}
    .risk-btn{padding:0.4rem 0.4rem;font-size:0.72rem}
    .bet-input .lotta-wager-bar input#betInput{font-size:0.85rem}
    .btn{padding:0.55rem 0.75rem;font-size:0.78rem}
    .stats-row{gap:0.4rem}
    .stat-pill{padding:0.35rem 0.6rem;flex:1}
    .stat-pill-val{font-size:0.82rem}
    .result-banner h3{font-size:1.35rem}
  }

/* === play/limbo.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;line-height:1.45;margin:0.5rem 0 1.25rem}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.8rem}
  .board-col{flex:1;min-width:0;display:flex;flex-direction:column}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .fx-panel{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column}
  .fx-panel > *{position:relative;z-index:1}
  .limbo-scene{position:relative;flex:1;min-height:260px;display:flex;align-items:center;justify-content:center}
  .limbo-grid{position:absolute;inset:0;pointer-events:none}
  .portal{
    width:min(320px,58%);
    aspect-ratio:1;
    border-radius:50%;
    border:2px solid rgba(198,241,53,0.35);
    background:radial-gradient(circle at 50% 50%, rgba(198,241,53,0.18) 0%, rgba(198,241,53,0.02) 44%, rgba(0,0,0,0) 68%);
    box-shadow:0 0 0 10px rgba(198,241,53,0.03), 0 26px 80px rgba(0,0,0,0.55);
    position:relative;
    filter:drop-shadow(0 10px 30px rgba(0,0,0,0.45));
  }
  .portal::before{
    content:'';
    position:absolute;inset:10%;
    border-radius:50%;
    border:1px dashed rgba(255,255,255,0.18);
    opacity:0.9;
  }
  .runner{
    position:absolute;
    left:50%;
    top:62%;
    width:34px;height:34px;
    background:linear-gradient(180deg,#f0f0f0,#7f8aa6);
    border-radius:10px;
    transform:translate(-50%,-50%);
    box-shadow:0 10px 30px rgba(0,0,0,0.55);
  }
  .runner::before{
    content:'';
    position:absolute;left:50%;top:-16px;
    width:18px;height:18px;border-radius:50%;
    background:#f0f0f0;
    transform:translateX(-50%);
  }
  .bar{
    position:absolute;left:50%;top:58%;
    width:min(360px,70%);
    height:10px;border-radius:999px;
    background:linear-gradient(90deg, rgba(226,75,74,0.0), rgba(226,75,74,0.7), rgba(226,75,74,0.0));
    box-shadow:0 0 28px rgba(226,75,74,0.28);
    transform:translate(-50%,-50%);
  }
  .bar{z-index:3}
  .runner{z-index:2}
  .limbo-scene.charging .portal{
    animation:portalCharge 0.6s ease-in-out infinite alternate;
  }
  @keyframes portalCharge{
    from{transform:scale(1)}
    to{transform:scale(1.03)}
  }
  .limbo-scene.jumping .runner{
    animation:runnerJump 0.55s cubic-bezier(.2,.9,.2,1) infinite;
  }
  @keyframes runnerJump{
    0%{transform:translate(-50%,-50%)}
    50%{transform:translate(-50%,-120%)}
    100%{transform:translate(-50%,-50%)}
  }
  .limbo-scene.win .bar{
    background:linear-gradient(90deg, rgba(65,199,122,0.0), rgba(65,199,122,0.75), rgba(65,199,122,0.0));
    box-shadow:0 0 36px rgba(65,199,122,0.28);
  }
  .limbo-scene.win .runner{
    animation:runnerWin 0.9s cubic-bezier(.2,.9,.2,1) both;
  }
  @keyframes runnerWin{
    0%{transform:translate(-50%,-50%)}
    40%{transform:translate(-50%,-140%)}
    100%{transform:translate(calc(-50% + 170px),-140%) rotate(10deg)}
  }
  .limbo-scene.lose .bar{
    animation:barDrop 0.55s cubic-bezier(.2,.9,.2,1) both;
  }
  .limbo-scene.lose .runner{
    animation:runnerFall 0.6s cubic-bezier(.2,.9,.2,1) both;
  }
  @keyframes barDrop{
    0%{transform:translate(-50%,-50%) rotate(0deg)}
    25%{transform:translate(calc(-50% + 10px),-35%) rotate(10deg)}
    100%{transform:translate(calc(-50% + 50px),170%) rotate(18deg);opacity:0}
  }
  @keyframes runnerFall{
    0%{transform:translate(-50%,-50%) rotate(0deg)}
    35%{transform:translate(-50%,-50%) rotate(-20deg)}
    100%{transform:translate(calc(-50% + 60px),110%) rotate(-95deg);opacity:0.85}
  }
  @keyframes barShake{
    0%{transform:translate(-50%,-50%)}
    20%{transform:translate(calc(-50% - 6px),-50%)}
    40%{transform:translate(calc(-50% + 6px),-50%)}
    60%{transform:translate(calc(-50% - 4px),-50%)}
    80%{transform:translate(calc(-50% + 4px),-50%)}
    100%{transform:translate(-50%,-50%)}
  }
  .spark{
    position:absolute;
    left:50%;top:50%;
    width:8px;height:8px;border-radius:50%;
    background:var(--gold);
    opacity:0;
    pointer-events:none;
  }
  .limbo-scene.win .spark{
    opacity:1;
    animation:sparkBurst 0.75s ease-out both;
  }
  @keyframes sparkBurst{
    0%{transform:translate(-50%,-50%) scale(0.8);filter:blur(0)}
    100%{transform:translate(calc(-50% + 120px),calc(-50% - 120px)) scale(0.2);opacity:0;filter:blur(0.6px)}
  }
  .out{font-family:'Syne',sans-serif;font-weight:800;font-size:2.75rem;text-align:center;margin:1rem 0;min-height:4rem}
  .out.win{color:var(--green)}.out.lose{color:var(--red)}
  @keyframes limboPulse{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}
  .out.loading{color:var(--muted);animation:limboPulse 0.35s ease-in-out infinite}
  label{font-size:0.78rem;color:var(--muted);display:block;margin-bottom:0.35rem}
  input[type=number]{width:100%;padding:0.65rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;margin-bottom:0.75rem}
  .stat-row{display:flex;justify-content:space-between;font-size:0.85rem;margin-bottom:0.35rem}.stat-row span{color:var(--gold);font-family:'Syne',sans-serif;font-weight:700}
  .btn{width:100%;padding:0.85rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;margin-top:0.5rem}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s;margin-top:0}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  @media(max-width:900px){
    .game-layout{flex-direction:column}
    .controls-col{flex:1;max-width:340px;margin:0 auto}
  }
  @media(max-width:760px){
    .wrap{padding:0.8rem 0.8rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .limbo-scene{min-height:280px}
    .out{font-size:2.25rem;min-height:3.25rem;margin:0.65rem 0}
  }
  @media(max-width:480px){
    .wrap{padding:0.65rem 0.55rem 1.25rem}
    h1{font-size:1.4rem}
    .limbo-scene{min-height:240px}
    .out{font-size:1.85rem;min-height:2.75rem;margin:0.5rem 0}
    .panel{padding:1rem}
    .disclaimer{font-size:0.68rem;margin:0.35rem 0 0.9rem}
    .stat-row{font-size:0.8rem}
  }

/* === play/mines.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}

  .game-wrap{flex:1;display:flex;flex-direction:column;gap:0.85rem;padding:1rem 1.5rem 1.25rem;width:100%;align-items:center}
  .game-head{width:100%;text-align:center}
  .game-head h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);margin:0}
  .game-head .disclaimer{font-size:0.72rem;color:var(--muted);line-height:1.45;margin:0.5rem auto 0.85rem;max-width:700px}

  .game-body{width:100%;display:flex;gap:2rem;align-items:stretch;justify-content:center;flex:1;flex-wrap:wrap;min-height:0}

  .mines-play-col{display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:center;flex:1 1 0;min-width:0;min-height:0}

  .game-controls{display:flex;flex-direction:column;gap:1rem;flex:0 0 280px;max-width:280px}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .panel-title{font-size:0.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:0.75rem}

  label{font-size:0.82rem;color:var(--muted);display:block;margin-bottom:0.3rem}
  input[type=number]{width:100%;padding:0.6rem 0.9rem;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:'Barlow',sans-serif;font-size:0.95rem;outline:none;margin-bottom:0.75rem}
  input[type=number]:focus{border-color:rgba(240,180,41,0.4)}
  input[type=range]{width:100%;accent-color:var(--gold);margin-bottom:0.5rem}
  .wager-row{display:flex;gap:0.5rem;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:rgba(198,241,53,0.1);
    border:1px solid rgba(198,241,53,0.3);
    border-radius:8px;
    color:var(--gold);
    font-family:'DM Sans',sans-serif;
    font-weight:700;
    font-size:0.85rem;
    cursor:pointer;
    transition:all 0.2s;
    flex-shrink:0;
    margin-bottom:0;
  }
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}

  .mine-count-label{display:flex;justify-content:space-between;margin-bottom:0.25rem}
  .mine-count-val{font-family:'Syne',sans-serif;font-size:1.05rem;font-weight:700;color:var(--gold)}

  .btn-primary{width:100%;padding:0.8rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;transition:opacity 0.2s,transform 0.15s}
  .btn-primary:disabled{opacity:0.3;cursor:not-allowed}
  .btn-primary:not(:disabled):hover{transform:scale(1.02)}
  .btn-cashout{width:100%;padding:0.8rem;border:none;border-radius:999px;background:#1f7a4d;border:1px solid var(--green);color:#ecfff4;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;transition:opacity 0.2s,transform 0.15s}
  .btn-cashout:disabled{opacity:0.3;cursor:not-allowed}
  .btn-cashout:not(:disabled):hover{transform:scale(1.02)}

  .mult-display{text-align:center;padding:0.75rem;background:rgba(240,180,41,0.05);border:1px solid var(--border);border-radius:6px;margin-bottom:0.5rem}
  .mult-big{font-family:'Syne',sans-serif;font-size:1.75rem;font-weight:800;letter-spacing:-0.2px;color:var(--gold)}
  .mult-label{font-size:0.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
  .profit-display{text-align:center;font-family:'DM Sans',sans-serif;font-size:1.05rem;font-weight:700;color:var(--green)}

  .mines-board{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;width:min(560px,calc(100vmin - 5.5rem));max-width:min(560px,calc(100vmin - 5.5rem),100%);flex:0 0 auto;margin-inline:auto}
  .mtile{
    aspect-ratio:1;border-radius:10px;border:1px solid var(--border);
    background:var(--bg2);display:flex;align-items:center;justify-content:center;
    font-size:1.8rem;cursor:pointer;transition:all 0.15s;user-select:none;
  }
  .mtile:not(.revealed):not(.mine-shown):hover{border-color:rgba(240,180,41,0.4);background:rgba(240,180,41,0.05);transform:scale(1.03)}
  .mtile.gem{background:rgba(56,161,105,0.15)!important;border-color:rgba(56,161,105,0.5)!important;animation:gemPop 0.35s ease both}
  .mtile.mine-shown{background:rgba(229,62,62,0.15)!important;border-color:rgba(229,62,62,0.5)!important;cursor:default;animation:boom 0.4s ease both}
  .mtile.revealed{cursor:default}
  @keyframes gemPop{0%{transform:scale(0.7) rotate(-10deg)}60%{transform:scale(1.15) rotate(3deg)}100%{transform:scale(1) rotate(0)}}
  @keyframes boom{0%{transform:scale(1.3)}50%{transform:scale(0.85)}100%{transform:scale(1)}}

  .stats-bar{display:flex;gap:0.75rem;flex-wrap:wrap;justify-content:center;width:100%;max-width:min(560px,calc(100vmin - 5.5rem),100%)}
  .stat-mini{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:0.5rem 1rem;text-align:center;flex:1;min-width:80px}
  .stat-mini-label{font-size:0.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
  .stat-mini-val{font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700}
  @keyframes boardShake{0%{transform:translateX(0)}20%{transform:translateX(-3px)}40%{transform:translateX(3px)}60%{transform:translateX(-2px)}80%{transform:translateX(2px)}100%{transform:translateX(0)}}
  .game-wrap.shake{animation:boardShake 0.35s ease-in-out both}
  .balance-pill .lotta-bal-main{display:block;font-size:0.88rem;line-height:1.2}
  .balance-pill .lotta-bal-fiat{display:block;font-size:0.72rem;color:var(--muted);font-weight:600;margin-top:0.12rem}
  @keyframes cashPulse{0%{box-shadow:0 0 0 rgba(56,161,105,0)}50%{box-shadow:0 0 0 6px rgba(56,161,105,0.12)}100%{box-shadow:0 0 0 rgba(56,161,105,0)}}
  .btn-cashout.pulse{animation:cashPulse 0.9s ease-in-out infinite}
  @media(max-width:760px){
    .game-wrap{padding:0.8rem 0.8rem 1.5rem;gap:0.85rem}
    .game-body{gap:1rem}
    .game-controls{min-width:0;max-width:100%;flex:1 1 100%}
    .mines-board{width:min(560px,calc(100vmin - 4.5rem),100%)}
    .stats-bar{max-width:min(560px,calc(100vmin - 4.5rem),100%)}
    .mtile{font-size:1.5rem;border-radius:8px}
  }
  @media(max-width:480px){
    .game-wrap{padding:0.65rem 0.55rem 1.25rem;gap:0.75rem}
    .game-head h1{font-size:1.4rem}
    .game-head .disclaimer{font-size:0.68rem;margin:0.35rem auto 0.9rem}
    .panel{padding:1rem}
    .mtile{font-size:1.3rem;border-radius:7px}
    .mines-board{gap:5px}
    .mult-big{font-size:1.5rem}
    .stat-mini{padding:0.4rem 0.65rem}
    .stat-mini-val{font-size:0.85rem}
  }

/* === play/plinko.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column;gap:0.8rem}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;margin:0.5rem 0 1.25rem;line-height:1.45}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.65rem}
  .board-col{flex:1;min-width:0;display:flex;flex-direction:column}
  .controls{display:grid;grid-template-columns:1fr;gap:0.5rem}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
  .panel label{font-size:0.72rem;color:var(--muted);text-transform:uppercase;display:block;margin-bottom:0.35rem}
  select,input[type=number]{width:100%;padding:0.55rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:0.95rem}
  .risk-btns{display:flex;gap:0.35rem;flex-wrap:wrap}
  .risk-btns button{flex:1;min-width:70px;padding:0.45rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.78rem;cursor:pointer}
  .risk-btns button.on{background:rgba(198,241,53,0.1);border-color:rgba(198,241,53,0.4);color:var(--gold)}
  .board{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:0.55rem 0.55rem 0.7rem;flex:1;display:flex;flex-direction:column;min-height:0}
  /* Bucket containers rendered below the triangle */
  .slots{position:absolute;left:0;right:0;bottom:12px;height:84px;pointer-events:none}
  .bucket{
    position:absolute;
    transform:translateX(-50%);
    bottom:0;
    width:36px;
    height:62px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-end;
    padding:0 2px;
  }
  .bucket-shape{
    width:100%;
    height:42px;
    background:linear-gradient(180deg,rgba(19,21,31,0.95),rgba(11,13,20,0.98));
    border:2px solid rgba(255,255,255,0.2);
    border-top:none;
    border-radius:0 0 6px 6px;
    position:relative;
    box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 12px rgba(0,0,0,0.3);
  }
  .bucket-shape::before{
    content:'';
    position:absolute;
    top:-2px;
    left:-2px;
    right:-2px;
    height:4px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);
  }
  .bucket-shape.bucket-hit{
    animation:bucketGlow 0.6s ease both;
  }
  @keyframes bucketGlow{
    0%{box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 12px rgba(0,0,0,0.3)}
    50%{box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 20px rgba(198,241,53,0.6),0 0 0 3px rgba(198,241,53,0.3)}
    100%{box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 12px rgba(0,0,0,0.3)}
  }
  .bucket-mult{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    font-size:0.62rem;
    font-family:'Syne',sans-serif;
    font-weight:800;
    color:var(--gold);
    text-shadow:0 1px 3px rgba(0,0,0,0.8);
    white-space:nowrap;
    pointer-events:none;
    line-height:1;
    text-align:center;
    max-width:100%;
    overflow:hidden;
  }
  .drop-area{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center}
  .drop-area .peg-area{margin-bottom:0.75rem}
  .drop-area .btn{margin-top:0}
  .dropbar .btn{margin-top:0}
  .dropbar .peg-area{margin:0;min-height:auto}
  .pegboard{
    position:relative;
    width:100%;
    min-height:560px;
    margin:0.35rem auto 0.1rem;
    border-radius:12px;
    background:linear-gradient(180deg,rgba(198,241,53,0.06) 0%,rgba(0,0,0,0) 60%),var(--bg);
    border:1px solid var(--border);
    overflow:hidden;
  }
  .peg{
    position:absolute;
    width:11px;
    height:11px;
    border-radius:50%;
    background:rgba(240,180,41,0.2);
    border:1px solid rgba(240,180,41,0.25);
    box-shadow:0 0 18px rgba(240,180,41,0.08);
    transform:translate(-50%,-50%);
  }
  .ball{
    position:absolute;
    width:18px;
    height:18px;
    border-radius:50%;
    background:radial-gradient(circle at 35% 30%,#fff 0%,rgba(255,255,255,0.6) 18%,rgba(240,180,41,0.95) 45%,rgba(240,180,41,0.25) 72%);
    border:1px solid rgba(240,180,41,0.45);
    box-shadow:0 10px 40px rgba(0,0,0,0.55), 0 0 30px rgba(240,180,41,0.18);
    transform:translate(-50%,-50%);
    left:50%;
    top:18px;
    z-index:2;
    will-change:left,top;
  }
  @keyframes ballLand{0%{transform:translate(-50%,-50%) scale(1)}40%{transform:translate(-50%,-50%) scale(1.18)}100%{transform:translate(-50%,-50%) scale(1)}}
  .ball.land{animation:ballLand 0.28s ease both}
  .peg-area{min-height:120px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;color:var(--muted);margin:0.5rem 0}
  .peg-area.playing{color:var(--gold)}
  .btn{width:100%;padding:0.85rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;margin-top:0.75rem}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  .drop-history{margin-top:0.75rem;display:flex;flex-direction:column;gap:0.3rem}
  .drop-history-item{font-size:0.82rem;color:var(--muted);text-align:center;transition:opacity 0.3s}
  .drop-history-item b{color:var(--gold)}
  .drop-history-item:first-child{color:var(--text)}
  @media (max-width: 768px) {
    nav{padding:0.85rem 1rem}
    .wrap{max-width:100%;padding:1.25rem 0.75rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .controls{grid-template-columns:1fr;gap:0.5rem}
    .pegboard{min-height:auto;max-height:55vh}
    .bucket{height:auto;min-height:44px}
    .bucket-mult{font-size:0.66rem}
  }
  @media (max-width: 480px) {
    nav{padding:0.75rem 0.75rem}
    .wrap{padding:1rem 0.5rem 1.25rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .pegboard{min-height:auto;max-height:50vh}
    .bucket{height:auto;min-height:40px}
    .bucket-mult{font-size:0.63rem}
    .panel{padding:0.75rem}
  }

/* === privacy.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  :root {
    --bg: #0b0d14; --bg2: #13151f;
    --accent: #c6f135; --text: #f0f0f0; --muted: #8b8fa8;
    --card-border: rgba(255,255,255,0.07); --radius: 16px;
  }
  body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 16px; line-height: 1.7; }
  nav { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 2.5rem; border-bottom: 1px solid var(--card-border); background: rgba(11,13,20,0.85); backdrop-filter: blur(12px); }
  .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.4rem; text-decoration: none; color: var(--text); }
  .logo span { color: var(--accent); }
  .nav-back { color: var(--muted); text-decoration: none; font-size: 0.875rem; }
  .nav-back:hover { color: var(--text); }
  .content { max-width: 760px; margin: 0 auto; padding: 4rem 2rem 6rem; }
  h1 { font-family: 'Syne', sans-serif; font-size: 2.5rem; font-weight: 800; letter-spacing: -1px; margin-bottom: 0.5rem; }
  .updated { color: var(--muted); font-size: 0.875rem; margin-bottom: 3rem; }
  h2 { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.15rem; margin: 2.5rem 0 0.75rem; color: var(--accent); }
  p { color: #c8cad8; margin-bottom: 1rem; }
  ul { color: #c8cad8; padding-left: 1.5rem; margin-bottom: 1rem; }
  li { margin-bottom: 0.4rem; }
  a { color: var(--accent); }

/* === signup.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  :root { --bg: #0b0d14; --bg2: #13151f; --accent: #c6f135; --accent2: #7f5af0; --text: #f0f0f0; --muted: #8b8fa8; --card-border: rgba(255,255,255,0.07); --radius: 16px; --danger: #e24b4a; }
  body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; min-height: 100vh; display: flex; flex-direction: column; }
  nav { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 2.5rem; border-bottom: 1px solid var(--card-border); }
  .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.4rem; text-decoration: none; color: var(--text); }
  .logo span { color: var(--accent); }
  .nav-link { font-size: 0.875rem; color: var(--muted); text-decoration: none; }
  .nav-link:hover { color: var(--text); }

  main { flex: 1; display: flex; align-items: center; justify-content: center; padding: 3rem 1.5rem; }
  .auth-card { background: var(--bg2); border: 1px solid var(--card-border); border-radius: 24px; padding: 2.5rem; width: 100%; max-width: 420px; }
  .auth-title { font-family: 'Syne', sans-serif; font-size: 1.75rem; font-weight: 800; letter-spacing: -0.5px; margin-bottom: 0.4rem; }
  .auth-sub { color: var(--muted); font-size: 0.9rem; margin-bottom: 2rem; }
  .auth-sub a { color: var(--accent); text-decoration: none; }

  .form-group { margin-bottom: 1rem; }
  label { display: block; font-size: 0.85rem; font-weight: 500; color: var(--muted); margin-bottom: 0.4rem; }
  input { width: 100%; padding: 0.75rem 1rem; background: rgba(255,255,255,0.05); border: 1px solid var(--card-border); border-radius: 10px; color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; outline: none; transition: border-color 0.2s; }
  input:focus { border-color: rgba(198,241,53,0.4); }
  input::placeholder { color: var(--muted); }
  input.error { border-color: var(--danger); }

  .error-msg { font-size: 0.8rem; color: var(--danger); margin-top: 0.35rem; display: none; }
  .error-msg.show { display: block; }

  .btn-submit { width: 100%; padding: 0.85rem; border: none; border-radius: 50px; background: var(--accent); color: #0b0d14; font-family: 'DM Sans', sans-serif; font-size: 1rem; font-weight: 700; cursor: pointer; margin-top: 0.5rem; transition: opacity 0.2s, transform 0.15s; }
  .btn-submit:hover { opacity: 0.9; }
  .btn-submit:active { transform: scale(0.98); }
  .btn-submit:disabled { opacity: 0.5; cursor: not-allowed; }

  .divider { display: flex; align-items: center; gap: 1rem; margin: 1.25rem 0; color: var(--muted); font-size: 0.8rem; }
  .divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: var(--card-border); }

  .btn-google { width: 100%; padding: 0.75rem; border: 1px solid var(--card-border); border-radius: 50px; background: transparent; color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; font-weight: 500; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 0.6rem; transition: border-color 0.2s, background 0.2s; }
  .btn-google:hover { border-color: rgba(255,255,255,0.25); background: rgba(255,255,255,0.04); }

  .terms { font-size: 0.78rem; color: var(--muted); text-align: center; margin-top: 1.25rem; line-height: 1.5; }
  .terms a { color: var(--muted); text-decoration: underline; }
  .opt-row { display:flex; align-items:center; gap:0.55rem; margin:0.2rem 0 0.75rem; color:var(--muted); font-size:0.82rem; }
  .opt-row input { width:auto; padding:0; }

  .alert { padding: 0.75rem 1rem; border-radius: 10px; font-size: 0.875rem; margin-bottom: 1rem; display: none; }
  .alert.show { display: block; }
  .alert-error { background: rgba(226,75,74,0.1); border: 1px solid rgba(226,75,74,0.3); color: #f09595; }
  .alert-success { background: rgba(198,241,53,0.1); border: 1px solid rgba(198,241,53,0.3); color: var(--accent); }

  .spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid rgba(11,13,20,0.3); border-top-color: #0b0d14; border-radius: 50%; animation: spin 0.7s linear infinite; vertical-align: middle; }
  @keyframes spin { to { transform: rotate(360deg); } }
  @media(max-width:480px){
    nav{padding:0.75rem 1rem}
    main{padding:1.5rem 0.75rem}
    .auth-card{padding:1.75rem 1.25rem;border-radius:16px}
    .auth-title{font-size:1.5rem}
  }

/* === terms.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  :root {
    --bg: #0b0d14; --bg2: #13151f;
    --accent: #c6f135; --text: #f0f0f0; --muted: #8b8fa8;
    --card-border: rgba(255,255,255,0.07); --radius: 16px;
  }
  body { background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 16px; line-height: 1.7; }
  nav { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 2.5rem; border-bottom: 1px solid var(--card-border); background: rgba(11,13,20,0.85); backdrop-filter: blur(12px); }
  .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.4rem; text-decoration: none; color: var(--text); }
  .logo span { color: var(--accent); }
  .nav-back { color: var(--muted); text-decoration: none; font-size: 0.875rem; }
  .nav-back:hover { color: var(--text); }
  .content { max-width: 760px; margin: 0 auto; padding: 4rem 2rem 6rem; }
  h1 { font-family: 'Syne', sans-serif; font-size: 2.5rem; font-weight: 800; letter-spacing: -1px; margin-bottom: 0.5rem; }
  .updated { color: var(--muted); font-size: 0.875rem; margin-bottom: 3rem; }
  h2 { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.15rem; margin: 2.5rem 0 0.75rem; color: var(--accent); }
  p { color: #c8cad8; margin-bottom: 1rem; }
  ul { color: #c8cad8; padding-left: 1.5rem; margin-bottom: 1rem; }
  li { margin-bottom: 0.4rem; }
  a { color: var(--accent); }
}

@layer lc-misc {
/* === lotta-queue.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0a0a0f;--bg2:#111118;--gold:#f0b429;--text:#f0ebe0;--muted:#7a7570;--border:rgba(240,180,41,0.15);--red:#e53e3e;--green:#38a169}
  body{background:var(--bg);color:var(--text);font-family:'Barlow',sans-serif;min-height:100vh;padding:1.5rem;line-height:1.5}
  h1{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:3px;color:var(--gold)}
  .sub{color:var(--muted);font-size:0.88rem;max-width:720px;margin:0.5rem 0 1.25rem}
  .warn{background:rgba(229,62,62,0.1);border:1px solid rgba(229,62,62,0.35);border-radius:10px;padding:0.85rem 1rem;font-size:0.82rem;margin-bottom:1.25rem;max-width:720px}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.25rem;max-width:960px;margin-bottom:1.5rem}
  label{display:block;font-size:0.75rem;color:var(--muted);margin-bottom:0.35rem;text-transform:uppercase;letter-spacing:0.5px}
  input{width:100%;max-width:440px;padding:0.65rem 0.85rem;border-radius:8px;border:1px solid var(--border);background:#18181f;color:var(--text);font-family:inherit;margin-bottom:0.75rem}
  input:focus{outline:none;border-color:rgba(240,180,41,0.45)}
  .row{display:flex;flex-wrap:wrap;gap:0.75rem;align-items:flex-end;margin-bottom:1rem}
  button{padding:0.55rem 1.1rem;border-radius:8px;font-family:inherit;font-weight:700;cursor:pointer;border:none;font-size:0.85rem}
  .btn-load{background:var(--gold);color:#0a0a0f}
  .btn-load:disabled{opacity:0.5;cursor:not-allowed}
  .btn-done{background:var(--green);color:#fff}
  .btn-fail{background:transparent;border:1px solid var(--red);color:#fc8181}
  table{width:100%;border-collapse:collapse;font-size:0.82rem}
  th{text-align:left;padding:0.65rem 0.5rem;border-bottom:1px solid var(--border);color:var(--muted);font-size:0.7rem;text-transform:uppercase;letter-spacing:0.5px}
  td{padding:0.75rem 0.5rem;border-bottom:1px solid rgba(255,255,255,0.05);vertical-align:top}
  tr:hover{background:rgba(255,255,255,0.02)}
  .mono{font-family:ui-monospace,monospace;font-size:0.78rem;word-break:break-all}
  .amt{color:var(--gold);font-weight:700}
  #status{font-size:0.85rem;margin-top:0.75rem}
  #status.err{color:#fc8181}
  #status.ok{color:var(--green)}
  .empty{color:var(--muted);padding:2rem;text-align:center}
  a{color:var(--gold)}

/* === maintenance.html (inline) === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root { --bg: #0b0d14; --bg2: #13151f; --text: #f0f0f0; --muted: #8b8fa8; --accent: #c6f135; --border: rgba(255,255,255,0.10); }
    body { background: radial-gradient(1100px 700px at 20% 0%, rgba(198,241,53,0.08), transparent 60%),
                   radial-gradient(900px 600px at 90% 40%, rgba(127,90,240,0.10), transparent 60%),
                   var(--bg);
           color: var(--text); font-family: 'DM Sans', sans-serif; min-height: 100vh; display: flex; }
    .wrap { width: 100%; max-width: 720px; margin: auto; padding: 3rem 1.5rem; }
    .card { background: rgba(19,21,31,0.9); border: 1px solid var(--border); border-radius: 22px; padding: 2.25rem; }
    .logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.5rem; letter-spacing: -0.5px; margin-bottom: 0.6rem; }
    .logo span { color: var(--accent); }
    h1 { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 2.0rem; margin: 0.2rem 0 0.75rem; }
    p { color: var(--muted); line-height: 1.6; font-size: 1rem; }
    .msg { margin-top: 0.9rem; padding: 0.9rem 1rem; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 14px; color: var(--text); }
    .row { display:flex; align-items:center; gap: 0.75rem; margin-top: 1.2rem; flex-wrap: wrap; }
    .pill { font-size: 0.85rem; color: var(--muted); border: 1px solid rgba(255,255,255,0.12); padding: 0.45rem 0.7rem; border-radius: 999px; }
    .btn { display:inline-flex; align-items:center; justify-content:center; gap:0.5rem; border-radius:999px; padding:0.65rem 0.95rem; border:1px solid rgba(255,255,255,0.16); background: rgba(255,255,255,0.04); color: var(--text); text-decoration:none; cursor:pointer; font-weight:600; }
    .btn:hover { background: rgba(255,255,255,0.06); }
    .btn-primary { border-color: rgba(198,241,53,0.35); background: rgba(198,241,53,0.12); }
    .btn-primary:hover { background: rgba(198,241,53,0.18); }
    .small { font-size: 0.85rem; color: var(--muted); margin-top: 1.1rem; }
}

@layer lc-games {
/* All /play/*.html rules from legacy bundle */
/* === play/blackjack.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.4rem 1rem;font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;color:var(--gold)}

  .game-wrap{flex:1;display:flex;flex-direction:column;align-items:stretch;padding:1rem 1.5rem 1.25rem;gap:0.75rem;width:100%}
  .game-title{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  
  .felt{
    width:100%;
    display:flex;
    flex-direction:column;
    position:relative;
    overflow:hidden;
    flex:1;
    min-height:340px;
    padding:2rem;
    border-radius:20px;
    border:3px solid rgba(198,241,53,0.22);
    box-shadow:0 0 80px rgba(0,0,0,0.75), inset 0 0 100px rgba(0,0,0,0.45);
    background-color:#0c2418;
    background-image:
      radial-gradient(ellipse 130% 55% at 50% -5%, rgba(65,199,122,0.22) 0%, transparent 52%),
      radial-gradient(ellipse 90% 70% at 50% 100%, rgba(0,0,0,0.35) 0%, transparent 45%),
      repeating-linear-gradient(92deg, rgba(0,0,0,0.04) 0 1px, transparent 1px 3px),
      repeating-linear-gradient(2deg, rgba(255,255,255,0.018) 0 1px, transparent 1px 4px),
      linear-gradient(168deg, #143a28 0%, #0d2619 42%, #071910 100%);
  }
  .felt::before{
    content:'';
    position:absolute;
    inset:10px;
    border:1px solid rgba(198,241,53,0.1);
    border-radius:14px;
    pointer-events:none;
    z-index:0;
  }
  /* Padded felt “rail” across the top of the table */
  .felt-dealer-rail{
    position:relative;
    z-index:1;
    flex-shrink:0;
    height:50px;
    margin-bottom:1.1rem;
    border-radius:12px;
    border:1px solid rgba(198,241,53,0.16);
    background-image:
      linear-gradient(180deg, rgba(255,255,255,0.07) 0%, transparent 42%),
      repeating-linear-gradient(88deg, rgba(0,0,0,0.06) 0 1px, transparent 1px 2px),
      linear-gradient(180deg, #1a4d34 0%, #0f3022 55%, #0a2418 100%);
    box-shadow:inset 0 -10px 22px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.05);
  }

  .dealer-area, .player-area{display:flex;flex-direction:column;align-items:center;gap:0.75rem;position:relative;z-index:1}
  .area-label{font-family:'Barlow Condensed',sans-serif;font-size:0.8rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(198,241,53,0.78)}
  .cards{display:flex;gap:0.75rem;flex-wrap:wrap;justify-content:center;min-height:100px;align-items:center}
  .hand-group{display:flex;flex-direction:column;align-items:center;gap:0.45rem;padding:0.75rem 0.9rem;border-radius:12px;border:1px solid rgba(198,241,53,0.1);background:rgba(0,0,0,0.14)}
  .hand-group.active{border-color:rgba(198,241,53,0.38);box-shadow:0 0 0 2px rgba(198,241,53,0.1)}
  .hand-label{font-size:0.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
  
  .card{width:70px;height:100px;border-radius:8px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.6rem;font-weight:900;box-shadow:0 4px 16px rgba(0,0,0,0.6);position:relative;cursor:default;animation:dealCard 0.3s ease both;flex-shrink:0}
  @keyframes dealCard{from{opacity:0;transform:translateY(-20px) scale(0.8)}to{opacity:1;transform:translateY(0) scale(1)}}
  .card.red{color:#d32f2f}
  .card.black{color:#1a1a1a}
  .card.back{background:linear-gradient(135deg,#1a3a6a,#0d2045);border:2px solid rgba(198,241,53,0.35)}
  .card-corner{position:absolute;top:4px;left:6px;font-size:0.8rem;font-weight:700;line-height:1}
  .card-corner.bot{top:auto;bottom:4px;left:auto;right:6px;transform:rotate(180deg)}
  .card-suit{font-size:1.8rem}

  .score-badge{background:rgba(0,0,0,0.5);border:1px solid var(--border);border-radius:4px;padding:2px 10px;font-family:'Barlow Condensed',sans-serif;font-size:0.9rem;font-weight:700;color:var(--gold)}

  .vs-divider{display:flex;align-items:center;gap:1rem;padding:0.5rem 0;position:relative;z-index:1}
  .vs-line{flex:1;height:1px;background:rgba(198,241,53,0.22)}
  .vs-text{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:rgba(198,241,53,0.45);letter-spacing:2px}

  .result-banner{position:absolute;inset:0;z-index:4;background:rgba(0,0,0,0.8);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.5rem;border-radius:16px;opacity:0;pointer-events:none;transition:opacity 0.3s}
  .result-banner.show{opacity:1;pointer-events:all}
  .result-text{font-family:'Bebas Neue',sans-serif;font-size:4rem;letter-spacing:4px}
  .result-text.win{color:var(--gold);text-shadow:0 0 36px rgba(198,241,53,0.55)}
  .result-text.lose{color:var(--red)}
  .result-text.push{color:var(--muted)}
  .result-sub{color:var(--muted);font-size:0.9rem;font-weight:600}

  .game-main{display:flex;gap:1.1rem;align-items:stretch;width:100%;flex:1;min-height:0}
  .controls{flex:0 0 280px;display:flex;flex-direction:column;align-items:stretch;gap:0.85rem}
  .table-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem}
  .bj-panel{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1rem;box-shadow:0 10px 26px rgba(0,0,0,0.22)}
  .bj-panel-title{font-size:0.68rem;font-weight:700;color:var(--muted);letter-spacing:1.6px;text-transform:uppercase;margin-bottom:0.7rem}
  .bet-input{width:100%;display:flex;flex-direction:column;gap:0.45rem;align-items:stretch;margin-bottom:0}
  .bet-input label{font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase}
  .bet-input input[type=number]{width:100%;padding:0.65rem 0.85rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;align-items:stretch}
  .wager-row #betInput{flex:1;width:auto;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
  }
  .action-row{display:flex;gap:0.6rem;flex-wrap:wrap;justify-content:center}
  .btn-action{padding:0.72rem 1.05rem;border-radius:999px;font-family:'Barlow Condensed',sans-serif;font-size:0.95rem;font-weight:900;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:none;transition:transform 0.15s,opacity 0.2s}
  .btn-action:disabled{opacity:0.3;cursor:not-allowed}
  .btn-deal{background:var(--gold);color:#0a0a0f}
  .btn-deal:not(:disabled):hover{transform:scale(1.05)}
  .btn-hit{background:#2d7a4a;color:#fff}
  .btn-hit:not(:disabled):hover{transform:scale(1.05)}
  .btn-stand{background:#7a2d2d;color:#fff}
  .btn-stand:not(:disabled):hover{transform:scale(1.05)}
  .btn-double{background:#1a3d7a;color:#fff}
  .btn-double:not(:disabled):hover{transform:scale(1.05)}
  .btn-split{background:#5a2d7a;color:#fff}
  .btn-split:not(:disabled):hover{transform:scale(1.05)}
  .btn-insure{background:#7a5c1a;color:#fff}
  .btn-insure:not(:disabled):hover{transform:scale(1.05)}
  .btn-surrender{background:#555;color:#fff}
  .btn-surrender:not(:disabled):hover{transform:scale(1.05)}

  .rules-strip{font-size:0.72rem;color:var(--muted);text-align:center;max-width:700px;line-height:1.45;margin:0.5rem 0 1.25rem}
  .rules-strip strong{color:var(--gold);font-weight:800}
  /* Play shell uses !important on .area-label — keep table chrome on-brand */
  body.with-play-shell .area-label{color:rgba(198,241,53,0.82)!important}
  body.with-play-shell .vs-line{background:rgba(198,241,53,0.24)!important}
  body.with-play-shell .vs-text{color:rgba(198,241,53,0.48)!important}
  .balance-pill .lotta-bal-main{display:block;font-size:0.88rem;line-height:1.2}
  .balance-pill .lotta-bal-fiat{display:block;font-size:0.72rem;color:var(--muted);font-weight:600;margin-top:0.12rem}
  @media(max-width:980px){
    .game-main{flex-direction:column}
    .controls{flex:0 0 auto;max-width:560px;width:100%;margin:0 auto}
  }
  @media(max-width:760px){
    .game-main{flex-direction:column}
    .game-wrap{padding:0.8rem 0.8rem 1.5rem;gap:0.75rem}
    .controls{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .table-col{flex:0 0 auto;width:100%}
    .felt{padding:1.25rem;min-height:340px}
    .card{width:58px;height:84px;font-size:1.35rem}
    .card-suit{font-size:1.5rem}
    .card-corner{font-size:0.7rem}
    .result-text{font-size:3rem}
    .action-row{gap:0.5rem}
    .btn-action{padding:0.65rem 1.25rem;font-size:0.9rem}
  }
  @media(max-width:480px){
    .game-wrap{padding:0.65rem 0.55rem 1.25rem;gap:0.6rem}
    .game-title{font-size:1.4rem}
    .rules-strip{font-size:0.68rem;margin:0.25rem 0 0.75rem}
    .felt{padding:1rem;min-height:300px;border-radius:14px}
    .card{width:48px;height:70px;font-size:1.1rem}
    .card-suit{font-size:1.25rem}
    .card-corner{font-size:0.62rem;top:3px;left:4px}
    .cards{gap:0.4rem;min-height:80px}
    .result-text{font-size:2.5rem;letter-spacing:2px}
    .result-sub{font-size:0.8rem}
    .action-row{gap:0.4rem}
    .btn-action{padding:0.55rem 0.85rem;font-size:0.82rem}
  }

/* === play/casebattle-create.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0a0b12;--panel:#121428;--line:rgba(255,255,255,0.09);--gold:#f5d96a;--gold2:#c6f135;--muted:#959ab7;--text:#f0f0f0}
  body{background:radial-gradient(800px 480px at 50% -100px,#1a1e3a 0%,transparent 55%),var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  /* Allow full page scroll with play-shell (sidebar) */
  body.with-play-shell{overflow-y:auto;height:auto;min-height:100vh}
  body.with-play-shell .page{flex:1 1 auto;height:auto!important;min-height:0!important;max-height:none!important;overflow:visible!important;padding-bottom:2.5rem}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.65rem 1rem;border-bottom:1px solid var(--line);background:rgba(18,20,40,0.95)}
  .exit{padding:0.4rem 0.85rem;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,0.04);color:var(--text);font-weight:800;font-size:0.78rem;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center}
  .cb-top{display:flex;align-items:center;justify-content:center;gap:0.5rem;padding:0.75rem 1rem;font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;border-bottom:1px solid var(--line);background:rgba(18,20,40,0.6)}
  .cb-top .mark{color:var(--gold2)}
  .page{flex:1;width:100%;padding:1rem 1.5rem 2rem}
  /* Two-column layout on wide screens: rules left, cases right */
  .page-cols{display:grid;grid-template-columns:360px 1fr;gap:1rem;align-items:start}
  @media(max-width:860px){.page-cols{grid-template-columns:1fr}}
  .page-cols .panel{margin-bottom:0}

  .rule-row{display:flex;flex-wrap:wrap;gap:0.5rem;align-items:center;margin-bottom:0.75rem}
  .rule-row label{font-size:0.72rem;color:var(--muted);font-weight:700}
  input[type=range]{font-family:'DM Sans',sans-serif}
  .toggle{display:inline-flex;align-items:center;gap:0.4rem;padding:0.45rem 0.65rem;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,0.03);cursor:pointer;font-size:0.78rem;font-weight:800}
  .toggle input{accent-color:var(--gold2)}
  .modes{display:flex;flex-wrap:wrap;gap:0.45rem;margin:0.75rem 0}
  .mode{padding:0.5rem 0.85rem;border-radius:12px;border:1px solid var(--line);background:transparent;color:var(--muted);font-weight:900;font-size:0.78rem;cursor:pointer;display:inline-flex;align-items:center;gap:0.35rem}
  .mode.on{border-color:rgba(245,217,106,0.55);color:var(--gold);background:rgba(245,217,106,0.1)}
  hr{border:none;border-top:1px dashed var(--line);margin:0.85rem 0}

  .panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:1rem;margin-bottom:1rem;box-shadow:0 10px 28px rgba(0,0,0,0.35)}
  .panel h3{font-size:0.68rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:0.65rem}
  .case-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0.65rem}
  .case-slot{min-height:160px;border-radius:14px;border:1px dashed var(--line);display:flex;align-items:center;justify-content:center;padding:0.5rem;background:rgba(0,0,0,0.15)}
  .case-slot.filled{border-style:solid;flex-direction:column;justify-content:flex-end;padding:0}
  .add-cases{width:100%;height:100%;min-height:140px;border:none;border-radius:12px;background:rgba(245,217,106,0.12);color:var(--gold);font-weight:900;cursor:pointer;font-size:0.85rem}
  .mini{font-size:0.72rem;color:var(--muted);margin-top:0.35rem;text-align:center}
  .case-slot.filled{position:relative}
  .slot-qty-badge{position:absolute;bottom:0.4rem;right:0.4rem;background:var(--gold2);color:#0a0b12;font-size:0.65rem;font-weight:900;border-radius:999px;padding:0.15rem 0.42rem;line-height:1.3;pointer-events:none;z-index:2;box-shadow:0 1px 4px rgba(0,0,0,0.5)}
  .btn-create{width:100%;padding:0.85rem;border:none;border-radius:999px;background:linear-gradient(180deg,#f1cf65,#c6a443);color:#1d1a12;font-weight:900;font-size:0.9rem;cursor:pointer}
  .btn-create:disabled{opacity:0.45;cursor:not-allowed}
  .err{color:#f26c6c;font-size:0.82rem;margin-top:0.5rem}

  .add-cases-overlay{position:fixed;inset:0;z-index:10050;background:rgba(6,8,18,0.94);backdrop-filter:blur(10px);display:none;align-items:stretch;justify-content:center;padding:0.75rem;box-sizing:border-box}
  .add-cases-overlay.open{display:flex}
  .add-cases-panel{flex:1;max-width:min(1040px,100%);display:flex;flex-direction:column;background:linear-gradient(180deg,#1e1a32 0%,#14122a 100%);border:1px solid rgba(255,255,255,0.1);border-radius:18px;box-shadow:0 24px 60px rgba(0,0,0,0.55);overflow:hidden}
  .add-cases-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:0.75rem;padding:1rem 1.1rem;border-bottom:1px solid var(--line);background:rgba(0,0,0,0.2)}
  .add-cases-title-wrap{display:flex;align-items:center;gap:0.5rem;font-family:'Syne',sans-serif;font-weight:800;font-size:1.15rem;letter-spacing:0.5px;text-transform:uppercase}
  .add-cases-title-wrap .mark{font-size:1.35rem;line-height:1}
  .add-cases-title-wrap h2{margin:0;font-size:inherit;background:linear-gradient(90deg,transparent 0%,transparent 28%,rgba(245,217,106,0.35) 28%,rgba(245,217,106,0.35) 42%,transparent 42%);padding-bottom:2px}
  .add-cases-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:0.5rem}
  .add-cases-toolbar select{min-width:140px}

  /* ── Unified select styling ───────────────────────────── */
  select{
    appearance:none;-webkit-appearance:none;
    font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:700;
    color:var(--text);
    background:rgba(255,255,255,0.04)
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23959ab7' d='M6 8L1 3h10z'/%3E%3C/svg%3E")
      no-repeat right 0.7rem center;
    border:1px solid rgba(255,255,255,0.12);
    border-radius:12px;
    padding:0.52rem 2.1rem 0.52rem 0.85rem;
    cursor:pointer;
    transition:border-color 0.15s,box-shadow 0.15s,background-color 0.15s;
    outline:none;
  }
  select:hover{
    border-color:rgba(255,255,255,0.22);
    background-color:rgba(255,255,255,0.07);
  }
  select:focus{
    border-color:rgba(198,241,53,0.5);
    box-shadow:0 0 0 3px rgba(198,241,53,0.1);
    background-color:rgba(198,241,53,0.04);
  }
  select option{
    background:#1a1830;
    color:var(--text);
  }
  /* Teams select in rule-row — slightly wider feel */
  .rule-row select{min-width:160px}
  .add-cases-search{flex:1;min-width:160px;max-width:280px;padding:0.52rem 0.85rem 0.52rem 2.35rem;border-radius:12px;border:1px solid rgba(255,255,255,0.1);background:rgba(0,0,0,0.35) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%238b8fa8' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 10-1.397 1.398h-.001l3.85 3.85a1 1 0 001.415-1.414l-3.85-3.85zm-5.242.656a5 5 0 110-10 5 5 0 010 10z'/%3E%3C/svg%3E") no-repeat 0.65rem 50%;color:var(--text);font-family:'DM Sans',sans-serif;font-size:0.88rem}
  .add-cases-search::placeholder{color:#6b7088}
  .add-cases-search:focus{outline:none;border-color:rgba(198,241,53,0.45);box-shadow:0 0 0 3px rgba(198,241,53,0.1)}
  .add-cases-grid{flex:1;overflow:auto;padding:1rem;display:grid;grid-template-columns:repeat(4,1fr);gap:0.75rem}
  @media (max-width:900px){.add-cases-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:480px){.add-cases-grid{grid-template-columns:1fr}}
  .picker-card{border-radius:14px;border:1px solid rgba(255,255,255,0.08);background:rgba(40,36,68,0.55);padding:0.5rem;display:flex;flex-direction:column;align-items:center;transition:border-color 0.15s,box-shadow 0.15s}
  .picker-card.picked{border-color:rgba(198,241,53,0.45);box-shadow:0 0 0 1px rgba(198,241,53,0.2)}
  .picker-card-art{width:100%;aspect-ratio:1;max-height:120px;border-radius:12px;background-size:cover;background-position:center}
  .picker-card-name{font-size:0.72rem;font-weight:800;text-transform:uppercase;text-align:center;margin:0.45rem 0 0.35rem;line-height:1.25;min-height:2.2em;display:flex;align-items:center;justify-content:center}
  .picker-card-add{width:100%;border:none;border-radius:999px;padding:0.45rem 0.5rem;font-size:0.78rem;font-weight:800;cursor:pointer;background:linear-gradient(180deg,#4a4428,#2e2a18);color:#f0e6c8;border:1px solid rgba(245,217,106,0.25);display:inline-flex;align-items:center;justify-content:center;gap:0.25rem}
  .picker-card-add:hover{filter:brightness(1.08)}
  .picker-card-add:disabled{opacity:0.45;cursor:not-allowed;filter:none}
  .picker-card-count{font-size:0.68rem;font-weight:800;color:var(--gold2);margin-top:0.25rem}
  .add-cases-foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:0.75rem;padding:0.85rem 1.1rem;border-top:1px solid var(--line);background:rgba(0,0,0,0.35)}
  .add-cases-summary{font-size:0.88rem;font-weight:700;display:flex;align-items:center;gap:0.35rem}
  .add-cases-actions{display:flex;gap:0.5rem}
  .btn-picker-cancel{padding:0.65rem 1.4rem;border-radius:12px;border:none;font-weight:800;font-size:0.82rem;cursor:pointer;background:#6b3d38;color:#fde8e6}
  .btn-picker-cancel:hover{filter:brightness(1.06)}
  .btn-picker-confirm{padding:0.65rem 1.5rem;border-radius:12px;border:none;font-weight:800;font-size:0.82rem;cursor:pointer;background:#3a3848;color:#c9c9d4}
  .btn-picker-confirm:not(:disabled){background:linear-gradient(180deg,#5c5a6e,#3d3b4d);color:#f0f0f0;border:1px solid rgba(255,255,255,0.12)}
  .btn-picker-confirm:not(:disabled):hover{filter:brightness(1.08)}
  .btn-picker-confirm:disabled{opacity:0.45;cursor:not-allowed}

/* === play/casebattle-room.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --br-bg:#0a0b12;--br-panel:#1e1b2e;--br-line:rgba(255,255,255,0.09);--br-gold:#f5d96a;--br-gold2:#c6f135;
    --br-muted:#959ab7;--br-text:#f0f0f0;
  }
  body{background:radial-gradient(900px 500px at 50% -120px,#1a1e3a 0%,transparent 55%),var(--br-bg);color:var(--br-text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  body.with-play-shell{overflow-y:auto;height:auto;min-height:100vh}
  .br-top{display:flex;align-items:center;justify-content:space-between;gap:0.75rem;flex-wrap:wrap;padding:0.65rem 1rem;border-bottom:1px solid var(--br-line);background:rgba(18,20,40,0.95);backdrop-filter:blur(8px);overflow:visible}
  .br-back{padding:0.45rem 0.9rem;border-radius:12px;border:1px solid var(--br-line);background:rgba(255,255,255,0.04);color:var(--br-text);font-weight:800;font-size:0.75rem;cursor:pointer;text-decoration:none;text-transform:uppercase;letter-spacing:0.04em}
  .br-back:hover{border-color:rgba(245,217,106,0.35);color:var(--br-gold)}
  .br-mode{display:flex;align-items:center;gap:0.35rem;font-family:'Syne',sans-serif;font-weight:800;font-size:0.68rem;letter-spacing:0.02em;color:var(--br-gold2);line-height:1.2;max-width:min(42vw,300px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .br-center{display:flex;align-items:center;gap:0.65rem;flex:1;justify-content:center;min-width:200px;flex-wrap:wrap}
  .br-case-mini{width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,0.12);flex-shrink:0;background-size:cover;background-position:center}
  .br-case-mini--current{box-shadow:0 0 0 2px rgba(198,241,53,0.55);border-color:rgba(198,241,53,0.45)}
  .br-case-mini--empty{opacity:0.25;background:rgba(255,255,255,0.06)!important;border-style:dashed}
  .br-coin{display:inline-flex;align-items:center;justify-content:center;font-size:1.05em;line-height:1;flex-shrink:0;padding:2px 0;transform:translateY(0.5px)}
  .br-pill{display:flex;align-items:center;gap:0.35rem;font-size:0.72rem;font-weight:800;color:var(--br-muted);text-transform:uppercase;letter-spacing:0.06em;line-height:1.25;overflow:visible}
  .br-pill strong{display:inline-flex;align-items:center;gap:0.28rem;color:var(--br-gold2);font-size:0.85rem;font-weight:800;line-height:1.25}
  .br-tools{display:flex;align-items:center;gap:0.45rem}
  .br-tool-btn{padding:0.4rem 0.65rem;border-radius:10px;border:1px solid var(--br-line);background:rgba(255,255,255,0.04);color:var(--br-text);font-size:0.72rem;font-weight:800;cursor:pointer}
  .br-tool-btn:hover{border-color:rgba(245,217,106,0.35)}

  .br-main{flex:1;padding:0.75rem 1rem 1.25rem;width:100%;max-width:1280px;margin:0 auto;min-height:0}
  .br-battle-head{max-width:920px;margin:0 auto 0.55rem;text-align:center}
  .br-battle-pot{font-family:'Syne',sans-serif;font-weight:800;font-size:2rem;color:var(--br-gold);letter-spacing:0.01em}
  .br-battle-sub{margin-top:0.2rem;font-size:0.8rem;color:var(--br-muted);font-weight:800;text-transform:uppercase;letter-spacing:0.06em}
  .br-battle-case-line{margin-top:0.4rem;font-size:1rem;font-weight:800;color:var(--br-gold2);min-height:1.35em}
  .br-battle-chips-wrap{margin:0.55rem auto 0;max-width:360px;overflow:hidden;border-radius:12px;border:1px solid var(--br-line);background:rgba(0,0,0,0.24);padding:0.35rem}
  .br-battle-chips-track{display:flex;align-items:center;gap:0.35rem;will-change:transform;transition:transform 420ms cubic-bezier(0.2,0.75,0.2,1)}
  .br-battle-chips-track .br-case-mini{width:34px;height:34px}
  .br-cols-shell{display:flex;flex-direction:column;min-height:min(65vh,680px);border:1px solid var(--br-line);border-radius:16px;overflow:hidden;background:rgba(20,18,38,0.65)}
  .br-cols{display:grid;gap:0;flex:0 0 auto;min-height:0}
  .br-cols-upper{min-height:min(38vh,420px)}
  .br-col{display:flex;flex-direction:column;border-left:1px solid var(--br-line);min-width:0;min-height:0}
  .br-col:first-child{border-left:none}
  .br-anim{flex:1;min-height:220px;background:linear-gradient(180deg,rgba(30,27,46,0.9),rgba(12,10,22,0.95));display:flex;align-items:stretch;justify-content:center;position:relative;padding:0.5rem}
  .br-anim-inner{width:100%;max-width:220px;min-height:200px;border-radius:14px;border:1px dashed rgba(255,255,255,0.12);background:rgba(0,0,0,0.35);display:flex;flex-direction:column;align-items:stretch;overflow:hidden}
  .br-anim-inner--reel{border:1px solid rgba(198,241,53,0.18);background:linear-gradient(180deg,#1a1830 0%,#0f0e1a 100%);padding:0.35rem 0.3rem 0.45rem}
  .br-reel-meta{font-size:0.58rem;font-weight:800;color:var(--br-muted);text-transform:uppercase;letter-spacing:0.06em;text-align:center;margin-bottom:0.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .br-reel-viewport{position:relative;flex:1;min-height:156px;max-height:168px;overflow:hidden;border-radius:10px;border:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.45)}
  .br-reel-viewport::before,.br-reel-viewport::after{content:'';position:absolute;left:0;right:0;height:28px;z-index:2;pointer-events:none}
  .br-reel-viewport::before{top:0;background:linear-gradient(180deg,rgba(12,10,22,0.97),transparent)}
  .br-reel-viewport::after{bottom:0;background:linear-gradient(0deg,rgba(12,10,22,0.97),transparent)}
  .br-reel-pointer{position:absolute;left:6px;right:6px;top:50%;height:2px;margin-top:-1px;transform:translateZ(0);background:linear-gradient(90deg,transparent,rgba(198,241,53,0.95),transparent);z-index:3;opacity:0.95;box-shadow:0 0 12px rgba(198,241,53,0.35)}
  .br-reel-track{will-change:transform;transform:translate3d(0,0,0);backface-visibility:hidden}
  .br-reel-item{
    display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
    padding:0.28rem 0.35rem;border-bottom:none;position:relative;
    color:#e8e9f4;font-size:0.62rem;font-weight:700;line-height:1.15;
  }
  .br-reel-item::after{
    content:'';position:absolute;left:10%;right:10%;bottom:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);
    opacity:0.7;
  }
  .br-reel-item:last-child::after{display:none}
  .br-reel-item[data-win="1"]{background:rgba(198,241,53,0.08);border-bottom-color:rgba(198,241,53,0.2)}
  .br-reel-ico{font-size:1.1rem;line-height:1;min-height:1.2rem;display:flex;align-items:center;justify-content:center}
  .br-reel-ico-img{width:20px;height:20px;object-fit:contain;display:block}
  .br-reel-nm{margin-top:0.12rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:0.58rem}
  .br-reel-v{font-size:0.55rem;color:var(--br-gold2);font-weight:800;margin-top:0.08rem}
  .br-reel-eos-foot{font-size:0.52rem;font-weight:600;color:var(--br-muted);font-family:ui-monospace,monospace;text-align:center;margin-top:0.35rem;overflow:hidden;text-overflow:ellipsis}
  .br-reel-stage{width:100%;padding:0.45rem 0.35rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.35rem;text-align:center;min-height:160px}
  .br-reel-val{font-size:0.72rem;font-weight:800;color:var(--br-gold)}
  .br-reel-payout{margin-top:0.2rem;font-size:0.76rem;font-weight:900;color:var(--br-gold2);letter-spacing:0.02em;line-height:1.2}
  .br-reel-stage.is-locked{border:1px solid rgba(255,255,255,0.1);border-radius:12px;background:rgba(0,0,0,0.25)}
  .br-reel-idle{opacity:0.45;font-size:1.25rem}
  .br-anim .spin{font-size:2rem;opacity:0.35}
  .br-bar{padding:0.55rem 0.65rem;border-top:1px solid var(--br-line);background:rgba(0,0,0,0.25)}
  .br-bar-final{display:flex;flex-direction:column;gap:0.35rem}
  .br-net-pill{
    align-self:flex-start;padding:0.18rem 0.48rem;border-radius:999px;border:1px solid var(--br-line);
    font-size:0.64rem;font-weight:900;letter-spacing:0.03em;background:rgba(255,255,255,0.04)
  }
  .br-net-pill.pos{color:var(--br-gold2);border-color:rgba(198,241,53,0.45);background:rgba(198,241,53,0.08)}
  .br-net-pill.neg{color:#f6a8a6;border-color:rgba(226,75,74,0.45);background:rgba(226,75,74,0.1)}
  .br-net-pill.neu{color:var(--br-muted)}
  .br-player{display:flex;align-items:center;gap:0.45rem}
  .br-av{width:40px;height:40px;border-radius:12px;background:linear-gradient(145deg,#4a3f7a,#2a2548);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:1rem;color:var(--br-gold2)}
  .br-meta{flex:1;min-width:0}
  .br-name{font-weight:800;font-size:0.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:0.25rem}
  .br-player-stats{margin-top:0.1rem;font-size:0.66rem;color:var(--br-muted);font-weight:800;letter-spacing:0.01em}
  .br-bot{font-size:0.85rem;opacity:0.85}
  .br-join-wrap{display:flex;align-items:stretch;gap:0.35rem}
  .br-join{flex:1;display:flex;align-items:center;justify-content:center;gap:0.35rem;padding:0.55rem 0.5rem;border-radius:12px;border:1px solid rgba(245,217,106,0.35);background:rgba(245,217,106,0.1);color:var(--br-gold);font-weight:900;font-size:0.72rem;cursor:pointer;font-family:'DM Sans',sans-serif}
  .br-join:hover{filter:brightness(1.08)}
  .br-join:disabled{opacity:0.45;cursor:not-allowed}
  .br-bot-call{width:40px;min-width:40px;border-radius:10px;border:1px solid var(--br-line);background:rgba(255,255,255,0.06);cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}
  .br-bot-call:hover{border-color:rgba(245,217,106,0.4)}
  .br-bot-call:disabled{opacity:0.35;cursor:not-allowed}
  .br-pulls-scroll{flex:1 1 auto;min-height:120px;max-height:min(52vh,520px);overflow-y:auto;overflow-x:hidden;border-top:1px solid var(--br-line);background:rgba(0,0,0,0.18);scrollbar-width:thin;scrollbar-color:rgba(198,241,53,0.35) rgba(0,0,0,0.2)}
  .br-pulls-scroll::-webkit-scrollbar{width:6px}
  .br-pulls-scroll::-webkit-scrollbar-thumb{background:rgba(198,241,53,0.28);border-radius:6px}
  .br-pulls-row{display:grid;gap:0;align-items:start}
  .br-pulls-row .br-grid{border-left:1px solid var(--br-line)}
  .br-pulls-row .br-grid:first-child{border-left:none}
  .br-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.42rem;padding:0.58rem}
  .br-cell{
    aspect-ratio:1;border-radius:12px;border:1px solid rgba(255,255,255,0.12);
    background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.02));
    display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem;color:var(--br-muted);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.04), 0 6px 18px rgba(0,0,0,0.18);
  }
  .br-cell.reveal{
    font-size:0.62rem;font-weight:700;color:var(--br-text);text-align:center;padding:0.34rem 0.3rem;
    line-height:1.2;flex-direction:column;gap:0.24rem;justify-content:center;
  }
  .br-cell-name{
    font-size:0.74rem;font-weight:800;line-height:1.16;max-width:100%;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  }
  .br-cell-val{
    font-size:0.8rem;font-weight:900;color:var(--br-gold2);letter-spacing:0.01em;
  }
  @keyframes br-pulse{from{opacity:0.88}to{opacity:1}}
  .br-cell.won{border-color:rgba(198,241,53,0.55);box-shadow:0 0 0 1px rgba(198,241,53,0.15)}
  .br-status{font-size:0.78rem;color:var(--br-muted);text-align:center;padding:0.5rem}
  .br-toast{text-align:center;font-size:0.82rem;color:var(--br-muted);margin:0.35rem 0;min-height:1.25em}
  .br-fail{background:rgba(226,75,74,0.12);border:1px solid rgba(226,75,74,0.35);color:#f5a8a7;padding:0.65rem;border-radius:12px;margin:0.5rem 0;font-size:0.85rem}

  .br-modal{position:fixed;inset:0;background:rgba(0,0,0,0.72);display:none;align-items:center;justify-content:center;padding:1rem;z-index:10020}
  .br-modal.show{display:flex}
  .br-modal-inner{max-width:520px;width:100%;background:#121428;border:1px solid var(--br-line);border-radius:16px;padding:1.1rem;max-height:85vh;overflow:auto}
  .br-modal-inner h3{font-family:'Syne',sans-serif;margin-bottom:0.5rem}
  .br-modal-inner pre{font-size:0.68rem;color:var(--br-muted);white-space:pre-wrap;word-break:break-word}

  .br-jackpot-stage{width:100%;max-width:1280px;margin:0 auto;padding:0.35rem 1rem 1rem;display:none}
  .br-jackpot-stage.is-on{display:block}
  .br-jp-head{text-align:center;font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;color:var(--br-gold2);margin-bottom:0.45rem;letter-spacing:0.02em}
  .br-jp-viewport{position:relative;height:132px;overflow:hidden;border-radius:16px;border:1px solid rgba(198,241,53,0.22);background:rgba(0,0,0,0.55)}
  .br-jp-viewport::before,.br-jp-viewport::after{content:'';position:absolute;top:0;bottom:0;width:48px;z-index:2;pointer-events:none}
  .br-jp-viewport::before{left:0;background:linear-gradient(90deg,rgba(12,10,22,0.98),transparent)}
  .br-jp-viewport::after{right:0;background:linear-gradient(270deg,rgba(12,10,22,0.98),transparent)}
  .br-jp-pointer{position:absolute;left:50%;top:6px;bottom:6px;width:3px;margin-left:-1.5px;transform:translateZ(0);background:linear-gradient(180deg,transparent,rgba(198,241,53,0.95),transparent);z-index:3;box-shadow:0 0 14px rgba(198,241,53,0.4)}
  .br-jp-track{display:flex;flex-direction:row;height:100%;align-items:stretch;will-change:transform;transform:translate3d(0,0,0);backface-visibility:hidden}
  .br-jp-item{flex:0 0 92px;width:92px;min-width:92px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid rgba(255,255,255,0.07);padding:0.3rem;background:rgba(255,255,255,0.03)}
  .br-jp-item[data-win="1"]{background:rgba(198,241,53,0.11);border-right-color:rgba(198,241,53,0.2)}
  .br-jp-av{width:58px;height:58px;border-radius:16px;background:linear-gradient(145deg,#4a3f7a,#2a2548);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:1.4rem;color:var(--br-gold2);flex-shrink:0}
  .br-jp-nm{font-size:0.58rem;font-weight:700;margin-top:0.22rem;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--br-text)}
  .br-jp-bot{font-size:0.55rem;color:var(--br-muted);margin-top:0.08rem}
  .br-jp-eos{margin-top:0.45rem;font-size:0.62rem;color:var(--br-muted);text-align:center;font-family:ui-monospace,monospace}

  @media(max-width:900px){
    .br-cols-shell{overflow-x:auto;-webkit-overflow-scrolling:touch;overflow-y:hidden}
    .br-cols-upper,.br-pulls-row{width:max(100%, calc(var(--br-min-slot, 160px) * var(--br-slots, 6)))}
  }

  /* ── Rematch banner ─────────────────────────────────────── */
  .br-rematch{
    max-width:920px;margin:1.1rem auto 0.5rem;
    border:1px solid rgba(198,241,53,0.28);border-radius:18px;
    background:linear-gradient(135deg,rgba(198,241,53,0.07) 0%,rgba(30,27,46,0.85) 100%);
    padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
    animation:br-rematch-in 0.45s cubic-bezier(0.2,0.8,0.3,1) both;
  }
  @keyframes br-rematch-in{
    from{opacity:0;transform:translateY(14px)}
    to{opacity:1;transform:translateY(0)}
  }
  .br-rematch-icon{font-size:2rem;line-height:1;flex-shrink:0}
  .br-rematch-body{flex:1;min-width:180px}
  .br-rematch-title{font-family:'Syne',sans-serif;font-weight:800;font-size:0.95rem;color:var(--br-gold2);letter-spacing:0.02em}
  .br-rematch-sub{margin-top:0.2rem;font-size:0.72rem;color:var(--br-muted);font-weight:700;line-height:1.4}
  .br-rematch-actions{display:flex;gap:0.55rem;flex-wrap:wrap;align-items:center}
  .br-rematch-btn{
    display:inline-flex;align-items:center;gap:0.35rem;
    padding:0.55rem 1.1rem;border-radius:12px;font-weight:900;font-size:0.8rem;font-family:'DM Sans',sans-serif;
    cursor:pointer;text-decoration:none;letter-spacing:0.02em;border:none;
    background:linear-gradient(135deg,#c6f135,#a8d422);color:#0a0b12;
    box-shadow:0 4px 14px rgba(198,241,53,0.25);transition:filter 0.15s,transform 0.12s;
  }
  .br-rematch-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
  .br-rematch-btn:active{transform:translateY(0);filter:brightness(0.97)}
  .br-rematch-dismiss{
    padding:0.5rem 0.75rem;border-radius:10px;border:1px solid var(--br-line);
    background:transparent;color:var(--br-muted);font-size:0.75rem;font-weight:700;
    cursor:pointer;font-family:'DM Sans',sans-serif;transition:border-color 0.15s,color 0.15s;
  }
  .br-rematch-dismiss:hover{border-color:rgba(255,255,255,0.25);color:var(--br-text)}

/* === play/casebattle.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --cb-bg:#0a0b12;--cb-panel:#121428;--cb-line:rgba(255,255,255,0.09);--cb-gold:#f5d96a;--cb-gold2:#c6f135;
    --cb-muted:#959ab7;--cb-text:#f0f0f0;
  }
  body{background:radial-gradient(900px 500px at 50% -120px,#1a1e3a 0%,transparent 55%),var(--cb-bg);color:var(--cb-text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  body.with-play-shell{overflow-y:auto;height:auto;min-height:100vh}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.4rem 1rem;font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;color:var(--gold)}

  .cb-page{flex:1;width:100%;padding:1rem 1.5rem 1.25rem}
  .cb-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}
  .cb-title{display:flex;align-items:center;gap:0.5rem;font-family:'Syne',sans-serif;font-weight:800;font-size:1.45rem;letter-spacing:-0.3px}
  .cb-title .ico{font-size:1.35rem}
  .cb-filters{display:inline-flex;align-items:center;gap:0.4rem}
  .cb-filter{border:1px solid var(--cb-line);background:rgba(255,255,255,0.03);color:var(--cb-muted);padding:0.38rem 0.85rem;border-radius:999px;font-size:0.72rem;font-weight:800;cursor:pointer;letter-spacing:0.06em}
  .cb-filter.on{border-color:rgba(245,217,106,0.55);color:var(--cb-gold);background:rgba(245,217,106,0.08)}
  .cb-create{display:inline-flex;align-items:center;gap:0.45rem;padding:0.45rem 1rem;border-radius:999px;border:1px solid rgba(245,217,106,0.55);background:rgba(245,217,106,0.1);color:var(--cb-gold);font-weight:900;font-size:0.78rem;text-decoration:none;letter-spacing:0.04em}
  .cb-create:hover{background:rgba(245,217,106,0.16)}

  .cb-list{display:flex;flex-direction:column;gap:0.65rem}
  .cb-row{
    display:grid;grid-template-columns:minmax(120px,150px) 1fr minmax(140px,1.2fr) auto;
    align-items:center;gap:0.75rem;padding:0.75rem 0.9rem;border-radius:14px;
    background:linear-gradient(180deg,#1a1c33 0%,#121428 100%);border:1px solid var(--cb-line);
    box-shadow:0 8px 28px rgba(0,0,0,0.35);
  }
  @media(max-width:860px){
    .cb-row{grid-template-columns:1fr;justify-items:stretch}
  }
  .cb-price{display:flex;flex-direction:column;gap:0.15rem}
  .cb-price .amt{font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;color:var(--cb-gold);display:flex;align-items:center;gap:0.35rem}
  .cb-mode{font-size:0.62rem;font-weight:800;color:var(--cb-muted);letter-spacing:0.06em;line-height:1.35;max-width:220px}
  .cb-teams{display:flex;align-items:center;justify-content:center;gap:0.35rem;flex-wrap:wrap}
  .cb-slot{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,0.12);background:rgba(0,0,0,0.25);display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:900;color:var(--cb-muted)}
  .cb-slot.filled{background:rgba(245,217,106,0.12);border-color:rgba(245,217,106,0.25);color:var(--cb-text)}
  .cb-vs{font-size:0.62rem;font-weight:900;color:var(--cb-gold);opacity:0.85;padding:0 0.15rem}
  .cb-cases{display:flex;align-items:center;gap:0.35rem;flex-wrap:wrap;justify-content:flex-end}
  .cb-case{width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,0.12);flex-shrink:0}
  .cb-more{font-size:0.65rem;font-weight:800;color:var(--cb-muted);padding:0.2rem 0.45rem;border-radius:999px;border:1px solid var(--cb-line)}
  .cb-eye{width:40px;height:40px;border-radius:10px;border:1px solid var(--cb-line);background:rgba(255,255,255,0.04);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem}
  .cb-eye:hover{border-color:rgba(245,217,106,0.4)}
  .cb-actions{display:flex;align-items:center;gap:0.45rem;justify-content:flex-end;flex-wrap:wrap}
  .cb-mini{padding:0.35rem 0.65rem;border-radius:10px;border:1px solid var(--cb-line);background:rgba(255,255,255,0.04);color:var(--cb-text);font-size:0.72rem;font-weight:800;cursor:pointer}
  .cb-mini:hover{border-color:rgba(245,217,106,0.35)}
  .cb-empty{text-align:center;color:var(--cb-muted);padding:2rem 1rem;font-size:0.9rem}
  .cb-toast{font-size:0.78rem;color:var(--cb-muted);margin-bottom:0.75rem}

/* === play/cases.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --bg:#090b12;--bg2:#121428;--bg3:#1a1d33;--bg4:#212446;
    --gold:#c6f135;--gold2:#f5d96a;--text:#f0f0f0;--muted:#959ab7;
    --line:rgba(255,255,255,0.09);--green:#3ecf8e;--danger:#f26c6c;
  }
  body{min-height:100vh;background:radial-gradient(1200px 600px at 50% -200px,#1a1e3a 0%,transparent 65%),var(--bg);color:var(--text);font-family:'DM Sans',sans-serif}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.4rem 1rem;font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;color:var(--gold)} 
  .page{width:100%;padding:1rem 1.5rem 1.25rem}
  .head{text-align:center;margin-bottom:1rem}
  .head h1{font-family:'Syne',sans-serif;font-size:2rem;letter-spacing:-0.2px}
  .head p{color:var(--muted);font-size:.8rem;margin-top:.3rem}

  .view{display:none}
  .view.active{display:block}

  .cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.95rem}
  .case-card{
    background:linear-gradient(180deg,#26284a 0%,#1a1c33 55%,#14172a 100%);
    border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;
    transition:transform .14s,border-color .14s,box-shadow .14s;
  }
  .case-card:hover{transform:translateY(-3px);border-color:rgba(198,241,53,.45);box-shadow:0 12px 34px rgba(0,0,0,.35)}
  .card-art{
    height:170px;display:flex;align-items:center;justify-content:center;position:relative;
    background:radial-gradient(420px 170px at 50% 0%,rgba(255,255,255,.08) 0%,transparent 65%);
  }
  .card-art img{width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(0,0,0,.45))}
  .new-pill{position:absolute;top:.55rem;right:.55rem;background:#f1cf65;color:#3b3420;border-radius:6px;padding:0 .42rem;font-size:.66rem;font-weight:800}
  .card-body{padding:.78rem .85rem .9rem}
  .case-title{font-family:'Syne',sans-serif;font-size:1rem}
  .case-cost{margin-top:.35rem;color:var(--gold2);font-weight:800;font-size:.88rem}
  .card-open{margin-top:.65rem;width:100%;padding:.6rem;border-radius:9px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);color:#edf0ff;font-weight:700;cursor:pointer}
  .card-open:hover{border-color:rgba(198,241,53,.45);color:var(--gold)}

  .detail-head{
    display:flex;align-items:center;justify-content:space-between;gap:.6rem;
    margin-bottom:.75rem;padding:.65rem .75rem;border:1px solid var(--line);border-radius:12px;
    background:linear-gradient(180deg,rgba(26,28,51,0.96),rgba(18,20,40,0.96));
    box-shadow:0 10px 28px rgba(0,0,0,.28)
  }
  .detail-left{display:flex;align-items:center;gap:.6rem}
  .detail-left img{width:42px;height:42px;object-fit:contain}
  .detail-name{font-family:'Syne',sans-serif;font-size:1.08rem}
  .btn-mini{padding:.45rem .65rem;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);font-weight:700;cursor:pointer}

  .reel-wrap{
    border:1px solid rgba(198,241,53,.22);border-radius:14px;background:linear-gradient(180deg,#1a1830 0%,#0f0e1a 100%);
    padding:.6rem;overflow:hidden;position:relative;min-height:118px;
    box-shadow:0 12px 30px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.04);
  }
  .reel-wrap::before,.reel-wrap::after{
    content:'';position:absolute;top:0;bottom:0;width:42px;z-index:2;pointer-events:none
  }
  .reel-wrap::before{left:0;background:linear-gradient(90deg,rgba(12,10,22,.98) 0%,transparent 100%)}
  .reel-wrap::after{right:0;background:linear-gradient(270deg,rgba(12,10,22,.98) 0%,transparent 100%)}
  .reel-pointer{
    position:absolute;top:8px;bottom:8px;left:50%;transform:translateX(-50%);width:2px;
    background:linear-gradient(180deg,transparent,#d9ff6d 25%,#d9ff6d 75%,transparent);z-index:3;opacity:.95;
    box-shadow:0 0 14px rgba(198,241,53,.4)
  }
  .reel-wrap.vertical{min-height:290px}
  .reel-wrap.vertical .reel-pointer{
    left:8px;right:8px;top:50%;bottom:auto;height:2px;width:auto;transform:translateY(-50%);
    background:linear-gradient(90deg,transparent,#d9ff6d 25%,#d9ff6d 75%,transparent);
  }
  .reel-track{display:flex;gap:.45rem;will-change:transform;transform:translateX(0)}
  .reel-track.vertical{display:flex;flex-direction:column;gap:.55rem;align-items:center;transform:translateY(0)}
  .reel-item{
    width:140px;min-width:140px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);border-radius:12px;
    padding:.55rem .5rem;text-align:center;color:#d8dced;height:96px;display:flex;flex-direction:column;align-items:center;justify-content:center;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.04)
  }
  .reel-item .ico{font-size:1.25rem;line-height:1.2;min-height:1.35rem;display:flex;align-items:center;justify-content:center}
  .reel-item .ico-img,.chance .ico-img{width:26px;height:26px;object-fit:contain;display:block}
  .chance .ico{min-width:32px;display:flex;align-items:center;justify-content:center}
  .reel-item .nm{font-size:.68rem;margin-top:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
  .reel-item .val{font-size:.68rem;color:var(--gold2);font-weight:800;margin-top:.2rem;white-space:nowrap;width:100%}
  .reel-lanes{display:grid;grid-template-columns:1fr;gap:.5rem;margin-top:.7rem}
  .reel-lanes.multi{grid-template-columns:repeat(var(--case-columns,2),minmax(0,1fr));align-items:stretch}
  .lane-col{overflow:hidden;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(0,0,0,.16);height:248px;padding:.3rem;display:flex;align-items:flex-start;justify-content:center}
  .lane-col.single{height:auto;border:none;background:transparent;padding:0}

  .detail-controls{
    margin-top:.75rem;padding:.75rem;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.02);
    display:flex;flex-wrap:wrap;gap:.55rem;align-items:center
  }
  .detail-controls{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01))}
  .count-row{display:flex;gap:.35rem}
  .count-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);font-weight:800;cursor:pointer}
  .count-btn.on{border-color:rgba(245,217,106,.6);color:#f5d96a;background:rgba(245,217,106,.12)}
  .btn-open{padding:.68rem 1rem;border-radius:10px;border:none;background:linear-gradient(180deg,#f1cf65 0%,#c6a443 100%);color:#1d1a12;font-weight:900;cursor:pointer}
  .btn-demo{padding:.68rem 1rem;border-radius:10px;border:1px solid var(--line);background:#6b6797;color:#f2f1ff;font-weight:800;cursor:pointer}
  .btn-open:disabled,.btn-demo:disabled{opacity:.55;cursor:not-allowed}
  .status{
    margin-top:.55rem;font-size:.82rem;color:var(--muted);min-height:1.2rem;
    border:1px solid var(--line);border-radius:10px;padding:.55rem .65rem;background:rgba(0,0,0,.2)
  }

  .chances{margin-top:1rem}
  .chances h3{font-family:'Syne',sans-serif;font-size:1.08rem;margin-bottom:.55rem;color:var(--gold2)}
  .chance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.55rem}
  .chance{
    display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.45rem;
    background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
    border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.55rem .6rem
  }
  .chance .ico{font-size:1.1rem}
  .chance .nm{font-size:.79rem;color:#e5e8f7}
  .chance .pct{font-size:.73rem;color:var(--muted)}
  .chance .val{font-size:.77rem;color:var(--gold2);font-weight:800}

  .lobby-controls{
    display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;
    margin-bottom:1rem;
  }
  .search-wrap{
    flex:1;min-width:180px;position:relative;
  }
  .search-wrap svg{
    position:absolute;left:.7rem;top:50%;transform:translateY(-50%);
    opacity:.45;pointer-events:none;
  }
  #caseSearch{
    width:100%;padding:.58rem .75rem .58rem 2.15rem;
    border-radius:10px;border:1px solid var(--line);
    background:rgba(255,255,255,.04);color:var(--text);
    font-family:'DM Sans',sans-serif;font-size:.85rem;outline:none;
  }
  #caseSearch::placeholder{color:var(--muted)}
  #caseSearch:focus{border-color:rgba(198,241,53,.4);background:rgba(255,255,255,.06)}
  .sort-btn{
    display:flex;align-items:center;gap:.4rem;
    padding:.55rem .85rem;border-radius:10px;
    border:1px solid var(--line);background:rgba(255,255,255,.04);
    color:var(--muted);font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:700;
    cursor:pointer;white-space:nowrap;transition:border-color .13s,color .13s;
  }
  .sort-btn:hover{border-color:rgba(198,241,53,.35);color:var(--text)}
  .sort-arrow{display:inline-block;font-size:.9rem;line-height:1}
  .no-results{color:var(--muted);font-size:.88rem;padding:.5rem 0}

  @media(max-width:900px){
    .cards-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
    .reel-item{width:125px;min-width:125px;height:92px}
    .lane-col{height:230px}
  }
  @media(max-width:760px){
    .page{padding:0.8rem}
    .cards-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:0.75rem}
    .card-art{height:140px}
    .card-art img{width:95px;height:95px}
    .detail-head{flex-wrap:wrap;gap:0.5rem}
    .reel-item{width:115px;min-width:115px;height:88px}
    .lane-col{height:210px}
    .chance-grid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:480px){
    .page{padding:0.65rem 0.55rem}
    .cards-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0.6rem}
    .card-art{height:120px}
    .card-art img{width:80px;height:80px}
    .head h1{font-size:1.5rem}
    .reel-item{width:100px;min-width:100px;height:80px;padding:0.4rem 0.35rem}
    .reel-item .ico{font-size:1rem}
    .reel-item .nm,.reel-item .val{font-size:0.62rem}
    .lane-col{height:190px}
    .detail-controls{flex-direction:column;align-items:flex-start}
    .chance-grid{grid-template-columns:1fr}
    .reel-wrap.vertical{min-height:240px}
  }

/* === play/crash.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  html:has(#crashScene),body:has(#crashScene){overflow-x:hidden;max-width:100%}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;margin:0.5rem 0 1.25rem;line-height:1.45}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.8rem}
  .board-col{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .fx-panel{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column}
  .fx-panel > *{position:relative;z-index:1}
  .crash-scene{
    position:relative;
    z-index:1;
    flex:1;
    min-height:480px;
    overflow:hidden;
    padding:1.25rem 0 6.75rem;
    --cashout-spin-ms:2.8s;
    /* Shared with landing keyframes: moon disk geometry */
    --moon-top-pct:52%;
    --moon-w:min(200px,28%);
  }
  /* Wrapper owns position; inner SVG only rotates — avoids transform-chain interpolation “dips”. */
  .rocket-mount{
    position:absolute;
    z-index:2;
    left:10%;
    top:50%;
    transform:translateY(-50%);
    width:min(220px,32%);
    max-width:240px;
    pointer-events:none;
  }
  .rocket{
    display:block;
    width:100%;
    height:auto;
    transform-origin:50% 92%;
    filter:drop-shadow(0 12px 28px rgba(0,0,0,0.5)) drop-shadow(0 4px 8px rgba(198,241,53,0.08));
  }
  .rocket-body{
    fill:url(#rocketBodyGrad);
    stroke:rgba(0,0,0,0.22);
    stroke-width:1.1;
  }
  .rocket-window{
    fill:#0d1018;
    stroke:rgba(198,241,53,0.7);
    stroke-width:2;
  }
  .limbo-cockpit{fill:#1a2230}
  .limbo-pilot{fill:#050608}
  .limbo-eye{fill:#f0f2ea}
  .rocket-fin{fill:url(#finGrad)}
  .rocket-accent{fill:url(#accentGrad)}
  .rcs-pod{fill:url(#rcsPodGrad);stroke:rgba(0,0,0,0.35);stroke-width:0.45}
  .rcs-port{fill:#2a3344;stroke:rgba(255,255,255,0.18);stroke-width:0.35}
  .rcs-flame{opacity:0;pointer-events:none}
  .rcs-flame path:not(.rcs-flame-glow){fill:url(#rcsFlameGrad)}
  .rcs-flame path.rcs-flame-glow{fill:url(#rcsFlameGlowGrad);opacity:0.75}
  /*
    RCS: left jet for first ~26% of spin; right jet ~26–62% (counter-thrust); main engine from ~62%.
    Main engine hidden until cashout-brake — no dim plume over the hull during RCS.
  */
  .crash-scene.cashout:not(.cashout-brake):not(.cashout-rcs-dual) .rcs-flame.rcs-left{
    opacity:1;
    animation:rcsPlume 0.14s ease-in-out infinite alternate;
  }
  .crash-scene.cashout:not(.cashout-brake):not(.cashout-rcs-dual) .rcs-flame.rcs-right{opacity:0;animation:none}
  .crash-scene.cashout:not(.cashout-brake).cashout-rcs-dual .rcs-flame.rcs-left{opacity:0;animation:none}
  .crash-scene.cashout:not(.cashout-brake).cashout-rcs-dual .rcs-flame.rcs-right{
    opacity:1;
    animation:rcsPlume 0.14s ease-in-out infinite alternate;
  }
  .thruster{
    transform-origin:0 0;
    opacity:0;
    visibility:visible;
  }
  .thrust-glow{fill:url(#thrustGlowGrad);opacity:0.55;filter:url(#thrustSoftBlur)}
  .thrust-outer{fill:url(#thrustOuterGrad);opacity:0.88}
  .thrust-mid{fill:url(#thrustMidGrad);opacity:0.95}
  .thrust-core{fill:url(#thrustCoreGrad)}
  .thrust-lobe{fill:url(#thrustLobeGrad);opacity:0.82}
  .crash-scene.running .rocket{
    animation:rocketBob 1.35s ease-in-out infinite;
  }
  .crash-scene.running .thruster{
    opacity:1;
    animation:thrustFlicker 0.12s linear infinite;
  }
  .crash-scene.cashout:not(.cashout-brake) .thruster{opacity:0;animation:none;visibility:hidden}
  .crash-scene.cashout.cashout-brake .rcs-flame{opacity:0;animation:none}
  .crash-scene.cashout.cashout-brake .thruster{
    opacity:1;
    visibility:visible;
    animation:thrustBrake 0.09s ease-in-out infinite;
  }
  @keyframes rocketBob{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-12px)}
  }
  @keyframes thrustFlicker{
    0%{transform:scaleY(0.85);filter:blur(0px)}
    50%{transform:scaleY(1.1);filter:blur(0.2px)}
    100%{transform:scaleY(0.9);filter:blur(0px)}
  }
  @keyframes thrustBrake{
    0%,100%{transform:scaleY(1.18) scaleX(1.06);filter:brightness(1.08)}
    50%{transform:scaleY(1.35) scaleX(1.1);filter:brightness(1.18)}
  }
  @keyframes rcsPlume{
    0%{opacity:0.55;filter:brightness(0.9)}
    100%{opacity:1;filter:brightness(1.25)}
  }
  .moon{
    position:absolute;
    z-index:1;
    right:-40%;
    top:var(--moon-top-pct);
    width:var(--moon-w);
    aspect-ratio:1;
    border-radius:50%;
    background:
      radial-gradient(ellipse 95% 90% at 32% 28%, rgba(255,255,255,0.38) 0%, rgba(255,255,255,0.0) 42%),
      radial-gradient(circle at 22% 78%, rgba(45,48,58,0.55) 0%, rgba(45,48,58,0.0) 28%),
      radial-gradient(circle at 78% 42%, rgba(38,40,52,0.5) 0%, rgba(38,40,52,0.0) 22%),
      radial-gradient(circle at 55% 68%, rgba(52,54,64,0.45) 0%, rgba(52,54,64,0.0) 25%),
      radial-gradient(circle at 48% 50%, #c5cad6 0%, #8f96a8 38%, #5a6274 72%, #353b48 100%);
    border:1px solid rgba(255,255,255,0.12);
    box-shadow:
      0 3px 12px rgba(0,0,0,0.45),
      0 14px 32px rgba(0,0,0,0.3),
      0 0 24px rgba(100,120,150,0.08),
      inset 0 3px 14px rgba(255,255,255,0.18),
      inset 0 -12px 32px rgba(8,10,16,0.45);
    opacity:0;
    transform:translate3d(0,0,0);
  }
  .moon::before{
    content:'';
    position:absolute;
    inset:0;
    border-radius:50%;
    background:
      radial-gradient(ellipse 28% 22% at 28% 38%, rgba(30,32,42,0.5) 0%, transparent 72%),
      radial-gradient(ellipse 22% 18% at 72% 32%, rgba(28,30,40,0.45) 0%, transparent 70%),
      radial-gradient(ellipse 35% 30% at 48% 72%, rgba(25,27,36,0.42) 0%, transparent 68%),
      radial-gradient(circle at 62% 18%, rgba(22,24,32,0.35) 0%, transparent 45%),
      radial-gradient(circle at 18% 62%, rgba(24,26,34,0.38) 0%, transparent 40%);
    opacity:0.85;
    mix-blend-mode:multiply;
  }
  .moon::after{
    content:'';
    position:absolute;
    inset:0;
    border-radius:50%;
    background:
      radial-gradient(circle at 78% 22%, rgba(255,248,230,0.14) 0%, rgba(255,248,230,0.0) 38%),
      radial-gradient(circle at 18% 88%, rgba(255,200,120,0.06) 0%, rgba(255,200,120,0.0) 35%),
      radial-gradient(circle at 70% 55%, rgba(6,8,14,0.55) 0%, rgba(6,8,14,0.0) 48%);
    opacity:0.9;
    pointer-events:none;
  }
  .crash-scene.cashout .moon{
    opacity:1;
    animation:moonIn 1.05s cubic-bezier(.2,.9,.2,1) both;
  }
  @keyframes moonIn{
    from{right:-40%}
    to{right:11%}
  }
  /*
    Turn + approach together: same duration/easing so the rocket rotates while translating toward the moon.
  */
  .crash-scene.cashout .rocket{
    animation:rocketCashoutFlip var(--cashout-spin-ms,2.8s) cubic-bezier(.14,.62,.12,1) forwards;
  }
  .crash-scene.cashout .rocket-mount{
    animation:rocketMountGlide var(--cashout-spin-ms,2.8s) cubic-bezier(.14,.62,.12,1) forwards;
  }
  @keyframes rocketCashoutFlip{
    from{transform:rotate(0deg)}
    to{transform:rotate(330deg)}
  }
  .crash-scene.cashout.landed .rocket{transform:rotate(330deg);animation:none}
  .crash-scene.cashout.landed .thruster{opacity:0;animation:none;visibility:hidden}
  @keyframes rocketMountGlide{
    0%{left:10%;top:50%;transform:translateY(-50%)}
    100%{
      /*
        11 o’clock rim on moon; tuned so nose/engine line sits on surface after 330° roll (not floating high-left).
      */
      left:calc(100% - 11% - var(--moon-w) * 0.52 - min(64px,8%) - min(40px,5.5%));
      top:calc(var(--moon-top-pct) + var(--moon-w) * 0.11 - min(16px,2.5%));
      transform:translateY(calc(-50% - min(52px,8.5%)));
    }
  }
  .boom{
    position:absolute;
    z-index:0;
    left:10%;
    top:50%;
    transform:translateY(-50%) scale(0.2);
    width:min(260px,38%);
    aspect-ratio:1;
    border-radius:50%;
    background:radial-gradient(circle at 50% 50%, rgba(255,255,255,0.95) 0%, rgba(255,181,71,0.75) 18%, rgba(226,75,74,0.28) 42%, rgba(226,75,74,0.0) 70%);
    opacity:0;
    pointer-events:none;
    filter:blur(0.2px);
  }
  .crash-scene.crashed .rocket-mount{opacity:0}
  .crash-scene.crashed .boom{
    opacity:1;
    animation:boomStay 1.1s ease-out both;
  }
  @keyframes boomStay{
    0%{transform:translateY(-50%) scale(0.2);opacity:0}
    30%{opacity:1}
    100%{transform:translateY(-50%) scale(1.05);opacity:1}
  }
  .mult{font-family:'Syne',sans-serif;font-weight:800;font-size:3.5rem;text-align:center;line-height:1;margin:1rem 0;min-height:5rem;color:var(--gold);text-shadow:0 0 40px rgba(198,241,53,0.2)}
  .mult.crashed{color:var(--red);text-shadow:none}
  label{font-size:0.78rem;color:var(--muted);display:block;margin-bottom:0.35rem}
  input[type=number]{width:100%;padding:0.65rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;margin-bottom:0.75rem}
  .row{display:grid;grid-template-columns:1fr 1fr;gap:0.5rem}
  .btn{padding:0.8rem;border:none;border-radius:999px;font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:700;cursor:pointer}
  .btn-start{background:var(--gold);color:#0b0d14}
  .btn-cash{background:var(--green);color:#fff}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  .status{font-size:0.82rem;color:var(--muted);text-align:center;margin-top:0.75rem;min-height:1.25rem}
  .odds{font-size:0.74rem;color:var(--muted);text-align:center;margin-top:0.45rem;line-height:1.45}
  .odds b{color:var(--gold)}
  @media(max-width:900px){
    .game-layout{flex-direction:column}
    .controls-col{flex:1;max-width:340px;margin:0 auto}
  }
  @media(max-width:760px){
    .wrap{padding:0.8rem 0.8rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .crash-scene{min-height:340px;padding:1rem 0 5rem}
    .mult{font-size:2.5rem;min-height:3.5rem}
  }
  @media(max-width:480px){
    .wrap{padding:0.65rem 0.55rem 1.25rem}
    h1{font-size:1.4rem}
    .crash-scene{min-height:300px;padding:0.75rem 0 4rem}
    .mult{font-size:2rem;min-height:3rem;margin:0.65rem 0}
    .panel{padding:1rem}
    .row{grid-template-columns:1fr 1fr;gap:0.4rem}
    .btn{padding:0.7rem}
    .disclaimer{font-size:0.68rem;margin:0.35rem 0 0.9rem}
  }

/* === play/dice.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;line-height:1.45;margin:0.5rem 0 1.25rem}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.8rem}
  .board-col{flex:1;min-width:0;display:flex;flex-direction:column}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .fx-panel{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column}
  .fx-panel > *{position:relative;z-index:1}
  .dice-scene{position:relative;flex:1;min-height:220px;display:flex;align-items:center;justify-content:center}
  .die{
    width:min(180px,55%);
    aspect-ratio:1;
    border-radius:22px;
    background:linear-gradient(180deg,#ffffff,#d7dde6);
    box-shadow:0 26px 70px rgba(0,0,0,0.55);
    border:1px solid rgba(0,0,0,0.18);
    position:relative;
    transform:rotate(8deg);
  }
  .die::before{
    content:'';
    position:absolute;
    inset:14%;
    border-radius:16px;
    box-shadow:inset 0 0 0 1px rgba(0,0,0,0.08);
    background:linear-gradient(180deg,rgba(0,0,0,0.03),rgba(0,0,0,0));
  }
  .pip{position:absolute;width:14px;height:14px;border-radius:50%;background:#111827;box-shadow:0 2px 0 rgba(255,255,255,0.28),0 8px 18px rgba(0,0,0,0.35)}
  .p1{left:22%;top:22%}
  .p2{right:22%;top:22%}
  .p3{left:22%;top:50%;transform:translateY(-50%)}
  .p4{left:50%;top:50%;transform:translate(-50%,-50%)}
  .p5{right:22%;top:50%;transform:translateY(-50%)}
  .p6{left:22%;bottom:22%}
  .p7{right:22%;bottom:22%}
  .dice-scene.rolling .die{
    animation:dieRoll 0.22s linear infinite;
    filter:blur(0.25px);
  }
  .dice-scene.rolling{
    animation:dieDrift 0.9s ease-in-out infinite;
  }
  @keyframes dieDrift{
    0%{transform:translate(0,0)}
    16%{transform:translate(-18px,-10px)}
    32%{transform:translate(16px,-18px)}
    48%{transform:translate(20px,10px)}
    64%{transform:translate(-16px,16px)}
    80%{transform:translate(10px,-6px)}
    100%{transform:translate(0,0)}
  }
  @keyframes dieRoll{
    0%{transform:translateY(0) rotate(8deg) rotateZ(0deg) scale(1)}
    25%{transform:translateY(-6px) rotate(18deg) rotateZ(90deg) scale(1.02)}
    50%{transform:translateY(0) rotate(-10deg) rotateZ(180deg) scale(1)}
    75%{transform:translateY(6px) rotate(14deg) rotateZ(270deg) scale(1.01)}
    100%{transform:translateY(0) rotate(8deg) rotateZ(360deg) scale(1)}
  }
  .dice-caption{margin-top:0.65rem;text-align:center;font-size:0.78rem;color:var(--muted)}
  .roll-big{font-family:'Syne',sans-serif;font-weight:800;font-size:3.25rem;text-align:center;letter-spacing:-1px;margin:0.75rem 0;min-height:4.5rem;display:flex;align-items:center;justify-content:center}
  .roll-big.win{color:var(--green)}.roll-big.lose{color:var(--red)}
  @keyframes rollRolling{0%{transform:scale(1)}50%{transform:scale(1.08) rotate(-2deg)}100%{transform:scale(1)}}
  .roll-big.rolling{color:var(--muted);animation:rollRolling 0.16s ease-in-out infinite}
  .tabs{display:flex;gap:0.35rem;margin-bottom:0.75rem}
  .tabs button{flex:1;padding:0.5rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-weight:700;cursor:pointer;font-size:0.78rem}
  .tabs button.on{background:rgba(198,241,53,0.1);border-color:rgba(198,241,53,0.35);color:var(--gold)}
  label{font-size:0.78rem;color:var(--muted);display:block;margin-bottom:0.35rem}
  input[type=number]{width:100%;padding:0.65rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;margin-bottom:0.75rem}
  input[type=range]{width:100%;accent-color:var(--gold);margin:0.5rem 0 0.25rem}
  /* Custom slider fill: under = left win zone, over = right win zone */
  input[type=range].lotta-slider{
    -webkit-appearance:none;appearance:none;height:10px;border-radius:999px;outline:none;
    background:linear-gradient(to right, rgba(65,199,122,0.9) 0%, rgba(65,199,122,0.9) var(--fill,50%), rgba(255,255,255,0.10) var(--fill,50%), rgba(255,255,255,0.10) 100%);
  }
  input[type=range].lotta-slider.over{
    background:linear-gradient(to right, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.10) var(--fill,50%), rgba(65,199,122,0.9) var(--fill,50%), rgba(65,199,122,0.9) 100%);
  }
  input[type=range].lotta-slider::-webkit-slider-thumb{
    -webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;
    background:var(--gold);border:2px solid rgba(0,0,0,0.25);box-shadow:0 6px 18px rgba(0,0,0,0.45);
  }
  input[type=range].lotta-slider::-moz-range-thumb{
    width:18px;height:18px;border-radius:50%;
    background:var(--gold);border:2px solid rgba(0,0,0,0.25);box-shadow:0 6px 18px rgba(0,0,0,0.45);
  }
  .stat-row{display:flex;justify-content:space-between;font-size:0.85rem;margin-bottom:0.35rem}.stat-row span{color:var(--gold);font-family:'Syne',sans-serif;font-weight:700}
  .btn{width:100%;padding:0.85rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;margin-top:0.5rem}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  @media(max-width:900px){
    .game-layout{flex-direction:column}
    .controls-col{flex:1;max-width:340px;margin:0 auto}
  }
  @media(max-width:760px){
    .wrap{padding:0.8rem 0.8rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .dice-scene{min-height:280px}
    .roll-big{font-size:2.5rem;min-height:3.5rem}
  }
  @media(max-width:480px){
    .wrap{padding:0.65rem 0.55rem 1.25rem}
    h1{font-size:1.4rem}
    .dice-scene{min-height:240px}
    .roll-big{font-size:2rem;min-height:3rem;margin:0.5rem 0}
    .panel{padding:1rem}
    .disclaimer{font-size:0.68rem;margin:0.35rem 0 0.9rem}
    .stat-row{font-size:0.8rem}
  }

/* === play/keno.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px;--cell:#171a26;--line:#2a3142}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2);backdrop-filter:blur(12px)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-size:0.9rem;font-weight:700;color:var(--gold)}

  .page{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  .keno-head{text-align:center;margin-bottom:1rem}
  .keno-head h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);margin:0}
  .keno-head p{font-size:0.72rem;color:var(--muted);margin:0.5rem auto 1.25rem;max-width:700px;line-height:1.45}

  .layout{display:grid;grid-template-columns:300px 1fr;gap:1.25rem;align-items:start;flex:1;min-height:0}
  @media(max-width:900px){.layout{display:flex;flex-direction:column}}
  @media(max-width:900px){.side{order:2;width:100%}}
  @media(max-width:900px){.board-wrap{order:1;width:100%;min-height:300px}}

  .board-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:1rem;min-width:0}
  .grid{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;width:100%}
  .knum{
    height:125px;border-radius:7px;border:1px solid var(--line);
    background:linear-gradient(180deg,var(--cell) 0%,#0d0f14 100%);
    display:flex;align-items:center;justify-content:center;
    font-family:'Barlow Condensed',sans-serif;font-size:0.88rem;font-weight:700;
    cursor:pointer;transition:all 0.12s;user-select:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
  }
  .knum:hover{border-color:rgba(198,241,53,0.35);color:var(--gold)}
  .knum.selected{background:rgba(198,241,53,0.14);border-color:var(--gold);color:var(--gold)}
  .knum.hit{background:var(--gold)!important;border-color:var(--gold)!important;color:#141210!important;animation:hitPop 0.45s ease both}
  .knum.miss{background:rgba(229,62,62,0.12)!important;border-color:rgba(229,62,62,0.35)!important;color:#fca5a5!important;opacity:0.85}
  @keyframes hitPop{0%{transform:scale(1.15)}50%{transform:scale(0.92)}100%{transform:scale(1)}}
  @keyframes drawPop{0%{transform:scale(1)}50%{transform:scale(1.12)}100%{transform:scale(1)}}
  .knum.drawing{animation:drawPop 0.12s ease both}

  .side{display:flex;flex-direction:column;gap:1rem;max-width:300px}
  @media(max-width:900px){.side{max-width:100%}}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:1rem}
  .panel h3{font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:0.65rem}

  .pay-rows{display:flex;flex-direction:row;flex-wrap:wrap;gap:5px}
  .pay-item{
    background:var(--bg3);border:1px solid var(--line);border-radius:8px;
    padding:0.45rem 0.5rem 0.4rem;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;min-width:64px;flex:1;text-align:center;
  }
  .pay-item .pi-mult{color:var(--text);font-family:'Barlow Condensed',sans-serif;font-size:0.92rem;font-weight:800;line-height:1}
  .pay-item .pi-hits{color:var(--muted);font-size:0.62rem;font-weight:600;letter-spacing:0.5px;line-height:1;margin-top:2px}
  .pay-item.active-pay{border-color:rgba(198,241,53,0.5);background:rgba(198,241,53,0.1)}
  .pay-item.active-pay .pi-mult{color:var(--gold)}
  .pay-item.active-pay .pi-hits{color:rgba(198,241,53,0.7)}
  .risk-row{display:flex;gap:6px;margin-bottom:0.75rem}
  .risk-btn{flex:1;padding:0.5rem 0.6rem;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--muted);font-family:'Barlow Condensed',sans-serif;font-size:0.78rem;font-weight:800;cursor:pointer;text-transform:uppercase;letter-spacing:0.5px}
  .risk-btn.active{border-color:rgba(240,180,41,0.45);background:rgba(240,180,41,0.08);color:var(--gold)}

  .bet-input{display:flex;flex-direction:column;gap:0.45rem;align-items:stretch;margin-bottom:0.65rem}
  .bet-input label{font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase}
  .bet-input .lotta-wager-bar input#betInput{padding:0.45rem 0.35rem;background:rgba(255,255,255,0.05);border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:0.92rem}

  .row-btns{display:flex;flex-wrap:wrap;gap:8px}
  .btn{padding:0.65rem 1rem;border-radius:8px;font-family:'Barlow Condensed',sans-serif;font-size:0.82rem;font-weight:800;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;border:none;transition:opacity 0.15s,transform 0.12s}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-play{background:linear-gradient(180deg,#ffd54a,#f0b429);color:#141210}
  .btn-play:not(:disabled):hover{transform:translateY(-1px)}
  .btn-ghost{background:transparent;border:1px solid var(--line);color:var(--muted)}
  .btn-ghost:not(:disabled):hover{border-color:var(--gold);color:var(--gold)}

  .pick-line{font-size:0.8rem;color:var(--muted);text-align:center}
  .pick-line b{color:var(--text)}

  .result-banner{display:none;margin-top:0.75rem;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:0.85rem 1rem;text-align:center;flex-direction:column;align-items:center;justify-content:center}
  .result-banner.show{display:flex}
  .result-banner h3{font-family:'Bebas Neue',sans-serif;font-size:1.65rem;letter-spacing:2px}
  .result-banner.win h3{color:var(--gold)}
  .result-banner.lose h3{color:var(--red)}
  .result-sub{color:var(--muted);font-size:0.85rem;margin-top:0.25rem}

  .stats-row{display:flex;gap:0.75rem;flex-wrap:wrap;margin-bottom:1rem}
  .stat-pill{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:0.45rem 1rem;text-align:center}
  .stat-pill-label{font-size:0.65rem;color:var(--muted);text-transform:uppercase}
  .stat-pill-val{font-family:'Barlow Condensed',sans-serif;font-weight:700}
  .balance-pill .lotta-bal-main{display:block;font-size:0.88rem;line-height:1.2}
  .balance-pill .lotta-bal-fiat{display:block;font-size:0.72rem;color:var(--muted);font-weight:600;margin-top:0.12rem}
  @media(max-width:760px){
    .page{padding:0.8rem 0.8rem 1.5rem}
    .layout{gap:1rem}
    .knum{font-size:0.78rem;border-radius:5px}
    .grid{gap:4px}
    .side{max-width:100%}
    .stats-row{gap:0.5rem}
    .stat-pill{padding:0.4rem 0.75rem}
  }
  @media(max-width:480px){
    .page{padding:0.65rem 0.55rem 1.25rem}
    .keno-head h1{font-size:1.4rem}
    .keno-head p{font-size:0.68rem;margin:0.35rem auto 0.9rem}
    .knum{font-size:0.68rem;border-radius:4px}
    .grid{gap:3px}
    .panel{padding:0.85rem}
    .risk-btn{padding:0.4rem 0.4rem;font-size:0.72rem}
    .bet-input .lotta-wager-bar input#betInput{font-size:0.85rem}
    .btn{padding:0.55rem 0.75rem;font-size:0.78rem}
    .stats-row{gap:0.4rem}
    .stat-pill{padding:0.35rem 0.6rem;flex:1}
    .stat-pill-val{font-size:0.82rem}
    .result-banner h3{font-size:1.35rem}
  }

/* === play/limbo.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;line-height:1.45;margin:0.5rem 0 1.25rem}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.8rem}
  .board-col{flex:1;min-width:0;display:flex;flex-direction:column}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .fx-panel{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column}
  .fx-panel > *{position:relative;z-index:1}
  .limbo-scene{position:relative;flex:1;min-height:260px;display:flex;align-items:center;justify-content:center}
  .limbo-grid{position:absolute;inset:0;pointer-events:none}
  .portal{
    width:min(320px,58%);
    aspect-ratio:1;
    border-radius:50%;
    border:2px solid rgba(198,241,53,0.35);
    background:radial-gradient(circle at 50% 50%, rgba(198,241,53,0.18) 0%, rgba(198,241,53,0.02) 44%, rgba(0,0,0,0) 68%);
    box-shadow:0 0 0 10px rgba(198,241,53,0.03), 0 26px 80px rgba(0,0,0,0.55);
    position:relative;
    filter:drop-shadow(0 10px 30px rgba(0,0,0,0.45));
  }
  .portal::before{
    content:'';
    position:absolute;inset:10%;
    border-radius:50%;
    border:1px dashed rgba(255,255,255,0.18);
    opacity:0.9;
  }
  .runner{
    position:absolute;
    left:50%;
    top:62%;
    width:34px;height:34px;
    background:linear-gradient(180deg,#f0f0f0,#7f8aa6);
    border-radius:10px;
    transform:translate(-50%,-50%);
    box-shadow:0 10px 30px rgba(0,0,0,0.55);
  }
  .runner::before{
    content:'';
    position:absolute;left:50%;top:-16px;
    width:18px;height:18px;border-radius:50%;
    background:#f0f0f0;
    transform:translateX(-50%);
  }
  .bar{
    position:absolute;left:50%;top:58%;
    width:min(360px,70%);
    height:10px;border-radius:999px;
    background:linear-gradient(90deg, rgba(226,75,74,0.0), rgba(226,75,74,0.7), rgba(226,75,74,0.0));
    box-shadow:0 0 28px rgba(226,75,74,0.28);
    transform:translate(-50%,-50%);
  }
  .bar{z-index:3}
  .runner{z-index:2}
  .limbo-scene.charging .portal{
    animation:portalCharge 0.6s ease-in-out infinite alternate;
  }
  @keyframes portalCharge{
    from{transform:scale(1)}
    to{transform:scale(1.03)}
  }
  .limbo-scene.jumping .runner{
    animation:runnerJump 0.55s cubic-bezier(.2,.9,.2,1) infinite;
  }
  @keyframes runnerJump{
    0%{transform:translate(-50%,-50%)}
    50%{transform:translate(-50%,-120%)}
    100%{transform:translate(-50%,-50%)}
  }
  .limbo-scene.win .bar{
    background:linear-gradient(90deg, rgba(65,199,122,0.0), rgba(65,199,122,0.75), rgba(65,199,122,0.0));
    box-shadow:0 0 36px rgba(65,199,122,0.28);
  }
  .limbo-scene.win .runner{
    animation:runnerWin 0.9s cubic-bezier(.2,.9,.2,1) both;
  }
  @keyframes runnerWin{
    0%{transform:translate(-50%,-50%)}
    40%{transform:translate(-50%,-140%)}
    100%{transform:translate(calc(-50% + 170px),-140%) rotate(10deg)}
  }
  .limbo-scene.lose .bar{
    animation:barDrop 0.55s cubic-bezier(.2,.9,.2,1) both;
  }
  .limbo-scene.lose .runner{
    animation:runnerFall 0.6s cubic-bezier(.2,.9,.2,1) both;
  }
  @keyframes barDrop{
    0%{transform:translate(-50%,-50%) rotate(0deg)}
    25%{transform:translate(calc(-50% + 10px),-35%) rotate(10deg)}
    100%{transform:translate(calc(-50% + 50px),170%) rotate(18deg);opacity:0}
  }
  @keyframes runnerFall{
    0%{transform:translate(-50%,-50%) rotate(0deg)}
    35%{transform:translate(-50%,-50%) rotate(-20deg)}
    100%{transform:translate(calc(-50% + 60px),110%) rotate(-95deg);opacity:0.85}
  }
  @keyframes barShake{
    0%{transform:translate(-50%,-50%)}
    20%{transform:translate(calc(-50% - 6px),-50%)}
    40%{transform:translate(calc(-50% + 6px),-50%)}
    60%{transform:translate(calc(-50% - 4px),-50%)}
    80%{transform:translate(calc(-50% + 4px),-50%)}
    100%{transform:translate(-50%,-50%)}
  }
  .spark{
    position:absolute;
    left:50%;top:50%;
    width:8px;height:8px;border-radius:50%;
    background:var(--gold);
    opacity:0;
    pointer-events:none;
  }
  .limbo-scene.win .spark{
    opacity:1;
    animation:sparkBurst 0.75s ease-out both;
  }
  @keyframes sparkBurst{
    0%{transform:translate(-50%,-50%) scale(0.8);filter:blur(0)}
    100%{transform:translate(calc(-50% + 120px),calc(-50% - 120px)) scale(0.2);opacity:0;filter:blur(0.6px)}
  }
  .out{font-family:'Syne',sans-serif;font-weight:800;font-size:2.75rem;text-align:center;margin:1rem 0;min-height:4rem}
  .out.win{color:var(--green)}.out.lose{color:var(--red)}
  @keyframes limboPulse{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}
  .out.loading{color:var(--muted);animation:limboPulse 0.35s ease-in-out infinite}
  label{font-size:0.78rem;color:var(--muted);display:block;margin-bottom:0.35rem}
  input[type=number]{width:100%;padding:0.65rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;margin-bottom:0.75rem}
  .stat-row{display:flex;justify-content:space-between;font-size:0.85rem;margin-bottom:0.35rem}.stat-row span{color:var(--gold);font-family:'Syne',sans-serif;font-weight:700}
  .btn{width:100%;padding:0.85rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;margin-top:0.5rem}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s;margin-top:0}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  @media(max-width:900px){
    .game-layout{flex-direction:column}
    .controls-col{flex:1;max-width:340px;margin:0 auto}
  }
  @media(max-width:760px){
    .wrap{padding:0.8rem 0.8rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .limbo-scene{min-height:280px}
    .out{font-size:2.25rem;min-height:3.25rem;margin:0.65rem 0}
  }
  @media(max-width:480px){
    .wrap{padding:0.65rem 0.55rem 1.25rem}
    h1{font-size:1.4rem}
    .limbo-scene{min-height:240px}
    .out{font-size:1.85rem;min-height:2.75rem;margin:0.5rem 0}
    .panel{padding:1rem}
    .disclaimer{font-size:0.68rem;margin:0.35rem 0 0.9rem}
    .stat-row{font-size:0.8rem}
  }

/* === play/mines.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}
  .logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600;transition:color 0.2s}
  .nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}

  .game-wrap{flex:1;display:flex;flex-direction:column;gap:0.85rem;padding:1rem 1.5rem 1.25rem;width:100%;align-items:center}
  .game-head{width:100%;text-align:center}
  .game-head h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);margin:0}
  .game-head .disclaimer{font-size:0.72rem;color:var(--muted);line-height:1.45;margin:0.5rem auto 0.85rem;max-width:700px}

  .game-body{width:100%;display:flex;gap:2rem;align-items:stretch;justify-content:center;flex:1;flex-wrap:wrap;min-height:0}

  .mines-play-col{display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:center;flex:1 1 0;min-width:0;min-height:0}

  .game-controls{display:flex;flex-direction:column;gap:1rem;flex:0 0 280px;max-width:280px}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
  .panel-title{font-size:0.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:0.75rem}

  label{font-size:0.82rem;color:var(--muted);display:block;margin-bottom:0.3rem}
  input[type=number]{width:100%;padding:0.6rem 0.9rem;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:'Barlow',sans-serif;font-size:0.95rem;outline:none;margin-bottom:0.75rem}
  input[type=number]:focus{border-color:rgba(240,180,41,0.4)}
  input[type=range]{width:100%;accent-color:var(--gold);margin-bottom:0.5rem}
  .wager-row{display:flex;gap:0.5rem;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:rgba(198,241,53,0.1);
    border:1px solid rgba(198,241,53,0.3);
    border-radius:8px;
    color:var(--gold);
    font-family:'DM Sans',sans-serif;
    font-weight:700;
    font-size:0.85rem;
    cursor:pointer;
    transition:all 0.2s;
    flex-shrink:0;
    margin-bottom:0;
  }
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}

  .mine-count-label{display:flex;justify-content:space-between;margin-bottom:0.25rem}
  .mine-count-val{font-family:'Syne',sans-serif;font-size:1.05rem;font-weight:700;color:var(--gold)}

  .btn-primary{width:100%;padding:0.8rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;transition:opacity 0.2s,transform 0.15s}
  .btn-primary:disabled{opacity:0.3;cursor:not-allowed}
  .btn-primary:not(:disabled):hover{transform:scale(1.02)}
  .btn-cashout{width:100%;padding:0.8rem;border:none;border-radius:999px;background:#1f7a4d;border:1px solid var(--green);color:#ecfff4;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;transition:opacity 0.2s,transform 0.15s}
  .btn-cashout:disabled{opacity:0.3;cursor:not-allowed}
  .btn-cashout:not(:disabled):hover{transform:scale(1.02)}

  .mult-display{text-align:center;padding:0.75rem;background:rgba(240,180,41,0.05);border:1px solid var(--border);border-radius:6px;margin-bottom:0.5rem}
  .mult-big{font-family:'Syne',sans-serif;font-size:1.75rem;font-weight:800;letter-spacing:-0.2px;color:var(--gold)}
  .mult-label{font-size:0.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
  .profit-display{text-align:center;font-family:'DM Sans',sans-serif;font-size:1.05rem;font-weight:700;color:var(--green)}

  .mines-board{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;width:min(560px,calc(100vmin - 5.5rem));max-width:min(560px,calc(100vmin - 5.5rem),100%);flex:0 0 auto;margin-inline:auto}
  .mtile{
    aspect-ratio:1;border-radius:10px;border:1px solid var(--border);
    background:var(--bg2);display:flex;align-items:center;justify-content:center;
    font-size:1.8rem;cursor:pointer;transition:all 0.15s;user-select:none;
  }
  .mtile:not(.revealed):not(.mine-shown):hover{border-color:rgba(240,180,41,0.4);background:rgba(240,180,41,0.05);transform:scale(1.03)}
  .mtile.gem{background:rgba(56,161,105,0.15)!important;border-color:rgba(56,161,105,0.5)!important;animation:gemPop 0.35s ease both}
  .mtile.mine-shown{background:rgba(229,62,62,0.15)!important;border-color:rgba(229,62,62,0.5)!important;cursor:default;animation:boom 0.4s ease both}
  .mtile.revealed{cursor:default}
  @keyframes gemPop{0%{transform:scale(0.7) rotate(-10deg)}60%{transform:scale(1.15) rotate(3deg)}100%{transform:scale(1) rotate(0)}}
  @keyframes boom{0%{transform:scale(1.3)}50%{transform:scale(0.85)}100%{transform:scale(1)}}

  .stats-bar{display:flex;gap:0.75rem;flex-wrap:wrap;justify-content:center;width:100%;max-width:min(560px,calc(100vmin - 5.5rem),100%)}
  .stat-mini{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:0.5rem 1rem;text-align:center;flex:1;min-width:80px}
  .stat-mini-label{font-size:0.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
  .stat-mini-val{font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700}
  @keyframes boardShake{0%{transform:translateX(0)}20%{transform:translateX(-3px)}40%{transform:translateX(3px)}60%{transform:translateX(-2px)}80%{transform:translateX(2px)}100%{transform:translateX(0)}}
  .game-wrap.shake{animation:boardShake 0.35s ease-in-out both}
  .balance-pill .lotta-bal-main{display:block;font-size:0.88rem;line-height:1.2}
  .balance-pill .lotta-bal-fiat{display:block;font-size:0.72rem;color:var(--muted);font-weight:600;margin-top:0.12rem}
  @keyframes cashPulse{0%{box-shadow:0 0 0 rgba(56,161,105,0)}50%{box-shadow:0 0 0 6px rgba(56,161,105,0.12)}100%{box-shadow:0 0 0 rgba(56,161,105,0)}}
  .btn-cashout.pulse{animation:cashPulse 0.9s ease-in-out infinite}
  @media(max-width:760px){
    .game-wrap{padding:0.8rem 0.8rem 1.5rem;gap:0.85rem}
    .game-body{gap:1rem}
    .game-controls{min-width:0;max-width:100%;flex:1 1 100%}
    .mines-board{width:min(560px,calc(100vmin - 4.5rem),100%)}
    .stats-bar{max-width:min(560px,calc(100vmin - 4.5rem),100%)}
    .mtile{font-size:1.5rem;border-radius:8px}
  }
  @media(max-width:480px){
    .game-wrap{padding:0.65rem 0.55rem 1.25rem;gap:0.75rem}
    .game-head h1{font-size:1.4rem}
    .game-head .disclaimer{font-size:0.68rem;margin:0.35rem auto 0.9rem}
    .panel{padding:1rem}
    .mtile{font-size:1.3rem;border-radius:7px}
    .mines-board{gap:5px}
    .mult-big{font-size:1.5rem}
    .stat-mini{padding:0.4rem 0.65rem}
    .stat-mini-val{font-size:0.85rem}
  }

/* === play/plinko.html (inline) === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--bg:#0b0d14;--bg2:#13151f;--bg3:#171a26;--gold:#c6f135;--red:#e24b4a;--green:#41c77a;--text:#f0f0f0;--muted:#8b8fa8;--border:rgba(255,255,255,0.07);--radius:14px}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column}
  nav{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg2)}
  .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.2rem;letter-spacing:0;color:var(--text);text-decoration:none}.logo span{color:var(--gold)}
  .nav-back{color:var(--muted);text-decoration:none;font-size:0.85rem;font-weight:600}.nav-back:hover{color:var(--gold)}
  .balance-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:0.35rem 1rem;font-family:'Syne',sans-serif;font-weight:700;color:var(--gold)}
  .wrap{flex:1;width:100%;padding:1rem 1.5rem 1.25rem;display:flex;flex-direction:column;gap:0.8rem}
  h1{font-family:'Syne',sans-serif;font-weight:800;font-size:1.75rem;letter-spacing:-0.2px;color:var(--gold);text-align:center;margin:0}
  .disclaimer{font-size:0.72rem;color:var(--muted);text-align:center;margin:0.5rem 0 1.25rem;line-height:1.45}
  .game-layout{display:flex;gap:1.1rem;align-items:stretch;flex:1;min-height:0}
  .controls-col{flex:0 0 280px;display:flex;flex-direction:column;gap:0.65rem}
  .board-col{flex:1;min-width:0;display:flex;flex-direction:column}
  .controls{display:grid;grid-template-columns:1fr;gap:0.5rem}
  .panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
  .panel label{font-size:0.72rem;color:var(--muted);text-transform:uppercase;display:block;margin-bottom:0.35rem}
  select,input[type=number]{width:100%;padding:0.55rem;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:0.95rem}
  .risk-btns{display:flex;gap:0.35rem;flex-wrap:wrap}
  .risk-btns button{flex:1;min-width:70px;padding:0.45rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.78rem;cursor:pointer}
  .risk-btns button.on{background:rgba(198,241,53,0.1);border-color:rgba(198,241,53,0.4);color:var(--gold)}
  .board{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:0.55rem 0.55rem 0.7rem;flex:1;display:flex;flex-direction:column;min-height:0}
  /* Bucket containers rendered below the triangle */
  .slots{position:absolute;left:0;right:0;bottom:12px;height:84px;pointer-events:none}
  .bucket{
    position:absolute;
    transform:translateX(-50%);
    bottom:0;
    width:36px;
    height:62px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-end;
    padding:0 2px;
  }
  .bucket-shape{
    width:100%;
    height:42px;
    background:linear-gradient(180deg,rgba(19,21,31,0.95),rgba(11,13,20,0.98));
    border:2px solid rgba(255,255,255,0.2);
    border-top:none;
    border-radius:0 0 6px 6px;
    position:relative;
    box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 12px rgba(0,0,0,0.3);
  }
  .bucket-shape::before{
    content:'';
    position:absolute;
    top:-2px;
    left:-2px;
    right:-2px;
    height:4px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);
  }
  .bucket-shape.bucket-hit{
    animation:bucketGlow 0.6s ease both;
  }
  @keyframes bucketGlow{
    0%{box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 12px rgba(0,0,0,0.3)}
    50%{box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 20px rgba(198,241,53,0.6),0 0 0 3px rgba(198,241,53,0.3)}
    100%{box-shadow:inset 0 -2px 8px rgba(0,0,0,0.4),0 2px 12px rgba(0,0,0,0.3)}
  }
  .bucket-mult{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    font-size:0.62rem;
    font-family:'Syne',sans-serif;
    font-weight:800;
    color:var(--gold);
    text-shadow:0 1px 3px rgba(0,0,0,0.8);
    white-space:nowrap;
    pointer-events:none;
    line-height:1;
    text-align:center;
    max-width:100%;
    overflow:hidden;
  }
  .drop-area{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center}
  .drop-area .peg-area{margin-bottom:0.75rem}
  .drop-area .btn{margin-top:0}
  .dropbar .btn{margin-top:0}
  .dropbar .peg-area{margin:0;min-height:auto}
  .pegboard{
    position:relative;
    width:100%;
    min-height:560px;
    margin:0.35rem auto 0.1rem;
    border-radius:12px;
    background:linear-gradient(180deg,rgba(198,241,53,0.06) 0%,rgba(0,0,0,0) 60%),var(--bg);
    border:1px solid var(--border);
    overflow:hidden;
  }
  .peg{
    position:absolute;
    width:11px;
    height:11px;
    border-radius:50%;
    background:rgba(240,180,41,0.2);
    border:1px solid rgba(240,180,41,0.25);
    box-shadow:0 0 18px rgba(240,180,41,0.08);
    transform:translate(-50%,-50%);
  }
  .ball{
    position:absolute;
    width:18px;
    height:18px;
    border-radius:50%;
    background:radial-gradient(circle at 35% 30%,#fff 0%,rgba(255,255,255,0.6) 18%,rgba(240,180,41,0.95) 45%,rgba(240,180,41,0.25) 72%);
    border:1px solid rgba(240,180,41,0.45);
    box-shadow:0 10px 40px rgba(0,0,0,0.55), 0 0 30px rgba(240,180,41,0.18);
    transform:translate(-50%,-50%);
    left:50%;
    top:18px;
    z-index:2;
    will-change:left,top;
  }
  @keyframes ballLand{0%{transform:translate(-50%,-50%) scale(1)}40%{transform:translate(-50%,-50%) scale(1.18)}100%{transform:translate(-50%,-50%) scale(1)}}
  .ball.land{animation:ballLand 0.28s ease both}
  .peg-area{min-height:120px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;color:var(--muted);margin:0.5rem 0}
  .peg-area.playing{color:var(--gold)}
  .btn{width:100%;padding:0.85rem;border:none;border-radius:999px;background:var(--gold);color:#0b0d14;font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;cursor:pointer;margin-top:0.75rem}
  .btn:disabled{opacity:0.35;cursor:not-allowed}
  .btn-bet-adjust{padding:0.65rem 1rem;background:rgba(198,241,53,0.1);border:1px solid rgba(198,241,53,0.3);border-radius:8px;color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
  .btn-bet-adjust:hover{background:rgba(198,241,53,0.2);border-color:rgba(198,241,53,0.6)}
  .wager-row{display:flex;gap:0.5rem;width:100%;margin-bottom:0.75rem;align-items:stretch}
  .wager-row #betInput{flex:1;margin-bottom:0;height:42px}
  .wager-row .btn-bet-adjust{
    height:42px;
    min-width:46px;
    padding:0 0.8rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    margin-bottom:0;
  }
  .drop-history{margin-top:0.75rem;display:flex;flex-direction:column;gap:0.3rem}
  .drop-history-item{font-size:0.82rem;color:var(--muted);text-align:center;transition:opacity 0.3s}
  .drop-history-item b{color:var(--gold)}
  .drop-history-item:first-child{color:var(--text)}
  @media (max-width: 768px) {
    nav{padding:0.85rem 1rem}
    .wrap{max-width:100%;padding:1.25rem 0.75rem 1.5rem}
    .game-layout{flex-direction:column;gap:0.8rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .controls{grid-template-columns:1fr;gap:0.5rem}
    .pegboard{min-height:auto;max-height:55vh}
    .bucket{height:auto;min-height:44px}
    .bucket-mult{font-size:0.66rem}
  }
  @media (max-width: 480px) {
    nav{padding:0.75rem 0.75rem}
    .wrap{padding:1rem 0.5rem 1.25rem}
    .controls-col{flex:0 0 auto;max-width:100%;margin:0;width:100%}
    .board-col{flex:0 0 auto;width:100%;min-width:0}
    .pegboard{min-height:auto;max-height:50vh}
    .bucket{height:auto;min-height:40px}
    .bucket-mult{font-size:0.63rem}
    .panel{padding:0.75rem}
  }
}
