/* 服装设计研发OA系统 - 主样式文件 */

:root {
    /* 主色系统 */
    --primary-color: #165DFF;
    --primary-light: #4080FF;
    --primary-dark: #0E42C2;
    --primary-color-rgb: 22, 93, 255;
    
    /* 辅助色系统 */
    --success-color: #00B42A;
    --success-light: #36CFC9;
    --warning-color: #FF7D00;
    --warning-light: #FFB946;
    --danger-color: #F53F3F;
    --danger-light: #FF7875;
    --info-color: #86909C;
    --info-light: #C9CDD4;
    
    /* 中性色系统 */
    --text-primary: #1D2129;
    --text-secondary: #4E5969;
    --text-tertiary: #86909C;
    --text-quaternary: #C9CDD4;
    
    --border-color: #E5E6EB;
    --border-light: #F2F3F5;
    --border-dark: #D9D9D9;
    
    --bg-color: #F7F8FA;
    --bg-light: #FFFFFF;
    --bg-dark: #F2F3F5;
    --bg-hover: rgba(0, 0, 0, 0.05);
    
    --shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    --shadow-light: 0 1px 4px rgba(0, 0, 0, 0.05);
    --shadow-dark: 0 4px 12px rgba(0, 0, 0, 0.15);
    
    /* 语义化颜色 */
    --white: #FFFFFF;
    --black: #000000;
    
    /* 圆角系统 */
    --radius-xs: 2px;
    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 8px;
    --radius-xl: 12px;
    --radius-2xl: 16px;
    --radius-full: 20px;
    
    /* 过渡动画 */
    --transition: all 0.3s ease;
    --transition-fast: all 0.15s ease;
    --transition-slow: all 0.5s ease;
}

/* 深色模式 */
[data-theme="dark"] {
    /* 主色系统 - 调整为深色模式适用 */
    --primary-color: #4080FF;
    --primary-light: #69B1FF;
    --primary-dark: #165DFF;
    --primary-color-rgb: 64, 128, 255;
    
    /* 辅助色系统 - 调整为深色模式适用 */
    --success-color: #36CFC9;
    --success-light: #73D13D;
    --warning-color: #FFB946;
    --warning-light: #FFD666;
    --danger-color: #FF7875;
    --danger-light: #FFA39E;
    --info-color: #C9CDD4;
    --info-light: #E5E6EB;
    
    /* 中性色系统 - 深色模式 */
    --text-primary: #F2F3F5;
    --text-secondary: #E5E6EB;
    --text-tertiary: #C9CDD4;
    --text-quaternary: #86909C;
    
    --border-color: #4E5969;
    --border-light: #3A4451;
    --border-dark: #667080;
    
    --bg-color: #1D2129;
    --bg-light: #272B33;
    --bg-dark: #191D24;
    --bg-hover: rgba(255, 255, 255, 0.08);
    
    --shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    --shadow-light: 0 1px 4px rgba(0, 0, 0, 0.2);
    --shadow-dark: 0 4px 12px rgba(0, 0, 0, 0.4);
    
    /* 语义化颜色 */
    --white: #272B33;
    --black: #000000;
}

/* 深色模式下的body样式 */
[data-theme="dark"] body {
    background-color: var(--bg-color);
    color: var(--text-primary);
}

/* 深色模式下的卡片和容器样式 */
[data-theme="dark"] .login-box,
[data-theme="dark"] .table-container,
[data-theme="dark"] .form-container,
[data-theme="dark"] .search-bar,
[data-theme="dark"] .card,
[data-theme="dark"] .modal-content,
[data-theme="dark"] .config-group,
[data-theme="dark"] .dashboard-stats > div,
[data-theme="dark"] .summary-card {
    background-color: var(--bg-light);
    box-shadow: var(--shadow);
    border: 1px solid var(--border-color);
}

/* 深色模式下的表格样式 */
[data-theme="dark"] .table th {
    background: var(--bg-dark);
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-color);
}

[data-theme="dark"] .table td {
    border-bottom: 1px solid var(--border-light);
}

[data-theme="dark"] .table tr:hover {
    background: var(--bg-dark);
}

/* 深色模式下的按钮样式 */
[data-theme="dark"] .btn-default {
    background: var(--bg-light);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

[data-theme="dark"] .btn-default:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: var(--bg-dark);
}

/* 深色模式下的表单样式 */
[data-theme="dark"] .form-group input,
[data-theme="dark"] .form-group select,
[data-theme="dark"] .form-group textarea,
[data-theme="dark"] .form-control {
    background: var(--bg-dark);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group select:focus,
[data-theme="dark"] .form-group textarea:focus,
[data-theme="dark"] .form-control:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(64, 128, 255, 0.2);
    background: var(--bg-dark);
}

/* 深色模式下的状态标签样式 */
[data-theme="dark"] .badge-success,
[data-theme="dark"] .badge-warning,
[data-theme="dark"] .badge-danger,
[data-theme="dark"] .badge-info {
    border: 1px solid currentColor;
}

[data-theme="dark"] .badge-success {
    background: rgba(54, 207, 201, 0.1);
    color: var(--success-color);
}

[data-theme="dark"] .badge-warning {
    background: rgba(255, 185, 70, 0.1);
    color: var(--warning-color);
}

[data-theme="dark"] .badge-danger {
    background: rgba(255, 120, 117, 0.1);
    color: var(--danger-color);
}

[data-theme="dark"] .badge-info {
    background: rgba(201, 205, 212, 0.1);
    color: var(--info-color);
}

/* 深色模式下的侧边栏样式 */
[data-theme="dark"] .sidebar {
    background: var(--bg-dark);
}

[data-theme="dark"] .sidebar-header {
    background: var(--bg-light);
}

[data-theme="dark"] .menu-item:hover {
    background: var(--primary-color);
    color: var(--white);
}

[data-theme="dark"] .menu-item.active {
    background: var(--primary-color);
    border-left-color: var(--white);
    color: var(--white);
}

[data-theme="dark"] .sidebar.collapsed .menu-group-children {
    background: #2a2a2b;
}

[data-theme="dark"] .sidebar.collapsed .menu-group-children li {
    color: #e5e5e5 !important;
}

[data-theme="dark"] .sidebar.collapsed .menu-group-children li:hover {
    color: #fff !important;
}

/* 深色模式下的顶部栏样式 */
[data-theme="dark"] .header {
    background: var(--bg-light);
    border-bottom: 1px solid var(--border-color);
}

/* 标签栏 */
.nav-tabs {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    border-bottom: 1px solid var(--border-color);
    padding: 0;
    margin: 0;
    list-style: none;
}

.nav-tabs li {
    flex-shrink: 0;
    margin-bottom: -1px;
}

.nav-tabs li a {
    display: block;
    padding: 8px 12px;
    text-decoration: none;
    color: var(--text-secondary);
    border-bottom: 2px solid transparent;
    white-space: nowrap;
    font-size: 13px;
}

.nav-tabs li.active a {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

.nav-tabs li a:hover {
    color: var(--primary-color);
}

/* 深色模式下的标签栏样式 */
[data-theme="dark"] .nav-tabs {
    border-bottom: 1px solid var(--border-color);
}

[data-theme="dark"] .nav-tabs li a {
    color: var(--text-secondary);
}

[data-theme="dark"] .nav-tabs li.active a {
    color: var(--primary-color);
    border-bottom: 2px solid var(--primary-color);
}

/* 深色模式下的分页样式 */
[data-theme="dark"] .pagination button {
    background: var(--bg-light);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

[data-theme="dark"] .pagination button:hover:not(:disabled) {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: var(--bg-dark);
}

[data-theme="dark"] .pagination .active {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* 深色模式下的错误提示样式 */
[data-theme="dark"] .error-tip {
    background: rgba(245, 63, 63, 0.1);
    border: 1px solid var(--danger-color);
    color: var(--danger-color);
}

/* 深色模式下的加载和空状态样式 */
[data-theme="dark"] .loading,
[data-theme="dark"] .empty-tip,
[data-theme="dark"] .text-center {
    color: var(--text-tertiary);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    font-size: 14px;
    line-height: 1.5;
    color: var(--text-primary);
    background-color: var(--bg-color);
    overflow: hidden;
}

html {
    overflow: hidden;
}

/* 应用容器 */
.app-layout {
    display: flex;
    height: 100vh;
    width: 100vw;
    overflow: hidden;
}

/* 登录页面 */
.login-container {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #f093fb 100%);
    padding: 20px;
    position: relative;
    overflow: hidden;
}

.login-container::before,
.login-container::after {
    content: '';
    position: absolute;
    width: 400px;
    height: 400px;
    border-radius: 50%;
    opacity: 0.3;
    animation: float 6s ease-in-out infinite;
}

.login-container::before {
    background: rgba(255, 255, 255, 0.4);
    top: -100px;
    right: -100px;
    animation-delay: 0s;
}

.login-container::after {
    background: rgba(102, 126, 234, 0.3);
    bottom: -100px;
    left: -100px;
    animation-delay: -3s;
}

@keyframes float {
    0%, 100% {
        transform: translateY(0) rotate(0deg);
    }
    50% {
        transform: translateY(-20px) rotate(5deg);
    }
}

.login-box {
    width: 100%;
    max-width: 420px;
    padding: 48px 40px 40px;
    background: var(--bg-light);
    border-radius: 20px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(10px);
}

.login-box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #667eea, #764ba2, #f093fb);
    background-size: 200% 100%;
    animation: shimmer 3s linear infinite;
}

@keyframes shimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

.login-box::after {
    content: '';
    position: absolute;
    top: -50%;
    right: -50%;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, rgba(102, 126, 234, 0.1) 0%, transparent 70%);
    pointer-events: none;
}

.login-header {
    text-align: center;
    margin-bottom: 36px;
}

.login-logo {
    display: flex;
    justify-content: center;
    margin-bottom: 24px;
}

.login-logo svg {
    color: var(--primary-color);
    transition: var(--transition);
}

.login-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--text-primary);
    transition: var(--transition);
}

.login-subtitle {
    font-size: 14px;
    color: var(--text-tertiary);
    margin: 0;
    transition: var(--transition);
}

.login-form .form-group {
    margin-bottom: 24px;
}

.form-label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    font-size: 14px;
    color: var(--text-secondary);
    transition: var(--transition);
}

.label-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.input-wrapper {
    position: relative;
    display: block;
}

.input-wrapper svg {
    position: absolute !important;
    left: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    color: var(--text-quaternary) !important;
    z-index: 10 !important;
    pointer-events: none !important;
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

.form-input {
    width: 100%;
    padding: 14px 56px 14px 45px !important;
    border: 2px solid transparent;
    border-radius: 12px;
    font-size: 16px;
    transition: all 0.3s ease;
    background: linear-gradient(var(--bg-light), var(--bg-light)) padding-box,
                linear-gradient(135deg, #667eea, #764ba2) border-box;
    color: var(--text-primary);
}

.form-input:focus {
    outline: none;
    background: var(--bg-light);
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.15),
                0 4px 20px rgba(102, 126, 234, 0.1);
    transform: translateY(-1px);
}

.form-input::placeholder {
    color: var(--text-quaternary);
}

.password-toggle {
    position: absolute !important;
    right: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    padding: 2px !important;
    color: var(--text-quaternary) !important;
    transition: var(--transition);
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 20 !important;
    width: 20px !important;
    height: 20px !important;
}

.password-toggle:hover {
    color: var(--text-secondary);
}

.form-actions {
    margin-top: 32px;
}

.login-btn {
    width: 100%;
    padding: 16px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: var(--white);
    border: none;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    position: relative;
    overflow: hidden;
}

.login-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s ease;
}

.login-btn:hover::before {
    left: 100%;
}

.login-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(102, 126, 234, 0.4);
}

.login-btn:active {
    transform: translateY(-1px);
}

.login-footer {
    margin-top: 32px;
    text-align: center;
}

.login-copyright {
    font-size: 12px;
    color: var(--text-quaternary);
    margin: 0;
    transition: var(--transition);
}

/* 深色模式下的登录页面优化 */
[data-theme="dark"] .login-box {
    background: var(--bg-light);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .form-input {
    background: var(--bg-dark);
    color: var(--text-primary);
    border-color: var(--border-color);
}

[data-theme="dark"] .form-input:focus {
    background: var(--bg-dark);
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(64, 128, 255, 0.2);
}

[data-theme="dark"] .input-wrapper svg {
    color: var(--text-quaternary);
}

[data-theme="dark"] .password-toggle {
    color: var(--text-quaternary);
}

[data-theme="dark"] .password-toggle:hover {
    color: var(--text-secondary);
}

/* 主布局 */
.app-layout {
    display: flex;
    min-height: 100vh;
}

/* 侧边栏 */
.sidebar {
    width: 150px;
    background: var(--bg-dark);
    color: var(--text-primary);
    transition: var(--transition);
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    overflow: hidden;
    z-index: 1000;
    font-size: 13px;
    display: flex;
    flex-direction: column;
}

.sidebar.collapsed {
    width: 64px;
    overflow: visible;
}

/* 侧边栏菜单区域滚动 */
.sidebar-menu {
    list-style: none;
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
}

.sidebar.collapsed .sidebar-menu {
    overflow: visible;
}

/* 侧边栏菜单自定义滚动条 */
.sidebar-menu::-webkit-scrollbar {
    width: 3px;
}

.sidebar-menu::-webkit-scrollbar-track {
    background: transparent;
}

.sidebar-menu::-webkit-scrollbar-thumb {
    background: var(--text-tertiary);
    border-radius: 2px;
}

.sidebar-menu::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
}

/* Header标签页滚动条 */
.nav-tabs::-webkit-scrollbar {
    width: 3px;
    height: 3px;
}

.nav-tabs::-webkit-scrollbar-track {
    background: transparent;
}

.nav-tabs::-webkit-scrollbar-thumb {
    background: var(--text-tertiary);
    border-radius: 2px;
}

.nav-tabs::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
}

/* 主内容区滚动条 */
.page-content::-webkit-scrollbar {
    width: 4px;
    height: 4px;
}

.page-content::-webkit-scrollbar-track {
    background: transparent;
}

.page-content::-webkit-scrollbar-thumb {
    background: var(--text-tertiary);
    border-radius: 2px;
}

.page-content::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
}

/* 全局滚动条样式 */
::-webkit-scrollbar {
    width: 5px;
    height: 5px;
}

::-webkit-scrollbar-track {
    background: var(--bg-dark);
}

::-webkit-scrollbar-thumb {
    background: var(--text-tertiary);
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
}

/* 折叠状态下的样式 */
.sidebar.collapsed .menu-item span:not(.menu-icon),
.sidebar.collapsed .menu-group-title span:not(.menu-icon) {
    display: none;
}

.sidebar.collapsed .menu-item {
    display: flex;
    justify-content: center;
    padding: 15px 0;
}

.sidebar.collapsed .menu-icon {
    margin-right: 0;
    font-size: 18px;
}

.sidebar.collapsed .sidebar-header span {
    display: inline;
    font-size: 14px;
}

.sidebar.collapsed .sidebar-header {
    justify-content: center;
}

.sidebar.collapsed .menu-group-title {
    justify-content: center;
    padding: 15px 0;
    position: relative;
    cursor: pointer;
    width: 100%;
    text-align: center;
    height: 48px;
    display: flex;
    align-items: center;
}

.sidebar.collapsed .menu-group-title .menu-icon {
    display: inline;
    font-size: 18px;
}

.sidebar.collapsed .menu-group-title:hover {
    background: rgba(255, 255, 255, 0.1);
}

.sidebar.collapsed .menu-group-title .arrow {
    display: none;
}

/* 折叠状态下的菜单组子项处理 */
.sidebar.collapsed .menu-group-children {
    position: absolute !important;
    left: 100% !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 160px !important;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    z-index: 1001 !important;
    display: none !important;
    max-height: 80vh;
    overflow-y: auto;
}

/* 折叠状态下hover显示子菜单 */
.sidebar.collapsed .menu-group:hover > .menu-group-children,
.sidebar.collapsed .menu-group:hover .menu-group-children,
.sidebar.collapsed .menu-group-title:hover + .menu-group-children,
.sidebar.collapsed .menu-group-title:hover ~ .menu-group-children {
    display: block !important;
}

.sidebar.collapsed .menu-group-title:hover {
    background: rgba(255, 255, 255, 0.1);
}

.sidebar.collapsed .menu-group.show-submenu > .menu-group-children {
    display: block !important;
}

.sidebar.collapsed .menu-group-children li {
    padding: 10px 15px;
    white-space: nowrap;
    color: #333 !important;
}

.sidebar.collapsed .menu-group-children li:hover {
    background: var(--primary-color);
    color: #fff !important;
}

.sidebar.collapsed .menu-group-children li span {
    display: inline !important;
    color: inherit !important;
}

.sidebar.collapsed .menu-group-children li .menu-icon {
    display: none;
}

.sidebar-header {
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-light);
    font-size: 16px;
    font-weight: bold;
    transition: var(--transition);
}

.menu-item {
    padding: 8px 10px;
    cursor: pointer;
    transition: var(--transition);
    border-left: 3px solid transparent;
}

.menu-item:hover {
    background: var(--primary-color);
    color: var(--white);
}

.menu-item.active {
    background: var(--primary-color);
    border-left-color: var(--white);
    color: var(--white);
}

.menu-icon {
    margin-right: 3px;
    font-size: 14px;
}

/* 菜单分组 */
.menu-group {
    margin-top: 5px;
    position: relative;
}

.sidebar.collapsed .menu-group {
    position: relative;
    z-index: 10;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    margin-top: 0;
    border-bottom: 1px solid transparent;
}

.sidebar.collapsed .menu-group:hover {
    z-index: 20;
    background: rgba(255, 255, 255, 0.05);
}

.sidebar.collapsed .menu-group:hover > .menu-group-children {
    display: block !important;
}

.sidebar.collapsed .menu-group-title {
    height: 100%;
    width: 100%;
    justify-content: center;
    padding: 0;
    position: relative;
    cursor: pointer;
    text-align: center;
    display: flex;
    align-items: center;
    margin: 0;
}

.sidebar.collapsed .menu-group.show-submenu {
    z-index: 20;
}

.menu-group-title {
    padding: 8px 10px;
    font-size: 12px;
    font-weight: bold;
    color: var(--text-tertiary);
    letter-spacing: 1px;
    cursor: pointer;
    display: flex;
    align-items: center;
    user-select: none;
    transition: color 0.2s;
}

.menu-group-title:hover {
    color: var(--white);
}

.menu-group-title .menu-icon {
    margin-right: 3px;
    font-size: 14px;
}

.menu-group-title .arrow {
    font-size: 10px;
    margin-left: auto;
    transition: transform 0.2s;
}

.menu-group-title.expanded .arrow {
    transform: rotate(90deg);
}

.menu-group-children {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.menu-group-children.expanded {
    max-height: 1000px;
}

/* 侧边栏搜索 */
.sidebar-search {
    display: flex;
    align-items: center;
    padding: 8px 12px;
    margin: 5px 8px 8px 8px;
    background: var(--bg-hover);
    border-radius: 6px;
    gap: 8px;
}

.sidebar-search svg {
    color: var(--text-tertiary);
    flex-shrink: 0;
}

.sidebar-search input {
    flex: 1;
    border: none;
    background: transparent;
    color: var(--text-primary);
    font-size: 12px;
    outline: none;
}

.sidebar-search input::placeholder {
    color: var(--text-tertiary);
}

.sidebar.collapsed .sidebar-search {
    display: none;
}

/* 侧边栏收藏 */
.sidebar-favorites {
    margin: 0 8px 8px 8px;
    background: var(--bg-hover);
    border-radius: 6px;
    overflow: hidden;
}

.favorites-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    font-size: 12px;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
}

.favorites-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.favorites-list .menu-item {
    padding: 8px 12px;
}

.remove-favorite {
    margin-left: auto;
    opacity: 0;
    cursor: pointer;
    color: var(--text-tertiary);
    font-size: 14px;
    transition: opacity 0.2s;
}

.menu-item:hover .remove-favorite {
    opacity: 1;
}

.remove-favorite:hover {
    color: var(--danger-color);
}

.sidebar.collapsed .sidebar-favorites {
    display: none !important;
}

/* 侧边栏头部 */
.sidebar-header {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px 12px;
    font-weight: 600;
    font-size: 14px;
    border-bottom: 1px solid var(--border-color);
}

.sidebar-collapse-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    color: var(--text-tertiary);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.sidebar-collapse-btn:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.sidebar.collapsed .sidebar-collapse-btn svg {
    transform: rotate(180deg);
}

.sidebar.collapsed .sidebar-title {
    display: none;
}

/* 菜单项增强 */
.menu-item {
    transition: background 0.2s, transform 0.1s;
}

.menu-item:hover {
    background: var(--bg-hover);
}

.menu-item:active {
    transform: scale(0.98);
}

