/* ── Game grid ── */
.game-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: .75rem;
  padding: 1rem;
}
@media (min-width: 640px) {
  .game-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
}

/* ── Game card ── */
.game-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: .75rem; overflow: hidden;
  transition: border-color .15s, transform .15s; display: block;
}
.game-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.game-card img {
  width: 100%; aspect-ratio: 16/9; object-fit: cover;
  display: block; background: var(--bg-3);
}
.game-card-body { padding: .5rem .6rem .6rem; }
.game-card-name {
  font-size: .8rem; font-weight: 500; color: var(--text-1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.game-card-provider { font-size: .7rem; color: var(--text-3); margin-top: .15rem; }

/* ── Provider card ── */
.provider-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: .75rem; padding: 1rem; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
  transition: border-color .15s, transform .15s;
}
.provider-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.provider-card img { width: 64px; height: 64px; object-fit: contain; border-radius: .5rem; background: var(--bg-3); }
.provider-card .name { font-size: .82rem; font-weight: 500; color: var(--text-1); }
.provider-fallback {
  width: 64px; height: 64px; border-radius: .5rem; background: var(--bg-3);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-3); font-weight: 700;
}

/* ── Game embed (detail) ── */
.game-embed-wrap {
  position: relative; width: 100%; aspect-ratio: 16/9;
  background: var(--bg-3); border-radius: .75rem;
  overflow: hidden; cursor: pointer;
}
.game-embed-wrap iframe { width: 100%; height: 100%; border: none; }
.game-embed-cover { position: absolute; inset: 0; }

/* ── Halaman detail game ── */
.game-title { font-size: clamp(1.2rem, 4vw, 1.8rem); }
.game-meta { text-align: center; font-size: .85rem; color: var(--text-3); margin-bottom: 1rem; }
.game-article {
  margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border);
  color: var(--text-2); line-height: 1.7;
  display: flex; flex-direction: column; gap: 1.5rem;
}
.game-article h2 { font-size: 1.05rem; color: var(--text-1); margin-bottom: .6rem; }

/* ── Spec card ── */
.spec-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: .75rem; padding: 1rem;
}
.spec-item { text-align: center; }
.spec-label { font-size: .7rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .05em; }
.spec-value { font-size: 1.1rem; font-weight: 700; color: var(--accent-text); margin-top: .2rem; }

/* ── Related games slider ── */
.slider-wrap { position: relative; overflow: hidden; }
.slider-track {
  display: flex; gap: .75rem; overflow-x: auto; scrollbar-width: none;
  padding: .25rem .25rem .5rem; scroll-snap-type: x mandatory;
}
.slider-track::-webkit-scrollbar { display: none; }
.slider-track .game-card { flex-shrink: 0; width: 42%; scroll-snap-align: start; }
@media (min-width: 640px)  { .slider-track .game-card { width: 22%; } }
@media (min-width: 1024px) { .slider-track .game-card { width: 15%; } }
.slider-fade-l, .slider-fade-r {
  position: absolute; top: 0; bottom: 0; width: 3rem; z-index: 5; pointer-events: none;
}
.slider-fade-l { left: 0;  background: linear-gradient(to right, var(--bg), transparent); }
.slider-fade-r { right: 0; background: linear-gradient(to left,  var(--bg), transparent); }

/* ── FAQ ── */
.faq-item {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: .75rem; padding: 1rem;
}
.faq-q { font-weight: 500; color: var(--text-1); margin-bottom: .4rem; }
.faq-a { font-size: .875rem; color: var(--text-3); }
