:root {
  --bg-0: #0c1226;
  --bg-1: #111a33;
  --panel: #16203c;
  --panel-2: #1d294a;
  --line: #2a3a63;
  --ink: #eef2fb;
  --muted: #95a3c2;
  --gold: #f4c84a;
  --gold-deep: #c8932a;
  --gem: #3fd0d6;
  --good: #58d6a0;
  --hot: #ff7a59;
  /* rarity scale (a real game convention, used intentionally) */
  --r-common: #9aa7bd;
  --r-rare: #4aa3ff;
  --r-epic: #b56bf2;
  --r-legendary: #f6a93a;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  color: var(--ink);
  font-family: "Inter", "Segoe UI", Roboto, Arial, sans-serif;
  line-height: 1.45;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(95,120,220,.18), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(63,208,214,.10), transparent 55%),
    linear-gradient(180deg, var(--bg-1), var(--bg-0));
  background-attachment: fixed;
}

h1, h2, h3, .wallet-val, .m-val, .btn { font-family: "Baloo 2", "Segoe UI", sans-serif; }

/* effects overlay for floating text (confetti draws its own canvas) */
.fx-layer { position: fixed; inset: 0; pointer-events: none; z-index: 60; overflow: hidden; }
.float-text {
  position: absolute; transform: translate(-50%, 0);
  font-family: "Baloo 2", sans-serif; font-weight: 800; font-size: 1.15rem;
  text-shadow: 0 2px 6px rgba(0,0,0,.5); white-space: nowrap;
  animation: floatUp 1.05s ease-out forwards;
}
.float-text.gold { color: var(--gold); }
.float-text.gem { color: var(--gem); }
.float-text.spend { color: var(--hot); }
.float-text.tier { color: #fff; font-size: 1.35rem; }
@keyframes floatUp {
  0% { opacity: 0; transform: translate(-50%, 6px) scale(.8); }
  20% { opacity: 1; transform: translate(-50%, -4px) scale(1.1); }
  100% { opacity: 0; transform: translate(-50%, -52px) scale(1); }
}

.masthead {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem;
  padding: 1.4rem 1.6rem 1rem;
}
.masthead h1 { margin: 0 0 .25rem; font-size: 1.7rem; font-weight: 800; letter-spacing: .3px; }
.sub { margin: 0; color: var(--muted); max-width: 62ch; font-size: .92rem; }

.layout {
  display: grid; grid-template-columns: 1.55fr 1fr; gap: 1.2rem;
  padding: .4rem 1.6rem 2.6rem; align-items: start;
}
@media (max-width: 920px) { .layout { grid-template-columns: 1fr; } }

/* wallet */
.wallet { display: flex; gap: .8rem; margin-bottom: 1.1rem; }
.coin {
  flex: 1; display: flex; align-items: center; gap: .6rem;
  background: linear-gradient(180deg, var(--panel-2), var(--panel));
  border: 1px solid var(--line); border-radius: 14px; padding: .6rem .8rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 6px 16px rgba(0,0,0,.25);
}
.cur-icon { width: 30px; height: 30px; flex: 0 0 auto; filter: drop-shadow(0 2px 3px rgba(0,0,0,.35)); }
.wallet-meta { display: flex; flex-direction: column; line-height: 1.1; }
.wallet-label { color: var(--muted); font-size: .68rem; text-transform: uppercase; letter-spacing: .9px; }
.wallet-val { font-size: 1.45rem; font-weight: 800; font-variant-numeric: tabular-nums; }
.coin--coins { box-shadow: inset 0 0 0 1px rgba(244,200,74,.18), 0 6px 16px rgba(0,0,0,.25); }
.coin--gems { box-shadow: inset 0 0 0 1px rgba(63,208,214,.18), 0 6px 16px rgba(0,0,0,.25); }
.bump { animation: bump .45s ease; }
@keyframes bump { 0%{transform:scale(1)} 45%{transform:scale(1.22); filter:brightness(1.3)} 100%{transform:scale(1)} }

/* panels */
.panel {
  background: linear-gradient(180deg, var(--panel), var(--bg-1));
  border: 1px solid var(--line); border-radius: 16px; padding: 1rem 1.1rem; margin-bottom: 1.1rem;
  box-shadow: 0 10px 24px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.04);
}
.panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .55rem; }
.panel-head h2 { margin: 0; font-size: 1.15rem; font-weight: 700; }
.panel h3.shop-sub { margin: 1.1rem 0 .55rem; font-size: .78rem; color: var(--muted); text-transform: uppercase; letter-spacing: .8px; }