.menu-item.search-highlight {
    background: rgba(var(--primary-color-rgb), 0.1);
}

.menu-item:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: -2px;
}

/* 菜单徽章 */
.menu-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: 10px;
    font-weight: 600;
    border-radius: 9px;
    background: var(--danger-color);
    color: white;
    margin-left: auto;
}

/* 平滑动画 */
.menu-group-children {
    transition: max-height 0.3s ease-out, opacity 0.2s ease-out;
    overflow: hidden;
}

.menu-group-children:not(.expanded) {
    max-height: 0;
    opacity: 0;
}

.menu-group-children.expanded {
    opacity: 1;
}

/* 主内容区 */
.main-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    margin-left: 150px;
    margin-top: 0;
    height: 100vh;
    overflow: hidden;
    position: relative;
    padding-top: 50px; /* 为header留出空间 */
}

/* 内容区域 */
.page-content {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 5px;
    height: calc(100vh - 50px); /* 减去header高度 */
}

/* 顶部导航 */
.header {
    height: 50px;
    background: var(--bg-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
    box-shadow: var(--shadow);
    transition: var(--transition);
    position: fixed;
    top: 0;
    right: 0;
    left: 150px;
    z-index: 999;
}

.header-left {
    display: flex;
    align-items: center;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

.user-info {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}

.user-name {
    color: var(--text-primary);
    font-size: 14px;
}

.user-dropdown {
    position: relative;
}

.user-dropdown-menu {
    display: none;
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 8px;
    background: var(--bg-light);
    border-radius: 6px;
    box-shadow: var(--shadow-dark);
    min-width: 140px;
    overflow: hidden;
    z-index: 1000;
}

.user-dropdown:hover .user-dropdown-menu {
    display: block;
}

.user-dropdown-name {
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-color);
}

.user-dropdown-item {
    padding: 10px 16px;
    cursor: pointer;
    font-size: 14px;
    color: var(--text-primary);
    transition: background 0.2s;
}

.user-dropdown-item:hover {
    background: var(--bg-dark);
}

.user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--primary-color);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
}

/* 内容区域 */
.content {
    flex: 1;
    padding: 24px;
    overflow-y: auto;
}

/* 表格响应式优化 */
.table {
    width: 100%;
    border-collapse: collapse;
}

.table th,
.table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
    white-space: nowrap;
    transition: var(--transition);
}

.table th {
    background: var(--bg-dark);
    font-weight: 500;
    font-size: 14px;
    color: var(--text-primary);
    transition: var(--transition);
}

.table td {
    font-size: 14px;
    transition: var(--transition);
}

.table tr:hover {
    background: var(--bg-dark);
    transition: var(--transition);
}

/* 按钮样式 */
.btn {
    padding: 8px 16px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    transition: var(--transition);
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: 44px;
    min-width: 44px;
    justify-content: center;
}

.btn-primary {
    background: var(--primary-color);
    color: var(--white);
}

.btn-primary:hover {
    background: var(--primary-light);
}

.btn-success {
    background: var(--success-color);
    color: var(--white);
}

.btn-success:hover {
    background: var(--success-light);
}

.btn-danger {
    background: var(--danger-color);
    color: var(--white);
}

.btn-danger:hover {
    background: var(--danger-light);
}

.btn-warning {
    background: var(--warning-color);
    color: var(--white);
}

.btn-warning:hover {
    background: var(--warning-light);
}

.btn-info {
    background: #17a2b8;
    color: var(--white);
}

.btn-info:hover {
    background: #138496;
}

.btn-default {
    background: var(--bg-light);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.btn-default:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: var(--bg-dark);
}

.btn-sm {
    padding: 4px 8px;
    font-size: 12px;
    min-height: auto;
    min-width: auto;
    border-radius: 4px;
}

.btn-sm i {
    font-size: 11px;
}

.btn-lg {
    padding: 12px 24px;
    font-size: 16px;
    min-height: 50px;
    min-width: 50px;
}

/* 表单样式 */
.form-container {
    background: var(--bg-light);
    padding: 24px;
    border-radius: 8px;
    box-shadow: var(--shadow);
    transition: var(--transition);
}

/* 搜索栏 */
/* 删除旧的search-bar样式，使用新的filter-section替代 */

/* 分页 */
.pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin-top: 20px;
}

.pagination button {
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    background: var(--bg-light);
    border-radius: 4px;
    cursor: pointer;
    transition: var(--transition);
    min-height: 36px;
    min-width: 36px;
    font-size: 14px;
    color: var(--text-primary);
}

.pagination button:hover:not(:disabled) {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: var(--bg-dark);
}

.pagination button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.pagination .active {
    background: var(--primary-color);
    color: var(--white);
    border-color: var(--primary-color);
}

/* 模态框 */
.modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2000;
    justify-content: center;
    align-items: center;
}

.modal.show {
    display: flex !important;
}

/* 确保模态框内容垂直水平居中 */
.modal-content {
    position: relative;
    background: var(--bg-light);
    border-radius: 8px;
    width: 95%;
    max-width: 900px;
    max-height: 85vh;
    min-height: 300px;
    height: fit-content;
    overflow: hidden;
    padding: 0;
    transition: var(--transition);
    z-index: 1050;
    margin: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
}

.modal-content .modal-header,
.modal-content .modal-header.trae-browser-inspect-draggable {
    flex-shrink: 0;
    padding: 14px 20px !important;
    margin-bottom: 0 !important;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--bg-dark) !important;
    cursor: move;
}

.modal-header h3 {
    margin: 0;
    font-size: 16px;
    color: var(--text-primary);
}

.modal-header-right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    margin-left: auto;
    padding-left: 20px;
}

.modal-fullscreen-btn {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-tertiary);
    padding: 6px 10px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
}

.modal-fullscreen-btn:hover {
    color: var(--text-primary);
    background-color: var(--bg-hover);
}

.modal-header .close {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
    color: var(--text-tertiary);
    padding: 6px 10px;
    margin: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    line-height: 1;
    border-radius: 4px;
}

.modal-header .close:hover {
    color: var(--text-primary);
    background-color: var(--bg-hover);
}

.modal-body {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    min-height: 0;
}

.modal-footer {
    flex-shrink: 0;
    padding: 14px 20px;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

/* 卡片 */
.card {
    background: var(--bg-light);
    border-radius: 8px;
    box-shadow: var(--shadow-light);
    overflow: hidden;
}

.card-header {
    padding: 14px 20px;
    border-bottom: 1px solid var(--border-color);
}

.card-header h3 {
    margin: 0;
    font-size: 16px;
    color: var(--text-primary);
}

.card-body {
    padding: 20px;
}

/* 详情行 */
.detail-view {
    margin: 0;
}

.detail-row {
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-light);
}

.detail-row:last-child {
    border-bottom: none;
}

.detail-label {
    color: var(--text-tertiary);
    font-size: 14px;
    flex-shrink: 0;
}

.detail-value {
    color: var(--text-primary);
    font-size: 14px;
}

.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1040;
}

/* 模态框尺寸变体 */
.modal-content {
    position: relative;
    background: var(--bg-light);
    border-radius: 8px;
    width: 95%;
    max-width: 900px;
    max-height: 85vh;
    height: auto;
    min-height: 200px;
    overflow: hidden;
    padding: 0;
    transition: var(--transition);
    z-index: 1050;
    margin: auto;
    display: flex;
    flex-direction: column;
}

/* 小模态框 */
.modal-content.modal-small {
    max-width: 500px;
    width: auto;
    min-width: 260px;
    min-height: auto;
    margin: auto;
    left: 0;
    right: 0;
}

.modal-content.modal-small.resizable {
    min-width: 260px;
    max-width: none;
}

/* 确认对话框样式 */
.confirm-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 20px 0;
}

.confirm-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(251, 191, 36, 0.1);
    border-radius: 50%;
    margin-bottom: 16px;
}

.confirm-icon i {
    font-size: 28px;
    color: var(--warning-color);
}

.confirm-content p {
    font-size: 15px;
    color: var(--text-primary);
    margin: 0;
    line-height: 1.6;
}

.modal-content.modal-small .modal-header {
    padding: 10px 16px;
}

.modal-content.modal-small .modal-header h3 {
    font-size: 16px;
}

.modal-content.modal-small .modal-body {
    padding: 12px 16px;
}

.modal-content.modal-small .modal-footer {
    padding: 10px 16px;
    justify-content: center;
    gap: 12px;
}

/* 中等模态框 */
.modal-content.modal-medium {
    max-width: 700px;
}

.modal-content.modal-medium .card-body {
    padding: 15px;
}

.modal-content.modal-medium .row {
    margin-bottom: 12px;
}

.modal-content.modal-medium h4 {
    margin-bottom: 12px;
    font-size: 15px;
}

/* 大模态框 */
.modal-content.modal-large {
    max-width: 900px;
}

/* 超大模态框 */
.modal-content.modal-xlarge {
    max-width: 1000px;
}

.modal-content.modal-xl {
    max-width: 1100px;
}

.modal-content.modal-xxl {
    max-width: 1300px;
}

.template-variable-toolbar {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px 12px;
    background: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
}

.template-variable-toolbar .btn-outline-primary {
    font-size: 12px;
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    white-space: nowrap;
    transition: all 0.15s ease;
    line-height: 1.6;
}

.template-variable-toolbar .btn-outline-primary:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-light);
}

.template-variable-toolbar .btn-outline-primary:active {
    transform: translateY(0);
}

.modal-header {
    padding: 12px 20px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    transition: var(--transition);
}

.modal-header h3 {
    margin: 0;
    flex: 1;
    text-align: center;
}

.modal-header .close {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
    color: var(--text-tertiary);
    padding: 4px 8px;
    margin: 0;
    line-height: 1;
    padding: 0;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-title {
    font-size: 18px;
    font-weight: bold;
    color: var(--text-primary);
    transition: var(--transition);
}

.modal-close {
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    padding: 0;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-body {
    padding: 16px;
    transition: var(--transition);
    overflow-y: auto;
    height: calc(100% - 80px);
    min-height: 0;
}

.modal-footer {
    padding: 12px 20px;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    transition: var(--transition);
}

/* 模态框内部表单样式更紧凑 */
.modal-body .form-group {
    margin-bottom: 14px;
}

.modal-body .form-group label {
    margin-bottom: 6px;
    font-size: 13px;
}

.modal-body .form-group input,
.modal-body .form-group select,
.modal-body .form-group textarea {
    padding: 10px 14px;
    min-height: 38px;
    font-size: 14px;
}

/* 模态框内部按钮更紧凑 */
.modal-footer .btn {
    min-height: 36px;
    padding: 7px 16px;
    font-size: 13px;
}

/* 模态框全屏和调整大小功能 */
.modal-toolbar {
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    gap: 8px;
    z-index: 10;
}

.modal-toolbar button {
    background: none;
    border: none;
    font-size: 16px;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 4px;
    color: var(--text-secondary);
    transition: var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-toolbar button:hover {
    background: rgba(0, 0, 0, 0.08);
    color: var(--text-primary);
}

.modal-toolbar button:active {
    background: rgba(0, 0, 0, 0.12);
}

/* 可调整大小的模态框 */
.modal.resizable {
    resize: none;
    overflow: hidden;
}

.modal-content.resizable {
    position: absolute;
    min-width: 400px;
    min-height: 300px;
    cursor: default;
}

/* 调整大小手柄 */
.modal-resize-handle {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 24px;
    height: 24px;
    cursor: se-resize;
    z-index: 100;
    background-color: var(--bg-light);
    border-radius: 0 0 8px 0;
}

.modal-resize-handle::before {
    content: '';
    position: absolute;
    bottom: 6px;
    right: 6px;
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--text-quaternary);
    border-bottom: 2px solid var(--text-quaternary);
    opacity: 0.5;
    transition: opacity 0.2s ease;
}

.modal-resize-handle:hover::before {
    opacity: 1;
}

/* 全屏模式 */
.modal.fullscreen .modal-content {
    width: 100vw !important;
    height: 100vh !important;
    max-width: 100vw !important;
    max-height: 100vh !important;
    border-radius: 0;
    top: 0;
    left: 0;
    transform: none;
}

.modal.fullscreen .modal-body {
    max-height: calc(100vh - 130px);
}

.modal.fullscreen .modal-resize-handle {
    display: none;
}

/* 模态框拖动时的样式 */
.modal-content.dragging {
    opacity: 0.9;
    cursor: grabbing;
}

.modal-content.dragging .modal-header {
    cursor: grabbing;
}

.img-preview-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0);
    z-index: 99999;
    display: flex;
    flex-direction: column;
    transition: background 0.3s ease;
    user-select: none;
}

.img-preview-overlay.show {
    background: rgba(0, 0, 0, 0.92);
}

.img-preview-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    z-index: 2;
    flex-shrink: 0;
}

.img-preview-title {
    color: rgba(255, 255, 255, 0.85);
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.img-preview-tools {
    display: flex;
    align-items: center;
    gap: 6px;
}

.img-preview-zoom-label {
    color: rgba(255, 255, 255, 0.9);
    font-size: 13px;
    font-weight: 600;
    min-width: 48px;
    text-align: center;
    padding: 4px 10px;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 6px;
    font-variant-numeric: tabular-nums;
}

.img-preview-tool-btn {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.85);
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.img-preview-tool-btn:hover {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.4);
    color: #fff;
}

.img-preview-tool-btn:active {
    transform: scale(0.92);
}

.img-preview-tool-divider {
    width: 1px;
    height: 20px;
    background: rgba(255, 255, 255, 0.2);
    margin: 0 4px;
}

.img-preview-viewport {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
    cursor: default;
}

.img-preview-viewport #imgPreviewImg {
    max-width: 90vw;
    max-height: calc(100vh - 120px);
    object-fit: contain;
    border-radius: 4px;
    transform-origin: center center;
    will-change: transform;
    pointer-events: auto;
}

.img-preview-hint {
    display: flex;
    justify-content: center;
    gap: 24px;
    padding: 10px 0 14px;
    z-index: 2;
    flex-shrink: 0;
}

.img-preview-hint span {
    color: rgba(255, 255, 255, 0.45);
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.img-preview-hint span i {
    font-size: 11px;
}

.dc-card {
    background: var(--bg-light);
    border-radius: 8px;
    padding: 20px;
    box-shadow: var(--shadow);
}

.dc-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

.dc-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}

.dc-title i {
    color: var(--primary-color);
}

.dc-add-btn {
    padding: 6px 14px;
    background: var(--primary-color);
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 5px;
    transition: all 0.2s;
}

.dc-add-btn:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

.dc-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
}

.dc-nav {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dc-nav-btn {
    width: 30px;
    height: 30px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    transition: all 0.2s;
    line-height: 1;
    padding: 0;
}

.dc-nav-btn:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

.dc-month-label {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary);
    min-width: 90px;
    text-align: center;
}

.dc-today-btn {
    padding: 4px 12px;
    border-radius: 6px;
    border: 1px solid var(--primary-color);
    background: white;
    color: var(--primary-color);
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    transition: all 0.2s;
}

.dc-today-btn:hover {
    background: var(--primary-color);
    color: white;
}

.dc-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 1px;
    background: var(--border-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 16px;
}

.dc-week-hd {
    background: var(--bg-secondary);
    padding: 6px 2px;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
}

.dc-week-hd:nth-child(6),
.dc-week-hd:nth-child(7) {
    color: var(--danger-color);
}

.dc-day {
    background: white;
    padding: 4px 5px;
    min-height: 48px;
    cursor: pointer;
    transition: background 0.15s;
    display: flex;
    flex-direction: column;
}

.dc-day:hover {
    background: var(--bg-hover);
}

.dc-day.other-month {
    background: var(--bg-secondary);
}

.dc-day.other-month .dc-day-num {
    color: var(--text-muted);
}

.dc-day.today {
    background: #eef2ff;
}

.dc-day.today .dc-day-num {
    background: var(--primary-color);
    color: white;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dc-day.has-plans {
    background: #fafbff;
}

.dc-day-num {
    font-size: 12px;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 2px;
}

.dc-plan-dots {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    align-items: center;
}

.dc-plan-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}

.dc-plan-more {
    font-size: 9px;
    color: var(--primary-color);
    font-weight: 600;
}

.dc-upcoming {
    border-top: 1px solid var(--border-color);
    padding-top: 12px;
}

.dc-empty {
    text-align: center;
    padding: 16px 0;
    color: var(--text-muted);
    font-size: 13px;
}

.dc-empty i {
    font-size: 24px;
    margin-bottom: 6px;
    display: block;
}

.dc-upcoming-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 0.15s;
    margin-bottom: 4px;
}

.dc-upcoming-item:hover {
    background: var(--bg-hover);
}

.dc-upcoming-color {
    width: 4px;
    min-height: 32px;
    border-radius: 2px;
    flex-shrink: 0;
    margin-top: 2px;
}

.dc-upcoming-info {
    flex: 1;
    min-width: 0;
}

.dc-upcoming-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dc-upcoming-meta {
    display: flex;
    gap: 8px;
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 2px;
    align-items: center;
}

.dc-upcoming-meta i {
    margin-right: 2px;
}

.dc-upcoming-status {
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 500;
}

.dc-upcoming-status.pending {
    background: #fef3c7;
    color: #92400e;
}

.dc-upcoming-status.in_progress {
    background: #dbeafe;
    color: #1e40af;
}

.dc-upcoming-status.completed {
    background: #dcfce7;
    color: #166534;
}

.dc-day-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

.dc-day-modal-date {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary);
}

.dc-day-modal-add {
    padding: 5px 12px;
    background: var(--primary-color);
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 4px;
    transition: all 0.2s;
}

.dc-day-modal-add:hover {
    opacity: 0.9;
}

.dc-day-empty {
    text-align: center;
    padding: 24px 0;
    color: var(--text-muted);
    font-size: 13px;
}

.dc-day-empty i {
    font-size: 28px;
    margin-bottom: 8px;
    display: block;
}

.dc-plan-item {
    display: flex;
    align-items: flex-start;
    gap: 0;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-color);
    transition: background 0.15s;
}

.dc-plan-item:last-child {
    border-bottom: none;
}

.dc-plan-color-bar {
    width: 4px;
    min-height: 40px;
    border-radius: 2px;
    flex-shrink: 0;
    margin-right: 10px;
}

.dc-plan-body {
    flex: 1;
    min-width: 0;
}

.dc-plan-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.dc-plan-item.completed .dc-plan-title {
    text-decoration: line-through;
    color: var(--text-muted);
}

.dc-plan-meta {
    display: flex;
    gap: 10px;
    font-size: 12px;
    color: var(--text-secondary);
    align-items: center;
}

.dc-plan-meta i {
    margin-right: 3px;
}

.dc-plan-status {
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 11px;
    font-weight: 500;
}

.dc-plan-status.pending {
    background: #fef3c7;
    color: #92400e;
}

.dc-plan-status.in_progress {
    background: #dbeafe;
    color: #1e40af;
}

.dc-plan-status.completed {
    background: #dcfce7;
    color: #166534;
}

.dc-plan-priority {
    font-size: 11px;
    font-weight: 500;
}

.dc-plan-desc {
    font-size: 12px;
    color: var(--text-secondary);
    margin-top: 4px;
    line-height: 1.5;
}

.dc-plan-actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
    margin-left: 8px;
    opacity: 0;
    transition: opacity 0.2s;
}

.dc-plan-item:hover .dc-plan-actions {
    opacity: 1;
}

.dc-act-btn {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: var(--text-secondary);
    transition: all 0.2s;
    line-height: 1;
    padding: 0;
}

.dc-act-btn:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

.dc-act-btn.dc-act-del:hover {
    background: var(--danger-color);
    border-color: var(--danger-color);
}

.dc-form-group {
    margin-bottom: 14px;
}

.dc-form-label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 5px;
}

.dc-required {
    color: var(--danger-color);
}

.dc-form-input {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-size: 13px;
    color: var(--text-primary);
    background: white;
    box-sizing: border-box;
    transition: border-color 0.2s;
}

.dc-form-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(var(--primary-color-rgb, 59, 130, 246), 0.1);
}

.dc-form-textarea {
    resize: vertical;
    min-height: 60px;
}

.dc-form-row {
    display: flex;
    gap: 12px;
}

.dc-form-half {
    flex: 1;
}

.dc-color-row {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.dc-color-opt {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all 0.2s;
}

.dc-color-opt:hover {
    transform: scale(1.15);
}

.dc-color-opt.active {
    border-color: var(--text-primary);
    box-shadow: 0 0 0 2px white, 0 0 0 4px var(--text-primary);
}

.dc-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid var(--border-color);
}

@media (max-width: 768px) {
    .dc-grid {
        gap: 0;
    }

    .dc-day {
        min-height: 36px;
        padding: 2px 3px;
    }

    .dc-day-num {
        font-size: 11px;
    }

    .dc-plan-dot {
        width: 4px;
        height: 4px;
    }

    .dc-form-row {
        flex-direction: column;
        gap: 0;
    }

    .dc-plan-actions {
        opacity: 1;
    }
}

