/* styles.css — lobby + shared components, faithful to the SwiftUI lobby. */

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body {
  margin: 0;
  padding: 0;
  background: var(--canvas);
  color: var(--text-primary);
  font-family: var(--font-display);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { min-height: 100vh; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; padding: 0; }
input, textarea, select { font-family: inherit; }

/* ---- Layout ---- */
.wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--space-md) calc(96px + env(safe-area-inset-bottom));
}

/* ===========================================================
   BRAND BAR (native overlays this in-app → hidden when embedded)
   =========================================================== */
.brandbar {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: calc(env(safe-area-inset-top) + 10px) var(--space-md) 8px;
  max-width: 720px;
  margin: 0 auto;
  position: sticky;
  top: 0;
  z-index: 20;
  background: linear-gradient(180deg, rgba(8,9,10,0.85), rgba(8,9,10,0));
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.brandbar .logo {
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -0.02em;
  display: flex;
  align-items: center;
  gap: 8px;
}
.brandbar .logo .gem {
  width: 26px; height: 26px; border-radius: 8px;
  background: linear-gradient(135deg, var(--emerald-bright), var(--emerald));
  border: 1px solid var(--specular-border);
  display: grid; place-items: center; font-size: 14px;
  box-shadow: 0 0 14px var(--glow-emerald);
}
.brandbar .logo b { color: var(--gold); }
.brandbar .spacer { flex: 1; }

/* Level chip with progress ring */
.chip {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 10px 5px 6px;
  border-radius: var(--radius-pill);
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--specular-border);
}
.ring { width: 24px; height: 24px; position: relative; flex: none; }
.ring svg { transform: rotate(-90deg); display: block; }
.ring .star { position: absolute; inset: 0; display: grid; place-items: center; color: var(--gold); font-size: 9px; }
.chip .lv { font-family: var(--font-mono); font-size: 10px; font-weight: 700; line-height: 1.1; }
.chip .xp { font-family: var(--font-mono); font-size: 8px; font-weight: 600; color: var(--text-secondary); line-height: 1.1; }
.icon-btn {
  width: 36px; height: 36px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--specular-border);
  color: var(--text-secondary);
}
.icon-btn.active { color: var(--gold); }
.icon-btn svg { width: 16px; height: 16px; }

body.embedded .brandbar,
body.embedded .tabbar { display: none; }
body.embedded .wrap { padding-bottom: calc(24px + env(safe-area-inset-bottom)); }

/* Embedded in the native shell: stay fully transparent so the app's own
   Theme.backgroundGradient (drawn behind the WKWebView) shows through and the
   background is pixel-identical to the native lobby. */
html.embedded, body.embedded { background: transparent !important; }
body.embedded .app-bg { display: none !important; }

/* ===========================================================
   GREETING + SEARCH
   =========================================================== */
.greeting { margin: var(--space-sm) 0 var(--space-sm); display: flex; align-items: baseline; gap: 6px; padding-left: 2px; }
.greeting .hi { font-size: 13px; font-weight: 600; color: var(--text-secondary); }
.greeting .dot { color: var(--text-secondary); }
.greeting .lvl { font-size: 13px; font-weight: 800; color: var(--gold); }

.search {
  display: flex; align-items: center; gap: var(--space-sm);
  padding: 12px var(--space-md);
  border-radius: var(--radius-control);
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--specular-border);
  margin-bottom: var(--space-md);
}
.search svg { width: 18px; height: 18px; opacity: 0.6; flex: none; }
.search input { flex: 1; background: none; border: none; outline: none; color: var(--text-primary); font-size: 15px; }
.search input::placeholder { color: var(--text-secondary); }

/* ===========================================================
   HERO BANNER
   =========================================================== */
