/* ============================================================
   gamepage.css — BeamNG + Assetto Corsa listing pages
   ============================================================ */

/* ── GAME HERO ─────────────────────────────────────────── */

.game-hero {
  padding: 72px 0 52px;
  border-bottom: 1px solid var(--border);
  position: relative; overflow: hidden;
}

.game-hero::before {
  content: "";
  position: absolute; top: -80px; left: -80px;
  width: 500px; height: 400px; z-index: 0;
  background: radial-gradient(ellipse, color-mix(in srgb, var(--game-accent, var(--accent)) 12%, transparent) 0%, transparent 70%);
  pointer-events: none;
}

.game-hero-inner {
  position: relative; z-index: 1;
  display: flex; align-items: flex-end;
  justify-content: space-between; gap: 40px; flex-wrap: wrap;
}

.game-hero-title {
  font-family: var(--font-d);
  font-size: clamp(52px, 8vw, 88px);
  letter-spacing: 2px; line-height: .95;
  color: #fff; margin: 14px 0 14px;
}
.game-hero-title .dot { color: var(--accent); }
.game-hero-title .accent-mark { color: var(--game-accent, var(--accent)); }
.ac-title { color: #fff; }

.game-hero-sub {
  font-size: 15px; color: var(--text2);
  max-width: 420px; line-height: 1.7;
}

.game-intro-section {
  padding: 34px 0 0;
}
.game-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: var(--r2);
  background: linear-gradient(135deg, var(--dark2), rgba(18,20,27,.74));
  padding: 26px 28px;
}
.game-intro h2 {
  font-family: var(--font-d);
  font-size: 34px;
  line-height: 1;
  letter-spacing: 1px;
  color: #fff;
  margin: 8px 0 10px;
}
.game-intro p {
  max-width: 860px;
  color: var(--text2);
  line-height: 1.75;
  overflow-wrap: break-word;
  text-wrap: pretty;
}
.game-intro-stat {
  min-width: 126px;
  border-left: 1px solid var(--border);
  padding-left: 26px;
}
.game-intro-stat span {
  display: block;
  font-family: var(--font-d);
  font-size: 54px;
  line-height: .9;
  color: var(--game-accent, var(--accent));
}
.game-intro-stat small {
  display: block;
  margin-top: 8px;
  font-family: var(--font-m);
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text3);
}

/* Hero search */
.hero-search-wrap { flex-shrink: 0; }
.hero-search {
  width: 320px; height: 48px;
  background: var(--dark3); border: 1px solid var(--border2);
  border-radius: var(--r); outline: none;
  color: var(--text); font-size: 14px;
  padding: 0 18px; font-family: var(--font-b);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.hero-search::placeholder { color: var(--text3); }
.hero-search:focus {
  border-color: var(--game-accent, var(--accent));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--game-accent, var(--accent)) 16%, transparent);
}

/* ── FEATURED STRIP ────────────────────────────────────── */

.featured-section { padding: 44px 0 36px; }

.section-header { margin-bottom: 22px; }
.section-label {
  font-family: var(--font-m); font-size: 11px; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--text3);
}

.featured-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}

.feat-item {
  display: flex; gap: 0; border-radius: var(--r2);
  border: 1px solid var(--border); overflow: hidden;
  background: var(--dark2); cursor: pointer;
  transition: border-color var(--transition), transform var(--transition);
  flex-direction: column;
}
.feat-item:hover {
  border-color: var(--border2); transform: translateY(-3px);
}

.feat-item-thumb {
  aspect-ratio: 16/9; overflow: hidden;
  position: relative;
}
.feat-item-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s;
}
.feat-item:hover .feat-item-thumb img { transform: scale(1.06); }

.feat-item-body { padding: 16px 18px; }
.feat-item-cat {
  font-family: var(--font-m); font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text3); margin-bottom: 6px;
}
.feat-item-title {
  font-family: var(--font-d); font-size: 20px; letter-spacing: .5px;
  color: var(--text); margin-bottom: 4px; line-height: 1.1;
}
.feat-item-sub { font-size: 12.5px; color: var(--text2); line-height: 1.5; }

/* ── GRID TOOLBAR ──────────────────────────────────────── */

.grid-section { padding: 36px 0 0; }