/* 状态标签 */
.badge {
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
    transition: var(--transition);
}

.badge-success {
    background: rgba(0, 180, 42, 0.1);
    color: var(--success-color);
    border: 1px solid var(--success-color);
    transition: var(--transition);
}

.badge-warning {
    background: rgba(255, 125, 0, 0.1);
    color: var(--warning-color);
    border: 1px solid var(--warning-color);
    transition: var(--transition);
}

.badge-danger {
    background: rgba(245, 63, 63, 0.1);
    color: var(--danger-color);
    border: 1px solid var(--danger-color);
    transition: var(--transition);
}

.badge-info {
    background: rgba(134, 144, 156, 0.1);
    color: var(--info-color);
    border: 1px solid var(--info-color);
    transition: var(--transition);
}

/* ==================== 响应式设计 ==================== */

/* 小屏幕手机 <=480px */
@media (max-width: 480px) {
    /* 登录页 */
    .login-container {
        padding: 16px;
        align-items: flex-start;
        padding-top: 40px;
    }

    .login-box {
        max-width: 100%;
        padding: 32px 24px 28px;
        border-radius: 12px;
    }

    .login-box::before {
        height: 3px;
    }

    .login-header {
        margin-bottom: 28px;
    }

    .login-logo {
        margin-bottom: 20px;
    }

    .login-logo svg {
        width: 48px;
        height: 48px;
    }

    .login-title {
        font-size: 22px;
        margin-bottom: 6px;
    }

    .login-subtitle {
        font-size: 13px;
    }

    .login-form .form-group {
        margin-bottom: 20px;
    }

    .form-label {
        font-size: 14px;
        margin-bottom: 6px;
    }

    .form-input {
        padding: 12px 12px 12px 40px;
        font-size: 16px;
        border-radius: 6px;
    }

    .input-wrapper svg {
        left: 12px;
        width: 14px;
        height: 14px;
    }

    .password-toggle {
        right: 10px;
        padding: 6px;
    }

    .password-toggle svg {
        width: 14px;
        height: 14px;
    }

    .form-actions {
        margin-top: 24px;
    }

    .login-btn {
        padding: 12px;
        font-size: 15px;
        border-radius: 6px;
    }

    .login-footer {
        margin-top: 24px;
    }

    .login-copyright {
        font-size: 11px;
    }

    /* 侧边栏 - 抽屉模式 */
    .sidebar {
        position: fixed;
        top: 0;
        left: -240px;
        width: 240px;
        z-index: 1100;
        height: 100vh;
        transition: left 0.3s ease;
    }

    .sidebar.mobile-open {
        left: 0;
    }

    /* 顶部导航 - 移动端 */
    .header {
        left: 0;
    }

    /* 主内容区 - 移动端 */
    .main-content {
        margin-left: 0;
        width: 100%;
        overflow-x: hidden;
    }

    /* 移动端遮罩 */
    .sidebar-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.45);
        z-index: 1050;
    }

    .sidebar-overlay.show {
        display: block;
    }

    .sidebar.mobile-open + .sidebar-overlay,
    .sidebar-overlay.show {
        display: block;
    }

    .sidebar-header {
        height: 56px;
        font-size: 16px;
    }

    .sidebar-header span,
    .menu-item span,
    .menu-group-title {
        display: inline !important;
    }

    .menu-icon {
        margin-right: 10px;
    }

    /* 侧边栏菜单文字优化 */
    .menu-item {
        padding: 8px 10px;
        font-size: 14px;
    }

    .menu-item span {
        font-size: 14px;
    }

    .menu-group-title {
        font-size: 14px;
        font-weight: 600;
        padding: 8px 10px;
        letter-spacing: 0.5px;
    }

    .menu-group-title .arrow {
        font-size: 10px;
    }

    .sidebar-header {
        height: 56px;
        font-size: 16px;
    }

    /* 头部 */
    .header {
        height: 56px;
        padding: 0 12px;
    }

    .header-right span:first-child {
        display: none;
    }

    .header-right {
        gap: 12px;
    }

    /* 内容区 */
    .content {
        padding: 12px;
        overflow-x: hidden;
    }

    /* 页面头部 */
    .page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        margin-bottom: 16px;
    }

    .page-title {
        font-size: 18px;
        line-height: 1.3;
    }

    .page-actions {
        width: 100%;
        flex-wrap: wrap;
        gap: 8px;
    }

    .page-actions .btn {
        flex: 1;
        min-width: 0;
        text-align: center;
        justify-content: center;
        min-height: 44px;
    }

    /* 搜索栏 - 每行一个元素 */
    .content .search-bar,
    div.search-bar,
    .search-bar {
        display: flex !important;
        flex-direction: column !important;
        flex-wrap: nowrap !important;
        overflow-x: hidden !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch;
        padding: 8px !important;
        gap: 8px !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 100% !important;
        min-height: auto !important;
        box-sizing: border-box !important;
        position: relative !important;
        left: auto !important;
        right: auto !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        transform: none !important;
    }

    .content .search-bar input,
    div.search-bar input,
    .search-bar input {
        flex: none !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        padding: 10px 12px !important;
        font-size: 14px !important;
        box-sizing: border-box !important;
        min-height: 40px !important;
    }

    .content .search-bar select,
    div.search-bar select,
    .search-bar select {
        flex: none !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .content .search-bar .btn,
    div.search-bar .btn,
    .search-bar .btn {
        flex: none !important;
        width: 100% !important;
        padding: 10px 16px !important;
        font-size: 14px !important;
        min-height: 42px !important;
        min-width: 0 !important;
        white-space: nowrap;
        border-radius: 4px;
        text-align: center;
        justify-content: center;
        box-sizing: border-box !important;
    }

    /* 表单容器 */
    .form-container {
        padding: 16px;
    }

    /* 标签栏 */
    .nav-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }

    .nav-tabs li {
        flex-shrink: 0;
    }

    .nav-tabs li a {
        white-space: nowrap;
        padding: 10px 16px;
        font-size: 13px;
    }

    /* 分页组件 */
    .pagination {
        flex-wrap: wrap;
        justify-content: center;
        gap: 8px;
    }

    .pagination > div {
        flex-wrap: wrap;
        justify-content: center !important;
        gap: 6px;
    }

    .pagination .btn {
        min-width: 36px;
        min-height: 36px;
        padding: 6px 10px;
        font-size: 13px;
    }

    .pagination span {
        width: 100%;
        text-align: center;
        margin-bottom: 8px;
    }

    .pagination select {
        min-width: 70px;
        padding: 6px 8px;
        font-size: 13px;
    }

    .form-row {
        grid-template-columns: 1fr;
        gap: 16px;
        margin-bottom: 16px;
    }

    .form-group {
        margin-bottom: 16px;
    }

    .form-group label {
        font-size: 14px;
        margin-bottom: 6px;
    }

    .form-group input,
    .form-group select,
    .form-group textarea {
        padding: 12px 14px;
        font-size: 16px;
        min-height: 44px;
    }

    /* 卡片 */
    .card {
        margin-bottom: 16px;
    }

    .card-header {
        padding: 12px 16px;
    }

    .card-header h3 {
        font-size: 16px;
    }

    .card-body {
        padding: 16px;
    }

    /* 信息卡片 */
    .info-cards {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .info-card {
        padding: 16px;
    }

    .info-card .value {
        font-size: 20px;
    }

    /* 按钮 */
    .btn {
        padding: 10px 16px;
        font-size: 14px;
        min-height: 44px;
    }

    .btn-lg {
        padding: 12px 20px;
        font-size: 16px;
        min-height: 50px;
    }

    .btn-sm {
        padding: 6px 12px;
        font-size: 12px;
        min-height: 36px;
    }

    /* 表格 */
    .table-container {
        margin-bottom: 16px;
    }

    .table th,
    .table td {
        padding: 12px;
        font-size: 13px;
    }

    /* 模态框 */
    .modal-content {
        width: calc(100vw - 32px);
        max-width: 600px;
        min-height: auto;
        max-height: 90vh;
        border-radius: 8px;
        padding: 16px;
        margin: 0;
    }

    .modal-content.modal-small {
        max-width: 260px;
        width: 260px;
    }

    .modal-content.modal-medium {
        max-width: 550px;
        width: calc(100vw - 32px);
    }

    .modal-content.modal-large {
        max-width: 580px;
        width: calc(100vw - 32px);
    }

    .modal-content.modal-xlarge {
        max-width: 1000px;
        width: calc(100vw - 32px);
    }

    .modal-header {
        padding: 12px 0;
    }

    .modal-body {
        padding: 12px 0;
    }

    .modal-footer {
        padding: 12px 16px;
        flex-direction: row !important;
        justify-content: flex-end !important;
        gap: 10px !important;
        flex-wrap: nowrap !important;
    }

    .modal-footer .btn {
        width: auto !important;
        min-width: 70px !important;
        justify-content: center;
    }

    .modal-body h3 {
        font-size: 16px;
        margin-bottom: 16px;
    }

    .modal-body .btn + .btn {
        margin-left: 0;
        margin-top: 8px;
    }

    /* 分页 */
    .pagination {
        gap: 6px;
    }

    .pagination button {
        padding: 6px 12px;
        font-size: 13px;
        min-height: 32px;
        min-width: 32px;
    }

    /* 响应式图片 */
    img {
        max-width: 100%;
        height: auto;
    }

    /* 触控反馈 */
    button,
    a,
    input[type="submit"],
    input[type="button"] {
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
    }

    /* 防止文本溢出 */
    .ellipsis {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    /* 滚动条优化 */
    ::-webkit-scrollbar {
        width: 6px;
        height: 6px;
    }

    ::-webkit-scrollbar-track {
        background: var(--bg-dark);
    }

    ::-webkit-scrollbar-thumb {
        background: var(--border-color);
        border-radius: 3px;
    }

    ::-webkit-scrollbar-thumb:hover {
        background: var(--border-dark);
    }

    /* 表格 - 横向滚动 */
    .table-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        border-radius: 6px;
    }

    .table th,
    .table td {
        padding: 10px 12px;
        font-size: 12px;
        white-space: nowrap;
    }

    .table th {
        font-size: 12px;
    }

    /* 搜索栏 */
    .search-bar {
        flex-direction: column;
        padding: 12px;
    }

    .search-bar input,
    .search-bar select,
    .search-bar .form-control,
    .search-input,
}

/* ==================== 财务管理模块样式 ==================== */

/* 统计卡片 */
.stat-card {
    background: var(--bg-light);
    border-radius: 8px;
    padding: 8px 12px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    box-shadow: var(--shadow-light);
    transition: var(--transition);
    border: 1px solid var(--border-light);
    flex-shrink: 1;
    width: auto;
    white-space: nowrap;
}

.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow);
}

.stat-card.stat-income {
    border-left: 4px solid var(--success-color);
    background: linear-gradient(135deg, #E8F7EE 0%, var(--bg-light) 100%);
}

.stat-card.stat-expense {
    border-left: 4px solid var(--danger-color);
    background: linear-gradient(135deg, #FFF0F0 0%, var(--bg-light) 100%);
}

.stat-card.stat-balance {
    border-left: 4px solid var(--primary-color);
    background: linear-gradient(135deg, #F0F8FF 0%, var(--bg-light) 100%);
}

.stat-card.stat-total {
    border-left: 4px solid #9C27B0;
    background: linear-gradient(135deg, #F8F0FF 0%, var(--bg-light) 100%);
}

.stat-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: var(--white);
    flex-shrink: 0;
}

.stat-card.stat-income .stat-icon {
    background: linear-gradient(135deg, var(--success-color) 0%, #36CFC9 100%);
}

.stat-card.stat-expense .stat-icon {
    background: linear-gradient(135deg, var(--danger-color) 0%, var(--danger-light) 100%);
}

.stat-card.stat-balance .stat-icon {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
}

.stat-card.stat-total .stat-icon {
    background: linear-gradient(135deg, #9C27B0 0%, #B974F0 100%);
}

.stat-content {
    flex: 1;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    flex-wrap: nowrap;
    min-width: 0;
}

.stat-label {
    font-size: 12px;
    color: var(--text-secondary);
    margin: 0;
}

.stat-value {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    line-height: 1.2;
    white-space: nowrap;
}

.stat-change {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 8px;
    font-size: 13px;
}

.stat-sub {
    font-size: 12px;
    color: var(--text-tertiary);
    margin-top: 4px;
}

.stat-card.stat-budget {
    border-left: 4px solid #FF9800;
    background: linear-gradient(135deg, #FFF8F0 0%, var(--bg-light) 100%);
}

.stat-card.stat-budget .stat-icon {
    background: linear-gradient(135deg, #FF9800 0%, #FFB74D 100%);
}

.stat-card.stat-primary {
    border-left: 4px solid var(--primary-color);
    background: linear-gradient(135deg, #F0F8FF 0%, var(--bg-light) 100%);
}

.stat-card.stat-primary .stat-icon {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
}

.stat-card.stat-info {
    border-left: 4px solid #86909C;
    background: linear-gradient(135deg, #F7F8FA 0%, var(--bg-light) 100%);
}

.stat-card.stat-info .stat-icon {
    background: linear-gradient(135deg, #86909C 0%, #C9CDD4 100%);
}

.stat-card.stat-success {
    border-left: 4px solid var(--success-color);
    background: linear-gradient(135deg, #E8F7EE 0%, var(--bg-light) 100%);
}

.stat-card.stat-success .stat-icon {
    background: linear-gradient(135deg, var(--success-color) 0%, #36CFC9 100%);
}

.stat-card.stat-warning {
    border-left: 4px solid var(--warning-color);
    background: linear-gradient(135deg, #FFF8F0 0%, var(--bg-light) 100%);
}

.stat-card.stat-warning .stat-icon {
    background: linear-gradient(135deg, var(--warning-color) 0%, #FFB946 100%);
}

.stat-value.success-text {
    color: var(--success-color);
}

.stat-value.warning-text {
    color: var(--warning-color);
}

.stat-value.danger-text {
    color: var(--danger-color);
}

.stat-change.positive {
    color: var(--success-color);
}

.stat-change.negative {
    color: var(--danger-color);
}

.stat-change span {
    font-weight: 600;
}

.stat-change small {
    color: var(--text-tertiary);
    font-size: 12px;
}

/* 图表占位符 */
.chart-placeholder {
    min-height: 280px;
}

/* 趋势图表 */
.trend-chart .table {
    margin-bottom: 0;
}

.trend-chart .table th,
.trend-chart .table td {
    text-align: center;
    vertical-align: middle;
    padding: 12px 8px;
}

.trend-chart .table th {
    font-weight: 600;
    background: var(--bg-dark);
    color: var(--text-primary);
    border-bottom: 2px solid var(--border-color);
}

.trend-chart .table td {
    font-size: 14px;
}

/* 分类图表 */
.category-chart {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.category-item {
    padding: 16px;
    background: var(--bg-dark);
    border-radius: 8px;
    transition: var(--transition);
}

.category-item:hover {
    background: var(--border-light);
}

.category-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.category-name {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 500;
    color: var(--text-primary);
}

.category-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

.category-amount {
    font-weight: 600;
    color: var(--text-primary);
    font-size: 16px;
}

/* 快速操作按钮 */
.stat-card button.btn {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px;
    border: none;
    transition: var(--transition);
}

.stat-card button.btn:hover {
    transform: scale(1.02);
}

.stat-card button.btn i {
    font-size: 32px;
    margin-bottom: 8px;
}

/* 页面标题 */
.page-header {
    display: none;
}

.page-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 12px;
}

.page-title i {
    color: var(--primary-color);
}

/* 进度条样式 */
.progress {
    background-color: var(--bg-dark);
    border-radius: 4px;
    overflow: hidden;
}

.progress-bar {
    height: 100%;
    border-radius: 4px;
    transition: width 0.5s ease;
}

/* 响应式适配 */
@media (max-width: 768px) {
    .stat-card {
        padding: 16px;
    }
    
    .stat-icon {
        width: 48px;
        height: 48px;
        font-size: 22px;
    }
    
    .stat-value {
        font-size: 22px;
    }
    
    .page-title {
        font-size: 20px;
    }
    
    .trend-chart .table th,
    .trend-chart .table td {
        padding: 8px 4px;
        font-size: 12px;
    }
}

/* ==================== 时间线样式 ==================== */
.timeline {
    position: relative;
    padding-left: 40px;
    padding-top: 8px;
}

.timeline::before {
    content: '';
    position: absolute;
    left: 6px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--primary-color) 0%, var(--border-color) 100%);
    border-radius: 1px;
}

.timeline-item {
    position: relative;
    padding: 16px 20px;
    background: var(--bg-dark);
    border-radius: 12px;
    margin-bottom: 16px;
    border: 1px solid var(--border-light);
    transition: all 0.3s ease;
}

.timeline-item:hover {
    transform: translateX(4px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    border-color: var(--primary-color);
}

.timeline-item:last-child {
    margin-bottom: 0;
}

.timeline-marker {
    position: absolute;
    left: -31px;
    top: 20px;
    width: 14px;
    height: 14px;
    background: var(--primary-color);
    border-radius: 50%;
    border: 3px solid var(--bg-light);
    box-shadow: 0 2px 8px rgba(22, 93, 255, 0.3);
}

.timeline-item:hover .timeline-marker {
    transform: scale(1.2);
    box-shadow: 0 0 12px rgba(22, 93, 255, 0.5);
}

.timeline-content {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.timeline-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.timeline-time {
    font-size: 13px;
    color: var(--text-tertiary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

.timeline-time::before {
    content: '';
    width: 14px;
    height: 14px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2386909C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E") no-repeat center;
    background-size: 14px;
}

.timeline-user {
    font-size: 13px;
    color: var(--text-secondary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

.timeline-user::before {
    content: '';
    width: 14px;
    height: 14px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%234E5969' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'%3E%3C/path%3E%3Ccircle cx='12' cy='7' r='4'%3E%3C/circle%3E%3C/svg%3E") no-repeat center;
    background-size: 14px;
}

.timeline-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-tertiary);
    font-size: 14px;
}

[data-theme="dark"] .timeline::before {
    background: linear-gradient(180deg, var(--primary-color) 0%, var(--border-color) 100%);
}

[data-theme="dark"] .timeline-marker {
    border-color: var(--bg-light);
}

[data-theme="dark"] .timeline-item {
    background: var(--bg-dark);
    border-color: var(--border-color);
}

[data-theme="dark"] .timeline-item:hover {
    border-color: var(--primary-color);
}

[data-theme="dark"] .timeline-title {
    color: var(--text-primary);
}

[data-theme="dark"] .timeline-time {
    color: var(--text-tertiary);
}

[data-theme="dark"] .timeline-user {
    color: var(--text-secondary);
}

/* ==================== 时间线样式结束 ==================== */

/* ==================== 财务管理模块样式结束 ==================== */

/* 财务管理模块加载状态 */
.finance-loading {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 400px;
    width: 100%;
    background: var(--bg-light);
}

.loading-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 40px;
    background: var(--bg-light);
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--border-light);
}

.loading-spinner {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(22, 93, 255, 0.1) 0%, rgba(64, 128, 255, 0.1) 100%);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% {
        transform: scale(1);
        opacity: 1;
    }
    50% {
        transform: scale(1.05);
        opacity: 0.8;
    }
}

.loading-text {
    font-size: 16px;
    color: var(--text-secondary);
    margin: 0;
    font-weight: 500;
}

/* Toastr提示框位置调整 */
#toast-container {
    top: 70px !important;
    right: auto !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
}

#toast-container > div {
    max-width: 380px !important;
    width: 100% !important;
}

/* ==================== 财务管理模块新样式 ==================== */

/* 财务页面容器 */
.finance-page {
    min-height: 100%;
}

/* 页面头部 */
.finance-page .page-header {
    background: linear-gradient(135deg, var(--bg-light) 0%, #F8FAFC 100%);
    padding: 24px 32px;
    border-radius: 16px;
    margin-bottom: 28px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--border-light);
}

.finance-page .header-info {
    flex: 1;
}

.finance-page .page-title {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0 0 8px 0;
    display: flex;
    align-items: center;
    gap: 14px;
}

.finance-page .page-subtitle {
    font-size: 14px;
    color: var(--text-tertiary);
    margin: 0;
}

.finance-page .btn-add {
    padding: 12px 24px;
    font-size: 15px;
    font-weight: 600;
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
}

.finance-page .btn-add:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 180, 42, 0.3);
}

/* 统计卡片网格 */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 20px;
    margin-bottom: 28px;
}

/* 统计卡片 */
.stat-card {
    background: var(--bg-light);
    border-radius: 16px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--border-light);
    transition: all 0.35s ease;
    position: relative;
    overflow: hidden;
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
}

.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);
}

.stat-card.stat-primary::before {
    background: linear-gradient(180deg, var(--success-color) 0%, #36CFC9 100%);
}

.stat-card.stat-danger::before {
    background: linear-gradient(180deg, var(--danger-color) 0%, var(--danger-light) 100%);
}

.stat-card.stat-secondary::before {
    background: linear-gradient(180deg, var(--primary-color) 0%, var(--primary-light) 100%);
}

.stat-card.stat-warning::before {
    background: linear-gradient(180deg, var(--warning-color) 0%, var(--warning-light) 100%);
}

.stat-card.stat-accent::before {
    background: linear-gradient(180deg, #9C27B0 0%, #B974F0 100%);
}

.stat-card.stat-info::before {
    background: linear-gradient(180deg, var(--info-color) 0%, #C9CDD4 100%);
}

.stat-icon-wrap {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    flex-shrink: 0;
    background: var(--bg-dark);
}

.stat-card.stat-primary .stat-icon-wrap {
    background: linear-gradient(135deg, rgba(0, 180, 42, 0.1) 0%, rgba(54, 207, 201, 0.1) 100%);
    color: var(--success-color);
}

.stat-card.stat-danger .stat-icon-wrap {
    background: linear-gradient(135deg, rgba(245, 63, 63, 0.1) 0%, rgba(255, 120, 117, 0.1) 100%);
    color: var(--danger-color);
}

.stat-card.stat-secondary .stat-icon-wrap {
    background: linear-gradient(135deg, rgba(22, 93, 255, 0.1) 0%, rgba(64, 128, 255, 0.1) 100%);
    color: var(--primary-color);
}

.stat-card.stat-warning .stat-icon-wrap {
    background: linear-gradient(135deg, rgba(255, 125, 0, 0.1) 0%, rgba(255, 185, 70, 0.1) 100%);
    color: var(--warning-color);
}

.stat-card.stat-accent .stat-icon-wrap {
    background: linear-gradient(135deg, rgba(156, 39, 176, 0.1) 0%, rgba(185, 116, 240, 0.1) 100%);
    color: #9C27B0;
}

.stat-card.stat-info .stat-icon-wrap {
    background: linear-gradient(135deg, rgba(134, 144, 156, 0.1) 0%, rgba(201, 205, 212, 0.1) 100%);
    color: var(--info-color);
}

.stat-info {
    flex: 1;
    min-width: 0;
}

.stat-label {
    font-size: 13px;
    color: var(--text-tertiary);
    margin: 0 0 6px 0;
    font-weight: 500;
}

.stat-amount {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
    line-height: 1.2;
}

.stat-trend {
    font-size: 20px;
    flex-shrink: 0;
}

.stat-trend.positive {
    color: var(--success-color);
}

.stat-trend.negative {
    color: var(--danger-color);
}

/* 内容盒子 */
.content-box {
    background: var(--bg-light);
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--border-light);
    overflow: hidden;
}

/* 盒子头部 */
.box-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-light);
    background: linear-gradient(90deg, var(--bg-dark) 0%, transparent 100%);
}

.box-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-light);
}

.box-actions {
    display: flex;
    gap: 8px;
}

.box-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.box-title i {
    color: var(--primary-color);
}

.box-actions {
    display: flex;
    gap: 8px;
}

.box-actions .btn {
    padding: 5px 10px;
    font-size: 12px;
    min-height: auto;
    min-width: auto;
    border-radius: 4px;
}

.box-actions .btn i {
    font-size: 11px;
}

/* 筛选区域 */
.filter-section {
    padding: 14px 20px;
    border-bottom: 1px solid var(--border-light);
    background: var(--bg-dark);
}

.filter-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 12px;
}

.filter-item {
    flex: 1;
    min-width: 130px;
    max-width: 180px;
}

.filter-item label {
    display: block;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.filter-select,
.filter-input {
    width: 100%;
    padding: 6px 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-size: 13px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: all 0.25s ease;
    outline: none;
}

.filter-select:focus,
.filter-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

.filter-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

.filter-actions .btn {
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 13px;
    min-width: auto;
    min-height: auto;
}

.filter-actions .btn i {
    font-size: 12px;
}

.btn-outline {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
}

.btn-outline:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
}

/* 表格包装器 */
.table-wrapper {
    padding: 16px 24px;
    overflow-x: auto;
}

/* 财务表格 */
.finance-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 700px;
}

.finance-table th {
    background: var(--bg-dark);
    padding: 14px 16px;
    text-align: left;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
    white-space: nowrap;
    position: relative;
}

.finance-table th:first-child {
    border-radius: 10px 0 0 0;
}

.finance-table th:last-child {
    border-radius: 0 10px 0 0;
}

.finance-table td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-light);
    font-size: 14px;
    color: var(--text-primary);
    white-space: nowrap;
}

