/* /Components/Toast.razor.rz.scp.css */
/* ================================================
   全局 Toast 通知样式
   固定显示在右上角，自动堆叠
   ================================================ */

.toast-container[b-npb4fy8tbh] {
    position: fixed;
    top: 1.25rem;
    right: 1.25rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    min-width: 260px;
    max-width: 380px;
}

.toast-item[b-npb4fy8tbh] {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    border-radius: 6px;
    font-size: 0.875rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
    animation: toast-in-b-npb4fy8tbh 0.2s ease;
}

@keyframes toast-in-b-npb4fy8tbh {
    from { opacity: 0; transform: translateX(20px); }
    to   { opacity: 1; transform: translateX(0);    }
}

.toast-msg[b-npb4fy8tbh] {
    flex: 1;
    line-height: 1.45;
    word-break: break-word;
}

.toast-close[b-npb4fy8tbh] {
    flex-shrink: 0;
    background: none;
    border: none;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    opacity: 0.6;
}

.toast-close:hover[b-npb4fy8tbh] {
    opacity: 1;
}

/* 类型配色 */
.toast-success[b-npb4fy8tbh] {
    background: #f0fdf4;
    border-left: 4px solid #22c55e;
    color: #166534;
}

.toast-error[b-npb4fy8tbh] {
    background: #fef2f2;
    border-left: 4px solid #ef4444;
    color: #991b1b;
}

.toast-info[b-npb4fy8tbh] {
    background: #eff6ff;
    border-left: 4px solid #3b82f6;
    color: #1e40af;
}

.toast-warning[b-npb4fy8tbh] {
    background: #fffbeb;
    border-left: 4px solid #f59e0b;
    color: #92400e;
}
/* /Layout/AdminLayout.razor.rz.scp.css */
.admin-layout[b-8ljnpe29qh] {
    display: flex;
    min-height: 100vh;
    background-color: #f5f6fa;
}

/* 侧边栏 */
.admin-sidebar[b-8ljnpe29qh] {
    width: 220px;
    background-color: #fff;
    border-right: 1px solid #e8e8e8;
    display: flex;
    flex-direction: column;
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    z-index: 100;
}

.sidebar-header[b-8ljnpe29qh] {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid #f0f0f0;
}

.sidebar-header h5[b-8ljnpe29qh] {
    font-size: 1.1rem;
    font-weight: 600;
    color: #1a1a2e;
}

/* 导航 */
.sidebar-nav[b-8ljnpe29qh] {
    flex: 1;
    padding: 0.75rem 0;
    overflow-y: auto;
}



/* 底部用户信息 */
.sidebar-footer[b-8ljnpe29qh] {
    padding: 1rem 1.25rem;
    border-top: 1px solid #f0f0f0;
}

.user-info[b-8ljnpe29qh] {
    margin-bottom: 0.75rem;
}

.user-name[b-8ljnpe29qh] {
    font-size: 0.875rem;
    font-weight: 600;
    color: #333;
}

.user-role[b-8ljnpe29qh] {
    font-size: 0.75rem;
    color: #888;
}

.logout-btn[b-8ljnpe29qh] {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    color: #dc3545;
    font-size: 0.8125rem;
    font-weight: 600;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: color 0.2s;
}

.logout-btn:hover[b-8ljnpe29qh] {
    color: #b02a37;
}

/* 主内容区 */
.admin-main[b-8ljnpe29qh] {
    flex: 1;
    margin-left: 220px;
    padding: 1.5rem 2rem;
    min-height: 100vh;
}
/* /Layout/LoginLayout.razor.rz.scp.css */
.login-page[b-er4dvl3aup] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #f8f9fa;
}
/* /Layout/MainLayout.razor.rz.scp.css */
.main-page[b-1p25wvzavo] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #f8f9fa;
}
/* /Layout/SupplierLayout.razor.rz.scp.css */
/* ============================================================
   供应商布局 - 移动优先响应式设计
   ============================================================ */

.supplier-layout[b-5hg2n8xb09] {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background-color: #f5f6fa;
}

/* ---- 顶部 Header ---- */
.supplier-header[b-5hg2n8xb09] {
    background-color: #fff;
    border-bottom: 1px solid #e8e8e8;
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.supplier-header-inner[b-5hg2n8xb09] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 56px;
    padding: 0 1rem;
    max-width: 960px;
    margin: 0 auto;
    width: 100%;
}

/* 品牌 */
.supplier-brand[b-5hg2n8xb09] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1rem;
    font-weight: 700;
    color: #1a1a2e;
    white-space: nowrap;
}

