:root{--violet:#6A4FE8;--violet-lt:#EDE9FC;--violet-dk:#3C3489;--teal:#1D9E75;--ink:#1A1830;--muted:#6B6885;--hint:#9794Ad;--page:#F4F3FA;--card:#FFF;--line:#E7E3F3;--line2:#D9D5EC;--on:#1D9E75;--on-bg:#E1F5EE;--due:#C77F0E;--due-bg:#FBF0DA;--br:#D8403F;--br-bg:#FBE6E6;--info:#185FA5;--info-bg:#E6F1FB;--sidebar:#1A1830;--side-mut:#9A95C0}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--page);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.side{background:var(--sidebar);color:#fff;padding:14px 0;position:sticky;top:0;height:100vh;overflow-y:auto}.side::-webkit-scrollbar{width:6px}.side::-webkit-scrollbar-thumb{background:#39355c;border-radius:3px}.side-brand{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px;padding:4px 18px 14px}.side-brand .logo{width:28px;height:28px;border-radius:8px;background:var(--violet);display:flex;align-items:center;justify-content:center;font-weight:700}.side-brand small{color:var(--side-mut);font-weight:400;font-size:11px;display:block}.nav-group{padding:12px 18px 4px;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:#6f6a9b}.nav-i{display:flex;align-items:center;gap:10px;padding:9px 18px;font-size:13px;color:var(--side-mut);cursor:pointer;border-left:3px solid transparent;width:100%;background:none;border-top:none;border-right:none;border-bottom:none;text-align:left}.nav-i:hover{background:#241f3f;color:#fff}.nav-i.on{background:#241f3f;color:#fff;border-left-color:var(--violet)}.nav-i .ic{width:16px;height:16px;flex:none}.nav-i .ct{margin-left:auto;font-size:10.5px;background:#332e52;color:#cfc9f0;padding:1px 7px;border-radius:9px}.main{min-width:0;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:11px 22px;display:flex;align-items:center;gap:14px}.topbar .sp{flex:1}.hamb{display:none;background:none;border:1px solid var(--line);border-radius:8px;width:34px;height:34px;cursor:pointer;font-size:16px;align-items:center;justify-content:center}.me{display:flex;align-items:center;gap:8px;font-size:13px}.me .av{width:32px;height:32px;border-radius:50%;background:var(--violet-lt);color:var(--violet-dk);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.content{padding:22px;max-width:1280px;width:100%}.ph{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}.ph h1{font-size:21px;font-weight:600}.ph .sub{font-size:12.5px;color:var(--muted);margin-top:2px}.card{background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px 18px;margin-bottom:14px}.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card-h b{font-size:14.5px}.card-h .m{font-size:12px;color:var(--muted)}.tag{font-size:11.5px;padding:3px 10px;border-radius:7px;font-weight:600;white-space:nowrap;display:inline-block}.t-on{background:var(--on-bg);color:var(--on)}.t-due{background:var(--due-bg);color:var(--due)}.t-br{background:var(--br-bg);color:var(--br)}.t-info{background:var(--info-bg);color:var(--info)}.t-violet{background:var(--violet-lt);color:var(--violet-dk)}.t-grey{background:#efeef4;color:var(--muted)}.t-teal{background:var(--on-bg);color:var(--teal)}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;color:var(--muted);font-weight:600;padding:9px 10px;border-bottom:1px solid var(--line2);text-transform:uppercase;letter-spacing:.03em}td{padding:11px 10px;font-size:13px;border-bottom:1px solid var(--line);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--page)}td.title{font-weight:600}.row-av{width:28px;height:28px;border-radius:50%;background:var(--violet-lt);color:var(--violet-dk);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;margin-right:8px;vertical-align:middle}.infog{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.ig{background:#fff;border:1px solid var(--line);border-radius:13px;padding:15px 16px}.ig .ig-n{font-size:25px;font-weight:700;line-height:1}.ig .ig-l{font-size:12px;color:var(--muted);margin-top:5px;font-weight:600}.ig .ig-s{font-size:11.5px;color:var(--hint);margin-top:4px}.ig .ig-bar{height:4px;border-radius:3px;margin-top:10px;background:var(--violet)}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.bar{height:8px;background:var(--page);border-radius:5px;overflow:hidden;margin-top:5px}.bar>i{display:block;height:100%;border-radius:5px}.statline{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-top:1px solid var(--line);font-size:13px}.statline:first-child{border-top:none}.empty{text-align:center;padding:34px 0;color:var(--hint);font-size:13px}.pillrow{display:flex;gap:7px;flex-wrap:wrap;margin-top:8px}.fn-row{display:flex;align-items:center;gap:10px;margin:8px 0}.fn-l{width:96px;font-size:11.5px;color:var(--muted);text-align:right;flex:none}.fn-track{flex:1;background:var(--page);border-radius:7px;overflow:hidden}.fn-bar{height:25px;border-radius:7px;display:flex;align-items:center;justify-content:flex-end;padding:0 9px;color:#fff;font-size:11.5px;font-weight:700;min-width:26px;transition:width .5s}.kanban{display:flex;gap:13px;overflow-x:auto;padding-bottom:8px}.kcol{flex:0 0 235px;background:var(--page);border-radius:12px;padding:11px}.kcol-h{font-size:12px;font-weight:600;color:var(--muted);display:flex;justify-content:space-between;margin-bottom:9px;padding:0 3px;text-transform:capitalize}.kcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 11px;margin-bottom:8px}.kcard .kt{font-weight:600;font-size:12.5px}.kcard .ks{font-size:11px;color:var(--muted);margin:3px 0 5px}.tree{font-size:13px}.tnode{margin:3px 0}.trow{display:flex;align-items:center;gap:9px;padding:8px 11px;border:1px solid var(--line);border-radius:10px;background:#fff}.tkids{margin-left:18px;padding-left:14px;border-left:1.5px solid var(--line);margin-top:3px}.tav{width:28px;height:28px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex:none}.btn{border:1px solid var(--line2);background:#fff;color:var(--ink);border-radius:8px;padding:7px 13px;font-size:13px;font-weight:600;cursor:pointer}.btn:hover{background:var(--page)}.btn.sm{padding:5px 10px;font-size:12px}.btn.ghost{background:none;border-color:var(--line2);color:var(--violet-dk)}.btn.primary{background:var(--violet);border-color:var(--violet);color:#fff}.btn.primary:hover{background:var(--violet-dk)}.btn:disabled{opacity:.55;cursor:default}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f0e1a;padding:24px}.login-card{width:100%;max-width:380px;background:#1a1830;border:1px solid #2a2747;border-radius:18px;padding:36px 32px;box-shadow:0 24px 70px #00000073;color:#e8e6f0}.login-card .lc-logo{width:46px;height:46px;border-radius:12px;background:var(--violet);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:22px;margin-bottom:18px}.login-card h1{font-size:21px;margin-bottom:4px}.login-card .lc-sub{color:#a8a4c0;font-size:13px;margin-bottom:24px}.login-card label{display:block;font-size:12px;color:#a8a4c0;margin:14px 0 6px;font-weight:600}.login-card input{width:100%;background:#0f0e1a;border:1px solid #2a2747;border-radius:10px;padding:11px 13px;color:#e8e6f0;font-size:14px}.login-card input:focus{outline:none;border-color:var(--violet)}.login-card .lc-btn{width:100%;margin-top:22px;background:var(--violet);color:#fff;border:none;border-radius:10px;padding:12px;font-weight:700;font-size:14.5px;cursor:pointer}.login-card .lc-btn:disabled{opacity:.6;cursor:default}.login-card .lc-err{margin-top:16px;background:var(--br-bg);color:var(--br);border-radius:9px;padding:10px 12px;font-size:13px}@media (max-width:900px){.app{grid-template-columns:1fr}.side{position:fixed;z-index:50;width:248px;transform:translate(-100%);transition:transform .2s}.side.open{transform:translate(0)}.grid2{grid-template-columns:1fr}.hamb{display:flex}}
