/* ============================================================
   森达木业 ERP - Linear 风格深色主题
   ============================================================
   设计原则:
   - 仅深色,无主题切换
   - Linear 风灰阶层次:6 层背景,4 阶文字
   - 无 accent 彩色,主按钮 = 白底深字
   - 状态色低饱和,仅用于徽章和数据可视化
   - Inter 字体 + -0.011em 字距 = Linear 招牌质感
============================================================ */

:root {
  /* === 背景层级(Linear 灰阶,由深到浅) === */
  --bg-0: #08090A;     /* 页面底/根背景 */
  --bg-1: #0C0D0E;     /* 主内容区 */
  --bg-2: #101113;     /* 卡片/侧栏 */
  --bg-3: #161718;     /* hover/输入框/表头 */
  --bg-4: #1F2023;     /* active/悬浮层/弹窗 */

  /* === 边框(极细,只用于必要分割) === */
  --border-1: #1A1B1D;   /* 卡片边框,几乎不可见 */
  --border-2: #232428;   /* 分隔线 */
  --border-3: #2E2F33;   /* hover 高亮边框 */

  /* === 文字(4 阶) === */
  --text-1: #F7F8F8;     /* 标题/重要数据 */
  --text-2: #B4B8BD;     /* 正文 */
  --text-3: #8A8F98;     /* 次要/标签 */
  --text-4: #62666D;     /* 弱化/占位 */
  --text-5: #44474D;     /* 禁用 */

  /* === 主色 = 白(Linear 风) === */
  --accent: #F7F8F8;             /* 主按钮 / focus ring */
  --accent-hover: #FFFFFF;
  --accent-bg: rgba(247, 248, 248, 0.06);
  --accent-border: rgba(247, 248, 248, 0.15);

  /* === 状态色(暗色"夜光"风格 - 高饱和+高亮度,纯深色背景上发光感) === */
  /* emerald: 经典 mint 绿,比原色更明亮且偏冷 */
  --emerald: #34E5A4;
  --emerald-bright: #4DFFB8;        /* 高亮变体(图标/数字) */
  --emerald-bg: rgba(52, 229, 164, 0.10);
  --emerald-border: rgba(52, 229, 164, 0.28);
  --emerald-glow: rgba(52, 229, 164, 0.4);

  /* blue: 偏 cyan 的电子蓝,夜光效果最强 */
  --blue: #5EB7FF;
  --blue-bright: #7CC9FF;
  --blue-bg: rgba(94, 183, 255, 0.10);
  --blue-border: rgba(94, 183, 255, 0.30);
  --blue-glow: rgba(94, 183, 255, 0.4);

  --amber: #F4C24A;
  --amber-bg: rgba(244, 194, 74, 0.10);
  --amber-border: rgba(244, 194, 74, 0.30);

  --orange: #FB923C;
  --orange-bg: rgba(251, 146, 60, 0.10);
  --orange-border: rgba(251, 146, 60, 0.30);

  --red: #FF5C5C;
  --red-bg: rgba(255, 92, 92, 0.10);
  --red-border: rgba(255, 92, 92, 0.30);

  --violet: #B197FC;
  --violet-bg: rgba(177, 151, 252, 0.10);
  --violet-border: rgba(177, 151, 252, 0.30);

  --slate: #8A8F98;
  --slate-bg: rgba(138, 143, 152, 0.10);
  --slate-border: rgba(138, 143, 152, 0.25);

  /* === 字体 (Linear 招牌组合,带强 fallback) === */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Source Han Sans CN', 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', 'Cascadia Code', 'Fira Code', 'Roboto Mono', 'Source Code Pro', Menlo, Consolas, 'DejaVu Sans Mono', monospace;

  /* Linear 字距精髓:标题略收紧,正文几乎不收 */
  --letter-tight: -0.022em;    /* 大标题 */
  --letter-snug: -0.014em;     /* 中标题/页头 */
  --letter-normal: -0.006em;   /* 正文 */
  --letter-wide: 0.04em;       /* 全大写小字 */

  /* === 阴影(深色下用更深的阴影提升层次) === */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.5);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.5);
  --shadow-lg: 0 16px 40px rgba(0, 0, 0, 0.6);
}

/* ============================================================
   基础重置
============================================================ */

* {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg-0);
  color: var(--text-1);
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: var(--letter-normal);
  /* Linear 字体优化特性 */
  font-feature-settings: 'cv11', 'ss01', 'ss03';
  font-variation-settings: normal;
}

/* 标题字距 */
h1, h2, h3, h4, h5, h6,
.page-title, .card-title, .modal-title {
  letter-spacing: var(--letter-snug);
}

/* 金额、纯数字 — 用 Inter + tabular-nums(等宽数字)
 * 视觉现代,字形商业感强,跟 KPI 数字保持一致 */
.font-mono, .num, .money {
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums slashed-zero;
  font-feature-settings: 'tnum' 1, 'cv11' 1;
  letter-spacing: -0.005em;
}

/* 单据号、编码 — 数字+字母混合,用 Inter 的 tnum/zero 变体保持可读性 */
.order-no, .code-text, .font-code {
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums slashed-zero;
  font-feature-settings: 'tnum' 1, 'zero' 1, 'cv11' 1;
  letter-spacing: -0.005em;
}

/* ============================================================
   滚动条(Linear 风极细)
============================================================ */

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--border-2);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover { background: var(--border-3); }

/* ============================================================
   布局
============================================================ */

.app-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  grid-template-rows: 56px 1fr;
  grid-template-areas:
    "sidebar topbar"
    "sidebar main";
  height: 100vh;
}

.app-sidebar {
  grid-area: sidebar;
  background: var(--bg-2);
  border-right: 1px solid var(--border-1);
  overflow-y: auto;
}

.app-topbar {
  grid-area: topbar;
  background: var(--bg-1);
  border-bottom: 1px solid var(--border-1);
  display: flex;
  align-items: center;
  padding: 0 24px;
}

.app-main {
  grid-area: main;
  background: var(--bg-1);
  overflow-y: auto;
  padding: 20px 24px;
}

/* ============================================================
   侧栏
============================================================ */

.sidebar-brand {
  height: 56px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-bottom: 1px solid var(--border-1);
}

.sidebar-brand .brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.sidebar-brand .brand-cn {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: var(--letter-snug);
  color: var(--text-1);
}

.sidebar-brand .brand-en {
  font-size: 9.5px;
  color: var(--text-4);
  letter-spacing: var(--letter-wide);
  margin-top: 2px;
  text-transform: uppercase;
}

.sidebar-brand .logo-mark {
  width: 26px;
  height: 26px;
  background: var(--bg-4);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  color: var(--text-1);
  font-weight: 600;
  flex-shrink: 0;
  border: 1px solid var(--border-2);
}

.sidebar-nav {
  padding: 12px 0;
}

