/* Bonuses Page Specific Styles */

/* Page Header */
.page-header {
  padding: 4rem 0 4rem;
  background: linear-gradient(135deg, rgba(15, 15, 35, 0.95), rgba(220, 38, 38, 0.8));
  position: relative;
  overflow: hidden;
}

.page-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><defs><pattern id="bonus-pattern" x="0" y="0" width="80" height="80" patternUnits="userSpaceOnUse"><polygon points="40,15 50,35 70,35 56,50 60,70 40,60 20,70 24,50 10,35 30,35" fill="%23FFD700" opacity="0.1"/><circle cx="20" cy="20" r="3" fill="%23DC2626" opacity="0.1"/><rect x="60" y="60" width="8" height="8" fill="%2300F5FF" opacity="0.1"/></pattern></defs><rect width="100%" height="100%" fill="url(%23bonus-pattern)"/></svg>');
  animation: bonusPattern 22s linear infinite;
  z-index: -1;
}

.page-title {
  font-family: 'Orbitron', monospace;
  font-size: 3rem;
  font-weight: 900;
  text-align: center;
  margin-bottom: 1.5rem;
  background: var(--gradient-1);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: bonusTitleGlow 3s ease-in-out infinite;
}

@keyframes bonusTitleGlow {
  0%, 100% { 
    filter: drop-shadow(0 0 15px rgba(255, 215, 0, 0.5));
    transform: scale(1);
  }
  50% { 
    filter: drop-shadow(0 0 35px rgba(255, 215, 0, 0.8));
    transform: scale(1.02);
  }
}

.page-subtitle {
  font-size: 1.2rem;
  text-align: center;
  color: var(--text-light);
  max-width: 800px;
  margin: 0 auto 2rem;
  line-height: 1.6;
}


@keyframes bonusPattern {
  0% { transform: translateX(0) translateY(0); }
  100% { transform: translateX(80px) translateY(80px); }
}

/* Welcome Package */
.welcome-package {
  padding: 5rem 0;
  background: var(--dark-bg);
}

.welcome-card {
  background: var(--dark-card);
  border-radius: 30px;
  padding: 3rem;
  border: 3px solid var(--primary-gold);
  position: relative;
  overflow: hidden;
}

.welcome-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--gradient-neon);
  opacity: 0.05;
  animation: welcomeGlow 4s ease-in-out infinite;
}

@keyframes welcomeGlow {
  0%, 100% { opacity: 0.05; }
  50% { opacity: 0.12; }
}

.welcome-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 3rem;
  flex-wrap: wrap;
  gap: 1rem;
}

.welcome-header h2 {
  font-family: 'Orbitron', monospace;
  font-size: 2.5rem;
  font-weight: 900;
  background: var(--gradient-1);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: welcomeTitleGlow 3s ease-in-out infinite;
}

@keyframes welcomeTitleGlow {
  0%, 100% { filter: drop-shadow(0 0 15px rgba(255, 215, 0, 0.5)); }
  50% { filter: drop-shadow(0 0 35px rgba(255, 215, 0, 0.8)); }
}

.promo-code {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: rgba(255, 215, 0, 0.1);
  padding: 1rem 1.5rem;
  border-radius: 20px;
  border: 2px solid var(--primary-gold);
}

.promo-code span {
  color: var(--text-light);
  font-weight: 600;
}

.promo-code code {
  background: var(--gradient-1);
  color: var(--dark-bg);
  padding: 0.5rem 1rem;
  border-radius: 10px;
  font-family: 'Orbitron', monospace;
  font-weight: 900;
  font-size: 1.1rem;
  letter-spacing: 1px;
}

.copy-code {
  background: var(--gradient-2);
  border: none;
  color: white;
  padding: 0.5rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.copy-code:hover {
  background: var(--primary-gold);
  color: var(--dark-bg);
  transform: scale(1.1);
}

.welcome-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

.welcome-visual {
  position: relative;
}

.welcome-visual img {
  width: 100%;
  height: 250px;
  object-fit: cover;
  border-radius: 20px;
}

.bonus-amount {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.8);
  border: 3px solid var(--primary-gold);
  border-radius: 20px;
  padding: 2rem;
  text-align: center;
  backdrop-filter: blur(10px);
}

.bonus-percentage {
  font-family: 'Orbitron', monospace;
  font-size: 3rem;
  font-weight: 900;
  color: var(--primary-gold);
  animation: bonusGlow 2s ease-in-out infinite;
}

@keyframes bonusGlow {
  0%, 100% { 
    text-shadow: 0 0 20px var(--primary-gold);
    transform: scale(1);
  }
  50% { 
    text-shadow: 0 0 40px var(--primary-gold), 0 0 60px var(--primary-gold);
    transform: scale(1.05);
  }
}

