/* Agros Website Styles - SIMPLIFIED VERSION */

:root {
  --primary-color: #4f9741;
  --secondary-color: #6c757d;
  --success-color: #7ed448;
  --danger-color: #dc3545;
  --warning-color: #ffc107;
  --info-color: #17a2b8;
  --light-color: #f8f9fa;
  --dark-color: #192217;
  /* Theme variables (defaults = light) */
  --agros-bg: white;
  --agros-text: #000000;
  --agros-card-bg: white;
  --agros-table-bg: white;
  --agros-table-text: #000000;
  --agros-muted: #6c757d;
  --agros-license-bg: linear-gradient(45deg, #ffffff, #f8f9fa);
  --agros-stripe-bg: white;
  --agros-stripe-border: #ced4da;
  /* Navbar defaults: dark text for light mode */
  --agros-navbrand: var(--agros-text);
  --agros-navlink: rgba(0, 0, 0, 0.75);
  --agros-footer: white;
  --agros-control-filter: none;
  --primary-variant: #0056b3;
  --primary-variant-2: #004d99;
  /* Additional semantic variables to reduce literal duplication */
  --agros-hero-gradient: linear-gradient(135deg, #4f9741 0%, #004d99 100%);
  --agros-feature-gradient: linear-gradient(135deg, #4f9741, #0056b3);
  --agros-footer-gradient: linear-gradient(135deg, #192217 0%, #2c3e50 100%);
  --agros-license-border: #4a5747;
  --agros-table-header-bg: #212529;
  --agros-white-50: rgba(255, 255, 255, 0.5);
  --agros-white-10: rgba(255, 255, 255, 0.1);
  /* Navbar defaults: light background for light mode */
  --agros-navbar-bg: var(--light-color);
  /* Background for the selector header inside dropdowns */
  --agros-selector-bg: rgba(0, 0, 0, 0.04);
  --agros-shadow: rgba(0, 0, 0, 0.1);
  --agros-border: #e9ecef;
  --agros-shadow-strong: rgba(0, 0, 0, 0.15);
  --agros-accent-shadow: rgba(0, 102, 204, 0.3);
  --agros-muted-border: #e6ebf1;
  --agros-table-hover: rgba(0, 102, 204, 0.05);
  --agros-modal-shadow: rgba(0, 0, 0, 0.3);
  --agros-white: white;
}

/* FORCE EVERYTHING TO BE DARK TEXT - NO EXCEPTIONS */
html {
  background-color: var(--agros-bg) !important;
}

body {
  font-family: "Oxygen", Tahoma, Geneva, Verdana, sans-serif !important;
  line-height: 1.6 !important;
  color: var(--agros-text) !important;
  background-color: var(--agros-bg) !important;
  padding-top: 56px !important; /* Match Bootstrap navbar height */
}

/* FORCE ALL ELEMENTS TO BE BLACK */
h1,
h2,
h3,
h4,
h5,
h6,
p,
div,
span,
li,
td,
th,
a {
  color: var(--agros-text) !important;
}

/* HERO SECTION - ONLY WHITE TEXT HERE */
.hero {
  background: var(--agros-hero-gradient) !important;
  min-height: 50vh !important;
  display: flex !important;
  align-items: center !important;
}

.hero {
  background: var(--agros-hero-gradient) !important;
  min-height: 50vh !important;
  display: flex !important;
  align-items: center !important;
  margin-top: 0 !important;
}
.hero h6,
.hero p,
.hero div,
.hero span,
.hero .lead {
  color: var(--agros-white) !important;
}

h1 {
  font-family: "Odor Mean Chey", Courier, monospace;
  font-size: 2.2rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.1rem;
}

h2 {
  font-family: "Odor Mean Chey", Courier, monospace;
  font-size: 1.8rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.1rem;
}

.hero h1 {
  margin-bottom: 1.5rem !important;
}

.hero .lead {
  font-size: 1rem !important;
  opacity: 0.9 !important;
}

/* Ensure hero CTA buttons have white text/icons regardless of theme */
.hero .btn {
  color: var(--agros-white) !important;
}

.hero .btn i {
  color: var(--agros-white) !important;
}

/* NAVIGATION - WHITE TEXT */
.navbar {
  transition: all 0.3s ease !important;
  backdrop-filter: blur(10px) !important;
  /* Ensure navbar follows theme variables instead of Bootstrap utility classes */
  background-color: var(--agros-navbar-bg) !important;
  color: var(--agros-navbrand) !important;
}

.navbar-scrolled {
  background-color: var(--agros-navbar-bg) !important;
  box-shadow: 0 2px 10px var(--agros-shadow) !important;
}

.navbar-brand {
  font-family: "Odor Mean Chey", Courier, monospace;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
  color: var(--agros-navbrand) !important;
  letter-spacing: 0.1rem;
}

.navbar-brand img {
  max-height: 32px !important;
}

.navbar-nav .nav-link {
  font-weight: 500 !important;
  margin: 0 0.5rem !important;
  transition: color 0.3s ease !important;
  color: var(--agros-navlink) !important;
}

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

/* Dropdown menu should follow theme variables for background and text */
.dropdown-menu {
  background-color: var(--agros-card-bg) !important;
  color: var(--agros-text) !important;
  border: 1px solid var(--agros-border) !important;
  box-shadow: 0 6px 18px var(--agros-shadow) !important;
}

.dropdown-item {
  color: var(--agros-text) !important;
}

/* Special selector header inside dropdown to visually separate it from regular menu items */
.dropdown-item.selector {
  background-color: var(--agros-selector-bg) !important;
  font-size: 0.9rem !important;
  color: var(--agros-muted) !important;
  pointer-events: none !important;
}

/* Hover/active states for dropdown items should use primary color subtly */
.dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--agros-table-hover) !important;
  color: var(--agros-text) !important;
}

/* CARDS - BLACK TEXT */
.card {
  border: none !important;
  box-shadow: 0 4px 6px var(--agros-shadow) !important;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease !important;
  background-color: var(--agros-card-bg) !important;
}

/* List group items should follow theme variables (light by default, dark in dark mode) */
.list-group-item {
  background-color: var(--agros-card-bg) !important;
  color: var(--agros-text) !important;
  border: 1px solid var(--agros-border) !important;
  box-shadow: 0 2px 6px var(--agros-shadow) !important;
}

.card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 8px 15px var(--agros-shadow-strong) !important;
}

.card h1,
.card h2,
.card h3,
.card h4,
.card h5,
.card h6,
.card p,
.card div,
.card span {
  color: var(--agros-text) !important;
}

/* BUTTONS */
.btn {
  font-weight: 500 !important;
  padding: 0.75rem 1.5rem !important;
  transition: all 0.3s ease !important;
}

.btn-primary {
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  color: var(--agros-white) !important;
}

.btn-primary:hover {
  background-color: var(--primary-variant) !important;
  border-color: var(--primary-variant) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 8px var(--agros-accent-shadow) !important;
  color: var(--agros-white) !important;
}

.btn-outline-primary {
  color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  background-color: transparent !important;
}

.btn-outline-primary:hover {
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  transform: translateY(-2px) !important;
  color: var(--agros-white) !important;
}

.btn-light {
  background-color: var(--light-color) !important;
  border-color: var(--light-color) !important;
  color: var(--agros-text) !important;
}

.btn-lg {
  padding: 1rem 2rem !important;
  font-size: 1.125rem !important;
}

/* TABLES - BLACK TEXT */
.table {
  border-radius: 10px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 6px var(--agros-shadow) !important;
  color: var(--agros-text) !important;
}

.table thead th {
  border-bottom: none !important;
  font-weight: 600 !important;
  color: var(--agros-white) !important;
  background-color: var(--agros-table-header-bg) !important;
}

.table tbody tr {
  transition: background-color 0.3s ease !important;
  color: var(--agros-text) !important;
}

.table tbody tr:hover {
  background-color: var(--agros-table-hover) !important;
}

.table td,
.table th {
  color: var(--agros-text) !important;
}

.table-dark th {
  color: var(--agros-white) !important;
}

/* BADGES */
.badge {
  font-size: 0.875rem !important;
  padding: 0.5rem 0.75rem !important;
  color: var(--agros-white) !important;
}

/* MODALS - BLACK TEXT */
.modal-content {
  border: none !important;
  border-radius: 15px !important;
  box-shadow: 0 10px 30px var(--agros-modal-shadow) !important;
  background-color: var(--agros-card-bg) !important;
}

.modal-content h1,
.modal-content h2,
.modal-content h3,
.modal-content h4,
.modal-content h5,
.modal-content h6,
.modal-content p,
.modal-content div,
.modal-content span {
  color: var(--agros-text) !important;
}

.modal-header {
  border-bottom: 1px solid var(--agros-border) !important;
  padding: 1.5rem !important;
}

.modal-body {
  padding: 2rem !important;
}

.modal-footer {
  border-top: 1px solid var(--agros-border) !important;
  padding: 1.5rem !important;
}

/* FOOTER - WHITE TEXT */
footer {
  background: var(--agros-footer-gradient) !important;
}

footer,
footer h1,
footer h2,
footer h3,
footer h4,
footer h5,
footer h6,
footer p,
footer div,
footer span,
footer a {
  color: var(--agros-white) !important;
}

footer a {
  transition: opacity 0.3s ease !important;
}

footer a:hover {
  opacity: 0.8 !important;
  color: var(--agros-white) !important;
}

/* Social links in footer */
.social-links a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 6px !important;
  background: transparent !important;
  text-decoration: none !important;
  transition:
    background-color 0.15s ease,
    color 0.15s ease !important;
}