.sidebar-section {
  padding: 14px 20px 6px;
  font-size: 10.5px;
  color: var(--text-4);
  text-transform: uppercase;
  letter-spacing: var(--letter-wide);
  font-weight: 500;
}

.sidebar-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 20px;
  color: var(--text-3);
  text-decoration: none;
  font-size: 13px;
  border-left: 2px solid transparent;
  transition: background 0.12s ease, color 0.12s ease;
  cursor: pointer;
}

.sidebar-item:hover {
  background: var(--bg-3);
  color: var(--text-1);
}

.sidebar-item.active {
  background: var(--bg-3);
  color: var(--text-1);
  border-left-color: var(--text-1);
  font-weight: 500;
}

.sidebar-item .item-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  opacity: 0.7;
}

.sidebar-subitem {
  display: flex;
  align-items: center;
  padding: 6px 20px 6px 50px;
  font-size: 12px;
  color: var(--text-3);
  cursor: pointer;
  border-left: 2px solid transparent;
  text-decoration: none;
}

.sidebar-subitem:hover {
  background: var(--bg-3);
  color: var(--text-1);
}

.sidebar-subitem.active {
  color: var(--text-1);
  background: var(--bg-3);
  border-left-color: var(--text-1);
  font-weight: 500;
}

/* 侧栏徽章(待办计数) */
.sidebar-badge {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  font-size: 10px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: #fff;
  background: var(--red);
  border-radius: 9px;
  line-height: 1;
}
.sidebar-item .sidebar-badge {
  margin-left: auto;
}

/* 折叠组(在销售下的"更多") */
.sidebar-group-toggle {
  display: flex !important;
  align-items: center;
  user-select: none;
  padding: 4px 20px 4px 50px !important;
  font-size: 11px !important;
  color: var(--text-4) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.sidebar-group-toggle:hover {
  color: var(--text-2) !important;
  background: transparent !important;
}
.sidebar-subsubitem {
  padding-left: 60px !important;
  font-size: 11px !important;
}
.group-arrow {
  transition: transform 0.15s ease;
}

/* ============================================================
   顶栏
============================================================ */

.topbar-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--text-2);
  font-size: 13px;
}

.topbar-breadcrumb .crumb {
  color: var(--text-2);
}

.topbar-breadcrumb .crumb-sep {
  color: var(--text-4);
  margin: 0 8px;
}
.topbar-breadcrumb .crumb-link {
  color: var(--text-3);
  text-decoration: none;
  cursor: pointer;
}
.topbar-breadcrumb .crumb-link:hover {
  color: var(--text-1);
}
.topbar-breadcrumb .crumb-current {
  color: var(--text-1);
  font-weight: 500;
}

.topbar-breadcrumb .crumb-current {
  color: var(--text-1);
}

.topbar-spacer { flex: 1; }

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.topbar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px;
  border-radius: 4px;
  cursor: pointer;
}

.topbar-user:hover { background: var(--bg-3); }

.topbar-user .avatar {
  width: 24px;
  height: 24px;
  background: var(--bg-4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--text-1);
  font-weight: 500;
  border: 1px solid var(--border-2);
}

/* ============================================================
   页头
============================================================ */

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border-1);
}

.page-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: var(--letter-snug);
  margin: 0;
}

.page-subtitle {
  font-size: 12px;
  color: var(--text-4);
  margin-top: 4px;
}

/* ============================================================
   卡片
============================================================ */

.card {
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 6px;
}

.card-padded { padding: 16px; }
.card-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-1);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.card-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: 0.02em;
}

.card-body { padding: 16px; }

/* KPI 卡片 */
.kpi {
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  padding: 14px 16px;
  position: relative;
  overflow: hidden;
}

.kpi-label {
  font-size: 10.5px;
  color: var(--text-4);
  text-transform: uppercase;
  letter-spacing: var(--letter-wide);
  margin-bottom: 8px;
  font-weight: 500;
}

.kpi-value {
  font-size: 22px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: var(--letter-tight);
  font-variant-numeric: tabular-nums;
}

.kpi-trend {
  font-size: 11px;
  color: var(--text-4);
  margin-top: 6px;
}

.kpi-bar {
  display: none;  /* Linear 风不使用左侧装饰条 */
}

.kpi-bar.emerald,
.kpi-bar.blue,
.kpi-bar.amber,
.kpi-bar.red,
.kpi-bar.violet { background: transparent; }

/* ============================================================
   按钮 (Linear 风)
   - btn-primary: 白底深字(最强调,每个页面通常只有一个)
   - btn-secondary: 浅灰边框透明底(常规操作)
   - btn-ghost: 透明底浅字(辅助操作)
============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 5px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 500;
  font-family: inherit;
  letter-spacing: var(--letter-normal);
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
  white-space: nowrap;
}

.btn:hover {
  background: var(--bg-3);
  color: var(--text-1);
}

/* 主按钮:Linear 招牌 — 白底深字 */
.btn-primary {
  background: var(--text-1);
  color: var(--bg-0);
  font-weight: 500;
  border-color: var(--text-1);
}
.btn-primary:hover {
  background: #FFFFFF;
  color: var(--bg-0);
  border-color: #FFFFFF;
}

/* 次按钮:边框 + 透明底 */
.btn-secondary {
  background: var(--bg-3);
  border-color: var(--border-2);
  color: var(--text-1);
}
.btn-secondary:hover {
  background: var(--bg-4);
  border-color: var(--border-3);
}

.btn-ghost {
  color: var(--text-3);
}
.btn-ghost:hover {
  color: var(--text-1);
  background: var(--bg-3);
}

.btn-danger {
  color: var(--red);
}
.btn-danger:hover {
  background: var(--red-bg);
  color: var(--red);
}

.btn-sm { padding: 4px 10px; font-size: 11px; }
.btn.icon-only { padding: 5px 7px; }
.btn.icon-only span { display: inline-flex; align-items: center; }

/* ============================================================
   输入框
============================================================ */

.input {
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  border-radius: 5px;
  padding: 6px 10px;
  color: var(--text-1);
  font-size: 12px;
  font-family: inherit;
  letter-spacing: var(--letter-normal);
  outline: none;
  transition: border-color 0.12s ease, box-shadow 0.12s ease;
}

.input:focus {
  border-color: var(--border-3);
  box-shadow: 0 0 0 3px rgba(247, 248, 248, 0.04);
}

.input::placeholder { color: var(--text-4); }

.input-search {
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  padding-left: 30px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238A8F98' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>");
  background-repeat: no-repeat;
  background-position: 9px center;
}

.select {
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  border-radius: 5px;
  padding: 6px 24px 6px 10px;
  color: var(--text-1);
  font-size: 12px;
  font-family: inherit;
  outline: none;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8F98' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 8px center;
}

.select:focus { border-color: var(--border-3); }

.toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.toolbar .spacer { flex: 1; }

/* ============================================================
   表格
============================================================ */

.data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 12.5px;
}

.data-table thead th {
  background: var(--bg-2);
  color: var(--text-4);
  font-weight: 500;
  text-align: left;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border-2);
  letter-spacing: var(--letter-normal);
  font-size: 11.5px;
  white-space: nowrap;
  position: sticky;
  top: 0;
  z-index: 1;
}

.data-table thead th.sortable {
  cursor: pointer;
  user-select: none;
}

.data-table thead th.sortable:hover { color: var(--text-1); }

.data-table thead th .sort-icon {
  margin-left: 4px;
  opacity: 0.4;
  font-size: 10px;
}

.data-table thead th.sort-active .sort-icon {
  opacity: 1;
  color: var(--text-1);
}

.data-table tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border-1);
  color: var(--text-2);
  vertical-align: middle;
}

.data-table tbody tr {
  transition: background 0.08s ease;
}

.data-table tbody tr:hover {
  background: var(--bg-3);
}

.data-table tbody tr:hover td {
  color: var(--text-1);
}

.data-table .strong { color: var(--text-1); font-weight: 500; }
.data-table .text-muted { color: var(--text-4); }
.data-table .num,
.data-table .money { text-align: right; }

.data-table .row-clickable { cursor: pointer; }

.empty-state {
  padding: 60px 20px;
  text-align: center;
  color: var(--text-3);
  font-size: 12px;
}

/* ============================================================
   OA Task Card (P1-1 重设计)
============================================================ */
.oa-card:hover {
  border-color: var(--text-3);
  background: var(--bg-3);
  transform: translateY(-1px);
}
.oa-card:hover .btn-primary {
  background: var(--text-1);
  color: var(--bg-0);
}

/* ============================================================
   AttachmentUploader / Viewer
============================================================ */
.att-uploader { display: block; }
.att-drop-zone {
  border: 1.5px dashed var(--border-2);
  border-radius: 6px;
  padding: 18px 14px;
  text-align: center;
  cursor: pointer;
  transition: all 0.15s;
  background: var(--bg-2);
}
.att-drop-zone:hover {
  border-color: var(--text-3);
  background: var(--bg-3);
}
.att-drop-zone.att-drag-over {
  border-color: var(--emerald);
  background: rgba(16,185,129,0.06);
}
.att-drop-zone.att-uploading {
  opacity: 0.5;
  cursor: wait;
}
.att-drop-hint { color: var(--text-3); }
.att-drop-text { font-size: 13px; color: var(--text-2); margin-top: 6px; }
.att-drop-sub { font-size: 11px; color: var(--text-4); margin-top: 3px; }

.att-thumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}
.att-thumb {
  position: relative;
  width: 120px;
}
.att-thumb img {
  width: 120px;
  height: 90px;
  object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--border-1);
}
.att-thumb-mask {
  position: absolute;
  top: 4px; right: 4px;
}
.att-thumb-del {
  background: rgba(0,0,0,0.7);
  border: 1px solid var(--border-2);
  color: white;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 0;
}
.att-thumb-del:hover { background: var(--red); }
.att-thumb-caption {
  width: 100%;
  margin-top: 4px;
  padding: 4px 6px;
  font-size: 11px;
  background: var(--bg-3);
  border: 1px solid var(--border-1);
  color: var(--text-2);
  border-radius: 3px;
}

/* Viewer 画廊 */
.att-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.att-gallery-item {
  width: 80px;
  cursor: pointer;
  transition: transform 0.12s;
}
.att-gallery-item:hover {
  transform: scale(1.05);
}
.att-gallery-item img {
  width: 80px;
  height: 60px;
  object-fit: cover;
  border-radius: 3px;
  border: 1px solid var(--border-1);
}
.att-gallery-caption {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 2px;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}
.btn:disabled,
.btn[disabled],
[data-no-perm="1"] {
  opacity: 0.45;
  cursor: not-allowed !important;
  pointer-events: auto;  /* 保留以显示 tooltip */
}
.btn:disabled:hover,
.btn[disabled]:hover {
  background: inherit;
  color: inherit;
  border-color: inherit;
}

/* RBAC: 无权限菜单项灰显(全局可见但不可点) */
.sidebar-item.no-perm,
.sidebar-subitem.no-perm {
  opacity: 0.35;
  cursor: not-allowed !important;
}
.sidebar-item.no-perm:hover,
.sidebar-subitem.no-perm:hover {
  background: transparent !important;
  color: var(--text-3) !important;
}

/* ============================================================
   Dashboard 入口卡片 (Linear 风:灰图标 + hover 微亮)
============================================================ */
.entry-card {
  transition: background 0.12s ease, border-color 0.12s ease;
}
.entry-card:hover {
  background: var(--bg-3);
  border-color: var(--border-3);
}
.entry-icon {
  width: 36px;
  height: 36px;
  background: var(--bg-4);
  color: var(--text-2);
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-2);
  flex-shrink: 0;
}
.entry-card:hover .entry-icon {
  color: var(--text-1);
  border-color: var(--border-3);
}

/* ============================================================
   状态徽章 (Linear 风:无边框,纯背景填充,大圆点)
============================================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  line-height: 1.5;
  font-weight: 500;
  border: 1px solid transparent;
  white-space: nowrap;
  letter-spacing: var(--letter-normal);
}

.badge::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
  flex-shrink: 0;
}

.badge.no-dot::before { display: none; }

/* Linear 风:无边框,只用背景色块 */
.badge.emerald { color: var(--emerald); background: var(--emerald-bg); }
.badge.blue    { color: var(--blue);    background: var(--blue-bg);    }
.badge.amber   { color: var(--amber);   background: var(--amber-bg);   }
.badge.orange  { color: var(--orange);  background: var(--orange-bg);  }
.badge.red     { color: var(--red);     background: var(--red-bg);     }
.badge.violet  { color: var(--violet);  background: var(--violet-bg);  }
.badge.slate   { color: var(--text-2);  background: var(--bg-4);       }

/* ============================================================
   进度条
============================================================ */

.progress {
  height: 4px;
  background: var(--bg-3);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}

.progress-bar {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  transition: width 0.3s ease;
}

.progress-bar.emerald { background: var(--emerald); }
.progress-bar.amber   { background: var(--amber); }
.progress-bar.red     { background: var(--red); }

/* ============================================================
   Modal
============================================================ */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(3px);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.15s ease;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.modal {
  background: var(--bg-2);
  border: 1px solid var(--border-2);
  border-radius: 8px;
  box-shadow: var(--shadow-lg);
  min-width: 420px;
  max-width: 90vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  animation: slideUp 0.18s ease;
}

@keyframes slideUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.modal-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--border-1);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
}

