/* FoxSocAU Promotions Page – page-specific CSS */

.promotions-hero {
  background: linear-gradient(110deg, #e71d36 0 35%, #1c1830 60% 100%);
  color: #fff;
  padding: var(--space-10) 0 var(--space-8) 0;
}
.promotions-hero-content {
  max-width: 750px;
  margin: 0 auto;
  text-align: center;
}
.promotions-hero h1 {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-3);
}
.promotions-hero .lead {
  font-size: var(--font-size-lg);
  color: var(--color-gray-50);
  margin-bottom: var(--space-5);
}

.featured-promos-section {
  padding: var(--space-10) 0 var(--space-7) 0;
}
.featured-promos-grid {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  justify-content: center;
  margin-top: var(--space-4);
}
.featured-promo-card {
  flex: 1 1 350px;
  min-width: 320px;
  max-width: 420px;
  padding: var(--space-6) var(--space-4);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
}
.promo-banner {
  width: 88%;
  margin-bottom: var(--space-4);
}
.promo-banner img {
  border-radius: var(--radius-lg);
  width: 17%;
  margin: 0 auto;
}
.promo-timer {
  margin: var(--space-3) 0;
  font-size: var(--font-size-sm);
}
.promo-countdown-label {
  font-weight: 600;
  color: var(--color-primary);
}
.promo-cta {
  margin-top: var(--space-2);
}

.daily-bonus-section {
  margin: var(--space-8) auto;
  max-width: 850px;
}
.daily-bonus-content {
  text-align: center;
}
.daily-bonus-streaks-grid {
  display: flex;
  justify-content: center;
  gap: var(--space-5);
  margin: var(--space-5) 0 var(--space-2) 0;
}
.streak-tier {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-3) var(--space-4);
  min-width: 95px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.streak-label {
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--space-2);
  font-size: var(--font-size-base);
}
.streak-coin {
  font-weight: 700;
  font-size: var(--font-size-lg);
  color: var(--color-success);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}
.daily-bonus-cta {
  margin-top: var(--space-3);
}

.achieve-challenges-section {
  padding: var(--space-8) 0 var(--space-6) 0;
  background: var(--color-surface);
}
.achieve-challenges-grid {
  display: flex;
  gap: var(--space-5);
  flex-wrap: wrap;
  margin-top: var(--space-4);
  justify-content: center;
}
.achievement-card {
  flex: 1 1 290px;
  max-width: 340px;
  min-width: 220px;
  padding: var(--space-5) var(--space-4);
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
}
.achieve-progress-bar {
  width: 100%;
  background: var(--color-gray-800);
  border-radius: var(--radius-md);
  height: 12px;
  margin: var(--space-3) 0 var(--space-0) 0;
  overflow: hidden;
  position: relative;
}
.achieve-progress {
  display: block;
  background: linear-gradient(90deg,var(--color-success),var(--color-primary));
  height: 100%;
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  transition: width .4s cubic-bezier(.4,0,.2,1);
}
.achieve-progress-label {
  color: var(--color-gray-200);
  font-size: var(--font-size-xs);
  margin-top: var(--space-2);
}
.achieve-note {
  font-size: var(--font-size-sm);
  margin-top: var(--space-2);
  text-align: center;
}

