/* =========================================
   💎 Premium Enterprise Design System
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
    /* 核心色盘 - 更稳重的高端蓝 */
    --primary-color: #0F172A;      /* 深邃午夜蓝 (文字/侧边栏) */
    --accent-color: #3B82F6;       /* 亮眼科技蓝 (按钮/高亮) */
    --bg-body: #F1F5F9;            /* 极淡的灰蓝背景 */
    --bg-card: #FFFFFF;
    
    /* 功能色 */
    --success: #10B981;
    --warning: #F59E0B;
    --danger: #EF4444;
    --text-main: #1E293B;
    --text-sub: #64748B;
    --border: #E2E8F0;

    /* 高级阴影 (弥散光感) */
    --shadow-card: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
    --shadow-hover: 0 20px 25px -5px rgba(0, 0, 0, 0.05), 0 10px 10px -5px rgba(0, 0, 0, 0.02);
    
    --sidebar-width: 260px;
}

body {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    font-variant-numeric: tabular-nums;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin: 0;
    background-color: var(--bg-body);
    color: var(--text-main);
    display: flex;
    height: 100vh;
    overflow: hidden;
}

/* 数字优化 */
* {
    font-variant-numeric: tabular-nums;
}

/* 表格、按钮、输入框数字特别优化 */
table, button, input, select, textarea, .badge, .stat-value, .progress-text {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    font-variant-numeric: tabular-nums;
}

a { text-decoration: none; color: inherit; }
* { box-sizing: border-box; outline: none; }

/* 1. 侧边栏 (极简高级感) */
.sidebar {
    width: var(--sidebar-width);
    background: #FFFFFF;
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    padding: 24px 16px;
    flex-shrink: 0;
    z-index: 100;
    overflow-y: auto;
    overflow-x: hidden;
    max-height: 100vh;
}

.sidebar h2 {
    font-size: 18px;
    font-weight: 800;
    color: var(--primary-color);
    margin: 0 0 30px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    letter-spacing: -0.5px;
}

.sidebar a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    margin-bottom: 4px;
    border-radius: 8px;
    color: var(--text-sub);
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
}

.sidebar a i { font-size: 18px; } /* 图标大小 */

.sidebar a:hover {
    background-color: #F8FAFC;
    color: var(--primary-color);
}

.sidebar a.active {
    background-color: #EFF6FF; /* 极淡的蓝色背景 */
    color: var(--accent-color);
    font-weight: 600;
}

/* 2. 主内容区 */
.main-content {
    flex: 1;
    padding: 32px 40px;
    overflow-y: auto;
}

.header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 32px;
}

.header h1 {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-main);
    margin: 0;
    letter-spacing: -0.5px;
}

/* 3. 卡片 (悬浮感) */
.card {
    background: var(--bg-card);
    border-radius: 12px;
    border: 1px solid var(--border);
    padding: 24px;
    margin-bottom: 24px;
    box-shadow: var(--shadow-card);
    transition: transform 0.2s, box-shadow 0.2s;
}

/* 4. 表格 (现代极简) */
table { width: 100%; border-collapse: collapse; }

th {
    text-align: left;
    padding: 12px 16px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--text-sub);
    border-bottom: 1px solid var(--border);
    background: #F8FAFC;
}

td {
    padding: 16px;
    border-bottom: 1px solid var(--border);
    font-size: 14px;
    color: var(--text-main);
}