.bonus-label {
  color: var(--text-light);
  font-weight: 600;
  margin-top: 0.5rem;
}

.bonus-features {
  margin-bottom: 2rem;
}

.bonus-feature {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
  padding: 1.5rem;
  background: rgba(255, 215, 0, 0.1);
  border-radius: 15px;
  border: 1px solid rgba(255, 215, 0, 0.3);
  transition: all 0.3s ease;
}

.bonus-feature:hover {
  background: rgba(255, 215, 0, 0.2);
  transform: translateX(10px);
}

.feature-icon {
  width: 60px;
  height: 60px;
  background: var(--gradient-2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: white;
  flex-shrink: 0;
  transition: all 0.3s ease;
}

.bonus-feature:hover .feature-icon {
  background: var(--gradient-1);
  transform: scale(1.1) rotate(360deg);
}

.feature-content h3 {
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--text-light);
}

.feature-content p {
  color: var(--text-gray);
  line-height: 1.5;
}

.welcome-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.welcome-actions .btn {
  padding: 1rem 2rem;
  font-size: 1.1rem;
}

/* Ongoing Promotions */
.ongoing-promotions {
  padding: 5rem 0;
  background: linear-gradient(180deg, var(--dark-bg), rgba(26, 26, 53, 0.8));
}

.promotions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 2rem;
}

.promotion-card {
  background: var(--dark-card);
  border-radius: 25px;
  overflow: hidden;
  position: relative;
  transition: all 0.4s ease;
  border: 3px solid transparent;
}

.promotion-card.friday {
  border-color: var(--primary-gold);
  background: linear-gradient(135deg, var(--dark-card), rgba(255, 215, 0, 0.05));
}

.promotion-card.cashback {
  border-color: var(--accent-green);
  background: linear-gradient(135deg, var(--dark-card), rgba(5, 150, 105, 0.05));
}

.promotion-card.daily {
  border-color: var(--primary-blue);
  background: linear-gradient(135deg, var(--dark-card), rgba(30, 58, 138, 0.05));
}

.promotion-card.sports {
  border-color: var(--accent-red);
  background: linear-gradient(135deg, var(--dark-card), rgba(220, 38, 38, 0.05));
}

.promotion-card:hover {
  transform: translateY(-10px) scale(1.02);
  box-shadow: 0 25px 50px rgba(255, 215, 0, 0.3);
}

.promotion-badge {
  position: absolute;
  top: 20px;
  right: 20px;
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 700;
  z-index: 3;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.friday .promotion-badge {
  background: var(--gradient-1);
  color: var(--dark-bg);
}

.cashback .promotion-badge {
  background: var(--accent-green);
}

.daily .promotion-badge {
  background: var(--gradient-2);
}

.sports .promotion-badge {
  background: var(--accent-red);
}

.promotion-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.promotion-card:hover img {
  transform: scale(1.05);
}

.promotion-content {
  padding: 2rem;
}

.promotion-content h3 {
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 0.8rem;
  color: var(--text-light);
}

.promotion-offer {
  font-family: 'Orbitron', monospace;
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--primary-gold);
  margin-bottom: 1rem;
  animation: offerPulse 3s ease-in-out infinite;
}

@keyframes offerPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.8; }
}

.promotion-content p {
  color: var(--text-gray);
  line-height: 1.5;
  margin-bottom: 1.5rem;
}

.promotion-details {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.promotion-details span {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255, 215, 0, 0.1);
  padding: 0.5rem 0.8rem;
  border-radius: 10px;
  font-size: 0.8rem;
  color: var(--text-light);
  border: 1px solid rgba(255, 215, 0, 0.2);
}

.promotion-details i {
  color: var(--primary-gold);
}

/* VIP & Loyalty */
.vip-loyalty {
  padding: 5rem 0;
  background: var(--dark-card);
}

.vip-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start;
}

.vip-description h3 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--primary-gold);
}

.vip-bangla {
  color: var(--primary-gold);
  font-weight: 600;
  margin-bottom: 1.5rem;
  font-size: 1.1rem;
}

.vip-description p {
  color: var(--text-gray);
  line-height: 1.6;
  margin-bottom: 2rem;
}

.vip-benefits {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}

.vip-benefit {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: rgba(255, 215, 0, 0.1);
  border-radius: 10px;
  border: 1px solid rgba(255, 215, 0, 0.3);
  transition: all 0.3s ease;
}

.vip-benefit:hover {
  background: rgba(255, 215, 0, 0.2);
  transform: scale(1.02);
}

.vip-benefit i {
  color: var(--primary-gold);
  font-size: 1.2rem;
}

.vip-benefit span {
  color: var(--text-light);
  font-weight: 500;
}

