/* Theme Variables */
:root {
    --bg-color: #f4f4f4;
    --text-color: #333;
    --nav-bg: rgba(255, 255, 255, 0.95);
    --button-bg: #007bff;
    --button-hover: #0056b3;
    --border-color: #ddd;
    --footer-bg: #333;
}

/* Dark Theme */
.dark {
    --bg-color: #222;
    --text-color: #f4f4f4;
    --nav-bg: rgba(34, 34, 34, 0.95);
    --button-bg: #444;
    --button-hover: #555;
    --border-color: #555;
    --footer-bg: #111;
}

/* Apply variables */
body {
    background-color: var(--bg-color);
    color: var(--text-color);
}

nav {
    background: var(--nav-bg);
}

button {
    background: var(--button-bg);
}

button:hover {
    background: var(--button-hover);
}

#threejs-container, #pong-game, #sorting-visualizer, #audio-visualizer {
    border-color: var(--border-color);
}

footer {
    background: var(--footer-bg);
}

/* Glassmorphism effect for nav */
nav {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

/* Neon effect for dark mode */
.dark .nav-menu a:hover {
    text-shadow: 0 0 10px #007bff;
}

.dark button:focus {
    box-shadow: 0 0 10px #007bff;
}