:root{
  --bg:#f7f8fa; --card:#fff; --line:#e3e4e8; --text:#0a0a0b; --muted:#8b909a;
  --brand:#0a0a0b; --brand-d:#26262b; --ok:#1aa260; --warn:#e8a93b; --risk:#e35d5d;
  --accent:#f1f1f3;
  --shadow:0 1px 3px rgba(15,20,40,.05),0 6px 16px rgba(15,20,40,.04);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:14px}
a{color:var(--brand);text-decoration:none}
.hidden{display:none!important}

/* ===== 登录 —— 近黑面板 + 白色表单（与 ERP 一致） ===== */
.login-wrap{min-height:100vh;display:flex;background:#fff}
/* 左侧深色品牌面板 */
.login-aside{position:relative;width:44%;background:#0a0a0b;color:#fff;padding:40px 46px;display:flex;flex-direction:column;overflow:hidden}
.login-aside::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(620px 460px at 72% 26%,rgba(32,96,68,.42),transparent 62%),
            radial-gradient(520px 520px at 24% 96%,rgba(18,38,32,.55),transparent 60%)}
.login-aside>*{position:relative;z-index:1}
.la-badge{width:48px;height:48px;border-radius:13px;background:#16161a;border:1px solid #2a2a30;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;letter-spacing:.5px}
.la-text{margin-top:auto;margin-bottom:7vh}
.la-text h2{font-size:38px;font-weight:800;margin:0 0 12px;letter-spacing:-.6px}
.la-text p{font-size:20px;color:#8b909a;margin:0;font-weight:400;line-height:1.5}

/* 右侧表单 */
.login-main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 32px;background:#fcfcfd}
.login-form{width:100%;max-width:380px}
.login-form h1{font-size:30px;font-weight:800;color:#0a0a0b;margin:0 0 8px;letter-spacing:-.5px}
.lf-sub{color:#8b909a;font-size:15px;margin:0 0 30px}
.fld-cap{display:block;font-size:13px;font-weight:600;color:#3a3a42;margin:0 0 8px}
.fld-cap i{color:#ef4444;font-style:normal}
.fld{display:flex;align-items:center;gap:10px;height:50px;border:1px solid #e3e4e8;border-radius:11px;padding:0 14px;background:#fff;margin-bottom:18px;transition:.15s}
.fld:focus-within{border-color:#0a0a0b;box-shadow:0 0 0 3px rgba(10,10,11,.08)}
.fld svg{flex:0 0 18px;color:#9aa0aa}
.fld input{flex:1;width:100%;min-width:0;border:none;background:none;outline:none;font-size:15px;color:#0a0a0b;padding:0}
.eye{border:none;background:none;color:#9aa0aa;display:flex;align-items:center;cursor:pointer;padding:4px;margin-right:-4px}
.eye:hover{color:#3a3a42}
.eye.on{color:#0a0a0b}
.lf-help{font-size:13px;color:#8b909a;margin:-8px 0 20px}
.lf-remember{display:flex;align-items:center;gap:9px;font-size:14px;color:#3a3a42;margin-bottom:22px;cursor:pointer;user-select:none}
.lf-remember input{width:17px;height:17px;accent-color:#2f6df6;cursor:pointer}
#loginBtn{width:100%;height:50px;border:none;border-radius:11px;font-size:15px;font-weight:700;color:#fff;cursor:pointer;background:#0a0a0b;transition:.15s}
#loginBtn:hover{background:#26262b}
#loginBtn:active{transform:translateY(1px)}
.err{color:#ef4444;font-size:13px;text-align:left}
.err:not(:empty){background:#fef2f2;border:1px solid #fee2e2;border-radius:10px;padding:10px 13px;margin-bottom:18px}

@media (max-width:820px){
  .login-aside{display:none}
  .login-main{background:#fff;padding:40px 26px}
  .fld input{font-size:16px}   /* iOS 防缩放 */
}

/* 顶栏 */
.topbar{height:56px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;
  padding:0 20px;gap:18px;position:sticky;top:0;z-index:20}
.topbar .logo{font-weight:700;font-size:16px;color:var(--brand)}
.tabs{display:flex;gap:4px;margin-left:6px}
.tab{padding:7px 16px;border-radius:8px;color:var(--muted);font-weight:600;border:none;background:none}
.tab.active{background:var(--accent);color:var(--brand)}
.topbar .spacer{flex:1}
.who{color:var(--muted);font-size:13px}
.btn{padding:8px 14px;border-radius:8px;border:1px solid var(--line);background:#fff;font-weight:600;color:var(--text)}
.btn:hover{border-color:#c2c6cf}
.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn.primary:hover{background:var(--brand-d)}
.btn.sm{padding:5px 10px;font-size:13px}
.btn.ghost{border:none;background:none;color:var(--muted)}

/* 主体 */
.main{max-width:1180px;margin:0 auto;padding:22px 20px 60px}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.toolbar input[type=search],.toolbar select{padding:8px 11px;border:1px solid var(--line);border-radius:8px;background:#fff}
.toolbar .spacer{flex:1}
.stat{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.stat .chip{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 16px;box-shadow:var(--shadow)}
.stat .chip b{font-size:20px;display:block}
.stat .chip span{color:var(--muted);font-size:12px}

/* 卡片网格 */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.pcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;box-shadow:var(--shadow);cursor:pointer;transition:.12s}
.pcard:hover{transform:translateY(-2px);border-color:#cfd2d8;box-shadow:0 6px 22px rgba(15,20,40,.09)}
.pcard .row1{display:flex;align-items:flex-start;gap:8px}
.pcard h3{margin:0;font-size:15px;flex:1}
.pcard .code{color:var(--muted);font-size:12px;font-weight:600}
.pcard .loc{color:var(--muted);font-size:12px;margin:3px 0 10px}
.bar{height:7px;background:#ececf0;border-radius:6px;overflow:hidden;margin:8px 0}
.bar>i{display:block;height:100%;background:var(--brand);border-radius:6px}
.pcard .meta{display:flex;justify-content:space-between;align-items:center;margin-top:4px}
.stage-pill{font-size:12px;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--accent);color:var(--brand)}
.owners{display:flex;gap:4px;flex-wrap:wrap;margin-top:10px}
.ava{width:26px;height:26px;border-radius:50%;background:#1a1a1f;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:600}
.pcard .last{margin-top:10px;font-size:12px;color:var(--muted);background:#f6f7f9;border-radius:8px;padding:7px 9px;border-left:3px solid #0a0a0b;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tag{font-size:11px;padding:2px 8px;border-radius:6px;font-weight:600}
.tag.ok{background:#e6f6ee;color:var(--ok)} .tag.warn{background:#fdf3e1;color:var(--warn)}
.tag.risk{background:#fde8e8;color:var(--risk)} .tag.norm{background:#ececf0;color:var(--muted)}
.prio{font-size:11px;padding:2px 9px;border-radius:20px;font-weight:700;display:inline-flex;align-items:center;gap:4px}
.prio::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.prio.risk{background:#fde8e8;color:var(--risk)} .prio.warn{background:#fdf3e1;color:var(--warn)} .prio.norm{background:#eef0f3;color:var(--muted)}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--ok,#1faa59);box-shadow:0 0 0 0 rgba(31,170,89,.5);animation:livePulse 2s infinite;flex:0 0 auto}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(31,170,89,.45)}70%{box-shadow:0 0 0 6px rgba(31,170,89,0)}100%{box-shadow:0 0 0 0 rgba(31,170,89,0)}}
.empty{text-align:center;color:var(--muted);padding:60px 0}

/* 抽屉/弹窗 */
.overlay{position:fixed;inset:0;background:rgba(20,28,50,.45);z-index:40;display:flex;justify-content:flex-end}
.drawer{width:620px;max-width:94vw;background:var(--bg);height:100%;overflow-y:auto;box-shadow:-8px 0 40px rgba(0,0,0,.2)}
.dhead{background:#fff;padding:18px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.dhead .x{float:right;font-size:22px;border:none;background:none;color:var(--muted)}
.dhead h2{margin:0 0 4px;font-size:18px}
.dbody{padding:18px 22px}
.section{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:14px;box-shadow:var(--shadow)}
.section h4{margin:0 0 12px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.field{display:flex;gap:10px;margin-bottom:9px;align-items:flex-start}
.field label{width:92px;color:var(--muted);font-size:13px;padding-top:7px;flex-shrink:0}
.field .val{flex:1}
.field input,.field select,.field textarea{width:100%;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text)}
.field textarea{resize:vertical;min-height:54px}
.field input:focus,.field select:focus,.field textarea:focus,
.toolbar input:focus,.toolbar select:focus{outline:none;border-color:#0a0a0b;box-shadow:0 0 0 3px rgba(10,10,11,.07)}

/* 阶段进度条 stepper */
.stepper{display:flex;gap:0;margin:6px 0 4px;flex-wrap:wrap}
.step{flex:1;min-width:74px;text-align:center;position:relative;padding-top:22px;cursor:pointer}
.step::before{content:"";position:absolute;top:7px;left:0;right:0;height:3px;background:var(--line)}
.step:first-child::before{left:50%} .step:last-child::before{right:50%}
.step .dot{position:absolute;top:0;left:50%;transform:translateX(-50%);width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--line)}
.step.done::before{background:var(--brand)} .step.done .dot{border-color:var(--brand);background:var(--brand)}
.step.cur .dot{border-color:var(--brand);box-shadow:0 0 0 4px #e3e3e7}
.step span{font-size:11px;color:var(--muted);display:block;line-height:1.3}
.step.done span,.step.cur span{color:var(--text);font-weight:600}

/* 记录时间线 */
.add-rec textarea{width:100%;padding:10px;border:1px solid var(--line);border-radius:9px;min-height:60px;resize:vertical}
.add-rec .row{display:flex;gap:8px;margin-top:8px;align-items:center}
.timeline{margin-top:6px}
.tl-item{display:flex;gap:10px;padding:11px 0;border-top:1px solid var(--line)}
.tl-item:first-child{border-top:none}
.tl-dot{width:9px;height:9px;border-radius:50%;background:var(--brand);margin-top:6px;flex-shrink:0}
.tl-body{flex:1}
.tl-body .who{font-weight:600;color:var(--text);font-size:13px}
.tl-body .when{color:var(--muted);font-size:12px;margin-left:8px}
.tl-body .txt{margin-top:3px;white-space:pre-wrap;line-height:1.5}
.tl-body .badge{font-size:11px;background:var(--accent);color:var(--brand);padding:1px 7px;border-radius:5px;margin-left:6px}
.hist .txt{color:var(--muted);font-size:13px}
.hist .tl-dot{background:#b9c0d4}

/* modal 居中 */
.modal{position:fixed;inset:0;background:rgba(20,28,50,.45);z-index:50;display:flex;align-items:center;justify-content:center}
.modal .box{background:#fff;border-radius:14px;padding:24px;width:440px;max-width:94vw;max-height:90vh;overflow:auto}
.modal h3{margin:0 0 16px}
.modal .field label{width:80px}
.modal .actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.chk{display:inline-flex;align-items:center;gap:6px;margin:3px 8px 3px 0;padding:5px 10px;border:1px solid var(--line);border-radius:8px;cursor:pointer}
.chk input{margin:0}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1f2533;color:#fff;padding:10px 18px;border-radius:8px;z-index:99;opacity:0;transition:.2s}
.toast.show{opacity:1}

/* ============ 手机端优化 ============ */
@media (max-width:640px){
  body{font-size:15px}
  .main{padding:14px 12px 60px}
  .topbar{padding:0 12px;gap:8px;height:52px}
  .topbar .logo{font-size:15px}
  .tabs{margin-left:0}
  .tab{padding:6px 12px;font-size:14px}
  .who{display:none}                         /* 隐藏过长的邮箱，腾出空间 */
  .btn.sm{padding:7px 11px}
  .grid{grid-template-columns:1fr;gap:11px}
  .stat .chip{flex:1;text-align:center;padding:10px 8px}
  .stat .chip b{font-size:18px}
  .toolbar{gap:8px}
  .toolbar input[type=search]{flex:1 1 100%;min-width:0}
  .toolbar select{flex:1}
  .toolbar .spacer{display:none}
  .toolbar #btnNew,.btn.primary{flex:1 1 100%}
  /* 抽屉全屏 */
  .overlay{justify-content:stretch}
  .drawer{width:100%;max-width:100%}
  .dhead{padding:16px 16px}
  .dbody{padding:14px 14px}
  .section{padding:14px}
  /* 字段竖排，更好点按 */
  .field{flex-direction:column;gap:4px;margin-bottom:13px}
  .field label{width:auto;padding-top:0;font-size:13px;font-weight:600}
  /* 防止 iOS 聚焦时自动放大（输入需 ≥16px） */
  .field input,.field select,.field textarea,.add-rec textarea,
  .modal input,.login-card input{font-size:16px}
  /* 阶段条改横向滑动，不挤压 */
  .stepper{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
  .step{min-width:72px;flex:0 0 auto}
  /* 弹窗 */
  .modal .box{width:94vw;padding:18px;max-height:88vh}
  .modal .field label{width:auto}
  .chk{font-size:14px;padding:7px 12px}
}

/* ===================== 新布局：侧边栏 + 视图 ===================== */
#app{display:flex;min-height:100vh}
.sidebar{width:232px;flex:0 0 232px;background:#0c0c0e;color:#e6e7ea;display:flex;flex-direction:column;
  padding:18px 14px;position:sticky;top:0;height:100vh}
.sb-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:16px;padding:6px 8px 20px}
.sb-badge{width:30px;height:30px;border-radius:9px;background:#16161a;border:1px solid #2a2a30;
  display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff}
.sb-nav{display:flex;flex-direction:column;gap:3px;flex:1}
.sb-nav .nav{display:flex;align-items:center;gap:11px;padding:10px 12px;border:none;background:none;color:#9a9ba2;
  font-weight:600;font-size:14px;border-radius:9px;text-align:left;width:100%;cursor:pointer;transition:.12s}
.sb-nav .nav:hover{background:#1a1a1e;color:#fff}
.sb-nav .nav.active{background:#1f1f24;color:#fff}
.sb-nav .nav svg{width:18px;height:18px;flex:0 0 18px;opacity:.9}
.sb-foot{border-top:1px solid #1f1f24;padding-top:14px;display:flex;align-items:center;gap:8px}
.sb-user{display:flex;align-items:center;gap:9px;flex:1;min-width:0}
.sb-uname{font-size:13px;color:#cfd0d4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-foot .ava{flex:0 0 28px;width:28px;height:28px}
.sb-foot .btn{color:#cfd0d4;border-color:#2a2a30;background:transparent}
.sb-foot .btn:hover{color:#fff;border-color:#3a3a42}

.content{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg)}
.vhead{display:flex;align-items:center;gap:14px;padding:18px 26px;background:#fff;border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:10;flex-wrap:wrap}
.vhead h1{font-size:20px;font-weight:800;margin:0;letter-spacing:-.3px}
.vhead .sub{color:var(--muted);font-size:13px;margin-top:3px}
.vhead .spacer{flex:1}
.vbody{padding:22px 26px 70px}

/* 分段切换 */
.seg{display:inline-flex;background:#eef0f3;border-radius:9px;padding:3px;gap:2px}
.seg button{border:none;background:none;padding:6px 14px;border-radius:7px;font-weight:600;font-size:13px;color:var(--muted);cursor:pointer}
.seg button.on{background:#fff;color:var(--text);box-shadow:0 1px 2px rgba(0,0,0,.1)}
.tbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.tbar input[type=search],.tbar select{padding:8px 11px;border:1px solid var(--line);border-radius:8px;background:#fff}
.tbar .spacer{flex:1}

/* 概览 */
.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(178px,1fr));gap:14px;margin-bottom:20px}
.dstat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:17px 19px;box-shadow:var(--shadow)}
.dstat .k{color:var(--muted);font-size:13px;display:flex;align-items:center;gap:7px}
.dstat .v{font-size:29px;font-weight:800;margin-top:8px;letter-spacing:-.6px}
.dstat .v small{font-size:13px;color:var(--muted);font-weight:600;letter-spacing:0}
.dash-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:18px}
.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow)}
.panel h3{margin:0 0 4px;font-size:15px;font-weight:700}
.panel .ph-sub{color:var(--muted);font-size:12px;margin-bottom:14px}
.funnel{display:flex;flex-direction:column;gap:10px}
.frow{display:flex;align-items:center;gap:11px;font-size:13px}
.frow .fl{width:80px;color:var(--muted);flex-shrink:0}
.frow .fb{flex:1;height:22px;background:#eef0f3;border-radius:6px;overflow:hidden}
.frow .fb>i{display:block;height:100%;background:#0a0a0b;border-radius:6px;min-width:3px;transition:width .3s}
.frow .fn{width:22px;text-align:right;font-weight:700}
.feed{display:flex;flex-direction:column}
.fi{display:flex;gap:11px;padding:11px 0;border-top:1px solid var(--line);align-items:flex-start}
.fi:first-child{border-top:none}
.fi .fmeta{flex:1;min-width:0}
.fi .ft{font-size:13px}
.fi .ft b{font-weight:700}
.fi .fw{color:var(--muted);font-size:12px;margin-top:2px}
.mine .fi .ft{display:flex;justify-content:space-between;gap:8px}

/* 看板 Kanban */
.board{display:flex;gap:14px;overflow-x:auto;padding-bottom:12px;align-items:flex-start}
.col{flex:0 0 272px;background:#eef0f3;border-radius:12px;padding:10px;min-height:140px}
.col.drag-over{background:#e2e4ea;outline:2px dashed #b7bcc8;outline-offset:-3px}
.col-head{display:flex;align-items:center;gap:8px;padding:5px 6px 11px;font-weight:700;font-size:13px}
.col-head .dot{width:8px;height:8px;border-radius:50%;background:#0a0a0b}
.col-head .cn{margin-left:auto;background:#fff;border:1px solid var(--line);border-radius:20px;padding:1px 9px;font-size:12px;color:var(--muted)}
.kcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 13px;margin-bottom:9px;cursor:pointer;
  box-shadow:0 1px 2px rgba(15,20,40,.05);transition:.1s}
.kcard:hover{border-color:#cfd2d8;box-shadow:0 5px 16px rgba(15,20,40,.1);transform:translateY(-1px)}
.kcard.dragging{opacity:.45}
.kcard h4{margin:0;font-size:14px;font-weight:700;display:flex;justify-content:space-between;align-items:flex-start;gap:6px}
.kcard .kcode{color:var(--muted);font-size:11px;font-weight:600;flex-shrink:0}
.kcard .kloc{color:var(--muted);font-size:12px;margin:3px 0 9px}
.kcard .krow{display:flex;align-items:center;justify-content:space-between;margin-top:9px;gap:6px}
.kcard .klast{font-size:12px;color:var(--muted);background:#f6f7f9;border-radius:7px;padding:6px 8px;margin-top:9px;
  border-left:3px solid #0a0a0b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Excel 表格 */
.xwrap{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:auto;box-shadow:var(--shadow)}
table.xtable{border-collapse:collapse;width:100%;font-size:13px;min-width:820px}
.xtable th{background:#f7f8fa;text-align:left;padding:10px 13px;font-weight:700;color:#3a3a42;border-bottom:1px solid var(--line);
  border-right:1px solid #eef0f3;position:sticky;top:0;white-space:nowrap;z-index:1}
.xtable td{padding:9px 13px;border-bottom:1px solid #eef0f3;border-right:1px solid #f3f4f6;white-space:nowrap;color:var(--text)}
.xtable tbody tr{cursor:pointer}
.xtable tbody tr:hover td{background:#fafbfc}
.xtable .mbar{width:60px;height:6px;background:#ececf0;border-radius:4px;display:inline-block;vertical-align:middle;overflow:hidden;margin-right:7px}
.xtable .mbar>i{display:block;height:100%;background:#0a0a0b}
.xtable .ava{display:inline-flex;margin-right:-6px;border:2px solid #fff}

@media (max-width:760px){
  #app{flex-direction:column}
  .sidebar{width:100%;flex:none;height:auto;position:sticky;top:0;z-index:30;flex-direction:row;align-items:center;padding:10px 14px;gap:10px}
  .sb-brand{padding:0;font-size:15px}
  .sb-nav{flex-direction:row;flex:1;overflow-x:auto;gap:2px}
  .sb-nav .nav{padding:8px 11px;white-space:nowrap}
  .sb-nav .nav span.lbl{display:none}
  .sb-foot{border-top:none;padding-top:0}
  .sb-user{display:none}
  .vhead{padding:14px 16px}
  .vbody{padding:16px 14px 60px}
  .dash-grid{grid-template-columns:1fr}
}

/* Excel 表格增强：排序 / 冻结首列 / 内联编辑 */
.xtable th[data-sort]{cursor:pointer;user-select:none}
.xtable th[data-sort]:hover{color:#0a0a0b}
.xtable td.ed{cursor:cell}
.xtable td.ed:hover{box-shadow:inset 0 0 0 1.5px #0a0a0b;background:#fbfbfd}
.xtable th.stick,.xtable td.stick{position:sticky;left:0;z-index:2}
.xtable td.stick{background:#fff;box-shadow:1px 0 0 #eef0f3}
.xtable th.stick{background:#f7f8fa;z-index:3}
.xtable tbody tr:hover td{background:#fafbfc}
.xtable tbody tr:hover td.stick{background:#fafbfc}
.cell-ed{width:100%;min-width:80px;border:1.5px solid #0a0a0b;border-radius:6px;padding:5px 7px;font-size:13px;outline:none;background:#fff;color:#0a0a0b}
.xtip{color:var(--muted);font-size:12px;margin-top:10px;padding-left:2px}
/* 看板停滞提醒 */
.kcard.is-stale{border-color:#f3c6c6;box-shadow:0 0 0 1px #f6d5d5}
.stale{color:var(--risk);font-size:11px;font-weight:600;margin-top:8px}

/* 表格分组行 + 过滤芯片激活态 */
.xtable tr.grp td{background:#f0f1f4;font-weight:700;color:#3a3a42;padding:8px 13px;border-top:1px solid var(--line);position:sticky;left:0}
.chiptog.on{background:#0a0a0b;color:#fff;border-color:#0a0a0b}

/* ===== 概览：图例 / 本周 / 月历 ===== */
.cal-legend{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.cal-leg{display:flex;align-items:center;gap:7px;padding:6px 12px;border:1px solid var(--line);border-radius:20px;font-size:13px;cursor:pointer;background:#fff;font-weight:600}
.cal-leg:hover{border-color:#c2c6cf}
.cal-leg.on{background:#0a0a0b;color:#fff;border-color:#0a0a0b}
.cal-leg .ld{width:9px;height:9px;border-radius:50%}
.cal-leg b{opacity:.7;font-weight:700}

.wk-title{font-weight:700;font-size:14px;margin:4px 0 12px}
.wk-list{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.wk-day,.wk-over,.wk-nodate{background:#fff;padding:11px 14px;display:flex;gap:14px;align-items:flex-start}
.wk-over{background:#fff5f5} .wk-nodate{background:#fafbfc}
.wk-over,.wk-nodate{border:1px solid var(--line);border-radius:12px;margin-bottom:12px}
.wk-day.today{background:#f6f7ff}
.wk-dlabel{width:96px;flex:0 0 96px;font-weight:700;font-size:13px;color:#3a3a42;display:flex;flex-direction:column;gap:2px}
.wk-dlabel span{color:var(--muted);font-weight:600;font-size:12px}
.wk-dlabel em{font-style:normal;color:#0a0a0b;background:#e8f0ff;border-radius:5px;padding:0 6px;font-size:11px;width:fit-content}
.wk-dlabel.risk{color:var(--risk)}
.wk-items{flex:1;display:flex;flex-wrap:wrap;gap:8px;min-width:0}
.wk-none{color:#c4c9d4;font-size:13px}
.ov-chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-left:3px solid #888;border-radius:9px;padding:6px 10px;font-size:13px;cursor:pointer;max-width:100%}
.ov-chip:hover{box-shadow:0 3px 10px rgba(15,20,40,.1)}
.ov-chip.od{background:#fff5f5;border-color:#f3c6c6}
.ov-chip .oc-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.ov-chip .ava{width:22px;height:22px;font-size:10px}

.cal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:10px}
.cal-nav{display:flex;align-items:center;gap:8px}
.cal-nav button{width:32px;height:32px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:17px;line-height:1}
.cal-nav button:hover{border-color:#c2c6cf}
.cal-title{font-size:16px;font-weight:800;min-width:120px;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.cal-dow{background:#f7f8fa;padding:9px;text-align:center;font-size:12px;font-weight:700;color:var(--muted)}
.cal-cell{background:#fff;min-height:104px;padding:7px;display:flex;flex-direction:column;gap:4px}
.cal-cell.out{background:#fafbfc}
.cal-cell .dnum{font-size:12px;color:var(--muted);font-weight:700;align-self:flex-start}
.cal-cell.today .dnum{background:#0a0a0b;color:#fff;border-radius:6px;padding:1px 7px}
.cal-chip{font-size:11px;background:#f3f4f6;border-left:3px solid #888;border-radius:5px;padding:2px 7px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-chip:hover{background:#e9eaee}
.cal-chip.od{background:#fdeaea;color:var(--risk)}

/* 截止日期/只读/锁定 */
.kdue{font-size:11px;font-weight:600;color:var(--muted);background:#f1f1f3;border-radius:5px;padding:1px 7px}
.kdue.od{background:#fdeaea;color:var(--risk)}
.kcard.ro{opacity:.92}
.ro-banner{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:10px;padding:10px 13px;font-size:13px;margin-bottom:14px}
.stepper.locked{opacity:.7;pointer-events:none}
.step{cursor:pointer}

@media (max-width:760px){
  .cal-cell{min-height:74px}
  .wk-dlabel{width:72px;flex-basis:72px}
  .ov-chip .oc-name{max-width:110px}
}

/* 任务/待办（详情内） */
.task-add{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.task-add input#taskTitle{flex:1;min-width:140px;padding:8px 11px;border:1px solid var(--line);border-radius:8px}
.task-add input#taskDue,.task-add select#taskStage{padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:#fff}
.task-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--line)}
.task-item:first-child{border-top:none}
.task-chk{width:17px;height:17px;flex:0 0 17px;accent-color:#0a0a0b;cursor:pointer}
.task-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.task-title{font-size:14px;font-weight:600}
.task-item.done .task-title{text-decoration:line-through;color:var(--muted);font-weight:500}
.task-meta{display:flex;align-items:center;gap:8px;font-size:12px}
.task-due{color:var(--muted);font-weight:600}
.task-due.od{color:var(--risk)}
.task-del{border:none;background:none;color:#c4c9d4;font-size:18px;cursor:pointer;padding:0 4px}
.task-del:hover{color:var(--risk)}

/* 任务可点击编辑 */
.task-edit{cursor:text;border-radius:5px;padding:0 3px}
.task-edit:hover{background:#f0f4ff;box-shadow:inset 0 0 0 1px #d6def5}
.task-due.task-edit{font-weight:600}
.task-item.done .task-edit{cursor:default}
.task-item.done .task-edit:hover{background:none;box-shadow:none}

/* 动态页 日期分隔 */
.act-day{font-size:12px;font-weight:700;color:var(--muted);padding:14px 0 6px;border-top:1px solid var(--line);margin-top:6px}
.feed .act-day:first-child{border-top:none;margin-top:0;padding-top:0}

/* 附件 */
.att-up{margin-bottom:12px}
.att-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--line)}
.att-item:first-child{border-top:none}
.att-ic{flex:0 0 auto}
.att-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.att-name{font-size:14px;font-weight:600;color:var(--brand);cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.att-name:hover{opacity:.7}
.att-meta{font-size:12px;color:var(--muted)}
.att-del{border:none;background:none;color:#c4c9d4;font-size:18px;cursor:pointer;padding:0 4px}
.att-del:hover{color:var(--risk)}
/* 看板列逾期徽标 */
.col-od{font-size:11px;font-weight:700;color:var(--risk);background:#fdeaea;border-radius:5px;padding:1px 6px;margin-left:6px}
/* @提及高亮 */
.ment{color:var(--brand);font-weight:600}
/* 成员邮箱可点 */
.mail-cell{cursor:text}
.mail-cell:hover{background:#fbfbfd}

/* 通知铃铛 + 面板 */
.sb-bell{position:relative;border:1px solid #2a2a30;background:transparent;color:#cfd0d4;border-radius:8px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 34px}
.sb-bell:hover{color:#fff;border-color:#3a3a42}
.nbadge{position:absolute;top:-5px;right:-5px;background:#e35d5d;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.nf-list{max-height:60vh;overflow:auto}
.nf-item{padding:11px 4px;border-top:1px solid var(--line);cursor:pointer}
.nf-item:first-child{border-top:none}
.nf-item:hover{background:#fafbfc}
.nf-item.unread{background:#f3f6ff}
.nf-item.unread:hover{background:#eaf0ff}
.nf-t{font-size:14px;color:var(--text)}
.nf-w{font-size:12px;color:var(--muted);margin-top:2px}
@media (max-width:760px){ .sb-bell{width:30px;height:30px;flex-basis:30px} }

/* ===================== 手机端统一优化（覆盖旧规则） ===================== */
@media (max-width:760px){
  /* 顶部导航：图标+文字、可横滑、当前项高亮 */
  .sidebar{padding:8px 10px;gap:8px;border-bottom:1px solid #1f1f24}
  .sb-nav{flex-direction:row;flex:1;gap:3px;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .sb-nav .nav{padding:8px 12px;gap:7px;border-radius:8px;white-space:nowrap;width:auto}
  .sb-nav .nav span.lbl{display:inline}
  .sb-nav .nav.active{background:#26262b;color:#fff}
  .sb-foot{border-top:none;padding-top:0;gap:6px;flex:0 0 auto}
  .sb-user{display:none}
  /* 视图头：标题 + 控件换行 */
  .vhead{padding:12px 14px;gap:10px}
  .vhead h1{font-size:18px}
  .vbody{padding:14px 12px 76px}
  /* 抽屉接近全屏 */
  .overlay{justify-content:stretch}
  .drawer{width:100%;max-width:100%}
  .dhead{padding:15px 16px}
  .dbody{padding:14px}
  .section{padding:14px}
  /* 详情字段竖排，好点按 */
  .field{flex-direction:column;gap:5px;margin-bottom:13px}
  .field label{width:auto;padding-top:0;font-weight:600;font-size:13px}
  /* iOS 聚焦防放大：所有输入 ≥16px */
  input,select,textarea{font-size:16px!important}
  /* 工具栏/筛选 */
  .tbar{gap:8px}
  .tbar input[type=search]{flex:1 1 100%;min-width:0}
  .tbar select{flex:1 1 40%}
  /* 概览/报表统计卡：每行 2 个 */
  .dash-stats{grid-template-columns:1fr 1fr;gap:10px}
  .dstat{padding:14px}
  .dstat .v{font-size:23px}
  .dash-grid{grid-template-columns:1fr}
  /* 日历更紧凑 */
  .cal-cell{min-height:62px;padding:5px}
  .cal-chip{font-size:10px;padding:2px 5px}
  .cal-legend{gap:6px}
  .cal-leg{padding:5px 9px;font-size:12px}
  .cal-title{font-size:15px;min-width:90px}
  .wk-dlabel{width:72px;flex-basis:72px}
  .ov-chip .oc-name{max-width:120px}
  /* 看板列窄一点 */
  .col{flex-basis:248px}
  /* 任务输入堆叠 */
  .task-add{gap:6px}
  .task-add input#taskTitle{flex:1 1 100%}
  /* 阶段条横滑 */
  .stepper{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
  .step{min-width:70px;flex:0 0 auto}
  /* 弹窗 */
  .modal{align-items:flex-start;padding-top:8vh}
  .modal .box{width:94vw;padding:18px;max-height:84vh}
  .modal .field label{width:auto}
}
@media (max-width:480px){
  .sb-brand span:last-child{display:none}   /* 窄屏只留 FE 徽标 */
  .sb-brand{padding:0}
  .dash-stats{grid-template-columns:1fr 1fr}
  .vhead h1{font-size:17px}
  .seg button{padding:6px 10px;font-size:13px}
  .btn,.btn.sm{padding:7px 11px}
}

/* 概览「需要关注」 */
.att-panel{margin-bottom:18px}
.att-chips{display:flex;flex-wrap:wrap;gap:8px}
.att-chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer}
.att-chip:hover{box-shadow:0 3px 10px rgba(15,20,40,.1)}
.att-chip i{font-style:normal;font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px}
.att-chip.overdue{border-color:#f3c6c6}
.att-chip.overdue i{background:#fdeaea;color:var(--risk)}
.att-chip.risk i{background:#fdf3e1;color:var(--warn)}

/* ===================== 手机原生风：底部 Tab + 顶部 App 栏 ===================== */
@media (max-width:760px){
  #app{display:block}
  .sidebar{display:contents}
  /* 顶部 App 栏 */
  .sb-brand{position:fixed;top:0;left:0;right:0;height:52px;margin:0;padding:0 14px;background:#0c0c0e;color:#fff;
    z-index:40;display:flex;align-items:center;gap:9px;font-size:15px;font-weight:800}
  .sb-brand span:last-child{display:inline}
  .sb-foot{position:fixed;top:0;right:6px;height:52px;z-index:41;padding:0;border:none;background:transparent;display:flex;align-items:center;gap:6px}
  .sb-user{display:flex;flex:0 0 auto;cursor:pointer}
  .sb-uname{display:none}
  .sb-foot .btn{padding:6px 10px;font-size:13px;color:#cfd0d4;border-color:#2a2a30}
  /* 底部 Tab 栏 */
  .sb-nav{position:fixed;left:0;right:0;bottom:0;z-index:40;flex-direction:row;justify-content:space-around;align-items:stretch;
    background:#0c0c0e;border-top:1px solid #1f1f24;padding:4px 2px;gap:0;overflow:visible}
  .sb-nav .nav{flex:1;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 2px;
    font-size:11px;border-radius:8px;width:auto;color:#9a9ba2}
  .sb-nav .nav svg{width:21px;height:21px;flex:none;opacity:.85}
  .sb-nav .nav span.lbl{display:block;font-size:11px;line-height:1;white-space:nowrap}
  .sb-nav .nav.active{background:transparent;color:#fff}
  .sb-nav .nav.active svg{opacity:1}
  /* 内容让出上下栏 */
  .content{padding-top:52px;padding-bottom:62px}
  .vhead{position:static}
  /* 弹窗/抽屉盖住底部栏 */
  .overlay{z-index:60}
  .modal{z-index:60}
  .toast{bottom:74px}
}
