:root{
  --bg:#0a0618;
  --bg2:#160a2e;
  --panel:rgba(22,10,46,.85);
  --panel2:rgba(36,16,70,.7);
  --ink:#f5f3ff;
  --muted:#a9a0c9;
  --line:rgba(139,92,246,.35);
  --pink:#ff2e63;
  --purple:#8b5cf6;
  --cyan:#22d3ee;
  --blue:#818cf8;
  --green:#22c55e;
  --gold:#fbbf24;
  --text:#f5f3ff;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{
  font-family:'Fredoka','Baloo 2','Comic Sans MS',system-ui,-apple-system,sans-serif;
  font-weight:600;
  background:radial-gradient(circle at 20% 10%,#241046,var(--bg) 60%);
  color:var(--text);
  user-select:none;
  touch-action:none;
}
#app{position:fixed;inset:0}

/* ---------- screens ---------- */
.screen{
  position:absolute;inset:0;
  display:none;flex-direction:column;align-items:center;justify-content:center;
  padding:20px;
  animation:fadeIn .35s ease;
}
.screen.active{display:flex}
#screen-select.active{justify-content:flex-start;padding-top:12px;overflow-y:auto}
@keyframes fadeIn{from{opacity:0;transform:scale(.98)}to{opacity:1;transform:none}}

/* ---------- animated background blobs ---------- */
.bg-blobs{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.bg-blobs span{
  position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;
  animation:float 12s ease-in-out infinite;
}
.bg-blobs span:nth-child(1){width:280px;height:280px;background:var(--purple);top:-60px;left:-40px}
.bg-blobs span:nth-child(2){width:240px;height:240px;background:var(--pink);bottom:-50px;right:-30px;animation-delay:-3s}
.bg-blobs span:nth-child(3){width:200px;height:200px;background:var(--cyan);top:40%;left:60%;animation-delay:-6s}
.bg-blobs span:nth-child(4){width:180px;height:180px;background:var(--gold);top:20%;left:20%;animation-delay:-9s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.15)}66%{transform:translate(-30px,20px) scale(.9)}}

