/* Cosmic Crash — dark space minimal */
:root{
  /* Colors */
  --bg:#070A12;
  --panel:#0B1020;
  --panel2:#0E1630;
  /* Design-system aliases (Phase 2) */
  --card: var(--panel);
  --surface: var(--panel2);
  --text:#EAF0FF;
  --muted:#AAB6D6;
  --success: var(--good);
  --danger: var(--bad);
  --line:rgba(255,255,255,.08);
  --good:#8CFFB2;
  --warn:#FFD37A;
  --bad:#FF7A8C;
  --accent:#7AA8FF;

  /* Typography */
  --font-sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;

  /* Spacing scale */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;

  /* Radii */
  --r-sm: 10px;
  --r-md: 12px;
  --r-lg: 14px;
  --r-xl: 16px;
  --r-pill: 999px;

  /* Shadows / depth */
  --shadow-1: 0 10px 30px rgba(0,0,0,.35);
  --shadow-2: 0 20px 60px rgba(0,0,0,.45);

  /* Motion */
  --ease: cubic-bezier(.2,.8,.2,1);
  --dur-1: 140ms;
  --dur-2: 220ms;

  /* Focus */
  --ring: 0 0 0 3px rgba(122,168,255,.22);

  /* Legacy aliases */
  --shadow: var(--shadow-2);
  --shadow2: var(--shadow-1);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: var(--font-sans);
  color:var(--text);
  background:
    radial-gradient(1200px 500px at 70% 10%, rgba(122,168,255,.20), transparent 60%),
    radial-gradient(900px 400px at 10% 0%, rgba(255,122,140,.10), transparent 55%),
    radial-gradient(900px 500px at 30% 90%, rgba(140,255,178,.10), transparent 55%),
    var(--bg);
  overflow-x:hidden;
}
#app{max-width:1200px;margin:0 auto;padding:var(--s-4)}
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--line);
  border-radius:14px;
  backdrop-filter: blur(10px);
}
.brand{display:flex;gap:12px;align-items:center}
.brand .dot{width:10px;height:10px;border-radius:99px;background:var(--accent);box-shadow:0 0 18px rgba(122,168,255,.6)}
.title{font-weight:700;letter-spacing:.2px}
.sub{font-size:12px;color:var(--muted)}
.user{display:flex;gap:10px;align-items:center}
.pill{
  padding:8px 10px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.15);
  font-size:12px;color:var(--muted)
}
.pill.balance{color:var(--text)}

.layout{display:grid;grid-template-columns: 1fr 340px;gap:var(--s-4);margin-top:var(--s-4)}
@media (max-width: 1200px){
  .layout{grid-template-columns: 1fr 300px;}
}
@media (max-width: 980px){
  .layout{grid-template-columns:1fr}
}

/* Keep the right sidebar usable on laptops: scroll inside, not the whole page */
aside.side{
  max-height: calc(100vh - 92px);
  overflow-y: auto;
  position: sticky;
  top: 86px;
}
@media (max-width: 980px){
  aside.side{ position: static; max-height: none; overflow: visible; }
}

.stage{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
}
.stage-header{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);margin-bottom:var(--s-3)}
.round{display:flex;gap:10px;align-items:baseline}
.round .label{font-size:12px;color:var(--muted)}
.round .value{font-size:14px;font-weight:700}
.status{
  padding:7px 10px;border-radius:999px;border:1px solid var(--line);
  background:rgba(0,0,0,.18);font-size:12px;letter-spacing:.3px;
}
.ghost{
  padding:8px 10px;border-radius:10px;border:1px solid var(--line);
  background:transparent;color:var(--text);cursor:pointer
}

.canvas-wrap{
  position:relative;
  border-radius:14px;
  border:1px solid var(--line);
  background:
    radial-gradient(700px 300px at 50% 20%, rgba(122,168,255,.12), transparent 60%),
    radial-gradient(500px 250px at 20% 90%, rgba(255,211,122,.08), transparent 55%),
    rgba(0,0,0,.22);
  overflow:hidden;
}
canvas{display:block;width:100%;height:auto}
.mult{
  position:absolute;left:16px;top:14px;
  font-size:46px;font-weight:800;letter-spacing:-.8px;
  text-shadow:0 10px 40px rgba(0,0,0,.55);
}
.countdown{
  position:absolute;right:16px;top:16px;
  font-size:12px;color:var(--muted);
  padding:7px 10px;border-radius:999px;border:1px solid var(--line);
  background:rgba(0,0,0,.18);
}

.controls{
  display:grid;grid-template-columns: 1fr 1fr 160px 160px;gap:var(--s-3);
  margin-top:var(--s-3);align-items:end;
}
@media (max-width: 980px){
  .controls{grid-template-columns:1fr 1fr}
}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.field input{
  width:100%;padding:10px 10px;border-radius:12px;
  border:1px solid var(--line);background:rgba(0,0,0,.20);color:var(--text);
  outline:none;
}
.input:focus{ box-shadow: var(--ring); border-color: rgba(122,168,255,.35); }

.btn{
  padding:12px 12px;border-radius:12px;border:1px solid rgba(122,168,255,.35);
  background:rgba(122,168,255,.18);color:var(--text);
  cursor:pointer;font-weight:700;
}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.warn{border-color: rgba(255,211,122,.35);background:rgba(255,211,122,.14)}
/* Button system */
.btn{
  transition: transform var(--dur-1) var(--ease), background var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
}
.btn:hover:not(:disabled){ transform: translateY(-1px); box-shadow: var(--shadow-1); }
.btn:active:not(:disabled){ transform: translateY(0px); }
.btn:focus-visible{ box-shadow: var(--ring), var(--shadow-1); outline:none; }

.btn--primary{ border-color: rgba(122,168,255,.40); background:rgba(122,168,255,.20); }
.btn--warn{ border-color: rgba(255,211,122,.40); background:rgba(255,211,122,.16); }
.btn--danger{ border-color: rgba(255,122,140,.40); background:rgba(255,122,140,.14); }
.btn--ghost{ border-color: var(--line); background:rgba(0,0,0,.10); color: var(--text); }

.btn.warn{ /* backward compat */ }
.btn.danger{ border-color: rgba(255,122,140,.35); background:rgba(255,122,140,.12); }
.btn.ghost{ border-color: var(--line); background:rgba(0,0,0,.10); }

