html {
  font-size: 14px;
  scroll-behavior: smooth;
  position: relative;
  min-height: 100%;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

body {
  margin: 0;
  padding: 0;
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

main {
  flex: 1 0 auto;
  padding-bottom: 3rem;
}

.footer {
  flex-shrink: 0;
  width: 100%;
  position: relative;
  margin-top: auto;
}

/* Ensure all sections have proper spacing */
section {
  position: relative;
  z-index: 1;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem rgba(255, 255, 255, 0.75), 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.35);
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

/* BODS Custom Color Theme - Light Mode */
:root {
  /* Clean light palette with royal blue accent */
  --bods-primary: #2563EB;
  --bods-primary-hover: #1D4ED8;
  --bods-accent: #3B82F6;
  --bods-bg: #FFFFFF;
  --bods-surface: #FFFFFF;
  --bods-surface-alt: #F8FAFC;
  --bods-text: #1E293B;
  --bods-text-secondary: #64748B;
  --bods-muted: #94A3B8;
  --bods-border: #E2E8F0;
  --bods-footer-bg: #0F172A;
  --bods-success: #22C55E;

  --bods-primary-rgb: 37, 99, 235;
  --bods-accent-rgb: 59, 130, 246;
  --bods-bg-rgb: 255, 255, 255;
  --bods-surface-rgb: 255, 255, 255;

  /* Back-compat aliases used throughout the site */
  --bods-teal: var(--bods-primary);
  --bods-teal-rgb: var(--bods-primary-rgb);
  --bods-dark: var(--bods-footer-bg);
  --bods-dark-rgb: 15, 23, 42;
  --bods-light: #F1F5F9;

  /* Bootstrap theme overrides */
  --bs-body-bg: var(--bods-bg);
  --bs-body-color: var(--bods-text);
  --bs-body-color-rgb: 30, 41, 59;
  --bs-border-color: var(--bods-border);

  --bs-primary: var(--bods-primary);
  --bs-primary-rgb: var(--bods-primary-rgb);
  --bs-danger: #EF4444;
  --bs-danger-rgb: 239, 68, 68;

  --bs-secondary: var(--bods-muted);
  --bs-secondary-rgb: 148, 163, 184;

  /* Bootstrap uses these for .text-muted and some placeholders */
  --bs-secondary-color: var(--bods-text-secondary);
  --bs-tertiary-color: var(--bods-muted);
  --bs-emphasis-color: var(--bods-text);
  --bs-heading-color: var(--bods-text);

  --bs-dark: var(--bods-footer-bg);
  --bs-dark-rgb: 15, 23, 42;
  --bs-light: var(--bods-light);
  --bs-light-rgb: 241, 245, 249;

  --bs-link-color: var(--bods-primary);
  --bs-link-hover-color: var(--bods-primary-hover);

  --bs-card-bg: var(--bods-surface);
  --bs-card-border-color: var(--bods-border);
  --bs-card-color: var(--bods-text);

  --bs-focus-ring-color: rgba(var(--bods-primary-rgb), 0.25);
}

.text-muted {
  color: var(--bods-text-secondary) !important;
}

.badge.bg-secondary {
  background-color: var(--bods-light) !important;
  color: var(--bods-text) !important;
  border: 1px solid var(--bods-border);
}

/* Navbar / footer theming */
.bods-navbar {
  background: rgba(255, 255, 255, 0.95);
  border-bottom: 1px solid var(--bods-border);
  backdrop-filter: blur(10px);
}

.bods-navbar .nav-link,
.bods-navbar .btn.btn-link {
  color: var(--bods-text) !important;
}

.bods-navbar .nav-link:hover,
.bods-navbar .btn.btn-link:hover {
  color: var(--bods-primary) !important;
}

.navbar-brand {
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--bods-primary) !important;
}

.card {
  border-radius: 1rem;
  background-color: var(--bs-card-bg);
  border: 1px solid var(--bods-border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.form-control:focus {
  border-color: var(--bods-primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--bods-primary-rgb), 0.15);
}

.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--bods-primary);
  --bs-btn-border-color: var(--bods-primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--bods-primary-hover);
  --bs-btn-hover-border-color: var(--bods-primary-hover);
  --bs-btn-focus-shadow-rgb: var(--bods-primary-rgb);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--bods-primary-hover);
  --bs-btn-active-border-color: var(--bods-primary-hover);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--bods-muted);
  --bs-btn-disabled-border-color: var(--bods-muted);

  background-color: var(--bods-primary);
  border-color: var(--bods-primary);
}

