/* ── 本地图标字体（防止CDN加载失败） ── */
@font-face {
  font-family: 'tabler-icons';
  src: url('../fonts/tabler-icons.woff2') format('woff2'),
       url('../fonts/tabler-icons.woff') format('woff'),
       url('../fonts/tabler-icons.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f5f3;--surface:#fff;--border:#e8e7e3;--border2:#d0ceca;
  --text:#1a1a18;--text2:#6b6a66;--text3:#9b9a96;
  --blue:#185FA5;--blue-bg:#E6F1FB;--blue-t:#0C447C;
  --green:#0F6E56;--green-bg:#E1F5EE;--green-t:#085041;
  --amber:#854F0B;--amber-bg:#FAEEDA;--amber-t:#633806;
  --red:#A32D2D;--red-bg:#FCEBEB;--red-t:#791F1F;
  --purple:#534AB7;--purple-bg:#EEEDFE;--purple-t:#3C3489;
  --r:8px;--rl:12px;
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);font-size:14px;min-height:100vh}

/* ── 通用组件 ── */
.badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500;white-space:nowrap}
.bg{background:var(--green-bg);color:var(--green-t)}.ba{background:var(--amber-bg);color:var(--amber-t)}
.br{background:var(--red-bg);color:var(--red-t)}.bb{background:var(--blue-bg);color:var(--blue-t)}
.bp{background:var(--purple-bg);color:var(--purple-t)}.bx{background:#f1efe8;color:#5f5e5a}

.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r);border:0.5px solid var(--border2);background:var(--surface);color:var(--text);font-size:13px;cursor:pointer;font-family:inherit;white-space:nowrap;text-decoration:none}
.btn:hover{background:var(--bg)}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-t)}
.btn-danger{color:var(--red);border-color:transparent}
.btn-danger:hover{background:var(--red-bg)}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-ghost{border-color:transparent;background:transparent}
.btn-ghost:hover{background:var(--bg)}

.card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--rl);overflow:hidden;margin-bottom:14px}
.card-head{padding:12px 16px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg)}
.card-title{font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px}
.card-title i{font-size:15px;color:var(--text2)}
.card-body{padding:16px}

/* ── 顶栏 ── */
.topnav{background:var(--surface);border-bottom:0.5px solid var(--border);padding:0 24px;height:52px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.logo{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;text-decoration:none;color:var(--text)}
.logo i{color:var(--blue);font-size:20px}
.top-nav{display:flex}
.top-link{padding:0 16px;height:52px;display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;text-decoration:none}
.top-link:hover{color:var(--text)}
.top-link.on{color:var(--blue-t);border-bottom-color:var(--blue);font-weight:500}
.top-link i{font-size:16px}
.top-right{display:flex;align-items:center;gap:10px}
.user-chip{display:flex;align-items:center;gap:8px;padding:5px 12px;border:0.5px solid var(--border);border-radius:20px}
.user-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;flex-shrink:0}
.user-name{font-size:13px;font-weight:500}
.user-role-lbl{font-size:11px;color:var(--text3)}

/* ── 弹窗 ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;align-items:center;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border-radius:var(--rl);border:0.5px solid var(--border);width:100%;max-width:520px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.12)}
.modal-lg{max-width:680px}
.modal-head{padding:16px 20px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:500}
.modal-close{background:none;border:none;cursor:pointer;color:var(--text2);font-size:20px;padding:2px}
.modal-body{padding:20px;max-height:72vh;overflow-y:auto}
.modal-foot{padding:14px 20px;border-top:0.5px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* ── 表单 ── */
.mf{margin-bottom:14px}
.mf label{display:block;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:5px}
.mf input,.mf select,.mf textarea{width:100%;padding:9px 11px;border:0.5px solid var(--border2);border-radius:var(--r);font-size:13px;font-family:inherit;color:var(--text);background:var(--surface)}
.mf input:focus,.mf select:focus,.mf textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(24,95,165,.08)}
.mf textarea{resize:vertical;min-height:72px}
.mf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mf-sec{font-size:11px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin:16px 0 10px;padding-bottom:6px;border-bottom:0.5px solid var(--border)}

/* ── 文件槽 ── */
.file-slot{border:0.5px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:10px}
.file-slot:last-child{margin-bottom:0}
.slot-head{display:flex;align-items:center;gap:10px;padding:9px 14px;background:var(--bg);border-bottom:0.5px solid var(--border)}
.slot-icon{font-size:16px;flex-shrink:0}
.slot-name{flex:1;font-size:13px;font-weight:500}
.slot-required{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:500}
.slot-required.must{background:var(--red-bg);color:var(--red-t)}
.slot-required.opt{background:var(--bg);color:var(--text3);border:0.5px solid var(--border)}
.slot-status{font-size:11px}
.slot-body{padding:8px 14px;display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px;min-height:44px}

