*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",Arial,sans-serif;background:#f3f6fb;color:#172033;overflow:hidden}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}.hidden{display:none!important}
:root{--bg:#f3f6fb;--panel:#fff;--panel2:#f8fbff;--text:#172033;--muted:#65758b;--line:#e3ebf5;--primary:#175cff;--primary2:#0049da;--green:#08a66a;--orange:#e69000;--red:#e5484d;--purple:#7c3aed;--cyan:#0891b2;--shadow:0 18px 45px rgba(20,34,65,.09);--radius:20px}
body.dark{--bg:#0b1220;--panel:#111a2b;--panel2:#172238;--text:#eef5ff;--muted:#9aa9bf;--line:#263552;--primary:#5d8cff;--primary2:#7fa5ff;--shadow:0 20px 50px rgba(0,0,0,.25);background:var(--bg);color:var(--text)}
.login{min-height:100%;display:grid;grid-template-columns:1.1fr 480px;gap:40px;align-items:center;padding:70px;background:radial-gradient(circle at 18% 15%,#d7e6ff,transparent 30%),radial-gradient(circle at 78% 80%,#d9fff0,transparent 28%),linear-gradient(135deg,#f7fbff,#eef5ff)}
.login-left{max-width:800px}.logo-xl{width:82px;height:82px;border-radius:26px;background:linear-gradient(135deg,#175cff,#00a884);display:grid;place-items:center;color:#fff;font-size:46px;font-weight:900;box-shadow:0 24px 50px rgba(23,92,255,.25)}.login h1{font-size:52px;margin:24px 0 12px}.login-left p{font-size:19px;line-height:1.9;color:#526276}.login-feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:26px}.login-feature-grid span{background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.92);box-shadow:0 12px 30px rgba(20,34,65,.08);padding:14px;border-radius:16px;font-weight:900;color:#22324c}.login-card{background:rgba(255,255,255,.86);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.9);box-shadow:0 30px 90px rgba(20,34,65,.16);border-radius:30px;padding:34px}.login-card h2{margin:0 0 8px;font-size:30px}.login-card p{color:#65758b;margin:0 0 24px}.role-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}.role-tabs button{padding:11px;border-radius:13px;background:#eef4fd;color:#4c5d74;font-weight:900}.role-tabs button.active{background:#175cff;color:#fff}.login-card label{display:block;margin:16px 0 7px;font-weight:900;color:#40506a}.login-card input,.menu-search,.field input,.field select,.field textarea,.filter input,.filter select{width:100%;padding:12px 14px;border:1px solid var(--line);background:var(--panel);color:var(--text);border-radius:13px;outline:none}.tip{margin-top:16px;background:#f6f9ff;color:#5b6c82;line-height:1.7;padding:13px;border-radius:15px}.app{height:100%;display:grid;grid-template-columns:310px 1fr;background:var(--bg)}
.sidebar{background:#0d1729;color:#dce8ff;padding:20px 16px;overflow:auto}.brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}.logo{width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,#175cff,#00a884);display:grid;place-items:center;color:#fff;font-size:24px;font-weight:900}.brand strong{display:block;font-size:18px}.brand small{color:#8da2c2}.menu-search{background:#17233b;border-color:#263958;color:#fff;margin-bottom:14px}.menu-group{margin-bottom:8px}.menu-title{display:flex;justify-content:space-between;align-items:center;padding:10px 11px;color:#8fa3c2;font-size:13px;font-weight:900}.menu-item{width:100%;display:flex;gap:10px;align-items:center;text-align:left;padding:11px 12px;margin:3px 0;border-radius:13px;background:transparent;color:#dce8ff;font-weight:800;transition:.15s}.menu-item:hover{background:#192842}.menu-item.active{background:linear-gradient(135deg,#175cff,#0d9cbb);box-shadow:0 10px 26px rgba(23,92,255,.22);color:#fff}.mi{width:22px;text-align:center}.main{overflow:auto}.topbar{min-height:88px;background:rgba(255,255,255,.86);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);padding:16px 24px;position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between}body.dark .topbar{background:rgba(17,26,43,.86)}.breadcrumb{color:var(--muted);font-size:13px;margin-bottom:5px}.topbar h1{margin:0;font-size:25px}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.primary,.ghost,.danger,.success,.warning,.mini{border-radius:12px;padding:10px 14px;font-weight:900}.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 10px 22px rgba(23,92,255,.20)}.wide{width:100%;padding:14px}.ghost{background:var(--panel2);border:1px solid var(--line);color:var(--text)}.danger{background:#fff0f1;color:var(--red);border:1px solid #ffd6da}.success{background:#eafbf4;color:var(--green);border:1px solid #bff0d9}.warning{background:#fff7e6;color:#b7791f;border:1px solid #ffe1a6}.mini{padding:7px 10px;font-size:12px;background:var(--panel2);border:1px solid var(--line);color:var(--text)}.mini.primary{background:#eaf1ff;color:var(--primary);box-shadow:none}.mini.success{background:#eafbf4;color:var(--green)}.mini.danger{background:#fff0f1;color:var(--red)}.badge{display:inline-grid;place-items:center;min-width:20px;height:20px;border-radius:20px;background:#e9f1ff;color:var(--primary);font-size:12px;padding:0 6px}.badge.danger{background:#fff0f1;color:var(--red)}.user{display:flex;gap:10px;align-items:center;padding:8px 12px;background:var(--panel2);border:1px solid var(--line);border-radius:15px}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#175cff,#00a884);color:#fff;font-weight:900}.user small{display:block;color:var(--muted)}
.content{padding:24px;min-height:calc(100vh - 88px)}.hero{background:linear-gradient(135deg,#12213b,#175cff);color:#fff;border:0!important;position:relative;overflow:hidden}.hero:after{content:"";position:absolute;right:-90px;top:-100px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.13)}.hero h2{font-size:30px;margin:0 0 10px}.hero p{color:#dce8ff;line-height:1.8;max-width:1000px}.card,.stat,.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.grid{display:grid;gap:18px}.g2{grid-template-columns:1.25fr .85fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}.g5{grid-template-columns:repeat(5,1fr)}.mb{margin-bottom:18px}.mt{margin-top:18px}.stat span{color:var(--muted);font-weight:900}.stat b{display:block;font-size:30px;margin:9px 0}.trend{font-size:13px;color:var(--green);font-weight:900}.trend.down{color:var(--red)}.toolbar,.filter,.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.panel-head h3{margin:0;font-size:18px}.panel-head p{margin:5px 0 0;color:var(--muted)}.filter{margin-bottom:14px}.filter input,.filter select{width:auto;min-width:170px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px;background:var(--panel)}table{width:100%;border-collapse:separate;border-spacing:0}th,td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}th{background:var(--panel2);color:var(--muted);font-size:13px;font-weight:900}tr:last-child td{border-bottom:0}.pill{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:900}.pill.blue{background:#e9f1ff;color:#175cff}.pill.green{background:#eafbf4;color:#08a66a}.pill.orange{background:#fff7e6;color:#b7791f}.pill.red{background:#fff0f1;color:#e5484d}.pill.purple{background:#f3eefe;color:#7c3aed}.pill.cyan{background:#e9fbff;color:#0891b2}.features{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}.features div{padding:10px 12px;border-radius:13px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);font-weight:900}.form{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.field label{display:block;font-weight:900;color:var(--muted);font-size:13px;margin-bottom:7px}.field.full{grid-column:1/-1}.calc-checks{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.calc-check{display:flex;gap:9px;align-items:flex-start;background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:12px}.calc-check input{width:auto;margin-top:3px}.calc-check b{display:block}.calc-check small{display:block;color:var(--muted);margin-top:3px}.result-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.result-box{padding:16px;border-radius:17px;background:var(--panel2);border:1px solid var(--line)}.result-box.big{grid-column:1/-1;background:linear-gradient(135deg,#175cff,#00a884);color:#fff}.result-box span{color:var(--muted);font-weight:900}.result-box.big span{color:#e8f1ff}.result-box b{display:block;font-size:27px;margin-top:8px}.flow{display:flex;gap:8px;flex-wrap:wrap}.flow span{padding:10px 12px;border-radius:13px;background:var(--panel2);border:1px solid var(--line);font-weight:900}.kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.kanban-col{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:13px}.kanban-col h4{margin:0 0 10px}.task{padding:12px;border-radius:14px;background:var(--panel2);border:1px solid var(--line);margin-bottom:9px}.task strong{display:block;margin-bottom:5px}.task small{color:var(--muted)}.gantt-row{display:grid;grid-template-columns:150px 1fr;gap:12px;align-items:center;margin:12px 0}.track{height:36px;border-radius:999px;background:var(--panel2);border:1px solid var(--line);position:relative;overflow:hidden}.bar{position:absolute;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),#00a884);color:#fff;font-size:12px;font-weight:900;display:flex;align-items:center;padding-left:12px}.chart{height:250px;display:flex;gap:12px;align-items:end;padding:20px 6px 0}.chart div{flex:1;border-radius:11px 11px 0 0;background:linear-gradient(180deg,var(--primary),#00a884);position:relative}.chart span{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);font-size:12px;color:var(--muted);margin-bottom:6px}.timeline{display:flex;flex-direction:column;gap:12px}.time-item{display:grid;grid-template-columns:90px 1fr;gap:12px}.time-item b{color:var(--muted)}.time-item div:last-child{padding:12px;border-radius:14px;background:var(--panel2);border:1px solid var(--line)}.no-perm{text-align:center;padding:60px;border-radius:24px;background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)}.drawer{position:fixed;inset:0;z-index:20}.drawer-mask{position:absolute;inset:0;background:rgba(4,10,20,.55)}.drawer-panel{position:absolute;right:0;top:0;height:100%;width:min(920px,94vw);background:var(--panel);box-shadow:-30px 0 80px rgba(0,0,0,.25);overflow:auto}.drawer-header{height:70px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);padding:0 22px}.drawer-header h3{margin:0}.icon{width:38px;height:38px;border-radius:12px;background:var(--panel2);color:var(--text);font-size:24px}.drawer-body{padding:22px}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.tab{padding:9px 12px;border-radius:12px;background:var(--panel2);border:1px solid var(--line);font-weight:900;color:var(--text)}.tab.active{background:var(--primary);color:#fff}.permission-matrix th:first-child,.permission-matrix td:first-child{position:sticky;left:0;background:var(--panel2);z-index:1}.check{width:18px;height:18px}.module-count{font-size:12px;color:#8fa3c2;margin-left:auto}
@media(max-width:1250px){.g4,.g5{grid-template-columns:repeat(2,1fr)}.g2{grid-template-columns:1fr}.features,.kanban{grid-template-columns:repeat(2,1fr)}.calc-checks{grid-template-columns:repeat(2,1fr)}}@media(max-width:820px){body{overflow:auto}.login{grid-template-columns:1fr;padding:24px}.login h1{font-size:38px}.login-feature-grid,.features,.g3,.g4,.g5,.form,.calc-checks,.kanban,.result-grid{grid-template-columns:1fr}.app{grid-template-columns:1fr}.sidebar{display:none}.topbar{align-items:flex-start;flex-direction:column}.content{padding:14px}.filter input,.filter select{width:100%}}