.finance-table .btn {
    padding: 4px 8px;
    font-size: 12px;
    min-height: auto;
    min-width: auto;
    border-radius: 4px;
}

.finance-table .btn i {
    font-size: 11px;
}

.table-row {
    transition: background 0.2s ease;
}

.table-row:hover {
    background: var(--bg-dark);
}

/* 表格单元格 */
.date-cell {
    position: relative;
}

.date-badge {
    display: inline-block;
    padding: 6px 12px;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
    color: white;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
}

.category-cell {
    padding-left: 0;
}

.category-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: var(--bg-dark);
    border-radius: 8px;
    font-size: 13px;
    color: var(--text-secondary);
    transition: all 0.2s ease;
}

.category-tag:hover {
    background: var(--border-color);
}

.tag-icon {
    font-size: 16px;
}

.account-cell {
    color: var(--text-secondary);
}

.amount-cell {
    font-weight: 600;
    text-align: right;
}

.income-amount {
    color: var(--success-color);
}

.expense-amount {
    color: var(--danger-color);
}

.desc-cell {
    color: var(--text-secondary);
    max-width: 200px;
    white-space: normal;
    word-break: break-all;
}

.text-muted {
    color: var(--text-quaternary);
}

.action-cell {
    text-align: center;
}

.action-buttons {
    display: flex;
    justify-content: center;
    gap: 6px;
}

.action-btn {
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.25s ease;
}

.action-btn.edit {
    background: rgba(22, 93, 255, 0.1);
    color: var(--primary-color);
}

.action-btn.edit:hover {
    background: var(--primary-color);
    color: white;
    transform: translateY(-1px);
}

.action-btn.delete {
    background: rgba(245, 63, 63, 0.1);
    color: var(--danger-color);
}

.action-btn.delete:hover {
    background: var(--danger-color);
    color: white;
    transform: translateY(-1px);
}

/* 空状态 */
.empty-state {
    padding: 60px 20px;
    text-align: center;
    background: var(--bg-dark);
    border-radius: 12px;
}

.empty-state i {
    font-size: 48px;
    color: var(--text-quaternary);
    margin-bottom: 16px;
    display: block;
}

.empty-state p {
    font-size: 15px;
    color: var(--text-tertiary);
    margin: 0 0 20px 0;
}

.empty-state .btn {
    padding: 10px 24px;
    border-radius: 8px;
    font-weight: 600;
}

/* 分页包装器 */
.pagination-wrapper {
    padding: 20px 24px;
    border-top: 1px solid var(--border-light);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}

.pagination-wrapper span {
    color: var(--text-secondary);
    font-size: 14px;
}

/* 分页列表 */
.pagination-list {
    display: flex;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 4px;
}

/* 分页链接 */
.page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 12px;
    border: 1px solid var(--border-light);
    border-radius: 6px;
    background: var(--bg-primary);
    color: var(--text-primary);
    text-decoration: none;
    font-size: 14px;
    transition: all 0.2s ease;
}

.page-link:hover:not(.disabled) {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: var(--primary-light);
}

.page-link.active {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: #fff;
}

.page-link.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* ==================== 设计管理模块样式 ==================== */

/* 表单布局 */
.form-layout {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* 表单行 - 两列布局 */
.form-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
}

/* 表单组 */
.form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* 表单标签 */
.form-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 6px;
}

.form-label i {
    color: var(--primary-color);
    font-size: 14px;
}

/* 必填标记 */
.form-label .required {
    color: var(--danger-color);
    font-weight: bold;
}

/* 表单输入框 */
.form-input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: all 0.25s ease;
    outline: none;
    box-sizing: border-box;
}

.form-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 4px rgba(22, 93, 255, 0.1);
}

.form-input::placeholder {
    color: var(--text-quaternary);
}

/* 只读输入框 */
.form-input.form-input-readonly {
    background: var(--bg-dark);
    color: var(--text-tertiary);
    cursor: not-allowed;
}

/* 表单选择框 */
.form-select {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: all 0.25s ease;
    outline: none;
    cursor: pointer;
    box-sizing: border-box;
}

.form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 4px rgba(22, 93, 255, 0.1);
}

/* 表单文本域 */
.form-textarea {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: all 0.25s ease;
    outline: none;
    resize: vertical;
    min-height: 80px;
    box-sizing: border-box;
}

.form-textarea:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 4px rgba(22, 93, 255, 0.1);
}

.form-textarea::placeholder {
    color: var(--text-quaternary);
}

/* 模态框头部优化 */
.modal-header {
    padding: 20px 24px;
    background: linear-gradient(135deg, rgba(22, 93, 255, 0.03) 0%, rgba(0, 180, 42, 0.02) 100%);
    border-bottom: 1px solid var(--border-light);
}

.modal-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 10px;
}

.modal-title i {
    font-size: 20px;
}

/* 模态框主体 */
.modal-body {
    padding: 24px;
    overflow-y: auto;
    height: calc(100% - 80px);
    min-height: 0;
}

/* 模态框底部 */
.modal-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--border-light);
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    background: var(--bg-dark);
}

/* 按钮优化 */
.btn-cancel {
    background: var(--bg-dark);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    padding: 12px 24px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    transition: all 0.25s ease;
    display: flex;
    align-items: center;
    gap: 8px;
}

.btn-cancel:hover {
    background: var(--border-light);
    color: var(--text-primary);
}

.btn-save {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
    border: none;
    color: white;
    padding: 12px 28px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    transition: all 0.25s ease;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 4px 12px rgba(22, 93, 255, 0.2);
}

.btn-save:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(22, 93, 255, 0.3);
}

.btn-save:active {
    transform: translateY(0);
}

/* 大模态框优化 */
.modal-content.modal-large {
    max-width: 700px;
    width: 85%;
    border-radius: 16px;
    overflow: hidden;
}

/* ==================== 设计详情样式 ==================== */

/* 详情卡片 */
.detail-card {
    background: var(--bg-light);
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 20px;
    border: 1px solid var(--border-light);
}

/* 详情头部 */
.detail-header {
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border-light);
}

.detail-title-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.detail-code {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
    color: white;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
}

.detail-status {
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
}

.detail-status.badge-default {
    background: rgba(108, 117, 125, 0.1);
    color: var(--text-tertiary);
}

.detail-status.badge-primary {
    background: rgba(22, 93, 255, 0.1);
    color: var(--primary-color);
}

.detail-status.badge-success {
    background: rgba(0, 180, 42, 0.1);
    color: var(--success-color);
}

.detail-status.badge-danger {
    background: rgba(245, 63, 63, 0.1);
    color: var(--danger-color);
}

.detail-name {
    font-size: 22px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
}

/* 详情信息网格 */
.detail-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.detail-info-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px 16px;
    background: var(--bg-dark);
    border-radius: 10px;
}

.detail-info-item i {
    color: var(--primary-color);
    font-size: 14px;
}

.detail-info-item .detail-label {
    font-size: 12px;
    color: var(--text-tertiary);
    font-weight: 500;
}

.detail-info-item .detail-value {
    font-size: 14px;
    color: var(--text-primary);
    font-weight: 600;
}

/* 详情统计 */
.detail-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

.stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
    background: linear-gradient(135deg, rgba(22, 93, 255, 0.03) 0%, rgba(0, 180, 42, 0.02) 100%);
    border-radius: 12px;
    border: 1px solid var(--border-light);
}

.stat-item i {
    font-size: 24px;
    color: var(--primary-color);
    margin-bottom: 8px;
}

.stat-item .stat-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary);
}

.stat-item .stat-label {
    font-size: 13px;
    color: var(--text-tertiary);
}

/* 详情备注 */
.detail-remark {
    padding: 16px;
    background: var(--bg-dark);
    border-radius: 10px;
    border-left: 4px solid var(--primary-color);
}

.detail-remark i {
    color: var(--primary-color);
    margin-right: 8px;
}

.detail-remark .detail-label {
    font-size: 13px;
    color: var(--text-secondary);
    font-weight: 600;
    margin-right: 8px;
}

.detail-remark p {
    margin: 8px 0 0 0;
    color: var(--text-primary);
    line-height: 1.6;
}

/* 详情区域 */
.detail-section {
    background: var(--bg-light);
    border-radius: 12px;
    padding: 20px;
    border: 1px solid var(--border-light);
    margin-bottom: 16px;
}

.detail-section:last-child {
    margin-bottom: 0;
}

.section-title {
    margin: 0 0 16px 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-light);
}

.section-title i {
    color: var(--primary-color);
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.detail-item .label {
    font-size: 13px;
    color: var(--text-muted);
    font-weight: 500;
}

.detail-item .value {
    font-size: 14px;
    color: var(--text-primary);
    font-weight: 500;
}

.detail-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.detail-table th,
.detail-table td {
    padding: 12px;
    text-align: left;
    border-bottom: 1px solid var(--border-light);
}

.detail-table th {
    background: var(--bg-dark);
    font-weight: 600;
    color: var(--text-primary);
}

.detail-table tr:hover td {
    background: var(--bg-dark);
}

.order-link {
    color: var(--primary-color);
    text-decoration: none;
    padding: 4px 8px;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.order-link:hover {
    background: var(--primary-color);
    color: white;
}

.sample-count-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 28px;
    padding: 0 10px;
    background: #e0f2fe;
    color: #0284c7;
    border-radius: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.sample-count-link:hover {
    background: #0ea5e9;
    color: white;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
}

.status-approved {
    background: #d1fae5;
    color: #065f46;
}

.status-approved i {
    color: #10b981;
}

.status-pending {
    background: #fef3c7;
    color: #92400e;
}

.status-pending i {
    color: #f59e0b;
}

.batch-action-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 16px;
    background: var(--bg-light);
    border: 1px solid var(--border-light);
    border-bottom: none;
    border-radius: 8px 8px 0 0;
    font-size: 14px;
}

.batch-action-bar span {
    color: var(--text-muted);
}

.batch-action-bar strong {
    color: var(--primary-color);
    font-weight: 600;
}

.col-checkbox {
    width: 40px;
    text-align: center;
}

.checkbox-cell {
    text-align: center;
}

input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--primary-color);
}

.import-modal {
    padding: 0;
}

.import-tabs {
    display: flex;
    border-bottom: 1px solid var(--border-light);
    margin-bottom: 20px;
}

.import-tabs .tab-btn {
    flex: 1;
    padding: 12px;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 14px;
    color: var(--text-muted);
    transition: all 0.2s ease;
}

.import-tabs .tab-btn:hover {
    color: var(--primary-color);
}

.import-tabs .tab-btn.active {
    color: var(--primary-color);
    border-bottom: 2px solid var(--primary-color);
}

.import-content {
    padding: 0 10px;
}

.upload-zone {
    border: 2px dashed var(--border-color);
    border-radius: 12px;
    padding: 40px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    background: var(--bg-light);
}

.upload-zone:hover {
    border-color: var(--primary-color);
    background: rgba(74, 144, 226, 0.05);
}

.upload-icon {
    font-size: 48px;
    color: var(--text-muted);
    margin-bottom: 16px;
}

.upload-text {
    font-size: 16px;
    color: var(--text-primary);
    margin-bottom: 8px;
}

.upload-hint {
    font-size: 13px;
    color: var(--text-muted);
}

.file-info {
    background: var(--bg-light);
    border-radius: 12px;
    padding: 20px;
}

.file-details {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.file-icon {
    font-size: 32px;
    color: #217346;
}

.file-meta {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.file-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-primary);
}

.file-size {
    font-size: 12px;
    color: var(--text-muted);
}

.import-progress {
    padding: 20px;
    text-align: center;
}

.progress-bar-wrap {
    height: 8px;
    background: var(--bg-dark);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 12px;
}

.progress-bar {
    height: 100%;
    background: var(--primary-color);
    border-radius: 4px;
    transition: width 0.3s ease;
    width: 0%;
}

.progress-text {
    font-size: 14px;
    color: var(--text-muted);
    margin: 0;
}

.import-result {
    padding: 20px;
}

.result-summary {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin-bottom: 20px;
}

.result-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.result-item i {
    font-size: 32px;
}

.result-item span {
    font-size: 24px;
    font-weight: 600;
}

.result-item label {
    font-size: 13px;
    color: var(--text-muted);
}

.result-success i,
.result-success span {
    color: #10b981;
}

.result-error i,
.result-error span {
    color: #ef4444;
}

.result-errors {
    max-height: 200px;
    overflow-y: auto;
    background: var(--bg-light);
    border-radius: 8px;
    padding: 16px;
}

.result-errors h4 {
    margin: 0 0 12px 0;
    font-size: 14px;
    color: var(--text-primary);
}

.result-errors ul {
    margin: 0;
    padding-left: 20px;
}

.result-errors li {
    font-size: 13px;
    color: var(--text-muted);
    margin-bottom: 4px;
}

.template-download {
    text-align: center;
    padding: 16px;
    font-size: 13px;
    color: var(--text-muted);
}

.template-download a {
    color: var(--primary-color);
    text-decoration: none;
}

.template-download a:hover {
    text-decoration: underline;
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-light);
}

.section-header h4 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.section-header h4 i {
    color: var(--primary-color);
}

/* 产品网格 */
.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}

/* 产品卡片 */
.product-card {
    background: var(--bg-dark);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-light);
    transition: all 0.25s ease;
}

.product-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
    border-color: var(--border-color);
}

.product-header {
    padding: 12px 16px;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
}

.product-code {
    color: white;
    font-size: 12px;
    font-weight: 600;
}

.product-name {
    margin: 0;
    padding: 12px 16px;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-light);
}

/* 产品图片 */
.product-images {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4px;
    padding: 8px;
    min-height: 100px;
}

.image-wrapper {
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 6px;
}

.product-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer;
    transition: transform 0.25s ease;
}

.product-image:hover {
    transform: scale(1.05);
}

.no-image {
    grid-column: span 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--text-quaternary);
    gap: 8px;
}

.no-image i {
    font-size: 24px;
}

.no-image span {
    font-size: 12px;
}

.image-more {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0, 0, 0, 0.6);
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    cursor: pointer;
}

/* 产品底部 */
.product-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px;
    border-top: 1px solid var(--border-light);
}

.product-category {
    font-size: 12px;
    color: var(--text-tertiary);
    padding: 4px 10px;
    background: var(--bg-light);
    border-radius: 12px;
}

.product-actions {
    display: flex;
    gap: 6px;
}

/* 产品操作按钮 */
.action-btn {
    padding: 6px 12px;
    border: none;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
}

.action-edit {
    background: rgba(22, 93, 255, 0.1);
    color: var(--primary-color);
}

.action-edit:hover {
    background: var(--primary-color);
    color: white;
}

.action-delete {
    background: rgba(245, 63, 63, 0.1);
    color: var(--danger-color);
}

.action-delete:hover {
    background: var(--danger-color);
    color: white;
}

/* 空产品状态 */
.empty-product {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 40px 20px;
    color: var(--text-tertiary);
}

.empty-product i {
    font-size: 48px;
    margin-bottom: 16px;
}

.empty-product p {
    margin: 0 0 16px 0;
    font-size: 15px;
}

.empty-product.error {
    color: var(--danger-color);
}

.empty-product.error i {
    font-size: 36px;
}

/* ==================== 入库单样式 ==================== */

/* 表单网格布局 */
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}

/* 表单组美化 */
.form-group {
    margin-bottom: 16px;
}

.form-group label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
}

.form-group label i {
    margin-right: 6px;
    color: var(--primary-color);
}

.form-group label .required {
    color: var(--danger-color);
    margin-left: 4px;
}

/* 表单控件美化 */
.form-control {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    font-size: 14px;
    background: var(--bg-dark);
    color: var(--text-primary);
    transition: all 0.2s ease;
}

.form-control:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

.form-control::placeholder {
    color: var(--text-quaternary);
}

.form-control:disabled {
    background: var(--bg-light);
    color: var(--text-tertiary);
    cursor: not-allowed;
}

/* 表单区域 */
.form-section {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--border-light);
}

.form-section .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.form-section h4 {
    margin: 0;
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.form-section h4 i {
    color: var(--primary-color);
}

/* 羽绒管理表单区块样式 */
.down-form-section {
    margin-bottom: 20px;
    padding: 16px;
    background: var(--bg-color);
    border-radius: 10px;
    border: 1px solid var(--border-light);
}

.down-form-section:last-child {
    margin-bottom: 0;
}

.down-section-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-light);
    display: flex;
    align-items: center;
    gap: 8px;
}

