/**
 * 佳誉 ERP 2.0 — 表单、按钮、卡片、Loading、业务页模块（非 Modal、非 ui_tables 纯表格）
 */


/* ==================== 表单与紧凑布局 ==================== */
.erp-card-compact {
    padding: var(--erp-card-padding, 1.25rem);
    background: #fff;
    border: 1px solid var(--erp-table-border, #E9ECEF);
    border-radius: 8px;
}
.erp-input-compact input,
.erp-input-compact select {
    height: var(--erp-input-height-compact, 32px);
    min-height: var(--erp-input-height-compact, 32px);
    font-size: var(--erp-list-font-size, 13px);
}
.erp-modal-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
}
.erp-modal-form-grid .erp-field-full { grid-column: 1 / -1; }
.erp-modal-form-grid label { font-size: 13px; color: #333; font-weight: 500; margin-bottom: 4px; display: block; }

/* ==================== 表单通用布局：Label 上、Input 下 ==================== */
.erp-form-vertical .erp-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
    margin-bottom: 12px;
}
.erp-form-vertical .erp-form-row-full {
    grid-column: 1 / -1;
}
.erp-form-vertical .erp-field {
    display: flex;
    flex-direction: column;
}
.erp-form-vertical .erp-field label {
    font-size: 13px;
    color: #374151;
    font-weight: 500;
    margin-bottom: 4px;
}
.erp-form-vertical .erp-field input,
.erp-form-vertical .erp-field select,
.erp-form-vertical .erp-field textarea {
    padding: 6px 10px;
    border-radius: 6px;
    border: 1px solid #d1d5db;
    font-size: 13px;
    min-height: 32px;
}
.erp-form-vertical .erp-field textarea {
    resize: vertical;
}

/* ==================== 基础设置页面：Card + Grid 布局 ==================== */
.erp-page-base {
    padding: 18px 20px;
}
.erp-card-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.erp-card {
    background: #ffffff;
    border-radius: 10px;
    border: 1px solid #E5E7EB;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.erp-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
}
.erp-card-title {
    font-size: 15px;
    font-weight: 600;
    color: #111827;
}
.erp-card-subtitle {
    font-size: 12px;
    color: #6B7280;
}
.erp-card-actions {
    display: flex;
    align-items: center;
    gap: 6px;
}

/* ==================== 通用按钮样式：渐变 Hover + Active 缩放 ==================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 6px 14px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 0.18s ease, box-shadow 0.18s ease, transform 0.08s ease, border-color 0.18s ease;
}
.btn-sm {
    padding: 4px 10px;
    font-size: 12px;
}
.btn-primary,
.btn-success {
    background-image: linear-gradient(135deg, #16a34a 0%, #0f766e 100%);
    color: #ffffff;
    border-color: #16a34a;
}
.btn-outline-primary {
    background: #ecfdf3;
    color: #16a34a;
    border-color: #bbf7d0;
}
.btn-outline-secondary {
    background: #f9fafb;
    color: #4b5563;
    border-color: #e5e7eb;
}
.btn:hover {
    box-shadow: 0 6px 16px rgba(15, 118, 110, 0.25);
    transform: translateY(-1px);
}
.btn:active {
    transform: scale(0.97);
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
}

/* ========= 按钮 Loading 状态 ========= */
.btn.is-loading {
    position: relative;
    pointer-events: none;
    color: transparent !important;
}
.btn.is-loading::after {
    content: '';
    position: absolute;
    width: 14px;
    height: 14px;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, 0.6);
    border-top-color: rgba(255, 255, 255, 1);
    animation: erp-spin 0.7s linear infinite;
}

/* ==================== AJAX Loading 遮罩（防止重复点击） ==================== */
.erp-loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255, 255, 255, 0.85);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
}
.erp-loading-overlay.erp-loading-active {
    opacity: 1;
    visibility: visible;
}
.erp-loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid #E9ECEF;
    border-top-color: #10B981;
    border-radius: 50%;
    animation: erp-spin 0.8s linear infinite;
}
.erp-loading-text {
    margin-top: 12px;
    font-size: 13px;
    color: #333;
}
@keyframes erp-spin {
    to { transform: rotate(360deg); }
}

