/**
 * Dark Mode Styles for MTTDB
 * Applied when body has 'dark-mode' class
 */

/* ==================== */
/* Dark Mode Variables  */
/* ==================== */
/* Support both html.dark-mode (flash prevention) and body.dark-mode (JS toggle) */
body.dark-mode,
html.dark-mode body {
    --primary-color: #818cf8;
    --primary-dark: #6366f1;
    --secondary-color: #e2e8f0;
    --nav-bg: #1e1e2e;
    --text-color: #e2e8f0;
    --text-light: #a0aec0;
    --text-lighter: #718096;
    --border-color: #374151;
    --bg-light: #111827;
    --bg-white: #1f2937;
    --bg-card: #1f2937;
    --bg-hover: #374151;
    --success-color: #47852d;
    --warning-color: #fbbf24;
    --danger-color: #f87171;
    --info-color: #38bdf8;
    --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 20px 60px rgba(0, 0, 0, 0.5);
}

/* ==================== */
/* Base Dark Overrides  */
/* ==================== */
/* Apply background to html element directly for flash prevention */
html.dark-mode {
    background: #111827;
}

body.dark-mode,
html.dark-mode body {
    background: var(--bg-light, #111827);
    color: var(--text-color, #e2e8f0);
}

/* Main content area */
html.dark-mode .main-content,
body.dark-mode .main-content {
    background: #111827;
}

html.dark-mode .container,
body.dark-mode .container {
    background: transparent;
}

body.dark-mode a {
    color: var(--primary-color);
}

body.dark-mode a:hover {
    color: var(--primary-dark);
}

/* ==================== */
/* Navigation           */
/* ==================== */
body.dark-mode .navbar {
    background: var(--nav-bg);
    border-bottom: 1px solid var(--border-color);
}

body.dark-mode .nav-logo a {
    color: #fff;
}

body.dark-mode .nav-links a {
    color: #cbd5e1;
}

body.dark-mode .nav-links a:hover,
body.dark-mode .nav-links a.active {
    color: #fff;
}

body.dark-mode .user-menu-dropdown {
    background: var(--bg-white);
    border: 1px solid var(--border-color);
}

body.dark-mode .user-menu-dropdown a {
    color: var(--text-color);
}

body.dark-mode .user-menu-dropdown a:hover {
    background: var(--bg-hover);
}

body.dark-mode .user-menu-btn span {
    color: #cbd5e1;
}

body.dark-mode .mobile-menu-toggle span {
    background: #fff;
}

body.dark-mode .nav-menu {
    background: var(--nav-bg);
}

/* ==================== */
/* Buttons              */
/* ==================== */
body.dark-mode .btn-primary {
    background: var(--primary-color);
    color: #111827;
}

body.dark-mode .btn-primary:hover {
    background: var(--primary-dark);
}

body.dark-mode .btn-outline {
    border-color: var(--text-light);
    color: var(--text-light);
}

body.dark-mode .btn-outline:hover {
    background: var(--text-light);
    color: var(--bg-light);
}

body.dark-mode .btn-secondary {
    background: var(--bg-hover);
    color: var(--text-color);
}

body.dark-mode .btn-text {
    color: var(--primary-color);
}

body.dark-mode .btn-text:hover {
    background: var(--bg-hover);
}

/* ==================== */
/* Cards & Containers   */
/* ==================== */
body.dark-mode .card,
body.dark-mode .tournament-card,
body.dark-mode .festival-card,
body.dark-mode .mttdb-card {
    background: var(--bg-white);
    border-color: var(--border-color);
}

body.dark-mode .card:hover,
body.dark-mode .tournament-card:hover,
body.dark-mode .festival-card:hover {
    box-shadow: var(--shadow-md);
}

body.dark-mode .section-header h2 {
    color: var(--text-color);
}

body.dark-mode .section-header p {
    color: var(--text-light);
}

/* ==================== */
/* Forms & Inputs       */
/* ==================== */
body.dark-mode input,
body.dark-mode select,
body.dark-mode textarea {
    background: var(--bg-white);
    border-color: var(--border-color);
    color: var(--text-color);
}

body.dark-mode input::placeholder,
body.dark-mode textarea::placeholder {
    color: var(--text-lighter);
}

body.dark-mode input:focus,
body.dark-mode select:focus,
body.dark-mode textarea:focus {
    border-color: var(--primary-color);
    outline: none;
}

body.dark-mode .search-wrapper input {
    background: var(--bg-white);
    color: var(--text-color);
}

/* ==================== */
/* Tables               */
/* ==================== */
body.dark-mode table {
    background: var(--bg-white);
}

body.dark-mode th {
    background: var(--nav-bg);
    color: #fff;
}

body.dark-mode td {
    border-color: var(--border-color);
    color: var(--text-color);
}

body.dark-mode tr:hover {
    background: var(--bg-hover);
}

body.dark-mode .recent-festivals-table {
    background: var(--bg-white);
}

body.dark-mode .recent-festivals-table thead {
    background: var(--nav-bg);
}

body.dark-mode .recent-festivals-table td {
    border-color: var(--border-color);
}

body.dark-mode .recent-festivals-table tr:hover {
    background: var(--bg-hover);
}

/* ==================== */
/* Modals               */
/* ==================== */
body.dark-mode .modal-content {
    background: var(--bg-white);
    border-color: var(--border-color);
}

body.dark-mode .modal-header {
    border-color: var(--border-color);
}

body.dark-mode .modal-header h2,
body.dark-mode .modal-header h3 {
    color: var(--text-color);
}

body.dark-mode .modal-body {
    color: var(--text-color);
}

body.dark-mode .close-btn {
    color: var(--text-light);
}

body.dark-mode .close-btn:hover {
    color: var(--text-color);
}

/* ==================== */
/* Hero Section         */
/* ==================== */
body.dark-mode .hero,
html.dark-mode .hero {
    background: linear-gradient(135deg, #1e1e2e 0%, #2d1f4e 100%);
}

body.dark-mode .hero h1,
body.dark-mode .hero p,
html.dark-mode .hero h1,
html.dark-mode .hero p {
    color: #fff;
}

/* ==================== */
/* Festival Cards       */
/* ==================== */
body.dark-mode .festival-card,
html.dark-mode .festival-card {
    background: var(--bg-white, #1f2937);
    border-color: var(--border-color, #374151);
}

body.dark-mode .festival-header,
html.dark-mode .festival-header {
    background: var(--nav-bg, #111827);
}

body.dark-mode .festival-header h3,
html.dark-mode .festival-header h3 {
    color: #fff;
}

body.dark-mode .festival-meta-item,
html.dark-mode .festival-meta-item {
    color: var(--text-light, #9ca3af);
}

body.dark-mode .festival-body,
html.dark-mode .festival-body {
    background: var(--bg-white, #1f2937);
    border-color: var(--border-color, #374151);
}

body.dark-mode .festival-card-draft,
html.dark-mode .festival-card-draft {
    background: #292524;
}

body.dark-mode .festival-card-draft .festival-header,
html.dark-mode .festival-card-draft .festival-header {
    background: #44403c;
}

/* ==================== */
/* Tournament Tables    */
/* ==================== */
body.dark-mode .tournament-table,
html.dark-mode .tournament-table {
    background: var(--bg-white, #1f2937);
}

body.dark-mode .tournament-table th,
html.dark-mode .tournament-table th {
    background: var(--nav-bg, #111827);
    color: #fff;
}

body.dark-mode .tournament-table td,
html.dark-mode .tournament-table td {
    color: var(--text-color, #e2e8f0);
    border-color: var(--border-color, #374151);
}

body.dark-mode .tournament-table tr:hover,
html.dark-mode .tournament-table tr:hover {
    background: var(--bg-hover, #374151);
}

/* Online Poker Tournament Table */
body.dark-mode .tournaments-table-header,
html.dark-mode .tournaments-table-header {
    background: var(--nav-bg, #111827);
    color: #fff;
}

body.dark-mode .tournaments-table-row,
html.dark-mode .tournaments-table-row {
    background: var(--bg-white, #1f2937);
    border-bottom-color: var(--border-color, #374151);
}

body.dark-mode .tournaments-table-row:nth-child(even),
html.dark-mode .tournaments-table-row:nth-child(even) {
    background: var(--bg-hover, #374151);
}

body.dark-mode .tournaments-table-row:hover,
html.dark-mode .tournaments-table-row:hover {
    background: #4b5563;
}

/* Mobile card view (768px) */
@media (max-width: 768px) {
    body.dark-mode .tournaments-table,
    html.dark-mode .tournaments-table {
        background: transparent;
    }

    body.dark-mode .tournaments-table-row,
    html.dark-mode .tournaments-table-row {
        background: var(--bg-white, #1f2937);
        border-color: var(--border-color, #374151);
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
    }

    body.dark-mode .tournaments-table-row:hover,
    html.dark-mode .tournaments-table-row:hover {
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    }

    body.dark-mode .col-tournament .tournament-name,
    html.dark-mode .col-tournament .tournament-name {
        color: var(--text-color, #e2e8f0);
    }

    body.dark-mode .col-game,
    html.dark-mode .col-game {
        color: var(--text-light, #a0aec0);
    }

    body.dark-mode .col-buyin::before,
    body.dark-mode .col-prize::before,
    body.dark-mode .col-time::before,
    html.dark-mode .col-buyin::before,
    html.dark-mode .col-prize::before,
    html.dark-mode .col-time::before {
        color: var(--text-lighter, #718096);
    }

    body.dark-mode .col-buyin,
    body.dark-mode .col-prize,
    body.dark-mode .col-time,
    html.dark-mode .col-buyin,
    html.dark-mode .col-prize,
    html.dark-mode .col-time {
        border-top-color: var(--border-color, #374151);
        color: var(--text-color, #e2e8f0);
    }

    body.dark-mode .tournaments-table-row.tournament-restricted,
    html.dark-mode .tournaments-table-row.tournament-restricted {
        background: linear-gradient(to right, rgba(255, 193, 7, 0.1), var(--bg-white, #1f2937));
    }
}

/* ==================== */
/* Stats Bar            */
/* ==================== */
body.dark-mode .stats-bar,
html.dark-mode .stats-bar,
body.dark-mode .analytics-stats-bar,
html.dark-mode .analytics-stats-bar {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

body.dark-mode .stat-item .stat-value,
html.dark-mode .stat-item .stat-value {
    color: var(--primary-color, #818cf8);
}

body.dark-mode .stat-item .stat-label,
html.dark-mode .stat-item .stat-label {
    color: var(--text-light, #a0aec0);
}

/* ==================== */
/* Filters              */
/* ==================== */
body.dark-mode .filters-section,
html.dark-mode .filters-section {
    background: var(--bg-white, #1f2937);
    border-color: var(--border-color, #374151);
}

body.dark-mode .filters-header h2,
html.dark-mode .filters-header h2 {
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .filter-toggle,
html.dark-mode .filter-toggle {
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .filter-toggle:hover {
    background: var(--bg-hover);
}

body.dark-mode .filters-container,
body.dark-mode .filter-section,
html.dark-mode .filters-container,
html.dark-mode .filter-section {
    background: var(--bg-white, #1f2937);
    border-color: var(--border-color, #374151);
}

body.dark-mode .filter-group label,
html.dark-mode .filter-group label,
body.dark-mode .filter-group-full > label,
html.dark-mode .filter-group-full > label,
body.dark-mode .filter-label-row > label,
html.dark-mode .filter-label-row > label {
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .apply-my-filters-link,
html.dark-mode .apply-my-filters-link {
    color: var(--primary-color-light, #818cf8);
}

body.dark-mode .filter-group input[type="text"],
body.dark-mode .filter-group input[type="date"],
body.dark-mode .filter-group select,
html.dark-mode .filter-group input[type="text"],
html.dark-mode .filter-group input[type="date"],
html.dark-mode .filter-group select {
    background: var(--bg-light, #111827);
    border-color: var(--border-color, #374151);
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .filter-group input[type="text"]:focus,
body.dark-mode .filter-group input[type="date"]:focus,
body.dark-mode .filter-group select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.2);
}

body.dark-mode .filter-group input[type="text"]::placeholder {
    color: var(--text-lighter);
}

body.dark-mode .filter-label {
    color: var(--text-color);
}

body.dark-mode .filter-chip {
    background: var(--bg-hover);
    color: var(--text-color);
    border-color: var(--border-color);
}

body.dark-mode .filter-chip:hover,
body.dark-mode .filter-chip.active {
    background: var(--primary-color);
    color: #fff;
}

body.dark-mode .game-checkbox-label {
    color: var(--text-color);
}

body.dark-mode .filter-checkbox-grid,
html.dark-mode .filter-checkbox-grid {
    background: var(--bg-light, #111827);
    border-color: var(--border-color, #374151);
}

body.dark-mode .filter-checkbox-grid .checkbox-label,
html.dark-mode .filter-checkbox-grid .checkbox-label {
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .filter-section-label {
    color: var(--text-color);
}

body.dark-mode .filters-common-section {
    border-color: var(--border-color);
}

body.dark-mode .filters-common-section h4 {
    color: var(--text-color);
}

body.dark-mode .checkbox-label {
    color: var(--text-color);
}

body.dark-mode .game-prefs-grid {
    background: var(--bg-light);
    border-color: var(--border-color);
}

/* Checkbox group (tournament list filters) */
body.dark-mode .checkbox-group,
html.dark-mode .checkbox-group {
    background: var(--bg-light, #111827);
    border-color: var(--border-color, #374151);
}

body.dark-mode .checkbox-group .checkbox-label,
html.dark-mode .checkbox-group .checkbox-label {
    color: var(--text-color, #e2e8f0);
}

/* Number inputs in filters */
body.dark-mode .filter-group input[type="number"],
html.dark-mode .filter-group input[type="number"] {
    background: var(--bg-light, #111827);
    border-color: var(--border-color, #374151);
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .filter-group input[type="number"]:focus,
html.dark-mode .filter-group input[type="number"]:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.2);
}

/* Date picker calendar icon in dark mode */
body.dark-mode .filter-group input[type="date"]::-webkit-calendar-picker-indicator,
html.dark-mode .filter-group input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(0.8);
    cursor: pointer;
}

body.dark-mode .filter-group input[type="number"]::placeholder,
html.dark-mode .filter-group input[type="number"]::placeholder {
    color: var(--text-lighter);
}

/* Initial state (search prompt) */
body.dark-mode .initial-state,
html.dark-mode .initial-state {
    background: var(--bg-light, #111827);
    color: var(--text-light, #9ca3af);
}

/* Select dropdown options */
body.dark-mode select option {
    background: var(--bg-white);
    color: var(--text-color);
}

/* ==================== */
/* Status Badges        */
/* ==================== */
body.dark-mode .status-badge {
    opacity: 0.9;
}

body.dark-mode .status-upcoming {
    background: rgba(59, 130, 246, 0.2);
    color: #60a5fa;
}

body.dark-mode .status-ongoing {
    background: rgba(34, 197, 94, 0.2);
    color: #4ade80;
}

body.dark-mode .status-completed {
    background: rgba(156, 163, 175, 0.2);
    color: #9ca3af;
}

/* ==================== */
/* Homepage Elements    */
/* ==================== */

/* Section Headers */
body.dark-mode .section-header-inline h2,
html.dark-mode .section-header-inline h2 {
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .view-all-link {
    color: var(--primary-color);
}

body.dark-mode .view-all-link:hover {
    color: var(--primary-dark);
}

/* Festival Card Compact */
body.dark-mode .festival-card-compact,
html.dark-mode .festival-card-compact {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

body.dark-mode .festival-card-compact .festival-header {
    background: var(--nav-bg);
}

body.dark-mode .festival-card-compact .festival-body {
    background: var(--bg-white);
}

body.dark-mode .festival-card-compact .festival-dates {
    color: var(--text-light);
}

/* Stat Box (in festival cards) */
body.dark-mode .stat-box,
html.dark-mode .stat-box {
    background: var(--bg-light, #111827);
}

body.dark-mode .stat-box .value {
    color: var(--primary-color);
}

body.dark-mode .stat-box .label {
    color: var(--text-light);
}

/* Big Tournament Items */
body.dark-mode .big-tournament-item,
html.dark-mode .big-tournament-item {
    background: var(--bg-light, #111827);
    border: 1px solid var(--border-color, #374151);
}

body.dark-mode .big-tournament-item:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

body.dark-mode .big-tournament-item .tournament-title {
    color: var(--text-color);
}

body.dark-mode .big-tournament-item .tournament-details {
    color: #cbd5e1;
}

body.dark-mode .big-tournament-item .detail-item {
    color: #cbd5e1;
}

body.dark-mode .detail-value {
    color: #e2e8f0;
}

body.dark-mode .detail-label {
    color: #cbd5e1;
}

body.dark-mode .big-tournament-item .tournament-buyin {
    color: var(--success-color);
}

/* Site Header in Big Tournaments */
body.dark-mode .site-header-row {
    border-bottom-color: var(--border-color);
}

/* Buyins Grid Cards */
body.dark-mode .buyin-box,
html.dark-mode .buyin-box {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
    border-top-color: var(--primary-color);
}

body.dark-mode .buyin-box h3 {
    color: var(--text-color);
}

body.dark-mode .buyin-subtitle {
    color: var(--text-light);
}

body.dark-mode .buyin-list li {
    border-bottom-color: var(--border-color);
}

body.dark-mode .buyin-amount {
    color: var(--success-color);
}

body.dark-mode .buyin-tournament {
    color: var(--text-color);
}

body.dark-mode .buyin-festival {
    color: var(--primary-color);
}

body.dark-mode .buyin-festival:hover {
    color: var(--primary-dark);
}

body.dark-mode .buyin-list .no-data {
    color: var(--text-light);
}

/* Demo Section bg-light override */
body.dark-mode .demo-section.bg-light,
html.dark-mode .demo-section.bg-light {
    background: var(--bg-light, #111827) !important;
}

/* Site Big Tournaments */
body.dark-mode .site-big-tournaments,
html.dark-mode .site-big-tournaments {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    border-top-color: var(--primary-color);
}

body.dark-mode .site-big-tournaments .site-name {
    color: var(--primary-color);
    border-bottom-color: var(--border-color);
}

/* Swiper slides */
body.dark-mode .swiper-slide .tournament-card-compact,
html.dark-mode .swiper-slide .tournament-card-compact {
    background: var(--bg-white, #1f2937);
}

body.dark-mode .tournament-card-compact {
    background: var(--bg-white);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
}

body.dark-mode .tournament-card-compact .tournament-name {
    color: var(--text-color);
}

body.dark-mode .tournament-card-compact .tournament-detail {
    color: var(--text-light);
}

body.dark-mode .tournament-card-compact .info-label {
    color: var(--text-light);
}

body.dark-mode .tournament-card-compact .info-value {
    color: var(--text-color);
}

body.dark-mode .tournament-card-compact .start-time {
    border-top-color: var(--border-color);
}

/* Recently Added Festivals Table */
body.dark-mode .recent-festivals-table,
html.dark-mode .recent-festivals-table {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

body.dark-mode .recent-festivals-table thead {
    background: var(--nav-bg);
}

body.dark-mode .recent-festivals-table td {
    border-bottom-color: var(--border-color);
    color: var(--text-color);
}

body.dark-mode .recent-festivals-table tbody tr:hover {
    background: var(--bg-hover);
}

body.dark-mode .recent-festivals-table .festival-name-link {
    color: var(--text-color);
}

body.dark-mode .recent-festivals-table .festival-name-link:hover {
    color: var(--primary-color);
}

body.dark-mode .recent-festivals-table .festival-circuit {
    color: var(--text-light);
}

body.dark-mode .recent-festivals-table .dates-cell {
    color: var(--text-light);
}

body.dark-mode .recent-festivals-table .events-cell {
    color: var(--primary-color);
}

body.dark-mode .recent-festivals-table .satellites-cell {
    color: var(--warning-color);
}

body.dark-mode .recent-festivals-table .view-link {
    color: var(--primary-color);
    background: rgba(129, 140, 248, 0.15);
}

body.dark-mode .recent-festivals-table .view-link:hover {
    background: var(--primary-color);
    color: #fff;
}

body.dark-mode .draft-festival-row {
    background: #343232;
}

/* Recently Added Festivals Cards (Mobile) */
body.dark-mode .recent-festivals-cards .festival-card {
    background: var(--bg-white);
    border-color: var(--border-color);
}

/* Analytics Cards */
body.dark-mode .analytics-card,
html.dark-mode .analytics-card {
    background: var(--bg-white, #1f2937);
    border-left-color: var(--primary-color);
}

body.dark-mode .analytics-card h3 {
    color: var(--primary-color);
}

body.dark-mode .analytics-grid {
    color: var(--text-color);
}

/* Stat Cards (Festival Analytics) */
body.dark-mode .stat-card,
html.dark-mode .stat-card {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

body.dark-mode .stat-card-value {
    color: var(--primary-color);
}

body.dark-mode .stat-card-label {
    color: var(--text-light);
}

/* Chart containers */
body.dark-mode .chart-card,
body.dark-mode .chart-container {
    background: var(--bg-white);
    border-color: var(--border-color);
}

body.dark-mode .chart-card h3 {
    color: var(--text-color);
}

/* Analytics Page Elements */
body.dark-mode .date-controls,
html.dark-mode .date-controls {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

body.dark-mode .date-controls .form-group label,
html.dark-mode .date-controls .form-group label {
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .date-controls .form-group input,
html.dark-mode .date-controls .form-group input {
    background: var(--bg-hover, #374151);
    border-color: var(--border-color, #374151);
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .analytics-section,
html.dark-mode .analytics-section {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

body.dark-mode .section-header,
html.dark-mode .section-header {
    border-bottom-color: var(--primary-color, #818cf8);
}

body.dark-mode .site-filter-checkbox,
html.dark-mode .site-filter-checkbox {
    background: var(--bg-hover, #374151);
    border-color: var(--border-color, #374151);
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .site-filter-checkbox:hover,
html.dark-mode .site-filter-checkbox:hover {
    border-color: var(--primary-color, #818cf8);
    background: var(--bg-white, #1f2937);
}

body.dark-mode .site-filter-checkbox.checked,
html.dark-mode .site-filter-checkbox.checked {
    border-color: var(--primary-color, #818cf8);
}

/* Site Sections (Analytics) */
body.dark-mode .site-section,
html.dark-mode .site-section {
    background: var(--bg-white, #1f2937);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
}

body.dark-mode .site-section h3,
html.dark-mode .site-section h3 {
    color: var(--text-color, #e2e8f0);
    border-bottom-color: var(--primary-color, #818cf8);
}

/* Breakdown grid items */
body.dark-mode .breakdown-grid,
html.dark-mode .breakdown-grid {
    background: transparent;
}

body.dark-mode .breakdown-item,
html.dark-mode .breakdown-item {
    background: var(--bg-hover, #374151);
}

body.dark-mode .breakdown-label,
html.dark-mode .breakdown-label {
    color: var(--text-color, #e2e8f0);
}

body.dark-mode .breakdown-value,
html.dark-mode .breakdown-value {
    color: var(--text-light, #a0aec0);
}

/* Festival Info Cards (Live Poker) */
body.dark-mode .festival-info-card,
html.dark-mode .festival-info-card {
    background: var(--bg-white, #1f2937);
}

body.dark-mode .festival-info-card h4,
body.dark-mode .festival-info-card h2 {
    color: var(--primary-color);
}

body.dark-mode .festival-info-card p {
    color: var(--text-color);
}

body.dark-mode .festival-info-card a {
    color: var(--primary-color);
}

body.dark-mode .festival-info-card a:hover {
    color: var(--primary-dark);
}

/* ==================== */
/* Footer               */
/* ==================== */
body.dark-mode footer,
body.dark-mode .site-footer {
    background: var(--nav-bg);
    border-top: 1px solid var(--border-color);
}

body.dark-mode footer a,
body.dark-mode .site-footer a {
    color: var(--text-light);
}

body.dark-mode footer a:hover,
body.dark-mode .site-footer a:hover {
    color: #fff;
}

/* ==================== */
/* Admin Tool Cards     */
/* ==================== */
body.dark-mode .tool-card {
    border: 1px solid var(--border-color);
}

body.dark-mode .tool-card-footer {
    background: transparent;
    border-top: 1px solid var(--border-color);
}

body.dark-mode .tool-title {
    color: var(--text-color);
}

body.dark-mode .tool-description {
    color: var(--text-light);
}

body.dark-mode .tool-link {
    color: var(--primary-color);
}

/* ==================== */
/* Scrollbar            */
/* ==================== */
body.dark-mode ::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

body.dark-mode ::-webkit-scrollbar-track {
    background: var(--bg-light);
}

body.dark-mode ::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 5px;
}

body.dark-mode ::-webkit-scrollbar-thumb:hover {
    background: var(--text-lighter);
}

/* ==================== */
/* Dark Mode Toggle     */
/* ==================== */
.dark-mode-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-right: 10px;
}

.dark-mode-toggle:hover {
    background: rgba(255, 255, 255, 0.1);
}

.dark-mode-toggle svg {
    width: 20px;
    height: 20px;
    fill: currentColor;
    transition: transform 0.3s ease;
}

.dark-mode-toggle .sun-icon {
    display: none;
    color: #fbbf24;
}

.dark-mode-toggle .moon-icon {
    display: block;
    color: #fff;
}

body.dark-mode .dark-mode-toggle .sun-icon {
    display: block;
}

body.dark-mode .dark-mode-toggle .moon-icon {
    display: none;
}

body.dark-mode .dark-mode-toggle:hover {
    background: rgba(255, 255, 255, 0.1);
}

/* Mobile toggle in nav menu */
.mobile-dark-toggle {
    display: none;
    padding: 12px 20px;
    border-top: 1px solid var(--border-color);
    margin-top: 10px;
}

.mobile-dark-toggle button {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 8px;
    color: #fff;
    cursor: pointer;
    font-size: 0.9rem;
}

.mobile-dark-toggle button:hover {
    background: rgba(255, 255, 255, 0.2);
}

.mobile-dark-toggle svg {
    width: 18px;
    height: 18px;
}

@media (max-width: 768px) {
    .dark-mode-toggle {
        display: none;
    }

    .mobile-dark-toggle {
        display: block;
    }
}

/* ==================== */
/* Misc Dark Overrides  */
/* ==================== */
body.dark-mode .bg-light {
    background: var(--bg-light) !important;
}

body.dark-mode .bg-white {
    background: var(--bg-white) !important;
}

body.dark-mode code {
    background: var(--bg-hover);
    color: var(--primary-color);
}

body.dark-mode pre {
    background: var(--bg-white);
    border-color: var(--border-color);
}

body.dark-mode hr {
    border-color: var(--border-color);
}

body.dark-mode .demo-section.bg-light {
    background: var(--bg-light) !important;
}

body.dark-mode .feature-card {
    background: var(--bg-white);
    border-color: var(--border-color);
}

body.dark-mode .feature-card h3 {
    color: var(--text-color);
}

body.dark-mode .feature-card p {
    color: var(--text-light);
}

body.dark-mode .stat-card {
    background: var(--bg-white);
}

body.dark-mode .stat-value {
    color: var(--primary-color);
}

body.dark-mode .stat-label {
    color: var(--text-light);
}

/* Live Poker specific */

/* Tournament Cards (Mobile view) */
body.dark-mode .tournament-card .card-title,
html.dark-mode .tournament-card .card-title {
    color: #d8d8d8;
}

body.dark-mode .tournament-card .card-field-value,
html.dark-mode .tournament-card .card-field-value {
    color: #d8d8d8;
}

body.dark-mode .search-filters-container {
    background: var(--bg-white);
    border-color: var(--border-color);
}

body.dark-mode .search-input {
    background: var(--bg-light);
    border-color: var(--border-color);
    color: var(--text-color);
}

body.dark-mode .filter-dropdown {
    background: var(--bg-white);
    border-color: var(--border-color);
}

body.dark-mode .pagination-btn {
    background: var(--bg-white);
    border-color: var(--border-color);
    color: var(--text-color);
}

body.dark-mode .pagination-btn:hover,
body.dark-mode .pagination-btn.active {
    background: var(--primary-color);
    color: #fff;
}

/* No results state */
body.dark-mode .no-results,
body.dark-mode .empty-state {
    background: var(--bg-white);
    border-color: var(--border-color);
    color: var(--text-light);
}

/* Tooltips */
body.dark-mode [data-tooltip]:after {
    background: var(--bg-white);
    color: var(--text-color);
    border-color: var(--border-color);
}

/* Loading states */
body.dark-mode .loading-spinner {
    border-color: var(--border-color);
    border-top-color: var(--primary-color);
}

body.dark-mode .skeleton {
    background: linear-gradient(90deg, var(--bg-white) 25%, var(--bg-hover) 50%, var(--bg-white) 75%);
}

/* ==================== */
/* About Page           */
/* ==================== */
body.dark-mode .about-content {
    background: var(--bg-light);
}

body.dark-mode .about-section h2 {
    color: var(--text-color);
}

body.dark-mode .about-section p {
    color: var(--text-light);
}

body.dark-mode .about-section ul,
body.dark-mode .about-section li {
    color: var(--text-light);
}

body.dark-mode .contact-section {
    background: var(--bg-white);
}

body.dark-mode .contact-card {
    background: var(--bg-light);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

body.dark-mode .contact-card h3 {
    color: var(--text-color);
}

body.dark-mode .contact-card p {
    color: var(--text-light);
}

body.dark-mode .contact-card a {
    color: var(--primary-color);
}

body.dark-mode .stat-number {
    color: var(--primary-color);
}