.hero {
  position: relative;
  border-radius: var(--radius-card);
  overflow: hidden;
  padding: var(--space-lg);
  min-height: 168px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border: 1px solid var(--specular-border);
  box-shadow: 0 12px 34px rgba(0,0,0,0.45), 0 0 26px var(--glow-gold);
  cursor: pointer;
  isolation: isolate;
}
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(120% 100% at 0% 0%, rgba(255,255,255,0.18), transparent 55%);
}
.hero .eyebrow { font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; color: var(--gold-bright); text-transform: uppercase; }
.hero h2 { margin: 8px 0 4px; font-size: 26px; font-weight: 900; letter-spacing: -0.02em; text-shadow: 0 2px 12px rgba(0,0,0,0.4); }
.hero p { margin: 0 0 4px; color: rgba(255,255,255,0.9); font-size: 14px; max-width: 78%; }
.hero .play-pill {
  margin-top: 12px; align-self: flex-start;
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: var(--radius-pill);
  font-weight: 800; font-size: 13px; color: #2a1c00;
  background: linear-gradient(135deg, var(--gold-bright), var(--gold));
  box-shadow: 0 0 18px var(--glow-gold);
}

/* ===========================================================
   DAILY REWARD + GAME OF THE DAY
   =========================================================== */
.tile {
  display: flex; align-items: center; gap: var(--space-md);
  padding: var(--space-md);
  border-radius: var(--radius-card);
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--specular-border);
  box-shadow: 0 8px 22px rgba(0,0,0,0.3), 0 0 18px var(--glow-gold);
  margin-top: var(--space-md);
  cursor: pointer;
}
.tile .badge-circle {
  width: 44px; height: 44px; border-radius: 50%; flex: none;
  display: grid; place-items: center; font-size: 19px; color: #1a1200;
  background: linear-gradient(135deg, var(--gold-bright), var(--gold));
  box-shadow: 0 0 16px var(--glow-gold);
}
.tile .thumb-sm { width: 64px; height: 64px; border-radius: var(--radius-control); flex: none; background-size: cover; background-position: center; border: 1px solid var(--specular-border); }
.tile .body { flex: 1; min-width: 0; }
.tile .eyebrow { font-family: var(--font-mono); font-size: 10px; font-weight: 700; color: var(--gold); letter-spacing: 0.06em; }
.tile .t { font-size: 16px; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tile .s { font-size: 12px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tile .cta {
  flex: none; font-weight: 900; font-size: 13px; color: #1a1200;
  padding: 8px 16px; border-radius: var(--radius-pill);
  background: linear-gradient(180deg, var(--gold-bright), var(--gold));
}
.tile .play-ico { flex: none; color: var(--gold); font-size: 30px; line-height: 1; }

/* ===========================================================
   SECTION HEADER
   =========================================================== */
.section-head { display: flex; align-items: center; margin: var(--space-lg) 0 var(--space-sm); }
.section-head .accent { width: 4px; height: 20px; border-radius: 2px; background: linear-gradient(180deg, var(--gold-bright), var(--gold)); margin-right: 10px; box-shadow: 0 0 8px var(--glow-gold); }
.section-head h3 { margin: 0; font-size: 20px; font-weight: 900; letter-spacing: -0.01em; }

/* ===========================================================
   CATEGORY PILLS
   =========================================================== */
.pills { display: flex; gap: var(--space-sm); overflow-x: auto; scrollbar-width: none; margin-top: var(--space-lg); padding: 4px 0 var(--space-sm); }
.pills::-webkit-scrollbar { display: none; }
.pill {
  flex: none; padding: 9px 16px; border-radius: var(--radius-pill);
  font-size: 14px; font-weight: 600; white-space: nowrap;
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--specular-border);
  color: var(--text-primary);
  transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1), background 0.2s;
}
.pill:active { transform: scale(0.95); }
.pill.active { background: linear-gradient(180deg, var(--gold-bright), var(--gold)); color: var(--canvas); border-color: transparent; box-shadow: 0 0 14px var(--glow-gold); }

/* ===========================================================
   RAIL + GRID
   =========================================================== */
.rail { display: flex; gap: var(--space-lg); overflow-x: auto; scrollbar-width: none; padding: 4px 2px 8px; }
.rail::-webkit-scrollbar { display: none; }
.rail .card { flex: none; width: 164px; }
.grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); }