.modal-close {
  cursor: pointer;
  color: var(--text-3);
  font-size: 18px;
  line-height: 1;
}

.modal-close:hover { color: var(--text-1); }

.modal-body {
  padding: 18px;
  overflow-y: auto;
  flex: 1;
}

.modal-footer {
  padding: 12px 18px;
  border-top: 1px solid var(--border-1);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

/* ============================================================
   表单
============================================================ */

.form-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  margin-bottom: 12px;
  align-items: center;
}

.form-label {
  color: var(--text-2);
  font-size: 12px;
}

.form-label .required {
  color: var(--red);
  margin-left: 2px;
}

.form-help {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 4px;
}

/* ============================================================
   通用工具
============================================================ */

.text-muted { color: var(--text-3); }
.text-strong { color: var(--text-1); }
.text-accent { color: var(--accent); }
.text-emerald { color: var(--emerald); }
.text-red { color: var(--red); }
.text-amber { color: var(--amber); }

.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-1 { gap: 4px; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.gap-4 { gap: 16px; }
.gap-6 { gap: 24px; }

.grid { display: grid; }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.grid-cols-5 { grid-template-columns: repeat(5, 1fr); }

.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mb-6 { margin-bottom: 24px; }

.w-full { width: 100%; }
.text-right { text-align: right; }
.text-center { text-align: center; }

/* ============================================================
   通知 toast
============================================================ */

.toast-container {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.toast {
  background: var(--bg-2);
  border: 1px solid var(--border-2);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  padding: 10px 16px;
  color: var(--text-1);
  font-size: 12px;
  box-shadow: var(--shadow-md);
  min-width: 260px;
  animation: slideIn 0.2s ease;
}

.toast.success { border-left-color: var(--emerald); }
.toast.error   { border-left-color: var(--red); }
.toast.warning { border-left-color: var(--amber); }
.toast.info    { border-left-color: var(--blue); }

@keyframes slideIn {
  from { transform: translateX(100%); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

/* ============================================================
   订单详情 V2 - 侧边 Tab + 主区域
============================================================ */
.order-shell {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 16px;
}
.order-side-tabs {
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  padding: 8px;
  height: fit-content;
  position: sticky;
  top: 16px;
}
.side-tab {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 12px; border-radius: 5px;
  cursor: pointer;
  color: var(--text-3); font-size: 13px;
  transition: background 0.12s ease, color 0.12s ease;
  text-decoration: none;
}
.side-tab:hover { background: var(--bg-3); color: var(--text-1); }
.side-tab.active {
  background: var(--bg-3);
  color: var(--text-1);
  font-weight: 500;
}
.side-tab .tab-icon {
  width: 14px; height: 14px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px;
  opacity: 0.7;
}
.side-tab.active .tab-icon { opacity: 1; }
.side-tab .tab-badge {
  margin-left: auto;
  font-size: 11px;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--bg-4);
  color: var(--text-4);
  font-variant-numeric: tabular-nums;
}
.side-tab.active .tab-badge {
  background: var(--text-1);
  color: var(--bg-0);
}
.side-more-toggle {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  cursor: pointer;
  color: var(--text-3);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 8px;
  border-top: 1px solid var(--border-1);
  padding-top: 12px;
}
.side-more-toggle:hover { color: var(--text-1); }
.side-more-content { display: none; }
.side-more-content.open { display: block; }

.order-head {
  padding: 16px 18px;
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  margin-bottom: 14px;
}
.order-head-row {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
}
.order-head .order-no {
  font-size: 18px; font-weight: 600;
  color: var(--text-1);
  letter-spacing: var(--letter-snug);
  font-variant-numeric: tabular-nums;
}
.order-head .order-meta {
  color: var(--text-4); font-size: 12px; margin-top: 6px;
  display: flex; gap: 10px; flex-wrap: wrap;
}
.order-head .order-meta .separator { color: var(--text-5); }

.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* 概览 KPI */
.ov-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
.ov-card {
  padding: 16px 18px;
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  transition: border-color 0.15s;
}
.ov-card:hover { border-color: var(--border-2); }
.ov-card .label {
  font-size: 10.5px;
  color: var(--text-3);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.ov-card .value {
  font-size: 26px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: -0.024em;
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums slashed-zero;
  font-feature-settings: 'tnum' 1, 'cv11' 1, 'zero' 1;
  line-height: 1.15;
}
.ov-card .sub {
  font-size: 11px;
  color: var(--text-4);
  margin-top: 8px;
  letter-spacing: -0.005em;
}
.ov-card .progress {
  margin-top: 10px;
  height: 4px;
  background: var(--bg-3);
  border-radius: 2px;
  overflow: hidden;
}
.ov-card .progress-fill {
  height: 100%;
  background: var(--text-4);
  transition: width 0.3s ease;
}
.ov-card.shipped .progress-fill {
  background: var(--blue);
  box-shadow: 0 0 8px var(--blue-glow);
}
.ov-card.settled .progress-fill {
  background: var(--amber);
}
.ov-card.paid .progress-fill {
  background: var(--emerald);
  box-shadow: 0 0 8px var(--emerald-glow);
}

.ov-section {
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  margin-bottom: 14px;
}
.ov-section-head {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-1);
}
.ov-section-body { padding: 14px 16px; }

/* Timeline */
.tl-list {
  position: relative;
  padding-left: 30px;
}
.tl-list::before {
  content: '';
  position: absolute;
  left: 10px;
  top: 8px;
  bottom: 8px;
  width: 1px;
  background: var(--border-2);
}
.tl-event {
  position: relative;
  margin-bottom: 18px;
  padding: 14px 16px;
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 6px;
}
.tl-event::before {
  content: '';
  position: absolute;
  left: -25px;
  top: 18px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid var(--bg-1);
  background: var(--text-3);
}
.tl-event.severity-success::before { background: var(--emerald); }
.tl-event.severity-info::before    { background: var(--blue); }
.tl-event.severity-warning::before { background: var(--amber); }
.tl-event.severity-danger::before  { background: var(--red); }
.tl-event.severity-neutral::before { background: var(--text-3); }
.tl-event-header {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 6px;
}
.tl-event-icon {
  width: 24px; height: 24px;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 14px;
}
.tl-event-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-1);
  flex: 1;
}
.tl-event-time {
  font-size: 11px;
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
}
.tl-event-time .time-since {
  color: var(--text-4);
  margin-left: 6px;
}
.tl-event-desc {
  font-size: 12px;
  color: var(--text-2);
  margin-bottom: 8px;
  margin-left: 32px;
}
.tl-event-meta {
  font-size: 11px;
  color: var(--text-3);
  margin-left: 32px;
}
.tl-event-changes {
  margin-left: 32px;
  margin-top: 8px;
  padding: 8px 12px;
  background: var(--bg-3);
  border-radius: 4px;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}
.tl-event-changes .change-line {
  display: flex; gap: 6px; align-items: center;
  padding: 2px 0;
}
.tl-event-attachments {
  margin-left: 32px;
  margin-top: 8px;
  display: flex; flex-wrap: wrap;
  gap: 6px;
}
.tl-attachment {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--bg-3);
  border: 1px solid var(--border-1);
  border-radius: 4px;
  font-size: 11px;
  color: var(--text-2);
  cursor: pointer;
  transition: all 0.15s ease;
}
.tl-attachment:hover {
  background: var(--bg-4);
  border-color: var(--border-3);
  color: var(--text-1);
}
.tl-attachment .name { font-family: var(--font-mono); }
.tl-attachment .size { color: var(--text-4); font-size: 10px; }

