/*!*******************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-14.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-14.use[2]!./src/assets/styles/variables.css ***!
  \*******************************************************************************************************************************************************************************/
:root {
  /* 主色调 - 蓝色系 */
  --primary-color: #2B85E4;
  --primary-light: #5CADFF;
  --primary-dark: #2472C8;
  --primary-bg: #ECF5FF;
  
  /* 辅助色 - 绿色系 */
  --success-color: #19BE6B;
  --success-light: #52D18D;
  --success-dark: #18A75E;
  --success-bg: #E8F9F0;
  
  /* 警告色 - 橙色系 */
  --warning-color: #FF9900;
  --warning-light: #FFAD33;
  --warning-dark: #E68900;
  --warning-bg: #FFF9ED;
  
  /* 错误色 - 红色系 */
  --error-color: #ED4014;
  --error-light: #F16643;
  --error-dark: #D53912;
  --error-bg: #FEEFEE;
  
  /* 文字颜色 */
  --text-primary: #303133;
  --text-regular: #606266;
  --text-secondary: #909399;
  --text-placeholder: #C0C4CC;
  
  /* 边框颜色 */
  --border-base: #DCDFE6;
  --border-light: #E4E7ED;
  --border-lighter: #EBEEF5;
  --border-extra-light: #F2F6FC;
  
  /* 背景颜色 */
  --background-base: #F5F7FA;
  --background-light: #F8F8F9;
  --background-lighter: #FFFFFF;
  
  /* 聊天气泡颜色 */
  --chat-bubble-left: #FFFFFF;
  --chat-bubble-right: #D4F5BC;
  --chat-bubble-shadow: rgba(0, 0, 0, 0.05);
  --chat-background: #F0F2F5;
  
  /* 特殊颜色 */
  --gradient-primary: linear-gradient(135deg, #2B85E4 0%, #5CADFF 100%);
  --gradient-login: linear-gradient(135deg, #2B85E4 0%, #2472C8 100%);
  --shadow-base: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  --shadow-light: 0 2px 8px 0 rgba(0, 0, 0, 0.05);
  --shadow-hover: 0 4px 12px 0 rgba(43, 133, 228, 0.2);
} 
/*!****************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-14.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-14.use[2]!./src/assets/styles/global.css ***!
  \****************************************************************************************************************************************************************************/
/* 全局样式重置 */
html, body {
  margin: 0;
  padding: 0;
  height: 100%;
  overflow: hidden !important;
  font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: fixed;
  width: 100%;
  color: var(--text-primary);
}

/* 全局滚动条样式 */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: #f8f8f7;
  border-radius: 3px;
}

::-webkit-scrollbar-thumb {
  background-color: rgba(144, 147, 153, 0.3);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background-color: rgba(144, 147, 153, 0.5);
}

/* Element UI 组件样式覆盖 */
.el-button--primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}

.el-button--primary:hover,
.el-button--primary:focus {
  background-color: var(--primary-light);
  border-color: var(--primary-light);
}

.el-button--success {
  background-color: var(--success-color);
  border-color: var(--success-color);
}

.el-button--success:hover,
.el-button--success:focus {
  background-color: var(--success-light);
  border-color: var(--success-light);
}

.el-button--warning {
  background-color: var(--warning-color);
  border-color: var(--warning-color);
}

.el-button--warning:hover,
.el-button--warning:focus {
  background-color: var(--warning-light);
  border-color: var(--warning-light);
}

.el-button--danger {
  background-color: var(--error-color);
  border-color: var(--error-color);
}

.el-button--danger:hover,
.el-button--danger:focus {
  background-color: var(--error-light);
  border-color: var(--error-light);
}

/* 全局按钮悬浮效果 */
.el-button {
  transition: all 0.3s ease !important;
}

.el-button:not(.is-disabled):hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

/* 输入框焦点效果 */
.el-input__inner:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 2px rgba(43, 133, 228, 0.2);
}

/* 路由过渡动画 */
.fade-transform-enter-active,
.fade-transform-leave-active {
  transition: all 0.3s;
}

.fade-transform-enter {
  opacity: 0;
  transform: translateX(-20px);
}

.fade-transform-leave-to {
  opacity: 0;
  transform: translateX(20px);
} 
/*!*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/StagewiseToolbar.vue?vue&type=style&index=0&id=76556829&scoped=true&lang=css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.stagewise-toolbar-container[data-v-76556829] {
  /* 工具栏容器样式，如果需要的话 */
}

/*!*********************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/App.vue?vue&type=style&index=0&id=7ba5bd90&lang=css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************************************************************/

#app {
  height: 100%;
  overflow: hidden;
}

/* 表单项过渡效果 */
.el-form-item {
  transition: all 0.3s ease;
}
.el-form-item:focus-within {
  transform: translateY(-2px);
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/views/Login.vue?vue&type=style&index=0&id=26084dc2&scoped=true&lang=css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.login-container[data-v-26084dc2] {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: var(--gradient-login);
    overflow: hidden;
    position: relative;
}
.login-container[data-v-26084dc2]::before {
    content: '';
    position: absolute;
    width: 140%;
    height: 140%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 70%);
    top: -20%;
    left: -20%;
    animation: rotate-26084dc2 20s linear infinite;
}
@keyframes rotate-26084dc2 {
from {
        transform: rotate(0deg);
}
to {
        transform: rotate(360deg);
}
}
.login-box[data-v-26084dc2] {
    width: 400px;
    background: rgba(255, 255, 255, 0.95);
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    backdrop-filter: blur(10px);
    animation: fadeInUp-26084dc2 0.8s ease;
    transform: translateZ(0);
}
@keyframes fadeInUp-26084dc2 {
from {
        opacity: 0;
        transform: translateY(30px);
}
to {
        opacity: 1;
        transform: translateY(0);
}
}
.login-header[data-v-26084dc2] {
    padding: 30px 20px 20px;
    text-align: center;
    background: linear-gradient(to right, var(--background-base), var(--background-lighter));
}
.title[data-v-26084dc2] {
    font-size: 28px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 8px;
}
.subtitle[data-v-26084dc2] {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 10px;
}
.login-form[data-v-26084dc2] {
    padding: 20px 30px 30px;
}
.custom-input[data-v-26084dc2] {
    margin-bottom: 5px;
}
.custom-input[data-v-26084dc2] .el-input__inner {
    height: 50px;
    line-height: 50px;
    border-radius: 8px;
    border: 1px solid var(--border-base);
    transition: all 0.3s ease;
    box-sizing: border-box;
    padding-left: 40px;
}
.custom-input[data-v-26084dc2] .el-input__inner:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(43, 133, 228, 0.2);
}
.custom-input[data-v-26084dc2] .el-input__prefix {
    left: 10px;
    font-size: 18px;
    color: var(--text-secondary);
}
.login-button[data-v-26084dc2] {
    width: 100%;
    height: 50px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 2px;
    margin-top: 10px;
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}
.login-button[data-v-26084dc2]:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
    background-color: var(--primary-light) !important;
    border-color: var(--primary-light) !important;
}
.button-ripple[data-v-26084dc2] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.7) 0%, rgba(255, 255, 255, 0) 70%);
    transform: scale(0);
    opacity: 1;
    border-radius: 50%;
    animation: ripple-26084dc2 0.6s linear;
    pointer-events: none;
}
@keyframes ripple-26084dc2 {
to {
        transform: scale(2.5);
        opacity: 0;
}
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/ExcelContent.vue?vue&type=style&index=0&id=72b630f2&scoped=true&lang=css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 主布局样式 */
.row.mx-0[data-v-72b630f2] {
  display: flex;
  height: calc(100vh - 70px);
  overflow: hidden;
}
/* 媒体查询：移动设备使用纵向布局 */
@media (max-width: 767px) {
  /* 布局优化 */
.row.mx-0[data-v-72b630f2] {
    flex-direction: column;
    height: calc(100vh - 60px);
    display: flex;
    flex-wrap: nowrap;
}
.resizable-spreadsheet[data-v-72b630f2] {
    flex: 0 0 55%;
    width: 100% !important;
    max-width: 100% !important;
    height: 55vh;
    min-height: auto;
}
.chat-container[data-v-72b630f2] {
    flex: 0 0 45%;
    width: 100% !important;
    height: 45vh;
    min-height: auto;
}
  /* 其他移动端样式保持不变... */
}
/* PC端横向布局优化 */
@media (min-width: 768px) {
.row.mx-0[data-v-72b630f2] {
    flex-direction: row;
    height: calc(100vh - 70px);
    flex-wrap: nowrap;
}
.resizable-spreadsheet[data-v-72b630f2] {
    flex: 1 1 auto;
    min-width: 300px;
    max-width: 100%;
    height: 100%;
    position: relative;
}
.chat-container[data-v-72b630f2] {
    flex: 0 0 25%;
    min-width: 100px;
    max-width: 300px;
    height: 100%;
    display: flex;
    flex-direction: column;
    position: relative;
    padding: 0;
    overflow: hidden;
}
.chat-container .card[data-v-72b630f2] {
    height: 100%;
    display: flex;
    flex-direction: column;
    margin: 0;
    border-radius: 0.25rem;
    overflow: hidden;
    flex: 1 1 auto;
}
.chat-container .card-header[data-v-72b630f2] {
    padding: 0.75rem 1rem;
    flex-shrink: 0;
}
.chat-container .card-body[data-v-72b630f2] {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: 0;
}
.resizer[data-v-72b630f2] {
    display: block;
    width: 8px;
    background-color: #e9ecef;
    cursor: col-resize;
    margin: 0;
}
.chat-messages[data-v-72b630f2] {
    flex: 1;
    height: auto !important;
    overflow-y: auto;
    padding: 1rem;
    max-height: none;
    display: flex;
    flex-direction: column;
}
.chat-input[data-v-72b630f2] {
    position: sticky;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 0.75rem;
    background-color: #f8f9fa;
    border-top: 1px solid #dee2e6;
    z-index: 10;
    flex-shrink: 0;
}
.chat-input .input-group[data-v-72b630f2] {
    width: 100%;
}
}
/* 特别针对大屏幕设备 */
@media (min-width: 1200px) {
.resizable-spreadsheet[data-v-72b630f2] {
    max-width: 80%;
}
.chat-container[data-v-72b630f2] {
    flex: 0 0 20%;
    min-width: 300px;
}
}
.resizable-spreadsheet[data-v-72b630f2] {
  flex: 1 1 auto;
  min-width: 300px;
  max-width: 100%;
  padding: 0;
  position: relative;
  justify-content: center;
}
.position-relative[data-v-72b630f2]{position:relative!important}
.h-100[data-v-72b630f2]{height:100%!important}
/* 基础表格样式 */
.custom-table[data-v-72b630f2] {
  font-family: Arial, sans-serif;
  border: 1px solid #e2e8f0;
}
.custom-table td[data-v-72b630f2] {
  border: 1px solid #e2e8f0;
  transition: background-color 0.2s;
}
.positive-value[data-v-72b630f2] {
  color: #10b981;
  font-weight: 500;
  background-color: #ecfdf5;
}
.negative-value[data-v-72b630f2] {
  color: #ef4444;
  font-weight: 500;
  background-color: #fef2f2;
}
.current-row td[data-v-72b630f2] {
  background-color: rgba(241, 245, 249, 0.6) !important;
}
.current-col[data-v-72b630f2] {
  background-color: rgba(241, 245, 249, 0.6) !important;
}
/* 文本格式化样式 */
.handsontable .htBold[data-v-72b630f2] {
  font-weight: bold;
}
.handsontable .htItalic[data-v-72b630f2] {
  font-style: italic;
}
.handsontable .htUnderline[data-v-72b630f2] {
  text-decoration: underline;
}
.bold-text[data-v-72b630f2] {
  font-weight: bold !important;
}
.italic-text[data-v-72b630f2] {
  font-style: italic !important;
}
.underline-text[data-v-72b630f2] {
  text-decoration: underline !important;
}
/* 标签样式 */
.labeled-cell[data-v-72b630f2] {
  position: relative;
}
.labeled-cell.high-priority[data-v-72b630f2] {
  background-color: rgba(254, 226, 226, 0.7) !important;
}
.labeled-cell.medium-priority[data-v-72b630f2] {
  background-color: rgba(254, 243, 199, 0.7) !important;
}
.labeled-cell.low-priority[data-v-72b630f2] {
  background-color: rgba(236, 253, 245, 0.7) !important;
}
/* 表格选择和高亮样式 */
.handsontable td.current[data-v-72b630f2] {
  background-color: rgba(229, 231, 235, 0.7) !important;
}
.handsontable tbody th.ht__highlight[data-v-72b630f2],
.handsontable thead th.ht__highlight[data-v-72b630f2] {
  background-color: rgba(229, 231, 235, 0.7);
}
.handsontable.ht__selection--columns thead th.ht__highlight[data-v-72b630f2] {
  background-color: rgba(229, 231, 235, 0.7);
}
.handsontable td.area[data-v-72b630f2] {
  background-color: rgba(66, 153, 225, 0.1) !important;
  box-shadow: 0 0 5px rgba(66, 153, 225, 0.5);
  transition: box-shadow 0.2s ease;
}
.handsontable td.area-selected[data-v-72b630f2] {
  background-color: rgba(66, 153, 225, 0.2) !important;
  box-shadow: 0 0 8px rgba(66, 153, 225, 0.8);
  z-index: 1;
  position: relative;
}
.handsontable .wtBorder.area[data-v-72b630f2] {
  background-color: #4299e1 !important;
}
.handsontable .wtBorder.area-selected[data-v-72b630f2] {
  background-color: #4299e1 !important;
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/WorkspaceTable.vue?vue&type=style&index=0&id=76b9bde9&scoped=true&lang=css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.workspace-table[data-v-76b9bde9] {
  padding: 20px;
  background-color: #fff;
  border-radius: 4px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding-top: 50px;
  box-sizing: border-box;
}
.title-row[data-v-76b9bde9] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}
.table-title[data-v-76b9bde9] {
  font-size: 18px;
  font-weight: 500;
  color: #333;
  margin-bottom: 0;
}
.action-buttons[data-v-76b9bde9] {
  margin-top: 17px;
}
.inline-buttons[data-v-76b9bde9] {
  display: inline-flex;
  gap: 8px;
}
.table-container[data-v-76b9bde9] {
  flex: 1;
  max-height: 70%;
  overflow-x: auto;
  overflow-y: auto;
  margin-bottom: 20px;
}
.empty-data[data-v-76b9bde9] {
  padding: 30px 0;
  text-align: center;
  color: #909399;
  font-size: 14px;
}
.pagination-container[data-v-76b9bde9] {
  margin-top: 15px;
  margin-bottom: 15px;
  padding: 10px 20px;
  display: flex;
  justify-content: flex-end;
  background-color: #fff;
  border-radius: 0 0 4px 4px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.05);
  min-height: 32px;
}
.no-data-pagination[data-v-76b9bde9] {
  color: #909399;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

/* 自定义滚动条样式 */
.table-container[data-v-76b9bde9]::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
.table-container[data-v-76b9bde9]::-webkit-scrollbar-thumb {
  background-color: #c0c4cc;
  border-radius: 4px;
}
.table-container[data-v-76b9bde9]::-webkit-scrollbar-track {
  background-color: #f5f7fa;
}

/* AI表格特殊样式 */
.ai-table[data-v-76b9bde9] {
  position: relative;
  border: 2px solid #409EFF;
  border-radius: 6px;
  background-color: #f9fbff;
  padding-top: 40px;
  padding-bottom: 30px;
  overflow-y: auto;
}
.ai-table .table-title[data-v-76b9bde9] {
  color: #409EFF;
  font-weight: bold;
}

/* AI行样式 */
[data-v-76b9bde9] .ai-row {
  background-color: #ecf5ff !important;
}
[data-v-76b9bde9] .ai-row:hover {
  background-color: #d9ecff !important;
}
[data-v-76b9bde9] .disabled-row {
  opacity: 0.5;
  filter: grayscale(100%);
}
[data-v-76b9bde9] .disabled-row:hover {
  background-color: #ecf5ff !important;
  cursor: not-allowed;
}

/* 双层表头样式 */
.dual-header[data-v-76b9bde9] {
  display: flex;
  flex-direction: column;
  padding: 5px 0;
}
.excel-header[data-v-76b9bde9] {
  font-weight: bold;
  padding-bottom: 3px;
}
.db-header[data-v-76b9bde9] {
  font-size: 12px;
  color: #409EFF;
  padding-top: 3px;
  border-top: 1px dashed #dcdfe6;
  font-weight: 600;
}
.db-header[data-v-76b9bde9]:not(.no-match) {
  color: #2a6bc6;
}
.db-header.no-match[data-v-76b9bde9] {
  color: #F56C6C;
  font-style: italic;
  font-weight: normal;
}

/* 数据库表头行样式 */
.db-headers-row[data-v-76b9bde9] {
  margin-bottom: 50px;
  padding: 15px 15px 30px;
  background-color: #f9fbff;
  border: 1px solid #d9ecff;
  border-radius: 6px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
  position: relative;
}
.db-header-title[data-v-76b9bde9] {
  font-size: 14px;
  font-weight: bold;
  color: #606266;
  margin-bottom: 10px;
}
.db-headers-scroll-container[data-v-76b9bde9] {
  overflow-x: auto;
  padding: 0 0 20px 0;
  height: auto;
  max-height: 200px;
}

/* Excel表头行样式 */
.excel-headers-row[data-v-76b9bde9] {
  display: flex;
  flex-wrap: nowrap;
  gap: 15px;
  min-width: -moz-min-content;
  min-width: min-content;
  margin-bottom: 10px;
  padding: 10px 5px;
  background-color: #f9fafc;
  border: 1px solid #ebeef5;
  border-radius: 4px;
}
.excel-header-item[data-v-76b9bde9] {
  padding: 6px 12px;
  background-color: #ecf5ff;
  border-radius: 4px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  color: #409EFF;
  font-weight: 600;
  font-size: 13px;
  position: relative;
  white-space: nowrap;
  min-width: 120px;
  text-align: center;
}

/* 连接线容器 */
.connections-container[data-v-76b9bde9] {
  position: relative;
  height: 60px;
  margin: 5px 0;
  display: flex;
  flex-wrap: nowrap;
  gap: 15px;
  min-width: -moz-min-content;
  min-width: min-content;
}
.connection-wrapper[data-v-76b9bde9] {
  position: relative;
  min-width: 120px;
  padding: 0 12px;
  display: flex;
  justify-content: center;
}
.connection-line[data-v-76b9bde9] {
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  height: 60px;
  transform: translateX(-50%);
  opacity: 0.5;
  pointer-events: none;
}
.connection-line[data-v-76b9bde9]:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 2px;
  height: 30px;
  /* 上半部分固定，不可拖动 */
  background-color: #dcdfe6;
}
.connection-line[data-v-76b9bde9]:after {
  content: "";
  position: absolute;
  top: 30px;
  left: 0;
  width: 2px;
  height: 30px;
  /* 下半部分可拖动 */
  background-color: #dcdfe6;
}
.connection-line.draggable[data-v-76b9bde9] {
  cursor: move;
  pointer-events: auto;
}
.connection-line.draggable[data-v-76b9bde9]:before {
  background-color: #409EFF;
}
.connection-line.draggable[data-v-76b9bde9]:after {
  background-color: #409EFF;
}
.connection-line.draggable .handle[data-v-76b9bde9] {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #409EFF;
  transform: translateX(-50%);
  cursor: move;
}
.connection-handle[data-v-76b9bde9] {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #409EFF;
  transform: translateX(-50%);
  cursor: move;
  z-index: 2;
}
.has-match .connection-line[data-v-76b9bde9]:not(.draggable) {
  display: none;
}

/* 系统字段行样式 */
.system-headers-row[data-v-76b9bde9] {
  display: flex;
  flex-wrap: nowrap;
  gap: 15px;
  min-width: -moz-min-content;
  min-width: min-content;
  padding: 10px 5px;
  background-color: #f9fafc;
  border: 1px solid #ebeef5;
  border-radius: 4px;
}
.system-header-item[data-v-76b9bde9] {
  padding: 6px 12px;
  background-color: #f5f7fa;
  border-radius: 4px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  color: #303133;
  font-weight: 500;
  font-size: 13px;
  position: relative;
  white-space: nowrap;
  min-width: 120px;
  text-align: center;
}