.down-section-title i {
    color: var(--primary-color);
    font-size: 15px;
}

/* 表格包装器 */
.table-wrapper {
    overflow-x: auto;
    border-radius: 10px;
    border: 1px solid var(--border-light);
}

/* 财务表格 */
.finance-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.finance-table thead {
    background: #FFFFFF;
    border-bottom: 2px solid #2d51a7;
}

.finance-table thead th {
    padding: 12px 14px;
    text-align: left;
    color: #2d51a7;
    font-weight: 600;
    white-space: nowrap;
}

.finance-table tbody td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--border-light);
    color: var(--text-primary);
}

.finance-table tbody tr:hover {
    background: rgba(22, 93, 255, 0.03);
}

.finance-table tbody tr:last-child td {
    border-bottom: none;
}

/* 模态框头部 */
.modal-header {
    padding: 20px 24px;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
    border-radius: 12px 12px 0 0;
}

.modal-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: white;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* 模态框主体 */
.modal-body {
    padding: 20px 24px;
    overflow-y: auto;
    height: calc(100% - 80px);
    min-height: 0;
}

/* 模态框底部 */
.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 16px 24px;
    background: var(--bg-dark);
    border-radius: 0 0 12px 12px;
    border-top: 1px solid var(--border-light);
}

/* 按钮样式 */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-primary {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
    color: white;
}

.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(22, 93, 255, 0.3);
}

.btn-secondary {
    background: var(--bg-light);
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
}

.btn-secondary:hover {
    background: var(--border-color);
}

.btn-success {
    background: linear-gradient(135deg, var(--success-color) 0%, #00c851 100%);
    color: white;
}

.btn-success:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 180, 42, 0.3);
}

.btn-danger {
    background: linear-gradient(135deg, var(--danger-color) 0%, #ff4444 100%);
    color: white;
}

.btn-danger:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(245, 63, 63, 0.3);
}

.btn-danger.disabled-btn,
.btn-danger[disabled] {
    background: var(--text-quaternary) !important;
    cursor: not-allowed;
    opacity: 0.6;
    pointer-events: none;
}

.btn-sm {
    padding: 6px 12px;
    font-size: 12px;
}

/* 金额显示 */
.item-amount {
    font-weight: 600;
    color: var(--primary-color);
}

/* 响应式适配 */
@media (max-width: 768px) {
    .finance-page .page-header {
        padding: 20px 16px;
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }
    
    .finance-page .page-title {
        font-size: 22px;
    }

    .finance-page .btn-add {
        width: 100%;
        justify-content: center;
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .stat-card {
        padding: 16px;
    }

    .stat-icon-wrap {
        width: 44px;
        height: 44px;
        font-size: 20px;
    }

    .stat-amount {
        font-size: 22px;
    }

    .filter-row {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-item {
        max-width: 100%;
    }

    .filter-actions {
        width: 100%;
    }

    .filter-actions .btn {
        flex: 1;
    }

    .box-header-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .box-actions {
        width: 100%;
    }

    .box-actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .form-row {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    
    .modal-body {
        padding: 16px;
    }
    
    .modal-header {
        padding: 16px;
    }
    
    .modal-footer {
        padding: 12px 16px;
        flex-direction: row;
        justify-content: flex-end;
        gap: 10px;
        flex-wrap: nowrap;
    }
    
    .modal-footer .btn {
        width: auto;
        min-width: 70px;
    }
}

@media (max-width: 480px) {
    .stats-grid {
        grid-template-columns: 1fr;
    }

    .stat-card {
        padding: 14px;
    }

    .stat-amount {
        font-size: 24px;
    }
}

/* 网格布局 */
.grid-2-col {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

.grid-3-col {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.grid-4-col {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.col-span-2 {
    grid-column: span 2;
}

/* 间距工具类 */
.gap-3 {
    gap: 12px;
}

/* 间距工具类 */
.mt-4 {
    margin-top: 24px;
}

/* 文本颜色工具类 */
.text-green {
    color: var(--success-color);
}

.text-red {
    color: var(--danger-color);
}

.text-info {
    color: var(--primary-color);
}

.text-accent {
    color: var(--accent-color);
}

.text-warning {
    color: var(--warning-color);
}

/* 分类列表样式 */
.category-list {
    padding: 8px;
}

.category-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    background: var(--bg-dark);
    border-radius: 10px;
    margin-bottom: 10px;
    transition: all 0.25s ease;
}

.category-item:hover {
    background: var(--bg-hover);
    transform: translateX(4px);
}

/* ==================== 订单管理模块样式 ==================== */

/* 信息卡片 */
.info-box {
    background: var(--bg-dark);
    border-radius: 10px;
    padding: 14px 16px;
    border: 1px solid var(--border-light);
    transition: all 0.25s ease;
}

.info-box:hover {
    box-shadow: var(--shadow-light);
}

.info-box.highlight {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0.05) 100%);
    border-color: var(--warning-color);
}

.info-label {
    font-size: 12px;
    color: var(--text-tertiary);
    margin-bottom: 6px;
    font-weight: 500;
}

.info-value {
    font-size: 15px;
    color: var(--text-primary);
    font-weight: 600;
}

/* 订单状态样式 */
.order-status {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    text-align: center;
    min-width: 70px;
}

.order-status.pending {
    background: rgba(255, 193, 7, 0.1);
    color: var(--warning-color);
    border: 1px solid rgba(255, 193, 7, 0.3);
}

.order-status.approved {
    background: rgba(0, 180, 42, 0.1);
    color: var(--success-color);
    border: 1px solid rgba(0, 180, 42, 0.3);
}

.order-status.delivered {
    background: rgba(64, 128, 255, 0.1);
    color: var(--primary-color);
    border: 1px solid rgba(64, 128, 255, 0.3);
}

.order-status.paid {
    background: rgba(156, 39, 176, 0.1);
    color: #9C27B0;
    border: 1px solid rgba(156, 39, 176, 0.3);
}

.order-status.completed {
    background: rgba(32, 201, 151, 0.1);
    color: #20c997;
    border: 1px solid rgba(32, 201, 151, 0.3);
}

.order-status.cancelled {
    background: rgba(245, 63, 63, 0.1);
    color: var(--danger-color);
    border: 1px solid rgba(245, 63, 63, 0.3);
}

/* 订单表格 */
.order-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-light);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--shadow-light);
}

.order-table th {
    background: var(--primary-color);
    color: var(--white);
    padding: 14px 16px;
    text-align: left;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
}

.order-table td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-light);
    font-size: 14px;
    color: var(--text-primary);
    white-space: nowrap;
}

.order-table tr:hover td {
    background: var(--bg-dark);
}

.order-table tr:last-child td {
    border-bottom: none;
}

/* 订单操作按钮组 */
.order-actions {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

/* 订单明细表格 */
.order-detail-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-light);
    border-radius: 10px;
    overflow: hidden;
}

.order-detail-table th {
    background: var(--bg-dark);
    color: var(--text-secondary);
    padding: 12px 14px;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    border-bottom: 2px solid var(--border-color);
}

.order-detail-table td {
    padding: 12px 14px;
    text-align: center;
    font-size: 13px;
    border-bottom: 1px solid var(--border-light);
}

.order-detail-table .price-cell {
    color: var(--primary-color);
    font-weight: 600;
}

/* 订单统计卡片 */
.order-stat-card {
    background: var(--bg-light);
    border-radius: 12px;
    padding: 20px;
    box-shadow: var(--shadow-light);
    border: 1px solid var(--border-light);
}

.order-stat-card .stat-label {
    font-size: 13px;
    color: var(--text-tertiary);
    margin-bottom: 8px;
}

.order-stat-card .stat-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
}

.order-stat-card.highlight .stat-value {
    color: var(--primary-color);
}

/* 深色模式适配 */
[data-theme="dark"] .info-box {
    background: var(--bg-light);
    border-color: var(--border-color);
}

[data-theme="dark"] .info-box.highlight {
    background: rgba(255, 193, 7, 0.15);
    border-color: var(--warning-color);
}

[data-theme="dark"] .info-label {
    color: var(--text-tertiary);
}

[data-theme="dark"] .info-value {
    color: var(--text-primary);
}

[data-theme="dark"] .order-table {
    background: var(--bg-light);
}

[data-theme="dark"] .order-table td {
    border-bottom-color: var(--border-color);
}

[data-theme="dark"] .order-table tr:hover td {
    background: var(--bg-dark);
}

[data-theme="dark"] .order-detail-table {
    background: var(--bg-light);
}

[data-theme="dark"] .order-detail-table th {
    background: var(--bg-dark);
    color: var(--text-primary);
    border-bottom-color: var(--border-color);
}

[data-theme="dark"] .order-detail-table td {
    border-bottom-color: var(--border-color);
}

[data-theme="dark"] .order-stat-card {
    background: var(--bg-light);
    border-color: var(--border-color);
}

.category-info {
    display: flex;
    align-items: center;
    gap: 10px;
}

.category-icon {
    font-size: 20px;
}

.category-name {
    font-weight: 500;
    color: var(--text-primary);
}

.category-stats {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.category-amount {
    font-weight: 600;
    color: var(--text-primary);
    font-size: 16px;
}

.category-percent {
    font-size: 13px;
    color: var(--text-tertiary);
}

/* 按钮小型样式 */
.btn-sm {
    padding: 8px 16px;
    font-size: 14px;
    min-height: 36px;
}

/* 响应式网格适配 */
@media (max-width: 1024px) {
    .grid-3-col {
        grid-template-columns: 1fr;
    }
    
    .col-span-2 {
        grid-column: span 1;
    }
}

@media (max-width: 768px) {
    .grid-2-col {
        grid-template-columns: 1fr;
    }
}

/* ==================== 财务管理模块新样式结束 ==================== */
.search-select {
        width: 100%;
        min-width: 0 !important;
        flex: 1 1 auto !important;
        padding: 10px 12px !important;
        font-size: 14px !important;
        min-height: 40px !important;
    }

    .search-bar select.form-control {
        flex: 1;
    }

    /* 移动端按钮布局 */
    .search-bar .btn {
        width: 100%;
        min-height: 40px !important;
        align-self: stretch !important;
        margin-left: 0 !important;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    /* 调整按钮顺序和间距 */
    .search-bar {
        flex-direction: column;
        gap: 8px;
    }

    /* 为按钮组添加特殊处理 */
    .search-bar button {
        width: 100%;
    }

    /* 导出按钮组特殊处理 */
    .search-bar button#exportSampleBtn {
        order: 10;
    }

    .search-bar button#exportSettingsBtn {
        order: 11;
    }

    /* 表单 */
    .form-container {
        padding: 16px;
    }

    .form-row {
        grid-template-columns: 1fr;
        gap: 0;
        margin-bottom: 0;
    }

    .form-group {
        margin-bottom: 16px;
    }

    .form-group input,
    .form-group select,
    .form-group textarea {
        padding: 10px 12px;
        font-size: 16px; /* 防止iOS缩放 */
    }

    /* 表单网格 */
    .form-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    /* 模态框 */
    .modal-content {
        width: calc(100vw - 32px);
        max-width: 600px;
        min-height: auto;
        max-height: 90vh;
        border-radius: 8px;
        padding: 16px;
        margin: 0;
    }

    .modal-content.modal-small {
        max-width: 260px;
        width: 260px;
    }

    .modal-content.modal-medium {
        max-width: 550px;
        width: calc(100vw - 32px);
    }

    .modal-content.modal-large {
        max-width: 580px;
        width: calc(100vw - 32px);
    }

    .modal-content.modal-xlarge {
        max-width: 1000px;
        width: calc(100vw - 32px);
    }

    .modal-header {
        padding: 12px 0;
    }

    .modal-body {
        padding: 12px 0;
    }

    .modal-footer {
        padding: 12px 16px;
        flex-direction: row;
        justify-content: flex-end;
        gap: 10px;
        flex-wrap: nowrap;
    }

    .modal-footer .btn {
        width: auto;
        min-width: 70px;
        justify-content: center;
    }

    .modal-body h3 {
        font-size: 16px;
        margin-bottom: 16px;
    }

    .modal-body .btn + .btn {
        margin-left: 0;
    }

    /* 按钮 */
    .btn {
        padding: 8px 12px;
        font-size: 13px;
    }

    .btn-lg {
        padding: 10px 16px;
        font-size: 14px;
    }

    .btn-sm {
        padding: 4px 8px;
        font-size: 11px;
    }

    /* 信息卡片 */
    .info-cards {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .info-card {
        padding: 14px 12px;
    }

    .info-card h4 {
        font-size: 11px;
    }

    .info-card .value {
        font-size: 18px;
    }

    /* 配置项 */
    .config-group {
        padding: 16px;
        margin-bottom: 12px;
    }

    .config-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }

    .config-item label {
        min-width: auto;
        font-size: 13px;
    }

    .config-item input[type="text"],
    .config-item textarea,
    .config-item select {
        max-width: 100%;
        width: 100%;
    }

    /* 系统设置配置网格 */
    .config-grid {
        grid-template-columns: 1fr !important;
    }

    /* 分页 */
    .pagination {
        flex-wrap: wrap;
        gap: 6px;
    }

    .pagination button {
        padding: 6px 10px;
        font-size: 12px;
        min-width: 32px;
        text-align: center;
    }

    /* 权限管理页面 */
    .permissions-page .page-header {
        flex-direction: column;
    }

    /* 表格内按钮 */
    .data-table .btn + .btn {
        margin-left: 4px;
    }

    /* 错误提示容器 */
    #error-container {
        top: 10px;
        right: 10px;
        left: 10px;
        max-width: none;
        padding: 12px;
        font-size: 13px;
    }
}

/* 中等屏幕手机 481px ~ 768px */
@media (min-width: 481px) and (max-width: 768px) {
    /* 登录页 */
    .login-container {
        padding: 20px;
    }

    .login-box {
        width: 100%;
        max-width: 420px;
        padding: 36px 28px 28px;
        border-radius: 10px;
    }

    .login-header {
        margin-bottom: 28px;
    }

    .login-logo {
        margin-bottom: 20px;
    }

    .login-logo svg {
        width: 52px;
        height: 52px;
    }

    .login-title {
        font-size: 24px;
        margin-bottom: 6px;
    }

    .login-subtitle {
        font-size: 14px;
    }

    .login-form .form-group {
        margin-bottom: 20px;
    }

    .form-input {
        padding: 13px 13px 13px 42px;
        border-radius: 7px;
    }

    .form-actions {
        margin-top: 28px;
    }

    .login-btn {
        padding: 13px;
        border-radius: 7px;
    }

    .login-footer {
        margin-top: 28px;
    }

    /* 侧边栏 - 抽屉模式 */
    .sidebar {
        position: fixed;
        top: 0;
        left: -240px;
        width: 240px;
        z-index: 1100;
        height: 100vh;
        transition: left 0.3s ease;
    }

    .sidebar.mobile-open {
        left: 0;
    }

    .sidebar-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.45);
        z-index: 1050;
    }

    .sidebar-overlay.show {
        display: block;
    }

    .sidebar-header span,
    .menu-item span,
    .menu-group-title {
        display: inline !important;
    }

    .menu-icon {
        margin-right: 10px;
    }

    /* 侧边栏菜单文字优化 */
    .menu-item {
        padding: 8px 10px;
        font-size: 14px;
    }

    .menu-item span {
        font-size: 14px;
    }

    .menu-group-title {
        font-size: 14px;
        font-weight: 600;
        padding: 8px 10px;
        letter-spacing: 0.5px;
    }

    .menu-group-title .arrow {
        font-size: 10px;
    }

    .sidebar-header {
        height: 56px;
        font-size: 16px;
    }

    /* 顶部导航 - 移动端 */
    .header {
        left: 0;
    }

    /* 主内容区 - 移动端 */
    .main-content {
        margin-left: 0;
        width: 100%;
        overflow-x: hidden;
    }

    /* 内容区 */
    .content {
        padding: 16px;
        overflow-x: hidden;
    }

    /* 标签栏 */
    .nav-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }

    .nav-tabs li {
        flex-shrink: 0;
    }

    .nav-tabs li a {
        white-space: nowrap;
        padding: 10px 16px;
        font-size: 13px;
    }

    /* 页面头部 */
    .page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .page-actions {
        width: 100%;
        flex-wrap: wrap;
    }

    /* 搜索栏 - 每行一个元素 */
    .content .search-bar,
    div.search-bar,
    .search-bar {
        display: flex !important;
        flex-direction: column !important;
        flex-wrap: nowrap !important;
        overflow-x: hidden !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch;
        padding: 10px !important;
        gap: 8px !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 100% !important;
        min-height: auto !important;
        box-sizing: border-box !important;
        position: relative !important;
        left: auto !important;
        right: auto !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        transform: none !important;
    }

    .content .search-bar input,
    div.search-bar input,
    .search-bar input {
        flex: none !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        padding: 10px 14px !important;
        font-size: 14px !important;
        box-sizing: border-box !important;
        min-height: 42px !important;
    }

    .content .search-bar select,
    div.search-bar select,
    .search-bar select {
        flex: none !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .content .search-bar .btn,
    div.search-bar .btn,
    .search-bar .btn {
        flex: none !important;
        width: 100% !important;
        padding: 10px 16px !important;
        font-size: 14px !important;
        min-height: 44px !important;
        min-width: 0 !important;
        white-space: nowrap;
        border-radius: 4px;
        text-align: center;
        justify-content: center;
        box-sizing: border-box !important;
    }

    /* 表格 */
    .table-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .table th,
    .table td {
        padding: 12px;
        font-size: 13px;
    }

    /* 分页组件 */
    .pagination {
        flex-wrap: wrap;
        justify-content: center;
        gap: 8px;
    }

    .pagination > div {
        flex-wrap: wrap;
        justify-content: center !important;
        gap: 6px;
    }

    .pagination .btn {
        min-width: 36px;
        min-height: 36px;
        padding: 6px 10px;
        font-size: 13px;
    }

    .pagination span {
        width: 100%;
        text-align: center;
        margin-bottom: 8px;
    }

    .pagination select {
        min-width: 70px;
        padding: 6px 8px;
        font-size: 13px;
    }

    .form-row {
        grid-template-columns: 1fr;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    /* 模态框 */
    .modal-content {
        width: 92%;
        max-width: 100%;
        padding: 20px;
    }

    .modal-content.modal-small,
    .modal-content.modal-medium {
        max-width: 500px;
    }

    .modal-content.modal-large {
        max-width: 700px;
    }

    .modal-content.modal-xlarge {
        max-width: 1000px;
    }

    .modal-content.modal-xl {
        max-width: 100%;
    }

    .modal-content.modal-xxl {
        max-width: 100%;
    }

    .modal-footer {
        flex-direction: row;
        justify-content: flex-end;
        gap: 10px;
        flex-wrap: nowrap;
    }

    /* 信息卡片 */
    .info-cards {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .info-card {
        padding: 16px;
    }

    .info-card .value {
        font-size: 20px;
    }

    /* 配置项 */
    .config-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }

    .config-item label {
        min-width: auto;
    }

    .config-item input[type="text"],
    .config-item textarea,
    .config-item select {
        max-width: 100%;
        width: 100%;
    }

    .config-grid {
        grid-template-columns: 1fr !important;
    }
}

/* 平板 769px ~ 1024px */
@media (min-width: 769px) and (max-width: 1024px) {
    /* 登录页 */
    .login-container {
        padding: 24px;
    }

    .login-box {
        max-width: 440px;
        padding: 40px 32px 32px;
    }

    .login-logo svg {
        width: 56px;
        height: 56px;
    }

    .login-title {
        font-size: 26px;
    }

    .sidebar {
        width: 150px;
    }

    .header {
        left: 150px;
    }

    .main-content {
        margin-left: 150px;
    }

    .content {
        padding: 20px;
    }

    .form-row {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }

    .modal-content.modal-xlarge {
        max-width: 1000px;
    }
}

/* 小型笔记本 1025px ~ 1200px */
@media (min-width: 1025px) and (max-width: 1200px) {
    .sidebar {
        width: 150px;
    }

    .header {
        left: 150px;
    }

    .main-content {
        margin-left: 150px;
    }
}

/* 通用移动端侧边栏覆盖层激活 */
@media (max-width: 768px) {
    .sidebar.mobile-open + .main-content,
    .sidebar-overlay.show ~ .main-content {
        /* 不需要偏移，侧边栏浮在内容上方 */
    }
}

/* ==================== 补充样式 ==================== */

/* 数据表格 */
.data-table {
    width: 100%;
    border-collapse: collapse;
}

.data-table th,
.data-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
    font-size: 14px;
    vertical-align: middle;
}

