:root{
  --bg:#0b0f19;
  --card:#101827;
  --text:#e5e7eb;
  --muted:#94a3b8;
  --line:rgba(148,163,184,.18);
  --accent:#7c3aed;
  --accent2:#22c55e;

  --max: 1100px;
  --r: 18px;
  --gap: 18px;
}

*{ box-sizing:border-box; }
/* html,body{ height:100%; } */
body{
  margin:0 auto;
  background: radial-gradient(1200px 800px at 20% -10%, rgba(124,58,237,.25), transparent 60%),
              radial-gradient(900px 600px at 90% 10%, rgba(34,197,94,.18), transparent 55%),
              var(--bg);
  color: var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  -webkit-text-size-adjust: 100%;
}

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }

.site{
  max-width: var(--max);
  margin: 0 auto;
  padding: 18px 16px 28px;
}

/* Topbar */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 10px 0 18px;
  border-bottom: 1px solid var(--line);
}

.brand{
  display:flex;
  align-items:center;
  gap: 10px;
}

.brand-logo{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  object-fit: cover;
}

.brand-name{
  font-weight: 800;
  letter-spacing: .2px;
  font-size: 18px;
}

.nav{
  display:flex;
  gap: 14px;
  color: var(--muted);
  font-weight: 600;
  font-size: 14px;
}
.nav a:hover{ color: var(--text); }

/* Hero */
.hero{
  padding: 24px 0 6px;
}

.hero-inner{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 22px;
  align-items: center;
  background: linear-gradient(180deg, rgba(16,24,39,.9), rgba(16,24,39,.55));
  border: 1px solid var(--line);
  border-radius: calc(var(--r) + 4px);
  padding: 22px;
}

.kicker{
  margin:0 0 10px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 12px;
  font-weight: 700;
}

.hero-title{
  margin: 0 0 10px;
  font-size: clamp(14px, 1vw, 46px);
  line-height: 1.05;
  letter-spacing: -.02em;
}

.hero-sub{
  margin: 0 0 16px;
  color: var(--muted);
  max-width: 52ch;
  line-height: 1.5;
  font-size: clamp(18px, 4vw, 23px);
}

.hero-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 14px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 14px;
  border: 1px solid var(--line);
}

.btn-primary{
  background: linear-gradient(135deg, rgba(124,58,237,1), rgba(99,102,241,1));
  border: none;
}

.btn-ghost{
  color: var(--text);
  background: rgba(148,163,184,.08);
}

.hero-art img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: var(--r);
  border: 1px solid var(--line);
}

/* Ad */
.ad{
  padding: 14px 0 4px;
}

/* Sections */
.section{
  padding: 18px 0 6px;
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 12px;
}

.section-head h2{
  margin:0;
  font-size: 18px;
  letter-spacing: -.01em;
}

.link{
  color: var(--muted);
  font-weight: 700;
  font-size: 13px;
}
.link:hover{ color: var(--text); }

/* Two columns panels */
.two-col{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
}

.panel{
  background: rgba(16,24,39,.75);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 14px;
}

.panel-title{
  margin: 0 0 10px;
  font-size: 14px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .14em;
}

/* Grid list for games */
.grid{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

/* 给未知 li 结构做兜底：不管里面是 a/img/p 都尽量规整 */
.grid > li{
  background: rgba(16,24,39,.75);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow:hidden;
  min-height: 160px;
}

/* 兼容常见结构：li a img */
.grid > li a{
  display:block;
  height:100%;
}

.grid img{
  width:100%;
  height: 120px;
  object-fit: cover;
}

.grid p, .grid span, .grid .name, .grid .title{
  margin: 10px 10px 12px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.25;
}

/* Ranking list 兼容：如果 top-con 生成的是 li */
.top-con{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.top-con > li{
  display:flex;
  gap: 10px;
  align-items:center;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(148,163,184,.06);
}

/* Footer */
.footer{
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
  text-align:center;
}

.footer-links{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap: 10px;
  color: var(--muted);
  font-weight: 700;
  font-size: 13px;
}
.footer-links a:hover{ color: var(--text); }

.muted{
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 12px;
}

/* Mobile */
@media (max-width: 860px){
  .hero-inner{ grid-template-columns: 1fr; }
  .hero-art img{ height: 200px; }
  .grid{ grid-template-columns: repeat(2, 1fr); }
  .two-col{ grid-template-columns: 1fr; }
}

@media (min-width: 861px) and (max-width: 1100px){
  .grid{ grid-template-columns: repeat(3, 1fr); }
}