/* ---------- panel ---------- */
.panel{
  position:relative;z-index:1;
  width:min(420px,92vw);
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px 24px;
  text-align:center;
  backdrop-filter:blur(10px);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.panel.wide{width:min(520px,94vw)}
.panel.glow{box-shadow:0 0 60px rgba(139,92,246,.35),0 20px 60px rgba(0,0,0,.5)}

.logo{
  font-size:2.8rem;font-weight:700;letter-spacing:1px;line-height:.95;
  background:linear-gradient(90deg,var(--pink),var(--gold),var(--cyan));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:hue 6s linear infinite;
}
.logo span{display:block}
@keyframes hue{to{filter:hue-rotate(360deg)}}
.subtitle{color:var(--muted);margin:10px 0 22px;font-size:.98rem;font-weight:600}
.rmb-ticker{display:inline-block;margin:0 auto 20px;padding:9px 18px;border-radius:14px;font-weight:700;font-size:.92rem;letter-spacing:.5px;text-decoration:none;color:#12061f;background:linear-gradient(90deg,var(--gold),#ffe08a);box-shadow:0 4px 16px rgba(251,182,46,.55);transition:transform .12s,filter .15s;animation:pulseTag 2s ease-in-out infinite}
.rmb-ticker:hover{transform:translateY(-2px);filter:brightness(1.06)}

/* ---------- form ---------- */
.field{text-align:left;margin-bottom:16px}
.field label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:6px;font-weight:700}
.field label em{color:var(--pink);font-style:normal}
.field input{
  width:100%;padding:14px 16px;font-size:1rem;font-family:inherit;font-weight:600;
  background:rgba(10,6,24,.6);border:2px solid var(--line);border-radius:14px;
  color:var(--text);outline:none;transition:.2s;
}
.field input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.2)}
.error{color:#ff5c8a;min-height:18px;font-size:.9rem;margin:4px 0 10px;font-weight:700}
.fineprint{color:var(--muted);font-size:.75rem;margin-top:12px}

/* ---------- buttons ---------- */
.btn{
  font-family:inherit;font-weight:700;cursor:pointer;border:none;border-radius:16px;
  padding:14px 22px;font-size:1.05rem;letter-spacing:.5px;text-transform:uppercase;
  transition:transform .12s,box-shadow .18s,filter .18s;
}
.btn-primary{
  width:100%;color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  box-shadow:0 8px 24px rgba(139,92,246,.5);
}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.5);transform:none}
.btn-primary.big{margin-top:18px;font-size:1.2rem;padding:16px}
.btn-ghost{background:rgba(139,92,246,.14);color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{background:rgba(139,92,246,.26)}
.btn.small{padding:8px 12px;font-size:1.1rem}

/* ---------- select screen ---------- */
.topbar{position:relative;width:100%;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;margin-bottom:8px;z-index:2}
.who{font-size:1rem;color:var(--text);font-weight:700}
.who b{color:var(--gold)}
.section-title{
  font-size:1.9rem;font-weight:700;margin-bottom:14px;text-align:center;letter-spacing:1px;
  background:linear-gradient(90deg,var(--pink),var(--cyan));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.coin-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;
  width:min(680px,94vw);max-height:58vh;overflow-y:auto;padding:6px;
}
.coin-card{
  position:relative;cursor:pointer;border-radius:18px;padding:14px 10px;text-align:center;
  background:var(--panel);border:2px solid var(--line);transition:.15s;overflow:hidden;
}
.coin-card:hover{transform:translateY(-4px);border-color:var(--cyan)}
.coin-card.selected{border-color:var(--gold);box-shadow:0 0 24px rgba(251,191,36,.5)}
.coin-card .avatar{width:64px;height:64px;margin:0 auto;display:flex;align-items:center;justify-content:center;font-size:2.4rem;line-height:1;border-radius:50%;overflow:hidden;background:rgba(10,6,24,.5);filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));animation:bob 2.5s ease-in-out infinite}
.coin-card .avatar img{width:100%;height:100%;object-fit:cover;display:block}
.live-tag{position:absolute;top:8px;right:8px;font-size:.55rem;font-weight:700;letter-spacing:.5px;color:#12061f;background:linear-gradient(90deg,var(--green),var(--cyan));padding:2px 7px;border-radius:10px;animation:pulseTag 1.4s ease-in-out infinite}
@keyframes pulseTag{50%{opacity:.5}}
.grid-empty{grid-column:1/-1;color:var(--muted);padding:40px 10px;text-align:center;font-size:.95rem;font-weight:600}
.section-sub{color:var(--muted);font-size:.85rem;margin:-6px 0 16px;text-align:center;font-weight:600}
.topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.feed-status{font-size:.72rem;font-weight:700;color:var(--muted);background:rgba(10,6,24,.5);border:1px solid var(--line);border-radius:12px;padding:5px 9px;white-space:nowrap}
.feed-status.live{color:var(--green);border-color:var(--green);animation:pulseTag 1.6s ease-in-out infinite}

/* ---------- character hub ---------- */
#pick-mode,#char-hub{display:flex;flex-direction:column;align-items:center;width:100%}
.hidden{display:none!important}
.hub-wrap{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;width:min(620px,94vw);margin-bottom:16px}
.hub-card{flex:1 1 200px;min-width:200px;background:var(--panel);border:2px solid var(--line);border-radius:22px;padding:18px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}
.hub-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;background:rgba(10,6,24,.5);box-shadow:0 0 22px rgba(139,92,246,.5);animation:bob 2.6s ease-in-out infinite}
.hub-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.hub-ticker{font-weight:700;font-size:1.25rem;margin-top:8px}
.hub-name{color:var(--muted);font-size:.85rem;font-weight:600}
.hub-locked{margin-top:6px;font-size:.72rem;color:var(--gold);font-weight:700}
.hub-side{flex:1 1 240px;min-width:240px;background:rgba(10,6,24,.4);border:2px solid var(--line);border-radius:22px;padding:18px;text-align:left}
.hub-stat{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px dashed var(--line)}
.hub-stat span{color:var(--muted);font-size:.82rem;font-weight:600}
.hub-stat b{color:var(--gold);font-size:1.2rem;font-weight:700}
.hub-no-runs{background:rgba(139,92,246,.12);border:1px dashed var(--line);border-radius:14px;padding:14px;text-align:center;color:var(--muted);font-weight:600;font-size:.85rem}
.hub-passives-title{margin:12px 0 8px;font-weight:700;font-size:.9rem;color:var(--text)}
.hub-passives-title em{color:var(--cyan);font-style:normal;font-weight:600;font-size:.72rem}
.hub-passives{display:flex;flex-direction:column;gap:6px;max-height:140px;overflow-y:auto}
.passive-chip{background:rgba(139,92,246,.15);border:1px solid var(--line);border-radius:12px;padding:6px 10px;font-size:.8rem;font-weight:700;color:var(--text)}
.passive-chip em{color:var(--muted);font-style:normal;font-weight:600;font-size:.7rem;margin-left:4px}
.hub-empty{color:var(--muted);font-size:.82rem;padding:8px 0;font-weight:600}