.data-table th {
    background: var(--bg-dark);
    font-weight: 600;
    color: var(--text-secondary);
    white-space: nowrap;
    transition: var(--transition);
}

.data-table tbody tr:hover {
    background: var(--bg-dark);
    transition: var(--transition);
}

.data-table code {
    background: var(--bg-dark);
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 12px;
    color: var(--text-secondary);
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
    transition: var(--transition);
}

/* 状态标签 */
.status-green {
    color: var(--success-color);
    font-size: 13px;
    font-weight: 500;
    transition: var(--transition);
}

.status-red {
    color: var(--danger-color);
    font-size: 13px;
    font-weight: 500;
    transition: var(--transition);
}

.status-yellow {
    color: var(--warning-color);
    font-size: 13px;
    font-weight: 500;
    transition: var(--transition);
}

.status-blue {
    color: var(--primary-color);
    font-size: 13px;
    font-weight: 500;
    transition: var(--transition);
}

/* 页面标题区域 */
.page-header {
    display: none;
}

.page-header .page-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--text-primary);
    transition: var(--transition);
}

.page-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

/* 按钮变体 */
.btn-warning {
    background: var(--warning-color);
    color: var(--white);
    border: none;
}

.btn-warning:hover {
    background: var(--warning-light);
    color: var(--white);
}

.btn-secondary {
    background: var(--bg-light);
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
}

.btn-secondary:hover {
    color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-sm {
    padding: 4px 12px;
    font-size: 12px;
    border-radius: 4px;
}

/* 表单控件 */
.form-control {
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    border-radius: 4px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: var(--transition);
    outline: none;
}

.form-control:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(22, 93, 255, 0.15);
}

.search-bar .form-control {
    flex: 1;
    min-width: 180px;
}

.search-bar select.form-control {
    min-width: 140px;
    flex: 0 0 auto;
}

/* 分页容器 */
.pagination-container {
    display: flex;
    justify-content: center;
    margin-top: 20px;
}

/* 信息卡片（数据库管理页面） */
.info-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.info-card {
    background: var(--bg-light);
    border-radius: 8px;
    padding: 20px;
    box-shadow: var(--shadow-light);
    border-left: 4px solid var(--primary-color);
    transition: box-shadow 0.3s;
}

.info-card:hover {
    box-shadow: var(--shadow-dark);
}

.info-card h4 {
    font-size: 13px;
    color: var(--text-tertiary);
    margin-bottom: 8px;
    font-weight: 400;
}

.info-card .value {
    font-size: 24px;
    font-weight: 600;
    color: var(--text-primary);
}

/* 系统设置页面 */
.config-group {
    background: var(--bg-light);
    border-radius: 8px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: var(--shadow-light);
}

.config-group h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

.config-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.config-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 8px 0;
}

.config-item label {
    min-width: 100px;
    font-weight: 500;
    color: var(--text-secondary);
    font-size: 14px;
    flex-shrink: 0;
}

.config-item input[type="text"],
.config-item textarea,
.config-item select {
    flex: 1;
    max-width: 320px;
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    border-radius: 4px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: all 0.3s;
    outline: none;
}

.config-item input[type="text"]:focus,
.config-item textarea:focus,
.config-item select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(24, 144, 255, 0.15);
}

/* 通用工具类 */
.text-center {
    text-align: center;
    color: var(--text-tertiary);
    padding: 30px 0;
    font-size: 14px;
}

.loading {
    text-align: center;
    padding: 40px;
    color: var(--text-tertiary);
    font-size: 14px;
}

.error-tip {
    background: rgba(245, 63, 63, 0.1);
    border: 1px solid var(--danger-color);
    color: var(--danger-color);
    padding: 12px 16px;
    border-radius: 6px;
    text-align: center;
    transition: var(--transition);
}

.empty-tip {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-quaternary);
    font-size: 15px;
    transition: var(--transition);
}

/* 首页统计卡片 */
.dashboard-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

@media (max-width: 480px) {
    .dashboard-stats {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
}

.dashboard-stats > div {
    background: white;
    padding: 20px;
    border-radius: 8px;
    box-shadow: var(--shadow);
}

@media (max-width: 480px) {
    .dashboard-stats > div {
        padding: 14px 12px;
    }

    .dashboard-stats > div h3 {
        font-size: 13px;
        margin-bottom: 6px !important;
    }

    .dashboard-stats > div > div:first-of-type {
        font-size: 28px !important;
    }
}

/* 区块标题 */
.section h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 16px;
}

/* 表单网格布局 */
.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

/* 系统设置配置网格 */
.config-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

@media (max-width: 600px) {
    .form-grid {
        grid-template-columns: 1fr;
    }
}

/* 模态框内标题优化 */
.modal-body h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

/* 模态框内按钮组 */
.modal-body .btn + .btn {
    margin-left: 8px;
}

/* 权限管理页面 */
.permissions-page .page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

/* 页面级别容器 */
.permissions-page,
.factories-page {
    padding: 0;
}

/* 表格内按钮间距 */
.data-table .btn + .btn {
    margin-left: 6px;
}

/* 数据表格圆角 */
.table-container .data-table thead tr:first-child th:first-child {
    border-radius: 8px 0 0 0;
}

.table-container .data-table thead tr:first-child th:last-child {
    border-radius: 0 8px 0 0;
}

/* Toastr 提示框样式 - 居右显示 */
#toast-container {
    top: 20px !important;
    right: 60px !important;
    left: auto !important;
}

#toast-container > div {
    margin: 0 0 12px 0 !important;
    padding: 15px 20px 15px 50px !important;
    border-radius: 6px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

#toast-container .toast-message {
    display: block !important;
    margin-left: 0 !important;
}

#toast-container .toast-close-button {
    top: 10px !important;
    right: 10px !important;
}

/* 提示框样式 */
.toast {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 12px 20px;
    border-radius: 6px;
    color: white;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    z-index: 3000;
    opacity: 0;
    transform: translateX(100%);
    transition: all 0.3s ease;
}

.toast.show {
    opacity: 1;
    transform: translateX(0);
}

.toast-success {
    background: var(--success-color);
}

.toast-error {
    background: var(--danger-color);
}

.toast-info {
    background: var(--info-color);
}

.toast-warning {
    background: var(--warning-color);
}

/* ==================== ԭ���Ͽ��ͳ�ƿ�Ƭ ==================== */
.stock-summary-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
    margin-bottom: 24px;
}

.summary-card {
    background: var(--bg-light);
    border-radius: 8px;
    padding: 16px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    display: flex;
    align-items: center;
    gap: 12px;
    transition: all 0.3s ease;
}

.summary-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-dark);
}

.summary-card .card-icon {
    font-size: 24px;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: var(--bg-dark);
}

.summary-card.total .card-icon {
    background: rgba(22, 93, 255, 0.1);
}

.summary-card.warning .card-icon {
    background: rgba(255, 125, 0, 0.1);
}

.summary-card.danger .card-icon {
    background: rgba(245, 63, 63, 0.1);
}

.summary-card.success .card-icon {
    background: rgba(0, 180, 42, 0.1);
}

.summary-card.info .card-icon {
    background: rgba(134, 144, 156, 0.1);
}

.summary-card.info .card-value {
    color: var(--info-color);
}

.summary-card .card-content {
    flex: 1;
}

.summary-card .card-label {
    font-size: 12px;
    color: var(--text-tertiary);
    margin-bottom: 2px;
}

.summary-card .card-value {
    font-size: 20px;
    font-weight: 600;
    color: var(--text-primary);
    transition: var(--transition);
}

.summary-card.total .card-value {
    color: var(--primary-color);
}

.summary-card.warning .card-value {
    color: var(--warning-color);
}

.summary-card.danger .card-value {
    color: var(--danger-color);
}

.summary-card.success .card-value {
    color: var(--success-color);
}

/* ==================== 入库单表单样式 ==================== */

/* 表单网格优化 */
.inbound-form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-bottom: 24px;
}

@media (max-width: 768px) {
    .inbound-form-grid {
        grid-template-columns: 1fr;
    }
}

/* 表单项优化 */
.inbound-form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.inbound-form-group label {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 6px;
}

.inbound-form-group label i {
    color: var(--primary-color);
    font-size: 14px;
}

.inbound-form-group label .required {
    color: var(--danger-color);
    font-weight: bold;
}

.inbound-form-control {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--border-color);
    border-radius: 10px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: all 0.3s ease;
    outline: none;
}

.inbound-form-control:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 4px rgba(22, 93, 255, 0.1);
    background: white;
}

.inbound-form-control::placeholder {
    color: var(--text-quaternary);
}

/* 尺码输入框 */
.size-input {
    width: 50px;
    padding: 6px 8px;
    text-align: center;
    font-size: 12px;
    border: 1px solid var(--border-color);
    border-radius: 4px;
}

.size-input:focus {
    outline: none;
    border-color: var(--primary-color);
}

/* 入库明细区域 */
.inbound-details-section {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 2px solid var(--border-light);
}

.details-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.details-section-header h4 {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 10px;
}

.details-section-header h4 i {
    color: var(--primary-color);
}

.add-item-btn {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 8px;
}

.add-item-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(22, 93, 255, 0.3);
}

.add-item-btn:active {
    transform: translateY(0);
}

/* 明细表格优化 */
.details-table-wrapper {
    border: 2px solid var(--border-light);
    border-radius: 14px;
    overflow: hidden;
    background: white;
}

.details-table {
    width: 100%;
    border-collapse: collapse;
}

.details-table thead {
    background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
}

.details-table thead th {
    padding: 14px 16px;
    text-align: left;
    font-size: 13px;
    font-weight: 700;
    color: var(--text-secondary);
    white-space: nowrap;
    border-bottom: 2px solid var(--border-color);
}

.details-table tbody td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-light);
    vertical-align: middle;
}

.details-table tbody tr:hover {
    background: rgba(22, 93, 255, 0.03);
}

.details-table tbody tr:last-child td {
    border-bottom: none;
}

/* 产品选择下拉框优化 */
.product-select-wrapper {
    position: relative;
}

.product-select {
    width: 100%;
    padding: 10px 36px 10px 14px;
    border: 2px solid var(--border-color);
    border-radius: 8px;
    font-size: 14px;
    color: var(--text-primary);
    background: white;
    cursor: pointer;
    transition: all 0.3s ease;
    outline: none;
    appearance: none;
}

.product-select:hover {
    border-color: var(--primary-color);
}

.product-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

/* SKU选择美化 */
.sku-select-wrapper {
    position: relative;
}

.sku-select {
    width: 100%;
    padding: 10px 36px 10px 14px;
    border: 2px solid var(--border-color);
    border-radius: 8px;
    font-size: 14px;
    color: var(--text-primary);
    background: white;
    cursor: pointer;
    transition: all 0.3s ease;
    outline: none;
    appearance: none;
}

.sku-select:hover {
    border-color: var(--primary-color);
}

.sku-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

.sku-select:disabled {
    background: var(--bg-dark);
    cursor: not-allowed;
    opacity: 0.6;
}

/* SKU信息显示 */
.sku-info-display {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sku-color-tag,
.sku-size-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
}

.sku-color-tag {
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.1) 0%, rgba(139, 92, 246, 0.05) 100%);
    color: #7c3aed;
}

.sku-size-tag {
    background: linear-gradient(135deg, rgba(22, 163, 74, 0.1) 0%, rgba(22, 163, 74, 0.05) 100%);
    color: #15803d;
}

/* 输入框优化 */
.item-input {
    width: 100%;
    padding: 10px 14px;
    border: 2px solid var(--border-color);
    border-radius: 8px;
    font-size: 14px;
    color: var(--text-primary);
    background: white;
    transition: all 0.3s ease;
    outline: none;
}

.item-input:hover {
    border-color: var(--primary-color);
}

.item-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

/* 金额显示 */
.item-amount-display {
    font-weight: 700;
    font-size: 15px;
    color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
    padding: 8px 12px;
    border-radius: 8px;
    display: inline-block;
}

/* 删除按钮优化 */
.remove-item-btn {
    background: linear-gradient(135deg, var(--danger-color) 0%, #ff6b6b 100%);
    color: white;
    border: none;
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 6px;
}

.remove-item-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(245, 63, 63, 0.3);
}

.remove-item-btn:active {
    transform: translateY(0);
}

/* 下拉箭头图标 */
.product-select-wrapper::after,
.sku-select-wrapper::after {
    content: '\f078';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-tertiary);
    pointer-events: none;
    font-size: 12px;
    transition: all 0.3s ease;
}

.product-select-wrapper:hover::after,
.sku-select-wrapper:hover::after {
    color: var(--primary-color);
}

/* 空行提示 */
.no-items-message {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-tertiary);
}

.no-items-message i {
    font-size: 48px;
    margin-bottom: 12px;
    display: block;
    opacity: 0.5;
}

/* 响应式优化 */
@media (max-width: 768px) {
    .details-table-wrapper {
        overflow-x: auto;
    }
}
/* 响应式：平板 */
@media (max-width: 1024px) {
    .stock-summary-cards {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .stock-summary-cards {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .stock-summary-cards {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .summary-card {
        padding: 16px;
    }
    .summary-card .card-icon {
        font-size: 24px;
        width: 48px;
        height: 48px;
    }
    .summary-card .card-value {
        font-size: 20px;
    }
}

/* ==================== 财务管理模块样式 ==================== */

/* 统计卡片 */
.stat-card {
    background: var(--bg-light);
    border-radius: 8px;
    padding: 8px 12px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    box-shadow: var(--shadow-light);
    transition: var(--transition);
    border: 1px solid var(--border-light);
    flex-shrink: 1;
    width: auto;
    white-space: nowrap;
}

.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow);
}

.stat-card.stat-income {
    border-left: 4px solid var(--success-color);
    background: linear-gradient(135deg, #E8F7EE 0%, var(--bg-light) 100%);
}

.stat-card.stat-expense {
    border-left: 4px solid var(--danger-color);
    background: linear-gradient(135deg, #FFF0F0 0%, var(--bg-light) 100%);
}

.stat-card.stat-balance {
    border-left: 4px solid var(--primary-color);
    background: linear-gradient(135deg, #F0F8FF 0%, var(--bg-light) 100%);
}

.stat-card.stat-total {
    border-left: 4px solid #9C27B0;
    background: linear-gradient(135deg, #F8F0FF 0%, var(--bg-light) 100%);
}

.stat-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: var(--white);
    flex-shrink: 0;
}

.stat-card.stat-income .stat-icon {
    background: linear-gradient(135deg, var(--success-color) 0%, #36CFC9 100%);
}

.stat-card.stat-expense .stat-icon {
    background: linear-gradient(135deg, var(--danger-color) 0%, var(--danger-light) 100%);
}

.stat-card.stat-balance .stat-icon {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
}

.stat-card.stat-total .stat-icon {
    background: linear-gradient(135deg, #9C27B0 0%, #B974F0 100%);
}

.stat-content {
    flex: 1;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    flex-wrap: nowrap;
    min-width: 0;
}

.stat-label {
    font-size: 12px;
    color: var(--text-secondary);
    margin: 0;
}

.stat-value {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    line-height: 1.2;
    white-space: nowrap;
}

.stat-change {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 8px;
    font-size: 13px;
}

.stat-sub {
    font-size: 12px;
    color: var(--text-tertiary);
    margin-top: 4px;
}

.stat-card.stat-budget {
    border-left: 4px solid #FF9800;
    background: linear-gradient(135deg, #FFF8F0 0%, var(--bg-light) 100%);
}

.stat-card.stat-budget .stat-icon {
    background: linear-gradient(135deg, #FF9800 0%, #FFB74D 100%);
}

.stat-value.success-text {
    color: var(--success-color);
}

.stat-value.warning-text {
    color: var(--warning-color);
}

.stat-value.danger-text {
    color: var(--danger-color);
}

.stat-change.positive {
    color: var(--success-color);
}

.stat-change.negative {
    color: var(--danger-color);
}

.stat-change span {
    font-weight: 600;
}

.stat-change small {
    color: var(--text-tertiary);
    font-size: 12px;
}

/* 图表占位符 */
.chart-placeholder {
    min-height: 280px;
}

/* 趋势图表 */
.trend-chart .table {
    margin-bottom: 0;
}

.trend-chart .table th,
.trend-chart .table td {
    text-align: center;
    vertical-align: middle;
    padding: 12px 8px;
}

.trend-chart .table th {
    font-weight: 600;
    background: var(--bg-dark);
    color: var(--text-primary);
    border-bottom: 2px solid var(--border-color);
}

.trend-chart .table td {
    font-size: 14px;
}

/* 分类图表 */
.category-chart {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.category-item {
    padding: 16px;
    background: var(--bg-dark);
    border-radius: 8px;
    transition: var(--transition);
}

.category-item:hover {
    background: var(--border-light);
}

.category-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.category-name {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 500;
    color: var(--text-primary);
}

.category-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

.category-amount {
    font-weight: 600;
    color: var(--text-primary);
    font-size: 16px;
}

/* 快速操作按钮 */
.stat-card button.btn {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px;
    border: none;
    transition: var(--transition);
}

.stat-card button.btn:hover {
    transform: scale(1.02);
}

.stat-card button.btn i {
    font-size: 32px;
    margin-bottom: 8px;
}

/* 页面标题 */
.page-header {
    display: none;
}

.page-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 12px;
}

.page-title i {
    color: var(--primary-color);
}

/* 进度条样式 */
.progress {
    background-color: var(--bg-dark);
    border-radius: 4px;
    overflow: hidden;
}

.progress-bar {
    height: 100%;
    border-radius: 4px;
    transition: width 0.5s ease;
}

/* 响应式适配 */
@media (max-width: 768px) {
    .stat-card {
        padding: 16px;
    }
    
    .stat-icon {
        width: 48px;
        height: 48px;
        font-size: 22px;
    }
    
    .stat-value {
        font-size: 22px;
    }
    
    .page-title {
        font-size: 20px;
    }
    
    .trend-chart .table th,
    .trend-chart .table td {
        padding: 8px 4px;
        font-size: 12px;
    }
}

/* ==================== 财务管理模块样式结束 ==================== */


/* 属性标签样式 */
.attr-tag {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.3s ease;
}

.attr-color {
    background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
    color: white;
}

.attr-size {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
}

.attr-tag:hover {
    transform: scale(1.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

/* 表格输入框优化 */
.details-table .item-input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    background: #fafafa;
    transition: all 0.3s ease;
}

.details-table .item-input:focus {
    outline: none;
    border-color: #667eea;
    background: white;
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

/* 选择框优化 */
.details-table .product-select,
.details-table .sku-select {
    width: 100%;
    padding: 10px 35px 10px 12px;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    background: white;
    cursor: pointer;
    transition: all 0.3s ease;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.details-table .product-select:hover,
.details-table .sku-select:hover {
    border-color: #667eea;
}

.details-table .product-select:focus,
.details-table .sku-select:focus {
    outline: none;
    border-color: #667eea;
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

/* 选择框箭头图标 */
.product-select-wrapper,
.sku-select-wrapper {
    position: relative;
}

.product-select-wrapper::after,
.sku-select-wrapper::after {
    content: '\f078';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #999;
    pointer-events: none;
    transition: all 0.3s ease;
}

.product-select-wrapper:hover::after,
.sku-select-wrapper:hover::after {
    color: #667eea;
}

/* 表格行高优化 */
.details-table td {
    padding: 12px 8px;
    vertical-align: middle;
}

.details-table th {
    padding: 12px 8px;
    font-weight: 600;
}

/* 删除按钮优化 */
.remove-item-btn {
    padding: 8px 14px;
    background: linear-gradient(135deg, #ff6b6b 0%, #ee5a5a 100%);
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.remove-item-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(238, 90, 90, 0.4);
}

.remove-item-btn:active {
    transform: translateY(0);
}

/* 详情表格包装器优化 */
.detail-view .table-wrapper {
    overflow-x: auto;
    padding: 16px;
}

/* 详情表格优化 */
.detail-view .finance-table {
    min-width: 1000px;
}

.detail-view .finance-table th,
.detail-view .finance-table td {
    padding: 14px 16px !important;
    min-width: 100px;
}

.detail-view .finance-table td {
    white-space: nowrap;
}

/* 入库明细表格包装器 */
.details-table-wrapper {
    overflow-x: auto;
    padding: 16px 0;
}

/* 入库明细表格优化 */
.details-table {
    min-width: 1000px;
    width: 100%;
}

.details-table th,
.details-table td {
    padding: 14px 12px;
    white-space: nowrap;
}

/* ==================== ��ͷ����ģ̬����ʽ ==================== */

.column-settings-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    max-height: 300px;
    overflow-y: auto;
}

.column-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    background: var(--bg-dark);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.column-checkbox:hover {
    background: var(--border-color);
}

.column-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--primary-color);
}

.column-checkbox span {
    font-size: 14px;
    color: var(--text-primary);
    user-select: none;
}

/* ==================== ��ק������ʽ ==================== */

.column-order-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 250px;
    overflow-y: auto;
    padding: 8px;
    background: var(--bg-dark);
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.column-order-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: var(--bg-light);
    border-radius: 6px;
    cursor: move;
    transition: all 0.2s ease;
    user-select: none;
}

.column-order-item:hover {
    background: var(--border-color);
}

.column-order-item.dragging {
    opacity: 0.5;
    transform: scale(1.02);
    background: var(--primary-color);
}

.column-order-item.drag-over {
    border: 2px dashed var(--primary-color);
    background: rgba(0, 123, 255, 0.1);
}

.column-order-item.hidden {
    opacity: 0.5;
}

.column-order-item.hidden .column-name {
    text-decoration: line-through;
    color: var(--text-secondary);
}

.drag-handle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    color: var(--text-secondary);
    cursor: grab;
    border-radius: 4px;
    transition: background 0.2s ease;
}

.column-order-item:hover .drag-handle {
    color: var(--text-primary);
}

.drag-handle:active {
    cursor: grabbing;
}

.column-name {
    flex: 1;
    font-size: 14px;
    color: var(--text-primary);
}

.column-status {
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 10px;
    background: var(--success-bg);
    color: var(--success-color);
}

.column-order-item.hidden .column-status {
    background: var(--border-color);
    color: var(--text-secondary);
}

/* ==================== 状态标签选择组件样式 ==================== */

.status-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border: 2px solid #e2e8f0;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 500;
    color: #64748b;
    background: white;
    cursor: pointer;
    transition: all 0.25s ease;
    outline: none;
    min-width: 90px;
    justify-content: center;
}

.status-tag:hover {
    border-color: #cbd5e1;
    background: #f8fafc;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.status-tag:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

.status-tag.status-tag-active {
    border-color: transparent;
    color: white;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.status-tag.status-tag-active:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.status-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.status-tag.status-tag-active .status-indicator {
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.5);
}

.status-tag[data-status="draft"] {
    border-color: #9ca3af;
}

.status-tag[data-status="draft"].status-tag-active {
    background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%);
}

.status-tag[data-status="in_progress"] {
    border-color: #60a5fa;
}

.status-tag[data-status="in_progress"].status-tag-active {
    background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
}

.status-tag[data-status="completed"] {
    border-color: #4ade80;
}

.status-tag[data-status="completed"].status-tag-active {
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
}

.status-tag[data-status="repairing"] {
    border-color: #fbbf24;
}

.status-tag[data-status="repairing"].status-tag-active {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.status-tag[data-status="cancelled"] {
    border-color: #f87171;
}

.status-tag[data-status="cancelled"].status-tag-active {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
}

@media (max-width: 768px) {
    .status-tag {
        padding: 8px 12px;
        font-size: 13px;
        min-width: 75px;
    }
}

@media (max-width: 480px) {
    .status-tag {
        padding: 6px 10px;
        font-size: 12px;
        min-width: 65px;
        gap: 6px;
    }
    
    .status-indicator {
        width: 6px;
        height: 6px;
    }
}

/* 用户管理编辑模态窗样式 */
.form-section {
    margin-bottom: 20px;
    padding: 16px;
    background: var(--bg-dark);
    border-radius: 8px;
}

.form-section h4 {
    margin: 0 0 16px 0;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}

.form-section h4 i {
    margin-right: 8px;
    color: var(--primary-color);
}

.form-row {
    display: flex;
    gap: 16px;
    margin-bottom: 12px;
}

.form-group {
    flex: 1;
    min-width: 0;
}

.form-group label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-secondary);
}

.form-group label i {
    margin-right: 6px;
    color: var(--text-tertiary);
}

.form-control {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-light);
    transition: var(--transition);
}

.form-control:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

.form-control::placeholder {
    color: var(--text-quaternary);
}

.required {
    color: var(--danger-color);
    margin-left: 4px;
}

.role-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 6px;
}

.role-checkboxes label {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    cursor: pointer;
    font-size: 13px;
    transition: var(--transition);
}

.role-checkboxes label:hover {
    border-color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
}

.role-checkboxes input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.role-checkboxes input[type="checkbox"]:checked + span {
    color: var(--primary-color);
    font-weight: 500;
}

.permission-section {
    max-height: 400px;
    overflow-y: auto;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 12px;
}

.permission-legend {
    display: flex;
    gap: 20px;
    margin-bottom: 15px;
    padding: 10px;
    background: var(--bg-light);
    border-radius: 6px;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--text-tertiary);
}

.legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

.legend-dot.role-dot {
    background: var(--success-color);
}

.legend-dot.user-dot {
    background: var(--primary-color);
}

.permission-content {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.loading-text {
    text-align: center;
    padding: 20px;
    color: var(--text-tertiary);
    font-size: 13px;
}

.permission-group {
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 12px;
}

.permission-group > div:first-child {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: 600;
    margin-bottom: 10px;
    color: var(--primary-color);
    font-size: 14px;
}

.permission-group > div:first-child label {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-weight: normal;
    font-size: 12px;
    color: var(--text-secondary);
}

.permission-group > div:first-child input {
    margin-right: 6px;
    transform: scale(0.9);
}

.permission-group > div:last-child {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.permission-group label {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    background: var(--bg-light);
    border-radius: 4px;
    cursor: pointer;
    font-size: 12px;
    transition: var(--transition);
}

.permission-group label:hover:not(:has(:disabled)) {
    background: rgba(22, 93, 255, 0.05);
}

.permission-group input[type="checkbox"] {
    transform: scale(0.85);
    cursor: pointer;
}

.permission-group input[type="checkbox"]:disabled {
    cursor: not-allowed;
}

.permission-group label:has(:disabled) {
    opacity: 0.6;
    cursor: not-allowed;
}

/* ==================== 用户管理模态窗美化样式 ==================== */

.modal-header-custom {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
    border-radius: 8px 8px 0 0;
    margin: -20px -20px 20px;
}

.modal-icon {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 12px;
    font-size: 24px;
    color: #fff;
}

.modal-icon.permission-icon {
    background: rgba(255, 255, 255, 0.15);
}

.modal-title-wrap {
    flex: 1;
}

.modal-title-wrap h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #fff;
}

.modal-subtitle {
    margin: 4px 0 0;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.8);
}

.user-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.form-section {
    background: var(--bg-light);
    border-radius: 10px;
    padding: 20px;
    border: 1px solid var(--border-color);
}

.section-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--border-color);
}

.section-header i {
    color: var(--primary-color);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.form-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 8px;
}

.label-icon {
    font-size: 12px;
    color: var(--primary-color);
}

.label-text {
    flex: 1;
}

.required-mark {
    color: var(--danger-color);
    font-size: 14px;
}

.form-control {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-white);
    transition: all 0.2s ease;
    box-sizing: border-box;
}

