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

body.dark-mode {
    --bg-primary: #1a1a2e;
    --bg-secondary: #16213e;
    --bg-card: #1e293b;
    --bg-input: #0f172a;
    --text-primary: #e2e8f0;
    --text-secondary: #94a3b8;
    --border-color: #334155;
    --hover-bg: #253049;

    background-color: var(--bg-primary) !important;
    color: var(--text-primary);
}

/* Body background overrides for different portals */
body.dark-mode,
body.dark-mode.guest-page {
    background: var(--bg-primary) !important;
}

/* Cards */
body.dark-mode .card,
body.dark-mode .stat-card,
body.dark-mode .data-card {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

body.dark-mode .card-header {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

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

body.dark-mode .card-footer {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
}

/* Tables */
body.dark-mode .table,
body.dark-mode .data-table {
    color: var(--text-primary);
    --bs-table-bg: var(--bg-card);
    --bs-table-striped-bg: var(--bg-secondary);
    --bs-table-hover-bg: var(--hover-bg);
    --bs-table-border-color: var(--border-color);
}

body.dark-mode .table th,
body.dark-mode .data-table th,
body.dark-mode .table-light {
    background-color: var(--bg-secondary) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-color) !important;
}

body.dark-mode .table td,
body.dark-mode .data-table td {
    border-color: var(--border-color) !important;
    color: var(--text-primary);
}

body.dark-mode .table tbody tr:hover,
body.dark-mode .data-table tbody tr:hover {
    background-color: var(--hover-bg) !important;
}

/* Form inputs */
body.dark-mode .form-control,
body.dark-mode .form-select {
    background-color: var(--bg-input) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

body.dark-mode .form-control::placeholder {
    color: var(--text-secondary) !important;
}

body.dark-mode .form-control:focus,
body.dark-mode .form-select:focus {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2) !important;
}

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

body.dark-mode .form-text,
body.dark-mode .text-muted {
    color: var(--text-secondary) !important;
}

body.dark-mode .input-group-text {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
    color: var(--text-secondary) !important;
}

/* Headers / Navbars */
body.dark-mode .top-navbar,
body.dark-mode .navbar,
body.dark-mode .employer-header,
body.dark-mode .admin-header {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    box-shadow: 0 2px 15px rgba(0, 0, 0, 0.3) !important;
}

body.dark-mode .navbar-light .navbar-brand,
body.dark-mode .navbar-light .nav-link {
    color: var(--text-primary) !important;
}

body.dark-mode .employer-header span.text-muted {
    color: var(--text-secondary) !important;
}

/* Headers bg-white overrides */
body.dark-mode .bg-white {
    background-color: var(--bg-card) !important;
}

/* Dropdowns */
body.dark-mode .dropdown-menu {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4) !important;
}

body.dark-mode .dropdown-item {
    color: var(--text-primary) !important;
}

body.dark-mode .dropdown-item:hover,
body.dark-mode .dropdown-item:focus {
    background-color: var(--hover-bg) !important;
}

body.dark-mode .dropdown-item.active {
    background-color: #4f46e5 !important;
    color: #fff !important;
}

body.dark-mode .dropdown-divider {
    border-color: var(--border-color) !important;
}