tr:last-child td { border-bottom: none; }
tr:hover td { background-color: #F8FAFC; }

/* 5. 按钮 (扁平化) */
.btn {
    padding: 9px 18px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid transparent;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    justify-content: center;
}

.btn-primary { background: var(--primary-color); color: white; }
.btn-primary:hover { background: #1E293B; box-shadow: 0 4px 12px rgba(15, 23, 42, 0.2); }

.btn-success { background: var(--success); color: white; }
.btn-success:hover { background: #059669; box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2); }

.btn-danger { background: white; border: 1px solid #FECACA; color: var(--danger); }
.btn-danger:hover { background: #FEF2F2; border-color: var(--danger); }

.btn:disabled { opacity: 0.5; cursor: not-allowed; box-shadow: none; }

/* 6. 输入框 & 下拉框 */
input, select, textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 6px;
    font-size: 14px;
    transition: all 0.2s;
    background: #F8FAFC;
}

input:focus, select:focus, textarea:focus {
    background: white;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* 7. 弹窗 */
.modal { background: rgba(15, 23, 42, 0.6); backdrop-filter: blur(4px); }
.modal-content {
    background: white;
    border-radius: 16px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    border: none;
    animation: slideUp 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes slideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Select2 适配 */
.select2-container .select2-selection--single {
    height: 40px !important;
    border: 1px solid var(--border) !important;
    border-radius: 6px !important;
    background-color: #F8FAFC !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 38px !important;
    color: var(--text-main) !important;
}

/* Page: client/index.html */
/* 仪表盘特有样式 */
        .page-dashboard .dashboard-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-bottom: 24px; }
        .page-dashboard .stat-card { background: white; padding: 20px; border-radius: 12px; border: 1px solid var(--border); box-shadow: var(--shadow-sm); transition: transform 0.2s; position: relative; overflow: hidden; }
        .page-dashboard .stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); }
        
        .page-dashboard .stat-icon-bg { position: absolute; right: -10px; bottom: -10px; font-size: 80px; opacity: 0.1; transform: rotate(-15deg); }
        .page-dashboard .stat-value { font-size: 28px; font-weight: 800; color: var(--text-main); margin: 10px 0 5px 0; }
        .page-dashboard .stat-label { font-size: 13px; color: var(--text-sub); font-weight: 500; }

        /* 布局分栏 */
        .page-dashboard .split-section { display: grid; grid-template-columns: 2fr 1fr; gap: 24px; }
        
        /* 列表卡片 */
        .page-dashboard .panel-card { background: white; border-radius: 12px; border: 1px solid var(--border); overflow: hidden; display: flex; flex-direction: column; }
        .page-dashboard .panel-header { padding: 15px 20px; border-bottom: 1px solid var(--border); background: #F8FAFC; display: flex; justify-content: space-between; align-items: center; }
        .page-dashboard .panel-title { font-weight: 700; font-size: 15px; display: flex; align-items: center; gap: 8px; }
        
        /* 列表项 */
        .page-dashboard .list-item { padding: 12px 20px; border-bottom: 1px solid #f1f5f9; display: flex; align-items: center; justify-content: space-between; font-size: 13px; }
        .page-dashboard .list-item:last-child { border-bottom: none; }
        
        /* 进度条 */
        .page-dashboard .mini-progress { width: 100px; height: 6px; background: #E2E8F0; border-radius: 3px; overflow: hidden; }
        .page-dashboard .mini-bar { height: 100%; background: var(--accent-color); border-radius: 3px; }

        /* 快捷入口按钮 */
        .page-dashboard .shortcut-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 15px; padding: 20px; }
        .page-dashboard .shortcut-btn { 
            display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
            padding: 20px; background: #F8FAFC; border: 1px solid var(--border); border-radius: 8px; 
            cursor: pointer; transition: all 0.2s; text-decoration: none; color: var(--text-main);
        }
        .page-dashboard .shortcut-btn:hover { background: white; border-color: var(--accent-color); color: var(--accent-color); box-shadow: var(--shadow-sm); }
        .page-dashboard .shortcut-btn i { font-size: 24px; color: var(--primary-color); }
        
        /* 状态颜色 */
        .page-dashboard .tag-processing { background: #E0F2FE; color: #0369A1; padding: 2px 8px; border-radius: 4px; font-weight: bold; font-size: 11px; }
        .page-dashboard .tag-completed { background: #DCFCE7; color: #15803D; padding: 2px 8px; border-radius: 4px; font-weight: bold; font-size: 11px; }


/* Page: client/inventory.html */

        /* 左树右表布局 */
        .page-inventory .inventory-layout {
            display: flex;
            gap: 0;
            min-height: calc(100vh - 140px);
        }
        .page-inventory .tree-panel {
            width: 280px;
            min-width: 280px;
            background: white;
            border: 1px solid var(--border);
            border-radius: 12px;
            margin-right: 16px;
            box-shadow: var(--shadow-card);
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }
        .page-inventory .tree-panel-header,
        .page-inventory .tree-nav-header {
            padding: 12px 18px 10px;
            border-bottom: 1px solid var(--border);
            font-weight: 700;
            font-size: 14px;
            color: var(--text-main);
            display: flex;
            align-items: center;
            justify-content: space-between;
            background: #F8FAFC;
            cursor: pointer;
            user-select: none;
        }
        .page-inventory .tree-nav-header:hover { background: #EFF6FF; }
        .page-inventory .tree-panel-header i,
        .page-inventory .tree-nav-header i { color: var(--accent-color); margin-right: 6px; font-size: 16px; }
        .page-inventory .tree-panel-body {
            flex: 1;
            overflow-y: auto;
            padding: 8px 0;
        }
        .page-inventory .tree-node {
            padding: 7px 14px 7px 18px;
            cursor: pointer;
            display: flex;
            align-items: center;
            font-size: 13px;
            color: var(--text-main);
            transition: background 0.15s;
            user-select: none;
            position: relative;
        }
        .page-inventory .tree-node:hover { background: #F1F5F9; }
        .page-inventory .tree-node.active { background: #EFF6FF; color: #2563EB; font-weight: 600; }
        .page-inventory .tree-node .tree-icon {
            width: 18px;
            font-size: 10px;
            color: #94A3B8;
            flex-shrink: 0;
            text-align: center;
            transition: transform 0.2s;
        }
        .page-inventory .tree-node .tree-icon.expanded { transform: rotate(90deg); }
        .page-inventory .tree-node .tree-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        .page-inventory .tree-node .tree-count {
            font-size: 11px;
            background: #F1F5F9;
            color: #64748B;
            padding: 1px 7px;
            border-radius: 10px;
            margin-left: 6px;
            flex-shrink: 0;
        }
        .page-inventory .tree-node.active .tree-count { background: #DBEAFE; color: #2563EB; }
        /* 二级缩进 (型号) */
        .page-inventory .tree-node.level-2 { padding-left: 36px; font-size: 12.5px; }
        .page-inventory .tree-children { display: none; }
        .page-inventory .tree-children.open { display: block; }
        .page-inventory .tree-divider { height: 1px; background: var(--border); margin: 6px 14px; }

        /* 配件规格库管理区域（树面板下半部） */
        .page-inventory .spec-manager-section {
            border-top: 1px solid var(--border);
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }
        .page-inventory .spec-manager-header {
            padding: 12px 18px 10px;
            font-weight: 700;
            font-size: 14px;
            color: var(--text-main);
            display: flex;
            align-items: center;
            justify-content: space-between;
            background: #F8FAFC;
            cursor: pointer;
            user-select: none;
            border-bottom: 1px solid var(--border);
        }
        .page-inventory .spec-manager-header:hover { background: #EFF6FF; }
        .page-inventory .spec-manager-header i { color: #7C3AED; margin-right: 6px; font-size: 16px; }
        .page-inventory .spec-manager-arrow {
            font-size: 10px;
            color: #94A3B8;
            transition: transform 0.2s;
            display: inline-block;
        }
        .page-inventory .spec-manager-arrow.expanded { transform: rotate(90deg); }
        .page-inventory .spec-manager-body {
            flex: 1;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }
        /* 类别列表项 */
        .page-inventory .spec-cat-item {
            padding: 6px 14px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: space-between;
            font-size: 12.5px;
            color: var(--text-main);
            transition: background 0.15s;
        }
        .page-inventory .spec-cat-item:hover { background: #F1F5F9; }
        .page-inventory .spec-cat-item.active { background: #F3E8FF; color: #7C3AED; font-weight: 600; }
        .page-inventory .spec-cat-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        .page-inventory .spec-cat-actions { display: flex; gap: 6px; opacity: 0; transition: opacity 0.15s; }
        .page-inventory .spec-cat-item:hover .spec-cat-actions { opacity: 1; }
        .page-inventory .spec-cat-icon { cursor: pointer; font-size: 13px; color: #94A3B8; }
        .page-inventory .spec-cat-icon:hover { color: #7C3AED; }
        .page-inventory .spec-cat-icon.del:hover { color: var(--danger); }
        /* 规格标签 */
        .page-inventory .spec-tags-wrap { display: flex; flex-wrap: wrap; gap: 6px; }
        .page-inventory .spec-tag-item {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            background: #F8FAFC;
            border: 1px solid var(--border);
            padding: 3px 8px;
            border-radius: 14px;
            font-size: 12px;
            transition: all 0.2s;
        }
        .page-inventory .spec-tag-item:hover { border-color: #7C3AED; background: #F5F3FF; }
        .page-inventory .spec-tag-action { cursor: pointer; color: #94A3B8; font-size: 12px; }
        .page-inventory .spec-tag-action:hover { color: #7C3AED; }
        .page-inventory .spec-tag-action.del:hover { color: var(--danger); }

        .page-inventory .right-panel {
            flex: 1;
            min-width: 0;
        }

        .page-inventory .batch-action-dropdown {
            position: relative;
        }
        .page-inventory .batch-action-trigger {
            background: #10B981;
            color: white;
            border: 1px solid #059669;
        }
        .page-inventory .batch-action-menu {
            position: absolute;
            top: calc(100% + 6px);
            right: 0;
            min-width: 180px;
            background: white;
            border: 1px solid var(--border);
            border-radius: 8px;
            box-shadow: var(--shadow-card);
            padding: 6px;
            display: none;
            z-index: 200;
        }
        .page-inventory .batch-action-dropdown.open .batch-action-menu {
            display: block;
        }
        .page-inventory .batch-action-item {
            width: 100%;
            border: none;
            background: white;
            color: var(--text-main);
            font-size: 13px;
            text-align: left;
            padding: 8px 10px;
            border-radius: 6px;
            display: flex;
            align-items: center;
            gap: 8px;
            cursor: pointer;
        }
        .page-inventory .batch-action-item:hover {
            background: #F8FAFC;
            color: var(--accent-color);
        }

/* 弹窗样式 */
        .page-inventory .modal { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); align-items: center; justify-content: center; z-index: 9999; }
        .page-inventory .modal-content { background: white; padding: 25px; border-radius: 12px; width: 550px; max-width: 90%; box-shadow: 0 4px 20px rgba(0,0,0,0.2); }
        
        /* 入库/编辑弹窗卡片布局 */
        .page-inventory .inbound-card {
            background: #FAFBFC;
            border: 1px solid #E2E8F0;
            border-radius: 10px;
            margin-bottom: 14px;
            transition: border-color 0.2s, box-shadow 0.2s;
        }
        .page-inventory .inbound-card:hover {
            border-color: #CBD5E1;
            box-shadow: 0 2px 8px rgba(0,0,0,0.04);
        }
        .page-inventory .inbound-card-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 10px 16px 0;
        }
        .page-inventory .inbound-card-num {
            font-size: 12px;
            font-weight: 700;
            color: #94A3B8;
            background: #F1F5F9;
            padding: 2px 10px;
            border-radius: 10px;
        }
        .page-inventory .inbound-card-body {
            display: grid;
            grid-template-columns: 1.2fr 1.2fr 0.6fr;
            gap: 16px;
            padding: 12px 16px 16px;
            align-items: start;
        }
        .page-inventory .inbound-field-group {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        .page-inventory .inbound-label {
            font-size: 11px;
            font-weight: 700;
            color: #64748B;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            display: flex;
            align-items: center;
            gap: 4px;
        }
        .page-inventory .inbound-label i { font-size: 13px; }
        .page-inventory .inbound-scope-wrap {
            display: flex;
            flex-direction: column;
            gap: 6px;
        }
        .page-inventory .inbound-share-toggle select {
            width: 100%;
            height: 32px;
            border: 1px solid #E2E8F0;
            border-radius: 6px;
            padding: 0 8px;
            font-size: 12px;
            color: #64748B;
            background: white;
            cursor: pointer;
        }
        .page-inventory .inbound-share-toggle select:focus {
            outline: none;
            border-color: #2563EB;
        }
        .page-inventory .inbound-qty-group {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        .page-inventory .inbound-qty {
            width: 100%;
            height: 40px;
            border: 1px solid #E2E8F0;
            border-radius: 8px;
            text-align: center;
            font-size: 16px;
            font-weight: 600;
            color: var(--text-main);
            background: white;
            transition: border-color 0.2s;
        }
        .page-inventory .inbound-qty:focus {
            outline: none;
            border-color: #10B981;
            box-shadow: 0 0 0 3px rgba(16,185,129,0.1);
        }
        .page-inventory .spec-chip-container {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            padding-top: 8px;
            border-top: 1px solid #F1F5F9;
        }
        
        /* Select2 样式微调 */
        .page-inventory .select2-container .select2-selection--single { height: 40px !important; border: 1px solid var(--border) !important; border-radius: 6px !important; background-color: white !important; display: flex; align-items: center; }
        .page-inventory .select2-selection--multiple { min-height: 40px !important; height: auto !important; border: 1px solid var(--border) !important; border-radius: 6px !important; background-color: white !important; display: flex; flex-wrap: wrap; align-items: center; padding: 4px 6px !important; }
        .page-inventory .select2-selection--multiple .select2-selection__choice { margin: 2px 4px 2px 0; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 12px; }
        .page-inventory .select2-selection--multiple .select2-search__field { min-width: 60px; }
        .page-inventory .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 38px !important; padding-left: 10px; color: var(--text-main); }
        .page-inventory .select2-container--default .select2-selection--single .select2-selection__arrow { height: 38px !important; }
        .page-inventory .select2-search__field { margin-top: 0 !important; }

        /* 筛选栏样式 */
        .page-inventory .filter-bar {
            display: grid;
            grid-template-columns: 1fr 1fr 1.5fr auto;
            gap: 15px;
            padding: 16px 20px;
            background: white;
            border-radius: 12px;
            border: 1px solid var(--border);
            margin-bottom: 16px;
            box-shadow: var(--shadow-card);
            align-items: end;
        }
        .page-inventory .filter-item-reset { grid-column: auto; }

        .page-inventory .filter-item label {
            display: block;
            font-size: 12px;
            font-weight: 600;
            color: var(--text-sub);
            margin-bottom: 6px;
        }

        /* 表格优化 */
        .page-inventory .data-table { width: 100%; border-collapse: separate; border-spacing: 0; }
        .page-inventory .data-table th { background: #F8FAFC; padding: 12px 16px; font-size: 13px; font-weight: 600; color: var(--text-sub); border-bottom: 1px solid var(--border); text-align: left; }
        .page-inventory .data-table td { padding: 14px 16px; border-bottom: 1px solid #f1f5f9; font-size: 14px; color: var(--text-main); background: white; }
        .page-inventory .data-table tr:hover td { background: #F8FAFC; }
        
        .page-inventory .badge { padding: 2px 8px; border-radius: 4px; font-size: 12px; font-weight: 500; }
        .page-inventory .badge-gray { background: #F1F5F9; color: #64748B; }
        .page-inventory .badge-blue { background: #EFF6FF; color: #3B82F6; }
        .page-inventory .badge-purple { background: #F3E8FF; color: #7E22CE; border: 1px solid #E9D5FF; }
        
        /* 规格 Tag */
        .page-inventory .chip { display: inline-block; padding: 4px 10px; border: 1px solid #E2E8F0; border-radius: 16px; background: white; font-size: 12px; cursor: pointer; margin: 0 6px 6px 0; transition: all 0.2s; }
        .page-inventory .chip:hover { border-color: var(--accent-color); color: var(--accent-color); }
        .page-inventory .chip.selected { background: var(--accent-color); color: white; border-color: var(--accent-color); }


/* Page: client/material_receiving_logs.html */
.page-material-receiving-logs .filter-bar { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 15px; padding: 20px; background: white; border-radius: 12px; border: 1px solid var(--border); margin-bottom: 20px; box-shadow: var(--shadow-card); align-items: end; }
        .page-material-receiving-logs .filter-item label { display: block; font-size: 12px; font-weight: 600; color: var(--text-sub); margin-bottom: 6px; }
        .page-material-receiving-logs .log-card { background: white; border-radius: 8px; margin-bottom: 15px; border: 1px solid var(--border); overflow: hidden; }
        .page-material-receiving-logs .log-header { padding: 15px; display: flex; justify-content: space-between; align-items: center; background: #F8FAFC; border-bottom: 1px solid transparent; cursor: pointer; transition: background-color 0.2s; user-select: none; }
        .page-material-receiving-logs .log-header:hover { background-color: #eff6ff; }
        .page-material-receiving-logs .log-card.expanded .log-header { border-bottom-color: var(--border); background: #eff6ff; }
        .page-material-receiving-logs .log-chevron { transition: transform 0.25s ease; color: #94a3b8; font-size: 18px; flex-shrink: 0; }
        .page-material-receiving-logs .log-card.expanded .log-chevron { transform: rotate(180deg); color: var(--primary-color); }
        .page-material-receiving-logs .log-details { display: none; }
        .page-material-receiving-logs .log-items-table { width: 100%; border-collapse: collapse; }
        .page-material-receiving-logs .log-items-table th, .page-material-receiving-logs .log-items-table td { padding: 12px 15px; text-align: left; border-bottom: 1px solid #f1f5f9; }
        .page-material-receiving-logs .log-items-table th { font-weight: 600; font-size: 13px; color: var(--text-sub); }
        .page-material-receiving-logs .badge { padding: 4px 10px; border-radius: 12px; font-size: 12px; font-weight: 500; }
        .page-material-receiving-logs .badge-green { background-color: #dcfce7; color: #166534; }
        .page-material-receiving-logs .badge-purple { background-color: #f3e8ff; color: #6b21a8; }

        /* Apple-style input */
        .page-material-receiving-logs .apple-input {
            background-color: #f8f8f8;
            border: 1px solid #e5e5e5;
            border-radius: 8px;
            padding: 0 15px;
            height: 40px;
            box-shadow: inset 0 1px 2px rgba(0,0,0,0.05);
            transition: all 0.2s ease;
        }
        .page-material-receiving-logs .apple-input:focus {
            border-color: var(--primary-color);
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
            outline: none;
        }


/* Page: client/external_inventory.html */
/* Copied styles from internal inventory page to ensure consistency */
        .page-external-inventory .modal { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); align-items: center; justify-content: center; z-index: 9999; }
        .page-external-inventory .modal-content { background: white; padding: 25px; border-radius: 12px; width: 550px; max-width: 90%; box-shadow: 0 4px 20px rgba(0,0,0,0.2); }
        .page-external-inventory .select2-container .select2-selection--single, .page-external-inventory .select2-selection--multiple { height: 40px !important; border: 1px solid var(--border) !important; border-radius: 6px !important; background-color: white !important; display: flex; align-items: center; }
        .page-external-inventory .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 38px !important; padding-left: 10px; color: var(--text-main); }
        .page-external-inventory .select2-container--default .select2-selection--single .select2-selection__arrow { height: 38px !important; }
        .page-external-inventory .filter-bar { display: grid; grid-template-columns: 1fr 0.6fr 1fr 1fr 1.5fr auto; gap: 15px; padding: 20px; background: white; border-radius: 12px; border: 1px solid var(--border); margin-bottom: 20px; box-shadow: var(--shadow-card); align-items: end; }
        .page-external-inventory .filter-item-reset { grid-column: auto; }
        .page-external-inventory .filter-item label { display: block; font-size: 12px; font-weight: 600; color: var(--text-sub); margin-bottom: 6px; }
        .page-external-inventory .data-table { width: 100%; border-collapse: separate; border-spacing: 0; }
        .page-external-inventory .data-table th { background: #F8FAFC; padding: 12px 16px; font-size: 13px; font-weight: 600; color: var(--text-sub); border-bottom: 1px solid var(--border); text-align: left; }
        .page-external-inventory .data-table td { padding: 14px 16px; border-bottom: 1px solid #f1f5f9; font-size: 14px; color: var(--text-main); background: white; }
        .page-external-inventory .data-table tr:hover td { background: #F8FAFC; }
        .page-external-inventory .badge { padding: 2px 8px; border-radius: 4px; font-size: 12px; font-weight: 500; }
        .page-external-inventory .badge-gray { background: #F1F5F9; color: #64748B; }
        .page-external-inventory .badge-blue { background: #EFF6FF; color: #3B82F6; }


/* Page: client/external_receiving_logs.html */
/* Copied styles from internal logs page to ensure consistency */
        .page-external-receiving-logs .filter-bar { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 15px; padding: 20px; background: white; border-radius: 12px; border: 1px solid var(--border); margin-bottom: 20px; box-shadow: var(--shadow-card); align-items: end; }
        .page-external-receiving-logs .filter-item label { display: block; font-size: 12px; font-weight: 600; color: var(--text-sub); margin-bottom: 6px; }
        .page-external-receiving-logs .log-card { background: white; border-radius: 8px; margin-bottom: 15px; border: 1px solid var(--border); }
        .page-external-receiving-logs .log-header { padding: 15px; display: flex; justify-content: space-between; align-items: center; background: #F8FAFC; border-bottom: 1px solid var(--border); cursor: pointer; transition: background-color 0.2s; }
        .page-external-receiving-logs .log-header:hover { background-color: #f1f5f9; }
        .page-external-receiving-logs .log-details { display: none; }
        .page-external-receiving-logs .log-items-table { width: 100%; border-collapse: collapse; }
        .page-external-receiving-logs .log-items-table th, .page-external-receiving-logs .log-items-table td { padding: 12px 15px; text-align: left; border-bottom: 1px solid #f1f5f9; }
        .page-external-receiving-logs .log-items-table th { font-weight: 600; font-size: 13px; color: var(--text-sub); }
        .page-external-receiving-logs .badge { padding: 4px 10px; border-radius: 12px; font-size: 12px; font-weight: 500; }
        .page-external-receiving-logs .badge-green { background-color: #dcfce7; color: #166534; }
        .page-external-receiving-logs .badge-purple { background-color: #f3e8ff; color: #6b21a8; }
        .page-external-receiving-logs .apple-input { background-color: #f8f8f8; border: 1px solid #e5e5e5; border-radius: 8px; padding: 0 15px; height: 40px; box-shadow: inset 0 1px 2px rgba(0,0,0,0.05); transition: all 0.2s ease; }
        .page-external-receiving-logs .apple-input:focus { border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2); outline: none; }


/* Page: client/external_dashboard.html */
.page-external-dashboard { 
            background: linear-gradient(135deg, #f8fafc 0%, #e8f4f8 100%);
            min-height: 100vh;
            margin: 0;
            padding: 0;
        }
        
        .page-external-dashboard .main-content {
            padding: 20px;
            max-width: 1200px;
            margin: 0 auto;
            box-sizing: border-box;
        }

        .page-external-dashboard .header { 
            justify-content: space-between;
            margin-bottom: 30px;
            padding-bottom: 20px;
            border-bottom: 2px solid rgba(255,255,255,0.5);
        }

        .page-external-dashboard .header h1 {
            background: linear-gradient(135deg, #2563eb, #1d4ed8);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin: 0;
            font-size: 28px;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        /* 统计面板 */
        .page-external-dashboard .stats-panel {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 15px;
            margin-bottom: 30px;
        }

        .page-external-dashboard .stat-card {
            background: white;
            border-radius: 12px;
            padding: 20px;
            box-shadow: 0 4px 6px rgba(0,0,0,0.05);
            border-left: 4px solid #2563eb;
            transition: transform 0.2s, box-shadow 0.2s;
        }

        .page-external-dashboard .stat-card:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 12px rgba(0,0,0,0.1);
        }

        .page-external-dashboard .stat-value {
            font-size: 28px;
            font-weight: 700;
            color: #1e293b;
            margin: 10px 0;
        }

        .page-external-dashboard .stat-label {
            font-size: 13px;
            color: #64748b;
            font-weight: 500;
            text-transform: uppercase;
        }

        .page-external-dashboard .stat-card.pending { border-left-color: #f59e0b; }
        .page-external-dashboard .stat-card.completed { border-left-color: #10b981; }

        /* 进度条 */
        .page-external-dashboard .progress-bar {
            background-color: #e2e8f0;
            border-radius: 12px;
            overflow: hidden;
            height: 20px;
            box-shadow: inset 0 1px 3px rgba(0,0,0,0.05);
        }

        .page-external-dashboard .progress-bar-fill {
            background: linear-gradient(90deg, #10b981 0%, #059669 100%);
            height: 100%;
            transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
            box-shadow: 0 0 10px rgba(16, 185, 129, 0.5);
        }

        .page-external-dashboard .badge {
            padding: 6px 12px;
            border-radius: 16px;
            font-size: 12px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .page-external-dashboard .badge-blue { 
            background: linear-gradient(135deg, #dbeafe, #bfdbfe);
            color: #1e40af;
        }

        .page-external-dashboard .badge-amber { 
            background: linear-gradient(135deg, #fef3c7, #fed7aa);
            color: #92400e;
        }

        .page-external-dashboard .badge-green { 
            background: linear-gradient(135deg, #dcfce7, #bbf7d0);
            color: #15803d;
        }

        .page-external-dashboard .badge-yellow { 
            background: linear-gradient(135deg, #fef9c3, #fef3c7);
            color: #714204;
        }

        .page-external-dashboard .badge-red {
            background: linear-gradient(135deg, #fee2e2, #fecaca);
            color: #991b1b;
        }

        /* 订单分组 */
        .page-external-dashboard .expand-icon {
            transition: transform 0.3s ease;
            font-size: 20px;
            color: #475569;
        }

        .page-external-dashboard .expand-icon.open {
            transform: rotate(180deg);
        }

        /* 第一层：日期组 */
        .page-external-dashboard .date-group { 
            background: white;
            border-radius: 12px;
            margin-bottom: 20px;
            border: 2px solid #e2e8f0;
            box-shadow: 0 2px 8px rgba(0,0,0,0.06);
            overflow: hidden;
            transition: all 0.3s ease;
        }

        .page-external-dashboard .date-group:hover {
            box-shadow: 0 4px 12px rgba(0,0,0,0.10);
        }

        .page-external-dashboard .date-header { 
            padding: 18px 20px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
            border-bottom: 1px solid #cbd5e1;
            border-left: 4px solid #64748b;
            cursor: pointer;
            transition: all 0.3s ease;
        }

        .page-external-dashboard .date-header:hover { 
            background: linear-gradient(135deg, #e2e8f0 0%, #cbd5e1 100%);
        }

        .page-external-dashboard .date-header-left {
            flex: 1;
            display: flex;
            align-items: center;
            gap: 15px;
        }

        .page-external-dashboard .date-value {
            font-weight: 700;
            font-size: 16px;
            color: #334155;
        }

        .page-external-dashboard .date-header-right {
            display: flex;
            align-items: center;
            gap: 15px;
            min-width: 250px;
        }

        .page-external-dashboard .date-details { 
            display: none !important;
            max-height: 0;
            overflow: hidden;
            padding: 0;
            background: #f8fafc;
            transition: all 0.3s ease;
        }

        .page-external-dashboard .date-details.show {
            display: block !important;
            max-height: 10000px;
            padding: 15px 0;
        }

        .page-external-dashboard .order-group { 
            background: white;
            border-radius: 8px;
            margin-bottom: 12px;
            border: 1px solid #dbeafe;
            box-shadow: 0 1px 3px rgba(0,0,0,0.05);
            overflow: hidden;
            transition: all 0.2s ease;
        }

        .page-external-dashboard .order-group:hover {
            box-shadow: 0 2px 8px rgba(0,0,0,0.08);
        }

        .page-external-dashboard .order-header { 
            padding: 15px 20px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
            border-bottom: 1px solid #bfdbfe;
            cursor: pointer;
            transition: all 0.2s ease;
        }

        .page-external-dashboard .order-header:hover { 
            background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
        }

        .page-external-dashboard .order-header .progress-text {
            color: #1e40af;
        }

        .page-external-dashboard .order-header-left {
            flex: 1;
            display: flex;
            align-items: center;
            gap: 20px;
        }

        .page-external-dashboard .order-number {
            font-weight: 700;
            font-size: 15px;
            color: #1e40af;
        }

        .page-external-dashboard .order-date {
            display: none;
        }

        .page-external-dashboard .order-header-right {
            display: flex;
            align-items: center;
            gap: 15px;
            min-width: 250px;
        }

        .page-external-dashboard .progress-section {
            flex: 1;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .page-external-dashboard .progress-text {
            font-size: 13px;
            font-weight: 600;
            color: #475569;
            min-width: 50px;
        }

        .page-external-dashboard .order-details { 
            display: none !important;
            max-height: 0;
            overflow: hidden;
            padding: 0;
            transition: all 0.3s ease;
        }

        .page-external-dashboard .order-details.show {
            display: block !important;
            max-height: 10000px;
            padding: 15px 0;
        }

        @keyframes slideDown {
            from {
                opacity: 0;
                max-height: 0;
            }
            to {
                opacity: 1;
                max-height: 1000px;
            }
        }

        .page-external-dashboard .data-table {
            width: 100%;
            border-collapse: collapse;
            padding: 0;
        }

        .page-external-dashboard .data-table tbody tr {
            border-bottom: 1px solid #f0f0f0;
            transition: background-color 0.2s;
        }

        .page-external-dashboard .data-table tbody tr:hover {
            background-color: #f9fafb;
        }

        .page-external-dashboard .data-table td {
            padding: 15px 20px;
            font-size: 14px;
            color: #334155;
        }

        .page-external-dashboard .data-table td:first-child {
            font-weight: 600;
            color: #1e293b;
        }

        .page-external-dashboard .shipment-history { 
            background-color: #f0fdf4;
            padding: 12px;
            font-size: 13px;
            border-radius: 8px;
            border-left: 3px solid #10b981;
            margin-bottom: 8px;
            line-height: 1.6;
        }

        .page-external-dashboard .shipment-history:last-child {
            margin-bottom: 0;
        }

        .page-external-dashboard .shipment-empty {
            font-size: 13px;
            color: #94a3b8;
            font-style: italic;
        }

        /* Modal美化 */
        .page-external-dashboard .ship-modal-content {
            background: white !important;
            padding: 35px !important;
            border-radius: 16px !important;
            box-shadow: 0 20px 60px rgba(0,0,0,0.15) !important;
            animation: modalSlideIn 0.3s ease !important;
        }

        @keyframes modalSlideIn {
            from {
                opacity: 0;
                transform: scale(0.95);
            }
            to {
                opacity: 1;
                transform: scale(1);
            }
        }

        .page-external-dashboard .ship-modal-content h3 {
            margin: 0 0 25px 0;
            font-size: 20px;
            font-weight: 700;
            color: #1e293b;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .page-external-dashboard .info-grid {
            display: grid;
            grid-template-columns: 100px 1fr;
            gap: 12px 20px;
            margin-bottom: 28px;
            font-size: 14px;
            background: #f8fafc;
            padding: 20px;
            border-radius: 12px;
        }

        .page-external-dashboard .info-grid dt {
            color: #64748b;
            font-weight: 600;
            text-align: right;
        }

        .page-external-dashboard .info-grid dd {
            margin: 0;
            font-weight: 700;
            color: #1e293b;
        }

        .page-external-dashboard .qty-input-label {
            display: block;
            font-weight: 700;
            font-size: 13px;
            margin-bottom: 12px;
            text-align: center;
            text-transform: uppercase;
            color: #64748b;
            letter-spacing: 0.5px;
        }

        .page-external-dashboard #ship-qty {
            font-size: 24px;
            font-weight: 700;
            text-align: center;
            color: #2563eb;
            padding: 15px;
            border: 2px solid #dbeafe;
            border-radius: 10px;
            transition: all 0.3s;
        }

        .page-external-dashboard #ship-qty:focus {
            outline: none;
            border-color: #2563eb;
            box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
        }

        .page-external-dashboard .modal-actions {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 12px;
            margin-top: 30px;
        }

        .page-external-dashboard .btn {
            border: none;
            padding: 12px 20px;
            border-radius: 8px;
            cursor: pointer;
            font-weight: 600;
            font-size: 14px;
            transition: all 0.3s;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .page-external-dashboard .btn:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }

        .page-external-dashboard .btn-outline {
            background: #f1f5f9;
            color: #475569;
            border: 1px solid #e2e8f0;
        }

        .page-external-dashboard .btn-outline:hover:not(:disabled) {
            background: #e2e8f0;
            border-color: #cbd5e1;
        }

        .page-external-dashboard .btn-primary {
            background: linear-gradient(135deg, #2563eb, #1d4ed8);
            color: white;
        }

        .page-external-dashboard .btn-primary:hover:not(:disabled) {
            background: linear-gradient(135deg, #1d4ed8, #1e40af);
            box-shadow: 0 4px 12px rgba(37, 99, 235, 0.4);
        }

        .page-external-dashboard .expand-icon {
            transition: transform 0.3s ease;
            color: #94a3b8;
        }

        .page-external-dashboard .expand-icon.open {
            transform: rotate(180deg);
        }
.page-login { margin: 0; padding: 0; background: #F1F5F9; font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif; display: flex; align-items: center; justify-content: center; height: 100vh; }
        .page-login .login-card { background: white; padding: 40px; border-radius: 20px; box-shadow: 0 10px 25px rgba(0,0,0,0.05); width: 360px; text-align: center; }
        .page-login .logo { font-size: 48px; color: #3B82F6; margin-bottom: 20px; }
        .page-login h1 { margin: 0 0 30px; font-size: 24px; color: #1E293B; letter-spacing: -0.5px; }
        .page-login .input-group { margin-bottom: 20px; text-align: left; }
        .page-login .input-group label { display: block; font-size: 13px; font-weight: 600; color: #64748B; margin-bottom: 8px; }
        .page-login .input-group input, .page-login .input-group select { width: 100%; padding: 12px; border: 1px solid #E2E8F0; border-radius: 8px; font-size: 14px; box-sizing: border-box; transition: all 0.2s; background: #F8FAFC; }
        .page-login .input-group input:focus, .page-login .input-group select:focus { border-color: #3B82F6; background: white; outline: none; box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1); }
        .page-login .btn-login { width: 100%; padding: 12px; background: #0F172A; color: white; border: none; border-radius: 8px; font-size: 15px; font-weight: 600; cursor: pointer; transition: background 0.2s; margin-top: 10px; }
        .page-login .btn-login:hover { background: #3B82F6; }


/* Page: client/receiving_logs.html */
.page-receiving-logs .filter-bar { display: flex; gap: 15px; background: white; padding: 15px; border-radius: 8px; border: 1px solid var(--border); margin-bottom: 20px; align-items: flex-end; }
        
        /* 列表样式 */
        .page-receiving-logs .batch-row { cursor: pointer; transition: background 0.2s; }
        .page-receiving-logs .batch-row:hover { background: #F8FAFC; }
        .page-receiving-logs .batch-icon { transition: transform 0.2s; }
        
        .page-receiving-logs .detail-row { display: none; background: #F8FAFC; }
        .page-receiving-logs .detail-row.open { display: table-row; }
        
        .page-receiving-logs .detail-table { width: 95%; margin: 10px auto; background: white; border: 1px solid #E2E8F0; border-radius: 6px; overflow: hidden; }
        .page-receiving-logs .detail-table th { background: #EFF6FF; color: #1E3A8A; font-size: 12px; padding: 8px; text-align: left; }
        .page-receiving-logs .detail-table td { font-size: 13px; padding: 8px; border-bottom: 1px solid #F1F5F9; }
        
        /* 表格通用 */
        .page-receiving-logs .main-table { width: 100%; border-collapse: collapse; }
        .page-receiving-logs .main-table th { background: #F8FAFC; padding: 12px 16px; font-size: 13px; font-weight: 600; color: var(--text-sub); border-bottom: 1px solid var(--border); text-align: left; }
        .page-receiving-logs .main-table td { padding: 14px 16px; border-bottom: 1px solid #f1f5f9; font-size: 14px; color: var(--text-main); background: white; }


/* Page: client/products.html */
        /* 筛选栏样式 */
        /* ================== Products 左右布局 ================== */
        .page-products .products-layout {
            display: grid;
            grid-template-columns: 280px 1fr;
            gap: 0;
            height: calc(100vh - 100px);
        }
        .page-products .tree-panel {
            background: white;
            border-radius: 16px 0 0 16px;
            border: 1px solid var(--border);
            border-right: none;
            margin-right: 0;
            box-shadow: var(--shadow-card);
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }
        .page-products .right-panel {
            background: var(--bg-main);
            border-radius: 0 16px 16px 0;
            overflow-y: auto;
            padding: 20px;
        }
        .page-products .collapsible-section {
            border-top: 1px solid var(--border);
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }
        .page-products .collapsible-section:first-child { border-top: none; }
        .page-products .collapsible-section.is-fill { flex: 1; min-height: 0; }
        .page-products .collapsible-header {
            padding: 12px 18px 10px;
            font-weight: 700;
            font-size: 14px;
            color: var(--text-main);
            display: flex;
            align-items: center;
            justify-content: space-between;
            background: #F8FAFC;
            cursor: pointer;
            user-select: none;
            border-bottom: 1px solid var(--border);
        }
        .page-products .collapsible-header:hover { background: #EFF6FF; }
        .page-products .collapsible-header i { color: var(--accent-color); margin-right: 6px; font-size: 16px; }
        .page-products .collapsible-header-green i { color: #10B981; }
        .page-products .collapsible-arrow {
            font-size: 10px;
            color: #94A3B8;
            transition: transform 0.2s;
            display: inline-block;
        }
        .page-products .collapsible-arrow.expanded { transform: rotate(90deg); }
        .page-products .collapsible-body {
            overflow: hidden;
            display: flex;
            flex-direction: column;
            flex: 1;
        }
        .page-products .collapsible-section:not(.is-fill) .collapsible-body {
            flex: 0 0 auto;
        }
        .page-products .filter-bar {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 12px;
            padding: 16px;
            background: white;
            border-radius: 12px;
            border: 1px solid var(--border);
            margin-bottom: 20px;
            box-shadow: var(--shadow-card);
            align-items: end;
        }

        .page-products .filter-item label {
            display: block;
            font-size: 12px;
            font-weight: 600;
            color: var(--text-sub);
            margin-bottom: 6px;
            font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
        }

        .page-products .filter-item select,
        .page-products .filter-item input,
        .page-products .filter-item .btn {
            font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
        }

/* 产能胶囊样式 */
        .page-products .capacity-badge { display: inline-block; padding: 4px 10px; border-radius: 4px; font-weight: bold; font-size: 13px; min-width: 80px; text-align: center; }
        .page-products .cap-high { background: #f6ffed; border: 1px solid #b7eb8f; color: #52c41a; } 
        .page-products .cap-low { background: #fffbe6; border: 1px solid #ffe58f; color: #faad14; } 
        .page-products .cap-zero { background: #fff1f0; border: 1px solid #ffa39e; color: #f5222d; } 

        /* 原料微型列表 */
        .page-products .ing-tag { font-size: 12px; background: #f0f2f5; padding: 2px 6px; border-radius: 4px; margin-right: 5px; display: inline-block; margin-bottom: 2px; border: 1px solid #e1e4e8; color: #555; }
        .page-products .ing-alert { color: #f5222d; background: #fff1f0; border-color: #ffa39e; font-weight: bold; }

        /* ================== 折叠卡片样式 ================== */
        .page-products .series-group { margin-bottom: 15px; border: 1px solid #e8e8e8; border-radius: 6px; background: white; overflow: hidden; }
        
        /* 头部（点击区域） */
        .page-products .series-header { 
            padding: 15px 20px; 
            background: #fafafa; 
            cursor: pointer; 
            display: flex; 
            justify-content: space-between; 
            align-items: center;
            border-bottom: 1px solid transparent; /* 默认隐藏分割线 */
            transition: all 0.2s;
        }
        .page-products .series-header:hover { background: #f0f7ff; }
        .page-products .series-header.active { border-bottom: 1px solid #e8e8e8; background: #e6f7ff; }
        
        .page-products .series-title { font-size: 16px; font-weight: bold; color: #333; display: flex; align-items: center; gap: 10px; }
        .page-products .arrow-icon { transition: transform 0.3s; font-size: 12px; color: #999; }
        .page-products .series-header.active .arrow-icon { transform: rotate(180deg); }

        /* 内容区域（表格） */
        .page-products .series-content { display: none; padding: 0; }
        .page-products .series-content table { margin: 0; border: none; }
        .page-products .series-content th { background: #fff; border-bottom: 2px solid #f0f0f0; color: #999; font-size: 12px; }
        .page-products .series-content td { padding: 12px 20px; border-bottom: 1px solid #f0f0f0; }
        .page-products .series-content tr:last-child td { border-bottom: none; }

        /* 弹窗样式调整 */
        .page-products .modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); display: none; align-items: center; justify-content: center; z-index: 1000; }
        .page-products .modal-content { background: white; padding: 25px; border-radius: 8px; width: 650px; max-height: 80vh; overflow-y: auto; box-shadow: 0 4px 15px rgba(0,0,0,0.2); }
        .page-products .bom-row { display: flex; gap: 10px; margin-bottom: 10px; align-items: center; background: #fafafa; padding: 10px; border-radius: 6px; border: 1px solid #eee; }
        
        /* Select2 修正 */
        .page-products .select2-container { width: 100% !important; }
        .page-products .select2-container .select2-selection--single { height: 38px; line-height: 38px; border: 1px solid #ddd; }
        .page-products .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 38px; }


/* Page: client/orders.html */
.page-orders {
            background: linear-gradient(135deg, #f8fafc 0%, #e8f4f8 100%);
            min-height: 100vh;
        }

        .page-orders .main-content {
            padding: 20px;
        }

        .page-orders .header {
            margin-bottom: 30px;
            padding-bottom: 20px;
            border-bottom: 2px solid rgba(255,255,255,0.5);
        }

        .page-orders .header h1 {
            background: linear-gradient(135deg, #2563eb, #1d4ed8);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin: 0 0 15px 0;
            font-size: 28px;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        /* 统计面板 */
        .page-orders .stats-panel {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 15px;
            margin-bottom: 25px;
        }

        .page-orders .stat-card {
            background: white;
            border-radius: 12px;
            padding: 20px;
            box-shadow: 0 4px 6px rgba(0,0,0,0.05);
            border-left: 4px solid #2563eb;
            transition: transform 0.2s, box-shadow 0.2s;
        }

        .page-orders .stat-card:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 12px rgba(0,0,0,0.1);
        }

        .page-orders .stat-value {
            font-size: 28px;
            font-weight: 700;
            color: #1e293b;
            margin: 10px 0;
        }

        .page-orders .stat-label {
            font-size: 13px;
            color: #64748b;
            font-weight: 500;
            text-transform: uppercase;
        }

        .page-orders .stat-card.partial { border-left-color: #f59e0b; }
        .page-orders .stat-card.completed { border-left-color: #10b981; }

        /* 进度条样式 */
        .page-orders .progress-container { 
            height: 20px;
            background: #e2e8f0;
            border-radius: 12px;
            overflow: hidden;
            display: inline-block;
            vertical-align: middle;
            margin-right: 12px;
            width: 120px;
            box-shadow: inset 0 1px 3px rgba(0,0,0,0.05);
        }

        .page-orders .progress-bar { 
            height: 100%;
            background: linear-gradient(90deg, #10b981 0%, #059669 100%);
            transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
            box-shadow: 0 0 10px rgba(16, 185, 129, 0.5);
        }

        .page-orders .progress-text { 
            font-size: 13px;
            color: #1e293b;
            font-family: 'Plus Jakarta Sans', monospace;
            font-weight: 600;
            font-variant-numeric: tabular-nums;
        }

        .page-orders .missing-text { 
            color: #dc2626;
            font-weight: bold;
            font-size: 13px;
            background: #fee2e2;
            padding: 2px 8px;
            border-radius: 6px;
        }

        .page-orders .status-badge { 
            padding: 6px 12px;
            border-radius: 16px;
            font-size: 12px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .page-orders .status-processing { 
            background: linear-gradient(135deg, #dbeafe, #bfdbfe);
            color: #1e40af;
        }

        .page-orders .status-partial { 
            background: linear-gradient(135deg, #fef3c7, #fed7aa);
            color: #92400e;
        }

        .page-orders .status-completed { 
            background: linear-gradient(135deg, #dcfce7, #bbf7d0);
            color: #15803d;
        }

        .page-orders .pending-shipment-badge { 
            background: linear-gradient(135deg, #fee2e2, #fecaca);
            color: #991b1b;
            padding: 4px 10px;
            border-radius: 16px;
            font-size: 11px;
            font-weight: 600;
            margin-left: 10px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .page-orders .shipment-table { 
            width: 100%;
            font-size: 13px;
            background-color: #fff;
            border: 1px solid #e2e8f0;
            border-radius: 8px;
            overflow: hidden;
        }

        .page-orders .shipment-table th { 
            background-color: #f8fafc;
            font-weight: 600;
            padding: 12px;
            text-align: left;
            border-bottom: 1px solid #e2e8f0;
        }

        .page-orders .shipment-table td {
            padding: 12px;
            border-bottom: 1px solid #f0f0f0;
        }

        .page-orders .order-row { 
            cursor: pointer;
            transition: all 0.3s ease;
            background: white;
            border-bottom: 1px solid #e2e8f0;
        }

        .page-orders .order-row:hover { 
            background: #f8fafc;
        }

        .page-orders .detail-row { 
            display: none;
            background: #f9fafb;
            border: 1px solid #f0f0f0;
            animation: slideDown 0.3s ease;
        }

        .page-orders .detail-row.open { 
            display: table-row;
        }

        @keyframes slideDown {
            from {
                opacity: 0;
                max-height: 0;
            }
            to {
                opacity: 1;
                max-height: 1000px;
            }
        }

        .page-orders .receive-table { 
            width: 100%;
            border-collapse: collapse;
            margin-top: 10px;
        }

        .page-orders .receive-table th { 
            text-align: left;
            background: #f8fafc;
            padding: 12px;
            font-size: 13px;
            color: #64748b;
            font-weight: 600;
            border-bottom: 1px solid #e2e8f0;
        }

        .page-orders .receive-table td { 
            padding: 12px;
            border-bottom: 1px solid #f0f0f0;
            font-size: 13px;
        }

        .page-orders .receive-input { 
            width: 100%;
            max-width: 100px;
            padding: 8px;
            border: 2px solid #e2e8f0;
            border-radius: 6px;
            text-align: center;
            font-weight: 600;
            color: #2563eb;
            transition: all 0.2s;
        }

        .page-orders .receive-input:focus { 
            outline: none;
            border-color: #2563eb;
            box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
            background: #eff6ff;
        }

        /* 下单明细行的 grid 布局 */
        .page-orders .item-line { 
            display: grid;
            grid-template-columns: 2fr 1.2fr 0.8fr 1fr 1.5fr 1.5fr 40px;
            gap: 10px;
            align-items: center;
            margin-bottom: 12px;
            padding: 12px;
            background: #f9fafb;
            border-radius: 8px;
            border: 1px solid #e2e8f0;
            transition: all 0.2s;
        }

        .page-orders .item-line:hover {
            background: #f1f5f9;
            border-color: #cbd5e1;
        }

        .page-orders .item-line select, .page-orders .item-line input {
            padding: 8px;
            border: 1px solid #cbd5e1;
            border-radius: 6px;
            font-size: 13px;
            transition: all 0.2s;
        }

        .page-orders .item-line select:focus, .page-orders .item-line input:focus {
            outline: none;
            border-color: #2563eb;
            box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
        }

        .page-orders .filter-bar {
            background: white !important;
            border-radius: 12px !important;
            box-shadow: 0 4px 6px rgba(0,0,0,0.05) !important;
            border: none !important;
            pointer-events: auto !important;
        }

        .page-orders .filter-item {
            pointer-events: auto !important;
        }

        .page-orders .card {
            border-radius: 12px !important;
            box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important;
            border: none !important;
        }

        .page-orders .btn {
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            transition: all 0.3s;
            border-radius: 8px !important;
            border: none !important;
            cursor: pointer !important;
            display: inline-block;
            pointer-events: auto !important;
        }

        .page-orders .btn-primary {
            background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
            color: white !important;
        }

        .page-orders .btn-primary:hover:not(:disabled) {
            background: linear-gradient(135deg, #1d4ed8, #1e40af) !important;
            box-shadow: 0 4px 12px rgba(37, 99, 235, 0.4);
        }

        .page-orders .btn-success {
            background: linear-gradient(135deg, #10b981, #059669) !important;
            color: white !important;
        }

        .page-orders .btn-success:hover:not(:disabled) {
            background: linear-gradient(135deg, #059669, #047857) !important;
            box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4);
        }

        /* 快速筛选按钮交互效果 */
        .page-orders .quick-filter-btn {
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
            overflow: hidden;
        }

        .page-orders .quick-filter-btn:hover {
            background: linear-gradient(135deg, #e2e8f0, #cbd5e1) !important;
            transform: translateY(-2px);
            box-shadow: 0 6px 12px rgba(0, 0, 0, 0.12);
            color: #1e293b !important;
        }

        .page-orders .quick-filter-btn:active, .page-orders .quick-filter-btn.active {
            background: linear-gradient(135deg, #0f172a, #1e293b) !important;
            color: white !important;
            transform: translateY(0);
            box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
        }

        .page-orders .quick-filter-btn.active::after {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
            animation: shine 0.6s ease-in-out;
        }

        @keyframes shine {
            0% { transform: translateX(-100%); }
            100% { transform: translateX(100%); }
        }

        .page-orders .btn-danger {
            background: linear-gradient(135deg, #ef4444, #dc2626) !important;
            color: white !important;
        }

        .page-orders .btn-danger:hover:not(:disabled) {
            background: linear-gradient(135deg, #dc2626, #b91c1c) !important;
            box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
        }

        .page-orders .expand-icon {
            transition: transform 0.3s ease;
            color: #94a3b8;
        }

        .page-orders .expand-icon.open {
            transform: rotate(90deg);
        }

        /* Modal 美化 */
        .page-orders .modal-content {
            border-radius: 16px !important;
            box-shadow: 0 20px 60px rgba(0,0,0,0.15) !important;
            animation: modalSlideIn 0.3s ease;
        }

        @keyframes modalSlideIn {
            from {
                opacity: 0;
                transform: scale(0.95);
            }
            to {
                opacity: 1;
                transform: scale(1);
            }
        }

        .page-orders .detail-table {
            width: 100% !important;
            border-collapse: collapse;
        }

        .page-orders .detail-table th {
            background: #f8fafc;
            padding: 10px;
            font-weight: 600;
            border-bottom: 1px solid #e2e8f0;
            font-size: 13px;
        }

        .page-orders .detail-table td {
            padding: 10px;
            border-bottom: 1px solid #f0f0f0;
            font-size: 13px;
        }

        .page-orders .detail-table tbody tr:hover {
            background-color: #f9fafb;
        }


/* Page: client/operation.html */
.page-operation .modal { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); align-items: center; justify-content: center; z-index: 9999; }
        .page-operation .modal-content { background: white; padding: 25px; border-radius: 12px; width: 500px; box-shadow: 0 4px 20px rgba(0,0,0,0.2); }
        .page-operation .select2-container { width: 100% !important; }
        .page-operation .select2-selection { height: 40px !important; display: flex; align-items: center; border: 1px solid #E2E8F0 !important; }

        /* 库存数字样式 */
        .page-operation .stock-num { font-weight: bold; font-size: 15px; }
        .page-operation .stock-high { color: var(--success); }
        .page-operation .stock-mid { color: #D97706; }
        .page-operation .stock-zero { color: #EF4444; background: #FEF2F2; padding: 2px 8px; border-radius: 4px; }
        
        /* 统计卡片 */
        .page-operation .stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 20px; }
        .page-operation .stat-card { background: white; padding: 20px; border-radius: 12px; border: 1px solid var(--border); box-shadow: var(--shadow-sm); display: flex; align-items: center; gap: 15px; }
        .page-operation .stat-icon { width: 50px; height: 50px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 24px; }




/* Page: client/settings.html */
.page-settings .setting-section { background: white; border-radius: 12px; border: 1px solid var(--border); margin-bottom: 14px; overflow: hidden; box-shadow: var(--shadow-card); }
    .page-settings .main-content { max-width: 1200px; margin: 0 auto; padding-top: 24px; }
    .page-settings .header h1 { font-size: 28px; letter-spacing: -0.3px; }
    .page-settings .section-title { font-size: 16px; font-weight: bold; margin: 0; display: flex; align-items: center; gap: 10px; padding: 18px 22px; cursor: pointer; user-select: none; background: #F8FAFC; }
    .page-settings .setting-section.expanded .section-title { border-bottom: 1px solid #eee; background: #EFF6FF; }
    .page-settings .setting-card-body { display: none; padding: 20px 24px 24px; }
    .page-settings .setting-section.expanded .setting-card-body { display: block; }
    .page-settings .collapse-indicator { margin-left: auto; font-size: 14px; color: #94A3B8; transition: transform 0.2s ease; }
    .page-settings .setting-section.expanded .collapse-indicator { transform: rotate(180deg); }
    .page-settings .section-title:focus-visible { outline: 2px solid #93C5FD; outline-offset: -2px; }
        
        .page-settings .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
        .page-settings .form-group label { display: block; font-size: 13px; font-weight: bold; color: var(--text-sub); margin-bottom: 8px; }
    .page-settings .form-group input,
    .page-settings .form-group select { width: 100%; height: 40px; padding: 0 12px; border: 1px solid #E2E8F0; border-radius: 8px; background: #FFF; font-size: 14px; color: var(--text-main); }
    .page-settings .form-group input:focus,
    .page-settings .form-group select:focus { border-color: var(--accent-color); outline: none; box-shadow: 0 0 0 3px rgba(59,130,246,0.08); }
    .page-settings .setting-card-body h4 { margin: 0 0 12px; font-size: 15px; color: #0F172A; font-weight: 700; }
    .page-settings .setting-card-body p,
    .page-settings .setting-card-body small,
    .page-settings .setting-card-body li { font-size: 13px; line-height: 1.6; }
    .page-settings .full-span { grid-column: span 2; }
    .page-settings .muted-text { color:#666; margin-bottom:15px; font-size:13px; }
    .page-settings .provider-box { background:#EFF6FF; border:1px solid #93C5FD; padding:12px; border-radius:8px; margin-bottom:20px; }
    .page-settings .provider-options { display:flex; gap:20px; align-items:center; }
    .page-settings .provider-option { display:flex; align-items:center; gap:8px; cursor:pointer; font-weight:700; }
    .page-settings .provider-link-twilio { color:#0284c7; }
    .page-settings .provider-link-aliyun { color:#ff6e1a; }
    .page-settings .form-grid-2 { grid-template-columns: 1fr 1fr; }
    .page-settings .form-grid-3 { grid-template-columns: 1fr 1fr 1fr; }
    .page-settings .form-grid-4 { grid-template-columns: 1fr 1fr 1fr 1fr; }
    .page-settings .mono-input { font-family: monospace; font-size:12px; }
    .page-settings .hint-text { color:#666; display:block; margin-top:4px; }
    .page-settings .optional-label { color:#999; font-weight:normal; }
    .page-settings .test-row { display:flex; gap:8px; align-items:center; }
    .page-settings .test-input { flex:1; }
    .page-settings .test-btn { color:white; padding:8px 12px; white-space:nowrap; font-size:12px; }
    .page-settings .test-btn.twilio { background:#3b82f6; }
    .page-settings .test-btn.aliyun { background:#ff6e1a; }
    .page-settings .status-box { background:#f0fdf4; border:1px solid #86efac; padding:12px; border-radius:8px; margin-top:15px; }
    .page-settings .status-text { margin:0; color:#166534; font-size:13px; }
    .page-settings .status-value { font-weight:bold; color:#dc2626; }
    .page-settings .sub-section { margin-bottom: 25px; }
    .page-settings .sub-section-bordered { margin-bottom: 15px; padding-bottom: 20px; border-bottom: 1px solid #e0e0e0; }
    .page-settings .preview-text { color:#666; display:block; margin-top:8px; }
    .page-settings .info-box { background:#F0F7FF; padding:15px; border-radius:8px; border-left:4px solid #3B82F6; }
    .page-settings .info-title { color:#0050b3; }
    .page-settings .info-list { margin:8px 0; padding-left:20px; font-size:13px; color:#333; }
    .page-settings .reset-row { display:flex; justify-content: space-between; align-items: flex-start; }
    .page-settings .reset-row.with-divider { margin-bottom: 20px; border-bottom:1px dashed #FECACA; padding-bottom:20px; }
    .page-settings .reset-title { margin:0 0 5px 0; color:#991B1B; }
    .page-settings .danger-hint { background:#FEE2E2; padding:2px 5px; border-radius:4px; }

        /* 危险区域 */
        .page-settings .danger-zone { border: 1px solid #FECACA; background: #FEF2F2; }
        .page-settings .danger-zone .section-title { color: #DC2626; border-color: #FECACA; }
        .page-settings .danger-btn { background: #DC2626; color: white; border: none; padding: 10px 20px; border-radius: 6px; cursor: pointer; transition: background 0.2s; }
        .page-settings .danger-btn:hover { background: #B91C1C; }
        .page-settings .danger-desc { font-size: 13px; color: #7F1D1D; margin-bottom: 15px; line-height: 1.6; }


/* Page: client/users.html */
.page-users .modal-content {
            box-shadow: 0 10px 25px rgba(0,0,0,0.1);
            transition: all 0.3s ease;
        }
        .page-users .modal-content h3 {
            border-bottom: 1px solid #f0f0f0;
            padding-bottom: 15px;
            margin-bottom: 20px;
            font-size: 18px;
            color: #333;
        }
        .page-users .permission-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 12px;
            background-color: #F8FAFC;
            padding: 15px;
            border-radius: 8px;
            border: 1px solid #E2E8F0;
            margin-bottom: 20px;
        }
        .page-users .permission-grid label {
            display: flex;
            align-items: center;
            padding: 8px;
            border-radius: 6px;
            transition: background-color 0.2s;
            cursor: pointer;
        }
        .page-users .permission-grid label:hover {
            background-color: #EFF6FF;
        }
        .page-users .permission-grid input[type="checkbox"] {
            margin-right: 10px;
            width: 16px;
            height: 16px;
        }
        .page-users .danger-permission {
            color: #EF4444;
            font-weight: bold;
        }


/* Page: server/index.html */
.page-server-index { font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif; background: #f0f2f5; margin: 0; padding: 20px; color: #333; display: block; height: auto; overflow: auto; }
        
        /* 布局网格 */
        .page-server-index .layout { display: grid; grid-template-columns: 280px 1fr 300px; gap: 20px; align-items: start; }
        
        /* 卡片样式 */
        .page-server-index .card { background: white; border-radius: 8px; box-shadow: 0 2px 6px rgba(0,0,0,0.08); padding: 15px; margin-bottom: 20px; }
        .page-server-index h3 { margin: 0 0 15px 0; font-size: 16px; border-left: 4px solid #1890ff; padding-left: 10px; display: flex; justify-content: space-between; align-items: center; }
        
        /* 表格 */
        .page-server-index table { width: 100%; border-collapse: collapse; font-size: 13px; }
        .page-server-index th, .page-server-index td { padding: 8px 5px; border-bottom: 1px solid #eee; text-align: left; }
        .page-server-index th { background: #fafafa; color: #666; }
        
        /* 按钮 */
        .page-server-index .btn { border: none; padding: 6px 12px; border-radius: 4px; cursor: pointer; color: white; font-size: 12px; transition: 0.2s; }
        .page-server-index .btn-primary { background: #1890ff; }
        .page-server-index .btn-success { background: #52c41a; }
        .page-server-index .btn-warning { background: #faad14; color: #333; }
        .page-server-index .btn-danger { background: #ff4d4f; }
        .page-server-index .btn-outline { background: transparent; border: 1px solid #1890ff; color: #1890ff; }
        .page-server-index .btn-outline:hover { background: #e6f7ff; }

        /* 输入框 */
        .page-server-index input, .page-server-index select { width: 100%; padding: 6px; margin-bottom: 5px; border: 1px solid #d9d9d9; border-radius: 4px; box-sizing: border-box; }

        /* 弹窗遮罩 */
        .page-server-index .modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); display: none; align-items: center; justify-content: center; z-index: 100; }
        .page-server-index .modal { background: white; width: 500px; padding: 20px; border-radius: 8px; box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
        
        .page-server-index .stock-tag { background: #e6f7ff; color: #1890ff; padding: 2px 6px; border-radius: 4px; font-weight: bold; }

/* =========================================
   🎬 加载动画
   ========================================= */
@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* =========================================
   📱 响应式设计 - 小屏幕适配
   ========================================= */

/* 小屏幕优化（768px以下）*/
@media (max-width: 768px) {
    body {
        flex-direction: column;
        overflow: hidden;
    }
    
    .sidebar {
        width: 100%;
        max-height: 35vh;
        border-right: none;
        border-bottom: 1px solid var(--border);
        padding: 16px 8px;
    }
    
    .sidebar h2 {
        margin: 0 0 16px 8px;
        font-size: 16px;
    }
    
    .sidebar a {
        padding: 10px 12px;
        font-size: 13px;
        margin-bottom: 2px;
        gap: 10px;
    }
    
    .sidebar a i {
        font-size: 16px;
    }
    
    .main-content {
        width: 100%;
        height: 65vh;
        padding: 16px 12px;
        flex: 0 0 auto;
    }
    
    .header h1 {
        font-size: 20px;
    }
}

/* 超小屏幕优化（480px以下）*/
@media (max-width: 480px) {
    .sidebar {
        max-height: 30vh;
        padding: 12px 6px;
    }
    
    .sidebar h2 {
        font-size: 14px;
        margin: 0 0 12px 6px;
    }
    
    .sidebar a {
        padding: 8px 10px;
        font-size: 12px;
        gap: 8px;
    }
    
    .sidebar a i {
        font-size: 14px;
    }
    
    .main-content {
        height: 70vh;
        padding: 12px 8px;
    }
}

/* ===== Select2 下拉框宽度优化 ===== */
.inbound-scope-dropdown {
    min-width: 700px !important;
    width: 700px !important;
}

.inbound-scope-dropdown .select2-results__option {
    white-space: nowrap;
    padding: 8px 12px;
    user-select: text !important;
    -webkit-user-select: text !important;
    -moz-user-select: text !important;
    -ms-user-select: text !important;
}

.inbound-scope-dropdown .select2-results__group {
    white-space: nowrap;
    padding: 8px 12px;
    user-select: text !important;
    -webkit-user-select: text !important;
    -moz-user-select: text !important;
    -ms-user-select: text !important;
}

.inbound-scope-dropdown .select2-rendered {
    user-select: text !important;
    -webkit-user-select: text !important;
    -moz-user-select: text !important;
    -ms-user-select: text !important;
}

.select2-container .select2-selection--single .select2-selection__rendered {
    user-select: text !important;
    -webkit-user-select: text !important;
    -moz-user-select: text !important;
    -ms-user-select: text !important;
}