.social-links a:hover {
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--agros-white) !important;
}

.social-links i {
  color: var(--agros-white) !important;
}

/* ALERTS */
.alert {
  border: none !important;
  border-radius: 10px !important;
  font-weight: 500 !important;
  box-shadow: 0 4px 6px var(--agros-shadow) !important;
}
.alert-success {
  color: var(--success-color) !important;
}

.alert-danger {
  color: var(--danger-color) !important;
}

.alert-info {
  color: var(--info-color) !important;
}

.alert-warning {
  color: var(--warning-color) !important;
}

/* TEXT UTILITIES */
.text-muted {
  color: var(--agros-muted) !important;
}

.text-white {
  color: var(--agros-footer) !important;
}

.text-white-50 {
  color: var(--agros-white-50) !important;
}

.text-dark {
  color: var(--agros-text) !important;
}

/* PRICING CARDS */
.pricing-card {
  position: relative !important;
  overflow: hidden !important;
}

.pricing-card.popular {
  border: 2px solid var(--primary-color) !important;
  position: relative !important;
  z-index: 1 !important;
}

.pricing-card.popular::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 4px !important;
  background: linear-gradient(
    90deg,
    var(--primary-color),
    var(--primary-variant)
  ) !important;
}

/* STRIPE ELEMENTS */
.StripeElement {
  box-sizing: border-box !important;
  padding: 10px 12px !important;
  border: 1px solid var(--agros-stripe-border) !important;
  border-radius: 6px !important;
  background-color: var(--agros-stripe-bg) !important;
  box-shadow: 0 1px 3px 0 var(--agros-muted-border) !important;
  transition: box-shadow 150ms ease !important;
  color: var(--agros-text) !important;
}

