*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#4f46e5;--primary-d:#4338ca;--ink:#0f172a;--ink-2:#475569;--ink-3:#94a3b8;
  --bg:#f1f5f9;--card:#fff;--line:#e6ebf2;--soft:#f8fafc;
  --ok:#10b981;--warn:#f59e0b;--info:#3b82f6;--danger:#ef4444;--purple:#7c3aed;
  --grad:linear-gradient(120deg,#4f46e5 0%,#6366f1 50%,#7c3aed 100%);
  --shadow:0 1px 3px rgba(15,23,42,.06),0 8px 24px -16px rgba(15,23,42,.2);
}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",Roboto,sans-serif;
  color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.6}
a{text-decoration:none;color:inherit}
[v-cloak]{display:none}

/* 登录 */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(900px 480px at 50% -10%,rgba(79,70,229,.14),transparent 60%),var(--bg)}
.login-card{width:390px;max-width:92vw;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:36px 32px;box-shadow:var(--shadow)}
.login-logo{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:800;margin-bottom:6px}
.login-logo .mk{width:38px;height:38px;border-radius:11px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:19px}
.login-sub{color:var(--ink-3);font-size:13px;margin-bottom:24px}
.login-tag{display:inline-block;font-size:12px;font-weight:700;color:var(--primary);background:rgba(79,70,229,.1);border-radius:6px;padding:3px 10px;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;color:var(--ink-2);margin-bottom:7px;font-weight:600}
.field input{width:100%;height:44px;padding:0 14px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:var(--soft);transition:.15s}
.field input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(79,70,229,.12)}
.login-err{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:9px;padding:9px 12px;font-size:13px;margin-bottom:16px}
.login-foot{margin-top:18px;text-align:center;font-size:12.5px;color:var(--ink-3)}
.login-foot a{color:var(--primary);cursor:pointer}