.foot{display:flex;justify-content:space-between;gap:var(--s-3);margin-top:var(--s-3)}
.hint{font-size:12px;color:var(--muted)}
.badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid var(--line);margin-right:6px}
.tiny{font-size:12px;color:var(--muted)}
.mono{font-family: var(--font-mono);
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  margin-bottom:14px;
}
.card-title{font-size:13px;color:var(--muted);margin-bottom:10px}
.table{display:flex;flex-direction:column;gap:8px}
.betrow{
  display:flex;justify-content:space-between;gap:10px;
  padding:8px 10px;border-radius:12px;border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  font-size:12px;
}
.betrow .l{display:flex;gap:10px;align-items:center;min-width:0}
.betrow .u{color:var(--text);font-weight:700;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.betrow .a{color:var(--muted)}
.betrow .r{color:var(--good);font-weight:700}
.betrow .r.loss{color:var(--bad)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  padding:6px 10px;
  border-radius:var(--r-pill);
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  font-size:12px;
  transition: background var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease);
}
.chip:hover{ background:rgba(0,0,0,.24); }
.chip.good{border-color:rgba(140,255,178,.25)}
.chip.bad{border-color:rgba(255,122,140,.25)}
.wallet .row{display:flex;justify-content:space-between;padding:var(--s-3) var(--s-2);border-bottom:1px solid var(--line)}
.wallet .row:last-child{border-bottom:none}
.muted{color:var(--muted)}

dialog{
  border:none;
  background:transparent;
}
dialog::backdrop{background:rgba(0,0,0,.55)}
.dlg{
  width:min(820px, calc(100vw - 24px));
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  color:var(--text);
}
.dlg-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px}
.dlg-title{font-size:16px;font-weight:800}
.dlg-sub{font-size:12px;color:var(--muted);margin-top:4px}
.kv{display:grid;grid-template-columns: 180px 1fr;gap:10px;align-items:center}
.kv .k{font-size:12px;color:var(--muted)}
.kv .v{font-size:12px;word-break:break-all;background:rgba(0,0,0,.18);border:1px solid var(--line);padding:10px;border-radius:12px}
.verify{display:flex;gap:10px;align-items:center;margin-top:12px}

/* Lobby */
.lobby{margin-top:var(--s-4)}
.lobby-hero{margin-bottom:var(--s-4)}
.hero-card{
  padding:14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.hero-title{font-size:18px;font-weight:900}
.hero-sub{font-size:12px;color:var(--muted);margin-top:6px;max-width:900px}
.hero-actions{display:flex;gap:var(--s-3);margin-top:var(--s-3);flex-wrap:wrap}
.hero-actions .seg{display:flex;gap:10px;flex-wrap:wrap}
.hero-actions .seg .btn{min-width:150px}

.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;align-items:stretch}
@media (max-width: 980px){.hero-grid{grid-template-columns:1fr;}}
.hero-mines .hero-actions{justify-content:flex-end}
.hero-counters{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
@media (max-width: 560px){.hero-counters{grid-template-columns:1fr;}}

.feed{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.hero-strip .feed{
  /* Phase 3: keep lobby layout stable. Fixed height, scroll inside. */
  height:220px;
  overflow:auto;
  padding-right:6px;
  scrollbar-gutter: stable;
  overscroll-behavior: contain;
}
.hero-strip .feed::-webkit-scrollbar{width:6px}
.hero-strip .feed::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:999px}
/* Keep lobby feeds from stretching the whole page */
.feed.big{gap:10px;max-height:420px;overflow:auto;padding-right:6px}

/* Mines/Chat panes */
.chat{max-height:320px;overflow:auto;display:flex;flex-direction:column;gap:8px;padding:10px;background:rgba(0,0,0,.12);border-radius:14px}

/* Sticky side card so the page doesn't grow vertically */
.game-side #side-card{position:sticky;top:86px;max-height:calc(100vh - 110px);overflow:hidden}
.game-side #side-card .tabpane{overflow:auto;max-height:320px}

/* Toast: top-casino behavior (auto-hide, no close button) */
.toast .x{display:none}
.feed-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);border-radius:14px}
.feed-left{display:flex;flex-direction:column;gap:2px}
.feed-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.feed-game{font-size:12px;padding:2px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05)}
.feed-game.crash{border-color:rgba(120,180,255,.22)}
.feed-game.mines{border-color:rgba(255,220,120,.22)}
.feed-main{font-weight:600}
.feed-sub{font-size:12px;opacity:.75}
.feed-right{display:flex;align-items:center;gap:10px;white-space:nowrap}
.feed-pill{font-variant-numeric:tabular-nums; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; padding:4px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.10); background:rgba(0,0,0,.10)}

/* Fairness dialog tweaks */
dialog#fairness .dlg{max-width:760px}
dialog#fairness .kv2 .v{display:flex;align-items:center;gap:10px;justify-content:space-between}
dialog#fairness .copybtn{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#dfe7ff;border-radius:10px;padding:6px 10px;cursor:pointer}
dialog#fairness .copybtn:hover{background:rgba(255,255,255,.10)}
.grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:var(--s-4);
}
@media (max-width: 980px){ .grid{grid-template-columns:1fr} }
.game{
  padding:12px;
  border:1px solid var(--line);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}
.game-top{display:flex;justify-content:space-between;align-items:center;gap:10px}
.game-name{font-size:14px;font-weight:900}
.game-desc{font-size:12px;color:var(--muted);margin-top:8px;min-height:44px}
.game-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.game-actions{margin-top:12px}
.tag{
  font-size:11px;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid var(--line);
}
.tag.on{color:var(--good);border-color:rgba(140,255,178,.25);background:rgba(140,255,178,.08)}
.tag.off{color:var(--warn);border-color:rgba(255,211,122,.25);background:rgba(255,211,122,.08)}
.game.disabled{opacity:.65}