/* ---------- hub level / xp / money ---------- */
.hub-level{margin-top:10px;font-size:.72rem;font-weight:700;color:var(--muted);letter-spacing:.5px}
.hub-level b{color:var(--gold);font-size:1.05rem}
.xp-bar{position:relative;width:100%;max-width:180px;height:16px;background:rgba(10,6,24,.6);border:2px solid var(--line);border-radius:10px;overflow:hidden;margin:6px auto 0}
#xp-fill{height:100%;width:0;background:linear-gradient(90deg,var(--cyan),var(--purple));transition:width .3s}
.xp-bar span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.7)}
.hub-money{margin-top:8px;font-weight:700;color:var(--gold);font-size:.85rem}
.hub-money b{font-size:1.1rem}

/* ---------- perk store ---------- */
.store-money{font-weight:700;color:var(--gold);margin-bottom:14px}
.store-money b{font-size:1.2rem}
.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;max-height:52vh;overflow-y:auto;margin-bottom:16px}
.store-slot{border-radius:16px;padding:14px 10px;text-align:center;border:2px solid var(--line);background:rgba(10,6,24,.5);transition:.15s}
.store-slot .slot-title{font-weight:700;font-size:.85rem}
.store-slot .slot-perk{font-size:.72rem;color:var(--muted);margin:8px 0;min-height:16px}
.store-slot .slot-tag{font-weight:700;font-size:.72rem;border-radius:10px;padding:4px 8px;display:inline-block}
.store-slot.available{border-color:var(--green);box-shadow:0 0 16px rgba(34,197,94,.3)}
.store-slot.available:hover{transform:translateY(-3px)}
.store-slot.available .slot-perk{color:var(--text)}
.store-slot .slot-tag.buy{background:var(--green);color:#052b12;cursor:pointer}
.store-slot .slot-tag.poor{background:rgba(180,83,9,.35);color:var(--gold)}
.store-slot.locked{border-color:#ef4444;opacity:.85}
.store-slot .slot-tag.locked{background:rgba(239,68,68,.22);color:#fca5a5}
.store-slot.owned{border-color:var(--gold)}
.store-slot.owned .slot-perk{color:var(--text)}
.store-slot .slot-tag.owned{background:rgba(251,191,36,.22);color:var(--gold)}
@keyframes bob{50%{transform:translateY(-6px) rotate(-4deg)}}
.coin-card .ticker{font-weight:700;margin-top:6px;font-size:.98rem}
.coin-card .cname{font-size:.7rem;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.coin-card .mini-stats{display:flex;justify-content:center;gap:8px;font-size:.64rem;margin-top:8px;color:var(--muted);font-weight:600}
.coin-card .mini-stats b{color:var(--text)}

/* ---------- HUD ---------- */
#hud{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;padding:12px 14px;z-index:3;pointer-events:none}
#hud .btn{pointer-events:auto}
.hp-wrap{position:relative;width:min(58vw,320px);height:26px;background:rgba(10,6,24,.7);border:2px solid rgba(255,46,99,.5);border-radius:20px;overflow:hidden}
#hp-bar{height:100%;width:100%;background:linear-gradient(90deg,#ff2e63,#ff7aa0);transition:width .2s}
#hp-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6)}
.hud-badges{display:flex;gap:8px;margin-top:8px}
.badge{background:rgba(10,6,24,.7);border:1px solid var(--line);border-radius:12px;padding:5px 10px;font-size:.82rem;font-weight:700;color:var(--text)}
.badge.gold{border-color:var(--gold);color:var(--gold)}

/* ---------- canvas ---------- */
#game-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none;
  background:radial-gradient(circle at 50% 40%,#1a0f36,#0a0618 70%);
}

/* ---------- overlays ---------- */
.overlay{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;background:rgba(6,3,15,.7);backdrop-filter:blur(6px)}
.overlay.hidden{display:none}
.upgrade-box{width:min(460px,94vw);background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:24px;text-align:center;animation:pop .3s ease;box-shadow:0 0 50px rgba(139,92,246,.4)}
@keyframes pop{from{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}
.upgrade-box h3{margin-bottom:18px;font-size:1.3rem;color:var(--text);font-weight:700}
.upgrade-box .btn{margin-top:10px}
.upgrade-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.up-card{cursor:pointer;background:rgba(10,6,24,.5);border:2px solid var(--line);border-radius:16px;padding:14px 8px;transition:.15s}
.up-card:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:0 0 18px rgba(251,191,36,.4)}
.up-card .up-ico{font-size:2rem}
.up-card .up-name{font-weight:700;font-size:.84rem;margin-top:6px;color:var(--text)}
.up-card .up-desc{font-size:.7rem;color:var(--muted);margin-top:4px;font-weight:600}

/* ---------- game over ---------- */
.over-stats{display:flex;justify-content:center;gap:22px;margin:16px 0}
.over-stats div{display:flex;flex-direction:column}
.over-stats span{font-size:.72rem;color:var(--muted);font-weight:600}
.over-stats b{font-size:1.7rem;color:var(--gold);font-weight:700}
.rank{color:var(--cyan);font-weight:700;margin-bottom:16px}

/* ---------- leaderboard ---------- */
.lb-list{max-height:56vh;overflow-y:auto;margin-bottom:16px}
.lb-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;margin-bottom:6px;background:rgba(10,6,24,.5);border:1px solid var(--line)}
.lb-row.me{border-color:var(--gold);background:rgba(251,191,36,.12)}
.lb-rank{font-weight:700;width:34px;text-align:center;color:var(--muted)}
.lb-row:nth-child(1) .lb-rank{color:var(--gold)}
.lb-av{font-size:1.4rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex:0 0 auto;background:rgba(10,6,24,.6)}
.lb-av img{width:100%;height:100%;object-fit:cover;display:block}
.lb-nick{flex:1;font-weight:700;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.lb-score{font-weight:700;color:var(--gold)}
.lb-empty{color:var(--muted);padding:20px;font-weight:600}
.lb-status{text-align:center;font-size:.72rem;font-weight:700;color:var(--muted);margin-bottom:8px}

/* ---------- joystick ---------- */
#joystick{position:absolute;width:110px;height:110px;border-radius:50%;
  background:rgba(139,92,246,.15);border:2px solid rgba(139,92,246,.4);z-index:4;
  transform:translate(-50%,-50%);pointer-events:none}
#joystick.hidden{display:none}
#joystick-knob{position:absolute;top:50%;left:50%;width:48px;height:48px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#c4b5fd,var(--purple));
  transform:translate(-50%,-50%);box-shadow:0 0 16px rgba(139,92,246,.7)}

@media (max-width:480px){
  .logo{font-size:2.2rem}
  .coin-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}
  .topbar{padding:10px 12px;gap:6px}
  .topbar .btn{padding:8px 12px;font-size:.8rem}
  .feed-status{font-size:.64rem;padding:4px 7px}
  .who{font-size:.9rem}
  .social-btn{font-size:.68rem;padding:7px 10px}
}

/* ---------- social bar (Telegram + copy CA) ---------- */
#social-bar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;padding:8px 10px;pointer-events:none;background:linear-gradient(0deg,rgba(10,6,24,.92),rgba(10,6,24,.5) 65%,transparent)}
#social-bar.hidden{display:none}
.social-btn{pointer-events:auto;font-family:inherit;font-weight:700;font-size:.8rem;cursor:pointer;border:2px solid var(--line);border-radius:14px;padding:8px 13px;text-decoration:none;color:var(--text);background:rgba(22,10,46,.92);transition:transform .12s,filter .15s}
.social-btn:hover{transform:translateY(-2px);filter:brightness(1.12)}
.social-btn.tg{background:linear-gradient(90deg,#229ED9,#2AABEE);color:#fff;border-color:transparent}
.social-btn.x{background:#000;color:#fff;border-color:#333}
.social-btn.ca{color:var(--gold)}
.social-btn.ca b{color:var(--text);font-weight:700}
.social-btn.copied{background:var(--green);color:#062611;border-color:transparent}