.coming-soon {
  padding: 60px 20px;
  text-align: center;
  background: var(--bg-2);
  border: 1px dashed var(--border-2);
  border-radius: 6px;
}
.coming-soon-icon {
  font-size: 32px;
  margin-bottom: 12px;
  opacity: 0.4;
}
.coming-soon-title {
  font-size: 14px;
  color: var(--text-2);
  margin-bottom: 6px;
}
.coming-soon-desc {
  font-size: 12px;
  color: var(--text-3);
}

.preview-pdf-page {
  background: white;
  width: 100%;
  max-width: 595px;
  margin: 0 auto;
  padding: 50px 60px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.3);
  color: #1a1a1a;
  font-family: serif;
  min-height: 500px;
}
.preview-img-wrap {
  width: 100%; text-align: center;
}
.preview-img-wrap img {
  max-width: 100%;
  max-height: 60vh;
  border-radius: 4px;
}

/* ============================================================
   订单中心 Tab 条 / 阶段徽章 / 进度条
============================================================ */
.order-tabs {
  display: flex; gap: 4px; margin-bottom: 14px;
  border-bottom: 1px solid var(--border-2);
  overflow-x: auto;
}
.order-tab {
  padding: 10px 14px;
  font-size: 12.5px;
  color: var(--text-3);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
  transition: color 0.12s ease, border-color 0.12s ease;
  font-weight: 500;
}
.order-tab:hover { color: var(--text-1); }
.order-tab.active {
  color: var(--text-1);
  border-bottom-color: var(--text-1);
}
.order-tab .count {
  font-size: 11px;
  padding: 1px 6px;
  background: var(--bg-3);
  border-radius: 4px;
  color: var(--text-4);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.order-tab.active .count {
  background: var(--bg-4);
  color: var(--text-1);
}

/* Tab 里的 SVG 图标 */
.order-tab .tab-icon-svg {
  display: inline-flex;
  align-items: center;
  opacity: 0.7;
  margin-right: 2px;
}
.order-tab.active .tab-icon-svg { opacity: 1; }

.progress-mini { display: flex; align-items: center; gap: 6px; }
.progress-mini-bar {
  width: 60px; height: 4px; background: var(--bg-4); border-radius: 2px;
  overflow: hidden;
}
.progress-mini-bar .fill {
  height: 100%; background: var(--text-4); border-radius: 2px;
  transition: width 0.3s ease;
}
.progress-mini-bar .fill.partial {
  background: var(--blue);
  box-shadow: 0 0 8px var(--blue-glow);
}
.progress-mini-bar .fill.full {
  background: var(--emerald);
  box-shadow: 0 0 8px var(--emerald-glow);
}
.progress-mini .pct {
  font-size: 11px; color: var(--text-4);
  min-width: 32px;
  font-variant-numeric: tabular-nums;
}

.stage-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 8px; border-radius: 4px;
  font-size: 11px; font-weight: 500;
  letter-spacing: var(--letter-normal);
}
.stage-badge .dot { width: 6px; height: 6px; border-radius: 50%; }
.stage-quoting    { background: var(--violet-bg);  color: var(--violet); }
.stage-quoting .dot { background: var(--violet); }
.stage-draft      { background: var(--bg-4);       color: var(--text-2); }
.stage-draft .dot   { background: var(--text-3); }
.stage-pending_finance    { background: var(--amber-bg);   color: var(--amber); }
.stage-pending_finance .dot { background: var(--amber); }
.stage-pending_warehouse  { background: var(--amber-bg);   color: var(--amber); }
.stage-pending_warehouse .dot { background: var(--amber); }
.stage-confirmed  { background: var(--blue-bg);    color: var(--blue); }
.stage-confirmed .dot { background: var(--blue); }
.stage-producing  { background: var(--orange-bg);  color: var(--orange); }
.stage-producing .dot { background: var(--orange); }
.stage-shipping   { background: var(--blue-bg);    color: var(--blue); }
.stage-shipping .dot { background: var(--blue); }
.stage-settling   { background: var(--amber-bg);   color: var(--amber); }
.stage-settling .dot { background: var(--amber); }
.stage-completed  { background: var(--emerald-bg); color: var(--emerald); }
.stage-completed .dot { background: var(--emerald); }
.stage-cancelled  { background: var(--bg-4);       color: var(--text-3); }
.stage-cancelled .dot { background: var(--text-4); }
.stage-exception  { background: var(--red-bg);     color: var(--red); }
.stage-exception .dot { background: var(--red); }

.relative-time {
  font-size: 11px; color: var(--text-4);
  font-variant-numeric: tabular-nums;
}

/* Timeline event role 色条(左侧 3px) - Linear 风,统一柔和色 */
.tl-event {
  position: relative;
}
.tl-event::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: transparent;
  border-radius: 6px 0 0 6px;
}
.tl-event[data-actor-role="sales"]::after      { background: var(--blue); }
.tl-event[data-actor-role="warehouse"]::after  { background: var(--orange); }
.tl-event[data-actor-role="finance"]::after    { background: var(--amber); }
.tl-event[data-actor-role="manager"]::after    { background: var(--violet); }
.tl-event[data-actor-role="supervisor"]::after { background: var(--violet); }
.tl-event[data-actor-role="system"]::after     { background: #94a3b8; opacity: 0.4; }

/* ==============================================
   订单详情 V3:头部 + 7 步流程条 + 业务化 KPI
   ============================================== */

/* === 头部:左主信息 + 右 3 张元数据卡 === */
.order-head-v3 {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: start;
  padding: 18px 22px;
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  margin-bottom: 12px;
}
.order-head-v3 .order-head-main { min-width: 0; }
.order-head-v3 .order-head-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.order-head-v3 .order-no {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.022em;
  color: var(--text-1);
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums slashed-zero;
  font-feature-settings: 'tnum' 1, 'zero' 1, 'cv11' 1;
}
.order-head-v3 .order-meta {
  font-size: 12px;
  color: var(--text-3);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.order-head-v3 .order-meta .separator { color: var(--text-4); }

.order-head-meta-cards {
  display: flex;
  gap: 10px;
}
.meta-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-3);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  min-width: 130px;
}
.meta-card-icon {
  width: 28px; height: 28px;
  border-radius: 6px;
  background: var(--blue-bg);
  color: var(--blue);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: inset 0 0 0 1px var(--blue-border);
}
.meta-card-text { line-height: 1.3; }
.meta-card-label {
  font-size: 10px;
  color: var(--text-4);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 2px;
}
.meta-card-value {
  font-size: 12.5px;
  color: var(--text-1);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.006em;
}

