/* stylelint-disable at-rule-empty-line-before,at-rule-name-space-after,at-rule-no-unknown */
/* stylelint-disable no-duplicate-selectors */
/* stylelint-disable */
/* stylelint-disable declaration-bang-space-before,no-duplicate-selectors,string-no-newline */
.week-mode[data-v-117d4e48] {
  overflow: hidden;
  -webkit-filter: invert(80%);
          filter: invert(80%);
}
.beauty-scroll[data-v-117d4e48] {
  scrollbar-color: #067bef #abe0ff;
  scrollbar-width: thin;
  -ms-overflow-style: none;
  position: relative;
}
.beauty-scroll[data-v-117d4e48]::-webkit-scrollbar {
  width: 12px;
  height: 1px;
}
.beauty-scroll[data-v-117d4e48]::-webkit-scrollbar-thumb {
  border-radius: 3px;
  background: #067bef;
}
.beauty-scroll[data-v-117d4e48]::-webkit-scrollbar-track {
  -webkit-box-shadow: inset 0 0 1px rgba(0, 0, 0, 0);
  border-radius: 3px;
  background: #82cdff;
}
.split-right[data-v-117d4e48]:not(:last-child) {
  border-right: 1px solid rgba(98, 98, 98, 0.2);
}
.disabled[data-v-117d4e48] {
  cursor: not-allowed;
  color: rgba(0, 0, 0, 0.85);
  pointer-events: none;
}
/* Make clicks pass-through */
#nprogress[data-v-117d4e48] {
  pointer-events: none;
}
#nprogress .bar[data-v-117d4e48] {
  background: #067bef;
  position: fixed;
  z-index: 1031;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
}
/* Fancy blur effect */
#nprogress .peg[data-v-117d4e48] {
  display: block;
  position: absolute;
  right: 0px;
  width: 100px;
  height: 100%;
  -webkit-box-shadow: 0 0 10px #067bef, 0 0 5px #067bef;
          box-shadow: 0 0 10px #067bef, 0 0 5px #067bef;
  opacity: 1;
  -webkit-transform: rotate(3deg) translate(0px, -4px);
  transform: rotate(3deg) translate(0px, -4px);
}
/* Remove these to get rid of the spinner */
#nprogress .spinner[data-v-117d4e48] {
  display: block;
  position: fixed;
  z-index: 1031;
  top: 15px;
  right: 15px;
}
#nprogress .spinner-icon[data-v-117d4e48] {
  width: 18px;
  height: 18px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: solid 2px transparent;
  border-top-color: #067bef;
  border-left-color: #067bef;
  border-radius: 50%;
  -webkit-animation: nprogress-spinner-data-v-117d4e48 400ms linear infinite;
  animation: nprogress-spinner-data-v-117d4e48 400ms linear infinite;
}
.nprogress-custom-parent[data-v-117d4e48] {
  overflow: hidden;
  position: relative;
}
.nprogress-custom-parent #nprogress .spinner[data-v-117d4e48],
.nprogress-custom-parent #nprogress .bar[data-v-117d4e48] {
  position: absolute;
}
@-webkit-keyframes nprogress-spinner-data-v-117d4e48 {
0% {
    -webkit-transform: rotate(0deg);
}
100% {
    -webkit-transform: rotate(360deg);
}
}
@keyframes nprogress-spinner-data-v-117d4e48 {
0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
}
100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
}
}
.fullscreen-container[data-v-117d4e48] {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
}
/* ================= 核心变量定义 ================= */
/* 纯白文字 */
/* 高亮青色 */
/* 行高，需与 JS rowHeight 一致 */
/* 关键：定义列宽变量 
  确保上下表格严格对齐
*/
/* 时间 / 组别 */
/* 组别 / 出勤 / 裁剪 */
/* 姓名 / 目标 / 领用 */
/* 工号 / 总目标 / 成品 (含平均产值) */
/* 产值 / 即时 / 未成品 (最宽列) */
/* 名次 / 完成率 */
.dashboard-container[data-v-117d4e48] {
  width: 100%;
  height: 100vh;
  background-color: #020b21;
  color: #ffffff;
  font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Microsoft YaHei", Arial, sans-serif;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 0 15px 15px 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
/* 通用列样式 */
.col[data-v-117d4e48] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  border-right: 1px solid #1e4f7e;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  text-align: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  /* 引用列宽变量 */
}
.col[data-v-117d4e48]:last-child {
  border-right: none;
}
.col.w1[data-v-117d4e48] {
  width: 12%;
}
.col.w2[data-v-117d4e48] {
  width: 12%;
}
.col.w3[data-v-117d4e48] {
  width: 12%;
}
.col.w4[data-v-117d4e48] {
  width: 14%;
}
.col.w5[data-v-117d4e48] {
  width: 35%;
}
.col.w6[data-v-117d4e48] {
  width: 15%;
}
/* 1. Header */
.header[data-v-117d4e48] {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  height: 70px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 10px;
  position: relative;
  background: url(../static/img/topbg.19125283.png) center bottom no-repeat;
  background-size: 136% 100%;
  /* 水平100%拉伸，垂直100% */
}
.header .time-box[data-v-117d4e48] {
  position: absolute;
  left: 10px;
  top: 10px;
  color: #00ffff;
}
.header .time-box .time[data-v-117d4e48] {
  font-size: 26px;
  font-weight: bold;
  font-family: monospace;
}
.header .time-box .date[data-v-117d4e48] {
  font-size: 16px;
  opacity: 0.8;
}
.header .title-box[data-v-117d4e48] {
  margin-top: -5px;
}
.header .title-box h1[data-v-117d4e48] {
  margin: 0;
  font-size: 24px;
  letter-spacing: 4px;
  color: #fff;
  text-shadow: 0 0 15px rgba(0, 150, 255, 0.8);
}
/* 2. 主体表格 */
.main-content[data-v-117d4e48] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 0;
  overflow: hidden;
  /* 防止溢出 */
  margin-bottom: 10px;
}
.main-content .section-title[data-v-117d4e48] {
  text-align: center;
  font-size: 22px;
  margin: 10px 0;
  color: #fff;
  font-weight: normal;
  letter-spacing: 2px;
}
.ranking-table[data-v-117d4e48] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  border: 1px solid #1e4f7e;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  background-color: rgba(0, 0, 0, 0.2);
  min-height: 0;
}
.ranking-table .header-row[data-v-117d4e48] {
  height: 45px;
  background-color: rgba(30, 79, 126, 0.4);
  border-bottom: 1px solid #1e4f7e;
  font-weight: bold;
  font-size: 20px;
  color: #00ffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.ranking-table .scroll-wrapper[data-v-117d4e48] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  overflow: hidden;
  position: relative;
}
.ranking-table .scroll-content[data-v-117d4e48] {
  width: 100%;
  will-change: transform;
  /* 性能优化：提示浏览器 */
}
.ranking-table .body-row[data-v-117d4e48] {
  height: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-bottom: 1px solid rgba(30, 79, 126, 0.3);
  color: #fff;
  /* 强制所有行文字为白色 */
  font-size: 32px;
  /* 前三名样式 */
}
.ranking-table .body-row[data-v-117d4e48]:nth-child(even) {
  background-color: rgba(255, 255, 255, 0.02);
}
.ranking-table .body-row[data-v-117d4e48]:hover {
  background-color: rgba(0, 255, 255, 0.15);
}
.ranking-table .body-row.top-3 .rank-num[data-v-117d4e48] {
  color: #00ffff;
  font-weight: bold;
  font-size: 36px;
  text-shadow: 0 0 5px #00ffff;
}
.ranking-table .body-row .mini-bar[data-v-117d4e48] {
  height: 4px;
  background: -webkit-gradient(linear, left top, right top, from(#1e4f7e), to(#00ffff));
  background: linear-gradient(90deg, #1e4f7e, #00ffff);
  border-radius: 2px;
  margin-top: 4px;
  display: block;
  width: 0;
}
.ranking-table .body-row .col.w5[data-v-117d4e48] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding: 0 10px;
}
/* 底部统计区域重构 */
.footer-stats-bottom[data-v-117d4e48] {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  height: 180px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /* 左右分栏 */
  border: 1px solid #1e4f7e;
  margin-top: 25px;
  position: relative;
  background-color: rgba(0, 0, 0, 0.3);
  min-width: 0;
  width: 100%;
  /* 左侧：组别大单元格 */
  /* 右侧：数据区 */
}
.footer-stats-bottom .left-header[data-v-117d4e48] {
  width: 12%;
  /* 宽度保持和上方“时间”一列一致 */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border-right: 1px solid #1e4f7e;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.footer-stats-bottom .left-header .label[data-v-117d4e48] {
  background-color: rgba(30, 79, 126, 0.4);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-bottom: 1px solid #1e4f7e;
  font-weight: bold;
  color: #add8e6;
  height: 44px;
  font-size: 20px;
}
.footer-stats-bottom .left-header .value[data-v-117d4e48] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  /* 占据下方两行的高度空间 */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 20px;
  color: #00ffff;
}
.footer-stats-bottom .right-content[data-v-117d4e48] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  min-width: 0;
  /* 内部对齐：因为左侧已经占了 w1，所以这里的列宽比例需要重新调整以对齐上方 */
}
.footer-stats-bottom .right-content .stat-row[data-v-117d4e48] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  /* 每行平分高度 */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-bottom: 1px solid #1e4f7e;
  min-width: 0;
}
.footer-stats-bottom .right-content .stat-row[data-v-117d4e48]:last-child {
  border-bottom: none;
}
.footer-stats-bottom .right-content .stat-row.label-row[data-v-117d4e48] {
  background-color: rgba(30, 79, 126, 0.25);
  font-size: 18px;
  color: #add8e6;
}
.footer-stats-bottom .right-content .stat-row.data-row[data-v-117d4e48] {
  font-size: 18px;
  color: #fff;
}
.footer-stats-bottom .right-content .col[data-v-117d4e48] {
  border-right: 1px solid #1e4f7e;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 0;
  /* 这里使用 calc 自动对齐或固定比例 */
  /* 对应上方 w2 */
  /* 对应上方 w3 */
  /* 对应上方 w4 */
  /* 对应上方 w5 */
  /* 对应上方 w6 */
}
.footer-stats-bottom .right-content .col[data-v-117d4e48]:last-child {
  border-right: none;
}
.footer-stats-bottom .right-content .col.w2-fixed[data-v-117d4e48] {
  width: 17.6%;
}
.footer-stats-bottom .right-content .col.w3-fixed[data-v-117d4e48] {
  width: 17.6%;
}
.footer-stats-bottom .right-content .col.w4-fixed[data-v-117d4e48] {
  width: 20%;
}
.footer-stats-bottom .right-content .col.w5-fixed[data-v-117d4e48] {
  width: 20%;
}
.footer-stats-bottom .right-content .col.w6-fixed[data-v-117d4e48] {
  width: 26.8%;
}
.footer-stats-bottom .right-content .floating-header-row[data-v-117d4e48] {
  position: absolute;
  top: -33px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
.footer-stats-bottom .right-content .floating-header-row .col[data-v-117d4e48] {
  border: none !important;
}
.footer-stats-bottom .right-content .floating-header-row .special-label[data-v-117d4e48] {
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding-bottom: 5px;
}
.col.w6-fixed[data-v-117d4e48] {
  padding: 0 5px;
  overflow: hidden;
  /* 确保不溢出单元格 */
}
.col.w6-fixed .marquee-box[data-v-117d4e48] {
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  /* 强制不换行 */
  position: relative;
  /* display: flex; */
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.col.w6-fixed .marquee-content[data-v-117d4e48] {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.col.w6-fixed .marquee-content.animate[data-v-117d4e48] {
  /* 动画时间根据内容长短调整，这里设为10s，linear确保匀速 */
  -webkit-animation: scroll-left-data-v-117d4e48 10s linear infinite;
          animation: scroll-left-data-v-117d4e48 10s linear infinite;
}
.col.w6-fixed .marquee-content[data-v-117d4e48]:hover {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
  /* 鼠标悬停时暂停 */
}
.col.w6-fixed .batch-item[data-v-117d4e48] {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  margin-right: 15px;
  /* 每个项之间的间距 */
  white-space: nowrap;
  color: #00ffff;
}
.col.w6-fixed .batch-item .kh[data-v-117d4e48] {
  margin-right: 5px;
  color: #fff;
  /* 款号用白色 */
  font-size: 16px;
}
.col.w6-fixed .batch-item .jd[data-v-117d4e48] {
  font-weight: bold;
  font-size: 16px;
}
/* 定义横向滚动动画 */
@-webkit-keyframes scroll-left-data-v-117d4e48 {
0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
}
100% {
    /* 这里 -50% 是关键。
       因为我们在 template 里复制了一份数据，
       当滚过一半（即整组数据）时，瞬间回到0，实现无缝连接。
    */
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
}
}
@keyframes scroll-left-data-v-117d4e48 {
0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
}
100% {
    /* 这里 -50% 是关键。
       因为我们在 template 里复制了一份数据，
       当滚过一半（即整组数据）时，瞬间回到0，实现无缝连接。
    */
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
}
}

