/* ============================================================
 * 奕境 DMS · 共享侧栏样式 v3.2.2（浅色主题）
 * ------------------------------------------------------------
 * 遵循规范：奕境项目-原型输出规范 v3.2.2 §4.12
 * 配套：components/sidebar.js
 *
 * 设计要点：
 *   · 侧栏纯白，顶部品牌 bar 用品牌红 → 视觉锚点醒目
 *   · 激活态：浅粉底色 + 左侧 3px 红条 + 红字
 *   · 分组标题可折叠（点击切换 .collapsed）
 *   · 用 .sidebar X 嵌套提升优先级，覆盖各页面 legacy 内联 CSS
 * ============================================================ */

/* —— 双栏布局骨架 —— */
html,
body {
  height: 100%;
  overflow: hidden;
}

.layout {
  display: flex;
  height: 100vh;
  min-height: 100vh;
  overflow: hidden;
}

/* ============================================================
 * 侧栏容器
 * ============================================================ */
.sidebar {
  width: 208px;
  min-width: 208px;
  height: 100vh;
  background: var(--sidebar-bg);
  color: var(--sidebar-text);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  /* v3.2.6：移除 border-right，三栏（侧/顶/主）同色无界 */
}

/* ============================================================
 * 顶部品牌 Bar（v3.2.6：高度 56px 与 topbar 严格对齐 / 无下分隔线）
 * ============================================================ */
.sidebar .sidebar-brand {
  height: 56px;                                   /* v3.2.6：与 topbar 同高 */
  min-height: 56px;
  padding: 0 16px;                                /* 不再上下 padding 撑高 */
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--sidebar-brand-bg);
  color: var(--sidebar-brand-color);
  font-weight: 600;
  letter-spacing: 0.5px;
  border-bottom: none;                            /* v3.2.6：去掉 hairline */
}
.sidebar .sidebar-brand .logo {
  width: 24px;
  height: 24px;
  background: var(--sidebar-brand-logo-bg);   /* 红方块 */
  border-radius: 3px;
  display: grid;
  place-items: center;
  position: relative;
}
/* 用伪元素注入白色"奕"字，避免改 25 个页面的 HTML */
.sidebar .sidebar-brand .logo::before {
  content: "奕";
  color: var(--sidebar-brand-logo-color);
  font-weight: 700;
  font-size: 13px;
  line-height: 1;
}
.sidebar .sidebar-brand .name {
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--sidebar-brand-color);
}

/* ============================================================
 * 菜单容器
 * ============================================================ */
.sidebar .sidebar-menu {
  flex: 1;
  padding: 6px 0;
}

/* ============================================================
 * 一级独立项（如"工作台"，无分组）
 * ============================================================ */
.sidebar .menu-item.lonely {
  padding: 10px 16px;
  color: var(--text-primary);
  font-weight: 500;
  border-left: 3px solid transparent;
}
.sidebar .menu-item.lonely:hover {
  background: var(--sidebar-hover-bg);
}
.sidebar .menu-item.lonely.active {
  background: var(--sidebar-active-bg);
  color: var(--sidebar-active-color);
  border-left-color: var(--sidebar-active-bar);
}

/* ============================================================
 * 分组（标题 + 折叠）
 * ============================================================ */
.sidebar .menu-group {
  user-select: none;
  margin-bottom: 2px;
}
.sidebar .menu-group-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  color: var(--text-primary);
  font-size: var(--font-size-base);
  font-weight: 500;
  cursor: pointer;
  /* 覆盖 v3.2 旧规则 */
  text-transform: none;
  letter-spacing: 0;
}
.sidebar .menu-group-title > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.sidebar .menu-group-title:hover {
  background: var(--sidebar-hover-bg);
}
.sidebar .menu-group-title .caret {
  color: var(--text-tertiary);
  width: 14px;
  height: 14px;
  transition: transform 0.15s;
  flex-shrink: 0;
  margin-left: 8px;
}
.sidebar .menu-group.collapsed .caret {
  transform: rotate(-90deg);
}
.sidebar .menu-group.collapsed .sub {
  display: none;
}

/* ============================================================
 * 子项（带左缩进，激活时左侧 3px 红条）
 * ============================================================ */
