/* ================================
   FocusSoc Games Page Custom CSS
================================== */

/* Gallery Grid */
.games-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
  margin-top: var(--space-6);
  margin-bottom: var(--space-8);
  justify-items: center;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}
.games-h1 {
  margin-top: 52px;
  text-align: center;
  background: linear-gradient(90deg, #f44336 20%, #ffb915 60%, #2ecc40 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
}
.gallery-intro { text-align: center; font-size: var(--font-size-lg); margin-bottom: 43px; }

.game-preview-card {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--space-6) var(--space-4);
  display: flex; flex-direction: column; align-items: center;
  transition: box-shadow var(--transition), transform var(--transition);
  min-height: 390px; position: relative; text-align: center;
  width: 100%; max-width: 400px;
}
.game-preview-card:hover, .game-preview-card:focus-within { box-shadow: var(--shadow-xl); transform: translateY(-4px) scale(1.03); }
.game-preview-img { width: 190px; height: 108px; object-fit: cover; border-radius: var(--radius-md); margin-bottom: var(--space-3); }
.game-title { font-size: var(--font-size-xl); margin-bottom: var(--space-2); }
.game-intro { color: var(--color-gray-200); font-size: var(--font-size-base); margin-bottom: var(--space-4); text-align: center; max-width: 52ch; }
.game-play-cta { margin-top: auto; min-width: 108px; }

/* How To Play Accordion */
.how-to-play-section { margin-top: var(--space-8); padding-left: var(--space-4); padding-right: var(--space-4); }
.htp-accordion { margin-top: 37px;display: flex; flex-direction: column; gap: var(--space-2); }
.htp-item { border-radius: var(--radius-md); background: var(--color-background); margin-bottom: var(--space-1); box-shadow: var(--shadow-sm); }
.htp-toggle {
  width: 100%; padding: var(--space-3) var(--space-4); background: none; color: var(--color-warning);
  text-align: left; font-size: var(--font-size-lg); font-weight: 700; border: none; cursor: pointer;
  border-radius: var(--radius-md); transition: background var(--transition);
}
.htp-toggle[aria-expanded="true"] { background: var(--color-surface); color: var(--color-primary); }
.htp-content {
  padding: 17px 0 12px 12px;
  color: var(--color-gray-200); font-size: var(--font-size-base);
  border-left: 4px solid var(--color-primary); background: var(--color-surface);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  text-align: left; margin-left: auto; margin-right: auto;
}
.htp-tips { margin-top: var(--space-2); color: var(--color-success); font-style: italic; font-size: var(--font-size-sm); }

/* Featured Game */
.featured-game-flex {
  gap: var(--space-8); align-items: center; margin-top: var(--space-2);
  padding-left: var(--space-4); padding-right: var(--space-4);
}
.featured-game-img {
  width: 140px; height: 140px; border-radius: var(--radius-lg); margin: 34px 0;
  box-shadow: var(--shadow-xl); object-fit: cover; background: #23244a; justify-self: center;
}
.featured-game-desc {
  display: flex; flex-direction: column; gap: var(--space-2);
  align-items: center; text-align: center; max-width: 70ch; margin: 0 auto;
}
.featured-cta { margin-top: 25px; align-self: center; }
.badge-achievement {
  display: inline-block; background: var(--color-success); color: var(--color-surface);
  font-weight: 700; border-radius: var(--radius-sm); padding: 2px 8px; margin-right: 10px;
  font-size: var(--font-size-sm); vertical-align: middle;
}

/* Achievements & Rewards */
.rewards-flex {
  display: flex; flex-direction: column; 1fr auto; align-items: center;
  gap: var(--space-8); margin-top: var(--space-2);
  padding-left: var(--space-4); padding-right: var(--space-4);
}
.rewards-info { max-width: 88ch; margin: 0 auto; }
.rewards-list { display: flex; flex-direction: column; gap: var(--space-2); font-size: var(--font-size-base);}
.rewards-list li {    margin: 14px 0;}
.rewards-visuals { display: flex; gap: var(--space-3); font-size: 2.1em; align-items: center; justify-content: center; }
.badge-icon { background: var(--color-primary); color: #fff; border-radius: var(--radius-md); padding: 6px 12px; box-shadow: 0 2px 8px rgba(24,26,32,0.18); }

/* Leaderboards */
.leaderboards-section { margin-top: var(--space-8); padding-left: var(--space-4); padding-right: var(--space-4); }
.live-leaderboard {
  margin-top: 34px; margin-bottom: 34px;
  display: flex; flex-direction: column; gap: var(--space-2);
  max-width: 1005px; margin-left: auto; margin-right: auto;
}
.live-leaderboard li {
  background: var(--color-background);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--font-size-lg);
  display: flex; align-items: center; gap: var(--space-3); color: var(--color-text);
}
.leader-pos { font-weight: 900; color: var(--color-primary); margin-right: var(--space-2); }
.leader-name { font-weight: 600; }
.leader-score { margin-left: auto; color: var(--color-warning); }
.leaderboard-info { margin-top: var(--space-2); font-size: var(--font-size-base); display: flex; flex-direction: column; gap: var(--space-2); align-items: center; }
.mini-cta { margin-top: var(--space-2); padding: 14px; min-width: 100px; font-size: var(--font-size-base); }

/* Social Play */
.social-flex {
  gap: var(--space-6); align-items: center; margin-bottom: var(--space-2);
  padding-left: var(--space-4); padding-right: var(--space-4);
}
.social-info { max-width: 70ch; margin: 30px auto; }
.social-visuals { display: flex; gap: var(--space-2); align-items: center; font-size: 2em; justify-content: center; }
.cta-center { display: flex; justify-content: center; }

/* Disclaimer */
.disclaimer-section { margin-top: var(--space-8); margin-bottom: var(--space-8); padding-left: var(--space-4); padding-right: var(--space-4); }
.disclaimer-card {
  background: var(--color-danger); color: var(--color-gray-100);
  font-size: var(--font-size-base); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl); padding: var(--space-8) var(--space-6);
  text-align: center; max-width: 1168px; margin: 0 auto;
}
.disclaimer-h2 { color: #fff; margin-bottom: var(--space-3); }

@media (max-width: 900px) {
  .featured-game-flex, .rewards-flex, .social-flex { grid-template-columns: 1fr; gap: var(--space-4); align-items: center; text-align: center; }
  .featured-game-img { margin-bottom: var(--space-2); width: 100%; max-width: 240px; height: auto; }
}
@media (max-width: 540px) {
  .games-h1 { font-size: 1.5rem; }
  .game-title { font-size: 1.1rem; }
  .gallery-intro { font-size: 1rem; }
  .game-preview-card { min-height: 0; padding: var(--space-4) var(--space-2); }
  .disclaimer-card { font-size: 0.92rem; padding: var(--space-4); }
}