.form-control:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

.form-control::placeholder {
    color: var(--text-tertiary);
}

.role-group {
    grid-column: span 2;
}

.role-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
}

.role-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--bg-white);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text-secondary);
    transition: all 0.2s ease;
}

.role-checkbox:hover {
    border-color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
}

.role-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.role-checkbox input[type="checkbox"]:checked + span {
    color: var(--primary-color);
    font-weight: 500;
}

.btn-lg {
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 500;
}

.btn-lg i {
    margin-right: 6px;
}

/* ==================== 用户编辑模态窗样式 ==================== */

.user-edit-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.user-edit-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    border-radius: 10px;
    margin-bottom: 4px;
}

.user-edit-notice-admin {
    background: linear-gradient(135deg, #fff8e1 0%, #ffecb3 100%);
    border: 1px solid #ffc107;
}

.user-edit-notice-admin > i {
    color: #ff8f00;
    font-size: 22px;
}

.user-edit-notice-admin .notice-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.user-edit-notice-admin .notice-content strong {
    color: #ff6f00;
    font-size: 14px;
}

.user-edit-notice-admin .notice-content span {
    color: #ff8f00;
    font-size: 13px;
}

.user-edit-section {
    background: var(--bg-light);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-color);
}

.user-edit-section .section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
    background: linear-gradient(135deg, var(--bg-dark) 0%, #e8eaed 100%);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-color);
}

.user-edit-section .section-title i {
    color: var(--primary-color);
    font-size: 16px;
    width: 20px;
    text-align: center;
}

.user-edit-section .section-content {
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.form-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.form-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.form-label i {
    color: var(--primary-color);
    font-size: 14px;
    width: 16px;
}

.form-label.required span::after {
    content: ' *';
    color: var(--danger-color);
}

.field-hint {
    display: block;
    font-size: 11px;
    color: var(--text-tertiary);
    margin-top: 4px;
}

/* 管理员开关样式 */
.admin-switch-wrapper {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
}

.admin-switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 26px;
    cursor: pointer;
}

.admin-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.switch-slider {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #ccc;
    transition: 0.3s;
    border-radius: 26px;
}

.switch-slider::before {
    position: absolute;
    content: "";
    height: 20px;
    width: 20px;
    left: 3px;
    bottom: 3px;
    background-color: white;
    transition: 0.3s;
    border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.admin-switch input:checked + .switch-slider {
    background: linear-gradient(135deg, #ffc107 0%, #ff9800 100%);
}

.admin-switch input:checked + .switch-slider::before {
    transform: translateX(24px);
}

.switch-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-secondary);
}

/* 角色复选框网格 */
.role-checkboxes-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 0;
}

.role-checkbox-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: var(--bg-white);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text-secondary);
    transition: all 0.2s ease;
}

.role-checkbox-item:hover {
    border-color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
}

.role-checkbox-item input[type="checkbox"] {
    display: none;
}

.role-checkbox-item .checkbox-box {
    width: 18px;
    height: 18px;
    border: 2px solid var(--border-color);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.role-checkbox-item input[type="checkbox"]:checked + .checkbox-box {
    background: var(--primary-color);
    border-color: var(--primary-color);
}

.role-checkbox-item input[type="checkbox"]:checked + .checkbox-box::after {
    content: '✓';
    color: white;
    font-size: 12px;
    font-weight: bold;
}

.role-checkbox-item input[type="checkbox"]:checked ~ .checkbox-label {
    color: var(--primary-color);
    font-weight: 500;
}

/* ==================== 权限管理模态窗样式 ==================== */

.permission-modal-content {
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: calc(100% - 80px);
    min-height: 200px;
    overflow: hidden;
    width: 100%;
    box-sizing: border-box;
}

/* 管理员提示 */
.perm-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-radius: 8px;
    flex-shrink: 0;
}

.perm-notice-admin {
    background: linear-gradient(135deg, #fff8e1 0%, #ffecb3 100%);
    border: 1px solid #ffc107;
}

.perm-notice-admin > i {
    color: #ff8f00;
    font-size: 22px;
}

.perm-notice-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.perm-notice-content strong {
    color: #ff6f00;
    font-size: 14px;
}

.perm-notice-content span {
    color: #ff8f00;
    font-size: 13px;
}

/* 统计栏 */
.perm-stats-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    padding: 12px 16px;
    background: linear-gradient(135deg, var(--bg-dark) 0%, var(--bg-light) 100%);
    border-radius: 8px;
    flex-shrink: 0;
    border: 1px solid var(--border-color);
}

.perm-stat-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--text-secondary);
}

.perm-stat-item i {
    font-size: 14px;
}

.perm-stat-item strong {
    color: var(--text-primary);
    font-weight: 600;
}

/* 图例 */
.perm-legend {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 16px;
    background: var(--bg-white);
    border-radius: 8px;
    flex-shrink: 0;
    flex-wrap: wrap;
    border: 1px solid var(--border-color);
}

.perm-legend-left {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.perm-legend-right {
    display: flex;
    gap: 8px;
}

.perm-legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--text-secondary);
}

.perm-legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

.perm-legend-dot-locked {
    background: var(--success-color);
}

.perm-legend-dot-editable {
    background: var(--primary-color);
}

.btn-outline {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    padding: 6px 12px;
    font-size: 12px;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.btn-outline:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
}

.btn-outline i {
    font-size: 11px;
}

/* 滚动区域 */
.permissions-scroll {
    flex: 1;
    overflow-y: auto;
    padding-right: 8px;
    width: 100%;
    box-sizing: border-box;
}

.permissions-scroll::-webkit-scrollbar {
    width: 6px;
}

.permissions-scroll::-webkit-scrollbar-track {
    background: var(--bg-dark);
    border-radius: 3px;
}

.permissions-scroll::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 3px;
}

.permissions-scroll::-webkit-scrollbar-thumb:hover {
    background: var(--text-tertiary);
}

/* 权限组 */
.perm-group {
    margin-bottom: 12px;
    background: var(--bg-white);
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border-color);
    width: 100%;
    box-sizing: border-box;
    transition: box-shadow 0.2s ease;
}

.perm-group:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.perm-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: linear-gradient(135deg, var(--bg-dark) 0%, #f0f2f5 100%);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    width: 100%;
    box-sizing: border-box;
    cursor: pointer;
    user-select: none;
    transition: background 0.2s ease;
}

.perm-group-header:hover {
    background: linear-gradient(135deg, #e8eaed 0%, #f5f6f7 100%);
}

.perm-group-left {
    display: flex;
    align-items: center;
    gap: 10px;
    text-align: left;
}

.perm-group-arrow {
    font-size: 12px;
    color: var(--text-tertiary);
    transition: transform 0.2s ease;
    width: 12px;
    flex-shrink: 0;
}

.perm-group-icon {
    color: var(--primary-color);
    font-size: 16px;
    width: 20px;
    text-align: center;
    flex-shrink: 0;
}

.perm-group-name {
    color: var(--text-primary);
    text-align: left;
    white-space: nowrap;
}

.perm-group-right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.perm-group-stats {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--text-tertiary);
}

.perm-selected-count {
    color: var(--primary-color);
    font-weight: 600;
}

.perm-total-count {
    color: var(--text-secondary);
}

.perm-role-badge {
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 500;
    color: var(--success-color);
    background: rgba(0, 180, 42, 0.1);
    border-radius: 10px;
}

/* 权限项容器 */
.perm-group-content {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 10px;
    padding: 14px;
    width: 100%;
    box-sizing: border-box;
    background: var(--bg-light);
}

/* 权限项 */
.perm-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: var(--bg-white);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text-secondary);
    transition: all 0.2s ease;
    flex-shrink: 0;
    box-sizing: border-box;
}

.perm-item-editable:hover {
    border-color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(22, 93, 255, 0.15);
}

.perm-item-locked {
    opacity: 0.75;
    cursor: not-allowed;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-color: #dee2e6;
}

.perm-item input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
    flex-shrink: 0;
}

.perm-item-locked input[type="checkbox"] {
    cursor: not-allowed;
}

.perm-name {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.perm-item input[type="checkbox"]:checked + .perm-name {
    color: var(--primary-color);
    font-weight: 500;
}

.perm-tag {
    padding: 2px 6px;
    font-size: 10px;
    font-weight: 600;
    border-radius: 4px;
    flex-shrink: 0;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.perm-tag-role {
    color: var(--success-color);
    background: rgba(0, 180, 42, 0.12);
}

.perm-tag-admin {
    color: #ff8f00;
    background: rgba(255, 143, 0, 0.12);
}

/* ==================== 角色权限标签样式 ==================== */
.role-perm-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
}

.role-perm-tag {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 500;
    color: rgb(var(--primary-6));
    background: rgba(22, 93, 255, 0.08);
    border: 1px solid rgba(22, 93, 255, 0.2);
    border-radius: 4px;
    white-space: nowrap;
    cursor: default;
    transition: all 0.2s ease;
}

.role-perm-tag:hover {
    background: rgba(22, 93, 255, 0.15);
    border-color: rgba(22, 93, 255, 0.35);
}

.role-perm-tag-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    font-size: 10px;
    font-weight: 600;
    color: #fff;
    background: rgb(var(--primary-6));
    border-radius: 8px;
}

.role-perm-tag-more {
    color: var(--text-tertiary);
    background: var(--color-fill-2);
    border-color: var(--border-color);
}

.role-perm-tag-more:hover {
    color: var(--text-secondary);
    background: var(--color-fill-3);
}

.role-perm-select-all {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 4px;
    transition: background 0.2s ease;
}

.role-perm-select-all:hover {
    background: rgba(22, 93, 255, 0.08);
}

.role-perm-select-all input[type="checkbox"] {
    width: 14px;
    height: 14px;
    cursor: pointer;
}

.perm-search-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: white;
    border-radius: 8px;
    margin-bottom: 8px;
    border: 1px solid var(--border-color);
    flex-shrink: 0;
}

.perm-search-input {
    flex: 1;
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-size: 13px;
    outline: none;
    transition: border-color 0.2s;
}

.perm-search-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(22, 93, 255, 0.1);
}

.perm-search-clear {
    background: none;
    border: none;
    color: var(--text-tertiary);
    cursor: pointer;
    padding: 4px 8px;
    font-size: 12px;
    border-radius: 4px;
    transition: all 0.2s;
}

.perm-search-clear:hover {
    color: var(--danger-color);
    background: rgba(239, 68, 68, 0.08);
}

.perm-template-dropdown {
    position: relative;
    display: inline-flex;
}

.perm-template-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: linear-gradient(135deg, var(--primary-color), #4f8cff);
    color: white;
    border: none;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.perm-template-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(22, 93, 255, 0.3);
}

.perm-template-menu {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    background: #ffffff;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    z-index: 100;
    min-width: 160px;
    padding: 4px;
    display: none;
}

.perm-template-menu.show {
    display: block;
}

.perm-template-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    font-size: 13px;
    color: var(--text-primary);
    cursor: pointer;
    border-radius: 6px;
    transition: all 0.15s;
    white-space: nowrap;
}

.perm-template-item:hover {
    background: rgba(22, 93, 255, 0.08);
    color: var(--primary-color);
}

.perm-template-item i {
    width: 16px;
    text-align: center;
    color: var(--text-tertiary);
    font-size: 13px;
}

.perm-template-item:hover i {
    color: var(--primary-color);
}

.perm-module-check {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 4px;
    transition: background 0.2s;
}

.perm-module-check:hover {
    background: rgba(22, 93, 255, 0.08);
}

.perm-module-check input[type="checkbox"] {
    width: 14px;
    height: 14px;
    cursor: pointer;
}

.perm-module-check span {
    font-size: 12px;
    color: var(--text-tertiary);
}

.perm-item-selected {
    border-left: 3px solid var(--primary-color);
    background: linear-gradient(135deg, rgba(22, 93, 255, 0.06), rgba(22, 93, 255, 0.02));
}

.perm-item-hidden {
    display: none;
}

.perm-group-hidden {
    display: none;
}

.perm-count-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    font-size: 11px;
    font-weight: 600;
    color: white;
    background: var(--success-color);
    border-radius: 10px;
    margin-left: 6px;
}

.perm-stat-change {
    animation: permStatPulse 0.3s ease;
}

@keyframes permStatPulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); color: var(--primary-color); }
    100% { transform: scale(1); }
}

/* ==================== 响应式调整 ====================*/
@media (max-width: 768px) {
    .form-grid {
        grid-template-columns: 1fr;
    }
    
    .role-group {
        grid-column: span 1;
    }
    
    .permission-modal-content {
        max-height: calc(100vh - 250px);
    }
    
    .perm-group-content {
        grid-template-columns: 1fr;
    }
    
    .perm-item {
        font-size: 12px;
        padding: 8px 12px;
    }
    
    .perm-stats-bar {
        gap: 12px;
    }
    
    .perm-stat-item {
        font-size: 12px;
    }
    
    .perm-group-header {
        font-size: 13px;
        padding: 10px 12px;
    }
    
    .perm-group-content {
        padding: 10px;
        gap: 8px;
    }
    
    .modal-header-custom {
        padding: 16px;
    }
    
    .modal-icon {
        width: 40px;
        height: 40px;
        font-size: 20px;
    }
    
    /* 权限模态窗响应式 */
    .perm-legend {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    
    .perm-legend-left {
        flex-direction: column;
        gap: 8px;
    }
    
    .perm-legend-right {
        width: 100%;
    }
    
    .btn-outline {
        flex: 1;
        justify-content: center;
    }
    
    /* 用户编辑模态窗响应式 */
    .form-grid-2 {
        grid-template-columns: 1fr;
    }
    
    .user-edit-section .section-title {
        font-size: 13px;
        padding: 12px 14px;
    }
    
    .user-edit-section .section-content {
        padding: 14px;
    }
    
    .role-checkboxes-grid {
        gap: 8px;
    }
    
    .role-checkbox-item {
        padding: 8px 12px;
        font-size: 12px;
    }
    
    .role-perm-tags {
        gap: 3px;
    }
    
    .role-perm-tag {
        font-size: 10px;
        padding: 1px 6px;
    }
}

/* ==================== 系统设置页面样式 ==================== */
.system-settings-page {
    padding: 20px;
}

.settings-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1600px;
    margin: 0 auto;
}