/* === 7 步流程条 === */
.stages-bar {
  display: flex;
  align-items: stretch;
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 16px 18px;
  margin-bottom: 12px;
  gap: 0;
}
.stage-step {
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
  min-width: 0;
  flex: 0 0 auto;
}
.stage-line {
  height: 1.5px;
  flex: 1 1 0;
  margin: 0 6px;
  background: var(--border-1);
  align-self: center;
  min-width: 8px;
}
.stage-circle {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  flex-shrink: 0;
  transition: all 0.2s;
}
.stage-meta {
  line-height: 1.25;
  min-width: 0;
  flex-shrink: 1;
  overflow: hidden;
}
.stage-label {
  font-size: 11.5px;
  font-weight: 500;
  color: var(--text-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.stage-state {
  font-size: 10px;
  color: var(--text-4);
  margin-top: 2px;
  white-space: nowrap;
}
/* 状态:done(已完成) */
.stage-done .stage-circle {
  background: var(--emerald);
  color: #08090A;
  border: none;
  box-shadow: 0 0 0 1px var(--emerald-bg), 0 0 16px var(--emerald-glow);
}
.stage-done .stage-label { color: var(--text-1); }
.stage-line-done {
  background: var(--emerald);
  opacity: 0.6;
  box-shadow: 0 0 6px var(--emerald-glow);
}
/* 状态:active(进行中) */
.stage-active .stage-circle {
  background: var(--blue);
  color: #08090A;
  box-shadow: 0 0 0 3px var(--blue-bg), 0 0 18px var(--blue-glow);
}
.stage-active .stage-label { color: var(--text-1); font-weight: 600; }
.stage-active .stage-state { color: var(--blue); font-weight: 500; }
/* 状态:pending(未开始) */
.stage-pending .stage-circle {
  background: var(--bg-3);
  color: var(--text-4);
  border: 1.5px solid var(--border-2);
}
.stage-pending .stage-label { color: var(--text-3); }

/* === 概览页 V3 :业务化 KPI === */
.ov-grid-v3 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 12px;
}
.ov-card-v3 {
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 16px 18px;
}
.ov-card-v3 .label {
  font-size: 11px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.ov-card-v3 .value-row {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 6px;
}
.ov-card-v3 .value-big {
  font-size: 28px;
  font-weight: 600;
  color: var(--text-1);
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum' 1, 'cv11' 1;
  letter-spacing: -0.024em;
}
.ov-card-v3 .value-mid {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: -0.014em;
}
.ov-card-v3 .value-divider {
  font-size: 17px;
  color: var(--text-4);
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums;
  font-weight: 400;
}
.ov-card-v3 .value-total {
  font-size: 17px;
  color: var(--text-3);
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.ov-card-v3 .value-unit {
  font-size: 13px;
  color: var(--text-3);
  margin-left: 4px;
}
.ov-card-v3 .progress {
  height: 4px;
  background: var(--bg-3);
  border-radius: 2px;
  overflow: hidden;
  margin: 8px 0 6px;
}
.ov-card-v3 .progress-fill {
  height: 100%;
  background: var(--blue);
  transition: width 0.3s;
}
.ov-card-v3 .sub-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
}

/* === 状态药丸(用于 KPI/客户/明细) === */
.status-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.4;
}
.status-emerald { background: var(--emerald-bg); color: var(--emerald); }
.status-blue    { background: var(--blue-bg);    color: var(--blue); }
.status-amber   { background: var(--amber-bg);   color: var(--amber); }
.status-red     { background: var(--red-bg);     color: var(--red); }
.status-slate   { background: var(--bg-3);       color: var(--text-3); }
.status-violet  { background: var(--violet-bg);  color: var(--violet); }

/* === 客户/Timeline 2 列布局 === */
.ov-two-col-v3 {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 12px;
  margin-bottom: 12px;
}
.kv-row {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  font-size: 12px;
}

/* === Mini Timeline V3 === */
/* === Mini Timeline V4 — 卡片式,状态色条 + glow === */
.mini-tl-v3 {
  padding: 12px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mini-tl-row {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px 12px 16px;
  background: var(--bg-3);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  transition: all 0.15s;
}
.mini-tl-row::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  border-radius: 6px 0 0 6px;
  background: var(--slate);
}
/* 状态色条:done(success) / active(info) / pending(neutral) / warning / danger */
.mini-tl-row.state-done::before {
  background: var(--emerald);
  box-shadow: 0 0 14px var(--emerald-glow);
}
.mini-tl-row.state-active::before {
  background: var(--blue);
  box-shadow: 0 0 14px var(--blue-glow);
}
.mini-tl-row.state-warning::before { background: var(--amber); }
.mini-tl-row.state-danger::before  { background: var(--red); }
.mini-tl-row.state-pending::before { background: var(--text-5); }

.mini-tl-row.current {
  background: var(--bg-4);
  border-color: var(--border-3);
}
.mini-tl-row:hover {
  border-color: var(--border-3);
}

.mini-tl-icon {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-4);
  color: var(--text-3);
}
.mini-tl-row.state-done .mini-tl-icon {
  background: var(--emerald-bg);
  color: var(--emerald);
}
.mini-tl-row.state-active .mini-tl-icon {
  background: var(--blue-bg);
  color: var(--blue);
}
.mini-tl-row.state-warning .mini-tl-icon {
  background: var(--amber-bg);
  color: var(--amber);
}
.mini-tl-row.state-danger .mini-tl-icon {
  background: var(--red-bg);
  color: var(--red);
}