/* Admin */
.admin{
  margin-top:var(--s-4);
  display:grid;
  grid-template-columns: 1fr;
  gap:var(--s-4);
}
.admin-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
}
.admin-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:var(--s-4);
}
@media (max-width: 980px){ .admin-grid{grid-template-columns:1fr} }
.formrow{display:flex;gap:var(--s-3);flex-wrap:wrap;align-items:end}
.formrow .field{flex:1;min-width:220px}
.tablebox{
  width:100%;
  overflow:auto;
  border:1px solid var(--line);
  border-radius:14px;
}
table{
  width:100%;
  border-collapse:collapse;
  font-size:12px;
}
th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
th{color:var(--muted);font-weight:700}
tr:hover td{background:rgba(0,0,0,.12)}
.smallbtn{
  padding:7px 10px;border-radius:10px;border:1px solid var(--line);
  background:rgba(0,0,0,.18);color:var(--text);cursor:pointer;font-size:12px
}
.smallbtn.danger{border-color:rgba(255,122,140,.25);background:rgba(255,122,140,.10)}
.note{font-size:12px;color:var(--muted)}


/* ---------- Preprod polish ---------- */
/* Tokens above include shadow/ring; legacy vars kept in :root */
a{color:inherit}
.ghost:hover, .smallbtn:hover, .btn:hover{transform:translateY(-1px)}
.ghost:active, .smallbtn:active, .btn:active{transform:translateY(0px)}
.btn, .ghost, .smallbtn{transition:transform .12s ease, background .12s ease, border-color .12s ease, opacity .12s ease}
.field input:focus{
  border-color: rgba(122,168,255,.55);
  box-shadow: var(--ring);
}
.input:focus{ box-shadow: var(--ring); border-color: rgba(122,168,255,.35); }

.btn{
  background:linear-gradient(180deg, rgba(122,168,255,.26), rgba(122,168,255,.14));
  border-color: rgba(122,168,255,.55);
}
.btn.warn{
  background:linear-gradient(180deg, rgba(255,211,122,.20), rgba(255,211,122,.10));
  border-color: rgba(255,211,122,.55);
}
.btn.danger{
  background:linear-gradient(180deg, rgba(255,122,140,.18), rgba(255,122,140,.08));
  border-color: rgba(255,122,140,.55);
}
.topbar{
  box-shadow: var(--shadow2);
}
.stage, .card{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  padding:var(--s-4);
  box-shadow: var(--shadow-1);
}

/* Panel is a lighter card used for headers/metrics blocks */
.panel{
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: var(--s-4);
  box-shadow: 0 12px 40px rgba(0,0,0,.22);
}
.panel.compact{ padding: var(--s-3); }
.side .card, .hero-card, .game{
  box-shadow: 0 14px 45px rgba(0,0,0,.22);
}
.canvas-wrap{
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), 0 18px 50px rgba(0,0,0,.28);
}
.mult{
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(170,182,214,.85));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.status{
  backdrop-filter: blur(10px);
}
.betrow{
  transition: background .12s ease, border-color .12s ease, transform .12s ease;
}
.betrow:hover{
  border-color: rgba(122,168,255,.25);
  transform: translateY(-1px);
}
.chip{
  transition: transform .12s ease;
}
.chip:hover{transform: translateY(-1px);}
.tag{font-weight:800;letter-spacing:.2px}
.game{
  transition: transform .14s ease, border-color .14s ease;
}
.game:hover{
  transform: translateY(-2px);
  border-color: rgba(122,168,255,.22);
}
.game.disabled:hover{transform:none}
.dialog-tight{
  max-width: 860px;
}
.toast{
  position: fixed;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  max-width: min(920px, calc(100vw - 24px));
  background: rgba(10,16,32,.78);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
  display: none;
  gap: 10px;
  align-items: center;
  z-index: 9999;
}
.toast.show{display:flex}
.toast .t{font-weight:800}
.toast .m{font-size:12px;color:var(--muted)}
.toast .x{
  margin-left:auto;
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  color:var(--text);
  border-radius:10px;
  padding:8px 10px;
  cursor:pointer;
}
/* Make the crash page layout slightly tighter on wide screens */
.layout{gap:var(--s-4)}
.side .card{padding:var(--s-4)}

select{outline:none}


/* P2 UI building blocks */
.grid2{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: var(--s-4);
  padding: var(--s-4);
  max-width: 1120px;
  margin: 0 auto;
}
@media (max-width: 920px){
  .grid2{grid-template-columns:1fr}
}
/* .card base style is defined once above (stage/card shared). Keep HTML simple and avoid duplicate definitions. */
.cardhead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.card .h{font-weight:900; font-size: 16px;}
.card .p{color:var(--muted); font-size: 13px; margin-top:2px;}
.notice{
  background: rgba(122,168,255,.08);
  border: 1px solid rgba(122,168,255,.18);
  border-radius: var(--r-xl);
  padding: var(--s-3);
}
.notice .row{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.notice .k{color:var(--muted); font-size:12px}
.notice .v{font-weight:800}
.hint{
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}
.cards{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
}
@media (max-width: 920px){ .cards{grid-template-columns:repeat(2,1fr)} }
.kpi{
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: var(--s-3);
}
.kpi .k{color:var(--muted); font-size:12px}
.kpi .v{font-size: 22px; font-weight: 950; margin-top: 4px; letter-spacing: .2px;}
.kpi .s{color:var(--muted); font-size:12px; margin-top:2px}


/* P2.4 - Crash UI polish: history strip + chat */
.history-strip{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(255,255,255,.02);
  margin-top:12px;
}
.history-strip .chip{
  padding:6px 10px;
  border-radius:999px;
  font-weight:700;
  letter-spacing:.2px;
}

.card.chat .chatlog{
  height:220px;
  overflow:auto;
  padding:10px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(0,0,0,.18);
}
.chatmsg{ display:flex; gap:8px; margin:6px 0; }
.chatmsg .nick{ font-weight:700; }
.chatmsg .nick.bot{ color:var(--warn); }
.chatmsg .txt{ color:var(--text); opacity:.92; }
.chatmsg.system .txt{ color:var(--good); font-weight:700; }
.chatmsg.system.bad .txt{ color:var(--bad); font-weight:700; }
.chatbar{ margin-top:10px; display:flex; flex-direction:column; gap:10px; }
.reactions{ display:flex; gap:8px; flex-wrap:wrap; }
.chipbtn{
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  color:var(--text);
  padding:6px 10px;
  border-radius:999px;
  cursor:pointer;
}
.chipbtn:hover{ background:rgba(255,255,255,.10); }
.chatrow{ display:flex; gap:10px; }
.btn.small{ padding:10px 14px; border-radius:12px; }

.table .betrow{ align-items:center; }
.betrow .u::after{
  content:'';
}


/* P2.6 - Crash visual UX */
.phase-ui{
  position:absolute;
  top:14px;
  left:14px;
  right:14px;
  display:flex;
  gap:12px;
  align-items:center;
  pointer-events:none;
}
.phase-ui .badge{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.35);
  font-weight:800;
  letter-spacing:.6px;
}
.phase-ui .bar{
  flex:1;
  height:10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  overflow:hidden;
}
.phase-ui .bar .fill{
  height:100%;
  width:0%;
  background:rgba(255,255,255,.25);
}
.bigwin{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:44px;
  font-weight:900;
  letter-spacing:2px;
  background:radial-gradient(circle at center, rgba(255,255,255,.08), rgba(0,0,0,0));
  text-shadow:0 0 24px rgba(255,255,255,.25);
  animation: pop 900ms ease-out;
  pointer-events:none;
}
@keyframes pop{
  0%{ transform:scale(.92); opacity:0; }
  20%{ opacity:1; }
  100%{ transform:scale(1.02); opacity:0; }
}

