/* ===================== Clash — Frozen-night brand restyle =====================
   Visual only — all IDs / classes / game logic unchanged.
   Matches the shared Snowflake "frozen-night sticker" system (theme.css),
   the same look used by Frost Duel, Blackjack, Roulette, Quickdraw, etc.
   ============================================================================ */
:root{
  --bg0:#081C33; --bg1:#0e1426; --bg2:#161f3a;
  --hero:#3DC6F5; --enemy:#FF5D6C;
  --win:#15D6C4; --lose:#FF5D6C;
  --panel:rgba(23,59,99,.72);
  --stroke:rgba(244,250,255,.12);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--font-body,'Nunito',system-ui,-apple-system,sans-serif);
  background:
    radial-gradient(1200px 600px at 50% -10%, var(--bg-grad-1,#123A63), transparent 60%),
    var(--bg,#123254);
  color:var(--cream,#F4FAFF); overflow:hidden; user-select:none;
}
#app{position:fixed;inset:0;display:flex;flex-direction:column}

/* ---- top bar ---- */
#topbar{
  height:60px;flex:0 0 60px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:0 20px;background:rgba(8,28,51,.86);
  border-bottom:3px solid var(--ink,#0A1A2F);backdrop-filter:blur(10px);z-index:30;
}
.topbar-left{display:flex;align-items:center}
/* rolling snowflake -> games menu */
.toolbar-btn{background:none;border:none;padding:4px;cursor:pointer;border-radius:50%;
  display:flex;align-items:center;justify-content:center;position:relative;z-index:301;
  transform:translateX(0);transition:transform .38s cubic-bezier(.22,1,.36,1)}
.toolbar-btn.is-open{transform:translateX(248px)}
.toolbar-icon{font-size:30px;display:block;
  color:var(--ice,#3DC6F5);filter:drop-shadow(0 2px 0 var(--ink,#0A1A2F));
  transition:transform .6s cubic-bezier(.22,1,.36,1);transform-origin:center}
.toolbar-btn:hover .toolbar-icon{transform:rotate(90deg)}
.toolbar-btn.is-open .toolbar-icon{transform:rotate(180deg)}
/* center Snowflake logo -> home */
.topbar-logo{display:flex;align-items:center;gap:9px;text-decoration:none;padding:7px 18px;border-radius:50px;
  border:1px solid transparent;transition:background .2s,border-color .2s,transform .2s}
.topbar-logo:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);transform:translateY(-1px)}
.topbar-logo:active{transform:scale(.97)}
.topbar-logo-icon{font-size:26px;color:var(--ice,#3DC6F5);filter:drop-shadow(0 2px 0 var(--ink,#0A1A2F))}
.topbar-logo-name{font-family:var(--font-display,'Lilita One'),sans-serif;
  font-size:22px;letter-spacing:.5px;color:var(--cream,#F4FAFF)}
.balance-wrap{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}
.balance-label{font-size:10px;letter-spacing:2px;color:var(--cream-dim,#9fb6cc);text-transform:uppercase;font-weight:800}
.balance-amt{font-size:20px;font-family:var(--font-display,'Lilita One'),sans-serif;color:var(--gold,#FFC83D)}

/* ---- games drawer ---- */
.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0);z-index:299;pointer-events:none;transition:background .35s}
.sidebar-backdrop.is-open{background:rgba(0,0,0,.5);pointer-events:auto}
.sidebar{position:fixed;top:0;left:0;width:248px;height:100vh;background:var(--bg-deep,#081C33);
  border-right:3px solid var(--ink,#0A1A2F);box-shadow:6px 0 40px rgba(0,0,0,.6);z-index:300;
  display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .38s cubic-bezier(.22,1,.36,1)}
.sidebar.is-open{transform:translateX(0)}
.sidebar-header{padding:24px 22px 16px;border-bottom:1px solid rgba(255,255,255,.1)}
.sidebar-title{font-family:var(--font-display,'Lilita One'),sans-serif;font-size:.95rem;letter-spacing:.5px;color:var(--ice,#3DC6F5)}
.sidebar-items{display:flex;flex-direction:column;padding:12px;gap:6px;overflow-y:auto}
.td-item{display:flex;align-items:center;gap:14px;padding:13px 16px;text-decoration:none;border-radius:14px;
  color:var(--cream-dim,#9fb6cc);font-size:.95rem;font-weight:800;
  transition:background .16s,color .16s,transform .16s}
.td-item:hover{background:var(--panel,#173B63);color:var(--cream,#F4FAFF);transform:translateX(3px)}
.td-item.td-active{color:var(--ink,#0A1A2F);background:var(--ice,#3DC6F5);border:2.5px solid var(--ink,#0A1A2F)}
.td-icon{font-size:1.2rem;flex-shrink:0}.td-name{flex:1}

/* ---- stage ---- */
#stage{position:relative;flex:1 1 auto;min-height:0}
#scene{position:absolute;inset:0;width:100%;height:100%;display:block}
/* cinematic vignette */
#stage::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:5;
  background:radial-gradient(120% 90% at 50% 38%,rgba(0,0,0,0) 55%,rgba(8,12,24,.45) 100%)}

.namecard{
  position:absolute;transform:translate(-50%,-100%);pointer-events:none;z-index:8;
  background:var(--panel);border:2.5px solid var(--ink,#0A1A2F);border-radius:14px;padding:8px 14px;
  text-align:center;backdrop-filter:blur(6px);box-shadow:0 8px 24px rgba(5,16,30,.5);
  transition:opacity .15s;
}
.namecard .nc-name{font-family:var(--font-display,'Lilita One'),sans-serif;font-size:16px;letter-spacing:.5px;color:var(--cream,#F4FAFF)}
.namecard .nc-role{font-size:11px;color:var(--ice,#3DC6F5);letter-spacing:2px;text-transform:uppercase;font-weight:800}

.pot-hud{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:7;text-align:center;
  pointer-events:none;transition:opacity .25s;
}
.pot-mult{font-family:var(--font-display,'Lilita One'),sans-serif;font-size:48px;line-height:1;
  color:var(--cream,#F4FAFF);text-shadow:0 3px 0 var(--ink,#0A1A2F),0 0 24px rgba(61,198,245,.5)}
.pot-win{font-size:14px;font-weight:800;color:var(--gold,#FFC83D);letter-spacing:1px;margin-top:3px}

.banner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:12;pointer-events:none}
.banner-inner{font-family:var(--font-accent,'Luckiest Guy'),sans-serif;font-size:64px;letter-spacing:3px;text-align:center;
  color:var(--cream,#F4FAFF);-webkit-text-stroke:3px var(--ink,#0A1A2F);paint-order:stroke fill;
  text-shadow:0 6px 0 var(--ink,#0A1A2F),0 10px 30px rgba(5,16,30,.6);
  transform:scale(.6);opacity:0;transition:transform .4s cubic-bezier(.2,1.3,.4,1),opacity .3s}
.banner.show .banner-inner{transform:scale(1);opacity:1}
.banner.win .banner-inner{color:var(--teal,#15D6C4)}
.banner.lose .banner-inner{color:var(--coral,#FF5D6C)}
.banner.jackpot .banner-inner{color:var(--gold,#FFC83D)}

.prompt{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:6;
  font-size:12px;font-weight:800;letter-spacing:2px;color:var(--cream,#F4FAFF);text-transform:uppercase;
  background:var(--panel);border:2.5px solid var(--ink,#0A1A2F);padding:8px 18px;border-radius:999px;backdrop-filter:blur(6px)}

/* ================= action board (bottom ~3/10) ================= */
#board{
  flex:0 0 30vh; min-height:210px; display:flex; flex-direction:column; gap:10px;
  padding:12px 20px 18px; z-index:20;
  background:var(--bg-deep,#081C33);
  border-top:3px solid var(--ink,#0A1A2F);
}
.board-bar{flex:0 0 58px;display:flex;align-items:center;justify-content:space-between;gap:14px}

/* prominent bet panel — gold-accented candy panel */
.bet-group{display:flex;align-items:center;gap:10px;
  background:rgba(255,200,61,.08);border:2.5px solid var(--ink,#0A1A2F);
  border-radius:16px;padding:7px 12px;box-shadow:0 4px 0 rgba(5,16,30,.35)}
.bet-tag{font-family:var(--font-display,'Lilita One'),sans-serif;font-size:13px;letter-spacing:2px;color:var(--gold,#FFC83D);text-transform:uppercase;margin-right:2px}
.bet-step{width:44px;height:42px;border-radius:12px;border:2.5px solid var(--ink,#0A1A2F);
  background:var(--panel,#173B63);color:var(--gold,#FFC83D);
  font-family:var(--font-display,'Lilita One'),sans-serif;font-size:16px;letter-spacing:.5px;cursor:pointer;line-height:1;
  transition:background .14s,border-color .14s,transform .1s}
.bet-step:hover{background:var(--panel-2,#1E4C7E);border-color:var(--gold,#FFC83D);transform:translateY(-1px)}
.bet-step:active{transform:translateY(1px)}
.bet-amount{display:flex;align-items:center;justify-content:center;min-width:104px;height:44px;
  border-radius:12px;background:rgba(8,28,51,.6);border:2.5px solid var(--ink,#0A1A2F)}
.bet-amount:focus-within{border-color:var(--gold,#FFC83D);box-shadow:0 0 0 3px rgba(255,200,61,.2)}
#betInput{width:100px;height:42px;border:none;background:transparent;color:var(--gold,#FFC83D);
  text-align:center;font-family:var(--font-display,'Lilita One'),sans-serif;font-size:26px;letter-spacing:.5px;outline:none}
.bet-quick{display:flex;gap:6px;margin-left:4px}
.bet-quick button{height:36px;padding:0 14px;border-radius:10px;border:2.5px solid var(--ink,#0A1A2F);background:var(--panel,#173B63);
  color:var(--cream,#F4FAFF);font-family:var(--font-display,'Lilita One'),sans-serif;font-size:14px;cursor:pointer;
  transition:background .15s,border-color .15s,transform .1s}
.bet-quick button:hover{background:var(--panel-2,#1E4C7E);transform:translateY(-1px)}
.bet-quick button[data-bet="max"]{border-color:var(--gold,#FFC83D);color:var(--gold,#FFC83D)}
.bet-group.locked{opacity:.45;pointer-events:none;filter:saturate(.6)}

/* cash-out keycap — chunky candy gold button */
.cap-mini{height:52px;padding:0 34px;border:3.5px solid var(--ink,#0A1A2F);border-radius:16px;cursor:pointer;
  font-family:var(--font-display,'Lilita One'),sans-serif;font-size:18px;letter-spacing:.6px;color:var(--ink,#0A1A2F);text-transform:uppercase;
  background:var(--gold,#FFC83D);
  box-shadow:inset 0 3px 0 rgba(255,255,255,.5),inset 0 -5px 0 rgba(0,0,0,.16),0 6px 0 0 var(--gold-deep,#E0A21F),0 12px 18px rgba(5,16,30,.4);
  transition:transform .1s,box-shadow .1s,filter .14s;
  animation:cashPulse 1.25s ease-in-out infinite}
.cap-mini:hover{transform:translateY(-2px) scale(1.02);animation:none}
.cap-mini:active{transform:translateY(4px);box-shadow:inset 0 3px 0 rgba(255,255,255,.5),0 2px 0 0 var(--gold-deep,#E0A21F);animation:none}
@keyframes cashPulse{
  0%,100%{box-shadow:inset 0 3px 0 rgba(255,255,255,.5),inset 0 -5px 0 rgba(0,0,0,.16),0 6px 0 0 var(--gold-deep,#E0A21F),0 12px 18px rgba(5,16,30,.4)}
  50%    {box-shadow:inset 0 3px 0 rgba(255,255,255,.5),inset 0 -5px 0 rgba(0,0,0,.16),0 6px 0 0 var(--gold-deep,#E0A21F),0 14px 30px rgba(255,200,61,.6)}
}

/* ---- character keycaps ---- */
.champ-row{flex:1 1 auto;display:flex;gap:18px;align-items:stretch;min-height:0}
.keycap{
  flex:1 1 0; min-width:0; position:relative; cursor:pointer; overflow:hidden;
  border:3.5px solid var(--ink,#0A1A2F); border-radius:22px; color:var(--cream,#F4FAFF); font-family:inherit;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px;
  background:linear-gradient(180deg,var(--top),var(--base));
  box-shadow:inset 0 4px 0 rgba(255,255,255,.28), 0 10px 0 var(--side), 0 16px 24px rgba(5,16,30,.5);
  transition:transform .08s ease, box-shadow .08s ease, filter .14s;
}
.keycap::before{content:"";position:absolute;left:10px;right:10px;top:9px;height:42%;border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.35),rgba(255,255,255,0));pointer-events:none}
.keycap:hover{filter:brightness(1.06);transform:translateY(-2px);box-shadow:inset 0 4px 0 rgba(255,255,255,.28),0 12px 0 var(--side),0 18px 26px rgba(5,16,30,.5)}
.keycap:active,.keycap.pressed{transform:translateY(8px);box-shadow:inset 0 4px 0 rgba(255,255,255,.28),0 2px 0 var(--side),0 5px 10px rgba(5,16,30,.45)}
.keycap[disabled]{cursor:default;filter:grayscale(.5) brightness(.62);box-shadow:0 6px 0 var(--side),0 9px 14px rgba(5,16,30,.4);transform:none}
.keycap.active-pick{outline:4px solid var(--gold,#FFC83D);outline-offset:-4px}
.kc-name{position:relative;font-family:var(--font-display,'Lilita One'),sans-serif;font-size:clamp(18px,2.4vw,30px);letter-spacing:.5px;text-shadow:0 2px 0 rgba(0,0,0,.3)}
.kc-role{position:relative;font-size:clamp(10px,1.1vw,13px);font-weight:800;letter-spacing:2px;text-transform:uppercase;opacity:.92}
.key-henry{    --top:#5AD2F5; --base:#1C97C4; --side:#125E7E}
.key-alexander{--top:#FF6E7B; --base:#D63B58; --side:#8C2236}
.key-plato{    --top:#A488FF; --base:#6A49E0; --side:#41299C}

/* ---- info button + rules modal ---- */
.info-btn{
  position:absolute;right:16px;bottom:16px;z-index:9;
  width:46px;height:46px;border-radius:50%;cursor:pointer;
  border:3px solid var(--ink,#0A1A2F);background:var(--ice,#3DC6F5);color:var(--ink,#0A1A2F);
  font-family:var(--font-display,'Lilita One'),serif;font-size:24px;line-height:1;font-style:italic;
  box-shadow:inset 0 2px 0 rgba(255,255,255,.45),0 5px 0 var(--ice-deep,#1C97C4),0 10px 16px rgba(5,16,30,.45);
  transition:transform .1s,box-shadow .1s,filter .14s}
.info-btn:hover{transform:translateY(-2px);filter:brightness(1.06)}
.info-btn:active{transform:translateY(4px);box-shadow:inset 0 2px 0 rgba(255,255,255,.45),0 1px 0 var(--ice-deep,#1C97C4),0 4px 8px rgba(5,16,30,.4)}

.info-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:20px}
.info-backdrop{position:absolute;inset:0;background:rgba(5,16,30,.62);backdrop-filter:blur(3px)}
.info-card{
  position:relative;z-index:1;width:100%;max-width:480px;max-height:88vh;overflow-y:auto;
  background:var(--bg-deep,#081C33);border:3.5px solid var(--ink,#0A1A2F);border-radius:24px;
  padding:26px 26px 22px;box-shadow:0 22px 48px rgba(5,16,30,.6);
  animation:infoPop .22s cubic-bezier(.2,1.3,.4,1)}
@keyframes infoPop{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.info-close{position:absolute;top:14px;right:16px;width:34px;height:34px;border-radius:10px;cursor:pointer;
  border:2.5px solid var(--ink,#0A1A2F);background:var(--panel,#173B63);color:var(--cream,#F4FAFF);
  font-size:22px;line-height:1;transition:background .14s,transform .1s}
.info-close:hover{background:var(--coral,#FF5D6C);color:var(--ink,#0A1A2F)}
.info-title{font-family:var(--font-display,'Lilita One'),sans-serif;font-size:1.7rem;color:var(--gold,#FFC83D);
  letter-spacing:.5px;margin:2px 0 16px;padding-right:36px}
.info-steps{margin:0 0 18px;padding-left:22px;display:flex;flex-direction:column;gap:9px}
.info-steps li{color:var(--cream,#F4FAFF);font-size:.96rem;line-height:1.45}
.info-steps b{color:var(--ice,#3DC6F5)}
.info-sub{font-family:var(--font-display,'Lilita One'),sans-serif;font-size:.8rem;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--cream-dim,#9fb6cc);margin-bottom:10px}
.info-matchups{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.mu-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:var(--panel,#173B63);border:2px solid var(--ink,#0A1A2F);border-radius:14px;padding:9px 12px}
.mu-hero{font-family:var(--font-display,'Lilita One'),sans-serif;font-size:.92rem;color:var(--ink,#0A1A2F);
  border:2px solid var(--ink,#0A1A2F);border-radius:999px;padding:3px 12px}
.hero-henry{background:#5AD2F5}.hero-alexander{background:#FF6E7B}.hero-plato{background:#A488FF}
.mu-vs{font-size:.74rem;letter-spacing:1px;text-transform:uppercase;color:var(--cream-dim,#9fb6cc);font-weight:800}
.mu-foe{font-weight:800;color:var(--coral,#FF5D6C)}
.info-note{color:var(--cream-dim,#9fb6cc);font-size:.86rem;line-height:1.5;margin:0 0 18px}
.info-note b{color:var(--gold,#FFC83D)}
.info-got{display:block;width:100%;height:48px;cursor:pointer;
  border:3.5px solid var(--ink,#0A1A2F);border-radius:16px;background:var(--gold,#FFC83D);color:var(--ink,#0A1A2F);
  font-family:var(--font-display,'Lilita One'),sans-serif;font-size:1.1rem;letter-spacing:.5px;text-transform:uppercase;
  box-shadow:inset 0 3px 0 rgba(255,255,255,.5),inset 0 -5px 0 rgba(0,0,0,.16),0 6px 0 0 var(--gold-deep,#E0A21F);
  transition:transform .1s,box-shadow .1s}
.info-got:hover{transform:translateY(-2px) scale(1.01)}
.info-got:active{transform:translateY(4px);box-shadow:inset 0 3px 0 rgba(255,255,255,.5),0 2px 0 0 var(--gold-deep,#E0A21F)}

.hidden{display:none !important}

/* ---- loading ---- */
.loading{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:var(--bg-deep,#081C33);z-index:50;color:var(--cream-dim,#9fb6cc);letter-spacing:2px;font-size:13px;font-weight:800;transition:opacity .5s}
.loading.gone{opacity:0;pointer-events:none}
.spinner{width:42px;height:42px;border-radius:50%;border:4px solid rgba(244,250,255,.14);border-top-color:var(--ice,#3DC6F5);
  animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
