/* ==========================================================================
   Fantasy Innings Theme - Main Stylesheet
   ========================================================================== */

/* Custom Properties (CSS Variables) */
:root {
  --primary-color: #8B4513;
  --secondary-color: #D2691E;
  --success-color: #228B22;
  --warning-color: #FF8C00;
  --danger-color: #DC143C;
  --info-color: #4169E1;
  --light-color: #FFF8DC;
  --dark-color: #2F4F4F;
  
  --font-family-base: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  --font-weight-normal: 400;
  --font-weight-bold: 600;
  
  --border-radius: 0.375rem;
  --box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --box-shadow-lg: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  
  --transition-base: all 0.15s ease-in-out;
}

/* Base Styles */
body {
  font-family: var(--font-family-base);
  line-height: 1.6;
  color: var(--dark-color);
  background-color: #ffffff;
}

/* Utility Classes */
.min-vh-50 {
  min-height: 50vh;
}

.text-decoration-none {
  text-decoration: none !important;
}

.fw-bold {
  font-weight: var(--font-weight-bold) !important;
}

/* Header Styles */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1020;
  box-shadow: var(--box-shadow);
}

.navbar-brand {
  font-size: 1.5rem;
  font-weight: var(--font-weight-bold);
}

.logo-img {
  height: 40px;
  width: auto;
}

.navbar-nav .nav-link {
  font-weight: 500;
  padding: 0.75rem 1rem;
  transition: var(--transition-base);
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
  color: var(--warning-color) !important;
}

.download-app-btn {
  font-weight: var(--font-weight-bold);
  transition: var(--transition-base);
}

.download-app-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--box-shadow-lg);
}

/* Hero Section */
.hero-section {
  background: linear-gradient(135deg, var(--primary-color) 0%, #A0522D 100%);
  position: relative;
  overflow: hidden;
}

.hero-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  opacity: 0.1;
  z-index: 0;
}

.hero-content {
  position: relative;
  z-index: 1;
}

.hero-image img {
  border-radius: var(--border-radius);
  transition: var(--transition-base);
}

.hero-image img:hover {
  transform: scale(1.05);
}

/* Feature Cards */
.feature-card {
  transition: var(--transition-base);
  border: 1px solid #e9ecef;
}

.feature-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--box-shadow-lg);
}

.feature-icon {
  transition: var(--transition-base);
}

.feature-card:hover .feature-icon {
  transform: scale(1.1);
}

/* New Fantasy Innings specific styles */
.earn-method {
  transition: var(--transition-base);
}

.earn-method:hover {
  transform: translateY(-3px);
  box-shadow: var(--box-shadow-lg);
}

.usage-guide {
  transition: var(--transition-base);
}

.usage-guide:hover {
  transform: translateY(-2px);
  box-shadow: var(--box-shadow);
}

.tip-card {
  transition: var(--transition-base);
}

.tip-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--box-shadow-lg);
}

.contact-card {
  transition: var(--transition-base);
}

.contact-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--box-shadow-lg);
}

.step-item {
  transition: var(--transition-base);
}

.step-item:hover {
  transform: translateY(-2px);
}

.step-icon {
  color: var(--primary-color);
}

.step-number .badge {
  background-color: var(--primary-color) !important;
}

.contact-icon {
  color: var(--primary-color);
}

.method-icon {
  color: var(--primary-color);
}

.tip-icon {
  color: var(--primary-color);
}

/* Page Header */
.page-header {
  background: linear-gradient(135deg, var(--primary-color) 0%, #A0522D 100%);
  position: relative;
}

.page-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('../images/cricket-pattern.png') repeat;
  opacity: 0.1;
}

/* Steps Section */
.step-number {
  width: 50px;
  height: 50px;
  font-size: 1.25rem;
}

.step-item {
  position: relative;
  padding-left: 0;
}

/* Point System Cards */
.point-card {
  transition: var(--transition-base);
  background: #ffffff;
}

.point-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--box-shadow-lg);
}

.point-item {
  padding: 0.5rem 0;
  border-bottom: 1px solid #f8f9fa;
}

.point-item:last-child {
  border-bottom: none;
}

/* Contact Form */
.contact-form {
  background: #ffffff;
  border-radius: var(--border-radius);
}

.form-control {
  border-radius: var(--border-radius);
  border: 1px solid #dee2e6;
  transition: var(--transition-base);
}

.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.contact-item {
  display: flex;
  align-items: center;
  padding: 1rem 0;
  border-bottom: 1px solid #f8f9fa;
}

.contact-item:last-child {
  border-bottom: none;
}

.contact-icon {
  min-width: 50px;
}

/* Age Verification Modal */
.age-verification-content {
  text-align: center;
}

.age-verification-buttons .btn {
  min-width: 150px;
}