.betrow.win{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); }
.betrow.loss{ background:rgba(255,0,0,.06); border:1px solid rgba(255,0,0,.18); }
.betrow.bot{ opacity:.92; }

.pulse{ animation: pulse 900ms ease-out; }
@keyframes pulse{ 0%{ transform:scale(1); } 35%{ transform:scale(1.03); } 100%{ transform:scale(1); } }

.glitch{
  animation: glitch 420ms linear;
}
@keyframes glitch{
  0%{ filter:none; transform:none; }
  25%{ filter:contrast(1.2) saturate(1.2); transform:translateX(2px); }
  50%{ filter:contrast(1.5); transform:translateX(-3px); }
  100%{ filter:none; transform:none; }
}


/* P2.7 - Live feed + bet lock UX */
.feedlog{
  height:140px;
  overflow:auto;
  padding:10px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(0,0,0,.18);
}
.feedline{ display:flex; gap:8px; margin:6px 0; }
.feedline .t{ color:var(--muted); font-size:12px; min-width:54px; }
.feedline .m{ color:var(--text); font-weight:700; }
.feedline.bad .m{ color:var(--bad); }
.feedline.good .m{ color:var(--good); }

.btn[disabled]{ opacity:.55; cursor:not-allowed; }
.input[disabled]{ opacity:.6; }


/* P2.8 - Round recap */
#recap{ display:none; }
.recap-grid{ display:flex; gap:12px; margin-top:10px; }
.recap-item{ flex:1; padding:10px; border:1px solid var(--line); border-radius:14px; background:rgba(0,0,0,.16); }
.recap-item .big{ font-size:22px; font-weight:900; margin-top:4px; }
.toplist{ margin-top:8px; display:flex; flex-direction:column; gap:6px; }
.toprow{ display:flex; justify-content:space-between; padding:8px 10px; border:1px solid var(--line); border-radius:12px; background:rgba(255,255,255,.03); }
.toprow .u{ font-weight:800; }
.toprow .x{ color:var(--muted); font-weight:700; }

/* Tutorial modal */
.tutorial-modal{
 position:fixed; inset:0; background:rgba(0,0,0,.6);
 display:none; align-items:center; justify-content:center; z-index:9999;
}
.tutorial-box{
 background:#0b0f1a; border:1px solid #2b3348; border-radius:16px;
 padding:24px; width:420px; max-width:90%;
}
.tutorial-title{ font-size:22px; font-weight:900; margin-bottom:12px; }
.tutorial-steps{ margin-left:18px; display:flex; flex-direction:column; gap:8px; }
.tutorial-tip{ margin-top:12px; color:#9aa4c6; font-style:italic; }


/* P3 - i18n switch + guided tour + tips */
.lang-switch{ display:flex; gap:8px; margin-left:auto; }
.lang-switch .chipbtn{ padding:8px 10px; }

.tour-overlay{
  position:fixed; inset:0; z-index:10000;
  background:rgba(0,0,0,.62);
}
.tour-hole{
  position:absolute;
  border-radius:16px;
  box-shadow: 0 0 0 9999px rgba(0,0,0,.62);
  outline: 1px solid rgba(255,255,255,.18);
  pointer-events:none;
}
.tour-box{
  position:absolute;
  width:320px;
  background:#0b0f1a;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
}
.tour-title{ font-size:16px; font-weight:900; margin-bottom:8px; }
.tour-body{ color:var(--muted); font-weight:650; line-height:1.35; }
.tour-btns{ display:flex; gap:8px; justify-content:flex-end; margin-top:12px; }
.btn.btn-ghost{
  background:transparent;
  border:1px solid rgba(255,255,255,.14);
}

.tip-banner{
  position:absolute;
  right:14px;
  bottom:14px;
  max-width:320px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.35);
  color:var(--text);
  font-weight:800;
  display:none;
  pointer-events:none;
}
.tip-banner .tiny{ color:var(--muted); font-weight:700; }

/* P3.5 status chips */
.status-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.25);
}
.status-chip::before{ content:''; width:8px; height:8px; border-radius:999px; background:rgba(255,255,255,.35); }
.status-chip.ok::before{ background:rgba(90,200,120,.95); }
.status-chip.warn::before{ background:rgba(240,200,90,.95); }
.status-chip.bad::before{ background:rgba(240,90,90,.95); }
.status-chip.dim{ opacity:.85; }

/* P3.7 Lobby polish */
.hero-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.hero-search{margin-top:12px}
.search{
  width:100%;
  max-width:520px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
}
.search:focus{border-color:rgba(140,255,178,.35); box-shadow:0 0 0 3px rgba(140,255,178,.08);}
.section-head{display:flex;align-items:center;justify-content:space-between;margin:12px 0 10px}
.section-title{font-size:13px;font-weight:900;letter-spacing:.4px;text-transform:uppercase;color:rgba(255,255,255,.85)}
.featured{margin-bottom:10px}
.feature-card{
  padding:14px;
  border:1px solid var(--line);
  border-radius:18px;
  background:radial-gradient(1200px 420px at 20% 0%, rgba(90,140,255,.20), transparent 60%),
             radial-gradient(900px 420px at 80% 0%, rgba(180,120,255,.18), transparent 55%),
             linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.feature-top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.feature-name{font-size:16px;font-weight:1000}
.feature-desc{font-size:12px;color:var(--muted);margin-top:6px;max-width:900px}
.feature-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.chip{
  font-size:11px;
  padding:4px 9px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.16);
}