/* ==================== 基础设置统一规范 (Unified Base Settings) ==================== */
/* 容器：所有设置项必须包裹在 .card 白色卡片中 */
.card {
    background: #ffffff;
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    padding: 24px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}
.admin-page-wrap {
    padding: 18px 20px;
}
.admin-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 16px;
    margin-bottom: 16px;
    border-bottom: 1px solid #f0f0f0;
}
.admin-page-title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #333;
}
.admin-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}
.admin-toolbar .admin-input { width: 200px; }

/* 表单规范 (Unified Form)：输入框 32px/40px，Label #555 14px，placeholder，focus 边框 #1890ff */
.admin-form .admin-form-row {
    margin-bottom: 16px;
}
.admin-form .admin-form-row:last-of-type { margin-bottom: 0; }
.admin-form label,
.admin-form .admin-form-label {
    display: block;
    font-size: 14px;
    color: #555;
    font-weight: 500;
    margin-bottom: 6px;
}
.admin-form input[type="text"],
.admin-form input[type="number"],
.admin-form select,
.admin-form textarea,
.admin-input {
    width: 100%;
    height: 32px;
    min-height: 32px;
    padding: 4px 10px;
    font-size: 14px;
    color: #333;
    border: 1px solid #d9d9d9;
    border-radius: 4px;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
}
.admin-form input.admin-input-lg,
.admin-form select.admin-input-lg,
.admin-input-lg {
    height: 40px;
    min-height: 40px;
    padding: 6px 12px;
}
.admin-form input::placeholder,
.admin-form textarea::placeholder { color: #bfbfbf; }
.admin-form input:focus,
.admin-form select:focus,
.admin-form textarea:focus,
.admin-input:focus {
    border-color: #1890ff;
    box-shadow: 0 0 0 2px rgba(24, 144, 255, 0.2);
}
.admin-form textarea {
    height: auto;
    min-height: 60px;
    resize: vertical;
}
.admin-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.admin-form-grid .admin-form-full { grid-column: 1 / -1; }
.admin-form-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 16px;
}

/* 按钮规范 (Action Buttons)：主 #1890ff，次 白底灰框，危险 #ff4d4f，0.3s 过渡 */
.btn-admin-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 6px 16px;
    height: 32px;
    font-size: 14px;
    font-weight: 500;
    color: #ffffff;
    background: #1890ff;
    border: 1px solid #1890ff;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s, border-color 0.3s, color 0.3s;
}
.btn-admin-primary:hover {
    background: #40a9ff;
    border-color: #40a9ff;
    color: #fff;
}
.btn-admin-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 6px 16px;
    height: 32px;
    font-size: 14px;
    font-weight: 500;
    color: #333;
    background: #ffffff;
    border: 1px solid #d9d9d9;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s, border-color 0.3s, color 0.3s;
}
.btn-admin-secondary:hover {
    color: #1890ff;
    border-color: #1890ff;
}
.btn-admin-danger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 6px 16px;
    height: 32px;
    font-size: 14px;
    font-weight: 500;
    color: #ffffff;
    background: #ff4d4f;
    border: 1px solid #ff4d4f;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s, border-color 0.3s, color 0.3s;
}
.btn-admin-danger:hover {
    background: #ff7875;
    border-color: #ff7875;
    color: #fff;
}
.btn-admin-sm {
    padding: 4px 12px;
    height: 28px;
    font-size: 13px;
}



.text-danger { color: #ff4d4f; }
.admin-desc {
    margin-bottom: 12px;
    font-weight: 400;
    font-size: 14px;
    color: #555;
}
.erp-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
}
.erp-card-icon { font-size: 20px; }
.admin-page-title.admin-page-title-top { margin-bottom: 8px; }
.admin-desc.admin-desc-top { margin-bottom: 18px; }

/* ==================== Standard UI Components (Personnel Management Standard) ==================== */
/* 佳誉 ERP 2.0 全局 UI 视觉样板。选择器已加强，优先于 design-system 等全局样式。 */

/* 页面骨架：全屏浅灰背景 */
.standard-page {
    min-height: 100vh;
    background: #f0f2f5;
}

/* 容器：内外边距 24px */
.standard-page .standard-container {
    padding: 24px;
}

/* 卡片化：白底、圆角 8px、无边框、极轻投影 */
.standard-page .erp-card {
    background: #ffffff;
    border-radius: 8px;
    border: none;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.03);
    padding: 24px;
}