/* ── 已上传文件行 ── */
.file-row{display:inline-flex;align-items:flex-start;gap:10px;padding:8px 10px;background:var(--surface);border-radius:var(--r);border:0.5px solid var(--border);flex-shrink:0;max-width:340px}
.file-thumb{width:120px;height:120px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--border);display:flex;align-items:center;justify-content:center}
.file-thumb img{width:100%;height:100%;object-fit:cover}
.file-ico{font-size:16px;flex-shrink:0}
.file-meta{flex:1;min-width:0}
.file-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.file-sub{font-size:10px;color:var(--text3);margin-top:1px}
.file-dl{font-size:11px;color:var(--blue);cursor:pointer;padding:3px 6px;border-radius:var(--r);border:0.5px solid var(--border);background:var(--surface);text-decoration:none;display:inline-flex;align-items:center;gap:3px;white-space:nowrap;flex-shrink:0}
.file-dl:hover{background:var(--blue-bg)}
/* ── 文档图标卡片 ── */
.file-doc-icon{width:40px;height:40px;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;gap:1px}
.file-doc-icon i{font-size:18px}
.file-doc-icon span{font-size:8px;font-weight:600;letter-spacing:.02em}

/* ── 文件删除按钮 ── */
.file-del-btn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;padding:3px 5px;border-radius:var(--r);flex-shrink:0;transition:all .15s}
.file-del-btn:hover{color:var(--red);background:var(--red-bg)}


/* ── 上传按钮 ── */
.upload-btn{
  border:1.5px dashed var(--border2);border-radius:var(--r);
  padding:14px 0;cursor:pointer;transition:all .15s;position:relative;
  background:transparent;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:6px;font-size:12px;color:var(--text2);font-family:inherit;
  width:100%;text-align:center;
}
.upload-btn i{font-size:22px}
.upload-btn:hover,.upload-btn.drag-over{background:var(--blue-bg);border-color:var(--blue);color:var(--blue-t)}
.upload-btn:hover{border-color:var(--blue);background:var(--blue-bg);color:var(--blue-t)}
.upload-btn input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upload-btn i{font-size:14px}

/* ── 维度照片 ── */
.dim-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:900px){.dim-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.dim-grid{grid-template-columns:1fr}}

.dim-card{
  border:0.5px solid var(--border);border-radius:var(--r);
  overflow:hidden;background:var(--surface);
  display:flex;flex-direction:column;
}
.dim-card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;
  background:var(--bg);border-bottom:0.5px solid var(--border);
  flex-shrink:0;
}
.dim-card-name{font-size:13px;font-weight:500}
.dim-prog{font-size:11px;font-weight:500;white-space:nowrap}
.dim-prog.ok{color:var(--green-t)}.dim-prog.warn{color:var(--amber-t)}

/* 照片区域 */
.dim-photos{
  display:flex;flex-wrap:wrap;
  gap:6px;padding:10px;
  min-height:110px;
  align-content:flex-start;
}

/* 无照片时显示上传区域占满 */
.dim-photos:empty::before{display:none}

