/* ============================================
   RESPONSIVE — DETECTIVE NOIR
   ============================================ */

/* --- Tablet (1024px) --- */
@media (max-width: 1024px) {
  :root {
    --section-gap: 80px;
  }

  .hero-content {
    grid-template-columns: 1fr;
    gap: 48px;
    text-align: center;
  }

  .hero-text {
    max-width: 100%;
  }

  .hero-title {
    font-size: var(--text-5xl);
  }

  .hero-description {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .hero-ctas {
    justify-content: center;
  }

  .hero-stats {
    justify-content: center;
  }

  .hero-visual {
    max-width: 560px;
    margin: 0 auto;
  }

  .hero-floating-card--top {
    right: -10px;
    top: -10px;
  }

  .hero-floating-card--bottom {
    left: -10px;
  }

  .features-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .game-details {
    grid-template-columns: repeat(2, 1fr);
  }

  .dashboard-grid {
    grid-template-columns: 1fr;
  }

  .categories-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .rewards-hero-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .rewards-grid {
    grid-template-columns: 1fr;
  }

  .about-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }

  .footer-brand {
    grid-column: 1 / -1;
  }

  .contact-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .section-header h2 {
    font-size: var(--text-4xl);
  }

  .page-hero h1 {
    font-size: var(--text-5xl);
  }
}

/* --- Mobile (768px) --- */
@media (max-width: 768px) {
  :root {
    --section-gap: 60px;
    --container-padding: 20px;
  }

  .main-nav {
    display: none;
  }

  .header-actions .btn {
    display: none;
  }

  .mobile-toggle {
    display: flex;
  }

  .mobile-menu {
    display: flex;
  }

  .hero {
    min-height: auto;
    padding-top: 120px;
    padding-bottom: 60px;
  }

  .hero-title {
    font-size: var(--text-4xl);
  }

  .hero-description {
    font-size: var(--text-base);
  }

  .hero-stats {
    gap: 24px;
    flex-wrap: wrap;
  }

  .hero-stat-value {
    font-size: var(--text-2xl);
  }

  .hero-floating-card {
    display: none;
  }

  .features-grid {
    grid-template-columns: 1fr;
  }

  .game-details {
    grid-template-columns: 1fr;
  }

  .game-toolbar {
    flex-direction: column;
    gap: 12px;
    padding: 12px 16px;
  }

  .game-toolbar-center {
    flex-wrap: wrap;
    justify-content: center;
  }

  .categories-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .leaderboard-podium {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 8px;
  }

  .podium-item {
    padding: 20px 12px;
  }

  .podium-item--1 {
    padding: 28px 12px;
  }

  .leaderboard-row {
    grid-template-columns: 40px 36px 1fr auto;
    gap: 10px;
    padding: 12px 14px;
  }

  .daily-days {
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
  }

  .newsletter-inner {
    padding: 40px 24px;
  }

  .newsletter-form {
    flex-direction: column;
  }

  .newsletter-inner h2 {
    font-size: var(--text-3xl);
  }

  .section-header h2 {
    font-size: var(--text-3xl);
  }

  .page-hero h1 {
    font-size: var(--text-4xl);
  }

  .page-hero {
    padding: 120px 0 60px;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .rewards-hero-stats {
    grid-template-columns: 1fr 1fr;
  }

  .team-grid {
    grid-template-columns: 1fr 1fr;
  }

  .about-visual {
    grid-template-columns: 1fr 1fr;
  }

  .profile-stats {
    grid-template-columns: 1fr 1fr;
  }

  .leaderboard-tabs {
    flex-wrap: wrap;
  }
}

/* --- Small Mobile (480px) --- */
@media (max-width: 480px) {
  .hero-title {
    font-size: var(--text-3xl);
  }

  .hero-ctas {
    flex-direction: column;
  }

  .hero-ctas .btn {
    width: 100%;
  }

  .hero-stats {
    flex-direction: column;
    gap: 16px;
    align-items: center;
  }

  .categories-grid {
    grid-template-columns: 1fr;
  }

  .leaderboard-podium {
    grid-template-columns: 1fr;
  }

  .podium-item--1 { order: 1; }
  .podium-item--2 { order: 2; }
  .podium-item--3 { order: 3; }

  .rewards-hero-stats {
    grid-template-columns: 1fr;
  }

  .team-grid {
    grid-template-columns: 1fr;
  }

  .about-visual {
    grid-template-columns: 1fr;
  }

  .daily-days {
    grid-template-columns: repeat(4, 1fr);
  }

  .page-hero h1 {
    font-size: var(--text-3xl);
  }

  .section-header h2 {
    font-size: var(--text-2xl);
  }
}