.restricted-regions {
  background: rgba(220, 53, 69, 0.1);
  border-radius: var(--border-radius);
  padding: 1rem;
  margin: 1rem 0;
}

/* Footer */
.site-footer {
  background: var(--dark-color) !important;
  margin-top: auto;
  color: #fff !important;
}

.text-muted .list-unstyled {
  color: #fff !important;
}

.site-footer a {
  transition: var(--transition-base);
}

.site-footer a:hover {
  color: var(--warning-color) !important;
}

/* Buttons */
.btn {
  border-radius: var(--border-radius);
  font-weight: 500;
  transition: var(--transition-base);
}

.btn-primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}

.btn-primary:hover {
  background-color: #0056b3;
  border-color: #004085;
  transform: translateY(-1px);
}

.btn-warning {
  background-color: var(--warning-color);
  border-color: var(--warning-color);
  color: var(--dark-color);
}

.btn-warning:hover {
  background-color: #e0a800;
  border-color: #d39e00;
  color: var(--dark-color);
  transform: translateY(-1px);
}

/* Responsive Design */
@media (max-width: 768px) {
  .hero-section {
      padding: 3rem 0;
  }
  
  .display-4 {
      font-size: 2rem;
  }
  
  .hero-buttons .btn {
      display: block;
      width: 100%;
      margin-bottom: 1rem;
  }
  
  .step-number {
      width: 40px;
      height: 40px;
      font-size: 1rem;
  }
  
  .contact-item {
      flex-direction: column;
      text-align: center;
  }
  
  .contact-icon {
      margin-bottom: 0.5rem;
  }
}

@media (max-width: 576px) {
  .navbar-brand {
      font-size: 1.25rem;
  }
  
  .logo-img {
      height: 30px;
  }
  
  .age-verification-buttons .btn {
      display: block;
      width: 100%;
      margin-bottom: 1rem;
  }
}

/* Loading Animation */
.loading {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 3px solid #f3f3f3;
  border-top: 3px solid var(--primary-color);
  border-radius: 50%;
  animation: spin 2s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Form Validation States */
.was-validated .form-control:valid {
  border-color: var(--success-color);
}

.was-validated .form-control:invalid {
  border-color: var(--danger-color);
}

.invalid-feedback {
  display: block;
  width: 100%;
  margin-top: 0.25rem;
  font-size: 0.875em;
  color: var(--danger-color);
}

.valid-feedback {
  display: block;
  width: 100%;
  margin-top: 0.25rem;
  font-size: 0.875em;
  color: var(--success-color);
}

/* Accessibility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Focus States */
.btn:focus,
.form-control:focus,
.nav-link:focus {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}

/* Print Styles */
@media print {
  .navbar,
  .site-footer,
  .btn,
  .modal {
      display: none !important;
  }
  
  .page-header {
      background: none !important;
      color: var(--dark-color) !important;
  }
  
  a {
      text-decoration: underline !important;
  }
}

/* Fantasy Innings Additional Styles */
.policy-content h2,
.terms-wrapper h2 {
  color: var(--primary-color);
  margin-top: 2rem;
  margin-bottom: 1rem;
  border-bottom: 2px solid var(--primary-color);
  padding-bottom: 0.5rem;
}

.policy-content h3,
.terms-wrapper h3 {
  color: var(--secondary-color);
  margin-top: 1.5rem;
  margin-bottom: 0.75rem;
}

.policy-content h4,
.terms-wrapper h4 {
  color: var(--dark-color);
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

.policy-content ul,
.terms-wrapper ul {
  padding-left: 1.5rem;
}

.policy-content li,
.terms-wrapper li {
  margin-bottom: 0.5rem;
}

.policy-content a,
.terms-wrapper a {
  color: var(--primary-color);
  text-decoration: none;
}

.policy-content a:hover,
.terms-wrapper a:hover {
  text-decoration: underline;
}

/* FAQ Accordion Styles */
.accordion-button:not(.collapsed) {
  background-color: var(--primary-color);
  color: white;
}

.accordion-button:focus {
  box-shadow: 0 0 0 0.25rem rgba(139, 69, 19, 0.25);
}

.accordion-button::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%238B4513'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.accordion-button:not(.collapsed)::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

/* Support Hours Styling */
.support-hours p {
  margin-bottom: 0.25rem;
}

.support-hours strong {
  color: var(--primary-color);
}

/* Social Links */
.social-links a {
  transition: var(--transition-base);
  display: inline-block;
}

.social-links a:hover {
  transform: translateY(-2px);
  color: var(--warning-color) !important;
}

/* Disclaimer Section */
.disclaimer-section {
  border-top: 2px solid var(--primary-color);
}

.disclaimer-section h6 {
  color: var(--primary-color);
}