/* 照片格子 */
.dim-photo{
  width:90px;height:90px;
  background:var(--bg);border-radius:6px;
  border:0.5px solid var(--border);
  overflow:hidden;position:relative;flex-shrink:0;
  cursor:zoom-in;
}
.dim-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* 上传按钮：和照片同尺寸，排在照片后面 */
.dim-upload-btn{
  width:90px;height:90px;border-radius:6px;
  border:1.5px dashed var(--border2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;position:relative;background:transparent;
  transition:all .15s;flex-shrink:0;color:var(--text3);gap:5px;
}
.dim-upload-btn:hover{background:var(--blue-bg);border-color:var(--blue);color:var(--blue-t)}
.dim-upload-btn i{font-size:24px}
.dim-upload-btn span{font-size:11px;font-weight:500}
.dim-upload-btn input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.dim-upload-btn.drag-over{
  background:var(--blue-bg);border-color:var(--blue);
  color:var(--blue-t);transform:scale(1.03);
}

/* ── 节点导航 ── */
.det-left{background:var(--surface);border-right:0.5px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}
.det-order-info{padding:14px 16px;border-bottom:0.5px solid var(--border)}
.det-order-no{font-size:10px;font-family:monospace;color:var(--text3);margin-bottom:2px}
.det-order-name{font-size:13px;font-weight:500;margin-bottom:4px}
.det-order-meta{font-size:11px;color:var(--text2)}
.det-nav-label{font-size:10px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;padding:10px 16px 4px}
.det-nav-item{display:flex;align-items:center;gap:8px;padding:9px 16px;cursor:pointer;border-left:2px solid transparent;border-bottom:0.5px solid var(--border);transition:all .1s}
.det-nav-item:hover{background:var(--bg)}
.det-nav-item.on{background:var(--blue-bg);border-left-color:var(--blue)}
.det-nav-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.det-nav-name{flex:1;font-size:12px;color:var(--text)}
.det-nav-item.on .det-nav-name{color:var(--blue-t);font-weight:500}
.det-nav-badge{font-size:10px;padding:1px 6px;border-radius:8px;background:var(--bg);border:0.5px solid var(--border);color:var(--text3)}
.det-nav-item.on .det-nav-badge{background:rgba(24,95,165,.1);color:var(--blue-t);border-color:transparent}

/* ── 节点内容区 ── */
.node-header{background:var(--surface);border-bottom:0.5px solid var(--border);padding:16px 20px;display:flex;align-items:flex-start;justify-content:space-between}
.node-title{font-size:16px;font-weight:500;margin-bottom:4px}
.node-meta-txt{font-size:12px;color:var(--text2)}
.node-section{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--rl);margin:14px;overflow:hidden}
.ns-head{padding:11px 16px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg)}
.ns-title{font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px}
.ns-title i{font-size:15px;color:var(--text2)}
.ns-body{padding:14px 16px}