/* ---- Game card (mirrors GameCardView) ---- */
.card {
  border-radius: var(--radius-card);
  overflow: hidden;
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--specular-border);
  box-shadow: 0 8px 16px rgba(0,0,0,0.35), 0 0 14px var(--glow-gold);
  transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1);
}
.card:active { transform: scale(0.97); }
.card .thumb {
  position: relative; height: 132px;
  display: grid; place-items: center;
  background-size: cover; background-position: center;
}
.card .thumb .glyph { font-size: 44px; font-weight: 900; color: rgba(255,255,255,0.9); text-shadow: 0 2px 8px rgba(0,0,0,0.4); }
.card .thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,0.35)); }
.card .heart {
  position: absolute; top: 8px; right: 8px; z-index: 2;
  width: 32px; height: 32px; border-radius: 50%;
  display: grid; place-items: center; color: #fff;
  background: rgba(8,9,10,0.35);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 1px solid var(--specular-border);
}
.card .heart.fav { color: var(--gold); box-shadow: 0 0 10px var(--glow-gold); }
.card .meta { padding: 10px var(--space-sm) 12px; }
.card .meta .name { font-size: 15px; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card .meta .stats { display: flex; align-items: center; justify-content: space-between; margin-top: 7px; }
.card .meta .rtp { font-family: var(--font-mono); font-size: 11px; font-weight: 700; color: var(--gold); }
.vol { display: flex; gap: 3px; align-items: center; }
.vol .pip { width: 16px; height: 6px; border-radius: 3px; background: rgba(255,255,255,0.15); }
.vol .pip.on { background: var(--gold); box-shadow: 0 0 6px var(--glow-gold); }

/* ===========================================================
   WINNERS TICKER
   =========================================================== */
.ticker-wrap {
  overflow: hidden; border-radius: var(--radius-control);
  border: 1px solid var(--specular-border); background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur)); backdrop-filter: blur(var(--glass-blur));
}
.ticker { display: flex; gap: var(--space-lg); padding: 11px var(--space-md); white-space: nowrap; width: max-content; animation: scroll-x 32s linear infinite; }
.ticker .win { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; }
.ticker .win .crown { color: var(--gold); font-size: 12px; }
.ticker .win .nm { color: var(--text-primary); font-weight: 700; }
.ticker .win b { color: var(--gold); font-family: var(--font-mono); font-weight: 700; }
.ticker .win .g { color: var(--text-secondary); }
@keyframes scroll-x { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ===========================================================
   MAIN BANNER (mirrors native MainBanner — full-bleed crowned lion)
   =========================================================== */
.main-banner { margin: var(--space-sm) calc(-1 * var(--space-md)) 0; }
.main-banner img { width: 100%; height: auto; display: block; }

/* ===========================================================
   PROVIDER SPOTLIGHT
   =========================================================== */
.spotlight {
  display: flex; align-items: center; gap: var(--space-md);
  padding: var(--space-md); border-radius: var(--radius-card);
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur)); backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--specular-border);
  box-shadow: 0 0 18px var(--glow-gold);
  margin-top: var(--space-lg);
}
.spotlight .ico { font-size: 26px; color: var(--gold); }
.spotlight .t { font-size: 16px; font-weight: 800; }
.spotlight .s { font-size: 12px; color: var(--text-secondary); }

/* ===========================================================
   BOTTOM TAB BAR (native overlays this in-app → hidden when embedded)
   =========================================================== */
.tabbar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 30;
  display: flex; justify-content: space-around; align-items: center;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  background: rgba(10,12,13,0.82);
  -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);
  border-top: 1px solid var(--specular-border);
}
.tabbar .tab { display: flex; flex-direction: column; align-items: center; gap: 3px; color: var(--text-secondary); font-size: 10px; font-weight: 600; }
.tabbar .tab.active { color: var(--gold); }
.tabbar .tab svg { width: 22px; height: 22px; }

/* ===========================================================
   STATES
   =========================================================== */
.empty { text-align: center; color: var(--text-secondary); padding: var(--space-xl); font-size: 14px; }
.skeleton .card .thumb { background: linear-gradient(90deg,#14181b 25%,#1d2226 37%,#14181b 63%); background-size: 400% 100%; animation: shimmer 1.4s ease infinite; }
@keyframes shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }

@media (min-width: 560px) {
  .grid { grid-template-columns: 1fr 1fr 1fr; }
  .rail .card { width: 180px; }
}
