:root{
  --bg:#0b1220;
  --text:#e6edf7;
  --muted:#a9b4c8;
  --card:#111b2f;
  --stroke:rgba(255,255,255,.10);
  --shadow: 0 10px 28px rgba(0,0,0,.28);
  --r:16px;
  --brand:#60a5fa;
}
*{box-sizing:border-box}
html,body{height:100%}
/* Layout: sticky footer */
body{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
.footer{margin-top:auto}

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(34,211,238,.16), transparent 60%),
    radial-gradient(900px 600px at 80% 20%, rgba(168,85,247,.16), transparent 58%),
    radial-gradient(900px 700px at 60% 90%, rgba(34,197,94,.10), transparent 55%),
    var(--bg);
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:14px 16px}

/* Header */
.header{
  position:sticky;top:0;z-index:60;
  background: rgba(11,18,32,.78);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.brandRow{display:flex;align-items:center;gap:10px;min-width:220px}
.logo{
  width:34px;height:34px;border-radius:12px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  display:grid;place-items:center;
}
.logo img{width:22px;height:22px;display:block}
.brand h1{margin:0;font-size:15px;letter-spacing:.2px}
.brand p{margin:0;font-size:12px;color:rgba(233,239,248,.72)}
.controls{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end;flex-wrap:wrap}

.search{
  flex:1;min-width:260px;display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:14px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.search input{width:100%;background:transparent;border:0;outline:0;color:var(--text);font-size:14px}

.pill{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;border-radius:999px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(233,239,248,.78);font-size:13px;
}
.pill select{background:transparent;border:0;outline:0;color:var(--text);font-size:13px;appearance:none}

.btn{
  padding:10px 12px;border-radius:999px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(233,239,248,.92);font-size:13px;cursor:pointer;
}
.btn:hover{border-color: rgba(96,165,250,.45)}

/* Hero */
.hero{padding:18px 16px 6px}
.heroGrid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.2fr .8fr;gap:14px}
@media (max-width:980px){.heroGrid{grid-template-columns:1fr}}
.card{
  border-radius:var(--r);
  background: rgba(17,27,47,.82);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.banner{padding:18px}
.banner h2{margin:0 0 8px;font-size:22px}
.banner p{margin:0;color:rgba(233,239,248,.78);line-height:1.6;max-width:72ch}
.sideCards{display:grid;gap:14px}
.sideCard{padding:14px}
.sideCard h3{margin:0 0 6px;font-size:14px}
.sideCard p{margin:0;font-size:13px;color:rgba(233,239,248,.72);line-height:1.5}

/* Ads */
.ad-slot{
  border-radius:14px;
  border:1px dashed rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  min-height:90px;padding:10px;
  display:flex;align-items:center;justify-content:center;
}
.ad-slot::before{content:"Advertisement";font-size:12px;color: rgba(233,239,248,.45);}
.ad-slot.hasAd::before{content:"";}
.gridAd{
  grid-column: 1 / -1;
  border-radius: var(--r);
  background: rgba(17,27,47,.82);
  border:1px dashed rgba(255,255,255,.18);
  box-shadow: var(--shadow);
  padding:12px;
}
.gridAd .ad-slot{min-height:110px}

/* Tabs */
.tabs{max-width:1180px;margin:12px auto 0;display:flex;gap:10px;flex-wrap:wrap;padding:0 16px}
.tab{
  padding:10px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color:rgba(233,239,248,.90);
  font-size:13px;cursor:pointer;
}
.tab[aria-pressed="true"]{border-color: rgba(96,165,250,.45); background: rgba(96,165,250,.12)}

/* Grid */
.main{padding:10px 16px 36px}
.sectionTitle{max-width:1180px;margin:0 auto;display:flex;justify-content:space-between;align-items:baseline;gap:10px;flex-wrap:wrap;padding:8px 2px}
.sectionTitle h2{margin:0;font-size:16px}
.sectionTitle span{color:rgba(233,239,248,.62);font-size:12px}
.grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns: repeat(5, 1fr);gap:12px}
@media (max-width:1180px){.grid{grid-template-columns: repeat(4, 1fr)}}
@media (max-width:980px){.grid{grid-template-columns: repeat(3, 1fr)}}
@media (max-width:720px){.grid{grid-template-columns: repeat(2, 1fr)}}
@media (max-width:520px){.grid{grid-template-columns: 1fr}}

.gameCard{
  background: rgba(17,27,47,.82);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--r);
  overflow:hidden;
  box-shadow: var(--shadow);
  transition: transform .12s ease, border-color .12s ease;
  display:flex;flex-direction:column;
}
.gameCard:hover{transform: translateY(-2px); border-color: rgba(96,165,250,.40)}
.thumb{
  height:112px;
  background:
    radial-gradient(circle at 30% 25%, rgba(34,211,238,.22), transparent 58%),
    radial-gradient(circle at 72% 75%, rgba(168,85,247,.18), transparent 58%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border-bottom:1px solid rgba(255,255,255,.10);
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.badge{
  position:absolute;top:10px;left:10px;
  font-size:11px;color:rgba(15,23,42,.96);
  background: rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.22);
  padding:6px 8px;border-radius:999px;
}
.fav{
  position:absolute;top:10px;right:10px;
  width:34px;height:34px;border-radius:999px;
  background: rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  display:grid;place-items:center;
}
.fav svg{width:16px;height:16px;opacity:.92}
.svgIcon{width:58px;height:58px;opacity:.92}
.cardBody{padding:10px 10px 12px;display:flex;flex-direction:column;gap:6px}
.cardBody h3{margin:0;font-size:13px}
.cardBody p{margin:0;font-size:12px;color:rgba(233,239,248,.72);line-height:1.35;min-height:30px}
.meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:2px}
.chip{font-size:11px;padding:6px 8px;border-radius:999px;background: rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:rgba(233,239,248,.80)}