.sidebar .menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px 8px 40px;
  color: var(--text-secondary);
  cursor: pointer;
  font-size: var(--font-size-sm);
  text-decoration: none;
  white-space: nowrap;
  border-left: 3px solid transparent;
  transition: background 0.15s, color 0.15s;
}
.sidebar .menu-item:visited {
  color: var(--text-secondary);
}
.sidebar .menu-item:hover {
  background: var(--sidebar-hover-bg);
  color: var(--text-primary);
}
.sidebar .menu-item.active {
  background: var(--sidebar-active-bg);
  color: var(--sidebar-active-color);
  border-left-color: var(--sidebar-active-bar);
  font-weight: 500;
}
.sidebar .menu-item .icon {
  flex-shrink: 0;
}

.dms-icon {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  color: currentColor;
  stroke-width: 1.75;
  flex-shrink: 0;
}

.q-icon .dms-icon {
  width: 20px;
  height: 20px;
}

.sidebar .menu-group-title .icon,
.sidebar .menu-item .icon {
  width: 18px;
  height: 18px;
}

/* ============================================================
 * 主区域 + 顶栏（保持 §4.11 规范）
 * ============================================================ */
.main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
}
.topbar {
  height: 56px;                                /* v3.2.5：56px = sidebar-brand 同高 */
  min-height: 56px;
  flex-shrink: 0;
  background: var(--bg-shell);                 /* v3.2.5：与 sidebar / 主区域同底色 */
  /* v3.2.6：去掉 border-bottom，三栏无界一体 */
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-lg);
}
.topbar-left {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.topbar-right {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}
.topbar-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--brand-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-sm);
  font-weight: 600;
  flex-shrink: 0;
}

/* ============================================================
 * 顶栏右侧工具栏 v3.2.5（搜索 + 图标按钮组 + 用户）
 * ============================================================ */
.topbar-tools {
  display: flex;
  align-items: center;
  gap: 16px;
}
.topbar-search {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 44px;
  padding: 0 16px;
  background: #fff;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  width: 364px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.topbar-search:focus-within {
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 2px rgba(134, 27, 47, 0.08);
}
.topbar-search-icon {
  color: var(--text-tertiary);
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}
.topbar-search input {
  flex: 1;
  border: 0;
  outline: none;
  font-size: 16px;
  background: transparent;
  color: var(--text-primary);
  min-width: 0;
}
.topbar-search input::placeholder { color: var(--text-placeholder); }

.topbar-icon {
  width: 28px;
  height: 32px;
  border: 0;
  background: transparent;
  color: var(--text-secondary);
  display: grid;
  place-items: center;
  cursor: pointer;
  border-radius: var(--radius-sm);
  position: relative;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}
.topbar-icon .dms-icon {
  width: 20px;
  height: 20px;
}
.topbar-icon:hover { background: rgba(0, 0, 0, 0.04); color: var(--text-primary); }
/* 红点徽标：data-badge="N" */
.topbar-icon[data-badge]::after {
  content: attr(data-badge);
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 14px;
  height: 14px;
  padding: 0 4px;
  background: var(--error);
  color: #fff;
  font-size: 10px;
  line-height: 14px;
  border-radius: var(--radius-full);
  text-align: center;
  font-weight: 600;
}

.topbar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 8px 4px 4px;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background 0.15s;
}
.topbar-user:hover { background: rgba(0, 0, 0, 0.04); }
.topbar-user .topbar-name {
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  font-weight: 500;
}

/* ============================================================
 * 富分页组件 v3.2.5
 * ============================================================ */