.StripeElement--focus {
  box-shadow: 0 1px 3px 0 var(--agros-muted-border) !important;
  border-color: var(--primary-color) !important;
}

.StripeElement--invalid {
  border-color: var(--danger-color) !important;
}

/* RESPONSIVE DESIGN */
@media (max-width: 768px) {
  .hero h1 {
    font-size: 2.5rem !important;
  }

  .hero .lead {
    font-size: 1rem !important;
  }

  .display-4 {
    font-size: 2rem !important;
  }

  .display-5 {
    font-size: 1.75rem !important;
  }

  .btn-lg {
    padding: 0.75rem 1.5rem !important;
    font-size: 1rem !important;
  }
}

@media (max-width: 576px) {
  body {
    padding-top: 70px !important;
  }

  .hero {
    min-height: 70vh !important;
  }

  .hero h1 {
    font-size: 2rem !important;
  }

  .container {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

/* BACKGROUND UTILITIES */
.bg-primary {
  background-color: var(--primary-color) !important;
}

.bg-dark {
  background-color: var(--dark-color) !important;
}

.bg-light {
  background-color: var(--light-color) !important;
}

/* Ensure Bootstrap navbar utilities don't force a static dark navbar; let variables control colors */
.navbar.navbar-dark.bg-dark,
.navbar.navbar-dark.bg-dark.fixed-top {
  background-color: var(--agros-navbar-bg) !important;
}

.navbar.navbar-dark.bg-dark .navbar-brand,
.navbar.navbar-dark.bg-dark .navbar-nav .nav-link {
  color: var(--agros-navlink) !important;
}

/* ADDITIONAL FIXES */
#paypal-button-container {
  margin-top: 1rem !important;
}

/* Theme forcing is now handled via CSS variables and a small injected stylesheet from JS. */

/* Feature Icons */
.feature-icon {
  width: 60px !important;
  height: 60px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--agros-feature-gradient) !important;
  color: var(--agros-white) !important;
  margin: 0 auto 1rem !important;
  font-size: 1.5rem !important;
}

