/**
 * Dark Mode Styles
 * CSS for dark mode presentation of the site
 * Uses variables defined in variables.css
 */

/* Core dark mode styles - element specific styles should be in their component files */
[data-theme="dark"] {
    background-color: var(--bg-primary);
    color: var(--text-primary);
}

/* General element dark mode overrides */
[data-theme="dark"] .card {
    background-color: var(--bg-card);
    border-color: var(--border-color);
}

[data-theme="dark"] hr {
    border-color: var(--border-color);
}

/* General element styles - for elements without specific component files */
[data-theme="dark"] .bg-light {
    background-color: var(--bg-secondary) !important;
}

[data-theme="dark"] .bg-white {
    background-color: var(--bg-secondary) !important;
}

[data-theme="dark"] .border {
    border-color: var(--border-color) !important;
}

/* Dark mode toggler */
.theme-toggle {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    color: inherit;
    display: flex;
    align-items: center;
    justify-content: center;
}

[data-theme="dark"] .ticker-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0 2rem;
    white-space: nowrap;
    color: white;
    transition: all 0.3s ease;
    border-radius: 4px;
}

[data-theme="dark"] .ticker-item:hover {
    transform: scale(1.05);
    box-shadow: 0 0 10px rgba(27, 20, 100, 0.3); /* Using primary-dark color with transparency */
    border-radius: 4px;
    transition: all 0.3s ease;
    cursor: pointer;
    text-decoration: none;
    color: white !important;
    /* padding: 0 2rem; */
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
}

.theme-toggle svg {
    width: 24px;
    height: 24px;
    transition: transform var(--transition-normal);
}

.theme-toggle:hover svg {
    transform: rotate(15deg);
}

/* Dark mode transition */
body {
    transition: background-color var(--transition-normal), color var(--transition-normal);
}

.card, .border, .bg-light, .bg-white {
    transition: background-color var(--transition-normal), border-color var(--transition-normal);
}

/* Apply dark mode to body with enhanced background */
[data-theme="dark"] body {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    background-image: linear-gradient(to bottom right, rgba(26, 26, 46, 0.8), rgba(10, 10, 26, 1));
    min-height: 100vh;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

/* Dark mode scrollbar */
.dark-mode ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

.dark-mode ::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-sm);
}

.dark-mode ::-webkit-scrollbar-thumb {
    background: var(--accent);
    border-radius: var(--radius-sm);
}

.dark-mode ::-webkit-scrollbar-thumb:hover {
    background: var(--accent-light);
}

/* Firefox scrollbar - Dark Mode */
.dark-mode * {
    scrollbar-width: thin;
    scrollbar-color: var(--accent) rgba(255, 255, 255, 0.1);
}

/* Container styles with enhanced effects */
[data-theme="dark"] .container {
    position: relative;
    backdrop-filter: blur(10px);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(var(--accent-rgb), 0.1);
    transition: all var(--transition-normal);
}

[data-theme="dark"] .container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: inherit;
    z-index: -1;
    transition: all var(--transition-normal);
}

/* Section styles with neon borders */
[data-theme="dark"] .section {
    position: relative;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    margin: var(--space-6) 0;
    background: linear-gradient(145deg, var(--bg-card), rgba(30, 30, 30, 0.7));
    box-shadow: 0 0 15px rgba(74, 74, 74, 0.5);
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[data-theme="dark"] .section::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: linear-gradient(45deg, var(--bg-tertiary), var(--accent));
    border-radius: inherit;
    z-index: -1;
    opacity: 0.3;
    filter: blur(8px);
    transition: all var(--transition-normal);
}

[data-theme="dark"] .section:hover::before {
    opacity: 0.5;
    filter: blur(12px);
}

[data-theme="dark"] .section:hover {
    box-shadow: 0 0 20px rgba(var(--accent-rgb), 0.4);
    transform: translateY(-2px);
}

/* Headings */
[data-theme="dark"] h1, 
[data-theme="dark"] h2, 
[data-theme="dark"] h3, 
[data-theme="dark"] h4, 
[data-theme="dark"] h5, 
[data-theme="dark"] h6 {
    color: var(--text-light);
    letter-spacing: 0.5px;
    text-shadow: 0 0 5px rgba(255, 255, 255, 0.3);
}

/* Links */
[data-theme="dark"] a {
    transition: all var(--transition-normal);
}

[data-theme="dark"] a:hover {
    color: var(--text-light);
    text-decoration: none;
}

/* Navbar dark mode */
[data-theme="dark"] .navbar {
    /* background-color: transparent; */
    box-shadow: var(--shadow-md);
    transition: all var(--transition-normal);
    z-index: 1;
}

[data-theme="dark"] .navbar.scrolled {
    background: rgba(18, 18, 18, 0.719);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    transition: all var(--transition-normal);
    z-index: 1;
}

/* Dark mode animations */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes glowPulse {
    0% { box-shadow: 0 0 5px rgba(var(--accent-rgb), 0.3); }
    50% { box-shadow: 0 0 15px rgba(var(--accent-rgb), 0.5); }
    100% { box-shadow: 0 0 5px rgba(var(--accent-rgb), 0.3); }
}

/* Responsive dark mode adjustments */
@media (max-width: 992px) {
    [data-theme="dark"] .container {
        padding: var(--space-4);
    }
    
    [data-theme="dark"] .section {
        padding: var(--space-4);
    }
}

@media (max-width: 768px) {
    [data-theme="dark"] .navbar {
        padding: var(--space-2);
    }
    
    .dark-mode-toggle {
        transform: scale(0.8);
    }
}

/* Dark mode toggle control */
.dark-mode-toggle {
    position: relative;
    width: 60px;
    height: 30px;
    border-radius: 15px;
    background: linear-gradient(to right, #121212, #4a4a4a);
    cursor: pointer;
    transition: all var(--transition-normal);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 5px;
}

.dark-mode-toggle::before {
    content: '';
    position: absolute;
    top: 3px;
    right: 3px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: black;
    transition: all var(--transition-normal);
    z-index: 2;
}

.dark-mode-toggle .toggle-icons {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: space-between;
    z-index: 1;
}

.dark-mode-toggle .toggle-icons .sun-icon,
.dark-mode-toggle .toggle-icons .moon-icon {
    font-size: var(--font-sm);
    color: var(--text-light);
}

[data-theme="dark"] .dark-mode-toggle {
    background: linear-gradient(to right, #786D3C, #a39669);
}

[data-theme="dark"] .dark-mode-toggle::before {
    transform: translateX(-30px);
    background: var(--bg-primary);
}

/* Animations */
[data-theme="dark"] .highlight-on-enter {
    animation: fadeIn var(--transition-slow);
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulseGlow {
    0% {
        box-shadow: 0 0 5px rgba(var(--accent-rgb), 0.3);
    }
    50% {
        box-shadow: 0 0 20px rgba(var(--accent-rgb), 0.6);
    }
    100% {
        box-shadow: 0 0 5px rgba(var(--accent-rgb), 0.3);
    }
}