.pagination {
  display: flex;
  align-items: center;
  justify-content: flex-end;     /* v3.2.5：右对齐，左侧 total 单独靠左 */
  gap: 12px;
  padding: 12px var(--space-lg);
  border-top: 1px solid var(--border-light);
  background: var(--bg-card);
  flex-wrap: wrap;
}
.pagination .pager-total,
.pagination .total {           /* 兼容老 markup 的 .total */
  margin-right: auto;          /* 总数推到最左 */
  color: var(--text-tertiary);
  font-size: var(--font-size-sm);
}
.pagination .pager {
  display: flex;
  align-items: center;
  gap: 4px;
}
.pagination .pager a,
.pagination .pager .pager-page,
.pagination .pager .pager-arrow {
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-default);
  background: #fff;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  cursor: pointer;
  text-decoration: none;
  user-select: none;
}
.pagination .pager a.active,
.pagination .pager .pager-page.active {
  background: var(--brand-primary);
  border-color: var(--brand-primary);
  color: #fff;
}
.pagination .pager a:hover:not(.active),
.pagination .pager .pager-page:hover:not(.active) {
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}
.pagination .pager a.disabled,
.pagination .pager .pager-arrow.disabled {
  color: var(--text-placeholder);
  cursor: not-allowed;
  pointer-events: none;
}
.pagination .pager-jump {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}
.pagination .pager-jump input {
  width: 48px;
  height: 32px;
  padding: 0 8px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  text-align: center;
  outline: none;
  color: var(--text-primary);
}
.pagination .pager-jump input:focus {
  border-color: var(--brand-primary);
}
.pagination .pager-size {
  height: 32px;
  padding: 0 8px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  background: #fff;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  cursor: pointer;
  outline: none;
}
.pagination .pager-size:focus {
  border-color: var(--brand-primary);
}
.content {
  flex: 1;
  overflow-y: auto;
  height: calc(100vh - 56px);
  padding: 14px 24px 16px;
}

/* ============================================================
 * 全局色彩规则（v3.2.3 同步对齐截图）
 * 用 body X 嵌套提升优先级，覆盖 25 个页面内联 CSS 的旧色
 * ============================================================ */

/* 主按钮：品牌红（覆盖部分页面把主按钮做成蓝色的历史遗留） */
body .btn-primary {
  background: var(--brand-primary);
  border-color: var(--brand-primary);
  color: #fff;
}
body .btn-primary:hover {
  background: var(--brand-primary-dark);
  border-color: var(--brand-primary-dark);
  color: #fff;
}

/* 单据/订单/工单 ID 链接：暖棕
   - 推荐使用 .link-id（语义清晰）
   - 兼容 .link：v3.2 老页面 ID 列普遍用此类，统一翻为暖棕
   - body 前缀提升优先级，覆盖各页面内联 CSS 中 `.link { color: var(--func-blue) }` */
body .link-id,
body .link {
  color: var(--func-id-color);
  cursor: pointer;
  text-decoration: none;
}
body .link-id:hover,
body .link:hover {
  color: var(--func-id-hover);
  text-decoration: underline;
}

/* ============================================================
 * 扁平容器（v3.2.6 强制）
 * 主区域所有"白卡片"去除外部边框 + 外部阴影
 * 仅保留容器内部的分隔线（如 .panel-header 的下边线、表格 thead 边线）
 * ============================================================ */
body .filter-section,
body .table-wrapper,
body .panel,
body .kpi-card,
body .config-section,
body .form-body,
body .detail-section,
body .dashboard-card,
body .chart-card {
  box-shadow: none;
  border: none;
}
/* 表格滚动容器同样扁平化 */
body .table-dense {
  box-shadow: none;
  border: none;
}

/* ============================================================
 * 列表页密度（v3.2.8）
 * 目标：顶部导航、页签、筛选区、操作区保持紧凑，避免列表首屏被空白挤压。
 * ============================================================ */
body .content > .tabs,
body .tab-panel > .tabs {
  margin-bottom: 12px;
}
body .filter-section {
  padding: 22px 24px;
  margin-bottom: 16px;
}
body .filter-grid {
  gap: 28px 24px;
}
body .filter-actions {
  margin-top: 24px;
}
body .action-bar {
  margin-bottom: 16px;
}

body .filter-item {
  gap: 0;
}
body .filter-item label {
  display: none;
}
body .filter-item input,
body .filter-item select {
  height: 44px;
  padding: 0 12px;
  border-radius: var(--radius-sm);
  font-size: 16px;
}

/* ============================================================
 * 高密度表格 · 横向滚动 + 固定列（v3.2.8）
 * 用法：<div class="table-wrapper table-scroll-x">
 *         <table>
 *           <thead><tr>...<th class="col-action col-sticky-right">操作</th></tr></thead>
 *           ...
 *         </table>
 *       </div>
 * 说明：JS 会自动把 table 包入 .table-scroll-body；分页留在外层，不参与横向滚动。
 * ============================================================ */