/* P3.7 Crash bet presets */
.presets{display:flex;flex-direction:column;gap:6px; margin:6px 0 2px}
.preset-row{display:flex;gap:8px;flex-wrap:wrap}
.chipbtn{
  padding:7px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  color:var(--text);
  font-weight:900;
  cursor:pointer;
}
.chipbtn:hover{border-color:rgba(122,168,255,.35); background:rgba(122,168,255,.10)}
.chipbtn.active{
  border-color: rgba(122,168,255,.45);
  background: rgba(122,168,255,.14);
}
.chipbtn:active{transform:translateY(1px)}
.chipbtn.ghosty{opacity:.92}

/* P3.8 lobby last multipliers strip */
.last-mults{ margin-bottom:14px; }
.mult-strip{ display:flex; flex-wrap:wrap; gap:8px; }
.mult-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  letter-spacing:.2px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
}
.mult-pill.m2{ border-color: rgba(120,220,160,.25); background: rgba(60,180,120,.10); }
.mult-pill.m3{ border-color: rgba(120,200,255,.25); background: rgba(70,140,240,.10); }
.mult-pill.m10{ border-color: rgba(255,190,120,.25); background: rgba(240,160,60,.10); }

/* P3.8 responsive + top-casino bet slip */
.controls.bet-slip{ border:1px solid rgba(255,255,255,.10); border-radius:14px; background: rgba(0,0,0,.18); padding:12px; }
.betslip-handle{display:none;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.betslip-handle .grab{flex:1;height:4px;border-radius:999px;background:rgba(255,255,255,.14)}
.controls.bet-slip.collapsed{max-height:72px;overflow:hidden}
.controls.bet-slip.collapsed .field,
.controls.bet-slip.collapsed .presets,
.controls.bet-slip.collapsed #cashout,
.controls.bet-slip.collapsed #place-bet{display:none}
.controls.bet-slip.collapsed .betslip-handle{display:flex;margin-bottom:0}
.controls.bet-slip .preset-row{ display:flex; gap:8px; flex-wrap:wrap; }
.controls.bet-slip .chipbtn.active{ outline:2px solid rgba(130,200,255,.45); }
.controls.bet-slip .btn{ height:44px; border-radius:12px; }
.controls.bet-slip input{ height:44px; border-radius:12px; }

/* Tablet & below: stack layout */
@media (max-width: 980px){
  main.layout{ grid-template-columns: 1fr; gap: 14px; }
  aside.side{ order: 2; }
  section.stage{ order: 1; }
}

/* Mobile: bet slip + fixed main buttons so Place bet / Cash out always visible */
@media (max-width: 820px){
  section.stage{ padding-bottom: 140px; }
  .controls.bet-slip{
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: calc(72px + 12px + env(safe-area-inset-bottom, 0px));
    z-index: 50;
    box-shadow: 0 16px 40px rgba(0,0,0,.55);
    backdrop-filter: blur(10px);
    max-height: 40vh;
    overflow: auto;
    padding-bottom: 8px;
  }
  .controls.bet-slip .autobet-box,
  .controls.bet-slip #auto-presets{ display: none !important; }
  .controls.bet-slip #place-bet,
  .controls.bet-slip #cashout{
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    z-index: 51;
    width: calc(50% - 14px);
    max-width: 200px;
    height: 48px;
    margin: 0;
    border-radius: 12px;
    font-weight: 800;
    box-sizing: border-box;
  }
  .controls.bet-slip #place-bet{ right: auto; }
  .controls.bet-slip #cashout{ left: auto; right: 12px; }
  .betslip-handle{display:flex;}
  .controls.bet-slip.collapsed{max-height:72px;overflow:hidden}
  .controls.bet-slip.collapsed #place-bet,
  .controls.bet-slip.collapsed #cashout{ display: inline-flex !important; }
  .controls.bet-slip .preset-row{ flex-wrap: nowrap; overflow-x: auto; padding-bottom: 6px; }
  .controls.bet-slip .preset-row::-webkit-scrollbar{ height: 6px; }
  .controls.bet-slip .preset-row::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.12); border-radius: 999px; }
  .controls.bet-slip .field{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
  .controls.bet-slip label{ min-width: 120px; }
}

/* Small phones */
@media (max-width: 420px){
  .controls.bet-slip label{ min-width: 96px; }
  .controls.bet-slip .btn{ height:42px; }
}

/* Short laptop screens: keep controls visible without hiding the fold */
@media (max-height: 820px) and (min-width: 821px){
  .controls.bet-slip{ position: sticky; bottom: 12px; }
  canvas#crash-canvas{ max-height: 360px; }
}

/* P3.9 rooms + one-hand + micro animations */
.roombar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.roomlabel{ font-weight:900; opacity:.9; }
.room-switch{ display:flex; gap:8px; flex-wrap:wrap; }
.onehand{ display:flex; align-items:center; gap:8px; font-size:12px; font-weight:800; opacity:.9; user-select:none; }
.onehand input{ width:16px; height:16px; }

.room-cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap:12px; margin-bottom:14px; }
.room-card{
  display:flex; flex-direction:column; gap:6px;
  padding:14px; border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  text-decoration:none;
}
.room-card:hover{ border-color: rgba(130,200,255,.28); transform: translateY(-1px); }
.rc-title{ font-weight:1000; letter-spacing:.2px; }
.rc-sub{ font-size:12px; opacity:.75; }

@media (max-width: 820px){
  .room-cards{ grid-template-columns: 1fr; }
  .roombar{ position:sticky; top:0; padding:10px 0; background: linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,0)); z-index:30; }
  body.onehand .controls.bet-slip{
    left: 8px; right: 8px; bottom: calc(8px + env(safe-area-inset-bottom, 0px));
  }
  body.onehand .controls.bet-slip label{ min-width: 92px; }
  body.onehand .controls.bet-slip .btn{ height:48px; }
}