/* Modals */
body.dark-mode .modal-content {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

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

body.dark-mode .modal-footer {
    border-color: var(--border-color) !important;
}

body.dark-mode .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

/* Alerts */
body.dark-mode .alert-info {
    background-color: rgba(14, 165, 233, 0.15) !important;
    border-color: rgba(14, 165, 233, 0.25) !important;
    color: #7dd3fc !important;
}

body.dark-mode .alert-warning {
    background-color: rgba(245, 158, 11, 0.15) !important;
    border-color: rgba(245, 158, 11, 0.25) !important;
    color: #fcd34d !important;
}

body.dark-mode .alert-danger {
    background-color: rgba(239, 68, 68, 0.15) !important;
    border-color: rgba(239, 68, 68, 0.25) !important;
    color: #fca5a5 !important;
}

body.dark-mode .alert-success {
    background-color: rgba(34, 197, 94, 0.15) !important;
    border-color: rgba(34, 197, 94, 0.25) !important;
    color: #86efac !important;
}

/* Badges - adjust for dark backgrounds */
body.dark-mode .badge.bg-light {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
}

body.dark-mode .badge-success { background-color: rgba(34, 197, 94, 0.2) !important; color: #86efac !important; }
body.dark-mode .badge-warning { background-color: rgba(245, 158, 11, 0.2) !important; color: #fcd34d !important; }
body.dark-mode .badge-danger { background-color: rgba(239, 68, 68, 0.2) !important; color: #fca5a5 !important; }
body.dark-mode .badge-info { background-color: rgba(14, 165, 233, 0.2) !important; color: #7dd3fc !important; }
body.dark-mode .badge-secondary { background-color: rgba(100, 116, 139, 0.2) !important; color: #cbd5e1 !important; }
body.dark-mode .badge-primary { background-color: rgba(99, 102, 241, 0.2) !important; color: #a5b4fc !important; }

/* Buttons */
body.dark-mode .btn-light {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

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

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

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

body.dark-mode .btn-outline-primary {
    border-color: #6366f1 !important;
    color: #a5b4fc !important;
}

body.dark-mode .btn-outline-primary:hover {
    background-color: rgba(99, 102, 241, 0.2) !important;
}

/* Breadcrumbs */
body.dark-mode .breadcrumb-item,
body.dark-mode .breadcrumb-item a {
    color: var(--text-secondary) !important;
}

body.dark-mode .breadcrumb-item.active {
    color: var(--text-primary) !important;
}

/* Pagination */
body.dark-mode .page-link {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

body.dark-mode .page-link:hover {
    background-color: var(--hover-bg) !important;
}

body.dark-mode .page-item.active .page-link {
    background-color: #4f46e5 !important;
    border-color: #4f46e5 !important;
}

/* Stat cards in employer/admin */
body.dark-mode .stat-card .stat-value {
    color: var(--text-primary) !important;
}

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

/* Data card header */
body.dark-mode .data-card-header {
    border-color: var(--border-color) !important;
}

body.dark-mode .data-card-title {
    color: var(--text-primary) !important;
}

/* Page header/titles */
body.dark-mode .page-title {
    color: var(--text-primary) !important;
}

body.dark-mode .page-subtitle {
    color: var(--text-secondary) !important;
}

/* Misc text overrides */
body.dark-mode strong,
body.dark-mode h1, body.dark-mode h2, body.dark-mode h3,
body.dark-mode h4, body.dark-mode h5, body.dark-mode h6 {
    color: var(--text-primary) !important;
}

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

body.dark-mode a:not(.btn):not(.nav-link):not(.dropdown-item) {
    color: #818cf8;
}

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

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

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

body.dark-mode ::-webkit-scrollbar-thumb:hover {
    background: #475569;
}

/* Footer */
body.dark-mode footer.bg-dark {
    background-color: #0f172a !important;
}

/* Dark mode toggle button style */
.dark-mode-toggle {
    background: none;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 6px 10px;
    cursor: pointer;
    font-size: 1.1rem;
    transition: all 0.3s ease;
    color: #475569;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
}

.dark-mode-toggle:hover {
    background: #f1f5f9;
    border-color: #cbd5e1;
}

body.dark-mode .dark-mode-toggle {
    border-color: var(--border-color);
    color: #fbbf24;
}

body.dark-mode .dark-mode-toggle:hover {
    background: var(--hover-bg);
    border-color: #475569;
}

/* Notes panel dark mode */
body.dark-mode .notes-panel .note-item {
    border-color: var(--border-color) !important;
}

body.dark-mode .notes-panel .note-item:hover {
    background-color: var(--hover-bg) !important;
}

body.dark-mode .notes-panel .note-text {
    color: var(--text-primary) !important;
}

body.dark-mode .notes-panel .note-meta {
    color: var(--text-secondary) !important;
}

/* Practice mode banner in dark mode */
body.dark-mode .practice-mode-banner {
    background: rgba(245, 158, 11, 0.15) !important;
    border-color: rgba(245, 158, 11, 0.3) !important;
    color: #fcd34d !important;
}

/* List groups */
body.dark-mode .list-group-item {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

/* Accordion */
body.dark-mode .accordion-item {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
}

body.dark-mode .accordion-button {
    background-color: var(--bg-card) !important;
    color: var(--text-primary) !important;
}

body.dark-mode .accordion-button::after {
    filter: invert(1);
}

/* Nav tabs */
body.dark-mode .nav-tabs {
    border-color: var(--border-color) !important;
}

body.dark-mode .nav-tabs .nav-link {
    color: var(--text-secondary) !important;
}

body.dark-mode .nav-tabs .nav-link.active {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

/* Opacity helpers */
body.dark-mode .opacity-75 {
    color: var(--text-secondary) !important;
}