.mini-tl-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.mini-tl-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-1);
  letter-spacing: -0.005em;
  line-height: 1.4;
}
.mini-tl-title .num,
.mini-tl-title .code-text {
  font-variant-numeric: tabular-nums slashed-zero;
}
.mini-tl-meta {
  font-size: 11px;
  color: var(--text-4);
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.mini-tl-meta .separator { color: var(--text-5); }
.mini-tl-row.current .mini-tl-title { color: var(--text-1); font-weight: 600; }
.mini-tl-row.state-done .mini-tl-title { color: var(--text-1); }

.mini-tl-now-badge {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 10px;
  background: var(--blue-bg);
  color: var(--blue);
  border: 1px solid var(--blue-border);
  align-self: center;
  white-space: nowrap;
  font-weight: 500;
}

/* === "更多操作" 下拉菜单 === */
.more-actions-wrap { position: relative; }
.more-actions-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  background: var(--bg-2);
  border: 1px solid var(--border-2);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
  padding: 6px 0;
  z-index: 100;
  display: none;
}
.more-actions-menu.open { display: block; }
.more-menu-section-title {
  font-size: 10px;
  color: var(--text-4);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 6px 14px 4px;
}
.more-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  font-size: 13px;
  color: var(--text-2);
  cursor: pointer;
  text-decoration: none;
  transition: background 0.1s;
}
.more-menu-item:hover {
  background: var(--bg-3);
  color: var(--text-1);
}
.more-menu-item.active {
  background: var(--bg-3);
  color: var(--blue);
}
.more-menu-icon {
  display: flex;
  align-items: center;
  width: 16px;
  color: var(--text-3);
}
.more-menu-item.active .more-menu-icon { color: var(--blue); }
.more-menu-badge {
  margin-left: auto;
  font-size: 10px;
  font-weight: 600;
  background: var(--bg-4);
  color: var(--text-3);
  padding: 1px 6px;
  border-radius: 8px;
  min-width: 16px;
  text-align: center;
}
.more-menu-item.active .more-menu-badge {
  background: var(--blue);
  color: #fff;
}

/* === 响应式:1080 以下 === */
@media (max-width: 1180px) {
  .stages-bar { padding: 14px 14px; }
  .stage-meta { display: none; }
  .stage-line { margin: 0 4px; }
  .order-head-meta-cards { flex-wrap: wrap; }
  .ov-grid-v3 { grid-template-columns: repeat(2, 1fr); }
  .ov-two-col-v3 { grid-template-columns: 1fr; }
}

/* ============================================================
   Timeline V5 — 左右交替样式(参考用户上传的设计图)
   居中竖线 + 圆形 icon 在线上 + 左右卡片交替
   ============================================================ */

.tl-filter-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 22px;
  padding: 10px 14px;
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  flex-wrap: wrap;
}
.tl-role-filter-btn {
  padding: 4px 12px;
  font-size: 11px;
  border-radius: 4px;
  cursor: pointer;
  background: var(--bg-3);
  color: var(--text-2);
  border: 1px solid var(--border-1);
  font-weight: 400;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.tl-role-filter-btn:hover {
  background: var(--bg-4);
  border-color: var(--border-2);
}
.tl-role-filter-btn.active {
  background: var(--blue-bg);
  color: var(--blue);
  border-color: var(--blue-border);
  font-weight: 500;
}
.role-dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
}
.role-count { opacity: 0.65; }

/* === 主容器:左右交替 === */
.tl-alt {
.tl-alt {
  position: relative;
  padding: 8px 0;
  /* 中央竖线由每个 .tl-alt-line 接续画成 */
}
.tl-alt-row {
  display: grid;
  grid-template-columns: 1fr 120px 1fr;
  align-items: stretch;
  position: relative;
  margin-bottom: 20px;
}

/* 左右两侧卡片容器 */
.tl-alt-card-wrap {
  display: flex;
  align-items: center;
  min-width: 0;
}
.tl-alt-card-left {
  justify-content: flex-end;
  padding-right: 24px;
}
.tl-alt-card-right {
  justify-content: flex-start;
  padding-left: 24px;
}

/* 卡片本体 */
.tl-alt-card {
  position: relative;
  background: var(--bg-3);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 14px 16px;
  max-width: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color 0.15s, transform 0.15s;
}
.tl-alt-card:hover {
  border-color: var(--border-3);
}
/* 卡片"指向中央"的小三角 */
.tl-alt-card::before {
  content: '';
  position: absolute;
  width: 0; height: 0;
  border-style: solid;
  top: 18px;
}
.tl-alt-card-left .tl-alt-card::before {
  right: -7px;
  border-width: 6px 0 6px 7px;
  border-color: transparent transparent transparent var(--border-1);
}
.tl-alt-card-right .tl-alt-card::before {
  left: -7px;
  border-width: 6px 7px 6px 0;
  border-color: transparent var(--border-1) transparent transparent;
}

/* 卡片头部:标题 + 徽章 */
.tl-alt-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}
.tl-alt-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: -0.011em;
  line-height: 1.4;
  flex: 1;
  min-width: 0;
}
.tl-alt-badges {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  flex-shrink: 0;
}
/* 时间 */
.tl-alt-time {
  font-size: 11px;
  color: var(--text-4);
  font-variant-numeric: tabular-nums;
}
.tl-alt-time .time-since {
  color: var(--text-5);
  margin-left: 4px;
}
/* 描述 */
.tl-alt-desc {
  font-size: 12.5px;
  color: var(--text-2);
  line-height: 1.5;
  letter-spacing: -0.005em;
}
/* 元数据 */
.tl-alt-meta {
  font-size: 11px;
  color: var(--text-3);
  padding-top: 6px;
  border-top: 1px solid var(--border-1);
}

/* === 中央(icon + 竖线) === */
.tl-alt-center {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding-top: 4px;
  gap: 2px;
}
/* 日期 */
.tl-alt-date {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  line-height: 1.2;
}
/* 时间(小字) */
.tl-alt-time-mini {
  font-size: 10px;
  color: var(--text-4);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.005em;
  line-height: 1.2;
  margin-bottom: 4px;
}
/* 圆圈本身 */
.tl-alt-circle {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-3);
  border: 2px solid var(--border-2);
  color: var(--text-3);
  z-index: 2;
  flex-shrink: 0;
  transition: all 0.2s;
}
/* 耗时(圆圈下方) */
.tl-alt-duration {
  font-size: 10px;
  font-weight: 500;
  color: var(--text-4);
  background: var(--bg-3);
  padding: 2px 8px;
  border-radius: 10px;
  border: 1px solid var(--border-1);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  letter-spacing: -0.005em;
}
.tl-alt-icon {
  display: flex;
  align-items: center;
  justify-content: center;
}
/* 状态色应用到圆圈 */
.tl-alt-circle.state-done {
  background: var(--emerald-bg);
  border-color: var(--emerald);
  color: var(--emerald);
  box-shadow: 0 0 18px var(--emerald-glow);
}
.tl-alt-circle.state-active {
  background: var(--blue-bg);
  border-color: var(--blue);
  color: var(--blue);
  box-shadow: 0 0 18px var(--blue-glow);
}
.tl-alt-circle.state-warning {
  background: var(--amber-bg);
  border-color: var(--amber);
  color: var(--amber);
}
.tl-alt-circle.state-danger {
  background: var(--red-bg);
  border-color: var(--red);
  color: var(--red);
}
.tl-alt-circle.state-pending {
  background: var(--bg-3);
  border-color: var(--border-2);
  color: var(--text-4);
}

