:root {
  /* Backgrounds */
  --primary-dark: #0F0F0F;          /* Main dark background */
  --primary-light: #1A1A1A;         /* Slightly lighter for cards/panels */
  --secondary-bg: #101010;          /* Secondary sections */
  --card-bg: #1B1B1B;               /* Cards */
  --header-bg: #0D0D0D;             /* Header */
  --footer-bg: #0D0D0D;             /* Footer */
  --footer-border: rgba(255, 255, 255, 0.05);

  /* Text */
  --text-color: #EAEAEA;            /* Main text in golden color */
  --muted-text: #A0A0A0;            /* Secondary text */

  /* Buttons & Accents */
  --accent-yellow: #C0FF47;         /* Golden color for buttons and highlights */
  --accent-red: #FF595E;            /* Error / Danger */
  --accent-green: #06D6A0;          /* Success */
  --accent-purple: #6842FF;         /* Alternative accent */
  --button-bg: #2C2C2C;             /* Default button background */
  --button-text: #C0FF47;           /* Golden text for buttons */
  --button-hover: #FFD166;          /* Hover background color */
  --button-hover-text: #0F0F0F;     /* Button hover text (dark for contrast) */

  /* Gray tones for subtle elements */
  --dark-gray: #C0C0C0;
  --medium-gray: #888888;
  --light-gray: #121212;
}


body.dark-theme {
  background-color: var(--light-gray);
  color: var(--text-color);
}
.dark-theme header {
  background-color: var(--header-bg);
  border-bottom: 1px solid var(--footer-border);
}
.dark-theme footer {
  background-color: var(--footer-bg);
  color: var(--footer-text);
}
.dark-theme .bg-indigo-100 {
  background-color: var(--card-bg) !important;
  color: var(--text-color) !important;
}
.dark-theme .bg-indigo-200 {
  background-color: var(--header-bg) !important;
  border-top-color: var(--footer-border) !important;
}
.dark-theme .text-indigo-800 {
  color: var(--text-color) !important;
}
.dark-theme .text-indigo-700 {
  color: var(--muted-text) !important;
}
.dark-theme .text-indigo-700:hover {
  color: var(--accent-yellow) !important;
}
.dark-theme .bg-white {
  background-color: var(--card-bg) !important;
  color: var(--text-color) !important;
}
.dark-theme .bg-secondary-bg {
  background-color: var(--secondary-bg) !important;
}
.dark-theme .text-dark-gray {
  color: var(--text-color) !important;
}
.dark-theme .text-medium-gray {
  color: var(--muted-text) !important;
}
.dark-theme .bg-indigo-200 {
  background-color: var(--card-bg) !important;
}
.dark-theme .hover\:bg-indigo-200:hover {
  background-color: var(--primary-dark) !important;
  color: white !important;
}
.dark-theme .navbar-desktop-nav-group a,
.dark-theme .navbar-desktop-auth-group a {
  color: var(--text-color);
}
.dark-theme .navbar-desktop-nav-group a:hover,
.dark-theme .navbar-desktop-auth-group a:hover {
  color: var(--accent-yellow);
}
.dark-theme input[type="text"],
.dark-theme input[type="password"],
.dark-theme input[type="email"] {
  background-color: var(--card-bg) !important; 
  color: var(--text-color) !important;       
  border-color: rgba(255, 255, 255, 0.1) !important; 
}
.dark-theme input::placeholder {
  color: var(--muted-text);
}
.dark-theme .game-card {
  background-color: var(--card-bg);
  border: 1px solid rgba(255, 255, 255, 0.05);
}
.dark-theme .game-card:hover {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.3);
}
.dark-theme .category-box {
  background-color: var(--card-bg);
  color: var(--text-color);
}
.dark-theme .category-box:hover {
  background-color: var(--primary-dark);
  color: white;
}
.dark-theme .category-dropdown-content {
  background-color: var(--card-bg);
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.dark-theme .category-dropdown-content a {
  color: var(--text-color);
}
.dark-theme .category-dropdown-content a:hover {
  background-color: rgba(255, 255, 255, 0.05);
}
.dark-theme .bg-accent-yellow {
  color: #111827 !important;
}
.dark-theme hr {
  border-color: rgba(255, 255, 255, 0.1);
}
.dark-theme .fa-search,
.dark-theme .fa-bars {
  color: var(--text-color);
}
.dark-theme input::placeholder {
  color: var(--muted-text);
}
.dark-theme aside .bg-white {
  background-color: var(--card-bg) !important;
}
.dark-theme .rounded-lg.shadow-md {
  background-color: var(--card-bg);
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.dark-theme .bg-white {
  background-color: var(--card-bg) !important;
  color: var(--text-color) !important;
}
.dark-theme .text-gray-700 {
  color: var(--text-color) !important;
}
.dark-theme .text-primary-dark {
  color: var(--accent-yellow) !important;
}
.dark-theme .hover\:text-primary-light:hover {
  color: var(--accent-yellow) !important;
}
.dark-theme .text-medium-gray {
  color: var(--muted-text) !important;
}
.dark-theme .bg-indigo-100 {
  background-color: var(--card-bg) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}
.dark-theme .text-indigo-700 {
  color: var(--muted-text) !important;
}
.dark-theme .hover\:shadow-xl:hover {
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.3), 0 10px 10px -5px rgba(0, 0, 0, 0.1) !important;
}
.dark-theme .category-dropdown-content a:hover {
  color: var(--accent-yellow) !important;
  background-color: rgba(255, 255, 255, 0.05) !important;
}

.dark-theme .navbar-desktop-nav-group a:hover,
.dark-theme .category-dropdown-button:hover {
  color: var(--accent-yellow) !important;
}

.dark-theme .hover\:text-primary-light:hover {
  color: var(--accent-yellow) !important;
}
.dark-theme .text-medium-gray {
  color: var(--muted-text) !important;
}
.dark-theme .bg-gray-200 {
  background-color: var(--card-bg) !important;
  color: var(--muted-text) !important;
}
.dark-theme #dynamicCategoryContainer a.category-box:hover {
  color: var(--accent-yellow) !important;
  background-color: var(--card-bg) !important;
  transform: translateY(-2px);
}
.dark-theme .bg-accent-yellow {
  color: #111827 !important;
  background-color: var(--accent-yellow) !important;
}
.dark-theme .hover\:bg-yellow-300:hover {
  background-color: #FCD34D !important;
  color: #111827 !important;
}
.dark-theme .game-card h3.text-gray-800 {
    color: var(--text-color) !important;
}