/* 桌面端导航 */
.desktop-nav[b-5hg2n8xb09] {
    display: none;
    align-items: center;
    gap: 0.25rem;
}

.supplier-nav-link[b-5hg2n8xb09] {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.75rem;
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    color: #555;
    text-decoration: none;
    transition: background-color .15s, color .15s;
}

.supplier-nav-link:hover[b-5hg2n8xb09] {
    background-color: #f0f2ff;
    color: #2563eb;
}

.supplier-nav-link.active[b-5hg2n8xb09] {
    background-color: #eff6ff;
    color: #2563eb;
    font-weight: 600;
}

/* 右侧用户区 */
.supplier-user-area[b-5hg2n8xb09] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.supplier-username[b-5hg2n8xb09] {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #444;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.supplier-icon-btn[b-5hg2n8xb09] {
    background: none;
    border: none;
    padding: 0.375rem;
    border-radius: 6px;
    color: #666;
    cursor: pointer;
    display: flex;
    align-items: center;
    transition: background-color .15s, color .15s;
}

.supplier-icon-btn:hover[b-5hg2n8xb09] {
    background-color: #f0f2ff;
    color: #2563eb;
}

.supplier-logout-btn:hover[b-5hg2n8xb09] {
    background-color: #fff5f5;
    color: #dc3545;
}

/* ---- 主内容 ---- */
.supplier-main[b-5hg2n8xb09] {
    flex: 1;
    padding: 1rem;
    /* 手机端底部导航占位 */
    padding-bottom: calc(1rem + 60px);
    max-width: 960px;
    margin: 0 auto;
    width: 100%;
}

/* ---- 移动端底部导航 ---- */
.mobile-bottom-nav[b-5hg2n8xb09] {
    display: flex;
    justify-content: space-around;
    align-items: center;
    background-color: #fff;
    border-top: 1px solid #e8e8e8;
    height: 60px;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 101;
    box-shadow: 0 -1px 6px rgba(0,0,0,.08);
}

.mobile-nav-item[b-5hg2n8xb09] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.2rem;
    flex: 1;
    height: 100%;
    padding: 0;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 0.625rem;
    font-weight: 500;
    color: #888;
    text-decoration: none;
    transition: color .15s;
}

.mobile-nav-item:hover[b-5hg2n8xb09],
.mobile-nav-item.active[b-5hg2n8xb09] {
    color: #2563eb;
}

.mobile-logout:hover[b-5hg2n8xb09] {
    color: #dc3545;
}

/* ---- 弹窗 ---- */
.modal-backdrop[b-5hg2n8xb09] {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.modal-card[b-5hg2n8xb09] {
    background: #fff;
    border-radius: 12px;
    width: 100%;
    max-width: 420px;
    box-shadow: 0 8px 32px rgba(0,0,0,.18);
    overflow: hidden;
}

.modal-header[b-5hg2n8xb09] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid #f0f0f0;
}

.modal-title[b-5hg2n8xb09] {
    font-size: 1rem;
    font-weight: 700;
    margin: 0;
}

.modal-close[b-5hg2n8xb09] {
    background: none;
    border: none;
    font-size: 1.25rem;
    color: #888;
    cursor: pointer;
    line-height: 1;
    padding: 0;
}

.modal-body[b-5hg2n8xb09] {
    padding: 1.25rem;
}