body .table-wrapper.table-scroll-x {
  overflow: hidden;
}
body .table-wrapper.table-scroll-x .table-scroll-body {
  overflow-x: auto;
  overflow-y: hidden;
}
body .table-wrapper.table-scroll-x .table-scroll-body table {
  min-width: max-content;          /* 让内容撑开宽度，触发滚动 */
}
body .col-sticky-right {
  position: sticky;
  background: var(--bg-card);      /* 防止滚动时透出下层内容 */
  z-index: 4;
}
body .col-sticky-right {
  right: 0;
}
/* hover 行时固定列底色跟随，但 sticky 列要单独覆盖一次 */
body tr:hover .col-sticky-right {
  background: var(--func-blue-light);
}
body .col-action {
  overflow: visible;
}
body .col-action.action-cell-open,
body tr:hover .col-action.action-cell-open {
  z-index: 60;
}
/* 表头里的 sticky 固定列底色（th 用表头灰） */
body thead .col-sticky-right {
  background: var(--bg-table-header);
  z-index: 3;                       /* 高于 td */
}
/* sticky 列阴影：滚动时与正文有视觉分隔 */
body .col-sticky-right::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0; left: -8px;
  width: 8px;
  pointer-events: none;
  box-shadow: inset -8px 0 8px -8px rgba(0, 0, 0, 0.08);
}

body .pill,
body .status-tag,
body .status-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 3px 10px;
  border-radius: var(--radius-sm);
  font-size: 16px;
  line-height: 1.25;
  font-weight: 400;
  white-space: nowrap;
}

body .pill-muted,
body .pill-pending,
body .status-pending,
body .status-tag.disabled {
  background: #eef0f4;
  color: #6b7280;
}

/* 操作列文字链接：v3.2.4 改为品牌红，与主按钮、激活态形成统一"行动色"
   body 前缀提升优先级，覆盖各页面内联 CSS 中 `.row-link { color: var(--func-blue) }` */
body .row-link,
body .row-action,
body .action-link {
  color: var(--brand-primary);
  cursor: pointer;
  text-decoration: none;
  margin-right: var(--space-sm);
  font-size: var(--font-size-sm);
  white-space: nowrap;
}
body .row-link:hover,
body .row-action:hover,
body .action-link:hover {
  color: var(--brand-primary-dark);
  text-decoration: underline;
}
body .row-link:last-child,
body .row-action:last-child,
body .action-link:last-child {
  margin-right: 0;
}

/* ============================================================
 * 全局行操作规范（v3.2.9）
 * - 每行最多展示 4 个操作
 * - 超过 4 个时，第 4 个固定为“更多”，其余动作折叠进浮层
 * - 浮层挂到 body，避免被 table-scroll / sticky 列 / 下方行裁切
 * ============================================================ */
body .action-more {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  color: var(--brand-primary);
  background: var(--sidebar-active-bg);
  cursor: pointer;
  user-select: none;
}
body .action-more:hover,
body .action-more.is-open {
  color: var(--brand-primary-dark);
  text-decoration: none;
  background: #F8E8EC;
}
body .action-more-data {
  display: none !important;
}
body .action-more-popup {
  position: fixed;
  z-index: 10000;
  min-width: 128px;
  max-width: 220px;
  padding: 6px 0;
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
}
body .action-more-popup-item {
  display: block;
  width: 100%;
  padding: 8px 14px;
  color: var(--text-primary);
  font-size: var(--font-size-sm);
  line-height: 1.4;
  white-space: nowrap;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  background: transparent;
  border: 0;
}
body .action-more-popup-item:hover {
  background: var(--func-blue-light);
  color: var(--brand-primary);
  text-decoration: none;
}
body .action-more-popup-item.danger,
body .action-more-popup-item.danger-link {
  color: var(--error);
}
body .action-more-popup-item.danger:hover,
body .action-more-popup-item.danger-link:hover {
  background: var(--error-light);
  color: var(--error);
}

/* 分页激活态：品牌红（覆盖各页面 .pager a.active 内联蓝色） */
body .pager a.active,
body .pagination a.active,
body .pagination .page.active {
  background: var(--brand-primary);
  border-color: var(--brand-primary);
  color: #fff;
}
body .pager a:hover:not(.active),
body .pagination a:hover:not(.active) {
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}