/* Footer */
.footer{
  margin-top: 18px;
  background: rgba(11,18,32,.80);
  border-top: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
}
.footerInner{
  max-width:1180px;margin:0 auto;padding:20px 16px;
  display:grid;grid-template-columns: 1.2fr .9fr .9fr;
  gap:16px;
}
@media (max-width: 900px){.footerInner{grid-template-columns:1fr}}
.footerBrand{display:flex;align-items:flex-start;gap:10px}
.footerBrand .mark{
  width:30px;height:30px;border-radius:12px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  display:grid;place-items:center;
}
.footerBrand .mark img{width:18px;height:18px;display:block}
.footerBrand h3{margin:0;font-size:14px}
.footerBrand p{margin:6px 0 0;color:rgba(233,239,248,.72);font-size:12px;line-height:1.55}
.footerCol h4{margin:0 0 10px;font-size:13px}
.footerLinks{display:grid;gap:8px}
.footerLinks a{color:rgba(233,239,248,.72);font-size:12px}
.footerLinks a:hover{color: rgba(96,165,250,.95)}
.footerBottom{
  max-width:1180px;margin:0 auto;
  padding:12px 16px 18px;
  display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;
  color:rgba(233,239,248,.56);
  font-size:12px;
}

/* Toast */
.toast{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);
  background: rgba(15,23,42,.92);
  border:1px solid rgba(255,255,255,.20);
  padding:10px 12px;border-radius:12px;
  color:rgba(255,255,255,.95);
  font-size:13px;opacity:0;pointer-events:none;transition: opacity .18s ease;
}
.toast.show{opacity:1}


/* --- Minimal game cards + hover preview --- */
.gameCard .cardBody{display:none !important;}
.gameCard{
  position:relative;
  min-height: 140px;
}
.thumb{
  height:140px;
  display:grid;
  place-items:center;
}
.thumb .svgIcon{width:64px;height:64px;opacity:.95}
.previewCanvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:none;
}
.gameCard:hover .previewCanvas{display:block;}
.gameCard:hover .svgIcon{opacity:.25; transform: scale(.95); transition: .12s ease;}
.hoverOverlay{
  position:absolute;left:10px;right:10px;bottom:10px;
  padding:10px 10px;
  border-radius:14px;
  background: rgba(11,18,32,.72);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  display:none;
}
.gameCard:hover .hoverOverlay{display:flex; align-items:center; justify-content:space-between; gap:10px;}
.hoverTitle{
  display:flex; flex-direction:column; gap:2px;
}
.hoverTitle b{font-size:13px; line-height:1.2}
.hoverTitle span{font-size:11px;color:rgba(233,239,248,.70)}
.playPill{
  padding:8px 10px;
  border-radius:999px;
  background: rgba(96,165,250,.18);
  border:1px solid rgba(96,165,250,.35);
  color: rgba(233,239,248,.92);
  font-size:12px;
}


.gameCard .badge{display:none;}
.gameCard:hover .badge{display:block;}
.gameCard .fav{opacity:.85}


/* Hide empty ad slots (show only when real ad code is injected) */
.ad-slot{display:none;}
.ad-slot.hasAd{display:flex;}
.gridAd{display:none;}
.gridAd.hasAdWrap{display:block;}



/* Cookie banner */
.cookieBanner{
  position:fixed; left:0; right:0; bottom:0; z-index:80;
  padding:12px 12px 16px;
  background: rgba(11,18,32,.88);
  border-top:1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
}
.cookieInner{
  max-width:1180px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; flex-wrap:wrap;
}
.cookieText{display:flex; flex-direction:column; gap:6px; max-width:760px}
.cookieText b{font-size:13px}
.cookieText span{font-size:12px; color: rgba(233,239,248,.72); line-height:1.4}
.cookieText a{font-size:12px; color: rgba(96,165,250,.92)}
.cookieBtns{display:flex; gap:10px; align-items:center}
.cookieBtn.primary{
  background: rgba(96,165,250,.18);
  border-color: rgba(96,165,250,.35);
}


/* No text overlays on hover (preview only) */
.hoverOverlay{display:none !important;}
.playPill{display:none !important;}
.hoverTitle{display:none !important;}
/* Show only icon; hide favorite + badge unless hover */
.gameCard .fav{opacity:0; pointer-events:none;}
.gameCard:hover .fav{opacity:.9; pointer-events:auto;}
.gameCard .badge{display:none !important;}