/* 顶部工具栏：标题左 + 主按钮右 */
.standard-page .standard-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}
.permission-map-page .perm-modal-hint {
    margin: 0 0 8px 0;
    font-size: 12px;
}
.standard-page .standard-title {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: #333;
}
.standard-page .standard-desc {
    margin: 0 0 16px 0;
    font-size: 14px;
    color: #555;
}
/* 主按钮：强制蓝底白字，覆盖 .btn / .btn-success 等 */
.standard-page button.standard-btn-primary,
.standard-page .standard-btn-primary,
button.standard-btn-primary {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    height: 32px !important;
    padding: 0 16px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #fff !important;
    background: #1890ff !important;
    border: none !important;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s, border-color 0.2s;
    box-shadow: none !important;
    transform: none !important;
}
.standard-page button.standard-btn-primary:hover,
.standard-page .standard-btn-primary:hover,
button.standard-btn-primary:hover {
    background: #40a9ff !important;
    color: #fff !important;
}

/* 筛选区：Flex 布局，输入/选择 32px 高，边框 #d9d9d9，Focus #1890ff + 淡蓝光晕 */
.standard-page .standard-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}
.standard-page .standard-input,
.standard-page .standard-select,
.standard-modal .standard-input,
.standard-modal .standard-select {
    height: 32px !important;
    padding: 4px 11px;
    font-size: 14px;
    color: #333;
    background: #fff !important;
    border: 1px solid #d9d9d9 !important;
    border-radius: 4px;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
}
.standard-page .standard-input {
    width: 200px;
    min-width: 120px;
}
.standard-page .standard-input::placeholder {
    color: #bfbfbf;
}
.standard-page .standard-input:focus,
.standard-page .standard-select:focus,
.standard-modal .standard-input:focus,
.standard-modal .standard-select:focus {
    border-color: #1890ff !important;
    box-shadow: 0 0 0 2px rgba(24, 144, 255, 0.2) !important;
}
.standard-page .standard-select {
    min-width: 120px;
}


/* 信息提示框：统一蓝色 info-box，用于显性化业务链路说明 */
.info-box {
    margin: 8px 0;
    padding: 10px 12px;
    border-radius: 6px;
    border: 1px solid #bfdbfe;
    background: #eff6ff;
    color: #1e40af;
    font-size: 13px;
    line-height: 1.6;
}
.info-box strong {
    color: #1e3a8a;
}


/* 页面内表单（非弹窗）：standard-page .erp-card .standard-form */
.standard-page .erp-card .standard-form .standard-form-row {
    margin-bottom: 14px;
}
.standard-page .erp-card .standard-form .standard-form-row:last-of-type {
    margin-bottom: 0;
}
.standard-page .erp-card .standard-form label {
    display: block;
    font-size: 14px;
    color: #333;
    font-weight: 500;
    margin-bottom: 6px;
}
.standard-page .erp-card .standard-form .standard-input,
.standard-page .erp-card .standard-form .standard-select {
    width: 100%;
    max-width: 320px;
}
.standard-page .erp-card .standard-form .standard-select.standard-select-w220 {
    min-width: 220px;
    max-width: 320px;
}
.standard-page .erp-card .standard-form .standard-input.standard-input-w200 {
    width: 200px;
    max-width: 200px;
}
.standard-page .erp-card .standard-form .standard-input.standard-input-w160 {
    width: 160px;
    max-width: 160px;
}
.standard-page .erp-card .standard-form textarea.standard-input {
    min-height: 60px;
    resize: vertical;
    max-width: 400px;
}
.standard-page .erp-card .standard-form-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 20px;
}
.standard-form-hint {
    font-size: 13px;
    color: #666;
    margin: 6px 0 0 0;
}
.standard-form-hint strong {
    color: #333;
}
.erp-card.erp-card-form-w720 {
    max-width: 720px;
}