.btn{height:44px;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn-primary{width:100%;background:var(--grad);color:#fff;box-shadow:0 6px 16px -8px rgba(79,70,229,.6)}
.btn-primary:hover{filter:brightness(1.05)}.btn-primary:active{transform:translateY(1px)}

/* 布局 */
.layout{display:flex;min-height:100vh}
.side{width:230px;background:#fff;border-right:1px solid var(--line);position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;z-index:20}
.side-logo{display:flex;align-items:center;gap:9px;font-size:15.5px;font-weight:800;padding:20px;border-bottom:1px solid var(--line)}
.side-logo .mk{width:30px;height:30px;border-radius:8px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:15px}
.side-logo .tag{font-size:10px;font-weight:700;color:var(--ink-3);border:1px solid var(--line);border-radius:5px;padding:1px 6px}
.menu{flex:1;padding:14px 12px;overflow:auto}
.menu a{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:10px;color:var(--ink-2);font-weight:600;margin-bottom:4px;cursor:pointer}
.menu a:hover{background:var(--soft);color:var(--ink)}
.menu a.active{background:linear-gradient(120deg,rgba(79,70,229,.12),rgba(124,58,237,.1));color:var(--primary)}
.menu a .mtag{margin-left:auto;background:var(--warn);color:#fff;font-size:11px;font-weight:700;border-radius:99px;min-width:18px;height:18px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center}
.menu a.menu-cta{background:linear-gradient(120deg,var(--primary),#7c3aed);color:#fff;justify-content:center;margin-bottom:10px;box-shadow:0 4px 12px rgba(79,70,229,.28)}
.menu a.menu-cta:hover{filter:brightness(1.06);color:#fff}
.side-foot{padding:14px 16px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-3)}
.side-foot .u{color:var(--ink);font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:7px}
.side-foot a{color:var(--ink-3);cursor:pointer}.side-foot a:hover{color:var(--primary)}

.main{flex:1;margin-left:230px;display:flex;flex-direction:column;min-width:0}
.topbar{height:60px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 26px;position:sticky;top:0;z-index:10}
.topbar h2{font-size:17px;font-weight:750}
.content{padding:24px 26px;flex:1}

/* 统计卡 */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px;margin-bottom:22px}
.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow)}
.stat .n{font-size:25px;font-weight:850;line-height:1.1}
.stat .l{font-size:12.5px;color:var(--ink-3);margin-top:5px;font-weight:600}
/* 我的任务:高亮可点 */
.stats-mine{margin-bottom:8px}
.stats-mine .stat{cursor:pointer;border-width:2px;transition:transform .12s,box-shadow .12s,border-color .12s}
.stats-mine .stat:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 8px 20px rgba(79,70,229,.14)}
/* 全部需求:弱化为参考 */
.stats-team{margin-bottom:18px}
.stats-team .stat{background:var(--soft);box-shadow:none;padding:11px 14px}
.stats-team .stat .n{font-size:19px;color:var(--ink-2)!important}
.stats-team .stat .l{font-size:11.5px}
.c-total .n{color:var(--ink)}.c-pending .n{color:var(--warn)}.c-accepted .n{color:var(--info)}
.c-processing .n{color:var(--primary)}.c-delivered .n{color:var(--purple)}.c-completed .n{color:var(--ok)}
.c-today .n{color:var(--danger)}.c-supplement .n{color:#d97706}

/* 工具条 */
.toolbar{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;box-shadow:var(--shadow)}
.toolbar input,.toolbar select{height:38px;padding:0 12px;border:1px solid var(--line);border-radius:9px;font-size:13.5px;background:var(--soft)}
.toolbar input:focus,.toolbar select:focus{outline:none;border-color:var(--primary);background:#fff}
.toolbar .grow{flex:1;min-width:180px}
.btn-sm{height:38px;padding:0 16px;font-size:13.5px;border-radius:9px;border:none;cursor:pointer;font-weight:700}
.btn-solid{background:var(--grad);color:#fff}.btn-solid:hover{filter:brightness(1.05)}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink-2);cursor:pointer;height:38px;padding:0 14px;border-radius:9px;font-weight:600;font-size:13.5px}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.tabs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.tabs .tab{padding:7px 16px;border-radius:9px;background:#fff;border:1px solid var(--line);cursor:pointer;font-weight:600;font-size:13.5px;color:var(--ink-2)}
.tabs .tab.on{background:var(--grad);color:#fff;border-color:transparent}

/* 表格 */
.table-wrapper{background:#fff;border:1px solid var(--line);border-radius:14px;overflow-x:auto;overflow-y:hidden;box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;font-size:13.5px;min-width:760px}
thead th{text-align:left;padding:13px 14px;background:var(--soft);color:var(--ink-2);font-weight:700;border-bottom:1px solid var(--line);white-space:nowrap}
tbody td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fcfdff}
.mono{font-family:ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--ink-2)}
.ell{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.muted{color:var(--ink-3)}.lk{color:var(--primary);cursor:pointer;font-weight:600}.lk:hover{text-decoration:underline}.lk.danger{color:var(--danger)}
.row-acts{display:flex;gap:8px;white-space:nowrap}

.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:700;white-space:nowrap}
.badge .d{width:6px;height:6px;border-radius:50%}
.s-pending{background:#fffbeb;color:#b45309}.s-pending .d{background:var(--warn)}
.s-accepted{background:#eff6ff;color:#1d4ed8}.s-accepted .d{background:var(--info)}
.s-processing{background:#eef2ff;color:#4338ca}.s-processing .d{background:var(--primary)}
.s-testing{background:#ecfeff;color:#0e7490}.s-testing .d{background:#06b6d4}
.s-supplement{background:#fffbeb;color:#b45309}.s-supplement .d{background:#f59e0b}
.s-delivered{background:#f5f3ff;color:#6d28d9}.s-delivered .d{background:var(--purple)}
.s-completed{background:#ecfdf5;color:#047857}.s-completed .d{background:var(--ok)}
.s-rejected{background:#fef2f2;color:#b91c1c}.s-rejected .d{background:var(--danger)}
.s-closed{background:#f1f5f9;color:#64748b}.s-closed .d{background:var(--ink-3)}
.pri{font-weight:700}.pri-high{color:var(--danger)}.pri-normal{color:var(--ink-2)}.pri-low{color:var(--ink-3)}

.pager{display:flex;align-items:center;justify-content:space-between;margin-top:16px;color:var(--ink-3);font-size:13px}
.pager .pg{display:flex;gap:6px}
.pager button{height:32px;min-width:32px;padding:0 10px;border:1px solid var(--line);background:#fff;border-radius:8px;cursor:pointer;color:var(--ink-2);font-weight:600}
.pager button:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}
.pager button:disabled{opacity:.45;cursor:not-allowed}.pager button.cur{background:var(--grad);color:#fff;border-color:transparent}

/* 弹窗 */
.mask{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:flex-start;justify-content:center;padding:36px 16px;z-index:100;overflow:auto}
.modal{background:#fff;border-radius:16px;width:760px;max-width:96vw;box-shadow:0 24px 60px -20px rgba(15,23,42,.4);animation:pop .18s ease}
.modal.sm{width:440px}
@keyframes pop{from{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-h h3{font-size:16.5px;font-weight:750}
.modal-h .x{cursor:pointer;color:var(--ink-3);font-size:22px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:8px}
.modal-h .x:hover{background:var(--soft);color:var(--ink)}
.modal-b{padding:20px 22px;max-height:70vh;overflow:auto}
.modal-f{padding:14px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}

.kv{display:grid;grid-template-columns:92px 1fr;gap:9px 14px;font-size:13.5px;margin-bottom:16px}
.kv .k{color:var(--ink-3);font-weight:600}.kv .v{color:var(--ink);word-break:break-all}
/* 详情顶部状态条 */
.detail-bar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin:0 0 4px}
.detail-bar .who{margin-left:auto;font-size:12.5px;color:var(--ink-3)}
/* 详情流程进度条 */
.flow{display:flex;margin:12px 0 18px;padding:2px 2px}
.flow-step{flex:1;text-align:center;position:relative;min-width:46px}
.flow-step::before{content:"";position:absolute;top:13px;right:50%;width:100%;height:2px;background:#e5e9f0}
.flow-step:first-child::before{display:none}
.flow-step.reached::before{background:var(--ok)}
.flow-dot{position:relative;z-index:1;width:28px;height:28px;border-radius:50%;margin:0 auto;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;background:#eef2f7;color:#94a3b8;border:2px solid #e5e9f0}
.flow-step.done .flow-dot{background:var(--ok);color:#fff;border-color:var(--ok)}
.flow-step.active .flow-dot{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 0 0 4px rgba(79,70,229,.16)}
.flow-lbl{font-size:11.5px;margin-top:7px;color:var(--ink-3);font-weight:600;white-space:nowrap}
.flow-step.done .flow-lbl{color:var(--ok)}
.flow-step.active .flow-lbl{color:var(--primary);font-weight:800}
.flow-term{margin:10px 0 16px;padding:11px 14px;border-radius:10px;text-align:center;font-weight:700;font-size:13.5px}
.flow-term.rej{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}
.flow-term.cls{background:var(--soft);color:var(--ink-2);border:1px solid var(--line)}
.flow-note{margin:-8px 0 16px;text-align:center;font-size:12.5px;color:#b45309;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:7px 10px}
.sect-t{font-size:13px;font-weight:700;color:var(--ink-2);margin:18px 0 10px;padding-bottom:7px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.content-box{background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:12px 14px;white-space:pre-wrap;word-break:break-word;font-size:13.5px}
.content-box img{max-width:100%;border-radius:6px;margin:4px 0;display:block}
/* 富文本编辑器(contenteditable) */
.rt-editor{min-height:120px;max-height:340px;overflow:auto;padding:10px 12px;border:1px solid var(--line);border-radius:9px;background:var(--soft);font-size:13.5px;line-height:1.6;outline:none}
.rt-editor:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.rt-editor:empty:before{content:attr(data-ph);color:var(--ink-3)}
.rt-editor img{max-width:100%;border-radius:6px;margin:4px 0;display:block}

.fm label{display:block;font-size:12.5px;color:var(--ink-2);margin-bottom:6px;font-weight:600}
.fm input,.fm select,.fm textarea{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-size:13.5px;background:var(--soft);font-family:inherit}
.fm input:focus,.fm select:focus,.fm textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.fm textarea{min-height:90px;resize:vertical}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid .full{grid-column:1/-1}
.fm{margin-bottom:14px}

/* 时间线/评论 */
.timeline{position:relative;padding-left:18px}
.timeline::before{content:"";position:absolute;left:5px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;padding:0 0 16px 8px}
.tl-item::before{content:"";position:absolute;left:-16px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px rgba(79,70,229,.15)}
.tl-item.sys::before{background:var(--ink-3);box-shadow:0 0 0 3px rgba(148,163,184,.18)}
.tl-head{font-size:12.5px;color:var(--ink-3);margin-bottom:3px}
.tl-head b{color:var(--ink);font-weight:700}
.tl-body{font-size:13.5px;color:var(--ink);white-space:pre-wrap;word-break:break-word}
.tl-body.note{background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:8px 11px;margin-top:3px}

/* 子任务 */
.subtask{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:#fff}
.subtask .t{flex:1;font-size:13.5px}
.subtask.done .t{color:var(--ink-3);text-decoration:line-through}
.st-status{font-size:11.5px;padding:2px 9px;border-radius:99px;font-weight:700;cursor:pointer}
.st-todo{background:#f1f5f9;color:#64748b}.st-doing{background:#eef2ff;color:#4338ca}.st-done{background:#ecfdf5;color:#047857}

/* 附件/标签 */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:5px 10px;font-size:12.5px;cursor:pointer}
.chip:hover{border-color:var(--primary);color:var(--primary)}
.chip .rm{color:var(--ink-3);cursor:pointer}.chip .rm:hover{color:var(--danger)}
.people{display:flex;flex-wrap:wrap;gap:7px}
.person{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;color:#4338ca;border-radius:99px;padding:4px 11px;font-size:12.5px;font-weight:600}
.person .rm{cursor:pointer;opacity:.6}.person .rm:hover{opacity:1}

/* 智能工作台 */
.alert-strip{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:linear-gradient(120deg,#fff7ed,#fef2f2);border:1px solid #fecaca;border-radius:14px;padding:14px 18px;margin-bottom:18px;box-shadow:var(--shadow)}
.alert-strip .ai{font-size:22px}
.alert-strip .at{font-weight:700;color:#b45309;font-size:14px}
.alert-strip .pill-warn{background:#fff;border:1px solid #fed7aa;color:#c2410c;border-radius:99px;padding:4px 12px;font-size:12.5px;font-weight:700;cursor:pointer}
.alert-strip .pill-danger{background:#fff;border:1px solid #fecaca;color:#b91c1c;border-radius:99px;padding:4px 12px;font-size:12.5px;font-weight:700;cursor:pointer}
.alert-strip .pill-warn:hover,.alert-strip .pill-danger:hover{filter:brightness(.97)}

.wb-section{margin-bottom:22px}
.wb-title{font-size:14px;font-weight:750;color:var(--ink);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.wb-title .more{margin-left:auto;font-size:12.5px;color:var(--ink-3);font-weight:600;cursor:pointer}.wb-title .more:hover{color:var(--primary)}
.todo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.todo-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow);transition:.2s;border-left:4px solid var(--line)}
.todo-card.hot{border-left-color:var(--primary)}
.todo-card.hot.warn{border-left-color:var(--warn)}
.todo-card.hot.danger{border-left-color:var(--danger)}
.todo-card .th{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.todo-card .th .ico{font-size:18px}
.todo-card .th .nm{font-weight:700;font-size:14px}
.todo-card .th .ct{margin-left:auto;font-size:22px;font-weight:850;color:var(--primary)}
.todo-card.warn .th .ct{color:var(--warn)}.todo-card.danger .th .ct{color:var(--danger)}
.todo-card .empty-mini{color:var(--ink-3);font-size:13px;padding:6px 0}
.mini-item{display:flex;align-items:center;gap:8px;padding:7px 0;border-top:1px dashed var(--line);font-size:13px}
.mini-item:first-of-type{border-top:none}
.mini-item .mt{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}
.mini-item .mt:hover{color:var(--primary)}
.mini-item .qbtn{font-size:11.5px;padding:3px 10px;border-radius:7px;border:none;cursor:pointer;font-weight:700;background:var(--grad);color:#fff;white-space:nowrap}
.mini-item .qbtn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink-2)}
.mini-more{font-size:12px;color:var(--ink-3);padding-top:8px;cursor:pointer}.mini-more:hover{color:var(--primary)}

.charts{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.chart-box{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow)}
.chart-box .cbt{font-size:13.5px;font-weight:700;color:var(--ink-2);margin-bottom:6px}
.chart-canvas{width:100%;height:230px}
@media (max-width:820px){.charts{grid-template-columns:1fr}}

/* 列表内:超期标记/优先级条/子任务进度 */
.ov-flag{display:inline-block;font-size:11px;font-weight:700;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:1px 7px;margin-left:6px}
.urgent-flag{display:inline-block;font-size:11px;font-weight:800;color:#fff;background:linear-gradient(120deg,#ef4444,#dc2626);border-radius:6px;padding:1px 7px;margin-right:6px;box-shadow:0 1px 4px rgba(220,38,38,.35)}
.due-flag{display:inline-block;font-size:11px;font-weight:700;color:#c2410c;background:#fff7ed;border:1px solid #fed7aa;border-radius:6px;padding:1px 7px;margin-left:6px}
.pbar{width:46px;height:3px;border-radius:99px;display:inline-block;vertical-align:middle;margin-right:7px}
.pbar.high{background:var(--danger)}.pbar.normal{background:var(--info)}.pbar.low{background:var(--ink-3)}
.prog{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-3)}
.prog .track{width:60px;height:6px;border-radius:99px;background:var(--line);overflow:hidden}
.prog .fill{height:100%;background:var(--grad);border-radius:99px}

/* 通知铃铛 */
.topbar-right{display:flex;align-items:center;gap:14px}
.bell{position:relative;cursor:pointer;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;border:1px solid var(--line);background:#fff}
.bell:hover{border-color:var(--primary)}
.bell.ringing{border-color:var(--danger);background:#fef2f2;animation:bell-shake 1s ease-in-out infinite;transform-origin:50% 30%}
@keyframes bell-shake{0%,55%,100%{transform:rotate(0)}5%,25%,45%{transform:rotate(13deg)}15%,35%{transform:rotate(-13deg)}}
.bell-badge{position:absolute;top:-5px;right:-5px;min-width:17px;height:17px;padding:0 4px;border-radius:99px;background:var(--danger);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px #fff}
.notif-panel{position:absolute;right:0;top:46px;width:360px;max-width:88vw;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 50px -16px rgba(15,23,42,.35);z-index:60;overflow:hidden;animation:pop .15s ease}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px}
.notif-head .all{font-size:12.5px;color:var(--primary);cursor:pointer;font-weight:600}
.notif-list{max-height:420px;overflow:auto}
.notif-item{padding:12px 16px;border-bottom:1px solid var(--line);cursor:pointer;display:flex;gap:10px}
.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--soft)}
.notif-item.unread{background:#f5f7ff}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);margin-top:6px;flex:none}
.notif-item.read .notif-dot{background:var(--line)}
.notif-main{flex:1;min-width:0}
.notif-t{font-size:13.5px;font-weight:600;color:var(--ink)}
.notif-c{font-size:12.5px;color:var(--ink-2);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notif-time{font-size:11.5px;color:var(--ink-3);margin-top:3px}

.empty{text-align:center;padding:54px 20px;color:var(--ink-3)}.empty .ic{font-size:38px;margin-bottom:10px}
.toast{position:fixed;top:18px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 20px;border-radius:10px;font-size:14px;z-index:200;box-shadow:0 10px 30px -10px rgba(0,0,0,.5)}
.toast.ok{background:#0f766e}.toast.err{background:#b91c1c}

@media (max-width:900px){.side{transform:translateX(-100%)}.main{margin-left:0}}

/* ===== 暗黑模式 ===== */
html.dark{
  --ink:#e6ebf3;--ink-2:#a7b4c8;--ink-3:#76869f;
  --bg:#0e1626;--card:#1a2536;--line:#2b3a52;--soft:#141d2e;
  --shadow:0 1px 3px rgba(0,0,0,.5),0 8px 24px -16px rgba(0,0,0,.7);
}
html.dark .side,html.dark .topbar,html.dark .stat,html.dark .toolbar,html.dark .table-wrapper,
html.dark .modal,html.dark .subtask,html.dark .bell,html.dark .notif-panel,html.dark .todo-card,
html.dark .chart-box,html.dark .btn-ghost,html.dark .tabs .tab,html.dark .pager button,
html.dark .mini-item .qbtn.ghost{background:var(--card)}
html.dark thead th{background:var(--soft)}
html.dark tbody tr:hover{background:#223149}
html.dark .field input:focus,html.dark .toolbar input:focus,html.dark .toolbar select:focus,
html.dark .fm input:focus,html.dark .fm select:focus,html.dark .fm textarea:focus,html.dark .rt-editor:focus{background:var(--soft)}
html.dark .notif-item.unread{background:#1c2740}
html.dark .notif-item:hover,html.dark .modal-h .x:hover,html.dark .menu a:hover{background:var(--soft)}
html.dark .bell-badge{box-shadow:0 0 0 2px var(--card)}
html.dark .modal{box-shadow:0 24px 60px -20px rgba(0,0,0,.8)}
html.dark .flow-dot{background:#243049;color:#76869f;border-color:#334155}
html.dark .flow-step::before{background:#334155}
/* 状态徽标深色化 */
html.dark .s-pending,html.dark .s-supplement{background:rgba(245,158,11,.15);color:#fcd34d}
html.dark .s-accepted{background:rgba(59,130,246,.16);color:#93c5fd}
html.dark .s-processing,html.dark .st-doing{background:rgba(99,102,241,.2);color:#a5b4fc}
html.dark .s-testing{background:rgba(6,182,212,.16);color:#67e8f9}
html.dark .s-delivered{background:rgba(124,58,237,.2);color:#c4b5fd}
html.dark .s-completed,html.dark .st-done{background:rgba(16,185,129,.16);color:#6ee7b7}
html.dark .s-rejected{background:rgba(239,68,68,.16);color:#fca5a5}
html.dark .s-closed,html.dark .st-todo{background:rgba(148,163,184,.16);color:#cbd5e1}
html.dark .person{background:rgba(99,102,241,.2);color:#c7d2fe}
html.dark .notif-item.read .notif-dot{background:#334155}
html.dark .prog .track{background:#2b3a52}
/* 浅色提示块深色化 */
html.dark .login-err,html.dark .flow-term.rej{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.35);color:#fca5a5}
html.dark .flow-note{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.35);color:#fcd34d}
html.dark .alert-strip{background:linear-gradient(120deg,#251a12,#251316);border-color:rgba(239,68,68,.3)}
html.dark .quote-bar{background:#1a2536!important;color:#a7b4c8!important;border-color:#2b3a52!important}
/* 主题切换按钮 */
.theme-toggle{cursor:pointer;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;border:1px solid var(--line);background:#fff}
html.dark .theme-toggle{background:var(--card)}
.theme-toggle:hover{border-color:var(--primary)}