.muted { color: var(--muted); }
.small { font-size: .82rem; }
.pill {
  font-size: .72rem; font-weight: 600; color: var(--gold);
  background: rgba(244,200,74,.12); border: 1px solid rgba(244,200,74,.3);
  padding: .12rem .55rem; border-radius: 999px;
}
.pill--hot { color: var(--hot); background: rgba(255,122,89,.14); border-color: rgba(255,122,89,.4); }

/* play stage */
.stage { background: linear-gradient(180deg, #1a2747, #131d38); }
.arena {
  border-radius: 12px; padding: .9rem 1rem; margin-bottom: .85rem; min-height: 3.4rem;
  display: flex; align-items: center;
  background:
    radial-gradient(600px 120px at 50% 0%, rgba(244,200,74,.10), transparent 70%),
    linear-gradient(180deg, #0f1830, #0c1326);
  border: 1px solid var(--line);
}
.result { margin: 0; font-size: 1rem; font-weight: 600; }
.result.win { color: var(--good); }
.result.loss { color: #ff9d8a; }

/* buttons */
.row { display: flex; gap: .6rem; flex-wrap: wrap; }
.row.spaced { justify-content: space-between; align-items: center; margin-top: .7rem; }
.btn {
  border: none; border-radius: 11px; padding: .6rem 1.05rem; font-size: .92rem; font-weight: 700;
  cursor: pointer; color: #1a1206; position: relative; overflow: hidden;
  background: linear-gradient(180deg, var(--gold), var(--gold-deep));
  box-shadow: 0 5px 0 #8a6312, 0 8px 16px rgba(0,0,0,.3);
  transition: transform .06s ease, box-shadow .06s ease, filter .12s ease;
}
.btn:hover { filter: brightness(1.05); }
.btn:active { transform: translateY(4px); box-shadow: 0 1px 0 #8a6312, 0 3px 8px rgba(0,0,0,.3); }
.btn:disabled { opacity: .5; cursor: not-allowed; box-shadow: 0 5px 0 #5b5446; filter: grayscale(.3); }
.btn-play { font-size: 1.02rem; padding: .7rem 1.5rem; }
.btn-play::after {
  content: ""; position: absolute; top: 0; left: 0; width: 40%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
  transform: translateX(-150%) skewX(-18deg); animation: sweep 3.4s ease-in-out infinite;
}
@keyframes sweep { 0%{transform:translateX(-150%) skewX(-18deg)} 55%,100%{transform:translateX(360%) skewX(-18deg)} }
.btn-ghost {
  background: transparent; color: var(--ink); border: 1px solid var(--line);
  box-shadow: none;
}
.btn-ghost:active { transform: translateY(2px); box-shadow: none; }
.btn-gem { background: linear-gradient(180deg, var(--gem), #1f9aa0); color: #06231f; box-shadow: 0 5px 0 #14676b, 0 8px 16px rgba(0,0,0,.3); }
.btn-gem:active { box-shadow: 0 1px 0 #14676b, 0 3px 8px rgba(0,0,0,.3); }
.btn-accent { background: linear-gradient(180deg, var(--good), #2f9d72); color: #052418; box-shadow: 0 5px 0 #1c6b4d, 0 8px 16px rgba(0,0,0,.3); }
.btn-small { padding: .42rem .75rem; font-size: .82rem; box-shadow: 0 4px 0 #8a6312, 0 6px 12px rgba(0,0,0,.3); }

/* season pass */
.track { display: flex; gap: .4rem; overflow-x: auto; padding: .1rem .1rem .4rem; }
.tier {
  flex: 0 0 auto; width: 62px; border-radius: 10px; padding: .4rem .3rem; text-align: center;
  background: linear-gradient(180deg, var(--panel-2), var(--panel)); border: 1px solid var(--line);
}
.tier.done {
  border-color: var(--gold);
  background: linear-gradient(180deg, rgba(244,200,74,.22), rgba(244,200,74,.06));
  box-shadow: 0 0 12px rgba(244,200,74,.25);
}
.tier .t-num { font-size: .66rem; color: var(--muted); font-weight: 700; }
.tier.done .t-num { color: var(--gold); }
.tier .t-free { font-size: .72rem; margin-top: .15rem; font-weight: 600; }
.tier .t-prem { font-size: .7rem; margin-top: .1rem; color: var(--r-epic); font-weight: 600; }
.tier.locked .t-prem { opacity: .4; }
.passbar { height: 8px; background: #0e1730; border-radius: 999px; margin: .55rem 0 0; overflow: hidden; border: 1px solid var(--line); }
.passbar__fill { display: block; height: 100%; width: 0; border-radius: 999px; background: linear-gradient(90deg, var(--gold-deep), var(--gold)); transition: width .4s ease; }

/* shop */
.shop { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; }
@media (max-width: 560px) { .shop { grid-template-columns: 1fr; } }
.item {
  position: relative; border-radius: 14px; padding: .65rem; display: flex; flex-direction: column; gap: .45rem;
  background: linear-gradient(180deg, var(--panel-2), var(--panel)); border: 1px solid var(--line);
  animation: popIn .3s ease both;
}
@keyframes popIn { from{opacity:0; transform:translateY(6px) scale(.97)} to{opacity:1; transform:none} }
.item[data-rarity="rare"] { border-color: rgba(74,163,255,.6); }
.item[data-rarity="epic"] { border-color: rgba(181,107,242,.65); box-shadow: 0 0 16px rgba(181,107,242,.18); }
.item[data-rarity="legendary"] { border-color: rgba(246,169,58,.7); box-shadow: 0 0 20px rgba(246,169,58,.25); }
.swatch {
  position: relative; height: 56px; border-radius: 9px; overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25), inset 0 -10px 18px rgba(0,0,0,.25);
}
.swatch::after {
  content: ""; position: absolute; top: 0; left: 0; width: 45%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.45), transparent);
  transform: translateX(-160%) skewX(-18deg);
}
.item:hover .swatch::after { animation: sweep 1.1s ease; }
.rarity-badge {
  position: absolute; top: .5rem; right: .5rem; font-size: .6rem; font-weight: 700; letter-spacing: .5px;
  text-transform: uppercase; padding: .12rem .4rem; border-radius: 6px; color: #0b1020;
}
.rarity-badge.common { background: var(--r-common); }
.rarity-badge.rare { background: var(--r-rare); }
.rarity-badge.epic { background: var(--r-epic); color: #fff; }
.rarity-badge.legendary { background: var(--r-legendary); }
.i-name { font-weight: 700; font-size: .9rem; }
.i-rarity { font-size: .7rem; color: var(--muted); margin-top: -.25rem; }
.i-buy { margin-top: auto; }
.owned-tag { margin-top: auto; font-size: .8rem; color: var(--good); font-weight: 700; display: inline-flex; align-items: center; gap: .3rem; }
.owned-tag::before { content: "✓"; }

.gem-shop { display: grid; grid-template-columns: repeat(4, 1fr); gap: .55rem; }
@media (max-width: 560px) { .gem-shop { grid-template-columns: 1fr 1fr; } }
.gem-pack {
  position: relative; border-radius: 11px; padding: .6rem .4rem; text-align: center; cursor: pointer;
  background: linear-gradient(180deg, var(--panel-2), var(--panel)); border: 1px solid var(--line);
  transition: transform .1s ease, border-color .1s ease, box-shadow .1s ease;
}
.gem-pack:hover { transform: translateY(-2px); border-color: var(--gem); box-shadow: 0 8px 16px rgba(0,0,0,.3); }
.gem-pack:active { transform: translateY(0); }
.gem-pack.best { border-color: var(--gold); box-shadow: 0 0 14px rgba(244,200,74,.2); }
.gem-pack .g-amt { font-weight: 800; font-family: "Baloo 2", sans-serif; }
.gem-pack .g-usd { font-size: .78rem; color: var(--muted); }
.gem-pack .best-tag { position: absolute; top: -.55rem; left: 50%; transform: translateX(-50%); font-size: .58rem; font-weight: 700; background: var(--gold); color: #1a1206; padding: .1rem .4rem; border-radius: 999px; }

.event { border-color: rgba(255,122,89,.5); box-shadow: 0 0 18px rgba(255,122,89,.15), 0 10px 24px rgba(0,0,0,.22); }

/* dashboard */
.dash {
  background: linear-gradient(180deg, var(--panel), var(--bg-1));
  border: 1px solid var(--line); border-radius: 16px; padding: 1.1rem 1.2rem; position: sticky; top: 1rem;
  box-shadow: 0 10px 24px rgba(0,0,0,.22);
}
.dash-title { margin: 0 0 .2rem; font-size: 1.2rem; font-weight: 700; }

.lo-read {
  background: linear-gradient(180deg, rgba(244,200,74,.10), rgba(244,200,74,.03));
  border: 1px solid rgba(244,200,74,.32); border-left: 3px solid var(--gold);
  border-radius: 12px; padding: .7rem .85rem; margin: 1rem 0;
}
.lo-read__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .35rem; }
.lo-pill { font-family: "Baloo 2", sans-serif; font-size: .72rem; font-weight: 700; color: #1a1206; background: var(--gold); padding: .12rem .55rem; border-radius: 999px; }
.lo-text { margin: 0; font-size: .9rem; line-height: 1.4; }

.metrics { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: .55rem; margin: 1rem 0; }
@media (max-width: 560px) { .metrics { grid-template-columns: 1fr 1fr; } }
.metric { background: #0f1830; border: 1px solid var(--line); border-radius: 10px; padding: .5rem .6rem; }
.m-label { display: block; color: var(--muted); font-size: .66rem; text-transform: uppercase; letter-spacing: .8px; }
.m-val { font-size: 1.2rem; font-weight: 800; font-variant-numeric: tabular-nums; }

.segment { margin: .6rem 0 1rem; }
.seg { display: inline-block; font-weight: 800; font-family: "Baloo 2", sans-serif; padding: .2rem .6rem; border-radius: 8px; margin: .3rem 0; }
.seg-none { background: #28324a; color: var(--muted); }
.seg-minnow { background: rgba(74,163,255,.2); color: var(--r-rare); }
.seg-dolphin { background: rgba(88,214,160,.2); color: var(--good); }
.seg-whale { background: rgba(246,169,58,.22); color: var(--r-legendary); box-shadow: 0 0 14px rgba(246,169,58,.3); }

.spark { margin-bottom: 1rem; }
#sparkline { width: 100%; height: 70px; margin-top: .3rem; background: #0f1830; border: 1px solid var(--line); border-radius: 10px; }

.log .m-label { margin-bottom: .3rem; }
#event-log { list-style: none; margin: 0; padding: 0; max-height: 200px; overflow-y: auto; font-size: .82rem; }
#event-log li { padding: .32rem 0; border-bottom: 1px solid var(--line); }
#event-log li:first-child { animation: logIn .35s ease; }
@keyframes logIn { from{opacity:0; transform:translateX(-6px)} to{opacity:1; transform:none} }
#event-log li .t { color: var(--gold); margin-right: .4rem; font-weight: 700; }

.dash-foot { margin-top: 1rem; }
.dash-foot a { color: var(--gold); }
