:root{--primary: #2463eb;--primary-light: #eef4ff;--primary-dark: #1a4fc3;--accent-green: #12b76a;--accent-yellow: #f5a623;--accent-red: #e53e3e;--accent-purple: #7c3aed;--accent-teal: #0e9384;--gray-25: #fcfcfd;--gray-50: #f9fafb;--gray-100: #f2f4f7;--gray-200: #eaecf0;--gray-300: #d0d5dd;--gray-400: #98a2b3;--gray-500: #667085;--gray-600: #475467;--gray-700: #344054;--gray-800: #1d2939;--gray-900: #101828;--radius-sm: 6px;--radius: 8px;--radius-md: 10px;--radius-lg: 12px;--shadow-xs: 0 1px 2px rgba(16,24,40,.05);--shadow-sm: 0 1px 3px rgba(16,24,40,.1), 0 1px 2px rgba(16,24,40,.06);--shadow-md: 0 4px 8px rgba(16,24,40,.08), 0 2px 4px rgba(16,24,40,.04);--shadow-lg: 0 8px 24px rgba(16,24,40,.1), 0 4px 8px rgba(16,24,40,.06);--sidebar-w: 248px;--header-h: 0px}*{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--gray-50);color:var(--gray-900);font-size:14px;line-height:1.5}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;background:#fff}.spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .65s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{min-height:100vh;display:flex;background:#fff;position:relative}.login-left{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.login-card{width:100%;max-width:380px;animation:fadeUp .5s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login-logo{margin-bottom:32px;text-align:center}.login-logo img{width:64px;height:64px;border-radius:16px}.login-card h1{font-size:28px;font-weight:700;text-align:center;color:var(--gray-900);letter-spacing:-.03em;margin-bottom:4px}.login-card .sub{text-align:center;color:var(--gray-500);font-size:15px;margin-bottom:32px}.login-field{margin-bottom:18px}.login-field label{display:block;font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:6px}.login-field input{width:100%;padding:10px 14px;border:1.5px solid var(--gray-300);border-radius:var(--radius);font-size:15px;outline:none;transition:all .2s;font-family:inherit;background:#fff;color:var(--gray-900)}.login-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2463eb1f}.login-field input::placeholder{color:var(--gray-400)}.login-btn{width:100%;padding:11px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px}.login-btn:hover{background:var(--primary-dark)}.login-btn:active{transform:scale(.99)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-btn .spinner{width:16px;height:16px;border-width:2px;border-color:#ffffff4d;border-top-color:#fff}.login-error{text-align:center;color:var(--accent-red);font-size:13px;margin-top:14px;font-weight:500;background:#fef3f2;padding:8px 12px;border-radius:var(--radius-sm)}.login-right{flex:1;display:none;background:linear-gradient(135deg,#0f1419,#1a2332);align-items:center;justify-content:center;padding:60px;position:relative;overflow:hidden}.login-right:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(36,99,235,.15) 0%,transparent 70%);top:-100px;right:-100px}.login-right:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(18,183,106,.08) 0%,transparent 70%);bottom:-80px;left:-80px}.login-right-content{position:relative;z-index:1;color:#fff;max-width:420px}.login-right-content h2{font-size:32px;font-weight:700;letter-spacing:-.03em;margin-bottom:12px;line-height:1.3}.login-right-content p{color:#fff9;font-size:15px;line-height:1.7}.login-right-content .stat{margin-top:40px;display:flex;gap:40px}.login-right-content .stat-num{font-size:28px;font-weight:700}.login-right-content .stat-label{font-size:13px;color:#ffffff80;margin-top:4px}@media(min-width:900px){.login-right{display:flex}}.app-layout{display:flex;min-height:100vh;background:var(--gray-50)}.sidebar{width:var(--sidebar-w);background:var(--gray-900);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}.sidebar-head{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px;flex-shrink:0}.sidebar-head img{width:34px;height:34px;border-radius:10px;flex-shrink:0}.sidebar-head-text h1{font-size:16px;font-weight:700;letter-spacing:-.02em;line-height:1.3}.sidebar-head-text h1 span{color:var(--primary)}.sidebar-head-text p{font-size:10px;color:#ffffff4d;letter-spacing:.02em}.sidebar-nav{flex:1;padding:10px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.sidebar-nav .label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#fff3;padding:14px 12px 6px}.sidebar-nav button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;border-radius:var(--radius);background:transparent;color:#ffffff80;font-size:13px;cursor:pointer;transition:all .12s;text-align:left;font-family:inherit;font-weight:450}.sidebar-nav button:hover{background:#ffffff0d;color:#fffc}.sidebar-nav button.active{background:#2463eb33;color:#fff;font-weight:500}.sidebar-nav button .icon{font-size:15px;width:22px;text-align:center;flex-shrink:0;opacity:.7}.sidebar-nav button.active .icon{opacity:1}.sidebar-foot{padding:12px 14px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.sidebar-foot .user{display:flex;align-items:center;gap:10px;padding:4px 2px}.sidebar-foot .avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-foot .name{font-size:13px;color:#fff;font-weight:500}.sidebar-foot .role{font-size:10px;color:#ffffff4d}.sidebar-foot .logout{font-size:11px;color:#ffffff40;cursor:pointer;padding:2px;display:inline-block;transition:color .12s;margin-top:4px;margin-left:38px}.sidebar-foot .logout:hover{color:var(--accent-red)}.main{margin-left:var(--sidebar-w);flex:1;min-width:0;padding:28px 32px 40px;max-width:1440px}.page-head{margin-bottom:24px}.page-head h2{font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--gray-900)}.page-head p{color:var(--gray-500);font-size:14px;margin-top:3px}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:24px;box-shadow:var(--shadow-xs)}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:11px;font-weight:500;color:var(--gray-600)}.filter-group select,.filter-group input{padding:7px 10px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:13px;color:var(--gray-800);background:#fff;min-width:130px;outline:none;transition:all .12s;font-family:inherit}.filter-group select:focus,.filter-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2463eb1a}.filter-clear{padding:7px 14px;border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;color:var(--gray-600);font-size:12px;cursor:pointer;font-weight:500;transition:all .12s;white-space:nowrap}.filter-clear:hover{border-color:var(--accent-red);color:var(--accent-red)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}.kpi-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all .2s;overflow:hidden;position:relative}.kpi-card:hover{box-shadow:var(--shadow-md)}.kpi-card:before{content:"";display:block;height:3px;background:var(--accent, var(--primary))}.kpi-card-inner{padding:18px 20px}.kpi-card .label{font-size:12px;font-weight:500;color:var(--gray-500);margin-bottom:6px}.kpi-card .value{font-size:30px;font-weight:700;color:var(--accent, var(--gray-900));line-height:1.15;letter-spacing:-.02em}.kpi-card .sub{font-size:13px;color:var(--gray-500);margin-top:4px}.kpi-card .trend{font-size:12px;margin-top:6px;display:inline-flex;align-items:center;gap:4px;font-weight:600}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);overflow:hidden;transition:box-shadow .2s}.card-hover:hover{box-shadow:var(--shadow-md)}.card-head{padding:16px 22px;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center}.card-head h3{font-size:15px;font-weight:600;color:var(--gray-800)}.card-body{padding:20px 22px}.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}.alert{display:flex;gap:14px;padding:14px 18px;border-radius:var(--radius);margin-bottom:10px}.alert-high{background:#fef3f2;border-left:3px solid var(--accent-red)}.alert-medium{background:#fffaeb;border-left:3px solid var(--accent-yellow)}.alert-icon{font-size:18px;flex-shrink:0;padding-top:1px}.alert-content h4{font-size:14px;font-weight:600;margin-bottom:2px;color:var(--gray-800)}.alert-content p{font-size:13px;color:var(--gray-600);line-height:1.5}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--gray-200)}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;padding:10px 14px;border-bottom:1px solid var(--gray-200);color:var(--gray-500);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;background:var(--gray-25)}tbody td{padding:10px 14px;border-bottom:1px solid var(--gray-100);color:var(--gray-700)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--gray-25)}.text-right{text-align:right}.text-center{text-align:center}.font-mono{font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:12px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;gap:4px}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-green{background:#ecfdf3;color:var(--accent-green)}.badge-yellow{background:#fffaeb;color:#b54708}.badge-red{background:#fef3f2;color:var(--accent-red)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.upload-zone{border:2px dashed var(--gray-300);border-radius:var(--radius-lg);padding:48px 32px;text-align:center;transition:all .2s;cursor:pointer;background:var(--gray-25)}.upload-zone:hover,.upload-zone.dragover{border-color:var(--primary);background:var(--primary-light)}.upload-zone .icon{font-size:36px;margin-bottom:10px}.upload-zone p{color:var(--gray-500);font-size:14px}.upload-zone .fn{color:var(--primary);font-weight:500}.custom-tooltip{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:10px 14px;box-shadow:var(--shadow-lg);font-size:12px;line-height:1.6}.custom-tooltip .tt-label{font-weight:600;margin-bottom:2px;color:var(--gray-800)}.gantt-wrap{min-width:720px}.gantt-tbl{width:100%;border-collapse:collapse;font-size:12px}.gantt-tbl th{padding:8px 10px;border-bottom:1px solid var(--gray-200);text-align:left;color:var(--gray-500);font-size:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:600;background:var(--gray-25)}.gantt-tbl td{padding:6px 10px;border-bottom:1px solid var(--gray-100)}.gantt-tbl .track{position:relative;height:28px;background:var(--gray-100);border-radius:5px;overflow:hidden}.gantt-tbl .bar{position:absolute;top:3px;height:22px;border-radius:4px;background:var(--primary);display:flex;align-items:center;overflow:hidden;cursor:pointer;transition:opacity .12s}.gantt-tbl .bar:hover{opacity:.85}.gantt-tbl .bar span{font-size:9px;color:#fff;padding:0 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}.conn-ip{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500;color:var(--gray-800)}@media(max-width:1024px){.sidebar{width:56px}.sidebar-head img{width:28px;height:28px}.sidebar-head-text,.sidebar-nav .label,.sidebar-nav button span:last-child,.sidebar-foot .info,.sidebar-foot .logout{display:none}.sidebar-nav button{justify-content:center;padding:10px}.main{margin-left:56px;padding:20px}.chart-grid{grid-template-columns:1fr}}@media(max-width:640px){.main{margin-left:56px;padding:14px}.kpi-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column}.filter-group select,.filter-group input{min-width:auto;width:100%}}