/* Theme toggle (flat) */
#theme-toggle {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--agros-navlink) !important;
  background: transparent !important;
  border: none !important;
  padding: 0.25rem 0.5rem !important;
  margin: 0 !important;
}

#theme-toggle i {
  transition: color 150ms ease !important;
}

#theme-toggle:hover,
#theme-toggle:active {
  background: transparent !important; /* no background change */
}

#theme-toggle:hover i {
  color: var(--primary-color) !important;
}

/* keep a visible focus ring for keyboard users */
#theme-toggle:focus {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(79, 151, 65, 0.15) !important; /* subtle primary ring */
  border-radius: 6px !important;
}

#themeDropdown {
  border-radius: 0.5em;
  /* Use variable-driven colors so JS overrides and prefers-color-scheme apply uniformly */
  background-color: var(--agros-card-bg) !important;
  color: var(--agros-text) !important;
}

/* License Key Display */
#licenseKey {
  font-family: "Courier New", monospace !important;
  font-size: 1.2rem !important;
  letter-spacing: 1px !important;
  word-break: break-all !important;
  background: var(--agros-license-bg) !important;
  border: 2px solid var(--agros-license-border) !important;
  color: var(--agros-text) !important;
}

/* ANIMATIONS */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-in-up {
  animation: fadeInUp 0.6s ease-out !important;
}