.settings-module {
    background: var(--bg-light);
    border-radius: 12px;
    box-shadow: var(--shadow-light);
    overflow: hidden;
    border: 1px solid var(--border-color);
}

.settings-module.module-wide {
    grid-column: span 3;
}

.module-header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    background: linear-gradient(135deg, var(--bg-dark) 0%, var(--bg-light) 100%);
    border-bottom: 1px solid var(--border-color);
}

.module-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    background: var(--primary-color);
    color: #fff;
    flex-shrink: 0;
}

.module-title {
    flex: 1;
    min-width: 0;
}

.module-title h3 {
    margin: 0 0 4px 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
}

.module-title p {
    margin: 0;
    font-size: 13px;
    color: var(--text-tertiary);
}

.module-save-btn {
    flex-shrink: 0;
    padding: 8px 20px;
    font-size: 14px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.module-content {
    padding: 20px;
}

.module-content .form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.module-content .form-group {
    margin: 0;
    display: flex;
    flex-direction: column;
}

.module-content .form-label {
    margin-bottom: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.module-content .form-label span:first-child {
    flex: 1;
}

.module-content .form-control {
    width: 100%;
    padding: 10px 12px;
    font-size: 14px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-light);
    color: var(--text-primary);
    transition: var(--transition);
    box-sizing: border-box;
    height: 38px;
    line-height: 1.5;
}

.module-content .form-control:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(22, 93, 255, 0.1);
}

.module-content .form-control:read-only {
    background: var(--bg-dark);
    color: var(--text-tertiary);
    cursor: not-allowed;
}

.module-content .form-checkbox {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--primary-color);
}

.module-content .info-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.module-content .info-grid-wide {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.module-content .info-item {
    display: flex;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--bg-dark);
    border-radius: 8px;
}

.module-content .info-label {
    font-size: 14px;
    color: var(--text-tertiary);
}

.module-content .info-value {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-primary);
}

.module-content .update-logs {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.module-content .update-logs-wide {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.module-content .update-item {
    padding: 16px;
    background: var(--bg-dark);
    border-radius: 8px;
}

.module-content .update-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.module-content .update-version {
    font-size: 14px;
    font-weight: 600;
    color: var(--primary-color);
}

.module-content .update-date {
    font-size: 13px;
    color: var(--text-tertiary);
}

.module-content .update-items {
    margin: 0;
    padding-left: 20px;
}

.module-content .update-items li {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.module-content .update-items li:last-child {
    margin-bottom: 0;
}

.module-content .update-items li i {
    color: var(--success-color);
    margin-right: 8px;
}

@media (max-width: 1200px) {
    .settings-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .settings-module.module-wide {
        grid-column: span 2;
    }

    .module-content .info-grid-wide {
        grid-template-columns: repeat(3, 1fr);
    }

    .module-content .update-logs-wide {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .settings-grid {
        grid-template-columns: 1fr;
    }

    .settings-module.module-wide {
        grid-column: span 1;
    }

    .module-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .module-save-btn {
        width: 100%;
        justify-content: center;
    }

    .module-content .info-grid-wide {
        grid-template-columns: repeat(2, 1fr);
    }

    .module-content .update-logs-wide {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .module-content .info-grid-wide {
        grid-template-columns: 1fr;
    }
}

/* 打印设置模块样式 */
.print-settings-overview {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.print-type-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: white;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.print-type-card:hover {
    border-color: var(--primary-color);
    box-shadow: 0 2px 8px rgba(22, 93, 255, 0.1);
    transform: translateX(4px);
}

.print-type-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    flex-shrink: 0;
}

.print-type-info {
    flex: 1;
}

.print-type-info h4 {
    margin: 0 0 4px 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
}

.print-type-info p {
    margin: 0;
    font-size: 13px;
    color: var(--text-tertiary);
}

.print-type-arrow {
    color: var(--text-quaternary);
    font-size: 16px;
}

/* 响应式调整 */
@media (max-width: 768px) {
    .print-settings-overview {
        gap: 10px;
    }
    
    .print-type-card {
        padding: 12px;
        gap: 12px;
    }
    
    .print-type-icon {
        width: 40px;
        height: 40px;
        font-size: 18px;
    }
    
    .print-type-info h4 {
        font-size: 15px;
    }
    
    .print-type-info p {
        font-size: 12px;
    }
}

.note-editor {
    border-radius: 8px !important;
    border: 1px solid #e2e8f0 !important;
    overflow: hidden;
}

.note-editor .note-toolbar {
    background: #f8fafc !important;
    border-bottom: 1px solid #e2e8f0 !important;
    padding: 6px 8px !important;
}

.note-editor .note-editing-area {
    border: none !important;
}

.note-editor .note-editable {
    font-family: Arial, SimSun, 'Microsoft YaHei', sans-serif;
    font-size: 12px;
    line-height: 1.4;
}

.note-editor .note-editable table {
    border-collapse: collapse;
}

.note-editor .note-editable td,
.note-editor .note-editable th {
    border: 1px solid #333;
    padding: 4px;
    min-width: 30px;
    min-height: 20px;
}

.note-editor .note-editable td:hover,
.note-editor .note-editable th:hover {
    outline: 2px solid #3b82f6;
    outline-offset: -1px;
}

#templatePreview table {
    border-collapse: collapse;
}

#templatePreview td,
#templatePreview th {
    border: 1px solid #333;
    padding: 4px;
}

.table-ctx-menu {
    position: fixed;
    z-index: 99999;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
    padding: 4px 0;
    min-width: 180px;
    display: none;
}
.table-ctx-menu .ctx-item {
    padding: 8px 16px;
    font-size: 13px;
    color: #334155;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
}
.table-ctx-menu .ctx-item:hover {
    background: #f1f5f9;
    color: #1e40af;
}
.table-ctx-menu .ctx-item.ctx-danger:hover {
    background: #fef2f2;
    color: #dc2626;
}
.table-ctx-menu .ctx-divider {
    height: 1px;
    background: #e2e8f0;
    margin: 4px 0;
}
.table-ctx-menu .ctx-item i {
    width: 16px;
    text-align: center;
    font-size: 12px;
}

.note-editable td,
.note-editable th {
    position: relative;
}
.note-editable .col-resize-handle {
    position: absolute;
    right: -2px;
    top: 0;
    bottom: 0;
    width: 5px;
    cursor: col-resize;
    z-index: 10;
}
.note-editable .row-resize-handle {
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 5px;
    cursor: row-resize;
    z-index: 10;
}
.note-editable td.cell-selected,
.note-editable th.cell-selected {
    background-color: #dbeafe !important;
    outline: 2px solid #3b82f6 !important;
    outline-offset: -1px;
}
.note-editable td.cell-selected:first-child,
.note-editable th.cell-selected:first-child {
    
}

/* ==================== 资产管理模块样式 ==================== */

.assets-loading {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 300px;
}

.assets-loading .loading-content {
    text-align: center;
}

.assets-loading .loading-spinner {
    margin-bottom: 16px;
}

.assets-loading .loading-text {
    color: var(--text-secondary);
    font-size: 14px;
}

.asset-detail {
    padding: 16px 0;
}

.asset-detail .detail-header {
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-color);
}

.asset-detail .detail-title {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.asset-detail .detail-title h4 {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
    color: var(--text-primary);
}

.asset-detail .detail-body {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.asset-detail .detail-section {
    background: var(--bg-dark);
    border-radius: 8px;
    padding: 16px;
}

.asset-detail .detail-section h5 {
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.asset-detail .detail-section h5::before {
    content: '';
    width: 3px;
    height: 14px;
    background: var(--primary-color);
    border-radius: 2px;
}

.asset-detail .detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

.asset-detail .detail-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 14px;
}

.asset-detail .detail-item .label {
    color: var(--text-tertiary);
    flex-shrink: 0;
    min-width: 80px;
}

.asset-detail .detail-section p {
    margin: 0;
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.6;
}

.pagination-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-top: 24px;
    padding: 16px 0;
}

.pagination-info {
    font-size: 13px;
    color: var(--text-secondary);
}

.pagination-info strong {
    color: var(--text-primary);
    font-weight: 600;
}

.pagination-controls {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
    justify-content: center;
}

.pagination-controls .btn {
    min-width: 36px;
    padding: 6px 12px;
}

.pagination-controls .btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.pagination-ellipsis {
    padding: 0 8px;
    color: var(--text-tertiary);
}

.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: var(--text-tertiary);
}

.empty-state i {
    margin-bottom: 16px;
    opacity: 0.5;
}

.empty-state p {
    margin: 0;
    font-size: 14px;
}

.table-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 80px 20px;
    background: var(--bg-dark);
    border-radius: 12px;
    margin-top: 16px;
}

.table-empty-state i {
    font-size: 56px;
    color: var(--text-quaternary);
    margin-bottom: 20px;
}

.table-empty-state p {
    font-size: 15px;
    color: var(--text-tertiary);
    margin: 0;
}

.table-actions {
    display: flex;
    align-items: center;
    gap: 4px;
}

.table-actions .btn-link {
    padding: 4px 8px;
    font-size: 13px;
    color: var(--primary-color);
    background: none;
    border: none;
    cursor: pointer;
}

.table-actions .btn-link:hover {
    text-decoration: underline;
}

.table-actions .btn-link.text-danger {
    color: var(--danger-color);
}

@media (max-width: 768px) {
    .asset-detail .detail-grid {
        grid-template-columns: 1fr;
    }
    
    .pagination-container {
        flex-direction: column;
        gap: 16px;
    }
    
    .pagination-controls {
        width: 100%;
        justify-content: center;
    }
    
    .pagination-controls .btn {
        flex: 1;
        max-width: 60px;
    }
}

@media (max-width: 480px) {
    .asset-detail .detail-title {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    
    .asset-detail .detail-title h4 {
        font-size: 18px;
    }
}

[data-theme="dark"] .asset-detail .detail-section {
    background: var(--bg-dark);
}

[data-theme="dark"] .asset-detail .detail-item .label {
    color: var(--text-quaternary);
}

[data-theme="dark"] .stat-card.stat-primary {
    background: linear-gradient(135deg, rgba(22, 93, 255, 0.1) 0%, var(--bg-light) 100%);
}

[data-theme="dark"] .stat-card.stat-info {
    background: linear-gradient(135deg, rgba(134, 144, 156, 0.1) 0%, var(--bg-light) 100%);
}

[data-theme="dark"] .stat-card.stat-success {
    background: linear-gradient(135deg, rgba(0, 180, 42, 0.1) 0%, var(--bg-light) 100%);
}

[data-theme="dark"] .stat-card.stat-warning {
    background: linear-gradient(135deg, rgba(255, 125, 0, 0.1) 0%, var(--bg-light) 100%);
}

/* ============================================
   财务概况 - 现代化仪表盘样式
   ============================================ */

.finance-dashboard {
    --finance-income: #10B981;
    --finance-expense: #EF4444;
    --finance-balance: #3B82F6;
    --finance-total: #8B5CF6;
    padding: 20px;
    min-height: 100%;
}

/* 仪表盘头部 */
.dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border-color);
}

.header-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dashboard-title {
    font-size: 24px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.dashboard-title i {
    color: var(--primary-color);
    font-size: 22px;
}

.dashboard-subtitle {
    font-size: 13px;
    color: var(--text-tertiary);
    margin: 0;
    padding-left: 32px;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 16px;
}

/* 周期选择器 */
.period-selector {
    display: flex;
    background: var(--bg-dark);
    border-radius: var(--radius-lg);
    padding: 3px;
    gap: 2px;
}

.period-btn {
    padding: 6px 14px;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-size: 13px;
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all 0.2s;
}

.period-btn:hover {
    color: var(--text-primary);
}

.period-btn.active {
    background: var(--bg-light);
    color: var(--primary-color);
    font-weight: 500;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* 指标卡片网格 */
.metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

.metric-card {
    position: relative;
    background: var(--bg-light);
    border-radius: var(--radius-xl);
    padding: 20px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    transition: transform 0.2s, box-shadow 0.2s;
}

.metric-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.metric-decoration {
    position: absolute;
    top: -20px;
    right: -20px;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    opacity: 0.1;
}

.metric-income .metric-decoration { background: var(--finance-income); }
.metric-expense .metric-decoration { background: var(--finance-expense); }
.metric-balance .metric-decoration { background: var(--finance-balance); }
.metric-total .metric-decoration { background: var(--finance-total); }

.metric-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.metric-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
    font-size: 16px;
}

.metric-income .metric-icon { background: rgba(16, 185, 129, 0.1); color: var(--finance-income); }
.metric-expense .metric-icon { background: rgba(239, 68, 68, 0.1); color: var(--finance-expense); }
.metric-balance .metric-icon { background: rgba(59, 130, 246, 0.1); color: var(--finance-balance); }
.metric-total .metric-icon { background: rgba(139, 92, 246, 0.1); color: var(--finance-total); }

.metric-label {
    font-size: 13px;
    color: var(--text-secondary);
    font-weight: 500;
}

.metric-body {
    display: flex;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 8px;
}

.metric-currency {
    font-size: 16px;
    color: var(--text-tertiary);
    font-weight: 500;
}

.metric-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.5px;
}

.metric-footer {
    display: flex;
    align-items: center;
    gap: 6px;
}

.metric-trend {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: var(--radius-sm);
}

.trend-up {
    background: rgba(16, 185, 129, 0.1);
    color: var(--finance-income);
}

.trend-down {
    background: rgba(239, 68, 68, 0.1);
    color: var(--finance-expense);
}

.trend-neutral {
    background: var(--bg-dark);
    color: var(--text-tertiary);
}

.metric-compare {
    font-size: 11px;
    color: var(--text-quaternary);
}

/* 仪表盘网格 */
.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

.dashboard-card {
    background: var(--bg-light);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-light);
}

.card-title-group {
    display: flex;
    align-items: center;
    gap: 10px;
}

.card-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-dark);
    border-radius: var(--radius-lg);
    color: var(--primary-color);
    font-size: 14px;
}

.card-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.card-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.year-select {
    padding: 6px 12px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--bg-light);
    color: var(--text-primary);
    font-size: 13px;
    cursor: pointer;
}

.action-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--bg-light);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
}

.action-btn:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.action-btn i {
    font-size: 14px;
}

.card-body {
    padding: 20px;
}

.chart-container {
    min-height: 280px;
}

.chart-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 280px;
    color: var(--text-tertiary);
    gap: 12px;
}

.loading-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* 趋势图表 */
.trend-chart-modern {
    padding: 10px 0;
}

.trend-legend {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-bottom: 20px;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--text-secondary);
}

.legend-item i { font-size: 8px; }
.legend-income i { color: var(--finance-income); }
.legend-expense i { color: var(--finance-expense); }
.legend-balance i { color: var(--finance-balance); }

.trend-bars {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    height: 200px;
    padding: 0 10px;
    gap: 8px;
}

.trend-bar-group {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.bar-container {
    display: flex;
    align-items: flex-end;
    gap: 3px;
    height: 160px;
    width: 100%;
    justify-content: center;
}

.bar {
    width: 16px;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    position: relative;
    transition: height 0.3s ease;
    min-height: 4px;
}

.bar-income { background: linear-gradient(180deg, var(--finance-income), rgba(16, 185, 129, 0.6)); }
.bar-expense { background: linear-gradient(180deg, var(--finance-expense), rgba(239, 68, 68, 0.6)); }

.bar-value {
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 9px;
    color: var(--text-tertiary);
    white-space: nowrap;
    opacity: 0;
    transition: opacity 0.2s;
}

.bar:hover .bar-value { opacity: 1; }

.bar-label {
    font-size: 11px;
    color: var(--text-secondary);
}

.bar-balance {
    font-size: 10px;
    font-weight: 600;
}

.bar-balance.positive { color: var(--finance-income); }
.bar-balance.negative { color: var(--finance-expense); }

/* 分类图表 */
.category-chart-modern {
    padding: 10px 0;
}

.category-summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: var(--bg-dark);
    border-radius: var(--radius-lg);
    margin-bottom: 16px;
}

.summary-total {
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.summary-label {
    font-size: 12px;
    color: var(--text-tertiary);
}

.summary-value {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
}

.summary-count {
    font-size: 12px;
    color: var(--text-tertiary);
}

.category-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.category-row {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    gap: 6px 12px;
    padding: 12px;
    background: var(--bg-dark);
    border-radius: var(--radius-lg);
    transition: background 0.2s;
}

.category-row:hover {
    background: var(--bg-hover);
}

.category-info {
    display: flex;
    align-items: center;
    gap: 10px;
}

.category-icon {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    font-size: 14px;
}

.category-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-primary);
}

.category-data {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.category-amount {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}

.category-percent {
    font-size: 11px;
    color: var(--text-tertiary);
}

.category-progress {
    grid-column: 1 / -1;
}

.progress-track {
    height: 6px;
    background: var(--border-color);
    border-radius: 3px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.3s ease;
}

/* 仪表盘底部 */
.dashboard-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    background: var(--bg-light);
    border-radius: var(--radius-xl);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.footer-info {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--text-tertiary);
}

.footer-actions {
    display: flex;
    gap: 10px;
}

.footer-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--bg-light);
    color: var(--text-secondary);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s;
}

.footer-btn:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
    background: rgba(22, 93, 255, 0.05);
}

/* 财务警告提示 */
.finance-alert {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 20px;
    border-radius: var(--radius-lg);
    margin: 20px;
}

.finance-alert-danger {
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger-color);
    border: 1px solid rgba(239, 68, 68, 0.2);
}

/* 响应式设计 */
@media (max-width: 1200px) {
    .metrics-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .dashboard-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .finance-dashboard {
        padding: 12px;
    }
    
    .dashboard-header {
        flex-direction: column;
        gap: 16px;
    }
    
    .header-right {
        width: 100%;
    }
    
    .period-selector {
        flex: 1;
        justify-content: center;
    }
    
    .metrics-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .metric-value {
        font-size: 24px;
    }
    
    .dashboard-footer {
        flex-direction: column;
        gap: 16px;
    }
    
    .footer-actions {
        width: 100%;
        justify-content: center;
    }
    
    .trend-bars {
        height: 150px;
    }
    
    .bar-container {
        height: 120px;
    }
    
    .bar {
        width: 12px;
    }
}

/* 深色模式适配 */
[data-theme="dark"] .finance-dashboard {
    background: var(--bg-color);
}

[data-theme="dark"] .metric-card,
[data-theme="dark"] .dashboard-card,
[data-theme="dark"] .dashboard-footer {
    background: var(--bg-light);
}

[data-theme="dark"] .metric-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .category-row {
    background: var(--bg-dark);
}

[data-theme="dark"] .category-row:hover {
    background: var(--bg-hover);
}

[data-theme="dark"] .category-summary {
    background: var(--bg-dark);
}

[data-theme="dark"] .period-btn.active {
    background: var(--bg-light);
}

[data-theme="dark"] .bar-income {
    background: linear-gradient(180deg, var(--finance-income), rgba(16, 185, 129, 0.4));
}

[data-theme="dark"] .bar-expense {
    background: linear-gradient(180deg, var(--finance-expense), rgba(239, 68, 68, 0.4));
}

/* 分类图表表格视图 */
.category-chart-modern.view-table .category-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}

.category-chart-modern.view-table .category-row {
    padding: 8px 10px;
}

.category-chart-modern.view-table .category-progress {
    display: none;
}

.category-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    color: var(--text-tertiary);
    gap: 12px;
}

.category-empty i {
    font-size: 48px;
    opacity: 0.5;
}

.category-empty p {
    margin: 0;
    font-size: 14px;
}

/* ==================== 权限拒绝页面样式 ==================== */

.permission-denied-page {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 400px;
    padding: 60px 20px;
    text-align: center;
}

.permission-denied-icon {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
}

.permission-denied-icon i {
    font-size: 48px;
    color: #dc2626;
}

.permission-denied-page h2 {
    margin: 0 0 12px 0;
    font-size: 24px;
    font-weight: 600;
    color: var(--text-primary);
}

.permission-denied-page p {
    margin: 0 0 8px 0;
    font-size: 15px;
    color: var(--text-secondary);
}

.permission-denied-page .permission-code {
    margin-top: 16px;
    padding: 8px 16px;
    background: var(--bg-light);
    border-radius: 6px;
    font-size: 13px;
    color: var(--text-tertiary);
}

.permission-denied-page .permission-code code {
    color: var(--primary-color);
    font-weight: 500;
    background: rgba(22, 93, 255, 0.1);
    padding: 2px 8px;
    border-radius: 4px;
}

.permission-denied-page .btn {
    margin-top: 24px;
}

[data-theme="dark"] .permission-denied-icon {
    background: linear-gradient(135deg, rgba(220, 38, 38, 0.2) 0%, rgba(220, 38, 38, 0.1) 100%);
}

[data-theme="dark"] .permission-denied-icon i {
    color: #f87171;
}