.tournament-section {
  margin: var(--space-10) auto;
  max-width: 1050px;
  padding: var(--space-7) var(--space-6);
}
.tournament-flex {
  display: flex;
  gap: var(--space-7);
  flex-wrap: wrap;
  align-items: flex-start;
}
.tournament-info {
  flex: 2 1 340px;
  min-width: 250px;
}
.tournament-leaderboard {
  flex: 1 1 230px;
  min-width: 210px;
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: 0 0 0 2px var(--color-gray-800);
  padding: var(--space-4);
  margin-top: var(--space-3);
}
.leaderboard-list {
  margin: var(--space-2) 0 var(--space-3) 0;
  padding: 0;
}
.lb-rank {
  font-weight: 700;
  color: var(--color-primary);
  min-width: 1.7em;
  display: inline-block;
}
.lb-name {
  font-weight: 500;
  color: var(--color-text);
  margin: 0 7px;
}
.lb-score {
  font-weight: 700;
  color: var(--color-success);
  float: right;
  min-width: 55px;
}
.lb-note {
  font-size: var(--font-size-xs);
  color: var(--color-gray-200);
  text-align: right;
}
.referral-cta {width: 152px;width: 191px;margin: 0 auto;}
.tournament-details, .winners-list {
  margin-top: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-gray-200);
  padding-left: var(--space-4);
  padding-bottom: 20px;
}
.tournament-winners {
  margin-top: var(--space-5);
  font-size: var(--font-size-sm);
}

.referral-section {
  margin: var(--space-10) auto;
  max-width: 700px;
  padding: var(--space-6) var(--space-6);
}
.referral-flex {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.referral-info {
  min-width: 230px;
  text-align: center;
  display: flex;
  flex-direction: column;
}
.referral-section h2, .referral-section li {text-align: center;}
.referral-details {
  margin: var(--space-2) 0 var(--space-6) 0;
  color: var(--color-gray-200);
  font-size: var(--font-size-sm);
  padding-left: var(--space-4);
  text-align: left;
  display: inline-block;
}
.ref-copy-feedback {
  display: block;
  font-size: var(--font-size-xs);
  color: var(--color-success);
  margin-top: var(--space-2);
  min-height: 1.3em;
}

.seasonal-section {
  padding: var(--space-8) 0 var(--space-5) 0;
  background: var(--color-surface);
}
.seasonal-grid {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  justify-content: center;
  margin-top: var(--space-3);
}
.seasonal-card {
  flex: 1 1 350px;
  max-width: 430px;
  display: flex;
  gap: var(--space-5);
  align-items: center;
  min-width: 250px;
  padding: var(--space-5) var(--space-4);
}
.seasonal-card img {
  width: 90px;
  min-width: 60px;
  border-radius: var(--radius-lg);
  margin-right: var(--space-2);
}
.seasonal-dates {
  font-size: var(--font-size-xs);
  color: var(--color-warning);
  font-weight: 700;
  margin-left: 4px;
}
.seasonal-note {
  margin-top: var(--space-4);
  text-align: center;
  color: var(--color-gray-200);
  font-size: var(--font-size-sm);
}

.howto-section {
  padding: var(--space-6) var(--space-2) var(--space-5) var(--space-2);
  margin: var(--space-8) auto var(--space-6) auto;
  max-width: 720px;
}
.howto-list {
  margin-bottom: var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: 1.54;
}
.howto-list li {
  margin-bottom: var(--space-3);
}
.howto-disclaimer {
  color: var(--color-gray-200);
  font-size: var(--font-size-xs);
}

@media (max-width: 1100px) {
  .featured-promos-grid,
  .achieve-challenges-grid,
  .seasonal-grid {
    flex-direction: column;
    align-items: center;
    gap: var(--space-6);
  }
  .tournament-flex {
    flex-direction: column;
    gap: var(--space-5);
  }
}
@media (max-width: 700px) {
  .promotions-hero {
    padding: var(--space-7) 0;
  }
  .featured-promo-card, .seasonal-card {
    min-width: 94vw;
    max-width: 99vw;
    padding: var(--space-4) var(--space-2);
  }
  .card {
    padding: var(--space-4);
  }
  .daily-bonus-section,
  .referral-section,
  .tournament-section {
    padding: var(--space-5) var(--space-2);
  }
  .seasonal-grid {
    gap: var(--space-3);
  }
  .footer-main {gap: var(--space-3);}
}
@media (max-width: 460px) {
  .streak-tier {padding: var(--space-2) var(--space-1);min-width:70px;}
  .featured-promo-card,.achievement-card,.seasonal-card{padding:var(--space-3);}
}