.vip-tiers {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.vip-tier {
  background: var(--dark-bg);
  border-radius: 20px;
  padding: 2rem;
  text-align: center;
  border: 2px solid rgba(255, 215, 0, 0.2);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.vip-tier:hover {
  border-color: var(--primary-gold);
  transform: translateY(-5px);
  box-shadow: 0 15px 30px rgba(255, 215, 0, 0.2);
}

.vip-tier.bronze {
  border-color: #CD7F32;
}

.vip-tier.silver {
  border-color: #C0C0C0;
}

.vip-tier.gold {
  border-color: var(--primary-gold);
}

.tier-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
  animation: tierGlow 3s ease-in-out infinite;
}

@keyframes tierGlow {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.1); }
}

.vip-tier h4 {
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: var(--text-light);
}

.tier-requirement {
  color: var(--primary-gold);
  font-weight: 600;
  margin-bottom: 1rem;
  font-size: 0.9rem;
}

.vip-tier ul {
  list-style: none;
  text-align: left;
}

.vip-tier li {
  color: var(--text-gray);
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
}

.vip-tier li::before {
  content: '✓ ';
  color: var(--accent-green);
  font-weight: 600;
}

/* Holiday Events */
.holiday-events {
  padding: 5rem 0;
  background: linear-gradient(180deg, var(--dark-card), var(--dark-bg));
}

.section-description {
  text-align: center;
  color: var(--text-gray);
  max-width: 700px;
  margin: 0 auto 3rem;
  font-size: 1.1rem;
  line-height: 1.6;
}

.events-timeline {
  max-width: 800px;
  margin: 0 auto;
  position: relative;
}

.events-timeline::before {
  content: '';
  position: absolute;
  left: 30px;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--gradient-1);
  border-radius: 2px;
}

.event-item {
  position: relative;
  margin-bottom: 3rem;
  padding-left: 100px;
  display: flex;
  align-items: center;
  gap: 2rem;
}

.event-item::before {
  content: '';
  position: absolute;
  left: 22px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: var(--primary-gold);
  border-radius: 50%;
  border: 3px solid var(--dark-bg);
  z-index: 2;
}

.event-item.upcoming::before {
  background: var(--primary-blue);
  animation: upcomingPulse 2s ease-in-out infinite;
}

.event-item.active::before {
  background: var(--accent-green);
  animation: activePulse 1.5s ease-in-out infinite;
}

.event-item.past::before {
  background: var(--text-gray);
  opacity: 0.6;
}

@keyframes upcomingPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(30, 58, 138, 0.7); }
  50% { box-shadow: 0 0 0 8px rgba(30, 58, 138, 0); }
}

@keyframes activePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(5, 150, 105, 0.7); }
  50% { box-shadow: 0 0 0 8px rgba(5, 150, 105, 0); }
}

.event-date {
  background: var(--dark-card);
  border-radius: 15px;
  padding: 1rem;
  text-align: center;
  border: 2px solid rgba(255, 215, 0, 0.3);
  min-width: 80px;
}

.event-date .month {
  color: var(--primary-gold);
  font-weight: 600;
  font-size: 0.8rem;
}

.event-date .day {
  color: var(--text-light);
  font-size: 1.5rem;
  font-weight: 900;
  font-family: 'Orbitron', monospace;
}

.event-content {
  flex: 1;
  background: var(--dark-card);
  border-radius: 15px;
  padding: 1.5rem;
  border: 2px solid rgba(255, 215, 0, 0.2);
  transition: all 0.3s ease;
}

.event-item:hover .event-content {
  border-color: var(--primary-gold);
  transform: translateX(10px);
}

.event-content h3 {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 0.8rem;
  color: var(--text-light);
}

.event-content p {
  color: var(--text-gray);
  line-height: 1.5;
  margin-bottom: 1rem;
}