/* AI数据表格样式 */
.ai-data-table[data-v-76b9bde9] {
  margin-top: 10px;
  position: relative;
  z-index: 1;
}

/* 为表头单元格添加高亮效果 */
.ai-table .el-table th[data-v-76b9bde9] {
  position: relative;
}
.ai-table .el-table th[data-v-76b9bde9]:before {
  content: "";
  position: absolute;
  top: -5px;
  left: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: rgba(64, 158, 255, 0.2);
  transform: translateX(-50%);
}

/* 调整AI表格整体布局 */
.ai-table[data-v-76b9bde9] {
  display: flex;
  flex-direction: column;
}
.ai-table[data-v-76b9bde9]::before {
  content: "AI";
  position: absolute;
  top: 10px;
  right: 20px;
  color: #409EFF;
  font-size: 14px;
  font-weight: bold;
  padding: 2px 8px;
  border: 1px solid #409EFF;
  border-radius: 4px;
  background-color: #ecf5ff;
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/Input.vue?vue&type=style&index=0&id=54844eca&scoped=true&lang=css ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.gemini-input-container[data-v-54844eca] {
  background-color: #ffffff;
  border-radius: 24px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
  border: 1px solid #eeeeee;
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  width: 70%;
  margin: 0 auto;
}
.input-text-area[data-v-54844eca] {
  position: relative;
  display: flex;
  align-items: center;
}
.message-input[data-v-54844eca] {
  width: 100%;
}
.message-input[data-v-54844eca] .el-textarea__inner {
  border: none;
  resize: none;
  padding: 10px 10px;
  min-height: 40px !important;
  background-color: transparent;
  font-size: 14px;
}
.message-input[data-v-54844eca] .el-textarea__inner:focus {
  box-shadow: none;
  outline: none;
}
.message-input[data-v-54844eca] .el-textarea__inner::-moz-placeholder {
  color: #a0a0a0;
}
.message-input[data-v-54844eca] .el-textarea__inner::placeholder {
  color: #a0a0a0;
}
.left-icon[data-v-54844eca] {
  position: relative;
  left: 0;
  margin-right: 8px;
  font-size: 18px;
  color: #a0a0a0;
  cursor: pointer;
  transition: color 0.3s;
}

/* 新增：录音状态样式 */
.left-icon.recording[data-v-54844eca] {
  color: #ff4d4f;
  animation: pulse-54844eca 1.5s infinite;
}
@keyframes pulse-54844eca {
0% { transform: scale(1);
}
50% { transform: scale(1.2);
}
100% { transform: scale(1);
}
}
.right-icons[data-v-54844eca] {
  display: flex;
  align-items: center;
}
.right-icon[data-v-54844eca] {
  margin-left: 12px;
  font-size: 18px;
  color: #a0a0a0;
  cursor: pointer;
}
.stop-icon[data-v-54844eca] {
  margin-left: 12px;
  font-size: 22px;
  color: #F56C6C;
  cursor: pointer;
  animation: pulse-54844eca 1.5s infinite;
}
.send-icon[data-v-54844eca] {
  margin-left: 12px;
  font-size: 20px;
  color: #409eff;
  cursor: pointer;
  transition: all 0.3s;
}
.send-icon[data-v-54844eca]:hover {
  transform: scale(1.1);
}
.right-icon[data-v-54844eca]:hover,
.left-icon[data-v-54844eca]:hover {
  color: #409eff;
}

/* 上传文件相关样式 */
.upload-area[data-v-54844eca] {
  display: inline-block;
}
.uploaded-file[data-v-54844eca] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  padding: 8px 12px;
  background-color: #f5f7fa;
  border-radius: 4px;
}
.file-info[data-v-54844eca] {
  display: flex;
  align-items: center;
}
.file-icon[data-v-54844eca] {
  font-size: 18px;
  color: #409eff;
  margin-right: 8px;
}
.file-name[data-v-54844eca] {
  font-size: 13px;
  color: #333;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.delete-icon[data-v-54844eca] {
  font-size: 16px;
  color: #909399;
  cursor: pointer;
  transition: color 0.3s;
}
.delete-icon[data-v-54844eca]:hover {
  color: #f56c6c;
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/RefSelection.vue?vue&type=style&index=0&id=abb0c42e&scoped=true&lang=css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.ref-select[data-v-abb0c42e] {
  width: 100%;
  font-size: 14px;
}
.ref-select[data-v-abb0c42e]:focus {
  border-color: #409EFF;
  outline: none;
  box-shadow: 0 0 0 2px rgba(74, 131, 187, 0.2);
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/chatSession/FormMessage.vue?vue&type=style&index=0&id=0d76e332&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 表单样式 */
.form-card[data-v-0d76e332] {
  background: white;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  padding: 16px;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  min-width: 300px;
  position: relative; /* Added for loading overlay positioning */
  color:#909399 !important;
}
.form-header[data-v-0d76e332] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.form-header-sticky[data-v-0d76e332] {
  position: sticky;
  top: 0;
  background: white;
  z-index: 10;
}
.form-title[data-v-0d76e332] {
  font-size: 16px;
  color: #909399;
  margin: 0;
  font-weight: 600;
}
.form-item[data-v-0d76e332] {
  margin-bottom: 12px;
}
.form-label[data-v-0d76e332] {
  display: block;
  color: #666;
  font-size: 14px;
  margin-bottom: 4px;
}
.form-control[data-v-0d76e332] {
  width: 100%;
  padding: 8px;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  font-size: 14px;
  box-sizing: border-box;
  color:#606266;
}
.form-control[data-v-0d76e332]:focus {
  border-color: #409EFF;
  outline: none;
  box-shadow: 0 0 0 2px rgba(74, 131, 187, 0.2);
}
.required-star[data-v-0d76e332] {
  color: #ff4444;
  margin-left: 2px;
}
.form-actions[data-v-0d76e332] {
  margin-top: 16px;
  padding-top: 12px;
}
.form-actions-sticky[data-v-0d76e332] {
  position: sticky;
  bottom: 0;
  background: white;
  z-index: 10;
}
.action-buttons[data-v-0d76e332] {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.action-button[data-v-0d76e332] {
  padding: 6px 16px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  border: none;
}
.submit-btn[data-v-0d76e332] {
  background: #409EFF;
  color: white;
}
.submit-btn[data-v-0d76e332]:hover {
  background: #66b1ff;
}
.cancel-btn[data-v-0d76e332] {
  background: white;
  color: #666;
  border: 1px solid #e0e0e0;
}
.cancel-btn[data-v-0d76e332]:hover {
  background: #f0f0f0;
}
.locked-btn[data-v-0d76e332] {
  color: #8c8080;
  cursor: not-allowed;
}
.datalink-btn[data-v-0d76e332] {
  background: #67C23A;
  color: white;
}
.datalink-btn[data-v-0d76e332]:hover {
  background: #85ce61;
}

/* 缩小图标样式 */
.zoom-icon[data-v-0d76e332] {
  font-size: 24px;
  color: #606266;
  cursor: pointer;
  transition: color 0.3s;
  width: 24px;
  height: 24px;
}
.zoom-icon[data-v-0d76e332]:hover {
  opacity: 0.8;
}

/* Loading overlay styles */
.loading-overlay[data-v-0d76e332] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.8); /* Semi-transparent white background */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10; /* Ensure it's above other content */
}
.loading-spinner[data-v-0d76e332] {
  border: 4px solid #f3f3f3;
  border-top: 4px solid #3498db;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  animation: spin-0d76e332 1s linear infinite;
}
@keyframes spin-0d76e332 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/TableComponent.vue?vue&type=style&index=0&id=01b2f77f&scoped=true&lang=css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.form-content[data-v-01b2f77f]{
  width: 40%;
  height: -moz-fit-content;
  height: fit-content;
  max-height: 70%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  overflow: auto;
}
.leave-table-container[data-v-01b2f77f] {
    width: 100%;
    overflow: hidden;
    border: 1px solid var(--border-lighter);
    border-radius: 8px;
    box-shadow: var(--shadow-light);
    margin: 20px 0;
    position: relative;
    transition: all 0.3s ease;
}
.leave-table-container[data-v-01b2f77f]:hover {
    box-shadow: var(--shadow-hover);
}
.leave-table-scroll[data-v-01b2f77f] {
    width: 100%;
    height: 350px;
    overflow: auto !important;
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE and Edge */
    scrollbar-color: transparent transparent;
    touch-action: none;
}
.leave-table-scroll[data-v-01b2f77f]::-webkit-scrollbar {
    height: 0;
    display: none;
}
.leave-table-scroll[data-v-01b2f77f]::-webkit-scrollbar-track {
    background: transparent;
}
.leave-table-scroll[data-v-01b2f77f]::-webkit-scrollbar-thumb {
    background-color: transparent;
}
.leave-table[data-v-01b2f77f] {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}
.leave-table th[data-v-01b2f77f],
.leave-table td[data-v-01b2f77f] {
    padding: 14px 16px;
    text-align: left;
    white-space: nowrap;
    font-size: 14px;
    border-bottom: 1px solid var(--border-lighter);
}
.leave-table th[data-v-01b2f77f] {
    background-color: var(--background-base);
    color: var(--text-regular);
    font-weight: 600;
    position: sticky;
    top: 0;
    z-index: 1;
    border-bottom: 2px solid var(--border-base);
}
.leave-table tbody tr[data-v-01b2f77f] {
    transition: all 0.3s ease;
}
.leave-table tbody tr[data-v-01b2f77f]:hover {
    background-color: var(--primary-bg);
    transform: translateY(-2px);
}
.animate-row[data-v-01b2f77f] {
    animation: fadeIn-01b2f77f 0.5s ease forwards;
    opacity: 0;
    transform: translateY(10px);
}
@keyframes fadeIn-01b2f77f {
from {
        opacity: 0;
        transform: translateY(10px);
}
to {
        opacity: 1;
        transform: translateY(0);
}
}
.view-button[data-v-01b2f77f] {
    padding: 6px 16px;
    font-size: 14px;
    color: white;
    background-color: var(--primary-color);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    box-sizing: border-box;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.view-button[data-v-01b2f77f]:hover {
    background-color: var(--primary-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
}
.view-button[data-v-01b2f77f]:active {
    transform: translateY(0);
}
.button-text[data-v-01b2f77f] {
    position: relative;
    z-index: 1;
}
.view-button[data-v-01b2f77f]::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    background-color: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: width 0.5s, height 0.5s;
}
.view-button[data-v-01b2f77f]:hover::before {
    width: 300%;
    height: 300%;
}
.table-empty[data-v-01b2f77f] {
    position: absolute;
    top: 45%;
    left: 45%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 0;
    color: var(--text-secondary);
}
.empty-icon[data-v-01b2f77f] {
    font-size: 48px;
    margin-bottom: 16px;
}
.empty-text[data-v-01b2f77f] {
    font-size: 14px;
}

/* 新增遮罩层样式 */
.form-modal[data-v-01b2f77f] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* 背景灰化效果 */
  display: flex;
  justify-content: center; /* 水平居中 */
  align-items: center; /* 垂直居中 */
  z-index: 1000; /* 确保在其他内容之上 */
}

/* 可选：为表单添加白色背景和阴影效果 */
.form-modal[data-v-01b2f77f] .form-message-container {
  background-color: white;
  padding: 24px;
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
  width: 90%;
  max-width: 600px;
}

/*!*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/EChartsComponent.vue?vue&type=style&index=0&id=89c1909a&scoped=true&lang=css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.echarts-container[data-v-89c1909a] {
  width: 100%;
  min-height: 350px;
  height: var(--89c1909a-height);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  background-color: #fff;
  margin: 10px 0;
  transition: all 0.3s ease;
}
.echarts-container[data-v-89c1909a]:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/ContentArea.vue?vue&type=style&index=0&id=1f660fa6&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 右侧内容区样式 */
.main-container[data-v-1f660fa6] {
  flex: 1;
  display: flex;
  flex-direction: column;
  background-color: #f0f0f0;
  height: 100%;
  overflow: hidden;
}

/* 分栏布局 */
.split-layout[data-v-1f660fa6] {
  display: flex;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.split-layout .message-bubble[data-v-1f660fa6] {
  max-width: 95%;
}

/* 分栏加载效果样式 */
.loading-container[data-v-1f660fa6] {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #f9f9f9;
}
.split-loading[data-v-1f660fa6] {
  text-align: center;
}
.loading-icon[data-v-1f660fa6] {
  font-size: 32px;
  color: #409EFF;
  margin-bottom: 10px;
  animation: rotate-1f660fa6 1.5s linear infinite;
}
@keyframes rotate-1f660fa6 {
from {
    transform: rotate(0deg);
}
to {
    transform: rotate(360deg);
}
}

/* 内容区样式 */
.content-area[data-v-1f660fa6] {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  background-color: #f0f0f0;
  scroll-behavior: smooth;
}
.empty-content[data-v-1f660fa6] {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #909399;
}
.empty-icon[data-v-1f660fa6] {
  font-size: 60px;
  margin-bottom: 20px;
  color: #dcdfe6;
}

/* 输入区域样式 */
.input-area[data-v-1f660fa6] {
  background-color: transparent;
  padding: 15px 20px 20px;
  width: 100%;
  margin: 0 auto 15px;
}

/* 消息区样式 */
.message-container[data-v-1f660fa6] {
  display: flex;
  flex-direction: column;
  gap: 15px;
  width: 70%;
  margin: 0 auto;
}
.message-bubble[data-v-1f660fa6] {
  display: inline-block;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 60%;
  padding: 12px 16px;
  border-radius: 12px;
  position: relative;
  word-break: break-word;
  font-size: 16px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  color: #333;
}
.left[data-v-1f660fa6] {
  align-self: flex-start;
  background: #fff;
}
.right[data-v-1f660fa6] {
  align-self: flex-end;
  background: #e6f1ff;
}
.modify[data-v-1f660fa6] {
  background-color: #f0f0f0 !important;
  width: 80%;
}

/* 表单样式 */
.form-card[data-v-1f660fa6] {
  background: white;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  padding: 16px;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  min-width: 300px;
}
.form-header[data-v-1f660fa6] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.header-actions[data-v-1f660fa6] {
  display: flex;
  align-items: center;
  gap: 10px;
}
.form-title[data-v-1f660fa6] {
  font-size: 16px;
  color: #333;
  margin: 0;
  font-weight: 600;
}
.form-item[data-v-1f660fa6] {
  margin-bottom: 12px;
}
.form-label[data-v-1f660fa6] {
  display: block;
  color: #666;
  font-size: 14px;
  margin-bottom: 4px;
}
.form-control[data-v-1f660fa6] {
  width: 100%;
  padding: 8px;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  font-size: 14px;
  box-sizing: border-box;
}
.form-control[data-v-1f660fa6]:focus {
  border-color: #409EFF;
  outline: none;
  box-shadow: 0 0 0 2px rgba(74, 131, 187, 0.2);
}
.required-star[data-v-1f660fa6] {
  color: #ff4444;
  margin-left: 2px;
}
.form-actions[data-v-1f660fa6] {
  margin-top: 16px;
  padding-top: 12px;
  position: relative;
}
.divider[data-v-1f660fa6] {
  position: absolute;
  top: 0;
  left: -16px;
  right: -16px;
  height: 1px;
  background: #e0e0e0;
}
.action-buttons[data-v-1f660fa6] {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.action-button[data-v-1f660fa6] {
  padding: 6px 16px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  border: none;
}
.submit-btn[data-v-1f660fa6] {
  background: #409EFF;
  color: white;
}
.submit-btn[data-v-1f660fa6]:hover {
  background: #66b1ff;
}
.cancel-btn[data-v-1f660fa6] {
  background: white;
  color: #666;
  border: 1px solid #e0e0e0;
}
.cancel-btn[data-v-1f660fa6]:hover {
  background: #f0f0f0;
}
.locked-btn[data-v-1f660fa6] {
  color: #8c8080;
  cursor: not-allowed;
}

/* 表格样式 */
.table-container[data-v-1f660fa6] {
  background: white;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  width: 100%;
  max-width: 100%;
}

/* 滚动锚点样式 */
.scroll-anchor[data-v-1f660fa6] {
  height: 1px;
  margin-top: 10px;
  visibility: hidden;
}

/* 放大表单区域样式 */
.zoomed-form-container[data-v-1f660fa6] {
  width: 61.8%;
  /* 黄金分割比例左侧 */
  background-color: #fff;
  padding: 20px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  overflow-y: auto;
  height: 100%;
}
.zoomed-form-content[data-v-1f660fa6] {
  display: flex;
  justify-content: center;
  height: 90%;
}
.zoomed[data-v-1f660fa6] {
  width: 100%;
  max-width: 100%;
  height: 100%;
}

/* 缩小图标样式 */
.zoom-icon[data-v-1f660fa6] {
  font-size: 24px;
  color: #606266;
  cursor: pointer;
  transition: color 0.3s;
  width: 24px;
  height: 24px;
}
.zoom-icon[data-v-1f660fa6]:hover {
  opacity: 0.8;
}

/* 聊天区域样式 */
.chat-container[data-v-1f660fa6] {
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  width: 38.2%;
  /* 黄金分割比例右侧 */
}
.ai-message.loading[data-v-1f660fa6]::after {
  content: "...";
  position: relative;
  font-size: 24px;
  letter-spacing: 2px;
  color: #007bff;
  animation: dots-1f660fa6 1.4s infinite;
}

/* ECharts容器样式 */
.echarts-container-out[data-v-1f660fa6] {
  width: 300px;
  max-width: 400px;
  overflow: hidden;
  border-radius: 4px;
  margin: 5px 0;
}
@keyframes dots-1f660fa6 {
0%,
  20% {
    content: ".";
}
40%,
  60% {
    content: "..";
}
80%,
  100% {
    content: "...";
}
}

/* AI解析内容表格样式 */
.ai-parsed-table[data-v-1f660fa6] {
  margin-top: 10px;
  border-top: 2px solid #409EFF;
  padding-top: 20px;
  position: relative;
}
.ai-section[data-v-1f660fa6] {
  margin-top: 40px;
  position: relative;
}
.ai-section[data-v-1f660fa6]::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  width: 60%;
  height: 2px;
  background-color: #409EFF;
}
.ai-section[data-v-1f660fa6]::after {
  content: "AI解析结果";
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background-color: white;
  padding: 0 15px;
  color: #409EFF;
  font-weight: bold;
  font-size: 14px;
}

/* 表头图例样式 */
.table-legend[data-v-1f660fa6] {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 10px;
  padding-right: 20px;
}
.legend-item[data-v-1f660fa6] {
  display: flex;
  align-items: center;
  margin-left: 15px;
  font-size: 12px;
}
.legend-color[data-v-1f660fa6] {
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 5px;
  border-radius: 3px;
}
.legend-color.excel[data-v-1f660fa6] {
  background-color: #303133;
}
.legend-color.db[data-v-1f660fa6] {
  background-color: #409EFF;
}

/* 微信风格时间条 */
.msg-time-bar[data-v-1f660fa6] {
  text-align: center;
  color: #999;
  font-size: 13px;
  margin: 18px 0 10px 0;
  letter-spacing: 1px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.scroll-to-bottom-btn[data-v-1f660fa6] {
  position: fixed;
  right: 36px;
  bottom: 110px;
  z-index: 99;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.10);
  border-radius: 50%;
  background: #fff;
  cursor: pointer;
  transition: box-shadow 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
}
.scroll-to-bottom-btn[data-v-1f660fa6]:hover {
  box-shadow: 0 4px 16px rgba(64, 158, 255, 0.18);
}
.scroll-to-bottom-btn svg[data-v-1f660fa6] {
  display: block;
}
.load-more-container[data-v-1f660fa6] {
  text-align: center;
  margin-bottom: 15px;
}

/*!*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/AddSessionDialog.vue?vue&type=style&index=0&id=08b0ba0d&scoped=true&lang=css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.el-select[data-v-08b0ba0d] {
  width: 100%;
}

/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/businessManage/DataAnalysis.vue?vue&type=style&index=0&id=6b0f8f70&scoped=true&lang=css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.page-container[data-v-6b0f8f70] {
  display: flex;
  justify-content: center;
  padding: 20px;
  background-color: #f5f7fa;
  min-height: 100vh;
}
.form-content[data-v-6b0f8f70]{
  width: 40%;
  height: -moz-fit-content;
  height: fit-content;
  max-height: 70%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  overflow: auto;
}
.card-container[data-v-6b0f8f70] {
  width: 100%;
  max-width: 1200px;
  background: white;
  border-radius: 6px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  padding: 16px;
  border: 1px solid #e8e8e8;
}
.business-data-analysis[data-v-6b0f8f70] {
  padding: 20px;
}
.header-section[data-v-6b0f8f70] {
  margin-bottom: 16px;
}
.header-actions[data-v-6b0f8f70] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  width: 100%;
}
.header-actions-right[data-v-6b0f8f70] {
  display: flex;
  align-items: center;
  width: 100%;
}
.action-buttons[data-v-6b0f8f70] {
  display: flex;
  gap: 8px;
}
.square-btn[data-v-6b0f8f70] {
  border-radius: 4px;
/* 改为轻微圆角以匹配卡片风格 */
  width: 30px;
/* 根据内容调整宽度 */
 height: 30px;
  display: flex;
  align-items: center;
 justify-content: center;
 border: 1px solid #e8e8e8;
}
.square-btn.active[data-v-6b0f8f70] {
  background-color: #409EFF;
  color: white;
}
.header-dropdown[data-v-6b0f8f70] {
  width: 100%;
  flex: 1;
  margin-left: 16px;
}
.el-select[data-v-6b0f8f70] {
  width: 100%;
}
.filter-options[data-v-6b0f8f70] {
  background-color: #f5f7fa;
  padding: 12px;
  border-radius: 4px;
}
.filter-bubbles[data-v-6b0f8f70] {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.filter-bubble[data-v-6b0f8f70] {
  cursor: pointer;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border-radius: 32px;
  height: 24px;
  line-height: 24px;
  padding: 0px 8px;
  color: rgb(35, 131, 226);
  background: rgb(232, 242, 250);
  border-color: rgb(166, 193, 221);
}
.sort-bubble[data-v-6b0f8f70] {
  cursor: pointer;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border-radius: 32px;
  height: 24px;
  line-height: 24px;
  padding: 0 8px;
  color: rgb(35, 131, 226);
  background: rgb(232, 242, 250);
  border-color: rgb(166, 193, 221);
}
.green-bubble[data-v-6b0f8f70] {
  background-color: #f0fff4;
  color: #52c41a;
  border-color: #b7eb8f;
}
.divider[data-v-6b0f8f70] {
  color: #d9d9d9;
  margin: 0 4px;
}
.table-section[data-v-6b0f8f70] {
  flex: 1;
  background: #f5f5f5;
  overflow: auto;
}
.table-section .el-table[data-v-6b0f8f70] {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.sort-item[data-v-6b0f8f70]{
  margin: 5px;
}
.filter-item[data-v-6b0f8f70]{
  margin: 5px;
}
.editable[data-v-6b0f8f70] {
  border-bottom: 1px dashed #1890ff;
  cursor: pointer;
  color: #1890ff;
}
.form-modal[data-v-6b0f8f70] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* 背景灰化效果 */
  display: flex;
  justify-content: center; /* 水平居中 */
  align-items: center; /* 垂直居中 */
  z-index: 1000; /* 确保在其他内容之上 */
}

/* 可选：为表单添加白色背景和阴影效果 */
.form-modal[data-v-6b0f8f70] .form-message-container {
  background-color: white;
  padding: 24px;
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
  width: 90%;
  max-width: 600px;
}
[data-v-6b0f8f70] .el-table--enable-row-transition .el-table__body td.el-table__cell {
  background: white;
  transition: background-color .25s ease;
}

/*!***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/views/workspace/index.vue?vue&type=style&index=0&id=6303bbae&scoped=true&lang=css ***!
  \***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.workspace-container[data-v-6303bbae] {
  display: flex;
  height: 100vh;
  width: 100%;
  box-sizing: border-box;
}
.workspace-table-out[data-v-6303bbae] {
  width: 100%;
  height: 90%;
  border-right: 1px solid #e6e6e6;
  overflow-y: auto;
  box-sizing: border-box;
}
.workspace-chat[data-v-6303bbae] {
  width: 0;
  height: 100%;
  box-sizing: border-box;
}

/* AI解析内容表格样式 */
.ai-parsed-table[data-v-6303bbae] {
  margin-top: 10px;
  border-top: 2px solid #409EFF;
  padding-top: 20px;
  position: relative;
}
.ai-section[data-v-6303bbae] {
  margin-top: 40px;
  position: relative;
}
.ai-section[data-v-6303bbae]::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  width: 60%;
  height: 2px;
  background-color: #409EFF;
}
.ai-section[data-v-6303bbae]::after {
  content: "AI解析结果";
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background-color: white;
  padding: 0 15px;
  color: #409EFF;
  font-weight: bold;
  font-size: 14px;
}

/* 表头图例样式 */
.table-legend[data-v-6303bbae] {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 10px;
  padding-right: 20px;
}
.legend-item[data-v-6303bbae] {
  display: flex;
  align-items: center;
  margin-left: 15px;
  font-size: 12px;
}
.legend-color[data-v-6303bbae] {
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 5px;
  border-radius: 3px;
}
.legend-color.excel[data-v-6303bbae] {
  background-color: #303133;
}
.legend-color.db[data-v-6303bbae] {
  background-color: #409EFF;
}
.add-button[data-v-6303bbae] {
  position: fixed;
  top: 80px;
  right: 30px;
  cursor: pointer;
  padding: 12px;
  background-color: #409EFF;
  color: white;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  z-index: 1000;
  transition: all 0.3s ease;
}
.add-button[data-v-6303bbae]:hover {
  transform: rotate(90deg);
  background-color: #66b1ff;
}
.add-button i[data-v-6303bbae] {
  font-size: 24px;
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/contacts/SidebarDeptNode.vue?vue&type=style&index=0&id=93d94fd2&scoped=true&lang=css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.sidebar-item[data-v-93d94fd2] {
  padding: 3px 10px;
  border-radius: 4px;
  margin: 1px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  cursor: pointer;
  min-height: 28px;
  position: relative;
  box-shadow: none;
  overflow: visible;
  color: #666;
  font-weight: 500;
}
.item-content[data-v-93d94fd2] {
  display: flex;
  align-items: center;
  flex-grow: 1;
  height: 100%;
  width: 100%;
  cursor: pointer;
}
.item-content span[data-v-93d94fd2] {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}
.sidebar-item[data-v-93d94fd2]:hover {
  background-color: #eaeae8;
}
.sidebar-item.active[data-v-93d94fd2] {
  font-weight: 500;
  background-color: #eaeae8;
  color: #32302C;
}
.sidebar-item svg[data-v-93d94fd2] {
  margin-right: 8px;
  width: 16px;
  height: 16px;
  color: #a3a29e;
}

/* 悬浮图标容器样式 */
.hover-icons[data-v-93d94fd2] {
  display: none;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background-color: inherit;
}
.sidebar-item:hover .hover-icons[data-v-93d94fd2] {
  display: flex;
  align-items: center;
}
.dots-icon[data-v-93d94fd2] {
  margin-right: 8px;
  color: #a3a29e;
  font-size: 16px;
}
.plus-icon[data-v-93d94fd2] {
  color: #a3a29e;
  font-size: 16px;
}

/* 折叠箭头图标样式 */
.collapse-icon[data-v-93d94fd2] {
  display: flex;
  align-items: center;
  margin-right: 8px;
  color: #a3a29e;
  font-size: 14px;
}

/* 默认隐藏带有hover-only类的元素 */
.hover-only[data-v-93d94fd2] {
  display: none;
}
.sidebar-item:hover .hover-only[data-v-93d94fd2] {
  display: flex;
}
.tag[data-v-93d94fd2] {
  background: #eee;
  color: #888;
  border-radius: 2px;
  font-size: 11px;
  padding: 0 4px;
  margin-left: 4px;
  white-space: nowrap;
}

/*!************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/notionComponents/NotionSidebar.vue?vue&type=style&index=0&id=47318ffc&scoped=true&lang=css ***!
  \************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.notion-sidebar[data-v-47318ffc] {
  width: 300px;
  height: 100%;
  background-color: #f8f8f7;
  border-right: 1px solid #e9e9e7;
  display: flex;
  flex-direction: column;
  font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI Variable Display", "Segoe UI", Helvetica, "Apple Color Emoji", Arial, sans-serif, "Segoe UI Emoji", "Segoe UI Symbol";
  color: #5f5e5b;
  font-size: 14px;
  font-weight: bold;
}

/* 自定义滚动条样式 */
.scrollable-sections[data-v-47318ffc]::-webkit-scrollbar {
  width: 8px;
}
.scrollable-sections[data-v-47318ffc]::-webkit-scrollbar-track {
  background-color: rgba(0, 0, 0, 0); /* 滚动条轨道设为透明 */
}
.scrollable-sections[data-v-47318ffc]::-webkit-scrollbar-thumb {
  background-color: #D3D1CB; /* 滚动条滑块颜色 */
  border-radius: 4px;
}
.scrollable-sections[data-v-47318ffc]::-webkit-scrollbar-thumb:hover {
  background-color: #c5c3bd; /* 悬停时颜色稍深 */
}

/* 搜索无结果提示样式 */
.no-results[data-v-47318ffc] {
  padding: 8px 10px;
  color: #a3a29e;
  font-size: 13px;
  font-style: italic;
  text-align: center;
}
.sidebar-header[data-v-47318ffc] {
  padding: 14px 14px;
  display: flex;
  align-items: center;
  background: #f8f8f7;

  justify-content: space-between;
  cursor: pointer;
}
.account-info[data-v-47318ffc] {
  display: flex;
  align-items: center;
}
.account-icon[data-v-47318ffc] {
  width: 18px;
  height: 18px;
  background-color: #37352f;
  color: white;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  margin-right: 8px;
}
.account-name[data-v-47318ffc] {
  font-size: 14px;
  font-weight: 500;
}
.header-icon[data-v-47318ffc] {
  color: #a3a29e;
  font-size: 12px;
}
.search-container[data-v-47318ffc] {
  padding: 0 10px 8px 10px;
}
.search-box[data-v-47318ffc] {
  padding: 3px 10px;
  border-radius: 4px;
  margin: 1px 0;
  display: flex;
  align-items: center;
  font-size: 14px;
  cursor: pointer;
  height: 28px;
  color: #5f5e5b;
  background-color: transparent;
  font-weight: bold;
}
.search-box svg[data-v-47318ffc] {
  margin-right: 8px;
  width: 16px;
  height: 16px;
  color: #a3a29e;
}
.sidebar-main[data-v-47318ffc] {
  flex: 1;
  padding: 0 4px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  /* 防止内容溢出 */
  min-height: 0;
  /* 允许内容区域收缩 */
  height: 100%;
  /* 确保填充父容器高度 */
  background-color: #f8f8f7;
}
.scrollable-sections[data-v-47318ffc] {
  flex: 1;
  overflow-y: auto;
  min-height: 100px;
  /* 给定最小高度 */
  margin-bottom: 0;
  /* 确保与底部没有空隙 */
  display: flex;
  flex-direction: column;
}
.sidebar-section[data-v-47318ffc] {
  margin-bottom: 8px;
  /* 减少部分之间的间距 */
}
.section-header[data-v-47318ffc] {
  padding: 6px 10px;
  font-size: 12px;
  color: #a3a29e;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  /* 添加指针样式 */
  border-radius: 4px;
}
.section-header span[data-v-47318ffc] {
  font-weight: bold;
  cursor: pointer;
}
.section-header .collapse-icon[data-v-47318ffc] {
  cursor: pointer;
}
.section-header[data-v-47318ffc]:hover {
  background-color: #eaeae8;
}
.section-header:hover span[data-v-47318ffc] {
  color: #666666;
}
.sidebar-item[data-v-47318ffc] {
  padding: 3px 10px;
  border-radius: 4px;
  margin: 1px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  cursor: pointer;
  min-height: 28px;
  /* 使用最小高度而不是固定高度 */
  position: relative;
  box-shadow: none;
  overflow: visible;
  /* 确保子元素不会被截断 */
  color: #666;
  font-weight: 500;
}
.item-content[data-v-47318ffc] {
  display: flex;
  align-items: center;
  flex-grow: 1;
  height: 100%;
  width: 100%; /* 确保宽度占满整个区域 */
  cursor: pointer; /* 明确显示可点击状态 */
}
.item-content span[data-v-47318ffc] {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px; /* 设置最大宽度 */
}
.expand-icon[data-v-47318ffc] {
  display: flex;
  align-items: center;
  color: #a3a29e;
  margin-right: 8px;
}
.sidebar-item[data-v-47318ffc]:hover {
  background-color: #eaeae8;
}
.sidebar-item.active[data-v-47318ffc],
.search-box.active-selected[data-v-47318ffc] {
  margin-bottom: 0; /* 原来是10px，改为0移除多余空白 */
  font-weight: 500;
  background-color: #eaeae8;
  color: #32302C;
}
.sidebar-item svg[data-v-47318ffc] {
  margin-right: 8px;
  width: 16px;
  height: 16px;
  color: #a3a29e;
}
.child-sessions[data-v-47318ffc] {
  margin-left: 15px;
  margin-top: 2px;
  margin-bottom: 2px;
  border-left: 1px solid #e9e9e7;
  padding-left: 5px;
}
.child-item[data-v-47318ffc] {
  font-size: 13px;
  min-height: 24px;
  /* 子项目稍小一些 */
}
.tag[data-v-47318ffc] {
  font-size: 11px;
  background-color: #37352f;
  color: white;
  padding: 1px 4px;
  border-radius: 3px;
  margin-left: 6px;
}
.sidebar-footer[data-v-47318ffc] {
  margin-top: auto;
  /* 自动推到底部 */
  padding-top: 8px;
  border-top: 1px solid #e9e9e7;
  background-color: #f8f8f7;
}

/* 添加悬浮图标容器样式 */
.hover-icons[data-v-47318ffc] {
  display: none;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  /* 确保悬浮图标始终在顶层 */
  background-color: inherit;
  /* 继承父元素背景色 */
}
.sidebar-item:hover .hover-icons[data-v-47318ffc] {
  display: flex;
  align-items: center;
}
.dots-icon[data-v-47318ffc] {
  margin-right: 8px;
  color: #a3a29e;
  font-size: 16px;
}
.plus-icon[data-v-47318ffc] {
  color: #a3a29e;
  font-size: 16px;
}

/* 添加section-header悬浮图标容器样式 */
.section-hover-icons[data-v-47318ffc] {
  display: none;
  align-items: center;
  margin-left: auto;
  /* 将图标推到右侧 */
}

/* 添加section-icons容器样式 */
.section-icons[data-v-47318ffc] {
  display: flex;
  align-items: center;
  margin-left: auto;
}

/* 添加折叠箭头图标样式 */
.collapse-icon[data-v-47318ffc] {
  display: flex;
  align-items: center;
  margin-right: 8px;
  color: #a3a29e;
  font-size: 14px;
}
.section-header:hover .section-hover-icons[data-v-47318ffc],
.section-header:hover .hover-only[data-v-47318ffc],
.sidebar-item:hover .hover-only[data-v-47318ffc] {
  display: flex;
}

/* 默认隐藏带有hover-only类的元素 */
.hover-only[data-v-47318ffc] {
  display: none;
}

/* 时间标签样式 */
.time-label[data-v-47318ffc] {
  font-size: 11px;
  color: #a3a29e;
  margin-left: 8px;
  white-space: nowrap;
}

/* 弹出框样式 */
.modal-overlay[data-v-47318ffc] {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.modal-container[data-v-47318ffc] {
  background-color: #fff;
  border-radius: 8px;
  width: 400px;
  max-width: 90%;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}
.modal-header[data-v-47318ffc] {
  padding: 16px;
  border-bottom: 1px solid #e9e9e7;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.modal-header h3[data-v-47318ffc] {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
}
.close-icon[data-v-47318ffc] {
  cursor: pointer;
  color: #a3a29e;
}
.modal-body[data-v-47318ffc] {
  padding: 16px;
}
.form-group[data-v-47318ffc] {
  margin-bottom: 16px;
  position: relative;
}
.form-group label[data-v-47318ffc] {
  display: block;
  margin-bottom: 8px;
  font-size: 14px;
  color: #37352f;
}
.form-group input[data-v-47318ffc],
.form-group select[data-v-47318ffc] {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #e9e9e7;
  border-radius: 4px;
  font-size: 14px;
  color: #37352f;
  background-color: #fff;
}
.form-group input[data-v-47318ffc]:focus,
.form-group select[data-v-47318ffc]:focus {
  outline: none;
  border-color: #a3a29e;
}
.form-group select[data-v-47318ffc]:disabled {
  background-color: #f7f7f5;
  cursor: not-allowed;
}
.modal-footer[data-v-47318ffc] {
  padding: 16px;
  border-top: 1px solid #e9e9e7;
  display: flex;
  justify-content: flex-end;
}
.btn-cancel[data-v-47318ffc],
.btn-confirm[data-v-47318ffc] {
  padding: 6px 12px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  border: none;
}
.btn-cancel[data-v-47318ffc] {
  background-color: #f7f7f5;
  color: #37352f;
  margin-right: 8px;
}
.btn-confirm[data-v-47318ffc] {
  background-color: #37352f;
  color: white;
}
.btn-confirm[data-v-47318ffc]:disabled {
  background-color: #a3a29e;
  cursor: not-allowed;
}
.btn-cancel[data-v-47318ffc]:hover {
  background-color: #eaeae8;
}
.btn-confirm[data-v-47318ffc]:hover:not(:disabled) {
  background-color: #2b2a25;
}
.loading-indicator[data-v-47318ffc] {
  margin-top: 8px;
  font-size: 12px;
  color: #a3a29e;
  display: flex;
  align-items: center;
}
.loading-indicator[data-v-47318ffc]::before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 2px solid #a3a29e;
  border-top-color: transparent;
  border-radius: 50%;
  margin-right: 6px;
  animation: spin-47318ffc 1s linear infinite;
}
@keyframes spin-47318ffc {
from {
    transform: rotate(0deg);
}
to {
    transform: rotate(360deg);
}
}
.search-home-section[data-v-47318ffc] {
  margin-bottom: 0px;
  position: relative;
  padding-bottom: 0px;
}
.search-home-section.with-border[data-v-47318ffc]::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background-color: #e9e9e7;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

/* 加载更多按钮样式 */
.load-more-button[data-v-47318ffc] {
  padding: 3px 10px;
  margin: 6px 0;
  border-radius: 4px;
  text-align: left;
  /* 左对齐文字 */
  font-size: 13px;
  color: #a3a29e;
  cursor: pointer;

  box-shadow: none;
  /* 去掉阴影 */
}
.load-more-button[data-v-47318ffc]:hover {
  background-color: #e1e1df;
  color: #666666;
}
.content-container[data-v-47318ffc] {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  /* 允许容器收缩 */
  overflow: hidden;
  /* 防止内容溢出 */
}

/* Element UI Tree组件自定义样式 */
.el-tree[data-v-47318ffc] {
  background-color: transparent;
  color: #5f5e5b;
}
.el-tree-node__content[data-v-47318ffc] {
  height: 32px;
  border-radius: 4px;
}

/* 增强选择器优先级，确保hover样式统一 */
.el-tree-node__content[data-v-47318ffc]:hover,
.workspaceTree .el-tree-node__content[data-v-47318ffc]:hover,
.notion-sidebar .el-tree-node__content[data-v-47318ffc]:hover {
  background-color: #eaeae8 !important;
}
.el-tree-node.is-current > .el-tree-node__content[data-v-47318ffc] {
  background-color: #eaeae8 !important;
  /* font-weight: 500 !important; */
  color: #32302C !important;
}

/* 全局覆盖Element UI树组件选中样式 */
[data-v-47318ffc] .el-tree-node.is-current > .el-tree-node__content {
  background-color: #eaeae8 !important;
  /* font-weight: 500 !important; */
  color: #32302C !important;
}

/* 工作台树组件样式 - 增强选择器并统一背景色 */
.workspaceTree[data-v-47318ffc] .el-tree-node.is-current > .el-tree-node__content,
.workspaceTree .el-tree-node.is-current > .el-tree-node__content[data-v-47318ffc] {
  background-color: #eaeae8 !important;
  /* font-weight: 500 !important; */
  color: #32302C !important;
}

/* 确保工作台树节点内的文本在选中时变色 */
.workspaceTree .el-tree-node.is-current .custom-tree-node span[data-v-47318ffc],
.workspaceTree[data-v-47318ffc] .el-tree-node.is-current .custom-tree-node span {
  color: #32302C !important;
}

/* 增强选择器优先级 */
.workspaceTree[data-v-47318ffc] .is-current .el-tree-node__content,
.workspaceTree .is-current .el-tree-node__content[data-v-47318ffc] {
  background-color: #eaeae8 !important;
  /* font-weight: 500 !important; */
  color: #32302C !important;
}

/* 覆盖hover状态 */
.workspaceTree[data-v-47318ffc] .el-tree-node__content:hover,
.workspaceTree .el-tree-node__content[data-v-47318ffc]:hover {
  background-color: #eaeae8 !important;
}

/* 确保子节点不继承父节点的选中状态 */
.workspaceTree[data-v-47318ffc] .el-tree-node.is-current > .el-tree-node__children .el-tree-node__content {
  background-color: transparent !important;
  font-weight: 400 !important;
}
.workspaceTree[data-v-47318ffc] .is-current > .el-tree-node__children .el-tree-node__content {
  background-color: transparent !important;
  font-weight: 400 !important;
}
.custom-tree-node[data-v-47318ffc] {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  padding-right: 8px;
  color: #5f5e5b;
  width: 100%;
  position: relative;
}

/* 工作台树节点中悬浮图标的样式 */
.custom-tree-node .hover-icons[data-v-47318ffc] {
  display: none;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background-color: inherit;
}
.custom-tree-node:hover .hover-icons[data-v-47318ffc] {
  display: flex;
  align-items: center;
}

/* 父节点信息样式 */
.parent-info[data-v-47318ffc] {
  padding: 8px 12px;
  border: 1px solid #e9e9e7;
  border-radius: 4px;
  background-color: #f7f7f5;
  font-size: 14px;
  color: #37352f;
}

/* 确保Tree组件中的图标与其他部分一致 */
.custom-tree-node .item-content[data-v-47318ffc] {
  display: flex;
  align-items: center;
  height: 100%;
}

/* 确保树节点内的文本在选中时也变色 */
.el-tree-node.is-current .custom-tree-node .item-content span[data-v-47318ffc] {
  color: #32302C !important;
}
.custom-tree-node .item-content svg[data-v-47318ffc] {
  margin-right: 8px;
  width: 16px;
  height: 16px;
  color: #a3a29e;
}

/* 确保Tree组件中的悬浮图标正常工作 */
.el-tree-node__content:hover .hover-icons[data-v-47318ffc] {
  display: flex;
}
.user-info[data-v-47318ffc] {
  display: flex;
  align-items: center;
  cursor: pointer;
  position: relative;
}
.user-name[data-v-47318ffc] {
  margin-left: 8px;
  font-size: 14px;
  font-weight: 500;
}
.el-icon-arrow-down[data-v-47318ffc] {
  margin-left: 4px;
  font-size: 12px;
  color: #a3a29e;
}
.user-menu[data-v-47318ffc] {
  position: absolute;
  top: 36px;
  left: 0;
  background: #fff;
  border: 1px solid #e9e9e7;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  min-width: 120px;
  z-index: 100;
  padding: 4px 0;
}
.menu-item[data-v-47318ffc] {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  cursor: pointer;
  font-size: 14px;
  color: #37352f;
}
.menu-item[data-v-47318ffc]:hover {
  background: #f5f5f5;
}

/* 重命名文件夹弹窗样式 */
.rename-icon[data-v-47318ffc] {
  margin-left: 8px;
  cursor: pointer;
  color: #a3a29e;
  font-size: 12px;
}

/* 搜索输入框样式 */
.search-input-container[data-v-47318ffc] {
  display: flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 4px;
  margin: 1px 0;
  height: 28px;
  background-color: #eaeae8;
}
.search-input-container svg[data-v-47318ffc] {
  margin-right: 8px;
  width: 16px;
  height: 16px;
  color: #a3a29e;
}
.search-input[data-v-47318ffc] {
  flex: 1;
  border: none;
  background: transparent;
  outline: none;
  font-size: 14px;
  color: #5f5e5b;
  width: 100%;
  font-weight: bold;
}

/* 清除搜索按钮样式 */
.clear-search-icon[data-v-47318ffc] {
  cursor: pointer;
  width: 16px;
  height: 16px;
  color: #a3a29e;
  margin-left: 4px;
}
.clear-search-icon[data-v-47318ffc]:hover {
  color: #37352f;
}

/* 高亮匹配的文本 */
.highlight[data-v-47318ffc] {
  background-color: #ffeb3b;
  font-weight: bold;
  border-radius: 2px;
  padding: 0 2px;
}

/* 添加拖拽提示样式 */
.drag-hint[data-v-47318ffc] {
  padding: 5px 10px;
  color: #a3a29e;
  font-size: 12px;
  font-style: italic;
  background-color: #f0f0ee;
  border-radius: 4px;
  margin: 0 10px 5px 10px;
}
.drag-hint i[data-v-47318ffc] {
  margin-right: 5px;
  color: #909399;
}
.fold-icon[data-v-47318ffc] {
  color: #a3a29e;
  font-size: 16px;
  cursor: pointer;
}
.fold-icon[data-v-47318ffc]:hover {
  color: #32302C;
}
.sheet-action-menu[data-v-47318ffc] {
  left: auto !important;
  right: 0;
  top: 15px;
  min-width: 140px;
  background: #fff;
  border: 1px solid #e9e9e7;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  z-index: 100;
  padding: 4px 0;
  position: absolute;
}
.sheet-action-menu-item[data-v-47318ffc] {
  padding: 8px 20px;
  font-size: 14px;
  color: #333;
  cursor: pointer;
  transition: background 0.2s;
}
.sheet-action-menu-item[data-v-47318ffc]:hover {
  background: #f5f7fa;
}
.inline-plus-menu[data-v-47318ffc] {
  background: #fff;
  border-radius: 4px;
  border: 1px solid #e9e9e7;
  margin: 4px 0 4px 36px;
  box-shadow: none;
  padding: 4px 0;
  min-width: 120px;
}
.inline-plus-menu .menu-item[data-v-47318ffc] {
  padding: 8px 16px;
  cursor: pointer;
  color: #37352f;
}
.inline-plus-menu .menu-item[data-v-47318ffc]:hover {
  background: #f5f5f5;
}
.sheet-plus-sublist[data-v-47318ffc] {
  background: none;
  border: none;
  margin: 0 0 0 0;
  box-shadow: none;
  padding: 0;
  display: block;
}
.sub-sheet-item[data-v-47318ffc] {
  background: none;
  border: none;
  color: #666;
  font-size: 14px;
  font-weight: 400;
  margin: 0;
  padding: 3px 10px 3px 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  box-sizing: border-box;
  border-radius: 4px;
  position: relative;
}
.sub-sheet-item[data-v-47318ffc]:hover {
  background: #eaeae8;
  color: #32302C;
}
.sub-sheet-item.active[data-v-47318ffc] {
  background: #eaeae8;
  color: #32302C;
  font-weight: 500;
}
.sub-item-icon[data-v-47318ffc] {
  width: 14px;
  height: 14px;
  margin-right: 8px;
  opacity: 0.7;
  vertical-align: middle;
}
.sub-sheet-item:hover .sub-item-icon[data-v-47318ffc] {
  opacity: 1;
}
.sub-sheet-item.active .sub-item-icon[data-v-47318ffc] {
  opacity: 1;
}
.sub-type-tag[data-v-47318ffc] {
  font-size: 12px;
  color: #a3a29e;
  margin-left: 8px;
}

/* 业务管理：左侧名称区域仅占自身宽度，避免覆盖整行点击 */
.sheet-item-left[data-v-47318ffc] {
  flex: 0 0 auto;
  width: auto;
}

/* 子菜单项内容区域样式 */
.sub-sheet-item .item-content[data-v-47318ffc] {
  display: flex;
  align-items: center;
  flex-grow: 1;
  cursor: pointer;
}

/* 子菜单项悬浮图标样式 */
.sub-sheet-item .hover-icons[data-v-47318ffc] {
  display: none;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background-color: inherit;
}
.sub-sheet-item:hover .hover-icons[data-v-47318ffc] {
  display: flex;
  align-items: center;
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/WorkflowViewer.vue?vue&type=style&index=0&id=167bb861&lang=css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.workflow-viewer {
  width: 100%;
  height: 100%;
  position: relative;
  border-radius: 4px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}
#viewer-canvas {
  width: 100%;
  height: 100%;
  background-color: #fff;
  background-image: 
    linear-gradient(rgba(200, 200, 200, 0.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 200, 200, 0.1) 1px, transparent 1px);
  background-size: 20px 20px;
  background-position: -1px -1px;
}

/* 高亮样式 */
.highlight:not(.djs-connection) .djs-visual > :nth-child(1) {
  fill: rgba(255, 230, 0, 0.4) !important;
  stroke: #ff9900 !important;
  stroke-width: 2px !important;
}
.highlight.djs-connection .djs-visual > :nth-child(1) {
  stroke: #ff9900 !important;
  stroke-width: 2px !important;
}

/* 优化节点样式 */
.djs-element .djs-visual > :nth-child(1) {
  stroke-width: 1.5px !important;
}

/* 优化字体 */
.djs-label {
  font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif !important;
}

/* 优化导航按钮 */
.djs-navigation-buttons {
  top: 15px;
  right: 15px;
}
.djs-navigation-buttons button {
  background-color: rgba(255, 255, 255, 0.9) !important;
  border: 1px solid #dcdfe6 !important;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1) !important;
  color: #606266 !important;
  padding: 6px !important;
  border-radius: 4px !important;
  margin-left: 8px !important;
  outline: none !important;
  transition: all 0.3s;
}
.djs-navigation-buttons button:hover {
  background-color: #fff !important;
  border-color: #c6e2ff !important;
  color: #409eff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
}

/* 优化鼠标悬浮提示 */
.djs-tooltip {
  font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif !important;
  background-color: rgba(0, 0, 0, 0.7) !important;
  color: #fff !important;
  padding: 6px 10px !important;
  border-radius: 4px !important;
  font-size: 12px !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
}

/* 优化上下文菜单 */
.djs-context-pad {
  border-radius: 4px !important;
  background-color: #fff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
  border: 1px solid #ebeef5 !important;
  padding: 2px !important;
}
.djs-context-pad .entry {
  border-radius: 4px !important;
  margin: 2px !important;
  color: #606266 !important;
}
.djs-context-pad .entry:hover {
  background-color: #ecf5ff !important;
  color: #409eff !important;
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/TableConfig.vue?vue&type=style&index=0&id=326b7eb0&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.table-config-container[data-v-326b7eb0] {
    padding: 20px;
    width: 100%;
    height: calc(100vh - 80px);
    overflow: auto;
}

/* 工单名称头部样式 */
.sheet-name-header[data-v-326b7eb0] {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 18px;
    font-weight: 600;
    color: #303133;
    margin-bottom: 15px;
    line-height: 1.4;
}
.sheet-name-header .el-icon-document[data-v-326b7eb0] {
    color: #409EFF;
    font-size: 18px;
}
.sheet-name-header .name[data-v-326b7eb0] {
    max-width: 60%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.table-config-container[data-v-326b7eb0]::-webkit-scrollbar {
    width: 0;
    display: none;
}

/* 可编辑字段样式 */
.field-table-section .editable-field .el-input__inner[data-v-326b7eb0] {
    background-color: #f0f8ff;
    border-color: #409EFF;
}
.field-table-section .el-table .el-input__inner[data-v-326b7eb0]:hover,
.field-table-section .el-table .el-input.is-focus .el-input__inner[data-v-326b7eb0] {
    border-color: #409EFF;
}

/* 新建工单标签页样式 */
.new-form-tabs[data-v-326b7eb0] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #e4e7ed;
    margin-bottom: 20px;
    background: #fff;
    border-radius: 4px 4px 0 0;
    z-index: 1000;
}
.new-form-tabs .leftTab[data-v-326b7eb0] {
    display: flex;
}
.tab-item[data-v-326b7eb0] {
    padding: 12px 24px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    color: #606266;
    font-size: 14px;
    transition: all 0.3s;
}
.tab-item[data-v-326b7eb0]:hover {
    color: #409EFF;
}
.tab-item.active[data-v-326b7eb0] {
    color: #409EFF;
    border-bottom-color: #409EFF;
    background-color: #f5f7fa;
}
.tab-content[data-v-326b7eb0] {
    background: #fff;
    padding: 0 20px;
    border-radius: 0 0 4px 4px;
    min-height: 300px;
    box-sizing: border-box;
}
.table-name-section[data-v-326b7eb0] {
    margin-bottom: 20px;
    width: 280px;
}
.field-table-section .el-table .el-input[data-v-326b7eb0] {
    width: 100%;
}
.field-table-section .el-select[data-v-326b7eb0] {
    width: 100%;
}
.field-table-section .el-table__header-wrapper[data-v-326b7eb0],
.field-table-section .el-table__body-wrapper[data-v-326b7eb0] {
    width: 100% !important;
}

/* 备注行样式 */
.field-table-section .remark-row[data-v-326b7eb0] {
    background-color: #f8f8f8;
}
.field-table-section .remark-row td[data-v-326b7eb0] {
    border-top: 1px dashed #DCDFE6;
}
.add-field-section[data-v-326b7eb0] {
    text-align: left;
}
.advanced-section[data-v-326b7eb0] {
    text-align: center;
}
.empty-content[data-v-326b7eb0] {
    padding: 60px 0;
}
@keyframes dot-flashing-326b7eb0 {
0% {
        opacity: .2;
}
100% {
        opacity: 1;
}
}
.form-content[data-v-326b7eb0] {
    max-width: 600px;
}
.form-item[data-v-326b7eb0] {
    margin-bottom: 20px;
}
.form-label[data-v-326b7eb0] {
    display: block;
    color: #606266;
    font-size: 14px;
    margin-bottom: 8px;
}
.form-control[data-v-326b7eb0] {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #DCDFE6;
    border-radius: 4px;
    font-size: 14px;
    background: #fff;
    box-sizing: border-box;
    transition: border-color .2s;
}
.form-control-el[data-v-326b7eb0] {
    width: 100%;
}
.form-control[data-v-326b7eb0]:focus {
    border-color: #409EFF;
    outline: none;
}
textarea.form-control[data-v-326b7eb0] {
    min-height: 80px;
    resize: vertical;
}
select.form-control[data-v-326b7eb0] {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    background: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27currentColor%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3e%3cpolyline points=%276 9 12 15 18 9%27%3e%3c/polyline%3e%3c/svg%3e") no-repeat right 10px center;
    background-size: 16px;
}
.required-star[data-v-326b7eb0] {
    color: #F56C6C;
    margin-left: 4px;
}

/* 表单底部操作区 */
.form-actions[data-v-326b7eb0] {
    margin-top: 30px;
}
.action-buttons[data-v-326b7eb0] {
    display: flex;
    gap: 15px;
}

/* 无表单选中时的提示 */
.no-form-selected[data-v-326b7eb0] {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
}

/* 备注字段样式 */
.remark-field[data-v-326b7eb0] {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px dashed #DCDFE6;
}
.remark-field .form-label[data-v-326b7eb0] {
    font-weight: 500;
}
.remark-field textarea.form-control-el[data-v-326b7eb0] {
    min-height: 120px;
}
.preview-form-control[data-v-326b7eb0] {
    width: 100%;
}
.field-table-section .el-table td[data-v-326b7eb0] {
    padding: 8px 0;
}
.field-table-section .el-table .disabled .el-input__inner[data-v-326b7eb0],
.field-table-section .el-table .el-input.is-disabled .el-input__inner[data-v-326b7eb0],
.field-table-section .el-table .el-textarea.is-disabled .el-textarea__inner[data-v-326b7eb0],
.field-table-section .el-table .el-select .el-input.is-disabled .el-input__inner[data-v-326b7eb0] {
    background-color: #f5f7fa;
    border-color: #e4e7ed;
    color: #606266;
    cursor: not-allowed;
}
.edit-notice[data-v-326b7eb0] {
    margin-bottom: 20px;
}
.advanced-card[data-v-326b7eb0] {
    margin-bottom: 20px;
}
.advanced-option[data-v-326b7eb0] {
    margin-bottom: 10px;
}
.option-description[data-v-326b7eb0] {
    color: #606266;
    font-size: 12px;
}
.workflow-section[data-v-326b7eb0] {
    margin-top: 20px;
}
.workflow-card[data-v-326b7eb0] {
    margin-bottom: 20px;
    box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
}
.workflow-header[data-v-326b7eb0] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.empty-workflow[data-v-326b7eb0] {
    text-align: center;
    padding: 60px 0;
}
.workflow-preview[data-v-326b7eb0] {
    padding: 10px;
}
.workflow-info[data-v-326b7eb0] {
    background-color: #f9f9f9;
    padding: 15px;
    border-radius: 4px;
    margin-bottom: 20px;
}
.workflow-name[data-v-326b7eb0],
.workflow-description[data-v-326b7eb0],
.workflow-created[data-v-326b7eb0] {
    margin-bottom: 10px;
    display: flex;
    align-items: baseline;
}
.workflow-name .label[data-v-326b7eb0],
.workflow-description .label[data-v-326b7eb0],
.workflow-created .label[data-v-326b7eb0] {
    font-weight: bold;
    width: 100px;
    color: #606266;
}
.workflow-name .value[data-v-326b7eb0],
.workflow-description .value[data-v-326b7eb0],
.workflow-created .value[data-v-326b7eb0] {
    flex: 1;
    color: #303133;
}
.workflow-diagram[data-v-326b7eb0] {
    margin-top: 20px;
    border: 1px solid #ebeef5;
    border-radius: 4px;
    padding: 15px;
    background-color: #fff;
}
.workflow-diagram h4[data-v-326b7eb0] {
    margin-top: 0;
    margin-bottom: 15px;
    color: #303133;
    font-size: 16px;
    font-weight: 500;
    border-bottom: 1px solid #ebeef5;
    padding-bottom: 10px;
}
.viewer[data-v-326b7eb0] {
    height: 300px;
    border: 1px solid #ebeef5;
    border-radius: 4px;
    overflow: hidden;
}
.workflow-tip[data-v-326b7eb0] {
    color: #606266;
    font-size: 12px;
    margin-top: 10px;
}

/* 节点表格样式美化 */
.workflow-card .el-table[data-v-326b7eb0] {
    margin-top: 10px;
    border-radius: 4px;
    overflow: hidden;
}
.workflow-card .el-table th[data-v-326b7eb0] {
    background-color: #f5f7fa;
    color: #606266;
    font-weight: 500;
}
.workflow-card .el-table td[data-v-326b7eb0] {
    padding: 12px 0;
}
.workflow-card .el-tag[data-v-326b7eb0] {
    font-weight: normal;
    padding: 4px 10px;
    height: auto;
    line-height: 20px;
}
.workflow-card .el-select[data-v-326b7eb0] {
    width: 100%;
}
.workflow-card .el-select .el-input__inner[data-v-326b7eb0] {
    border-color: #e4e7ed;
}
.workflow-card .el-card__header[data-v-326b7eb0] {
    padding: 15px 20px;
    font-weight: bold;
    background-color: #f5f7fa;
}
.workflow-card .el-card__body[data-v-326b7eb0] {
    padding: 20px;
}

/* 节点配置头部 */
.node-config-header[data-v-326b7eb0] {
    display: flex;
    align-items: center;
}
.node-config-header i.el-icon-question[data-v-326b7eb0] {
    margin-left: 8px;
    color: #909399;
    cursor: pointer;
    font-size: 14px;
}
.node-config-header i.el-icon-setting[data-v-326b7eb0] {
    margin-right: 5px;
    color: #606266;
}

/* 节点配置工具栏 */
.node-config-toolbar[data-v-326b7eb0] {
    display: flex;
    justify-content: space-between;
    margin-bottom: 15px;
    align-items: center;
}
.node-search[data-v-326b7eb0] {
    width: 200px;
}

/* 节点名称单元格 */
.node-name-cell[data-v-326b7eb0] {
    display: flex;
    align-items: center;
}
.node-icon[data-v-326b7eb0] {
    margin-right: 8px;
    font-size: 16px;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}
.start-icon[data-v-326b7eb0] {
    color: #409EFF;
    background-color: rgba(64, 158, 255, 0.1);
}
.task-icon[data-v-326b7eb0] {
    color: #67C23A;
    background-color: rgba(103, 194, 58, 0.1);
}
.gateway-icon[data-v-326b7eb0] {
    color: #E6A23C;
    background-color: rgba(230, 162, 60, 0.1);
}
.end-icon[data-v-326b7eb0] {
    color: #909399;
    background-color: rgba(144, 147, 153, 0.1);
}

/* 处理人单元格 */
.assignee-cell[data-v-326b7eb0] {
    width: 100%;
}
.no-assignee[data-v-326b7eb0] {
    color: #C0C4CC;
    text-align: center;
}

/* 节点操作按钮 */
.node-actions[data-v-326b7eb0] {
    display: flex;
    justify-content: center;
}
.node-actions .el-button[data-v-326b7eb0] {
    padding: 2px 5px;
    margin: 0 3px;
}

/* 节点行样式 */
.workflow-card .node-row[data-v-326b7eb0] {
    transition: background-color 0.3s;
}
.workflow-card .node-row[data-v-326b7eb0]:hover {
    background-color: #f5f7fa;
}
.workflow-card .node-type-start[data-v-326b7eb0] {
    background-color: rgba(64, 158, 255, 0.03);
}
.workflow-card .node-type-end[data-v-326b7eb0] {
    background-color: rgba(144, 147, 153, 0.03);
}

/* 节点配置底部 */
.node-config-footer[data-v-326b7eb0] {
    margin-top: 20px;
}
.node-config-footer .el-alert[data-v-326b7eb0] {
    border-radius: 4px;
}
.workflow-list[data-v-326b7eb0] {
    max-height: 50vh;
    overflow-y: auto;
}

/* 基础信息卡片样式 */
.info-card[data-v-326b7eb0] {
    margin-bottom: 20px;
}
.info-card .el-card__header[data-v-326b7eb0] {
    padding: 15px 20px;
    font-weight: bold;
    background-color: #f5f7fa;
}
.info-card .el-form-item__label[data-v-326b7eb0] {
    font-weight: 500;
    color: #606266;
}
.card-header[data-v-326b7eb0] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.table-name-section .el-form-item[data-v-326b7eb0]:last-child {
    margin-top: 20px;
    margin-bottom: 0;
}

/* 示例值提示样式 */
.field-example-hint[data-v-326b7eb0] {
    margin-top: 4px;
    color: #909399;
    font-size: 12px;
}

/* 拖拽相关样式 */
.drag-handle[data-v-326b7eb0] {
    cursor: move;
    color: #909399;
    font-size: 18px;
    transition: all 0.3s;
}
.drag-handle[data-v-326b7eb0]:hover {
    color: #409EFF;
    transform: scale(1.1);
}

/* 主键开关样式 */
.field-table-section .el-switch.is-checked .el-switch__core[data-v-326b7eb0] {
    border-color: #409EFF;
    background-color: #409EFF;
}
[data-v-326b7eb0] .row-dragging {
    opacity: 0.8;
}
[data-v-326b7eb0] .row-dragging td {
    background-color: #409EFF !important;
    color: #fff !important;
}
[data-v-326b7eb0] .row-dragging td .cell {
    color: #fff !important;
}
.el-table__row[data-v-326b7eb0] {
    transition: all 0.2s;
}

/* 节点配置头部 */
.node-config-header[data-v-326b7eb0] {
    display: flex;
    align-items: center;
}
.table-type-info[data-v-326b7eb0] {
    margin-top: 20px;
}
.table-type-content[data-v-326b7eb0] {
    padding: 10px;
    background-color: #f9f9f9;
    border-radius: 4px;
    box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
    font-size: 14px;
}
.required-field[data-v-326b7eb0] {
    color: #F56C6C;
    margin-left: 2px;
    font-size: 14px;
    font-weight: bold;
}
.rightBtn[data-v-326b7eb0] {
    z-index: 10;
}
.small-button[data-v-326b7eb0] {
    padding: 6px 12px;
    font-size: 12px;
    height: 30px;
    line-height: 1;
}
.new-form-tabs .leftTab[data-v-326b7eb0] {
    display: flex;
}
.tab-navigation[data-v-326b7eb0] {
    display: flex;
}
.tab-actions[data-v-326b7eb0] {
    display: flex;
    align-items: center;
}
.small-button[data-v-326b7eb0] {
    padding: 6px 12px;
    font-size: 12px;
    height: 30px;
    line-height: 1;
}
.form-preview-section[data-v-326b7eb0] {
    position: relative;
    z-index: 1;
}

/* 锁定行样式 */
.locked-row td[data-v-326b7eb0] {
    background-color: #fafafa;
}
.drag-handle.is-disabled[data-v-326b7eb0] {
    cursor: not-allowed;
    opacity: 0.4;
}

/*!****************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-24.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-24.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-24.use[3]!./src/plugins/package/theme/index.scss ***!
  \****************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* 改变主题色变量 */
/* 改变 icon 字体路径变量，必需 */
.process-drawer .el-drawer__header {
  padding: 16px 16px 8px 16px;
  margin: 0;
  line-height: 24px;
  font-size: 18px;
  color: #303133;
  box-sizing: border-box;
  border-bottom: 1px solid #e8e8e8;
}

div[class^=el-drawer]:focus,
span:focus {
  outline: none;
}

.process-drawer .el-drawer__body {
  box-sizing: border-box;
  padding: 16px;
  width: 100%;
  overflow-y: auto;
}

.process-design .el-table td,
.process-design .el-table th {
  color: #333;
}
.process-design .el-dialog__header {
  padding: 16px 16px 8px 16px;
  box-sizing: border-box;
  border-bottom: 1px solid #e8e8e8;
}
.process-design .el-dialog__body {
  padding: 16px;
  max-height: 80vh;
  box-sizing: border-box;
  overflow-y: auto;
}
.process-design .el-dialog__footer {
  padding: 16px;
  box-sizing: border-box;
  border-top: 1px solid #e8e8e8;
}
.process-design .el-dialog__close {
  font-weight: 600;
}
.process-design .el-select {
  width: 100%;
}
.process-design .el-divider:not(.el-divider--horizontal) {
  margin: 0 8px;
}
.process-design .el-divider.el-divider--horizontal {
  margin: 16px 0;
}

.djs-palette {
  background: var(--palette-background-color);
  border: solid 1px var(--palette-border-color) !important;
  border-radius: 2px;
}

.my-process-designer {
  padding: 5px 0 10px 10px;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
.my-process-designer .my-process-designer__header {
  width: 100%;
  min-height: 36px;
}
.my-process-designer .my-process-designer__header .el-button {
  text-align: center;
}
.my-process-designer .my-process-designer__header .el-button-group {
  margin: 4px;
}
.my-process-designer .my-process-designer__header .el-tooltip__popper .el-button {
  width: 100%;
  text-align: left;
  padding-left: 8px;
  padding-right: 8px;
}
.my-process-designer .my-process-designer__header .el-tooltip__popper .el-button:hover {
  background: rgba(64, 158, 255, 0.8);
  color: #ffffff;
}
.my-process-designer .my-process-designer__header .align {
  position: relative;
}
.my-process-designer .my-process-designer__header .align i:after {
  content: "|";
  position: absolute;
  transform: rotate(90deg) translate(200%, 60%);
}
.my-process-designer .my-process-designer__header .align.align-left i {
  transform: rotate(90deg);
}
.my-process-designer .my-process-designer__header .align.align-right i {
  transform: rotate(-90deg);
}
.my-process-designer .my-process-designer__header .align.align-top i {
  transform: rotate(180deg);
}
.my-process-designer .my-process-designer__header .align.align-bottom i {
  transform: rotate(0deg);
}
.my-process-designer .my-process-designer__header .align.align-center i {
  transform: rotate(90deg);
}
.my-process-designer .my-process-designer__header .align.align-center i:after {
  transform: rotate(90deg) translate(0, 60%);
}
.my-process-designer .my-process-designer__header .align.align-middle i {
  transform: rotate(0deg);
}
.my-process-designer .my-process-designer__header .align.align-middle i:after {
  transform: rotate(90deg) translate(0, 60%);
}
.my-process-designer .my-process-designer__container {
  display: inline-flex;
  width: 100%;
  flex: 1;
}
.my-process-designer .my-process-designer__container .my-process-designer__canvas {
  flex: 1;
  height: 100%;
  position: relative;
  background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAiIGhlaWdodD0iNDAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PHBhdHRlcm4gaWQ9ImEiIHdpZHRoPSI0MCIgaGVpZ2h0PSI0MCIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHBhdGggZD0iTTAgMTBoNDBNMTAgMHY0ME0wIDIwaDQwTTIwIDB2NDBNMCAzMGg0ME0zMCAwdjQwIiBmaWxsPSJub25lIiBzdHJva2U9IiNlMGUwZTAiIG9wYWNpdHk9Ii4yIi8+PHBhdGggZD0iTTQwIDBIMHY0MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZTBlMGUwIi8+PC9wYXR0ZXJuPjwvZGVmcz48cmVjdCB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2EpIi8+PC9zdmc+) repeat !important;
}
.my-process-designer .my-process-designer__container .my-process-designer__canvas div.toggle-mode {
  display: none;
}
.my-process-designer .my-process-designer__container .my-process-designer__property-panel {
  height: 100%;
  overflow: scroll;
  overflow-y: auto;
  z-index: 10;
}
.my-process-designer .my-process-designer__container .my-process-designer__property-panel * {
  box-sizing: border-box;
}
.my-process-designer .my-process-designer__container svg {
  width: 100%;
  height: 100%;
  min-height: 100%;
  overflow: hidden;
}

.djs-palette.open .djs-palette-entries div[class^=bpmn-icon-]:before,
.djs-palette.open .djs-palette-entries div[class*=bpmn-icon-]:before {
  line-height: unset;
}
.djs-palette.open .djs-palette-entries div.entry {
  position: relative;
}
.djs-palette.open .djs-palette-entries div.entry:hover::after {
  width: -moz-max-content;
  width: max-content;
  content: attr(title);
  vertical-align: text-bottom;
  position: absolute;
  right: -10px;
  top: 0;
  bottom: 0;
  overflow: hidden;
  transform: translateX(100%);
  font-size: 0.5em;
  display: inline-block;
  text-decoration: inherit;
  font-variant: normal;
  text-transform: none;
  background: #fafafa;
  box-shadow: 0 0 6px #eeeeee;
  border: 1px solid #cccccc;
  box-sizing: border-box;
  padding: 0 16px;
  border-radius: 4px;
  z-index: 100;
}

pre {
  margin: 0;
  height: 100%;
  overflow: hidden;
  max-height: calc(80vh - 32px);
  overflow-y: auto;
}

.hljs {
  word-break: break-word;
  white-space: pre-wrap;
}

.hljs * {
  font-family: Consolas, Monaco, monospace;
}

.process-design .process-panel__container {
  box-sizing: border-box;
  padding: 0 8px;
  border-left: 1px solid #eeeeee;
  box-shadow: 0 0 8px #cccccc;
  max-height: 100%;
  overflow-y: scroll;
}
.process-design .panel-tab__title {
  font-weight: 600;
  padding: 0 8px;
  font-size: 1.1em;
  line-height: 1.2em;
}
.process-design .panel-tab__title i {
  margin-right: 8px;
  font-size: 1.2em;
}
.process-design .panel-tab__content {
  width: 100%;
  box-sizing: border-box;
  border-top: 1px solid #eeeeee;
  padding: 8px 16px;
}
.process-design .panel-tab__content .panel-tab__content--title {
  display: flex;
  justify-content: space-between;
  padding-bottom: 8px;
}
.process-design .panel-tab__content .panel-tab__content--title span {
  flex: 1;
  text-align: left;
}
.process-design .element-property {
  width: 100%;
  display: flex;
  align-items: flex-start;
  margin: 8px 0;
}
.process-design .element-property .element-property__label {
  display: block;
  width: 90px;
  text-align: right;
  overflow: hidden;
  padding-right: 12px;
  line-height: 32px;
  font-size: 14px;
  box-sizing: border-box;
}
.process-design .element-property .element-property__value {
  flex: 1;
  line-height: 32px;
}
.process-design .element-property .el-form-item {
  width: 100%;
  margin-bottom: 0;
  padding-bottom: 18px;
}
.process-design .list-property {
  flex-direction: column;
}
.process-design .list-property .element-listener-item {
  width: 100%;
  display: inline-grid;
  grid-template-columns: 16px auto 32px 32px;
  grid-column-gap: 8px;
}
.process-design .list-property .element-listener-item + .element-listener-item {
  margin-top: 8px;
}
.process-design .listener-filed__title {
  display: inline-flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  margin-top: 0;
}
.process-design .listener-filed__title span {
  width: 200px;
  text-align: left;
  font-size: 14px;
}
.process-design .listener-filed__title i {
  margin-right: 8px;
}
.process-design .element-drawer__button {
  margin-top: 8px;
  width: 100%;
  display: inline-flex;
  justify-content: space-around;
}
.process-design .element-drawer__button > .el-button {
  width: 100%;
}
.process-design .el-collapse-item__content {
  padding-bottom: 0;
}
.process-design .el-input.is-disabled .el-input__inner {
  color: #999999;
}
.process-design .el-form-item.el-form-item--mini {
  margin-bottom: 0;
}
.process-design .el-form-item.el-form-item--mini + .el-form-item {
  margin-top: 16px;
}

.process-viewer {
  position: relative;
  border: 1px solid #EFEFEF;
  background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAiIGhlaWdodD0iNDAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PHBhdHRlcm4gaWQ9ImEiIHdpZHRoPSI0MCIgaGVpZ2h0PSI0MCIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHBhdGggZD0iTTAgMTBoNDBNMTAgMHY0ME0wIDIwaDQwTTIwIDB2NDBNMCAzMGg0ME0zMCAwdjQwIiBmaWxsPSJub25lIiBzdHJva2U9IiNlMGUwZTAiIG9wYWNpdHk9Ii4yIi8+PHBhdGggZD0iTTQwIDBIMHY0MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZTBlMGUwIi8+PC9wYXR0ZXJuPjwvZGVmcz48cmVjdCB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2EpIi8+PC9zdmc+) repeat !important;
}
.process-viewer .success-arrow {
  fill: #4eb819;
  stroke: #4eb819;
}
.process-viewer .success-conditional {
  fill: white;
  stroke: #4eb819;
}
.process-viewer .fail-arrow {
  fill: #E6A23C;
  stroke: #E6A23C;
}
.process-viewer .fail-conditional {
  fill: white;
  stroke: #E6A23C;
}
.process-viewer .success.djs-connection .djs-visual path {
  stroke: #4eb819 !important;
  marker-end: url(#sequenceflow-end-white-success) !important;
}
.process-viewer .success.djs-connection.condition-expression .djs-visual path {
  marker-start: url(#conditional-flow-marker-white-success) !important;
}
.process-viewer .success.djs-shape .djs-visual rect {
  stroke: #4eb819 !important;
  fill: #4eb819 !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .success.djs-shape .djs-visual polygon {
  stroke: #4eb819 !important;
}
.process-viewer .success.djs-shape .djs-visual path:nth-child(2) {
  stroke: #4eb819 !important;
  fill: #4eb819 !important;
}
.process-viewer .success.djs-shape .djs-visual circle {
  stroke: #4eb819 !important;
  fill: #4eb819 !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .primary.djs-shape .djs-visual rect {
  stroke: #409EFF !important;
  fill: #409EFF !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .primary.djs-shape .djs-visual polygon {
  stroke: #409EFF !important;
}
.process-viewer .primary.djs-shape .djs-visual circle {
  stroke: #409EFF !important;
  fill: #409EFF !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .warning.djs-connection .djs-visual path {
  stroke: #E6A23C !important;
  marker-end: url(#sequenceflow-end-white-fail) !important;
}
.process-viewer .warning.djs-connection.condition-expression .djs-visual path {
  marker-start: url(#conditional-flow-marker-white-fail) !important;
}
.process-viewer .warning.djs-shape .djs-visual rect {
  stroke: #E6A23C !important;
  fill: #E6A23C !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .warning.djs-shape .djs-visual polygon {
  stroke: #E6A23C !important;
}
.process-viewer .warning.djs-shape .djs-visual path:nth-child(2) {
  stroke: #E6A23C !important;
  fill: #E6A23C !important;
}
.process-viewer .warning.djs-shape .djs-visual circle {
  stroke: #E6A23C !important;
  fill: #E6A23C !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .danger.djs-shape .djs-visual rect {
  stroke: #F56C6C !important;
  fill: #F56C6C !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .danger.djs-shape .djs-visual polygon {
  stroke: #F56C6C !important;
}
.process-viewer .danger.djs-shape .djs-visual circle {
  stroke: #F56C6C !important;
  fill: #F56C6C !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .cancel.djs-shape .djs-visual rect {
  stroke: #909399 !important;
  fill: #909399 !important;
  fill-opacity: 0.15 !important;
}
.process-viewer .cancel.djs-shape .djs-visual polygon {
  stroke: #909399 !important;
}
.process-viewer .cancel.djs-shape .djs-visual circle {
  stroke: #909399 !important;
  fill: #909399 !important;
  fill-opacity: 0.15 !important;
}

.process-viewer .djs-tooltip-container, .process-viewer .djs-overlay-container, .process-viewer .djs-palette {
  display: none;
}
/*!*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/TreeSelect/index.vue?vue&type=style&index=0&id=3b6dbb26&scoped=true&lang=css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.mask[data-v-3b6dbb26] {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  opacity: 0;
  z-index: 11;
}
.common-tree[data-v-3b6dbb26] {
  overflow: auto;
}
.tree-select[data-v-3b6dbb26] {
  z-index: 111;
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/plugins/package/penal/task/task-components/UserTask.vue?vue&type=style&index=0&id=66698ac2&scoped=true&lang=scss ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
.el-row .el-radio-group[data-v-66698ac2] {
  margin-bottom: 15px;
}
.el-row .el-radio-group .el-radio[data-v-66698ac2] {
  line-height: 28px;
}
.el-tag[data-v-66698ac2] {
  margin-bottom: 10px;
}
.el-tag + .el-tag[data-v-66698ac2] {
  margin-left: 10px;
}
.custom-label[data-v-66698ac2] {
  padding-left: 5px;
  font-weight: 500;
  font-size: 14px;
  color: #606266;
}
/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/ProcessDesigner/index.vue?vue&type=style&index=0&id=36f2fa7d&lang=scss ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
body {
  overflow: auto !important;
  margin: 0;
  box-sizing: border-box;
}
body,
body * {
  /* 滚动条 */
}
body::-webkit-scrollbar-track-piece,
body *::-webkit-scrollbar-track-piece {
  background-color: #fff; /*滚动条的背景颜色*/
  -webkit-border-radius: 0; /*滚动条的圆角宽度*/
}
body::-webkit-scrollbar,
body *::-webkit-scrollbar {
  width: 10px; /*滚动条的宽度*/
  height: 8px; /*滚动条的高度*/
}
body::-webkit-scrollbar-thumb:vertical,
body *::-webkit-scrollbar-thumb:vertical {
  /*垂直滚动条的样式*/
  height: 50px;
  background-color: rgba(153, 153, 153, 0.5);
  -webkit-border-radius: 4px;
  outline: 2px solid #fff;
  outline-offset: -2px;
  border: 2px solid #fff;
}
body::-webkit-scrollbar-thumb,
body *::-webkit-scrollbar-thumb {
  /*滚动条的hover样式*/
  background-color: rgba(159, 159, 159, 0.3);
  -webkit-border-radius: 4px;
}
body::-webkit-scrollbar-thumb:hover,
body *::-webkit-scrollbar-thumb:hover {
  /*滚动条的hover样式*/
  background-color: rgba(159, 159, 159, 0.5);
  -webkit-border-radius: 4px;
}
/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/WorkflowModeler.vue?vue&type=style&index=0&id=976b7952&lang=css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.workflow-modeler {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  background-color: #fafafa;
  border-radius: 4px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}
.modeler-toolbar {
  padding: 10px;
  border-bottom: 1px solid #eaeaea;
  background-color: #f5f5f5;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 10;
}
.toolbar-left, .toolbar-right {
  display: flex;
  align-items: center;
}
.toolbar-left .el-button-group {
  margin-right: 10px;
}
.toolbar-right .el-button {
  margin-left: 5px;
}
.modeler-container {
  display: flex;
  flex: 1;
  overflow: hidden;
}
#modeler-canvas {
  flex: 1;
  height: 100%;
  overflow: hidden;
  background-color: #fff;
  background-image: 
    linear-gradient(rgba(200, 200, 200, 0.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 200, 200, 0.1) 1px, transparent 1px);
  background-size: 20px 20px;
  background-position: -1px -1px;
}
#modeler-properties {
  width: 300px;
  height: 100%;
  overflow: auto;
  border-left: 1px solid #eaeaea;
  background-color: #fff;
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.05);
  padding: 0;
}

/* 美化属性面板 - 自定义样式 */
.bpp-properties-panel {
  background-color: white;
  border-left: 1px solid #eaeaea;
  overflow: auto;
  font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif !important;
}
.bpp-properties-panel .bpp-properties-group {
  margin: 0;
  padding: 0;
  list-style: none;
}
.bpp-properties-panel .bpp-properties-header {
  padding: 15px 15px 10px 15px;
}
.bpp-properties-panel .bpp-properties-header .label {
  font-size: 16px;
  font-weight: bold;
}
.bpp-properties-panel [data-group] {
  margin-bottom: 15px;
  border-bottom: 1px solid #eaeaea;
}
.bpp-properties-panel [data-group]:last-child {
  border-bottom: none;
}
.bpp-properties-panel [data-group] > .group-label {
  font-size: 14px !important;
  font-weight: bold !important;
  color: #606266 !important;
  background-color: #f5f7fa !important;
  border-bottom: 1px solid #ebeef5 !important;
  padding: 10px !important;
  margin: 0 !important;
}
.bpp-properties-panel [data-entry] {
  margin: 10px 15px;
}
.bpp-properties-panel [data-entry] .bpp-field-wrapper {
  margin-top: 5px !important;
}
.bpp-properties-panel [data-entry] label {
  color: #606266 !important;
  font-weight: normal !important;
  font-size: 13px;
  display: block;
  margin-bottom: 5px;
}
.bpp-properties-panel [data-entry] input,
.bpp-properties-panel [data-entry] textarea,
.bpp-properties-panel [data-entry] select {
  width: 100%;
  padding: 5px;
  border: 1px solid #dcdfe6;
  border-radius: 4px;
  box-sizing: border-box;
  font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif;
}
.bpp-properties-panel [data-entry] input:focus,
.bpp-properties-panel [data-entry] textarea:focus,
.bpp-properties-panel [data-entry] select:focus {
  outline: none;
  border-color: #409eff;
}
.bpp-properties-panel [data-entry] button {
  background-color: #f4f4f4;
  border: 1px solid #ddd;
  border-radius: 3px;
  padding: 5px 10px;
  font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif;
  cursor: pointer;
}
.bpp-properties-panel [data-entry] button:hover {
  background-color: #e8e8e8;
}

/* 美化工具面板 */
.djs-palette {
  background-color: #fff !important;
  border-right: 1px solid #eaeaea !important;
  box-shadow: 2px 0 5px rgba(0, 0, 0, 0.05) !important;
}
.djs-palette .entry {
  color: #606266 !important;
}
.djs-palette .entry:hover {
  color: #409eff !important;
}
.djs-palette .djs-palette-toggle {
  background-color: #f5f5f5 !important;
  border-bottom: 1px solid #eaeaea !important;
  color: #606266 !important;
}

/* 美化节点样式 */
.djs-element .djs-visual > :nth-child(1) {
  stroke-width: 1.5px !important;
}
.djs-element.selected .djs-visual > :nth-child(1) {
  stroke: #409eff !important;
  stroke-width: 2px !important;
}

/* 在只读模式下隐藏工具栏和属性面板 */
.workflow-modeler.read-only .modeler-toolbar,
.workflow-modeler.read-only #modeler-properties {
  display: none;
}

/* 美化弹窗样式 */
.el-dialog__header {
  padding: 15px 20px;
  background-color: #f5f7fa;
  border-bottom: 1px solid #ebeef5;
}
.el-dialog__title {
  font-size: 16px;
  font-weight: bold;
  color: #303133;
}
.el-dialog__body {
  padding: 20px;
}
.el-upload-dragger {
  background-color: #fafafa;
}
.el-upload-dragger:hover {
  border-color: #409eff;
}
.el-upload__text {
  color: #606266;
}
.el-upload__text em {
  color: #409eff;
  font-style: normal;
}

/* 帮助内容样式 */
.bpmn-help-content {
  max-height: 400px;
  overflow-y: auto;
  padding: 0 10px;
  font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif;
}
.bpmn-help-content h3 {
  font-size: 16px;
  color: #409eff;
  margin-top: 5px;
  margin-bottom: 15px;
  border-bottom: 1px solid #ebeef5;
  padding-bottom: 10px;
}
.bpmn-help-content h4 {
  font-size: 14px;
  color: #606266;
  margin-top: 15px;
  margin-bottom: 10px;
}
.bpmn-help-content p {
  font-size: 13px;
  line-height: 1.6;
  color: #606266;
  margin-bottom: 10px;
}
.bpmn-help-content ul {
  padding-left: 20px;
  margin-bottom: 15px;
}
.bpmn-help-content li {
  font-size: 13px;
  line-height: 1.8;
  color: #606266;
}
.bpmn-help-content strong {
  color: #303133;
  font-weight: bold;
}

/* 导入对话框样式 */
.import-diagram-dialog .el-dialog__header {
  background-color: #f5f7fa;
  padding: 15px 20px;
  border-bottom: 1px solid #ebeef5;
}
.import-diagram-dialog .el-dialog__title {
  font-size: 16px;
  font-weight: bold;
  color: #303133;
}
.import-diagram-dialog .el-dialog__body {
  padding: 20px;
}
.import-diagram-dialog .el-dialog__footer {
  padding: 15px 20px;
  border-top: 1px solid #ebeef5;
  background-color: #f5f7fa;
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/views/workflow/index.vue?vue&type=style&index=0&id=a49883c8&lang=css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.workflow-container {
  padding: 20px;
  height: 100%;
}
.workflow-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}
.workflow-actions {
  display: flex;
  gap: 10px;
}
.search-input {
  width: 250px;
}
.pagination {
  margin-top: 20px;
  text-align: right;
}
.workflow-editor-container {
  height: 600px;
  width: 100%;
  border: 1px solid #ddd;
}
.workflow-viewer-container {
  height: 600px;
  width: 100%;
  border: 1px solid #ddd;
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/notionComponents/HomePage.vue?vue&type=style&index=0&id=1f4d6c2e&scoped=true&lang=css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 主页样式 */
.home-page-container[data-v-1f4d6c2e] {
  padding: 16px 60px;
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
}

/* 问候语部分 */
.greeting-section[data-v-1f4d6c2e] {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
  margin-top: 16px;
  justify-content: center;
}
.greeting-icon[data-v-1f4d6c2e] {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: #f5f5f5;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 16px;
  font-weight: 600;
  color: #333;
}
.greeting-text[data-v-1f4d6c2e] {
  font-size: 24px;
  font-weight: 500;
  color: #333;
  margin: 0;
}

/* Input组件容器 */
.input-container[data-v-1f4d6c2e] {
  margin-bottom: 40px;
}

/* 部分标题 */
.section[data-v-1f4d6c2e] {
  margin-bottom: 40px;
  width: 70%;
  margin-left: auto;
  margin-right: auto;
}
.section-header[data-v-1f4d6c2e] {
  display: flex;
  align-items: center;
  margin-bottom: 16px;
}
.section-icon[data-v-1f4d6c2e] {
  margin-right: 8px;
  display: flex;
  align-items: center;
  color: #666;
}
.section-title[data-v-1f4d6c2e] {
  font-size: 14px;
  font-weight: 500;
  color: #333;
  margin: 0;
}

/* 卡片容器 */
.cards-scroll-container[data-v-1f4d6c2e] {
  position: relative;
  padding: 0 20px;
  margin-top: 8px;
}
.cards-container[data-v-1f4d6c2e] {
  display: flex;
  overflow-x: auto;
  gap: 16px;
  margin-top: 8px;
  padding-bottom: 10px;
  scrollbar-width: none; /* Firefox */
  -webkit-overflow-scrolling: touch;
  min-height: 100px; /* 确保加载状态有足够高度 */
}

/* 隐藏滚动条 */
.cards-container[data-v-1f4d6c2e]::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Edge */
}
.card[data-v-1f4d6c2e] {
  background-color: #f5f5f5;
  border-radius: 6px;
  padding: 16px;
  cursor: pointer;
  transition: background-color 0.2s;
  height: 80px;
  min-width: 180px;
  flex: 0 0 auto;
  position: relative;
}
.card[data-v-1f4d6c2e]:hover {
  background-color: #eaeaea;
}
.card-content[data-v-1f4d6c2e] {
  display: flex;
  height: 100%;
  align-items: flex-start;
}
.card-icon[data-v-1f4d6c2e] {
  margin-right: 12px;
  color: #666;
  flex-shrink: 0;
}
.card-info[data-v-1f4d6c2e] {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.card-title[data-v-1f4d6c2e] {
  font-size: 14px;
  font-weight: 500;
  color: #333;
  margin-bottom: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.card-time[data-v-1f4d6c2e] {
  font-size: 12px;
  color: #888;
}

/* 加载状态样式 */
.loading-indicator[data-v-1f4d6c2e] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100px;
}
.loading-spinner[data-v-1f4d6c2e] {
  width: 24px;
  height: 24px;
  border: 3px solid #f5f5f5;
  border-top: 3px solid #333;
  border-radius: 50%;
  animation: spin-1f4d6c2e 1s linear infinite;
  margin-bottom: 8px;
}
.loading-text[data-v-1f4d6c2e] {
  font-size: 14px;
  color: #666;
}
@keyframes spin-1f4d6c2e {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}

/* 空状态样式 */
.empty-state[data-v-1f4d6c2e] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100px;
  color: #888;
}
.empty-icon[data-v-1f4d6c2e] {
  font-size: 24px;
  margin-bottom: 8px;
}
.empty-text[data-v-1f4d6c2e] {
  font-size: 14px;
}

/* 日历连接卡片 */
.calendar-connect-card[data-v-1f4d6c2e] {
  background-color: #f5f5f5;
  border-radius: 6px;
  padding: 20px;
  display: flex;
  margin-bottom: 20px;
  margin-top: 8px;
}
.calendar-card-icon[data-v-1f4d6c2e] {
  margin-right: 16px;
  font-size: 24px;
  color: #666;
}
.calendar-card-content[data-v-1f4d6c2e] {
  flex: 1;
}
.calendar-card-title[data-v-1f4d6c2e] {
  font-size: 16px;
  font-weight: 500;
  color: #333;
  margin: 0 0 8px 0;
}
.calendar-card-description[data-v-1f4d6c2e] {
  font-size: 14px;
  color: #666;
  margin: 0 0 16px 0;
}
.calendar-card-button[data-v-1f4d6c2e] {
  background-color: #333;
  color: white;
  border: none;
  padding: 6px 12px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
}

/* 事件容器 */
.events-container[data-v-1f4d6c2e] {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 8px;
}
.event-day[data-v-1f4d6c2e] {
  display: flex;
}
.event-day-label[data-v-1f4d6c2e] {
  min-width: 80px;
  padding-right: 16px;
  display: flex;
  flex-direction: column;
}
.day-label[data-v-1f4d6c2e] {
  font-size: 14px;
  font-weight: 500;
  color: #333;
}
.date-label[data-v-1f4d6c2e] {
  font-size: 14px;
  color: #666;
}
.event-card[data-v-1f4d6c2e] {
  flex: 1;
  background-color: #f5f5f5;
  border-radius: 6px;
  padding: 16px;
}
.event-details[data-v-1f4d6c2e] {
  margin-bottom: 12px;
}
.event-title[data-v-1f4d6c2e] {
  font-size: 14px;
  font-weight: 500;
  color: #333;
  margin: 0 0 4px 0;
}
.event-time[data-v-1f4d6c2e] {
  font-size: 14px;
  color: #666;
}
.event-actions[data-v-1f4d6c2e] {
  display: flex;
}
.event-action-button[data-v-1f4d6c2e] {
  display: flex;
  align-items: center;
  gap: 6px;
  background-color: #e0e0e0;
  border: none;
  padding: 6px 12px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  color: #333;
}
.event-action-button svg[data-v-1f4d6c2e] {
  font-size: 16px;
}

/* 滚动按钮 */
.scroll-button[data-v-1f4d6c2e] {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: white;
  border: 1px solid #e0e0e0;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  color: #666;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.scroll-button[data-v-1f4d6c2e]:hover {
  background-color: #f5f5f5;
}
.scroll-button.left[data-v-1f4d6c2e] {
  left: -16px;
}
.scroll-button.right[data-v-1f4d6c2e] {
  right: -16px;
}
.left-gradient[data-v-1f4d6c2e], .right-gradient[data-v-1f4d6c2e] {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 40px;
  pointer-events: none;
  z-index: 5;
}
.left-gradient[data-v-1f4d6c2e] {
  left: 0;
  background: linear-gradient(to right, white 0%, rgba(255, 255, 255, 0) 100%);
}
.right-gradient[data-v-1f4d6c2e] {
  right: 0;
  background: linear-gradient(to left, white 0%, rgba(255, 255, 255, 0) 100%);
}

/*!************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/Account.vue?vue&type=style&index=0&id=6d0444a6&scoped=true&lang=css ***!
  \************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.account-container[data-v-6d0444a6] {
    overflow: scroll;
    padding: 20px;
}
.header[data-v-6d0444a6] {
    margin-bottom: 20px;
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/approval/ApprovalList.vue?vue&type=style&index=0&id=1d4d538d&scoped=true&lang=css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.approval-list[data-v-1d4d538d] {
  height: 100%;
  border-right: 1px solid #e6e6e6;
  display: flex;
  flex-direction: column;
}
.approval-list-header[data-v-1d4d538d] {
  padding: 10px 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #e6e6e6;
}
.el-dropdown-link[data-v-1d4d538d] {
  cursor: pointer;
  color: #606266;
}

/* 项目标题样式 */
.project-header[data-v-1d4d538d] {
  padding: 10px 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  border-bottom: 1px solid #f0f0f0;
  cursor: pointer;
  background-color: #f8f8f8;
}
.collapse-icon[data-v-1d4d538d] {
  cursor: pointer;
}
.approval-list-content[data-v-1d4d538d] {
  flex: 1;
  overflow-y: auto;
}
.approval-item[data-v-1d4d538d] {
  padding: 15px;
  border-bottom: 1px solid #f0f0f0;
  cursor: pointer;
  transition: background-color 0.2s;
}
.approval-item[data-v-1d4d538d]:hover {
  background-color: #f5f7fa;
}
.approval-item.active[data-v-1d4d538d] {
  background-color: #ecf5ff;
}
.approval-item-title[data-v-1d4d538d] {
  font-weight: 500;
  margin-bottom: 10px;
}
.approval-item-info[data-v-1d4d538d] {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
  font-size: 12px;
  color: #606266;
}
.approval-item-time[data-v-1d4d538d] {
  flex: 1;
}
.approval-item-user[data-v-1d4d538d] {
  display: flex;
  align-items: center;
  font-size: 12px;
  color: #909399;
}
.approval-item-process-time[data-v-1d4d538d] {
  margin-left: 5px;
}
.no-data[data-v-1d4d538d] {
  padding: 30px 0;
  text-align: center;
  color: #909399;
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/approval/ApprovalTabs.vue?vue&type=style&index=0&id=cfd73326&scoped=true&lang=css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.approval-tabs[data-v-cfd73326] {
  width: 100%;
}

/* 固定标签导航 */
.sticky-tabs[data-v-cfd73326] {
  position: sticky;
  top: 0;
  z-index: 10;
  background: #fff;
  border-bottom: 1px solid #e4e7ed;
}

/* 内容滚动容器 */
.tab-content-container[data-v-cfd73326] {
  /* 修改为相对高度，确保填充父容器 */
  height: calc(100vh - 220px);
  overflow-y: auto;
  padding: 16px;
}

/* 内容区块样式 */
.tab-section[data-v-cfd73326] {
  min-height: 500px; /* 确保每个区块有足够高度触发滚动 */
  margin-bottom: 32px;
  padding: 16px;
  border-radius: 4px;
}

/* 最后一个区块移除底部边距 */
.tab-section[data-v-cfd73326]:last-child {
  margin-bottom: 0;
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/approval/ApprovalRecord.vue?vue&type=style&index=0&id=54478400&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.approval-record[data-v-54478400] {
  padding: 10px 0;
}
.record-title[data-v-54478400] {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  border-left: 4px solid #409EFF;
  padding-left: 10px;
}
.approver[data-v-54478400] {
  display: flex;
  align-items: center;
}
.approver .el-avatar[data-v-54478400] {
  margin-right: 8px;
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/approval/ApprovalDetail.vue?vue&type=style&index=0&id=2a95a000&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 全局样式，确保流程图正确显示 */
.process-viewer {
  width: 100%;
  height: 100%;
}
.djs-container {
  width: 100% !important;
  height: 100% !important;
}
.bjs-container {
  height: 100% !important;
}
.canvas {
  height: 100% !important;
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/approval/ApprovalDetail.vue?vue&type=style&index=1&id=2a95a000&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.approval-detail[data-v-2a95a000] {
  padding: 20px;
  height: 100%;
  /* 移除以下行 */
  /* overflow-y: auto; */
}
.approval-header[data-v-2a95a000] {
  display: flex;
  justify-content: left;
  align-items: center;
  margin-bottom: 20px;
}
.approval-header h2[data-v-2a95a000] {
  margin: 0;
  font-size: 20px;
}
.approval-submitter[data-v-2a95a000] {
  display: flex;
  align-items: center;
  margin-bottom: 30px;
  padding-bottom: 20px;
  border-bottom: 1px solid #ebeef5;
}
.submitter-info[data-v-2a95a000] {
  margin-left: 10px;
}
.submitter-name[data-v-2a95a000] {
  font-weight: bold;
}
.submit-time[data-v-2a95a000] {
  font-size: 12px;
  color: #909399;
  margin-top: 5px;
}
.info-section[data-v-2a95a000] {
  margin-bottom: 30px;
}
.info-title[data-v-2a95a000] {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  border-left: 4px solid #409EFF;
  padding-left: 10px;
}
.info-item[data-v-2a95a000] {
  display: flex;
  margin-bottom: 15px;
}
.info-label[data-v-2a95a000] {
  width: 100px;
  color: #606266;
}
.info-value[data-v-2a95a000] {
  flex: 1;
  color: #303133;
}
.comments-title[data-v-2a95a000] {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  border-left: 4px solid #409EFF;
  padding-left: 10px;
}
.comment-item[data-v-2a95a000] {
  display: flex;
  margin-bottom: 20px;
}
.comment-content[data-v-2a95a000] {
  margin-left: 10px;
  flex: 1;
}
.comment-header[data-v-2a95a000] {
  display: flex;
  justify-content: space-between;
  margin-bottom: 5px;
}
.comment-user[data-v-2a95a000] {
  font-weight: bold;
}
.comment-time[data-v-2a95a000] {
  font-size: 12px;
  color: #909399;
}
.comment-text[data-v-2a95a000] {
  line-height: 1.5;
}
.no-comments[data-v-2a95a000] {
  text-align: center;
  padding: 20px;
  color: #909399;
}
.comment-input[data-v-2a95a000] {
  margin-top: 20px;
}
.comment-input .el-button[data-v-2a95a000] {
  margin-top: 10px;
  float: right;
}
.process-container[data-v-2a95a000] {
  width: 100%;
  height: 550px;
  position: relative;
}
.process-container .box-card[data-v-2a95a000] {
  height: 100%;
}
.process-container .el-card__body[data-v-2a95a000] {
  height: 100%;
  padding: 0;
}
.loading-container[data-v-2a95a000] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(255, 255, 255, 0.7);
}
.box-card[data-v-2a95a000] {
  width: 100%;
  margin-bottom: 20px;
}
.no-data[data-v-2a95a000] {
  text-align: center;
  padding: 50px 0;
  color: #909399;
}
.el-timeline[data-v-2a95a000] {
  padding-left: 20px;
}
.clearfix[data-v-2a95a000]:before,
.clearfix[data-v-2a95a000]:after {
  display: table;
  content: "";
}
.clearfix[data-v-2a95a000]:after {
  clear: both
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/views/notification/LeaveApproval.vue?vue&type=style&index=0&id=adee0320&scoped=true&lang=css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.leave-approval-container[data-v-adee0320] {
  height: 100%;
  padding: 20px;
}
.approval-layout[data-v-adee0320] {
  display: flex;
  height: 100%;
  background-color: #fff;
  border-radius: 4px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  overflow: hidden;
}
.approval-sidebar[data-v-adee0320] {
  width: 300px;
  border-right: 1px solid #e6e6e6;
  overflow: hidden;
}
.approval-content[data-v-adee0320] {
  flex: 1;
  overflow: hidden;
}
.no-selection[data-v-adee0320] {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  color: #909399;
  font-size: 14px;
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/contacts/DepartmentMembers.vue?vue&type=style&index=0&id=1a2c131b&scoped=true&lang=css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.department-members[data-v-1a2c131b] {
  height: 100%;
  display: flex;
  flex-direction: column;
}
.header-section[data-v-1a2c131b] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  background: #fff;
  border-bottom: 1px solid #e8e8e8;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}
.header-left[data-v-1a2c131b] {
  display: flex;
  align-items: center;
  gap: 16px;
}
.dept-name[data-v-1a2c131b] {
  margin: 0;
  font-size: 24px;
  font-weight: 600;
  color: #1a1a1a;
}
.member-count[data-v-1a2c131b] {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 14px;
  color: #666;
}
.current-count[data-v-1a2c131b] {
  font-weight: 600;
  color: #409eff;
  font-size: 16px;
}
.separator[data-v-1a2c131b] {
  color: #999;
}
.total-count[data-v-1a2c131b] {
  font-weight: 600;
  color: #333;
}
.count-label[data-v-1a2c131b] {
  color: #999;
}
.header-right[data-v-1a2c131b] {
  display: flex;
  gap: 12px;
}
.table-section[data-v-1a2c131b] {
  flex: 1;
  padding: 24px;
  background: #f5f5f5;
  overflow: auto;
}
.table-section .el-table[data-v-1a2c131b] {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/* 响应式设计 */
@media (max-width: 768px) {
.header-section[data-v-1a2c131b] {
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
}
.header-left[data-v-1a2c131b] {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}
.table-section[data-v-1a2c131b] {
    padding: 16px;
}
}
.transfer-wrapper[data-v-1a2c131b] {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-left: -20px;
  min-width: 600px;
  gap: 0;
}
[data-v-1a2c131b] .el-transfer {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  width: 600px !important;
  gap: 0;
}
[data-v-1a2c131b] .el-transfer__buttons {
  flex-direction: column !important;
  margin: 0 8px;
  width: 40px;
}
[data-v-1a2c131b] .el-transfer-panel {
  width: 200px !important;
  min-width: 180px !important;
}
[data-v-1a2c131b] .el-transfer__button {
  margin: 0 !important;
}
.execute-switch[data-v-1a2c131b] {
  display: flex;
  align-items: center;
  margin: 16px 0 0 0;
  /* 上下间距更大，去掉左边距 */
  padding-left: 100px;
  /* 与表单label对齐 */
}
.execute-switch span[data-v-1a2c131b] {
  margin-right: 16px;
  font-size: 15px;
  color: #606266;
  min-width: 80px;
  text-align: left;
}
.dialog-footer[data-v-1a2c131b] {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-right: 8px;
  gap: 16px;
}

/* 与 Formcalc.vue 保持一致的必填星号样式 */
.required-star[data-v-1a2c131b] {
  color: #f56c6c;
  margin-right: 4px;
}
[data-v-1a2c131b] .el-dialog__body {
  padding-top: 16px !important;
  padding-bottom: 4px !important;
}
[data-v-1a2c131b] .el-form-item {
  margin-bottom: 18px !important;
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/contacts/MemberDetail.vue?vue&type=style&index=0&id=9604aef2&scoped=true&lang=css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.member-detail-container[data-v-9604aef2] {
  padding: 20px;
  width: 100%;
  height: calc(100vh - 80px);
  overflow: auto;
  background: #fff;
  border-radius: 4px;
}
.new-form-tabs[data-v-9604aef2] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #e4e7ed;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 4px 4px 0 0;
}
.tab-navigation[data-v-9604aef2] {
  display: flex;
}
.tab-actions[data-v-9604aef2] {
  display: flex;
  align-items: center;
}
.small-button[data-v-9604aef2] {
  padding: 6px 12px;
  font-size: 12px;
  height: 30px;
  line-height: 1;
}
.tab-item[data-v-9604aef2] {
  padding: 12px 24px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  color: #606266;
  font-size: 14px;
  transition: all 0.3s;
}
.tab-item.active[data-v-9604aef2] {
  color: #409EFF;
  border-bottom-color: #409EFF;
  background-color: #f5f7fa;
}
.tab-content[data-v-9604aef2] {
  background: #fff;
  padding: 0 20px 0 60px;
  border-radius: 0 0 4px 4px;
  min-height: 300px;
  box-sizing: border-box;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
}
.member-detail-table[data-v-9604aef2] {
  width: 420px;
  margin: 32px auto 0 auto;
  border-collapse: collapse;
  background: #fff;
  box-shadow: 0 2px 8px #eee;
  font-size: 14px;
}
.member-detail-table th[data-v-9604aef2] {
  text-align: right;
  background: #f8f8f7;
  color: #888;
  font-weight: normal;
  padding: 8px 12px;
  border-bottom: 1px solid #eee;
  width: 120px;
}
.member-detail-table td[data-v-9604aef2] {
  text-align: left;
  padding: 8px 12px;
  border-bottom: 1px solid #eee;
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/ProcessInfo.vue?vue&type=style&index=0&id=5ff03f3d&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.process-info-container[data-v-5ff03f3d] {
  padding: 20px;
  width: 100%;
  height: calc(100vh - 80px);
  overflow: auto;
  background: #fff;
  border-radius: 4px;
}
.process-tabs[data-v-5ff03f3d] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #e4e7ed;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 4px 4px 0 0;
}
.tab-navigation[data-v-5ff03f3d] {
  display: flex;
}
.tab-actions[data-v-5ff03f3d] {
  display: flex;
  align-items: center;
}
.small-button[data-v-5ff03f3d] {
  padding: 6px 12px;
  font-size: 12px;
  height: 30px;
  line-height: 1;
}
.execute-switch[data-v-5ff03f3d] {
  display: flex;
  align-items: center;
  margin-left: 15px;
}
.execute-switch span[data-v-5ff03f3d] {
  margin-right: 8px;
  font-size: 14px;
  color: #606266;
}
.tab-item[data-v-5ff03f3d] {
  padding: 12px 24px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  color: #606266;
  font-size: 14px;
  transition: all 0.3s;
}
.tab-item[data-v-5ff03f3d]:hover {
  color: #409EFF;
}
.tab-item.active[data-v-5ff03f3d] {
  color: #409EFF;
  border-bottom-color: #409EFF;
  background-color: #f5f7fa;
}
.tab-content[data-v-5ff03f3d] {
  background: #fff;
  padding: 0 20px;
  border-radius: 0 0 4px 4px;
  min-height: 300px;
  box-sizing: border-box;
}
.table-name-section[data-v-5ff03f3d] {
  margin-bottom: 20px;
}
.table-name-section h3[data-v-5ff03f3d] {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 15px;
  color: #303133;
}
.info-card[data-v-5ff03f3d] {
  margin-bottom: 20px;
}
.card-header[data-v-5ff03f3d] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: bold;
  background-color: #f5f7fa;
}
.design-card[data-v-5ff03f3d] {
  margin-bottom: 20px;
}
.required-star[data-v-5ff03f3d] {
  color: #f56c6c;
  margin-left: 4px;
}
.tab-content h3[data-v-5ff03f3d] {
  margin-top: 0;
  margin-bottom: 20px;
  color: #303133;
  font-size: 16px;
  font-weight: 500;
}
.table-name-section[data-v-5ff03f3d] {
  margin-bottom: 20px;
  width: 280px;
}
.loading-overlay[data-v-5ff03f3d] {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}
.loading-overlay p[data-v-5ff03f3d] {
  margin-top: 10px;
  color: #606266;
  font-size: 14px;
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/datalink/Datalink.vue?vue&type=style&index=0&id=5c60be6f&scoped=true&lang=css ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.datalink-container[data-v-5c60be6f] {
    padding: 20px;
    width: 100%;
    height: calc(100vh - 80px);
    overflow: auto;
}
.datalink-container[data-v-5c60be6f]::-webkit-scrollbar {
    width: 0;
    display: none;
}

/* 新建工单标签页样式 */
.new-form-tabs[data-v-5c60be6f] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #e4e7ed;
    margin-bottom: 20px;
    background: #fff;
    border-radius: 4px 4px 0 0;
    z-index: 1000;
}
.tab-navigation[data-v-5c60be6f] {
    display: flex;
}
.tab-item[data-v-5c60be6f] {
    padding: 12px 24px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    color: #606266;
    font-size: 14px;
    transition: all 0.3s;
}
.tab-item[data-v-5c60be6f]:hover {
    color: #409EFF;
}
.tab-item.active[data-v-5c60be6f] {
    color: #409EFF;
    border-bottom-color: #409EFF;
    background-color: #f5f7fa;
}
.tab-content[data-v-5c60be6f] {
    background: #fff;
    padding: 0 20px;
    border-radius: 0 0 4px 4px;
    min-height: 300px;
    box-sizing: border-box;
}
.tab-content h3[data-v-5c60be6f] {
    margin-top: 0;
    margin-bottom: 20px;
    color: #303133;
    font-size: 16px;
    font-weight: 500;
}
.table-name-section[data-v-5c60be6f] {
    margin-bottom: 20px;
    width: 280px;
}
.tab-actions[data-v-5c60be6f] {
    display: flex;
    align-items: center;
}
.small-button[data-v-5c60be6f] {
    padding: 6px 12px;
    font-size: 12px;
    height: 30px;
    line-height: 1;
}
.execute-switch[data-v-5c60be6f] {
    display: flex;
    align-items: center;
    margin-left: 15px;
}
.execute-switch span[data-v-5c60be6f] {
    margin-right: 8px;
    font-size: 14px;
    color: #606266;
}
.required-star[data-v-5c60be6f] {
    color: #F56C6C;
    margin-left: 4px;
}

/* DataLink Loading 遮罩层样式 */
.datalink-loading-mask[data-v-5c60be6f] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.8);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* DataLink 相关样式 */
.datalink-section[data-v-5c60be6f] {
    margin-top: 20px;
    position: relative;
    z-index: 1;
}
.form-preview-section[data-v-5c60be6f] {
    position: relative;
    z-index: 1;
}
.form-title[data-v-5c60be6f] {
    font-size: 18px;
    color: #303133; 
    font-weight: 500;
    text-align: center;
    margin-bottom: 20px;
}

/* SQL提示语样式 */
.sql-hint-section[data-v-5c60be6f] {
    margin-top: 10px;
    padding: 10px;
    background-color: #f4f4f4;
    border: 1px solid #ebeef5;
    border-radius: 4px;
    font-size: 14px;
    color: #606266;
    line-height: 1.6;
}
.sql-hint-title[data-v-5c60be6f] {
    font-weight: bold;
    margin-bottom: 5px;
}
.sql-hint-content[data-v-5c60be6f] {
    word-break: break-all; /* 允许在单词内换行 */
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/dataflow/Dataflow.vue?vue&type=style&index=0&id=3f2598ef&scoped=true&lang=css ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.data-flow-container[data-v-3f2598ef] {
  padding: 20px;
  width: 100%;
  height: calc(100vh - 80px);
  overflow: auto;
  background: #fff;
  border-radius: 4px;
}
.required-star[data-v-3f2598ef] {
  color: #f56c6c;
  margin-right: 4px;
}
.new-form-tabs[data-v-3f2598ef] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #e4e7ed;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 4px 4px 0 0;
}
.tab-navigation[data-v-3f2598ef] {
  display: flex;
}
.tab-actions[data-v-3f2598ef] {
  display: flex;
  align-items: center;
}
.small-button[data-v-3f2598ef] {
  padding: 6px 12px;
  font-size: 12px;
  height: 30px;
  line-height: 1;
}
.execute-switch[data-v-3f2598ef] {
  display: flex;
  align-items: center;
  margin-left: 15px;
}
.execute-switch span[data-v-3f2598ef] {
  margin-right: 8px;
  font-size: 14px;
  color: #606266;
}
.form-calc-switch[data-v-3f2598ef] {
  display: flex;
  align-items: center;
  margin-left: 15px;
}
.form-calc-switch span[data-v-3f2598ef] {
  margin-right: 8px;
  font-size: 14px;
  color: #606266;
}
.tab-item[data-v-3f2598ef] {
  padding: 12px 24px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  color: #606266;
  font-size: 14px;
  transition: all 0.3s;
}
.tab-item[data-v-3f2598ef]:hover {
  color: #409EFF;
}
.tab-item.active[data-v-3f2598ef] {
  color: #409EFF;
  border-bottom-color: #409EFF;
  background-color: #f5f7fa;
}
.tab-content[data-v-3f2598ef] {
  background: #fff;
  padding: 0 20px;
  border-radius: 0 0 4px 4px;
  min-height: 300px;
  box-sizing: border-box;
}
.tab-content h3[data-v-3f2598ef] {
  margin-top: 0;
  margin-bottom: 20px;
  color: #303133;
  font-size: 16px;
  font-weight: 500;
}
.table-name-section[data-v-3f2598ef] {
  margin-bottom: 20px;
  width: 280px;
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/dataflow/Formcalc.vue?vue&type=style&index=0&id=0c26eca0&scoped=true&lang=css ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.formcalc-container[data-v-0c26eca0] {
  padding: 20px;
  width: 100%;
  height: calc(100vh - 80px);
  overflow: auto;
  background: #fff;
  border-radius: 4px;
}
.required-star[data-v-0c26eca0] {
  color: #f56c6c;
  margin-right: 4px;
}
.new-form-tabs[data-v-0c26eca0] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #e4e7ed;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 4px 4px 0 0;
}
.tab-navigation[data-v-0c26eca0] {
  display: flex;
}
.tab-actions[data-v-0c26eca0] {
  display: flex;
  align-items: center;
}
.small-button[data-v-0c26eca0] {
  padding: 6px 12px;
  font-size: 12px;
  height: 30px;
  line-height: 1;
}
.execute-switch[data-v-0c26eca0] {
  display: flex;
  align-items: center;
  margin-left: 15px;
}
.execute-switch span[data-v-0c26eca0] {
  margin-right: 8px;
  font-size: 14px;
  color: #606266;
}
.tab-item[data-v-0c26eca0] {
  padding: 12px 24px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  color: #606266;
  font-size: 14px;
  transition: all 0.3s;
}
.tab-item[data-v-0c26eca0]:hover {
  color: #409EFF;
}
.tab-item.active[data-v-0c26eca0] {
  color: #409EFF;
  border-bottom-color: #409EFF;
  background-color: #f5f7fa;
}
.tab-content[data-v-0c26eca0] {
  background: #fff;
  padding: 0 20px;
  border-radius: 0 0 4px 4px;
  min-height: 300px;
  box-sizing: border-box;
}
.tab-content h3[data-v-0c26eca0] {
  margin-top: 0;
  margin-bottom: 20px;
  color: #303133;
  font-size: 16px;
  font-weight: 500;
}
.table-name-section[data-v-0c26eca0] {
  margin-bottom: 20px;
  width: 280px;
}

/*!******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/refselection/RefSelection.vue?vue&type=style&index=0&id=d8991222&scoped=true&lang=css ***!
  \******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.ref-selection-container[data-v-d8991222] {
  padding: 20px;
  width: 100%;
  height: calc(100vh - 80px);
  overflow: auto;
  background: #fff;
  border-radius: 4px;
}
.required-star[data-v-d8991222] {
  color: #f56c6c;
  margin-right: 4px;
}
.new-form-tabs[data-v-d8991222] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #e4e7ed;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 4px 4px 0 0;
}
.tab-navigation[data-v-d8991222] {
  display: flex;
}
.tab-actions[data-v-d8991222] {
  display: flex;
  align-items: center;
}
.small-button[data-v-d8991222] {
  padding: 6px 12px;
  font-size: 12px;
  height: 30px;
  line-height: 1;
}
.execute-switch[data-v-d8991222] {
  display: flex;
  align-items: center;
  margin-left: 15px;
}
.execute-switch span[data-v-d8991222] {
  margin-right: 8px;
  font-size: 14px;
  color: #606266;
}
.tab-item[data-v-d8991222] {
  padding: 12px 24px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  color: #606266;
  font-size: 14px;
  transition: all 0.3s;
}
.tab-item[data-v-d8991222]:hover {
  color: #409EFF;
}
.tab-item.active[data-v-d8991222] {
  color: #409EFF;
  border-bottom-color: #409EFF;
  background-color: #f5f7fa;
}
.tab-content[data-v-d8991222] {
  background: #fff;
  padding: 0 20px;
  border-radius: 0 0 4px 4px;
  min-height: 300px;
  box-sizing: border-box;
}
.tab-content h3[data-v-d8991222] {
  margin-top: 0;
  margin-bottom: 20px;
  color: #303133;
  font-size: 16px;
  font-weight: 500;
}
.table-name-section[data-v-d8991222] {
  margin-bottom: 20px;
  width: 280px;
}
.ref-selection-design-section[data-v-d8991222] {
  padding: 20px 0;
}
.ref-selection-right[data-v-d8991222] {
  display: flex;
  flex-direction: column;
}
.ref-selection-form-group[data-v-d8991222] {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ref-selection-form-group label[data-v-d8991222] {
  font-size: 14px;
  color: #303133;
}
.ref-selection-form-group .el-select[data-v-d8991222] {
  width: 200px;
}
.ref-selection-form-group .el-textarea[data-v-d8991222] {
  width: 100%;
}
.ref-selection-rule-info[data-v-d8991222] {
  margin-top: 20px;
}
.ref-selection-rule-content[data-v-d8991222] {
  padding: 10px;
  background-color: #f9f9f9;
  border-radius: 4px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  font-size: 14px;
}

/*!************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/notionComponents/NotionContent.vue?vue&type=style&index=0&id=487ae299&scoped=true&lang=css ***!
  \************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.notion-content[data-v-487ae299] {
  flex: 1;
  overflow-y: hidden;
  background-color: #ffffff;
  padding: 0 0;
  display: flex;
  flex-direction: column;
}
.notion-header[data-v-487ae299] {
  padding: 0 24px;
  border-bottom: 1px solid #e9e9e9;
  background-color: #ffffff;
  z-index: 10;
  height: 57px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.header-left[data-v-487ae299] {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}

/* 展开图标样式 */
.expand-icon[data-v-487ae299] {
  cursor: pointer;
  color: #5f6368;
  margin-right: 4px;
}
.expand-icon[data-v-487ae299]:hover {
  color: #000;
}
.breadcrumb-item[data-v-487ae299],
.breadcrumb-static[data-v-487ae299] {
  display: inline-flex;
  align-items: center;
  color: #333333;
}
.breadcrumb-separator[data-v-487ae299] {
  color: #dcdcdc;
  margin: 0 2px;
}
.header-right[data-v-487ae299] {
  display: flex;
  align-items: center;
  gap: 16px;
}
.action-button[data-v-487ae299] {
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: 0;
  color: #5f6368;
}
.action-button[data-v-487ae299]:hover {
  color: #000;
}
.share-button[data-v-487ae299] {
  font-size: 14px;
  font-weight: 500;
  padding: 4px 8px;
}
.icon-button[data-v-487ae299] {
  padding: 4px;
}
.header-title[data-v-487ae299] {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: #333333;
}
.last-modified-time[data-v-487ae299] {
  font-size: 14px;
  color: #8c8c8c;
  white-space: nowrap;
}
.notion-body[data-v-487ae299] {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}
.content-container[data-v-487ae299] {
  display: flex;
  flex-direction: column;
  height: 100%;
  width: 100%;
}
.empty-content[data-v-487ae299] {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #a3a29e;
}
.empty-content svg[data-v-487ae299] {
  font-size: 48px;
  margin-bottom: 16px;
}
.member-detail-table[data-v-487ae299] {
  width: 420px;
  margin: 32px auto 0 auto;
  border-collapse: collapse;
  background: #fff;
  box-shadow: 0 2px 8px #eee;
  font-size: 14px;
}
.member-detail-table th[data-v-487ae299] {
  text-align: right;
  background: #f8f8f7;
  color: #888;
  font-weight: normal;
  padding: 8px 12px;
  border-bottom: 1px solid #eee;
  width: 100px;
}
.member-detail-table td[data-v-487ae299] {
  text-align: left;
  padding: 8px 12px;
  border-bottom: 1px solid #eee;
}

/*!***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/notionComponents/NotionFooter.vue?vue&type=style&index=0&id=051d21ab&scoped=true&lang=css ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.notion-footer[data-v-051d21ab] {
  padding: 10px 20px;
  border-top: 1px solid #e9e9e7;
  background-color: #f7f7f5;
  font-size: 13px;
}
.footer-content[data-v-051d21ab] {
  display: flex;
  justify-content: center;
  gap: 20px;
}
.footer-item[data-v-051d21ab] {
  display: flex;
  align-items: center;
  color: #6b6b6b;
  cursor: pointer;
}
.footer-item[data-v-051d21ab]:hover {
  color: #37352f;
}
.footer-item svg[data-v-051d21ab] {
  margin-right: 5px;
  width: 14px;
  height: 14px;
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/layouts/WebNotionLayout.vue?vue&type=style&index=0&id=08538538&scoped=true&lang=css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.notion-layout[data-v-08538538] {
  display: flex;
  height: 100vh;
  width: 100%;
  background-color: #ffffff;
  overflow: hidden;
  font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI Variable Display", "Segoe UI", Helvetica, "Apple Color Emoji", Arial, sans-serif, "Segoe UI Emoji", "Segoe UI Symbol";
}
.notion-main[data-v-08538538] {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* 侧边栏折叠样式 */
.notion-sidebar.collapsed[data-v-08538538] {
  width: 0 !important;
  overflow: hidden;
  padding: 0;
  margin: 0;
  border: none;
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/ErpLayout.vue?vue&type=style&index=0&id=0a4593ed&scoped=true&lang=css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 全局布局样式 */
.erp-layout[data-v-0a4593ed] {
  height: 100vh;
  width: 100%;
  overflow: hidden;
  color: #333;
  font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif;
}
.layout-container[data-v-0a4593ed] {
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* 顶部导航栏样式 */
.top-header[data-v-0a4593ed] {
  height: 40px;
  background-color: #fff;
  border-bottom: 1px solid #e6e6e6;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0;
}
.header-left[data-v-0a4593ed] {
  width: 340px;
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 20px;
  box-sizing: border-box;
  border-right: 1px solid #e6e6e6;
  position: relative;
}
.user-info[data-v-0a4593ed] {
  display: flex;
  align-items: center;
  margin-right: 15px;
  position: relative;
  cursor: pointer;
}
.user-name[data-v-0a4593ed] {
  margin-left: 10px;
  font-size: 18px;
}
.el-icon-arrow-down[data-v-0a4593ed] {
  margin-left: 5px;
  font-size: 16px;
  color: #909399;
}
.user-menu[data-v-0a4593ed] {
  position: absolute;
  top: 45px;
  left: 0;
  width: 140px;
  background-color: #fff;
  border-radius: 4px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  z-index: 100;
}
.menu-item[data-v-0a4593ed] {
  padding: 10px 15px;
  display: flex;
  align-items: center;
  transition: background-color 0.3s;
}
.menu-item[data-v-0a4593ed]:hover {
  background-color: #f5f7fa;
}
.menu-item i[data-v-0a4593ed] {
  margin-right: 10px;
  font-size: 16px;
  color: #909399;
}
.menu-item[data-v-0a4593ed]:last-child {
  border-top: 1px solid #ebeef5;
}
.menu-item:last-child i[data-v-0a4593ed] {
  color: #f56c6c;
}
.add-button[data-v-0a4593ed] {
  position: absolute;
  right: 20px;
  font-size: 24px;
  cursor: pointer;
}
.header-right[data-v-0a4593ed] {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  justify-content: flex-end;
  padding-bottom: 5px;
  padding-left: 10px;
  padding-right: 10px;
}
.global-search[data-v-0a4593ed] {
  width: 300px;
}
.global-search[data-v-0a4593ed] .el-input__inner {
  border-radius: 20px;
  background-color: #f5f7fa;
  border: 1px solid #e6e6e6;
  height: 26px;
}

/* 会话信息样式 */
.session-info[data-v-0a4593ed] {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: #606266;
  background-color: #FFFFFF;
  padding: 5px 10px;
  margin-bottom: 0;
  border-radius: 4px;
  width: 100%;
}
.session-path[data-v-0a4593ed],
.session-time[data-v-0a4593ed] {
  display: flex;
  align-items: center;
}
.session-path i[data-v-0a4593ed],
.session-time i[data-v-0a4593ed] {
  margin-right: 5px;
  font-size: 14px;
}
.session-icon[data-v-0a4593ed] {
  margin-left: 8px;
  cursor: pointer;
  font-size: 14px;
}
.user-actions[data-v-0a4593ed] {
  display: flex;
  align-items: center;
  gap: 20px;
}
.notification-badge[data-v-0a4593ed] .el-badge__content {
  background-color: #f56c6c;
}

/* 主布局区域 */
.main-layout[data-v-0a4593ed] {
  flex: 1;
  overflow: hidden;
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/MainNavigation.vue?vue&type=style&index=0&id=c5e56f46&scoped=true&lang=css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 左侧主导航区样式 */
.main-nav-aside[data-v-c5e56f46] {
  background-color: #DAD8DD;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100%;
}
.nav-icons[data-v-c5e56f46] {
  display: flex;
  flex-direction: column;
  padding: 0 0;
  align-items: center;
}
.nav-icon-item[data-v-c5e56f46] {
  display: flex;
  padding: 15px 0;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.3s;
  margin-bottom: 0;
  width: 100%;
  justify-content: center;
}
.nav-icon-content[data-v-c5e56f46] {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.nav-icon-item i[data-v-c5e56f46] {
  font-size: 24px;
  color: #606266;
}
.nav-icon-item.active[data-v-c5e56f46] {
  background-color: #e6f1fc;
}
.nav-icon-item.active i[data-v-c5e56f46] {
  color: #409EFF;
}
.nav-icon-img[data-v-c5e56f46] {
  width: 24px;
  height: 24px;
  -o-object-fit: contain;
     object-fit: contain;
}
.nav-icon-item.active .nav-icon-img[data-v-c5e56f46] {
  filter: brightness(0.8) sepia(1) hue-rotate(190deg) saturate(5);
}
.nav-badge[data-v-c5e56f46] .el-badge__content {
  background-color: #f56c6c;
}

/* Notion导航项样式 */
.notion-nav-item[data-v-c5e56f46] {
  margin-top: 20px;
  position: relative;
}
.notion-nav-item[data-v-c5e56f46]::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 25%;
  width: 50%;
  height: 1px;
  background-color: #c0c4cc;
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/DepartmentTree.vue?vue&type=style&index=0&id=26038f80&scoped=true&lang=css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.custom-tree-node[data-v-26038f80] {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.node-actions[data-v-26038f80] {
  display: none;
  margin-left: auto;
  padding-right: 8px;
}
.el-tree-node__content:hover .node-actions[data-v-26038f80] {
  display: inline-flex;
  align-items: center;
}
.el-tree-node__content:hover .node-actions .el-button[data-v-26038f80] {
  padding: 2px 4px;
}
.el-tree-node__content:hover .node-actions .el-button + .el-button[data-v-26038f80] {
  margin-left: 4px;
}
.department-tree[data-v-26038f80] {
  height: 100%;
  overflow-y: auto;
}
[data-v-26038f80] .el-tree {
  background-color: transparent;
  color: #303133;
}
[data-v-26038f80] .el-tree-node__content {
  height: 48px;
  padding: 0 12px;
  border-bottom: 1px solid #f0f0f0;
}
[data-v-26038f80] .el-tree-node__content:hover {
  background-color: #f5f7fa;
}
[data-v-26038f80] .el-tree-node.is-current > .el-tree-node__content {
  background-color: #e6f1fc;
}
[data-v-26038f80] .el-tree-node__label {
  font-size: 15px;
  font-weight: 500;
}
[data-v-26038f80] .el-tree-node__expand-icon {
  color: #909399;
}
[data-v-26038f80] .el-tree-node__children {
  background-color: #f0f0f0;
}
[data-v-26038f80] .el-tree-node__children .el-tree-node__content {
  padding-left: 40px;
}
[data-v-26038f80] .el-tree-node__children .el-tree-node__children .el-tree-node__content {
  padding-left: 60px;
  background-color: #e6e6e6;
}

/*!******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/SubNavigation.vue?vue&type=style&index=0&id=28bb7e74&scoped=true&lang=css ***!
  \******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 中间子导航区样式 */
.sub-nav-aside[data-v-28bb7e74] {
  background-color: #E5E5E5;
  display: flex;
  flex-direction: column;
  border-right: 1px solid #e6e6e6;
  overflow: hidden;
}

/* 子导航搜索区域样式 */
.search-container[data-v-28bb7e74] {
  padding: 15px;
  border-bottom: 1px solid #e6e6e6;
}
.search-input[data-v-28bb7e74] .el-input__inner {
  border-radius: 20px;
  background-color: #e6e6e6;
  border: none;
  height: 36px;
}

/* 会话列表区域样式 */
.conversation-section[data-v-28bb7e74] {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.conversation-list[data-v-28bb7e74] {
  flex: 1;
  overflow-y: auto;
}
.conversation-item[data-v-28bb7e74] {
  display: flex;
  align-items: center;
  padding: 12px 12px;
  border-bottom: 1px solid #f0f0f0;
  cursor: pointer;
  position: relative;
  transition: all 0.3s;
}
.conversation-item[data-v-28bb7e74]:hover {
  background-color: #f5f7fa;
}
.conversation-item.active[data-v-28bb7e74] {
  background-color: #e6f1fc;
}
.conversation-info[data-v-28bb7e74] {
  flex: 1;
  margin-left: 12px;
  overflow: hidden;
}
.conversation-header[data-v-28bb7e74] {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4px;
}
.name[data-v-28bb7e74] {
  font-weight: 500;
  font-size: 15px;
  color: #303133;
}
.time[data-v-28bb7e74] {
  font-size: 12px;
  color: #909399;
}
.unread-badge[data-v-28bb7e74] .el-badge__content {
  background-color: #f56c6c;
}

/* 子菜单样式 */
.sub-menu[data-v-28bb7e74] {
  background-color: #f0f0f0;
}
.sub-item[data-v-28bb7e74] {
  padding-left: 40px;
  background-color: #f0f0f0;
}
.sub-icon[data-v-28bb7e74] {
  font-size: 16px;
  color: #606266;
  margin-right: 10px;
}

/* 二级子菜单样式 */
.sub-sub-menu[data-v-28bb7e74] {
  background-color: #e6e6e6;
}
.sub-sub-item[data-v-28bb7e74] {
  padding-left: 60px;
  background-color: #e6e6e6;
}
.sub-sub-icon[data-v-28bb7e74] {
  font-size: 14px;
  color: #909399;
  margin-right: 10px;
}
.expand-icon[data-v-28bb7e74] {
  margin-left: 5px;
  color: #909399;
  font-size: 14px;
}

/* 空列表样式 */
.empty-list[data-v-28bb7e74] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 200px;
  color: #909399;
}
.empty-list i[data-v-28bb7e74] {
  font-size: 48px;
  margin-bottom: 10px;
  color: #dcdfe6;
}
.empty-list p[data-v-28bb7e74] {
  font-size: 14px;
}

/* el-tree 自定义样式 */
[data-v-28bb7e74] .el-tree {
  background-color: transparent;
  color: #303133;
}
[data-v-28bb7e74] .el-tree-node__content {
  height: 48px;
  padding: 0 12px;
  border-bottom: 1px solid #f0f0f0;
}
[data-v-28bb7e74] .el-tree-node__content:hover {
  background-color: #f5f7fa;
}
[data-v-28bb7e74] .el-tree-node.is-current > .el-tree-node__content {
  background-color: #e6f1fc;
}
[data-v-28bb7e74] .el-tree-node__label {
  font-size: 15px;
  font-weight: 500;
}
[data-v-28bb7e74] .el-tree-node__expand-icon {
  color: #909399;
}
[data-v-28bb7e74] .el-tree-node__children {
  background-color: #f0f0f0;
}
[data-v-28bb7e74] .el-tree-node__children .el-tree-node__content {
  padding-left: 40px;
}
[data-v-28bb7e74] .el-tree-node__children .el-tree-node__children .el-tree-node__content {
  padding-left: 60px;
  background-color: #e6e6e6;
}

/*!***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/TicketList.vue?vue&type=style&index=0&id=0a85620c&scoped=true&lang=css ***!
  \***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.ticket-list-container[data-v-0a85620c] {
  height: 100%;
  display: flex;
  flex-direction: column;
}
.content-header[data-v-0a85620c] {
  height: 60px;
  background-color: #fff;
  border-bottom: 1px solid #e6e6e6;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 20px;
}
.header-title[data-v-0a85620c] {
  font-size: 16px;
  font-weight: 500;
}
.content-area[data-v-0a85620c] {
  flex: 1;
  padding: 20px;
  overflow-y: auto;
  background-color: #f5f7fa;
}
.empty-content[data-v-0a85620c] {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #909399;
  margin-top: 40px;
}
.empty-icon[data-v-0a85620c] {
  font-size: 60px;
  margin-bottom: 20px;
  color: #dcdfe6;
}

/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/ChatSessionTree.vue?vue&type=style&index=0&id=032cb8dc&scoped=true&lang=css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* 会话树容器样式 */
.session-tree-container[data-v-032cb8dc] {
  width: 280px;
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: #f5f7fa;
  border-right: 1px solid #e6e6e6;
}
.tree-container[data-v-032cb8dc] {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* 搜索容器样式 */
.search-container[data-v-032cb8dc] {
  padding: 15px;
  border-bottom: 1px solid #e6e6e6;
}
.search-input[data-v-032cb8dc] .el-input__inner {
  border-radius: 20px;
  background-color: #e6e6e6;
  border: none;
  height: 36px;
}

/* 树形控件样式 */
.session-tree[data-v-032cb8dc] {
  padding: 10px;
  flex: 1;
  overflow-y: auto;
}
.custom-tree-node[data-v-032cb8dc] {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  padding-right: 8px;
}
.node-icon[data-v-032cb8dc] {
  margin-right: 5px;
  color: #409EFF;
}
.node-actions[data-v-032cb8dc] {
  opacity: 0;
  transition: opacity 0.3s;
}
.custom-tree-node:hover .node-actions[data-v-032cb8dc] {
  opacity: 1;
}

/* 排序号标签样式 */
.sort-no-tag[data-v-032cb8dc] {
  font-size: 12px;
  color: #909399;
  margin-left: 4px;
}

/* El-tree 覆盖样式 */
.session-tree[data-v-032cb8dc] .el-tree-node__content {
  height: 40px;
  border-radius: 4px;
  margin: 2px 0;
}
.session-tree[data-v-032cb8dc] .el-tree-node__content:hover {
  background-color: #ecf5ff;
}
.session-tree[data-v-032cb8dc] .is-current .el-tree-node__content {
  background-color: #ecf5ff;
}
.session-tree[data-v-032cb8dc] .el-tree-node__label {
  font-size: 14px;
}

/*!***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/layouts/webLayout.vue?vue&type=style&index=0&id=3180d50f&scoped=true&lang=css ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.main-layout[data-v-3180d50f] {
  height: 100%;
}

/* 工作台内容区域样式 */
.workspace-content[data-v-3180d50f] {
  flex: 1;
  overflow: auto;
  background-color: #f5f7fa;
  display: flex;
  flex-direction: column;
}

/* 空内容提示样式 */
.empty-content[data-v-3180d50f] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: #909399;
}
.empty-content i[data-v-3180d50f] {
  font-size: 64px;
  margin-bottom: 20px;
  color: #dcdfe6;
}
.empty-content p[data-v-3180d50f] {
  font-size: 16px;
}

/* 设置内容区域样式 */
.settings-content[data-v-3180d50f] {
  flex: 1;
  overflow: auto;
  background-color: #fff;
  padding: 20px;
}
.settings-header[data-v-3180d50f] {
  border-bottom: 1px solid #ebeef5;
  padding-bottom: 15px;
  margin-bottom: 20px;
}
.settings-body[data-v-3180d50f] {
  padding: 0 10px;
}

/* 树形导航样式 */
.chat-session-tree-nav[data-v-3180d50f] {
  height: 100%;
  border-right: 1px solid #e6e6e6;
}
.chat-session-tree-nav[data-v-3180d50f] .el-tree-node__content {
  height: 40px;
}
.chat-session-tree-nav[data-v-3180d50f] .el-tree-node__children .el-tree-node__content {
  padding-left: 28px !important;
}
.chat-session-tree-nav[data-v-3180d50f] .el-tree-node__children .el-tree-node__children .el-tree-node__content {
  padding-left: 48px !important;
}

/* 添加更多层级的节点样式 */
.chat-session-tree-nav[data-v-3180d50f] .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__content {
  padding-left: 68px !important;
}
.chat-session-tree-nav[data-v-3180d50f] .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__content {
  padding-left: 88px !important;
}
.chat-session-tree-nav[data-v-3180d50f] .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__content {
  padding-left: 108px !important;
}

/* 为更深层级节点提供通用样式规则 */
.chat-session-tree-nav[data-v-3180d50f] .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__children .el-tree-node__content {
  padding-left: 128px !important;
}

/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/BaseTree.vue?vue&type=style&index=0&id=16f09ebf&scoped=true&lang=css ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.base-tree[data-v-16f09ebf] {
  height: 100%;
  overflow-y: auto;
}
.tree-container[data-v-16f09ebf] {
  height: 100%;
}
.search-container[data-v-16f09ebf] {
  padding: 8px;
}
.search-input[data-v-16f09ebf] {
  width: 100%;
}
.custom-tree-node[data-v-16f09ebf] {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.node-content[data-v-16f09ebf] {
  display: flex;
  align-items: center;
}
.node-icon[data-v-16f09ebf] {
  margin-right: 5px;
}
.node-label[data-v-16f09ebf] {
  font-size: 14px;
}
.node-actions[data-v-16f09ebf] {
  display: none;
  margin-left: auto;
  padding-right: 8px;
}
[data-v-16f09ebf] .el-tree-node__content:hover .node-actions {
  display: inline-flex;
  align-items: center;
}
[data-v-16f09ebf] .el-tree-node__content:hover .node-actions .el-button {
  padding: 2px 4px;
}
[data-v-16f09ebf] .el-tree-node__content:hover .node-actions .el-button + .el-button {
  margin-left: 4px;
}
[data-v-16f09ebf] .el-tree {
  background-color: transparent;
  color: #303133;
}
[data-v-16f09ebf] .el-tree-node__content {
  height: 32px;
}
[data-v-16f09ebf] .el-tree-node__content:hover {
  background-color: #f5f7fa;
}
[data-v-16f09ebf] .el-tree-node.is-current > .el-tree-node__content {
  background-color: #e6f1fc;
}
[data-v-16f09ebf] .el-tree-node__label {
  font-size: 14px;
}

/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/TreeDemo.vue?vue&type=style&index=0&id=0909ce51&scoped=true&lang=css ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.tree-demo[data-v-0909ce51] {
  padding: 20px;
}
.demo-section[data-v-0909ce51] {
  margin-bottom: 30px;
  border: 1px solid #ebeef5;
  border-radius: 4px;
  padding: 15px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
}
h3[data-v-0909ce51] {
  margin-top: 0;
  margin-bottom: 20px;
  color: #303133;
}
h4[data-v-0909ce51] {
  margin-top: 0;
  margin-bottom: 15px;
  color: #606266;
  font-size: 16px;
}
.checked-info[data-v-0909ce51] {
  margin-top: 10px;
  padding: 8px;
  background-color: #f2f6fc;
  border-radius: 4px;
  color: #606266;
}