/* Micro animations */
@keyframes pop {
  0%{ transform: scale(.92); opacity:.0; }
  70%{ transform: scale(1.03); opacity:1; }
  100%{ transform: scale(1.0); opacity:1; }
}
.toast{ animation: pop .18s ease-out; }
.winflash{
  position:absolute; inset:0;
  pointer-events:none;
  background: radial-gradient(circle at 50% 40%, rgba(120,220,160,.20), rgba(0,0,0,0) 55%);
  opacity:0;
  transition: opacity .18s ease;
}
.winflash.on{ opacity:1; }


/* Utilities */
.row{ display:flex; align-items:center; gap: var(--s-2); }
.col{ display:flex; flex-direction:column; gap: var(--s-2); }
.spread{ display:flex; align-items:center; justify-content:space-between; gap: var(--s-2); }
.muted{ color: var(--muted); }

/* ---------------- Lobby v2 (production-style) ---------------- */
.lobby-operator{display:none}
.lobby-operator.show{display:inline-flex}

.hero-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}
.kpi{border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.12);border-radius:14px;padding:10px 12px}
.kpi .k{font-size:12px;opacity:.72}
.kpi .v{font-size:16px;font-weight:800;margin-top:4px}

.hero-strip{margin-top:12px;border-top:1px solid rgba(255,255,255,.08);padding-top:12px}
.hero-extra{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hero-extra .mini{border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px;background:rgba(255,255,255,.02)}
.hero-extra .mini-title{font-size:12px;color:rgba(255,255,255,.7);margin-bottom:8px}
.hero-extra .mini-body{font-size:13px;line-height:1.35}
.strip-title{font-weight:800;margin-bottom:8px}
.strip{display:flex;gap:8px;flex-wrap:wrap}
.strip-sub{margin-top:8px;font-size:12px;opacity:.7}

.lobby-section{margin-top:16px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin:0 0 10px}
.sec-title{font-size:16px;font-weight:900}
.sec-sub{opacity:.72;font-size:13px;margin-top:4px}

.tables{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media (max-width: 980px){.tables{grid-template-columns:1fr}}

.table-card{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:10px}
.table-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.table-name{font-weight:900;font-size:15px}
.table-sub{opacity:.72;font-size:13px;margin-top:4px}
.table-right{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.limits{display:flex;gap:10px}
.lim{border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.12);border-radius:12px;padding:8px 10px;min-width:92px;text-align:right}
.lim .k{display:block;font-size:11px;opacity:.7}
.lim .v{display:block;font-weight:900}
.table-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}
.table-foot{border-top:1px solid rgba(255,255,255,.06);padding-top:10px;margin-top:2px}



/* Auto-bet */
.autobet-box{ margin-top:10px; padding-top:10px; border-top:1px solid rgba(255,255,255,.06); }
.autobet-row{ display:flex; gap:10px; align-items:flex-end; flex-wrap:wrap; }
.field.mini{ width:120px; }
#autobet-status{ margin-top:6px; min-height:16px; }
.switch{ position:relative; display:inline-block; width:44px; height:24px; }
.switch input{ opacity:0; width:0; height:0; }
.slider{ position:absolute; cursor:pointer; top:0; left:0; right:0; bottom:0;
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.12); transition:.2s; border-radius:24px; }
.slider:before{ position:absolute; content:""; height:18px; width:18px; left:3px; top:2px;
  background:rgba(255,255,255,.75); transition:.2s; border-radius:50%; }
.switch input:checked + .slider{ background:rgba(88, 214, 141, .25); border-color:rgba(88,214,141,.35); }
.switch input:checked + .slider:before{ transform:translateX(20px); }


/* Challenges */
#challenges-card{display:block}
.ch-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.ch-item{border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:10px 12px;background:rgba(255,255,255,.03)}
.ch-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ch-name{font-weight:800}
.ch-reward{font-size:12px;opacity:.85;white-space:nowrap}
.ch-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden;margin-top:8px}
.ch-bar > div{height:100%;width:0%;background:rgba(120,200,255,.75)}
.ch-meta{display:flex;justify-content:space-between;gap:10px;margin-top:6px}
.ch-meta .tiny{opacity:.8}
.ch-done{border-color:rgba(120,255,180,.35);background:rgba(120,255,180,.06)}
.ch-done .ch-name{color:rgba(120,255,180,.95)}

/* Confetti */
.confetti-wrap{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:9999}
.confetti{position:absolute;top:-12px;width:10px;height:10px;border-radius:2px;opacity:.9;animation:confetti-fall 1200ms linear forwards}
@keyframes confetti-fall{to{transform:translateY(110vh) rotate(480deg);opacity:0.9}}

/* Multiplier pop */
.mult.pop{animation:mult-pop 220ms ease-out}
@keyframes mult-pop{0%{transform:scale(1)}50%{transform:scale(1.07)}100%{transform:scale(1)}}

/* Rocket boost pulse */
.rocket-boost{filter:drop-shadow(0 0 10px rgba(120,200,255,.35))}


/* Missions & Records */
.ms-list, .ch-list { display:flex; flex-direction:column; gap:10px; }
.ms-item, .ch-item{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; padding:10px; border:1px solid rgba(255,255,255,.08);
  border-radius:12px; background:rgba(255,255,255,.03);
}
.ms-left, .ch-left{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.ms-title, .ch-title{ font-weight:600; }
.ms-sub, .ch-sub{ font-size:12px; opacity:.75; }
.ms-progress, .ch-progress{ font-size:12px; opacity:.85; white-space:nowrap; }
.ms-done, .ch-done{ opacity:.55; text-decoration:line-through; }

#records-card .rows{ display:flex; flex-direction:column; gap:8px; margin-top:6px; }
#records-card .row{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
#records-card .progress{ margin-top:10px; }
#records-card .bar{ height:8px; border-radius:999px; overflow:hidden; background:rgba(255,255,255,.08); }
#records-card .fill{ height:100%; width:0%; background:linear-gradient(90deg, rgba(122,215,255,.9), rgba(167,255,203,.9)); }

.streak-float{
  position:absolute; right:14px; top:14px; z-index:5;
  pointer-events:none;
}
.streak-float .pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px; border-radius:999px;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter: blur(10px);
  font-weight:700;
}
.streak-float.bounce .pill{ animation: streakBounce .45s ease-out; }
@keyframes streakBounce{ 0%{ transform:scale(.85); opacity:.6;} 60%{ transform:scale(1.08); opacity:1;} 100%{ transform:scale(1); opacity:1;} }