@keyframes checkmark {
  0% {
    transform: scale(0);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

.success-checkmark {
  animation: checkmark 0.6s ease-in-out !important;
}

/* LIGHT AND DARK MODE SUPPORT */
/* Light mode is the default (what we have above) */

/* Dark mode styles */
@media (prefers-color-scheme: dark) {
  /* Dark-mode semantic variables; JS will override :root to force modes */
  :root {
    --agros-bg: #1a1a1a;
    --agros-text: #e0e0e0;
    --agros-card-bg: #2d2d2d;
    --agros-table-bg: #2d2d2d;
    --agros-table-text: #2f2d32;
    --agros-muted: #b0b0b0;
    --agros-license-bg: linear-gradient(45deg, #2d2d2d, #1a1a1a);
    --agros-stripe-bg: #2d2d2d;
    --agros-stripe-border: #6c757d;
    --agros-control-filter: invert(1);
    /* Navbar in dark mode */
    --agros-navbar-bg: rgba(14, 15, 14, 1);
    --agros-navbrand: var(--agros-white);
    --agros-navlink: rgba(255, 255, 255, 0.75);
    --agros-table-hover: var(--agros-white-10);
    /* Dark selector header background inside dropdowns */
    --agros-selector-bg: rgba(255, 255, 255, 0.03);
    --btn-outline-success-bg: #ffcc00;
  }

  html {
    background-color: var(--agros-bg) !important;
  }

  body {
    background-color: var(--agros-bg) !important;
    color: var(--agros-text) !important;
  }

  /* Dark mode: All text should be light */
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  p,
  div,
  span,
  li,
  td,
  th,
  a {
    color: var(--agros-text) !important;
  }

  /* Cards in dark mode */
  .card {
    background-color: var(--agros-card-bg) !important;
  }

  .card h1,
  .card h2,
  .card h3,
  .card h4,
  .card h5,
  .card h6,
  .card p,
  .card div,
  .card span {
    color: var(--agros-text) !important;
  }

  /* Tables in dark mode */
  .table {
    color: var(--agros-text) !important;
    background-color: var(--agros-table-bg) !important;
  }

  .table td,
  .table th {
    color: var(--agros-table-text) !important;
  }

  .table tbody tr:hover {
    background-color: var(--agros-table-hover) !important;
  }

  /* Modals in dark mode */
  .modal-content {
    background-color: var(--agros-card-bg) !important;
  }

  .modal-content h1,
  .modal-content h2,
  .modal-content h3,
  .modal-content h4,
  .modal-content h5,
  .modal-content h6,
  .modal-content p,
  .modal-content div,
  .modal-content span {
    color: var(--agros-text) !important;
  }

  /* Background adjustments for dark mode */
  .bg-light {
    background-color: var(--agros-table-bg) !important;
  }

  /* Text utilities for dark mode */
  .text-muted {
    color: var(--agros-muted) !important;
  }

  .text-dark {
    color: var(--agros-text) !important;
  }

  /* Buttons in dark mode - keep their specific colors */
  .btn-outline-success {
    background-color: var(--btn-outline-success-bg);
    border-color: var(--btn-outline-success-bg);
    color: var(--agros-footer) !important;
  }

  .btn-outline-success:hover {
    background-color: var(--success-color);
  }

  .btn-outline-light:hover,
  .btn-outline-light:hover i {
    color: var(--success-color) !important;
  }

  /* Hero section stays the same in dark mode */
  .hero,
  .hero h1,
  .hero h2,
  .hero h3,
  .hero h4,
  .hero h5,
  .hero h6,
  .hero p,
  .hero div,
  .hero span,
  .hero .lead {
    color: var(--agros-white) !important;
  }

  /* Navigation stays the same in dark mode */
  .navbar-brand {
    color: var(--agros-white) !important;
  }

  .navbar-nav .nav-link {
    color: var(--agros-navlink) !important;
  }

  /* Footer stays the same in dark mode */
  footer,
  footer h1,
  footer h2,
  footer h3,
  footer h4,
  footer h5,
  footer h6,
  footer p,
  footer div,
  footer span,
  footer a {
    color: var(--agros-white) !important;
  }

  /* License key display in dark mode */
  #licenseKey {
    background: var(--agros-license-bg) !important;
    color: var(--agros-text) !important;
  }

  /* Stripe elements in dark mode */
  .StripeElement {
    background-color: var(--agros-stripe-bg) !important;
    color: var(--agros-text) !important;
    border-color: var(--agros-stripe-border) !important;
  }

  .carousel-control-prev-icon,
  .carousel-control-next-icon {
    filter: var(--agros-control-filter) !important;
  }

  .carousel-indicators button {
    background-color: var(--primary-color) !important;
  }

  /* Theme variables and variable-driven rules
       These rules allow JavaScript to force a theme by setting a small set of
       CSS custom properties. They intentionally use !important to take precedence
       over existing literal rules so migration can be incremental. */
  :root {
    /* defaults (light) */
    --agros-bg: white;
    --agros-text: #000000;
    --agros-card-bg: white;
    --agros-table-bg: white;
    --agros-table-text: #000000;
    --agros-muted: #6c757d;
    --agros-license-bg: linear-gradient(45deg, #ffffff, #f8f9fa);
    --agros-stripe-bg: white;
    --agros-stripe-border: #ced4da;
    --agros-navbrand: white;
    --agros-navlink: rgba(255, 255, 255, 0.75);
    --agros-footer: white;
    --agros-control-filter: none;
  }

  /* Apply variables across the site. Use !important to override existing literal styles. */
  body {
    background-color: var(--agros-bg) !important;
    color: var(--agros-text) !important;
  }

  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  p,
  div,
  span,
  li,
  td,
  th,
  a {
    color: var(--agros-text) !important;
  }

  .card,
  .modal-content {
    background-color: var(--agros-card-bg) !important;
  }

  .card h1,
  .card h2,
  .card h3,
  .card h4,
  .card h5,
  .card h6,
  .card p,
  .card div,
  .card span {
    color: var(--agros-text) !important;
  }

  .table {
    color: var(--agros-text) !important;
    background-color: var(--agros-table-bg) !important;
  }

  .table td,
  .table th {
    color: var(--agros-table-text) !important;
  }

  .bg-light {
    background-color: var(--agros-table-bg) !important;
  }

  .text-muted {
    color: var(--agros-muted) !important;
  }

  .text-dark {
    color: var(--agros-text) !important;
  }

  .navbar-brand {
    color: var(--agros-navbrand) !important;
  }

  .navbar-nav .nav-link {
    color: var(--agros-navlink) !important;
  }

  footer,
  footer h1,
  footer h2,
  footer h3,
  footer h4,
  footer h5,
  footer h6,
  footer p,
  footer div,
  footer span,
  footer a {
    color: var(--agros-footer) !important;
  }

  #licenseKey {
    background: var(--agros-license-bg) !important;
    color: var(--agros-text) !important;
  }

  .StripeElement {
    background-color: var(--agros-stripe-bg) !important;
    color: var(--agros-text) !important;
    border-color: var(--agros-stripe-border) !important;
  }

  .carousel-control-prev-icon,
  .carousel-control-next-icon {
    filter: var(--agros-control-filter) !important;
  }
}