.event-prizes {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.event-prizes span {
  background: rgba(255, 215, 0, 0.2);
  color: var(--primary-gold);
  padding: 0.3rem 0.8rem;
  border-radius: 10px;
  font-size: 0.8rem;
  font-weight: 500;
  border: 1px solid rgba(255, 215, 0, 0.3);
}

.event-status {
  padding: 0.5rem 1rem;
  border-radius: 15px;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.event-status.upcoming {
  background: var(--primary-blue);
  color: white;
}

.event-status.active {
  background: var(--accent-green);
  color: white;
}

.event-status.past {
  background: var(--text-gray);
  color: var(--dark-bg);
  opacity: 0.7;
}

/* How to Claim */
.how-to-claim {
  padding: 5rem 0;
  background: var(--dark-bg);
}

.claim-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
}

.claim-step {
  background: var(--dark-card);
  border-radius: 20px;
  padding: 2rem;
  text-align: center;
  position: relative;
  border: 2px solid rgba(255, 215, 0, 0.2);
  transition: all 0.4s ease;
}

.claim-step:hover {
  border-color: var(--primary-gold);
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(255, 215, 0, 0.2);
}

.step-number {
  width: 60px;
  height: 60px;
  background: var(--gradient-2);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 900;
  margin: 0 auto 1.5rem;
  font-family: 'Orbitron', monospace;
  transition: all 0.3s ease;
}

.claim-step:hover .step-number {
  background: var(--gradient-1);
  transform: scale(1.1);
}

.step-content h3 {
  font-size: 1.2rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: var(--text-light);
}

.step-content p {
  color: var(--text-gray);
  line-height: 1.5;
}

/* Responsible Gaming */
.responsible-gaming {
  padding: 4rem 0;
  background: rgba(220, 38, 38, 0.1);
}

.responsible-card {
  background: var(--dark-card);
  border-radius: 25px;
  padding: 3rem;
  display: flex;
  align-items: center;
  gap: 2rem;
  border: 3px solid var(--accent-red);
  max-width: 900px;
  margin: 0 auto;
}

.responsible-icon {
  width: 100px;
  height: 100px;
  background: var(--accent-red);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  color: white;
  flex-shrink: 0;
  animation: responsibleGlow 3s ease-in-out infinite;
}

@keyframes responsibleGlow {
  0%, 100% { 
    box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.7);
  }
  50% { 
    box-shadow: 0 0 0 15px rgba(220, 38, 38, 0);
  }
}

.responsible-content h3 {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--accent-red);
}

.responsible-content p {
  color: var(--text-gray);
  line-height: 1.6;
  margin-bottom: 1rem;
}

.responsible-bangla {
  color: var(--primary-gold);
  font-weight: 600;
  margin-bottom: 2rem;
}

.responsible-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

/* Bonus Terms */
.bonus-terms {
  padding: 4rem 0;
  background: var(--dark-card);
}

.terms-card {
  background: var(--dark-bg);
  border-radius: 25px;
  padding: 3rem;
  border: 2px solid rgba(255, 215, 0, 0.3);
  max-width: 1000px;
  margin: 0 auto;
}

.terms-card h3 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 2rem;
  color: var(--primary-gold);
  text-align: center;
}

.terms-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-bottom: 2rem;
}

.terms-section h4 {
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: var(--text-light);
}

.terms-section ul {
  list-style: none;
}

.terms-section li {
  color: var(--text-gray);
  margin-bottom: 0.8rem;
  padding-left: 1.5rem;
  position: relative;
  line-height: 1.5;
}

.terms-section li::before {
  content: '•';
  color: var(--primary-gold);
  position: absolute;
  left: 0;
  font-size: 1.2rem;
}

.terms-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.terms-actions .btn {
  padding: 1rem 2rem;
  font-size: 1.1rem;
}

/* Responsive Design */
@media (max-width: 768px) {
  .welcome-content {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  
  .welcome-header {
    flex-direction: column;
    text-align: center;
  }
  
  .welcome-header h2 {
    font-size: 2rem;
  }
  
  .promotions-grid {
    grid-template-columns: 1fr;
  }
  
  .vip-content {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  
  .vip-benefits {
    grid-template-columns: 1fr;
  }
  
  .event-item {
    padding-left: 80px;
    flex-direction: column;
    gap: 1rem;
  }
  
  .events-timeline::before {
    left: 20px;
  }
  
  .event-item::before {
    left: 12px;
  }
  
  .claim-steps {
    grid-template-columns: 1fr;
  }
  
  .responsible-card {
    flex-direction: column;
    text-align: center;
  }
  
  .terms-content {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
	.promo-code {
		flex-wrap: wrap;
	}
}

@media (max-width: 480px) {
  .page-header {
    padding: 6rem 0 3rem;
  }
  
  .welcome-card {
    padding: 1rem;
  }
  
  .bonus-percentage {
    font-size: 2.5rem;
  }
  
  
  .promotion-content {
    padding: 1.5rem;
  }
  
  .vip-tier {
    padding: 1.5rem;
  }
  
  .event-item {
    padding-left: 60px;
  }
  
  .event-date {
    min-width: 60px;
    padding: 0.8rem;
  }
  
  .claim-step {
    padding: 1.5rem;
  }
  
  .step-number {
    width: 50px;
    height: 50px;
    font-size: 1.2rem;
  }
  
  .responsible-card {
    padding: 2rem;
    margin: 0 1rem;
  }
  
  .responsible-icon {
    width: 80px;
    height: 80px;
    font-size: 2rem;
  }
  
  .terms-card {
    padding: 1rem;
  }
}