.ms-header{margin-top:2px; padding:2px 2px; letter-spacing:.08em; text-transform:uppercase;}

/* Fixed26 - Rank badge pill */
.pill.rank{ color: var(--text); font-weight: 800; letter-spacing:.2px; }
.pill.rank.bronze{ background: rgba(205,127,50,.18); border-color: rgba(205,127,50,.35); }
.pill.rank.silver{ background: rgba(192,192,192,.16); border-color: rgba(192,192,192,.35); }
.pill.rank.gold{ background: rgba(255,215,0,.14); border-color: rgba(255,215,0,.35); }

/* Fixed26 - Pro chat UI */
.card.chat .card-title{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.card.chat .chat-tools{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; justify-content:flex-end; }
.card.chat .chatlog{ background: rgba(0,0,0,.16); }
.chatmsg{ display:flex; gap:10px; margin:10px 0; align-items:flex-start; }
.chatmsg .avatar{ width:30px; height:30px; border-radius:999px; display:flex; align-items:center; justify-content:center; border:1px solid var(--line); background: rgba(255,255,255,.05); font-size:14px; }
.chatmsg .avatar.bot{ background: rgba(255,193,122,.12); border-color: rgba(255,193,122,.30); }
.chatmsg .bubble{ flex:1; padding:10px 12px; border-radius:14px; border:1px solid var(--line); background: rgba(255,255,255,.04); }
.chatmsg.system .bubble{ background: rgba(160,255,203,.10); border-color: rgba(160,255,203,.22); }
.chatmsg.system.bad .bubble{ background: rgba(255,122,122,.10); border-color: rgba(255,122,122,.22); }
.chatmsg .meta{ display:flex; align-items:baseline; gap:8px; margin-bottom:4px; }
.chatmsg .nick{ font-weight: 900; letter-spacing:.2px; }
.chatmsg .rankchip{ font-size:12px; padding:2px 8px; border-radius:999px; border:1px solid var(--line); background: rgba(0,0,0,.18); }
.chatmsg .time{ margin-left:auto; font-size:11px; color: var(--muted); }
.chatmsg .txt{ opacity:.95; }

/* Top-tier chat UI */
.chat-head{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%}
.chat-tabs{display:flex;gap:6px;margin-top:8px;overflow-x:auto;white-space:nowrap;padding-bottom:4px}
.chat-tabs::-webkit-scrollbar{height:6px}
.chat-tabs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:999px}
.tabbtn{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:#eaf1ff;padding:6px 10px;border-radius:10px;font-size:12px;cursor:pointer}
.tabbtn.active{background:rgba(117,204,255,.16);border-color:rgba(117,204,255,.35)}
.tabpane{min-height:240px}
.listlog{max-height:320px;overflow:auto;display:flex;flex-direction:column;gap:8px;padding:10px;background:rgba(0,0,0,.12)}
.listitem{display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:8px 10px;border-radius:12px}
.listitem .l{display:flex;flex-direction:column;gap:2px}
.listitem .l .t{font-size:12px;color:#eaf1ff}
.listitem .l .s{font-size:11px;color:rgba(234,241,255,.7)}
.listitem .r{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:12px;color:#eaf1ff;white-space:nowrap}
.pin{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08);background:rgba(255,226,125,.08)}
.pin-text{flex:1;font-size:12px;color:#ffe6a3}
.modbar{padding:10px;border-top:1px dashed rgba(255,255,255,.12)}
.modrow{display:flex;align-items:center;gap:8px;margin-top:6px}
.modrow select{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#eaf1ff;border-radius:10px;padding:6px 8px;font-size:12px}
.mentionwrap{position:relative;flex:1}
.mentionlist{position:absolute;left:0;right:0;bottom:44px;max-height:160px;overflow:auto;background:#0a1020;border:1px solid rgba(255,255,255,.15);border-radius:12px;box-shadow:0 12px 30px rgba(0,0,0,.45);z-index:20}
.mentionitem{padding:8px 10px;cursor:pointer;font-size:12px;color:#eaf1ff;display:flex;align-items:center;justify-content:space-between}
.mentionitem:hover{background:rgba(117,204,255,.12)}
.mentionitem .mrank{opacity:.8}

.emoji-panel{ display:grid; grid-template-columns: repeat(10, 1fr); gap:8px; padding:10px; border:1px solid var(--line); border-radius:14px; background: rgba(0,0,0,.18); }
.emoji-btn{ padding:8px 0; border-radius:12px; border:1px solid var(--line); background: rgba(255,255,255,.05); cursor:pointer; }
.emoji-btn:hover{ background: rgba(255,255,255,.10); }


/* Sound controls */
.sound-ctl{display:flex;align-items:center;gap:8px;margin-right:8px}
.pill.sound{min-width:44px;text-align:center;cursor:pointer}
#sound-volume{width:90px;accent-color:#7bdcff;opacity:.85}
#sound-volume:disabled{opacity:.35}

/* --- Mines --- */
.mines-wrap{display:grid;grid-template-columns: 1fr 280px;gap:16px;align-items:stretch;margin-top:14px}
/* Keep Mines controls from pushing the page down: scroll inside the right column. */
.mines-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;min-height:420px;max-height:calc(100vh - 220px)}
.mines-side{max-height:calc(100vh - 220px);overflow:auto;padding-right:6px}
.mines-side::-webkit-scrollbar{width:6px}
.mines-side::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:999px}
.mine-tile{height:78px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);box-shadow: inset 0 0 0 1px rgba(0,0,0,.15);cursor:pointer;transition:transform .06s ease, background .12s ease}
.mine-tile:hover{transform:translateY(-1px)}
.mine-tile.rev{background:rgba(120,220,255,.10);border-color:rgba(120,220,255,.28)}
.mine-tile.mine{background:rgba(255,80,120,.10);border-color:rgba(255,80,120,.32)}
.mine-tile.safe{background:rgba(120,255,210,.08);border-color:rgba(120,255,210,.24)}
.mine-tile.flip{transform:translateY(-1px) scale(0.98)}
.mine-tile.disabled{opacity:.55;cursor:not-allowed}

/* Turbo mode: snappier tiles + tighter animations */
body.turbo .mine-tile{transition:transform .03s ease, background .06s ease}

/* Mines streak rewards */
.streakbar .streakrow{display:flex;align-items:center;gap:10px;margin:8px 0}
.streakbar .streakrow span{font-size:12px;color:rgba(255,255,255,.8)}
.streakbar .bar{flex:1;height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.streakbar .fill{height:100%;width:0%;background:rgba(120,255,210,.55)}

/* Quick emoji row in chat */
.chat-input .quick{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.chat-input .quick .chipbtn{padding:6px 8px}

/* Chat system messages */
.chat-msg.system{border-left:3px solid rgba(120,220,255,.55);background:rgba(120,220,255,.08)}

/* Mines cosmetics: simple chat frames */
.chat-msg.frame-frame_bronze{border:1px solid rgba(180,120,60,.35)}
.chat-msg.frame-frame_silver{border:1px solid rgba(180,180,190,.45)}
.chat-msg.frame-frame_gold{border:1px solid rgba(210,170,60,.45)}
.chat-msg.frame-frame_neon{border:1px solid rgba(80,200,255,.35);box-shadow:0 0 0 1px rgba(80,200,255,.12)}
.mines-side .field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.mines-side input,.mines-side select{height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);color:#fff;padding:0 12px}
.mines-history{margin-bottom:10px}
.mines-history .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);font-size:12px;line-height:1}
.chip.good{border-color:rgba(120,255,210,.25);background:rgba(120,255,210,.06)}
.chip.bad{border-color:rgba(255,80,120,.25);background:rgba(255,80,120,.06)}
.rowbtns{display:flex;flex-wrap:wrap;gap:8px;margin:-2px 0 10px 0}
.rowbtns .chipbtn{padding:7px 10px}
.soundbar{display:flex;align-items:center;gap:8px}
.soundbar input[type=range]{width:90px;accent-color:#7bdcff;opacity:.85}
.mines-stats{margin:8px 0 12px 0;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04)}
.mines-stats .row{display:flex;justify-content:space-between;gap:10px;margin:6px 0}
.mines-actions{display:flex;flex-direction:column;gap:10px}
.btn.alt{background:rgba(255,255,255,.10)}

@media (max-width: 980px){
  .mines-wrap{grid-template-columns:1fr}
  .mine-tile{height:64px}
}

/* === Layout fixes: keep game panels from stacking & stretching === */
.game-layout{display:grid;grid-template-columns:1fr 420px;gap:16px;align-items:start}

/* Mines v2 (production-style): board left, controls+social right */
.mines2{display:grid;grid-template-columns:1fr 420px;gap:16px;align-items:start}
.mines2-board{min-width:0}
.mines2-side{position:sticky;top:86px;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 110px)}
.mines2-side .card{overflow:hidden}
.mines2-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.mines2-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
.mines2-metrics .mrow{display:flex;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid rgba(255,255,255,.06);border-radius:14px;background:rgba(255,255,255,.03)}
.mines2-metrics .mrow span:last-child{font-weight:700}
.mines2-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:12px}
.mines2-betcard{padding:12px}
.mines2-betcard .bet-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.mines2-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.mines2-actions .ghost{grid-column:1 / span 2}
.mines2-tabs{padding:12px;display:flex;flex-direction:column;min-height:360px}
.mines2-tabs .tabpane{flex:1;min-height:0}
.mines2-tabs .chat{height:260px}
.mines2-tabs .listlog{height:320px}
.mines2-tabs .chat-input{margin-top:10px}
.pgrid{display:grid;grid-template-columns:1fr;gap:12px;padding-top:10px}
.psection{border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:12px;background:rgba(255,255,255,.02)}
.game-main{min-width:0}
.game-side{min-width:0}
@media(max-width:1100px){.game-layout{grid-template-columns:1fr}.game-side{position:static}.mines2{grid-template-columns:1fr}.mines2-side{position:static;max-height:none}}
/* Make right panel scroll internally instead of growing page */
.game-side #side-card{position:sticky;top:86px;max-height:calc(100vh - 110px);overflow:hidden}
.game-side #side-card .tabpane{overflow:auto;max-height:calc(100vh - 320px)}


/* Phase 1: network banner */
.netbar{position:sticky;top:0;z-index:50;display:none;align-items:center;justify-content:center;padding:8px 10px;font-size:13px;background:rgba(255,184,0,.12);border-bottom:1px solid rgba(255,184,0,.35);backdrop-filter: blur(6px);}
.netbar.bad{background:rgba(255,80,80,.12);border-bottom-color:rgba(255,80,80,.35);}
.netbar strong{margin-right:6px;}

/* === Blackjack: one-screen layout (no scroll on laptop), mobile-friendly === */
body.page-blackjack{height:100%;overflow:hidden;display:flex;flex-direction:column;}
body.page-blackjack #app{display:flex;flex-direction:column;max-width:100%;height:100%;padding:8px 12px;margin:0 auto;overflow:hidden;}
body.page-blackjack .topbar{flex-shrink:0;}
body.page-blackjack .netbar{flex-shrink:0;}
body.page-blackjack .game-layout{flex:1;min-height:0;display:flex;flex-direction:column;grid-template-columns:1fr;gap:8px;}
body.page-blackjack .game-layout .card.panel{flex-shrink:0;}
body.page-blackjack .game-layout .bj-table.bj-felt{flex:1;min-height:120px;}
body.page-blackjack .game-layout .bj-actions{flex-shrink:0;}
body.page-blackjack .bj-controls-row{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;}
body.page-blackjack .bj-chips{display:flex;gap:6px;flex-shrink:0;}
body.page-blackjack .bj-chips .chip{cursor:pointer;min-width:44px;}
body.page-blackjack .bj-bet-input{text-align:center;}
body.page-blackjack .bj-history{max-height:60px;overflow:auto;}
body.page-blackjack .bj-history-section{flex-shrink:1;min-height:0;}
@media (max-width:640px){body.page-blackjack .bj-controls-row{flex-wrap:wrap;}}
