/**
 * 深色模式增强样式
 * 为发卡系统提供完整的深色模式支持
 */

/* 深色模式下的Bootstrap组件覆盖 */
@media (prefers-color-scheme: dark) {
    /* 模态框 */
    .modal-content {
        background-color: var(--card-bg) !important;
        color: var(--text-color) !important;
        border: 1px solid var(--border-color) !important;
    }
    
    .modal-header {
        border-bottom-color: var(--border-color) !important;
    }
    
    .modal-footer {
        border-top-color: var(--border-color) !important;
    }
    
    /* 下拉菜单 */
    .dropdown-menu {
        background-color: var(--card-bg) !important;
        border-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    .dropdown-item {
        color: var(--text-color) !important;
    }
    
    .dropdown-item:hover,
    .dropdown-item:focus {
        background-color: var(--bg-color) !important;
        color: var(--text-color) !important;
    }
    
    /* 表单控件 */
    .form-control {
        background-color: var(--input-bg) !important;
        border-color: var(--input-border) !important;
        color: var(--text-color) !important;
    }
    
    .form-control:focus {
        background-color: var(--input-bg) !important;
        border-color: var(--primary-color) !important;
        color: var(--text-color) !important;
        box-shadow: 0 0 0 0.2rem rgba(71, 118, 230, 0.25) !important;
    }
    
    .form-control::placeholder {
        color: var(--text-muted) !important;
    }
    
    /* 输入组 */
    .input-group-text {
        background-color: var(--bg-color) !important;
        border-color: var(--input-border) !important;
        color: var(--text-color) !important;
    }
    
    /* 按钮变体 */
    .btn-outline-secondary {
        color: var(--text-color) !important;
        border-color: var(--border-color) !important;
    }
    
    .btn-outline-secondary:hover {
        background-color: var(--bg-color) !important;
        border-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    /* 导航标签 */
    .nav-tabs {
        border-bottom-color: var(--border-color) !important;
    }
    
    .nav-tabs .nav-link {
        color: var(--text-secondary) !important;
        border-color: transparent !important;
    }
    
    .nav-tabs .nav-link:hover {
        border-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    .nav-tabs .nav-link.active {
        background-color: var(--card-bg) !important;
        border-color: var(--border-color) var(--border-color) var(--card-bg) !important;
        color: var(--text-color) !important;
    }
    
    /* 分页 */
    .page-link {
        background-color: var(--card-bg) !important;
        border-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    .page-link:hover {
        background-color: var(--bg-color) !important;
        border-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    .page-item.active .page-link {
        background-color: var(--primary-color) !important;
        border-color: var(--primary-color) !important;
    }
    
    /* 警告框 */
    .alert {
        border-color: var(--border-color) !important;
    }
    
    .alert-info {
        background-color: rgba(71, 118, 230, 0.1) !important;
        border-color: rgba(71, 118, 230, 0.2) !important;
        color: #4776E6 !important;
    }
    
    .alert-warning {
        background-color: rgba(255, 140, 0, 0.1) !important;
        border-color: rgba(255, 140, 0, 0.2) !important;
        color: #FF8C00 !important;
    }
    
    .alert-danger {
        background-color: rgba(255, 56, 96, 0.1) !important;
        border-color: rgba(255, 56, 96, 0.2) !important;
        color: #FF3860 !important;
    }
    
    .alert-success {
        background-color: rgba(40, 167, 69, 0.1) !important;
        border-color: rgba(40, 167, 69, 0.2) !important;
        color: #28a745 !important;
    }
    
    /* 表格 */
    .table {
        color: var(--text-color) !important;
    }
    
    .table th,
    .table td {
        border-color: var(--border-color) !important;
    }
    
    .table-striped tbody tr:nth-of-type(odd) {
        background-color: var(--bg-color) !important;
    }
    
    /* 列表组 */
    .list-group-item {
        background-color: var(--card-bg) !important;
        border-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    .list-group-item:hover {
        background-color: var(--bg-color) !important;
    }
    
    /* 进度条 */
    .progress {
        background-color: var(--bg-color) !important;
    }
    
    /* 工具提示 */
    .tooltip-inner {
        background-color: var(--card-bg) !important;
        color: var(--text-color) !important;
        border: 1px solid var(--border-color) !important;
    }
    
    /* 弹出框 */
    .popover {
        background-color: var(--card-bg) !important;
        border-color: var(--border-color) !important;
    }
    
    .popover-body {
        color: var(--text-color) !important;
    }
    
    .popover-header {
        background-color: var(--bg-color) !important;
        border-bottom-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    /* 面包屑导航 */
    .breadcrumb {
        background-color: var(--bg-color) !important;
    }
    
    .breadcrumb-item a {
        color: var(--primary-color) !important;
    }
    
    .breadcrumb-item.active {
        color: var(--text-secondary) !important;
    }
    
    /* 卡片组件增强 */
    .card-header {
        background-color: var(--bg-color) !important;
        border-bottom-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    .card-footer {
        background-color: var(--bg-color) !important;
        border-top-color: var(--border-color) !important;
        color: var(--text-color) !important;
    }
    
    /* 特殊元素 */
    hr {
        border-color: var(--border-color) !important;
    }
    
    /* 代码块 */
    code {
        background-color: var(--bg-color) !important;
        color: var(--text-color) !important;
    }
    
    pre {
        background-color: var(--input-bg) !important;
        color: var(--text-color) !important;
        border: 1px solid var(--border-color) !important;
    }
    
    /* 选择框 */
    .form-select {
        background-color: var(--input-bg) !important;
        border-color: var(--input-border) !important;
        color: var(--text-color) !important;
    }
    
    .form-select:focus {
        border-color: var(--primary-color) !important;
        box-shadow: 0 0 0 0.2rem rgba(71, 118, 230, 0.25) !important;
    }
    
    /* 复选框和单选框 */
    .form-check-input {
        background-color: var(--input-bg) !important;
        border-color: var(--input-border) !important;
    }
    
    .form-check-input:checked {
        background-color: var(--primary-color) !important;
        border-color: var(--primary-color) !important;
    }
    
    .form-check-label {
        color: var(--text-color) !important;
    }
    
    /* 滚动条样式 */
    ::-webkit-scrollbar {
        width: 8px;
        height: 8px;
    }
    
    ::-webkit-scrollbar-track {
        background: var(--bg-color);
    }
    
    ::-webkit-scrollbar-thumb {
        background: var(--border-color);
        border-radius: 4px;
    }
    
    ::-webkit-scrollbar-thumb:hover {
        background: var(--text-muted);
    }
    
    /* 移动端特定样式 */
    @media (max-width: 768px) {
        .navbar-toggler {
            border-color: var(--border-color) !important;
        }
        
        .navbar-toggler-icon {
            background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28224, 224, 224, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
        }
    }
}

/* 强制深色模式类（用于手动切换） */
.dark-mode {
    --bg-color: #1a1a1a;
    --card-bg: #2d2d2d;
    --text-color: #e0e0e0;
    --text-secondary: #b0b0b0;
    --text-muted: #888888;
    --border-color: #555555;
    --input-bg: #3a3a3a;
    --input-border: #555;
    --shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    --panel-bg: #2d2d2d;
    --overlay-bg: rgba(0, 0, 0, 0.7);
    --navbar-bg: linear-gradient(135deg, #2d3748 0%, #4a5568 100%);
}

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