/* app.css — 事业 Agent OS 体验层（任务为中心操作台 + 达人码）。配色对齐 Cowork 原型。 */
:root{
  --bg:#0b111c;--panel:#111a29;--card:#152136;--card2:#1a2740;--line:#243350;
  --txt:#e9eef7;--mut:#8fa2c0;--accent:#4d9fff;--gold:#e0b768;--g:#3ad29a;--y:#f2c14e;--r:#f06a6a;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"PingFang SC","Microsoft YaHei",-apple-system,system-ui,sans-serif;
  background:radial-gradient(1100px 700px at 78% -12%,#16294a55,transparent),var(--bg);
  color:var(--txt);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;height:100vh;overflow:hidden}
.hide{display:none!important}
.muted{color:var(--mut)}
.app{display:grid;grid-template-columns:230px 1fr;height:100vh}
.side{background:#0a0f18;border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.brand{display:flex;align-items:center;gap:10px;padding:4px 8px 16px}
.brand .mk{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#4d9fff,#7d5bff);display:flex;align-items:center;justify-content:center;font-size:16px}
.brand b{font-size:15px;font-weight:700}.brand small{display:block;color:var(--mut);font-size:10.5px;margin-top:1px}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.nav a{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;color:var(--mut);text-decoration:none;font-size:13.5px;transition:.15s;cursor:pointer}
.nav a .ic{width:18px;text-align:center}
.nav a:hover{background:#141f33;color:var(--txt)}
.nav a.on{background:linear-gradient(90deg,#1c3157,#152340);color:#fff;font-weight:600}
.nav a .cnt{margin-left:auto;font-size:11px;background:#2a3a5a;color:#cfe0ff;padding:1px 7px;border-radius:20px}
.nav a.on .cnt{background:var(--accent);color:#04121f}
.nav .grp{color:#4f6079;font-size:11px;font-weight:600;letter-spacing:.6px;padding:14px 11px 5px}
.side .foot{margin-top:auto;font-size:11px;color:#4f6079;padding:8px;line-height:1.6;border-top:1px solid var(--line)}
.main{overflow-y:auto;position:relative}
.top{position:sticky;top:0;z-index:5;background:#0b111ccc;backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:15px 30px;display:flex;align-items:center;gap:16px}
.top h1{font-size:17px;font-weight:700}.top .sub{color:var(--mut);font-size:12.5px}
.right{margin-left:auto;display:flex;align-items:center;gap:10px}
.right label{color:var(--mut);font-size:12px}
select,input{background:var(--card);color:var(--txt);border:1px solid var(--line);border-radius:9px;padding:7px 11px;font-size:13px}
.av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#e0b768,#c98a3a);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#1a1206}
.wrap{padding:22px 30px 60px;max-width:1080px}
.hello h2{font-size:22px;font-weight:700}.hello .line{color:var(--mut);font-size:13.5px;margin-top:5px}
.chips{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.chip{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 16px;min-width:120px}
.chip .n{font-size:22px;font-weight:700;line-height:1}.chip .t{color:var(--mut);font-size:11.5px;margin-top:4px}
.chip.a .n{color:var(--accent)}.chip.b .n{color:var(--gold)}.chip.c .n{color:var(--g)}
.bar{display:flex;align-items:center;gap:8px;margin:22px 0 14px;flex-wrap:wrap}
.bar .lbl{color:#6d82a5;font-size:11.5px;font-weight:600;letter-spacing:.5px;margin-right:2px}
.vtab{background:var(--card);border:1px solid var(--line);color:var(--mut);padding:7px 13px;border-radius:9px;font-size:12.5px;cursor:pointer}
.vtab.on{background:var(--accent);color:#04121f;border-color:var(--accent);font-weight:600}
.filt{margin-left:auto;display:flex;gap:7px}
.f{background:transparent;border:1px solid var(--line);color:var(--mut);padding:6px 11px;border-radius:20px;font-size:11.5px;cursor:pointer}
.f.on{background:#3d1717;border-color:var(--r);color:#ff9a9a}
.pinbar{background:linear-gradient(180deg,#1a1c10,#14160c);border:1px solid #3a3418;border-radius:12px;padding:6px 8px;margin-bottom:20px}
.pinbar .ph{color:var(--gold);font-size:11.5px;font-weight:600;padding:7px 6px 4px}
.group{margin-bottom:16px}
.ghead{display:flex;align-items:center;gap:9px;padding:7px 4px;cursor:pointer;user-select:none;border-radius:8px}
.ghead:hover{background:#0f1826}
.ghead .gi{font-size:15px}.ghead .gn{font-size:13.5px;font-weight:600}
.ghead .gc{font-size:11px;color:var(--mut);background:#1c2942;padding:1px 8px;border-radius:20px}
.ghead .chev{margin-left:auto;color:var(--mut);font-size:11px;transition:.2s}
.group.col .chev{transform:rotate(-90deg)}.group.col .glist{display:none}
.task{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;padding:13px 15px;margin-bottom:9px;cursor:pointer;transition:.16s;display:flex;gap:13px;align-items:flex-start}
.task:hover{transform:translateX(3px);border-color:#3a557f;background:var(--card2)}
.task.lane-g{border-left-color:var(--g)}.task.lane-y{border-left-color:var(--y)}.task.lane-r{border-left-color:var(--r)}
.task .body{flex:1;min-width:0}
.task .tt{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}
.task .tt .pin{color:var(--gold);font-size:12px}
.task .now{color:var(--mut);font-size:12.5px;margin-top:5px;line-height:1.5}.task .now .ai{color:#8fd0ff}
.task .meta{display:flex;gap:7px;margin-top:9px;flex-wrap:wrap;align-items:center}
.tag{font-size:10.5px;padding:2px 8px;border-radius:20px;background:#22314e;color:#bcd0ef}
.tag.g{background:#123d2e;color:#7fe9be}.tag.y{background:#40350f;color:#f2d488}.tag.r{background:#3d1717;color:#ff9a9a}
.tag.step{background:#1b2a45;color:#9fb6da}
.task .cta{align-self:center;white-space:nowrap}
.btn{border:1px solid var(--line);background:var(--card2);color:var(--txt);border-radius:9px;padding:8px 13px;font-size:12.5px;cursor:pointer;font-weight:500}
.btn:hover{border-color:var(--accent);background:#22335a}
.btn.pri{background:linear-gradient(180deg,#4d9fff,#2f7fe0);border-color:#4d9fff;color:#fff;font-weight:600}
.btn.g{border-color:var(--g);color:#bff3dd}.btn.r{border-color:var(--r);color:#ffb4b4}.btn.sm{padding:5px 10px;font-size:11.5px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:14px}
.card h3{font-size:14px;margin-bottom:10px}
table{width:100%;border-collapse:collapse;font-size:12.5px}
th,td{text-align:left;padding:7px 8px;border-bottom:1px solid var(--line)}
th{color:#6d82a5;font-weight:600}
/* drawer */
.scrim{position:fixed;inset:0;background:#04070cbb;opacity:0;pointer-events:none;transition:.2s;z-index:20}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:540px;max-width:94vw;background:var(--panel);border-left:1px solid var(--line);transform:translateX(100%);transition:.26s cubic-bezier(.4,0,.2,1);z-index:21;display:flex;flex-direction:column;box-shadow:-30px 0 60px #0008}
.drawer.show{transform:none}
.dh{padding:18px 22px;border-bottom:1px solid var(--line)}
.dh .x{float:right;cursor:pointer;color:var(--mut);font-size:18px}.dh h3{font-size:16px;font-weight:700;padding-right:26px}
.dh .dsub{color:var(--mut);font-size:12px;margin-top:6px}
.db{flex:1;overflow-y:auto;padding:20px 22px}.blk{margin-bottom:22px}
.blk .bt{font-size:11.5px;color:#6d82a5;font-weight:600;letter-spacing:.6px;margin-bottom:11px}
.sop .st{display:flex;gap:12px;position:relative}
.sop .st:before{content:"";position:absolute;left:8px;top:20px;bottom:-4px;width:2px;background:var(--line)}
.sop .st:last-child:before{display:none}
.sop .dot{width:18px;height:18px;border-radius:50%;background:var(--card);border:2px solid var(--line);flex-shrink:0;margin-top:1px;z-index:1;display:flex;align-items:center;justify-content:center;font-size:9px}
.sop .st.done .dot{background:#1f6f4d;border-color:var(--g);color:#c9f5e4}
.sop .st.cur .dot{background:#2f5bb0;border-color:var(--accent)}
.sop .lb{padding-bottom:14px}.sop .lb .n{font-size:13px;font-weight:500}
.sop .st.cur .lb .n{color:var(--accent);font-weight:700}.sop .st.done .lb .n{color:var(--mut)}
.sop .lb .d{color:#6a7f9f;font-size:11.5px;margin-top:2px}
.redline{margin-top:14px;font-size:11px;color:#8a9bbb;background:#141d2e;border:1px solid var(--line);border-radius:9px;padding:9px 12px;line-height:1.6}
.redline b{color:#ffb4b4}
/* 达人码 */
.dana{display:grid;grid-template-columns:300px 1fr;gap:16px}
.radar-wrap{text-align:center}
.skillrow{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.skillrow .sn{width:150px;font-size:12.5px}
.bar-bg{flex:1;height:8px;background:#0e1826;border-radius:6px;overflow:hidden}
.bar-fg{height:100%;background:linear-gradient(90deg,#4d9fff,#7d5bff)}
.lv{font-size:11px;color:var(--mut);width:26px}
.badge{display:inline-block;font-size:10.5px;padding:2px 8px;border-radius:20px;background:#241b3a;color:#c8b5ef;margin:2px}
.placeholder{color:#5a6d8c;font-size:12px;font-style:italic}
/* login */
#authOverlay{position:fixed;inset:0;z-index:9999;background:rgba(8,12,20,.97);display:none;align-items:center;justify-content:center}
.authbox{width:340px;background:#0f1622;border:1px solid rgba(0,212,255,.22);border-radius:14px;padding:26px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.authbox h2{font-size:18px;color:#00d4ff;margin-bottom:4px}
.authbox .s{color:#7a8a9a;font-size:12px;margin-bottom:18px}
.authbox input{width:100%;margin-bottom:11px;padding:10px;border-radius:8px;border:1px solid #24323f;background:#0a1019;color:#dfe8f0}
.authbox button{width:100%;padding:10px;border:none;border-radius:8px;background:linear-gradient(90deg,#00d4ff,#0094c8);color:#04121b;font-weight:600;cursor:pointer}
.err{color:#ff6b6b;font-size:12px;margin-top:8px}
.flash{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#152136;border:1px solid var(--accent);color:#dfe8f0;padding:10px 18px;border-radius:10px;display:none;z-index:9998}
@media(max-width:820px){.app{grid-template-columns:0 1fr}.side{display:none}.dana{grid-template-columns:1fr}}