.btn-primary:hover {
  background-color: var(--bods-primary-hover);
  border-color: var(--bods-primary-hover);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(var(--bods-primary-rgb), 0.35);
}

.btn-outline-primary {
  --bs-btn-color: var(--bods-primary);
  --bs-btn-border-color: var(--bods-primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--bods-primary);
  --bs-btn-hover-border-color: var(--bods-primary);
}

.btn-success {
  --bs-btn-bg: var(--bods-success);
  --bs-btn-border-color: var(--bods-success);
  --bs-btn-hover-bg: #16A34A;
  --bs-btn-hover-border-color: #16A34A;
}

.btn-danger {
  --bs-btn-color: #fff;
  --bs-btn-bg: #EF4444;
  --bs-btn-border-color: #EF4444;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #DC2626;
  --bs-btn-hover-border-color: #DC2626;
  --bs-btn-focus-shadow-rgb: 239, 68, 68;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #DC2626;
  --bs-btn-active-border-color: #DC2626;
}

.btn-danger:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(239, 68, 68, 0.38);
}

a {
  text-decoration: none;
  color: var(--bods-primary);
}

a:hover {
  text-decoration: underline;
  color: var(--bods-primary-hover);
}

/* Platform Cards */
.platform-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  background: #fff;
}

.platform-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1) !important;
}

/* Affiliate Cards */
.affiliate-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  border-left: 4px solid var(--bods-primary);
}

.affiliate-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1) !important;
  border-left-color: var(--bods-primary-hover);
}

.affiliate-card .badge {
  font-size: 0.85rem;
  padding: 0.4rem 0.8rem;
}

/* Ensure affiliate banner images display correctly */
.affiliate-card img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* Special Offer Card Animation */
@keyframes pulse-border {
  0%, 100% {
    border-left-color: var(--bods-teal);
  }
  50% {
    border-left-color: var(--bs-primary);
  }
}

.card[style*="border-left: 5px solid #667eea"] {
  animation: pulse-border 3s ease-in-out infinite;
}

/* Special Offer Badge */
.badge.rounded-pill[style*="background: linear-gradient"] {
  animation: subtle-bounce 2s ease-in-out infinite;
}

@keyframes subtle-bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}

/* Performance Section */
.nav-tabs .nav-link {
  color: var(--bs-secondary-color);
  border: none;
  border-bottom: 3px solid transparent;
  font-weight: 600;
}

.nav-tabs .nav-link:hover {
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}

.nav-tabs .nav-link.active {
  color: var(--bs-primary);
  border-color: var(--bs-primary);
  background-color: transparent;
}

/* Hero Section */
.hero-section {
  background-color: var(--bods-surface-alt);
}

/* Use the same background as the hero section */
.bods-section {
  background-color: var(--bods-surface-alt);
}

/* Smooth Transitions */
.btn {
  transition: all 0.3s ease;
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Table Styling */
.table {
  --bs-table-color: var(--bods-text);
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--bods-border);
  --bs-table-striped-color: var(--bods-text);
  --bs-table-striped-bg: var(--bods-surface-alt);
  --bs-table-hover-color: var(--bods-text);
  --bs-table-hover-bg: rgba(var(--bods-primary-rgb), 0.05);
}

.table thead th {
  border-bottom: 2px solid var(--bods-primary);
  color: var(--bods-text);
  font-weight: 600;
}

code {
  background-color: var(--bods-surface-alt);
  border: 1px solid var(--bods-border);
  color: var(--bods-primary);
  padding: 0.2rem 0.4rem;
  border-radius: 0.25rem;
  font-size: 0.9em;
}

/* Footer link colors on dark background */
.footer {
  background-color: var(--bods-footer-bg);
  color: #fff;
}

.footer a {
  color: rgba(255, 255, 255, 0.8);
}

.footer a:hover {
  color: #fff;
}

.footer .text-muted {
  color: rgba(255, 255, 255, 0.6) !important;
}

/* Container spacing fix */
.container-fluid {
  padding-bottom: 2rem;
}