/* 样衣邮寄-新增：多选颜色、尺码件数区域 */
.sample-ship-multi-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    align-items: center;
}
.sample-ship-multi-wrap label {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: normal;
    cursor: pointer;
}
.sample-ship-multi-wrap label input[type="checkbox"] {
    margin: 0;
}
.sample-ship-size-row {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.sample-ship-size-row input[type="number"] {
    width: 64px;
}

/* 表单横排：多列网格，能横排的字段同一行 */
.standard-page .erp-card .standard-form .standard-form-inline-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px 24px;
    margin-bottom: 14px;
    align-items: start;
}
.standard-page .erp-card .standard-form .standard-form-inline-row .standard-form-row {
    margin-bottom: 0;
}
.standard-page .erp-card .standard-form .standard-form-inline-row .standard-input,
.standard-page .erp-card .standard-form .standard-form-inline-row .standard-select {
    width: 100%;
    max-width: none;
}
.standard-page .erp-card .standard-form .standard-form-inline-row-2 {
    grid-template-columns: repeat(2, 1fr);
}

/* 样衣邮寄新增页：紧凑布局，无说明文案 */
.sample-ship-create-card .standard-header {
    margin-bottom: 12px;
}
.sample-ship-create-card .standard-form .standard-form-row {
    margin-bottom: 10px;
}
.sample-ship-create-card .standard-form .standard-form-inline-row {
    margin-bottom: 10px;
    gap: 10px 20px;
}
.sample-ship-create-card .standard-form label {
    margin-bottom: 4px;
}
.sample-ship-create-card .standard-form-hint {
    margin-top: 4px;
}
.sample-ship-create-card .standard-form-actions {
    margin-top: 14px;
}

/* ==========================================================================
   Standard UI Components (Personnel Management Standard)
   Author: Jiayu ERP 2.0 Team
   ========================================================================== */

/* 1. Layout & Containers */
.standard-page {
    background: #f0f2f5;
    min-height: 100vh;
    width: 100%;
}
.standard-container {
    padding: 24px;
}
.erp-card {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.03);
    padding: 24px;
    border: none;
}

/* 2. Header & Filter System */
.standard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}
.standard-title {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: #333;
}
.standard-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

/* 3. Forms & Inputs */
.standard-input, .standard-select {
    height: 32px;
    padding: 4px 11px;
    font-size: 14px;
    border: 1px solid #d9d9d9;
    border-radius: 4px;
    transition: all 0.3s;
}
.standard-input:focus, .standard-select:focus {
    border-color: #40a9ff;
    box-shadow: 0 0 0 2px rgba(24, 144, 255, 0.2);
    outline: 0;
}

/* 4. Standard Table System */
.standard-table-wrap {
    overflow-x: auto;
}
.standard-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    border: 1px solid #e8e8e8;
}
.standard-table th {
    background: #fafafa;
    color: #555;
    font-weight: 600;
    padding: 14px 16px;
    border: 1px solid #e8e8e8;
    text-align: center;
}
.standard-table td {
    padding: 0 16px;
    height: 54px;
    border: 1px solid #e8e8e8;
    text-align: center;
    color: #333;
    vertical-align: middle;
}
.standard-table tbody tr:hover {
    background-color: #fafafa;
}