/* 状态色也影响卡片边框(让识别更直接) */
.tl-alt-row.state-done .tl-alt-card {
  border-color: var(--emerald-border);
}
.tl-alt-row.state-active .tl-alt-card {
  border-color: var(--blue-border);
}
.tl-alt-row.state-warning .tl-alt-card {
  border-color: var(--amber-border);
}
.tl-alt-row.state-danger .tl-alt-card {
  border-color: var(--red-border);
}
.tl-alt-row.state-done .tl-alt-card-left .tl-alt-card::before {
  border-left-color: var(--emerald-border);
}
.tl-alt-row.state-done .tl-alt-card-right .tl-alt-card::before {
  border-right-color: var(--emerald-border);
}
.tl-alt-row.state-active .tl-alt-card-left .tl-alt-card::before {
  border-left-color: var(--blue-border);
}
.tl-alt-row.state-active .tl-alt-card-right .tl-alt-card::before {
  border-right-color: var(--blue-border);
}

/* 节点简短描述(标题下) */
.tl-alt-shortdesc {
  font-size: 12px;
  color: var(--text-3);
  font-weight: 500;
  letter-spacing: -0.005em;
  padding: 4px 8px;
  background: var(--bg-2);
  border-radius: 4px;
  display: inline-block;
  align-self: flex-start;
}
.tl-alt-row.state-done .tl-alt-shortdesc {
  color: var(--emerald);
  background: var(--emerald-bg);
}
.tl-alt-row.state-active .tl-alt-shortdesc {
  color: var(--blue);
  background: var(--blue-bg);
}
.tl-alt-row.state-warning .tl-alt-shortdesc {
  color: var(--amber);
  background: var(--amber-bg);
}
.tl-alt-row.state-danger .tl-alt-shortdesc {
  color: var(--red);
  background: var(--red-bg);
}

/* 中央接续竖线 — 调整 top 让它从耗时下方开始 */
.tl-alt-line {
  position: absolute;
  top: 100px;     /* 在 duration 之下 */
  bottom: -16px;
  left: 50%;
  width: 2px;
  margin-left: -1px;
  background: var(--border-2);
  z-index: 1;
}

/* === 顶栏按钮里的"计数小角标" === */
.btn-count-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 0 6px;
  min-width: 16px;
  height: 16px;
  line-height: 16px;
  text-align: center;
  background: var(--blue-bg);
  color: var(--blue);
  border-radius: 8px;
  font-size: 10px;
  font-weight: 600;
  vertical-align: middle;
  font-variant-numeric: tabular-nums;
}
.btn.btn-active {
  background: var(--blue-bg);
  color: var(--blue);
  border-color: var(--blue-border);
}

/* === 响应式:窄屏改为单列(全部右侧) === */
@media (max-width: 900px) {
  .tl-alt-row {
    grid-template-columns: 44px 1fr;
  }
  .tl-alt-card-left { display: none; }
  .tl-alt-center {
    grid-column: 1;
  }
  .tl-alt-card-right {
    grid-column: 2;
    padding-left: 16px;
    justify-content: flex-start;
  }
  .tl-alt-card-right .tl-alt-card::before {
    left: -7px;
  }
  /* 强制所有卡片显示在右侧 */
  .tl-alt-card-left .tl-alt-card { display: none; }
  /* 当原本是左侧的事件,clone 到右侧 — 用 JS 处理更好,这里简单留空 */
}

/* ============================================================
   Summary Grid — 结算单/发货单/入库单 等详情页通用 KPI 行
   跟 ov-card 视觉一致(夜光数字 + 紧字距)
   ============================================================ */

.summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.summary-card {
  padding: 16px 18px;
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  transition: border-color 0.15s;
}
.summary-card:hover { border-color: var(--border-2); }
.summary-card .label {
  font-size: 10.5px;
  color: var(--text-3);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.summary-card .value {
  font-size: 24px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: -0.022em;
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums slashed-zero;
  font-feature-settings: 'tnum' 1, 'cv11' 1, 'zero' 1;
  line-height: 1.2;
}
.summary-card .sub {
  font-size: 11px;
  color: var(--text-4);
  margin-top: 8px;
}
/* 状态语义化变体 */
.summary-card.payable .value { color: var(--text-1); }
.summary-card.paid .value {
  color: var(--emerald);
  text-shadow: 0 0 12px var(--emerald-glow);
}
.summary-card.unpaid .value {
  color: var(--amber);
}
.summary-card.overdue .value {
  color: var(--red);
}
.summary-card.due .value {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.011em;
}

/* ============================================================
   全局去除 number input 的上下调节小箭头(spinner)
   ============================================================ */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  appearance: none !important;
  margin: 0 !important;
  display: none !important;
}
input[type="number"] {
  -moz-appearance: textfield !important;
  appearance: textfield !important;
}

/* 权限矩阵可点击 cell */
td[data-toggle-perm] {
  transition: background 0.12s, transform 0.08s;
  user-select: none;
}
td[data-toggle-perm]:hover {
  background: var(--bg-3);
}
td[data-toggle-perm]:active {
  transform: scale(0.92);
}

/* ============================================================
   新建订单 - 产品行删除按钮(序号下方,小图标)
   ============================================================ */
.order-row .row-num {
  display: block;
  font-size: 12px;
  color: var(--text-3);
}
.order-row .row-delete-btn {
  display: block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px;
  margin: 2px auto 0;
  color: var(--text-4);
  opacity: 0.6;
  transition: opacity 0.15s, color 0.15s;
}
.order-row .row-delete-btn:hover {
  opacity: 1;
  color: var(--red);
}

/* 强化 — 在表格内的 number input 也彻底去 spinner */
.order-items-table input[type="number"]::-webkit-outer-spin-button,
.order-items-table input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  display: none !important;
  margin: 0 !important;
}
.order-items-table input.no-spin::-webkit-outer-spin-button,
.order-items-table input.no-spin::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  display: none !important;
  margin: 0 !important;
}
input.no-spin {
  -moz-appearance: textfield !important;
  appearance: textfield !important;
}
input.no-spin::-webkit-outer-spin-button,
input.no-spin::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  display: none !important;
  margin: 0 !important;
}

/* ============================================================
   EnhancedSelect 通用增强下拉样式
   ============================================================ */
.esel-row { display: flex; gap: 4px; align-items: center; }
.esel-btn {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border: 1px solid var(--border-2);
  border-radius: 5px;
  background: var(--bg-3);
  color: var(--text-3);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: border-color 0.12s, color 0.12s, background 0.12s;
}
.esel-btn:hover:not(:disabled) {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--bg-2);
}
.esel-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.esel-add:hover:not(:disabled) { color: var(--emerald); border-color: var(--emerald); }
.esel-edit:hover:not(:disabled) { color: var(--blue); border-color: var(--blue); }
.esel-del:hover:not(:disabled) { color: var(--red); border-color: var(--red); }