.modal-footer[b-5hg2n8xb09] {
    padding: 0.75rem 1.25rem;
    border-top: 1px solid #f0f0f0;
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

/* ============================================================
   桌面端（≥ 768px）
   ============================================================ */
@media (min-width: 768px) {
    .supplier-header-inner[b-5hg2n8xb09] {
        height: 64px;
        padding: 0 1.5rem;
    }

    .desktop-nav[b-5hg2n8xb09] {
        display: flex;
    }

    .mobile-bottom-nav[b-5hg2n8xb09] {
        display: none;
    }

    .supplier-main[b-5hg2n8xb09] {
        padding: 1.5rem 2rem;
        padding-bottom: 1.5rem;
    }
}
/* /Pages/Admin/AgreementManagement.razor.rz.scp.css */
.page-header[b-9k4lhz0iyq] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.page-title[b-9k4lhz0iyq] {
    font-size: 1.375rem;
    font-weight: 600;
    color: #1a1a2e;
    margin-bottom: 0.25rem;
}

.page-desc[b-9k4lhz0iyq] {
    font-size: 0.8125rem;
    color: #888;
    margin-bottom: 0;
}

.card[b-9k4lhz0iyq] {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.table[b-9k4lhz0iyq] {
    font-size: 0.875rem;
}

.table thead th[b-9k4lhz0iyq] {
    font-weight: 500;
    color: #555;
    border-bottom: 1px solid #e8e8e8;
    padding: 0.875rem 1.25rem;
    background-color: #fafbfc;
}

.table tbody td[b-9k4lhz0iyq] {
    padding: 0.875rem 1.25rem;
    vertical-align: middle;
    color: #333;
    word-break: break-word;
    overflow-wrap: break-word;
}

.table tbody td:last-child[b-9k4lhz0iyq] {
    white-space: nowrap;
    word-break: normal;
}

.table tbody tr:hover[b-9k4lhz0iyq] {
    background-color: #f8f9fa;
}

.btn-sm[b-9k4lhz0iyq] {
    font-size: 0.8125rem;
    padding: 0.25rem 0.625rem;
}

/* ---- 筛选栏 ---- */
.filter-bar[b-9k4lhz0iyq] {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex-wrap: wrap;
}

.filter-bar .form-control[b-9k4lhz0iyq],
.filter-bar .form-select[b-9k4lhz0iyq] {
    max-width: 180px;
}

/* ---- 加载 / 空状态 ---- */
.loading-state[b-9k4lhz0iyq],
.empty-state[b-9k4lhz0iyq] {
    padding: 2.5rem;
    text-align: center;
    color: #888;
    font-size: 0.875rem;
}

/* ---- 模态弹窗 ---- */
.modal[b-9k4lhz0iyq] {
    z-index: 1055;
}

.modal-backdrop[b-9k4lhz0iyq] {
    z-index: 1050;
    background-color: rgba(0, 0, 0, 0.45);
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
}

.modal-header[b-9k4lhz0iyq] {
    align-items: flex-start;
}

.modal-header .btn-close[b-9k4lhz0iyq] {
    flex-shrink: 0;
    margin-left: auto;
}

/* ---- 审批人选择器 ---- */
.approver-select-container[b-9k4lhz0iyq] {
    display: flex;
    gap: 1rem;
    min-height: 300px;
    max-height: 420px;
}

.approver-panel[b-9k4lhz0iyq] {
    flex: 1;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.approver-panel-title[b-9k4lhz0iyq] {
    padding: 0.625rem 0.875rem;
    font-weight: 600;
    font-size: 0.8125rem;
    color: #444;
    background: #f8f9fa;
    border-bottom: 1px solid #e0e0e0;
}

.approver-list[b-9k4lhz0iyq] {
    flex: 1;
    overflow-y: auto;
    padding: 0.25rem;
}

.approver-item[b-9k4lhz0iyq] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 0.75rem;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.8125rem;
    transition: background 0.15s;
    min-width: 0;
}

.approver-item-name[b-9k4lhz0iyq] {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-shrink: 1;
    min-width: 0;
    margin-right: 0.5rem;
}

.approver-item:hover[b-9k4lhz0iyq] {
    background: #f0f4ff;
}

.approver-item.selected[b-9k4lhz0iyq] {
    background: #e8f0fe;
}

.approver-item-hint[b-9k4lhz0iyq] {
    font-size: 0.75rem;
    color: #999;
    margin-left: auto;
    margin-right: 0.5rem;
}

.approver-add-btn[b-9k4lhz0iyq] {
    background: #4c6ef5;
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    flex-shrink: 0;
}

.approver-add-btn:hover[b-9k4lhz0iyq] {
    background: #3b5de7;
}

.approver-remove-btn[b-9k4lhz0iyq] {
    background: #e03131;
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    flex-shrink: 0;
}

.approver-remove-btn:hover[b-9k4lhz0iyq] {
    background: #c92a2a;
}

.approver-empty[b-9k4lhz0iyq] {
    padding: 2rem;
    text-align: center;
    color: #aaa;
    font-size: 0.8125rem;
}

/* ---- 弹窗标题协议名自动换行 ---- */
.agreement-name-wrap[b-9k4lhz0iyq] {
    word-break: break-word;
    overflow-wrap: break-word;
}
/* /Pages/Admin/ApprovalConfig.razor.rz.scp.css */
.page-header[b-7kjhx9fipr] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.page-title[b-7kjhx9fipr] {
    font-size: 1.375rem;
    font-weight: 600;
    color: #1a1a2e;
    margin-bottom: 0.25rem;
}

.page-desc[b-7kjhx9fipr] {
    font-size: 0.8125rem;
    color: #888;
    margin-bottom: 0;
}

.config-card[b-7kjhx9fipr] {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    padding: 24px 28px;
    max-width: 720px;
}

.config-card .card-header-title[b-7kjhx9fipr] {
    font-size: 1rem;
    font-weight: 600;
    color: #1a1a2e;
}

.config-card hr[b-7kjhx9fipr] {
    border-color: #ccc;
}

.config-card .form-label[b-7kjhx9fipr] {
    font-size: 0.875rem;
    font-weight: 500;
    color: #333;
}

.config-card .form-control[b-7kjhx9fipr] {
    max-width: 200px;
    font-size: 0.9375rem;
}

.input-row[b-7kjhx9fipr] {
    display: flex;
    align-items: center;
    gap: 8px;
}

.status-select[b-7kjhx9fipr] {
    max-width: 100px;
    font-size: 0.875rem;
}

.hint-text[b-7kjhx9fipr] {
    color: #999;
    font-size: 0.75rem;
    margin-left: 4px;
}

.help-text[b-7kjhx9fipr] {
    color: #888;
    font-size: 0.8125rem;
    margin-bottom: 0;
}
/* /Pages/Admin/ApprovalRecords.razor.rz.scp.css */
.page-header[b-jy9y4jqc9s] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.page-title[b-jy9y4jqc9s] {
    font-size: 1.375rem;
    font-weight: 600;
    color: #1a1a2e;
    margin-bottom: 0.25rem;
}

.page-desc[b-jy9y4jqc9s] {
    font-size: 0.8125rem;
    color: #888;
    margin-bottom: 0;
}

/* 筛选卡片 */
.record-card[b-jy9y4jqc9s] {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    padding: 24px 28px;
}

/* 筛选区域 */
.filter-bar[b-jy9y4jqc9s] {
    display: flex;
    gap: 1.5rem;
    align-items: flex-end;
    flex-wrap: wrap;
}

.filter-group[b-jy9y4jqc9s] {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    flex: 1;
    min-width: 180px;
}

.filter-label[b-jy9y4jqc9s] {
    font-size: 0.8125rem;
    color: #666;
    font-weight: 500;
}

.filter-group .form-select[b-jy9y4jqc9s] {
    font-size: 0.875rem;
    height: 36px;
    border-radius: 6px;
    border: 1px solid #d9d9d9;
    padding: 0.375rem 2rem 0.375rem 0.75rem;
    background-color: #fff;
    width: 100%;
}

/* 结果卡片（参照供应商管理） */
.card[b-jy9y4jqc9s] {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.result-card[b-jy9y4jqc9s] {
    margin-top: 1.25rem;
}

.table[b-jy9y4jqc9s] {
    font-size: 0.875rem;
    table-layout: fixed;
    width: 100%;
}

.table thead th[b-jy9y4jqc9s] {
    font-weight: 500;
    color: #555;
    border-bottom: 1px solid #e8e8e8;
    padding: 0.875rem 1.25rem;
    background-color: #fafbfc;
}

.table tbody td[b-jy9y4jqc9s] {
    padding: 0.875rem 1.25rem;
    vertical-align: middle;
    color: #333;
    word-break: break-word;
    overflow-wrap: break-word;
}

.table tbody tr:hover[b-jy9y4jqc9s] {
    background-color: #f8f9fa;
}

/* 标题列 */
.title-main[b-jy9y4jqc9s] {
    font-weight: 500;
    color: #1a1a2e;
    line-height: 1.5;
    word-break: break-word;
    overflow-wrap: break-word;
}

.title-sub[b-jy9y4jqc9s] {
    font-size: 0.75rem;
    color: #999;
    margin-top: 4px;
}

/* 状态徽章 */
.status-badge[b-jy9y4jqc9s] {
    display: inline-block;
    font-size: 12px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 12px;
    line-height: 1.6;
}

.status-badge.status-rejected[b-jy9y4jqc9s] {
    background: #fff1f0;
    color: #cf1322;
    border: 1px solid #ffa39e;
}

.status-badge.status-completed[b-jy9y4jqc9s] {
    background: #f6ffed;
    color: #389e0d;
    border: 1px solid #b7eb8f;
}

.status-badge.status-pending[b-jy9y4jqc9s] {
    background: #fffbe6;
    color: #d48806;
    border: 1px solid #ffe58f;
}

/* 按钮 */
.btn-sm[b-jy9y4jqc9s] {
    font-size: 0.8125rem;
    padding: 0.25rem 0.625rem;
}

/* 加载 / 空状态 */
.loading-state[b-jy9y4jqc9s],
.empty-state[b-jy9y4jqc9s] {
    padding: 2.5rem;
    text-align: center;
    color: #888;
    font-size: 0.875rem;
}

/* 分页 */
.pagination-row[b-jy9y4jqc9s] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 20px 0 12px;
    border-top: 1px solid #f0f0f0;
    margin: 0 1.25rem;
}

.btn-page[b-jy9y4jqc9s] {
    font-size: 0.8125rem;
    padding: 5px 14px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-page:hover:not(:disabled)[b-jy9y4jqc9s] {
    border-color: #1677ff;
    color: #1677ff;
}

.btn-page:disabled[b-jy9y4jqc9s] {
    opacity: 0.45;
    cursor: not-allowed;
}

.page-info[b-jy9y4jqc9s] {
    font-size: 0.8125rem;
    color: #888;
}

/* 导出区域 */
.export-section[b-jy9y4jqc9s] {
    margin: 0 1.25rem 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid #f0f0f0;
}

.export-title[b-jy9y4jqc9s] {
    font-size: 0.95rem;
    font-weight: 600;
    color: #1a1a2e;
    margin-bottom: 8px;
}

.export-desc[b-jy9y4jqc9s] {
    font-size: 0.8125rem;
    color: #888;
    line-height: 1.7;
    margin-bottom: 0.25rem;
}

/* 弹窗遮罩 */
.modal-overlay[b-jy9y4jqc9s] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1050;
    animation: fadeIn-b-jy9y4jqc9s 0.15s ease;
}

@keyframes fadeIn-b-jy9y4jqc9s {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-content[b-jy9y4jqc9s] {
    background: #fff;
    border-radius: 12px;
    width: 440px;
    max-width: 90vw;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.15);
    animation: slideUp-b-jy9y4jqc9s 0.2s ease;
}

@keyframes slideUp-b-jy9y4jqc9s {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.modal-header[b-jy9y4jqc9s] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid #f0f0f0;
}

.modal-title[b-jy9y4jqc9s] {
    font-size: 0.95rem;
    font-weight: 600;
    color: #1a1a2e;
    margin: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    margin-right: 0.75rem;
}

.modal-close[b-jy9y4jqc9s] {
    background: none;
    border: none;
    font-size: 1.25rem;
    color: #999;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    flex-shrink: 0;
}

.modal-close:hover[b-jy9y4jqc9s] {
    color: #333;
}

.modal-body[b-jy9y4jqc9s] {
    padding: 0.75rem 1.25rem 1.25rem;
    overflow-y: auto;
    flex: 1;
}

/* 弹窗内审批人列表 */
.handler-list-modal[b-jy9y4jqc9s] {
    display: flex;
    flex-direction: column;
}

.handler-group-modal[b-jy9y4jqc9s] {
    border-bottom: 1px solid #f0f0f0;
    padding: 0.5rem 0;
}

.handler-group-modal:last-child[b-jy9y4jqc9s] {
    border-bottom: none;
}

.handler-item-modal[b-jy9y4jqc9s] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.handler-name-modal[b-jy9y4jqc9s] {
    font-size: 0.875rem;
    font-weight: 500;
    color: #333;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.handler-reason-modal[b-jy9y4jqc9s] {
    font-size: 0.8rem;
    border-radius: 6px;
    padding: 0.375rem 0.625rem;
    margin-top: 0.375rem;
}

.handler-reason-reject[b-jy9y4jqc9s] {
    color: #dc3545;
    background: #fff5f5;
    border: 1px solid #fecaca;
}

.handler-reason-approve[b-jy9y4jqc9s] {
    color: #198754;
    background: #f0fdf4;
    border: 1px solid #86efac;
}

.handler-reason-auto[b-jy9y4jqc9s] {
    color: #0d47a1;
    background: #e3f2fd;
    border: 1px solid #90caf9;
}

.handler-item-modal .status-badge[b-jy9y4jqc9s] {
    border-radius: 20px;
}
/* /Pages/Admin/SupplierManagement.razor.rz.scp.css */
.page-header[b-ueq1xsy0iv] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.page-title[b-ueq1xsy0iv] {
    font-size: 1.375rem;
    font-weight: 600;
    color: #1a1a2e;
    margin-bottom: 0.25rem;
}

.page-desc[b-ueq1xsy0iv] {
    font-size: 0.8125rem;
    color: #888;
    margin-bottom: 0;
}

.card[b-ueq1xsy0iv] {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.table[b-ueq1xsy0iv] {
    font-size: 0.875rem;
}

.table thead th[b-ueq1xsy0iv] {
    font-weight: 500;
    color: #555;
    border-bottom: 1px solid #e8e8e8;
    padding: 0.875rem 1.25rem;
    background-color: #fafbfc;
}

.table tbody td[b-ueq1xsy0iv] {
    padding: 0.875rem 1.25rem;
    vertical-align: middle;
    color: #333;
    word-break: break-word;
    overflow-wrap: break-word;
}

.table tbody td:last-child[b-ueq1xsy0iv] {
    white-space: nowrap;
    word-break: normal;
}

.table tbody tr:hover[b-ueq1xsy0iv] {
    background-color: #f8f9fa;
}

.btn-sm[b-ueq1xsy0iv] {
    font-size: 0.8125rem;
    padding: 0.25rem 0.625rem;
}

/* ---- 筛选栏 ---- */
.filter-bar[b-ueq1xsy0iv] {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex-wrap: wrap;
}

.filter-bar .form-control[b-ueq1xsy0iv] {
    max-width: 180px;
}

/* ---- 加载 / 空状态 ---- */
.loading-state[b-ueq1xsy0iv],
.empty-state[b-ueq1xsy0iv] {
    padding: 2.5rem;
    text-align: center;
    color: #888;
    font-size: 0.875rem;
}

/* ---- 模态弹窗 ---- */
.modal[b-ueq1xsy0iv] {
    z-index: 1055;
}

.modal-backdrop[b-ueq1xsy0iv] {
    z-index: 1050;
    background-color: rgba(0, 0, 0, 0.45);
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
}

.modal-header[b-ueq1xsy0iv] {
    align-items: flex-start;
}

.modal-header .btn-close[b-ueq1xsy0iv] {
    flex-shrink: 0;
    margin-left: auto;
}

/* ---- 审批人选择器 ---- */
.approver-select-container[b-ueq1xsy0iv] {
    display: flex;
    gap: 1rem;
    min-height: 300px;
    max-height: 420px;
}

.approver-panel[b-ueq1xsy0iv] {
    flex: 1;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.approver-panel-title[b-ueq1xsy0iv] {
    padding: 0.625rem 0.875rem;
    font-weight: 600;
    font-size: 0.8125rem;
    color: #444;
    background: #f8f9fa;
    border-bottom: 1px solid #e0e0e0;
}

.approver-list[b-ueq1xsy0iv] {
    flex: 1;
    overflow-y: auto;
    padding: 0.25rem;
}

.approver-item[b-ueq1xsy0iv] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 0.75rem;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.8125rem;
    transition: background 0.15s;
    min-width: 0;
}

.approver-item-name[b-ueq1xsy0iv] {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-shrink: 1;
    min-width: 0;
    margin-right: 0.5rem;
}

.approver-item:hover[b-ueq1xsy0iv] {
    background: #f0f4ff;
}

.approver-item.selected[b-ueq1xsy0iv] {
    background: #e8f0fe;
}

.approver-item-hint[b-ueq1xsy0iv] {
    font-size: 0.75rem;
    color: #999;
    margin-left: auto;
    margin-right: 0.5rem;
}

.approver-add-btn[b-ueq1xsy0iv] {
    background: #4c6ef5;
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    flex-shrink: 0;
}

.approver-add-btn:hover[b-ueq1xsy0iv] {
    background: #3b5de7;
}

.approver-remove-btn[b-ueq1xsy0iv] {
    background: #e03131;
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    flex-shrink: 0;
}

.approver-remove-btn:hover[b-ueq1xsy0iv] {
    background: #c92a2a;
}

.approver-empty[b-ueq1xsy0iv] {
    padding: 2rem;
    text-align: center;
    color: #aaa;
    font-size: 0.8125rem;
}

/* ---- 审批人弹窗标题供应商名自动换行 ---- */
.supplier-name-wrap[b-ueq1xsy0iv] {
    word-break: break-word;
    overflow-wrap: break-word;
}
/* /Pages/Admin/UserManagement.razor.rz.scp.css */
.page-header[b-4hlriaedgk] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.page-title[b-4hlriaedgk] {
    font-size: 1.375rem;
    font-weight: 600;
    color: #1a1a2e;
    margin-bottom: 0.25rem;
}

.page-desc[b-4hlriaedgk] {
    font-size: 0.8125rem;
    color: #888;
    margin-bottom: 0;
}

.card[b-4hlriaedgk] {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.table[b-4hlriaedgk] {
    font-size: 0.875rem;
}

.table thead th[b-4hlriaedgk] {
    font-weight: 500;
    color: #555;
    border-bottom: 1px solid #e8e8e8;
    padding: 0.875rem 1.25rem;
    background-color: #fafbfc;
}

.table tbody td[b-4hlriaedgk] {
    padding: 0.875rem 1.25rem;
    vertical-align: middle;
    color: #333;
}

.table tbody tr:hover[b-4hlriaedgk] {
    background-color: #f8f9fa;
}

.badge[b-4hlriaedgk] {
    font-size: 0.75rem;
    font-weight: 500;
    padding: 0.25rem 0.625rem;
    border-radius: 4px;
}

.badge.bg-purple[b-4hlriaedgk] {
    background-color: #f3e8ff !important;
    color: #7c3aed;
}

.badge.bg-blue[b-4hlriaedgk] {
    background-color: #dbeafe !important;
    color: #2563eb;
}

.btn-sm[b-4hlriaedgk] {
    font-size: 0.8125rem;
    padding: 0.25rem 0.625rem;
}

/* ---- 筛选栏 ---- */
.filter-bar[b-4hlriaedgk] {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex-wrap: wrap;
}

.filter-bar .form-control[b-4hlriaedgk],
.filter-bar .form-select[b-4hlriaedgk] {
    max-width: 180px;
}

/* ---- 加载 / 空状态 ---- */
.loading-state[b-4hlriaedgk],
.empty-state[b-4hlriaedgk] {
    padding: 2.5rem;
    text-align: center;
    color: #888;
    font-size: 0.875rem;
}

/* ---- 模态弹窗 ---- */
.modal[b-4hlriaedgk] {
    z-index: 1055;
}

.modal-backdrop[b-4hlriaedgk] {
    z-index: 1050;
    background-color: rgba(0, 0, 0, 0.45);
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
}

.modal-header[b-4hlriaedgk] {
    align-items: flex-start;
}

.modal-header .btn-close[b-4hlriaedgk] {
    flex-shrink: 0;
    margin-left: auto;
}

/* ---- 表格长文本自动换行 ---- */
.table td[b-4hlriaedgk] {
    word-break: break-word;
    overflow-wrap: break-word;
}

/* ---- 弹窗标题用户名自动换行 ---- */
.user-name-wrap[b-4hlriaedgk] {
    word-break: break-word;
    overflow-wrap: break-word;
}

/* /Pages/Forbidden.razor.rz.scp.css */
.forbidden-card[b-gg83pp4jyx] {
    text-align: center;
    padding: 48px 24px;
    max-width: 400px;
    margin: 0 auto;
}

.forbidden-icon[b-gg83pp4jyx] {
    color: #dc3545;
    margin-bottom: 16px;
    opacity: 0.8;
}

.forbidden-title[b-gg83pp4jyx] {
    font-size: 1.5rem;
    font-weight: 600;
    color: #343a40;
    margin-bottom: 8px;
}

.forbidden-desc[b-gg83pp4jyx] {
    color: #6c757d;
    margin-bottom: 0;
}
/* /Pages/Login.razor.rz.scp.css */
.login-card[b-zhl14rb3z0] {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    padding: 2.5rem 2rem;
    width: 100%;
    max-width: 420px;
    margin: 1rem;
}

.login-header[b-zhl14rb3z0] {
    text-align: center;
    margin-bottom: 2rem;
}

.login-title[b-zhl14rb3z0] {
    font-size: 1.5rem;
    font-weight: 600;
    color: #1a1a2e;
    margin-bottom: 0.5rem;
}

.login-subtitle[b-zhl14rb3z0] {
    font-size: 0.875rem;
    color: #6c757d;
    margin-bottom: 0;
}

.login-form .form-label[b-zhl14rb3z0] {
    font-size: 0.875rem;
    font-weight: 500;
    color: #333;
    margin-bottom: 0.375rem;
}

.login-form .form-control[b-zhl14rb3z0] {
    font-size: 0.875rem;
    padding: 0.625rem 0.875rem;
    border-color: #dee2e6;
}

.login-form .form-control:focus[b-zhl14rb3z0] {
    border-color: #0d6efd;
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.15);
}

.login-btn[b-zhl14rb3z0] {
    font-size: 0.9375rem;
    font-weight: 500;
    padding: 0.625rem;
    border-radius: 6px;
}
/* /Pages/NotFound.razor.rz.scp.css */
.not-found-card[b-4vwxprvjr6] {
    text-align: center;
    padding: 64px 24px;
    max-width: 440px;
    margin: 0 auto;
}

.not-found-icon[b-4vwxprvjr6] {
    color: #ffc107;
    margin-bottom: 20px;
    opacity: 0.9;
}

.not-found-title[b-4vwxprvjr6] {
    font-size: 1.5rem;
    font-weight: 600;
    color: #343a40;
    margin-bottom: 8px;
}

.not-found-desc[b-4vwxprvjr6] {
    color: #6c757d;
    margin-bottom: 24px;
    line-height: 1.6;
}

.not-found-btn[b-4vwxprvjr6] {
    padding: 0.5rem 1.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: #fff;
    background-color: #2563eb;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.2s;
}

.not-found-btn:hover[b-4vwxprvjr6] {
    background-color: #1d4ed8;
}
/* /Pages/Supplier/ProcessCreate.razor.rz.scp.css */
/* 弹窗遮罩 */
.modal-overlay[b-wv8cgxovv0] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1050;
    animation: fadeIn-b-wv8cgxovv0 0.15s ease;
}

@keyframes fadeIn-b-wv8cgxovv0 {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-content[b-wv8cgxovv0] {
    background: #fff;
    border-radius: 12px;
    width: 900px;
    max-width: 95vw;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.15);
    animation: slideUp-b-wv8cgxovv0 0.2s ease;
}

@keyframes slideUp-b-wv8cgxovv0 {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.modal-header[b-wv8cgxovv0] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e5e7eb;
}

.modal-title[b-wv8cgxovv0] {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0;
}

.modal-body[b-wv8cgxovv0] {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
}

.modal-footer[b-wv8cgxovv0] {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    padding: 12px 20px;
    border-top: 1px solid #e5e7eb;
}

.btn-close[b-wv8cgxovv0] {
    background: none;
    border: none;
    font-size: 1.3rem;
    cursor: pointer;
    color: #6b7280;
    padding: 0;
    line-height: 1;
}

.btn-close:hover[b-wv8cgxovv0] {
    color: #111827;
}

.sticky-top[b-wv8cgxovv0] {
    position: sticky;
    top: 0;
    z-index: 1;
}

.agreement-table th[b-wv8cgxovv0],
.agreement-table td[b-wv8cgxovv0] {
    vertical-align: middle;
    white-space: nowrap;
    font-weight: normal;
}

.agreement-table td:last-child[b-wv8cgxovv0] {
    white-space: normal;
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.agreement-select-row[b-wv8cgxovv0] {
    display: flex;
    gap: 8px;
    align-items: center;
}

.agreement-select-row .form-control[b-wv8cgxovv0] {
    flex: 1;
}

.pagination-bar[b-wv8cgxovv0] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 12px;
    font-size: 0.8rem;
    color: #6b7280;
}

.pagination-info[b-wv8cgxovv0] {
    flex-shrink: 0;
}

.pagination-btns[b-wv8cgxovv0] {
    display: flex;
    gap: 4px;
}
/* /Pages/Supplier/ProcessEdit.razor.rz.scp.css */
/* 弹窗遮罩 */
.modal-overlay[b-w47paomnbg] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1050;
    animation: fadeIn-b-w47paomnbg 0.15s ease;
}

@keyframes fadeIn-b-w47paomnbg {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-content[b-w47paomnbg] {
    background: #fff;
    border-radius: 12px;
    width: 900px;
    max-width: 95vw;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.15);
    animation: slideUp-b-w47paomnbg 0.2s ease;
}

@keyframes slideUp-b-w47paomnbg {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.modal-header[b-w47paomnbg] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e5e7eb;
}

.modal-title[b-w47paomnbg] {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0;
}

.modal-body[b-w47paomnbg] {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
}

.modal-footer[b-w47paomnbg] {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    padding: 12px 20px;
    border-top: 1px solid #e5e7eb;
}

.btn-close[b-w47paomnbg] {
    background: none;
    border: none;
    font-size: 1.3rem;
    cursor: pointer;
    color: #6b7280;
    padding: 0;
    line-height: 1;
}

.btn-close:hover[b-w47paomnbg] {
    color: #111827;
}

.sticky-top[b-w47paomnbg] {
    position: sticky;
    top: 0;
    z-index: 1;
}

.agreement-table th[b-w47paomnbg],
.agreement-table td[b-w47paomnbg] {
    vertical-align: middle;
    white-space: nowrap;
    font-weight: normal;
}

.agreement-table td:last-child[b-w47paomnbg] {
    white-space: normal;
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.agreement-select-row[b-w47paomnbg] {
    display: flex;
    gap: 8px;
    align-items: center;
}

.agreement-select-row .form-control[b-w47paomnbg] {
    flex: 1;
}

.pagination-bar[b-w47paomnbg] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 12px;
    font-size: 0.8rem;
    color: #6b7280;
}

.pagination-info[b-w47paomnbg] {
    flex-shrink: 0;
}

.pagination-btns[b-w47paomnbg] {
    display: flex;
    gap: 4px;
}
/* /Pages/TestLogout.razor.rz.scp.css */
.test-logout-container[b-orzy680yvg] {
    max-width: 700px;
    margin: 60px auto;
    padding: 0 16px;
}