.mods-layout {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.mods-sidebar {
  position: sticky;
  top: 82px;
  border: 1px solid var(--border);
  border-radius: var(--r2);
  background: linear-gradient(145deg, rgba(18,20,27,.9), rgba(10,11,16,.86));
  padding: 12px;
}

.mods-main {
  min-width: 0;
}

.grid-toolbar {
  display: flex; align-items: center; justify-content: flex-start;
  flex-wrap: wrap; gap: 16px; margin-bottom: 28px;
}

.toolbar-right {
  display: grid;
  grid-template-columns: minmax(260px, 360px) auto auto;
  align-items: center;
  justify-content: start;
  gap: 10px 16px;
  width: 100%;
}
.toolbar-right .hero-search {
  width: 100%;
}

/* Category nav on game pages */
.cat-nav { display: flex; flex-direction: column; gap: 6px; }
.cat-nav .nav-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: var(--dark3); border: 1px solid var(--border);
  color: var(--text2); padding: 9px 11px; border-radius: 6px;
  font-size: 12px; font-weight: 500;
  text-align: left;
  transition: all var(--transition);
}
.cat-nav .nav-btn:hover  { color: var(--text); border-color: var(--border2); }
.cat-nav .nav-btn.active {
  color: var(--game-accent, var(--accent));
  border-color: var(--game-accent, var(--accent));
  background: color-mix(in srgb, var(--game-accent, var(--accent)) 12%, transparent);
}
.cat-nav .nav-btn em {
  min-width: 28px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  color: var(--text3);
  font-style: normal;
  font-family: var(--font-m);
  font-size: 10px;
}
.cat-nav .nav-btn.active em {
  color: var(--black);
  background: var(--game-accent, var(--accent));
}

.mod-count-label {
  font-family: var(--font-m); font-size: 11px;
  letter-spacing: 1px; color: var(--text3);
  white-space: nowrap;
}

.sort-select {
  background: var(--dark3); border: 1px solid var(--border);
  color: var(--text); padding: 8px 14px; border-radius: var(--r);
  outline: none; font-size: 13px; font-family: var(--font-b);
  cursor: pointer; transition: border-color var(--transition);
}
.sort-select:focus { border-color: var(--game-accent, var(--accent)); }

/* ── MODS GRID ─────────────────────────────────────────── */

.mods-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  padding-bottom: 26px;
}

.pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 0 0 60px;
}
.page-btn {
  min-width: 40px;
  height: 38px;
  padding: 0 14px;
  border-radius: var(--r);
  border: 1px solid var(--border);
  background: var(--dark3);
  color: var(--text2);
  font-family: var(--font-m);
  font-size: 11px;
  letter-spacing: 1px;
  cursor: pointer;
  transition: color var(--transition), border-color var(--transition), background var(--transition);
}
.page-btn:hover:not(:disabled),
.page-btn.active {
  color: var(--game-accent, var(--accent));
  border-color: var(--game-accent, var(--accent));
  background: color-mix(in srgb, var(--game-accent, var(--accent)) 10%, transparent);
}
.page-btn:disabled {
  opacity: .35;
  cursor: default;
}

/* Empty state */
.grid-empty {
  grid-column: 1 / -1;
  display: flex; flex-direction: column; align-items: center;
  padding: 80px 20px; gap: 16px; color: var(--text3);
}
.grid-empty svg { width: 44px; height: 44px; margin-bottom: 8px; }
.grid-empty p { font-size: 15px; color: var(--text2); }
.grid-empty button {
  background: var(--dark3); border: 1px solid var(--border2);
  color: var(--text2); padding: 10px 24px;
  border-radius: var(--r); font-size: 13px;
  transition: border-color var(--transition), color var(--transition);
}
.grid-empty button:hover { border-color: var(--game-accent, var(--accent)); color: var(--game-accent, var(--accent)); }

/* ── RESPONSIVE ────────────────────────────────────────── */

@media (max-width: 768px) {
  .game-hero-inner { flex-direction: column; align-items: flex-start; }
  .game-intro { grid-template-columns: 1fr; }
  .game-intro-stat {
    border-left: 0;
    border-top: 1px solid var(--border);
    padding-left: 0;
    padding-top: 18px;
  }
  .hero-search { width: 100%; }
  .hero-search-wrap { width: 100%; }
  .mods-layout { grid-template-columns: 1fr; }
  .mods-sidebar {
    position: static;
  }
  .cat-nav {
    max-height: 300px;
    overflow: auto;
  }
  .grid-toolbar { flex-direction: column; align-items: flex-start; }
  .toolbar-right {
    width: 100%;
    justify-content: stretch;
    grid-template-columns: 1fr;
  }
  .toolbar-right .hero-search {
    width: 100%;
  }
}
@media (max-width: 1100px) {
  .mods-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 820px) {
  .mods-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 500px) {
  .mods-grid { grid-template-columns: 1fr; }
}