/* 5. Buttons (Primary & Secondary) */
.standard-btn-primary {
    background: #1890ff;
    color: #fff;
    border: none;
    height: 32px;
    padding: 0 15px;
    border-radius: 4px;
    cursor: pointer;
    transition: background 0.3s;
}
.standard-btn-primary:hover { background: #40a9ff; }

.standard-btn-secondary {
    background: #fff;
    border: 1px solid #d9d9d9;
    color: #333;
    height: 32px;
    padding: 0 15px;
    border-radius: 4px;
    cursor: pointer;
}
.standard-btn-secondary:hover { border-color: #1890ff; color: #1890ff; }


/* 7. Tags (Status) */
.standard-tag {
    display: inline-block;
    padding: 0 8px;
    height: 22px;
    line-height: 22px;
    font-size: 12px;
    border-radius: 999px;
    border: 1px solid;
}
.standard-tag-success { background: #f6ffed; color: #52c41a; border-color: #b7eb8f; }
.standard-tag-default { background: #fafafa; color: #666; border-color: #e8e8e8; }


/* ==================== 订单导入向导 (Order Import Wizard) ==================== */
.order-import-block { margin-bottom: 24px; }
.order-import-wizard { display: flex; flex-direction: column; gap: 16px; }
.order-import-compact { display: flex; flex-direction: column; gap: 12px; }
/* 佳誉品牌色：深蓝主色、暖色强调 */
.order-import-block { --order-brand: #1e3a5f; --order-brand-light: #2d4a6f; --order-accent: #c45c26; --order-accent-light: #e8a87a; --order-bg-subtle: #f8fafc; --order-shadow: 0 1px 3px rgba(30, 58, 95, 0.06); --order-radius: 8px; }
.order-import-step-card {
    background: #fff;
    border-radius: var(--order-radius);
    box-shadow: var(--order-shadow);
    padding: 16px 20px;
    border: 1px solid rgba(30, 58, 95, 0.08);
}
.order-import-step-title { font-size: 13px; font-weight: 600; color: var(--order-brand); margin: 0 0 12px 0; display: flex; align-items: center; gap: 6px; }
.order-import-step-title .step-num { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 50%; background: var(--order-brand); color: #fff; font-size: 12px; font-weight: 700; }
/* Step1: 表头横向 */
.order-import-header-row { display: flex; flex-wrap: wrap; align-items: center; gap: 16px 24px; }
.order-import-header-row .standard-form-row { margin: 0; display: flex; align-items: center; gap: 8px; }
.order-import-header-row label { min-width: 56px; font-size: 13px; color: #475569; }
.order-import-header-row label.required::after { content: ' *'; color: #dc2626; }
.order-import-header-row .standard-select { min-width: 160px; }
.order-import-header-row .standard-input { width: 140px; }
/* Step2: 交期管理器紧凑 */
.order-import-delivery-header { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.order-import-delivery-header .order-import-step-title { margin: 0; }
.order-import-delivery-title { font-size: 13px; font-weight: 600; color: var(--order-brand); }
.order-import-tooltip-wrap { position: relative; display: inline-flex; }
.order-import-tooltip-icon { width: 18px; height: 18px; border-radius: 50%; background: #cbd5e1; color: #475569; font-size: 11px; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; cursor: help; border: none; padding: 0; line-height: 1; }
.order-import-tooltip-icon:hover { background: var(--order-brand); color: #fff; }
.order-import-tooltip-icon:hover + .order-import-tooltip-content { opacity: 1; visibility: visible; }
.order-import-tooltip-content { position: absolute; left: 100%; top: 50%; transform: translateY(-50%); margin-left: 8px; padding: 10px 14px; background: #1e293b; color: #f1f5f9; font-size: 12px; line-height: 1.5; border-radius: 6px; white-space: normal; max-width: 320px; z-index: 100; opacity: 0; visibility: hidden; transition: opacity 0.2s, visibility 0.2s; box-shadow: 0 4px 12px rgba(0,0,0,0.2); }
.order-import-tooltip-content::before { content: ''; position: absolute; right: 100%; top: 50%; transform: translateY(-50%); border: 6px solid transparent; border-right-color: #1e293b; }
.order-batch-list { display: flex; flex-direction: column; gap: 8px; }
.order-batch-compact { display: flex; align-items: center; gap: 12px; padding: 8px 12px; background: var(--order-bg-subtle); border-radius: 6px; border: 1px solid #e2e8f0; }
.order-batch-compact label { font-size: 12px; color: #64748b; white-space: nowrap; min-width: 90px; }
.order-batch-compact .batch-deadline { width: 140px; }
.order-batch-compact .batch-column { width: 140px; }
.order-batch-compact .batch-del { font-size: 12px; color: #dc2626; cursor: pointer; background: none; border: none; padding: 0 4px; }
.order-batch-compact .batch-del:hover { text-decoration: underline; }
.order-btn-add-batch { font-size: 12px; color: var(--order-brand); background: none; border: 1px dashed var(--order-brand); border-radius: 6px; padding: 6px 12px; cursor: pointer; }
.order-btn-add-batch:hover { background: rgba(30, 58, 95, 0.06); }
/* Step3: 上传区 + 提交 */
.order-import-upload-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.order-import-upload-row label { min-width: 56px; font-size: 13px; color: #475569; }
.order-import-upload-inline { display: inline-flex !important; align-items: center; gap: 8px; }
.order-import-upload-row .standard-btn-secondary { height: 32px; padding: 0 14px; }
.order-import-upload-row .standard-btn-secondary:disabled { opacity: 0.65; cursor: not-allowed; }
.order-import-upload-row .standard-btn-secondary.pseudo-disabled { opacity: 0.75; }
.order-upload-file-name { font-size: 13px; color: #64748b; }
.order-import-drop-zone {
    border: 2px dashed #cbd5e1;
    border-radius: var(--order-radius);
    background: var(--order-bg-subtle);
    padding: 28px 24px;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}
.order-import-drop-zone:hover, .order-import-drop-zone.dragover { border-color: var(--order-brand); background: rgba(30, 58, 95, 0.04); }
.order-import-drop-zone.order-drop-zone-disabled { opacity: 0.65; cursor: not-allowed; background: #e2e8f0; }
.order-preview-caption { font-size: 13px; color: #475569; margin-bottom: 8px; }
.order-preview-caption strong { color: var(--order-brand, #1e3a5f); }
.order-import-drop-zone .drop-text { font-size: 14px; color: #475569; margin: 0; }
.order-import-drop-zone .drop-hint { font-size: 12px; color: #94a3b8; margin-top: 6px; }
.order-import-submit-wrap { margin-top: 20px; display: flex; justify-content: center; }
.order-import-submit-btn {
    min-width: 180px;
    padding: 12px 24px;
    font-size: 15px;
    font-weight: 600;
    border-radius: var(--order-radius);
    border: none;
    background: linear-gradient(180deg, var(--order-accent) 0%, #a84a1e 100%);
    color: #fff;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(196, 92, 38, 0.35);
    transition: transform 0.05s, box-shadow 0.2s;
}
.order-import-submit-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(196, 92, 38, 0.4); }
.order-import-submit-btn:disabled { opacity: 0.7; cursor: not-allowed; }
.order-import-submit-btn.loading { pointer-events: none; }
.order-import-submit-btn .btn-text { display: inline; }
.order-import-submit-btn.loading .btn-text { display: none; }
.order-import-submit-btn .btn-loading { display: none; align-items: center; justify-content: center; gap: 8px; }
.order-import-submit-btn.loading .btn-loading { display: inline-flex; }
.order-import-help-link { font-size: 12px; color: #64748b; margin-top: 8px; display: inline-block; }
.order-import-help-link:hover { color: var(--order-brand); }
.order-preview-detail-link-wrap { margin-bottom: 8px; }
.order-preview-detail-link-wrap .standard-table-link { font-weight: 600; }
.order-import-price-lock-tag { margin-left: 8px; font-size: 12px; color: #15803d; white-space: nowrap; }
.order-deadline-1 { color: #15803d; font-weight: 600; }
.order-deadline-2 { color: #b45309; font-weight: 600; }
.order-deadline-3 { color: #7c3aed; font-weight: 600; }
.order-deadline-4 { color: #be123c; font-weight: 600; }

/* ==================== 报价测算：历史记录卡片规范 ==================== */
.quote-history-card {
    margin-top: 12px;
    padding: 14px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
}
.quote-history-header {
    margin-bottom: 10px;
}
.quote-history-title {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
}
.quote-history-desc {
    margin: 0 0 10px 0;
    font-size: 13px;
    color: #64748b;
}
.quote-history-table-wrap {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
}
.quote-history-table th,
.quote-history-table td {
    height: 44px;
    padding-top: 0;
    padding-bottom: 0;
    vertical-align: middle;
}
.quote-history-link-danger {
    margin-left: 10px;
    color: #dc2626 !important;
}
.quote-history-link-danger:hover {
    color: #b91c1c !important;
}
.quote-history-card .standard-btn-primary {
    height: 32px;
    min-height: 32px;
    padding: 0 14px !important;
}



/* ==================== 权限映射页：中文标签流 + 配置弹窗 ==================== */
.permission-tag-cloud { display: flex; flex-wrap: wrap; gap: 6px 10px; align-items: center; }
.permission-tag { display: inline-block; padding: 4px 10px; border-radius: 6px; font-size: 12px; font-weight: 500; }
.permission-tag.tag-menu { background: #dbeafe; color: #1e40af; }
.permission-tag.tag-action { background: #d1fae5; color: #065f46; }
.permission-tag.tag-todo { background: #fef3c7; color: #92400e; }

/* ==================== 登录页：指令台 - 冷峻严苛工业风（方圆 | 生产管理平台） ==================== */
.login-split-body { margin: 0; min-height: 100vh; }
.login-split-page {
    display: flex;
    width: 100%;
    min-height: 100vh;
}
.login-split-left {
    width: 60%;
    min-height: 100vh;
    background: #1e293b center/cover no-repeat;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.login-split-left:not(.login-split-left-has-bg) {
    background: linear-gradient(180deg, #0f172a 0%, #1e293b 40%, #334155 100%);
}
.login-split-left:not(.login-split-left-has-bg)::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h40v40H0z' fill='none' stroke='rgba(255,255,255,0.04)' stroke-width='1'/%3E%3C/svg%3E");
    pointer-events: none;
}
.login-split-left-has-bg { background-size: cover; background-position: center; }
.login-split-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.75) 0%, rgba(30, 41, 59, 0.82) 100%);
}
.login-split-brand { position: relative; z-index: 1; text-align: center; padding: 2rem; }
.login-split-title {
    margin: 0 0 8px 0;
    font-size: 42px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.12em;
}
.login-split-subtitle {
    margin: 0 0 32px 0;
    font-size: 16px;
    color: rgba(255, 255, 255, 0.85);
    letter-spacing: 0.2em;
}
.login-split-slogan {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.92);
    letter-spacing: 0.35em;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}
/* 右侧 40%：纯白表单区，全直角 */
.login-split-right {
    position: relative;
    width: 40%;
    min-width: 320px;
    min-height: 100vh;
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 40px;
    box-sizing: border-box;
}
.login-split-form-wrap {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 360px;
    background: #fff;
    border-radius: 0;
    padding: 32px 0;
}
.login-split-logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 24px;
}
.login-split-logo-text {
    font-size: 22px;
    font-weight: 700;
    color: #1e293b;
    letter-spacing: 0.08em;
}
.login-split-logo-sub {
    font-size: 11px;
    color: #64748b;
    letter-spacing: 0.06em;
    margin-top: 4px;
}
.login-split-form-title {
    margin: 0 0 4px 0;
    font-size: 18px;
    font-weight: 700;
    color: #1e293b;
}
.login-split-form-subtitle {
    margin: 0 0 20px 0;
    font-size: 13px;
    color: #64748b;
}
.login-split-form .login-split-error {
    margin: 0 0 12px 0;
    padding: 10px 12px;
    font-size: 13px;
    color: #dc2626;
    background: #fef2f2;
    border-radius: 0;
    border: 1px solid #fecaca;
}
.login-split-field {
    display: flex;
    align-items: center;
    height: 44px;
    margin-bottom: 12px;
    border: 1px solid #cbd5e1;
    border-radius: 0;
    background: #fff;
    transition: border-color 0.2s;
}
.login-split-field:focus-within {
    border-color: #475569;
    background: #fff;
}
.login-split-icon {
    width: 44px;
    flex-shrink: 0;
    text-align: center;
    color: #64748b;
    font-size: 14px;
}
.login-split-field:focus-within .login-split-icon { color: #1e293b; }
.login-split-field input {
    flex: 1;
    height: 100%;
    border: none;
    background: transparent;
    padding: 0 12px 0 0;
    font-size: 14px;
    outline: none;
}
.login-split-field input::placeholder { color: #94a3b8; }
.login-split-captcha-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}
.login-split-captcha-input-wrap { flex: 1; margin-bottom: 0; }
.login-split-captcha-img {
    width: 120px;
    height: 44px;
    border-radius: 0;
    border: 1px solid #cbd5e1;
    cursor: pointer;
    object-fit: cover;
    flex-shrink: 0;
}
.login-split-captcha-img:hover { border-color: #475569; opacity: 0.95; }
.login-split-btn {
    width: 100%;
    height: 44px;
    margin-top: 4px;
    background: #1e293b;
    color: #fff;
    border: none;
    border-radius: 0;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
}
.login-split-btn:hover { background: #0f172a; }
.login-split-btn:active { background: #020617; }

/* 供应商管理：类型多选（面料 / 辅料 / 加工厂可同时勾选） */
.standard-page .supplier-type-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    align-items: center;
}
.standard-page .supplier-type-checkboxes__item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: normal;
    margin: 0;
    cursor: pointer;
}
.standard-page .supplier-type-row .supplier-type-hint {
    margin: 6px 0 0;
    font-size: 12px;
    color: #6b7280;
    width: 100%;
}