/* ── 表格 ── */
.data-table{width:100%;border-collapse:collapse}
.data-table th{font-size:11px;color:var(--text3);font-weight:500;padding:10px 16px;text-align:left;background:var(--bg);border-bottom:0.5px solid var(--border)}
.data-table td{padding:12px 16px;border-bottom:0.5px solid var(--border);font-size:13px;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:#fafaf8}

/* ── 角色标签 ── */
.role-tag{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:500}
.r-boss{background:#EEEDFE;color:#3C3489}
.r-follow{background:#E6F1FB;color:#0C447C}
.r-biz{background:#FAEEDA;color:#633806}
.r-finance{background:#E1F5EE;color:#085041}

/* ── 看板订单卡片 ── */
.order-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--rl);overflow:hidden;margin-bottom:8px;cursor:pointer;transition:all .15s}
.order-card:hover{border-color:var(--blue);box-shadow:0 2px 8px rgba(24,95,165,.08)}
.order-card.red{border-left:3px solid var(--red)}
.order-card.yellow{border-left:3px solid var(--amber)}
.order-card.green{border-left:3px solid var(--green)}
.oc-head{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:0.5px solid var(--border)}
.oc-no{font-size:10px;font-family:monospace;color:var(--text3);width:130px;flex-shrink:0}
.oc-name{font-size:14px;font-weight:500;flex:1}
.oc-deadline{font-size:12px;color:var(--text2);margin-right:4px}
.oc-body{display:grid;grid-template-columns:1fr 1fr 1fr 180px}
.oc-cell{padding:9px 16px;border-right:0.5px solid var(--border)}
.oc-cell:last-child{border-right:none}
.oc-lbl{font-size:10px;color:var(--text3);margin-bottom:3px;text-transform:uppercase;letter-spacing:.03em}
.oc-val{font-size:12px;color:var(--text)}
.oc-val.warn{color:var(--amber-t);font-weight:500}
.oc-val.danger{color:var(--red-t);font-weight:500}
.oc-val.ok{color:var(--green-t);font-weight:500}
.prog-row{display:flex;gap:3px;align-items:center;margin-top:4px}
.prog-dot{width:18px;height:6px;border-radius:3px;flex-shrink:0}
.prog-dot.done{background:var(--green)}
.prog-dot.active{background:var(--blue)}
.prog-dot.overdue{background:var(--red)}
.prog-dot.pending{background:var(--border)}
.alert-row{display:flex;align-items:center;gap:6px;padding:5px 16px;font-size:11px}
.alert-row.red-a{background:var(--red-bg);color:var(--red-t);border-top:0.5px solid #F7C1C1}
.alert-row.amber-a{background:var(--amber-bg);color:var(--amber-t);border-top:0.5px solid #FAC775}

/* ── 统计卡片 ── */
.stat-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--rl);padding:14px 18px}
.stat-num{font-size:24px;font-weight:500;margin-bottom:3px}
.stat-lbl{font-size:12px;color:var(--text2)}

/* ── 分页 ── */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px 0}
.page-btn{padding:5px 10px;border:0.5px solid var(--border2);border-radius:var(--r);background:var(--surface);color:var(--text2);cursor:pointer;font-size:12px;font-family:inherit}
.page-btn:hover{background:var(--bg)}
.page-btn.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.page-btn:disabled{opacity:.4;cursor:not-allowed}
.page-info{font-size:12px;color:var(--text3);padding:0 8px}

/* ── 空状态 ── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:var(--text3);gap:12px}
.empty-state i{font-size:40px}
.empty-state p{font-size:13px}

/* ── Toast ── */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(12px);background:#1a1a18;color:#fff;padding:10px 20px;border-radius:var(--r);font-size:13px;z-index:600;opacity:0;transition:all .2s;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 权限提示 ── */
.perm-notice{background:var(--amber-bg);border:0.5px solid #FAC775;border-radius:var(--r);padding:10px 14px;font-size:12px;color:var(--amber-t);display:flex;align-items:center;gap:6px;margin-bottom:16px}

:root {
  --sb-w: 220px;
  --sb-w-col: 56px;
}

/* ══════════════════════════════════════
   左侧抽屉导航 - 仿企业ERP树形菜单
══════════════════════════════════════ */

/* html/body 全屏flex布局 */
html { height: 100%; }
body.has-sidebar {
  display: flex;
  height: 100%;
  min-height: 100vh;
  overflow: hidden;
}

/* 侧栏 */
.sidebar {
  width: var(--sb-w);
  height: 100vh;
  background: #1c2336;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  position: relative;
  z-index: 200;
  transition: width .2s ease;
  overflow: hidden;
}
.sidebar.collapsed { width: var(--sb-w-col); }

/* Logo */
.sb-logo {
  display: flex; align-items: center; gap: 10px;
  padding: 0 14px; height: 52px; flex-shrink: 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
  cursor: pointer; text-decoration: none;
}
.sb-logo-icon { font-size: 20px; color: #4da3ff; flex-shrink: 0; }
.sb-logo-text {
  font-size: 13px; font-weight: 700; color: #fff;
  white-space: nowrap; overflow: hidden;
  transition: opacity .15s, width .2s;
}
.sidebar.collapsed .sb-logo-text { opacity: 0; width: 0; }

/* 折叠按钮 */
.sb-toggle {
  position: absolute; top: 14px; right: -11px;
  width: 22px; height: 22px;
  background: #2a3450; border: 1px solid rgba(255,255,255,.15);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: rgba(255,255,255,.7); font-size: 11px; z-index: 10;
  box-shadow: 0 2px 6px rgba(0,0,0,.3);
}
.sb-toggle:hover { background: #3a4a6a; color: #fff; }

/* 导航滚动区 */
.sb-nav { flex: 1; overflow-y: auto; overflow-x: hidden; }
.sb-nav::-webkit-scrollbar { width: 3px; }
.sb-nav::-webkit-scrollbar-track { background: transparent; }
.sb-nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 3px; }

/* 一级菜单项 */
.sb-item {
  display: flex; align-items: center; gap: 0;
  padding: 0 0 0 14px; height: 42px;
  cursor: pointer; color: rgba(255,255,255,.65);
  font-size: 13px; text-decoration: none;
  border-left: 3px solid transparent;
  transition: background .1s, color .1s;
  position: relative; white-space: nowrap; overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.sb-item:hover { background: rgba(255,255,255,.06); color: rgba(255,255,255,.9); }
.sb-item.on {
  background: rgba(77,163,255,.15);
  color: #4da3ff;
  border-left-color: #4da3ff;
}
.sb-item.open { background: rgba(255,255,255,.04); color: #fff; }

.sb-item-icon {
  font-size: 17px; flex-shrink: 0;
  width: 20px; text-align: center; margin-right: 10px;
}
.sb-item-label { flex: 1; font-size: 13px; overflow: hidden; text-overflow: ellipsis; }
.sb-item-arrow {
  font-size: 11px; flex-shrink: 0;
  width: 32px; text-align: center;
  transition: transform .2s;
}
.sb-item.open > .sb-item-arrow { transform: rotate(90deg); }

/* 折叠时隐藏文字 */
.sidebar.collapsed .sb-item-label,
.sidebar.collapsed .sb-item-arrow { display: none; }
.sidebar.collapsed .sb-item {
  padding: 0; justify-content: center;
  border-left: 3px solid transparent;
}
.sidebar.collapsed .sb-item-icon { margin: 0; }

/* 折叠时 tooltip */
.sidebar.collapsed .sb-item[data-label]:hover::after {
  content: attr(data-label);
  position: absolute; left: calc(var(--sb-w-col) + 8px); top: 50%;
  transform: translateY(-50%);
  background: #1c2336; color: #fff; font-size: 12px;
  padding: 5px 12px; border-radius: 6px; white-space: nowrap;
  z-index: 999; pointer-events: none;
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 4px 14px rgba(0,0,0,.35);
}

/* 子菜单 */
.sb-sub {
  overflow: hidden; max-height: 0;
  background: rgba(0,0,0,.2);
  transition: max-height .22s ease;
}
.sb-sub.open { max-height: 500px; }
.sidebar.collapsed .sb-sub { display: none; }

/* 二级菜单项 */
.sb-sub-item {
  display: flex; align-items: center; gap: 8px;
  padding: 0 12px 0 44px; height: 36px;
  cursor: pointer; color: rgba(255,255,255,.5);
  font-size: 12px; text-decoration: none;
  border-left: 3px solid transparent;
  transition: background .1s, color .1s;
  white-space: nowrap; overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.03);
}
.sb-sub-item:hover { background: rgba(255,255,255,.05); color: rgba(255,255,255,.85); }
.sb-sub-item.on { color: #4da3ff; background: rgba(77,163,255,.1); border-left-color: #4da3ff; }
.sb-sub-item i { font-size: 13px; flex-shrink: 0; opacity: .7; }

/* 底部用户 */
.sb-user {
  padding: 10px 12px; flex-shrink: 0;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex; align-items: center; gap: 8px;
  overflow: hidden;
}
.sb-user-avatar {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.sb-user-info { flex: 1; min-width: 0; overflow: hidden; transition: opacity .15s; }
.sidebar.collapsed .sb-user-info { opacity: 0; width: 0; }
.sb-user-name { font-size: 12px; font-weight: 500; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sb-user-role { font-size: 10px; color: rgba(255,255,255,.4); margin-top: 1px; }
.sb-logout {
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,.4); font-size: 15px; flex-shrink: 0; padding: 3px;
}
.sb-logout:hover { color: #fff; }

/* ══════════════════════════════════════
   主内容区
══════════════════════════════════════ */
.main-with-sidebar {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
  height: 100vh; overflow: hidden;
}

/* 精简顶栏 */
.topbar-slim {
  background: var(--surface); border-bottom: 0.5px solid var(--border);
  padding: 0 20px; height: 52px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: space-between;
  z-index: 100;
}
.topbar-title { font-size: 15px; font-weight: 500; }
.topbar-hamburger {
  display: none; background: none; border: none;
  cursor: pointer; font-size: 22px; color: var(--text); padding: 4px; margin-right: 4px;
}

/* 内容滚动区 */
.main-content-scroll {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  /* sticky需要这个容器可滚动 */
  position: relative;
}

/* ══════════════════════════════════════
   手机端
══════════════════════════════════════ */
@media (max-width: 768px) {
  .topbar-hamburger { display: flex; align-items: center; justify-content: center; }
  body.has-sidebar { display: block; height: auto; overflow: visible; }
  .sidebar {
    position: fixed; top: 0; left: 0; height: 100vh;
    transform: translateX(-100%);
    transition: transform .25s ease;
    width: var(--sb-w) !important;
    z-index: 300;
  }
  .sidebar.mobile-open { transform: translateX(0); }
  .main-with-sidebar { height: auto; min-height: 100vh; }
  .main-content-scroll { overflow: visible; height: auto; }
  .sidebar-mask {
    display: none; position: fixed; inset: 0;
    background: rgba(0,0,0,.5); z-index: 299;
  }
  .sidebar-mask.open { display: block; }
}

/* 隐藏旧版topnav */
body.has-sidebar .topnav { display: none; }
body.has-sidebar .top-nav { display: none; }

/* 维度上传拖拽 */
.dim-upload.drag-over{
  background:var(--blue-bg)!important;
  border-color:var(--blue)!important;
  transform:scale(1.02);
}

.node-section:last-child{margin-bottom:24px}

.approval-banner{margin:0}

.slot-actions{padding:0 14px 10px;}