:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;padding:0;width:100%;min-width:320px;min-height:100vh}#root{width:100%;height:100%}.login-container{display:flex;height:100vh;width:100%;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-left{flex:1.2;position:relative;background-image:url(https://images.unsplash.com/photo-1556108139-3889025c84d6?q=80&w=2070&auto=format&fit=crop);background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:space-between;padding:60px;color:#fff}.login-left:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#000000e6,#3c1414b3);z-index:1}.login-left-content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:space-between}.brand-logo{font-size:24px;font-weight:700;letter-spacing:1px;display:flex;align-items:center;gap:10px}.brand-slogan h1{font-size:48px;margin-bottom:20px;font-weight:600;line-height:1.2}.brand-slogan p{font-size:18px;opacity:.8;max-width:80%}.login-right{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:space-between;background-color:#fff;padding:40px}.login-form-wrapper{width:100%;max-width:420px;margin-top:auto;margin-bottom:auto}.form-header{margin-bottom:40px}.form-header h2{font-size:32px;font-weight:700;color:#1f1f1f;margin-bottom:10px}.form-header p{color:#8c8c8c;font-size:16px}.login-form .ant-input-affix-wrapper{padding:12px 11px}.login-form .ant-btn-primary{height:48px;font-size:16px;font-weight:500;background-color:#0052cc}.login-form .ant-btn-primary:hover{background-color:#003eb3}@media(max-width:768px){.login-left{display:none}}.dashboard-root.ant-layout{min-height:100vh;background:#eef1f6}.dashboard-header.ant-layout-header{position:sticky;top:0;z-index:30;height:58px;line-height:58px;padding:0 22px 0 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:linear-gradient(100deg,#1a2332,#243447 38%,#1c2838 72%,#17202e);border-bottom:1px solid rgba(148,163,184,.28);box-shadow:0 1px #ffffff0d inset,0 4px 20px #02061759}.dashboard-brand{display:flex;align-items:center;gap:0;cursor:pointer;min-width:0;border-radius:10px;padding:5px 10px 5px 6px;margin:-5px -10px -5px -6px;transition:background-color .2s ease}.dashboard-brand:hover{background-color:#f8fafc0f}.dashboard-brand:focus-visible{outline:2px solid rgba(147,197,253,.85);outline-offset:2px}.dashboard-brand-logo{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:5px 8px;border-radius:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);box-shadow:0 1px 2px #0003}.dashboard-brand-logo img{height:30px;width:auto;display:block}.dashboard-brand-divider{flex-shrink:0;width:1px;height:34px;margin:0 14px;background:linear-gradient(180deg,#94a3b800,#94a3b873,#94a3b800)}.dashboard-brand-text{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:0;min-width:0}.dashboard-brand-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px 10px;min-width:0}.dashboard-brand-title{font-size:16px;font-weight:600;letter-spacing:.02em;color:#f8fafc;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(46vw,380px);text-shadow:0 1px 1px rgba(0,0,0,.2)}.dashboard-brand-badge{flex-shrink:0;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#dbeafe;padding:3px 9px;border-radius:999px;line-height:1.2;background:linear-gradient(145deg,#2563eb73,#1e40af59);border:1px solid rgba(147,197,253,.35);box-shadow:0 0 0 1px #0f172a40}.dashboard-header-right{display:flex;align-items:center;gap:14px;flex-shrink:0}.dashboard-user-pill{display:flex;align-items:center;gap:10px;padding:4px 14px 4px 4px;border-radius:999px;background:#f8fafc12;border:1px solid rgba(148,163,184,.28);max-width:260px}.dashboard-user-pill .ant-avatar{flex-shrink:0;background:linear-gradient(145deg,#3b82f6,#1d4ed8)!important}.dashboard-user-meta{display:flex;flex-direction:column;line-height:1.25;min-width:0;text-align:left}.dashboard-user-name{color:#f8fafc;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-user-role{color:#e2e8f0b8;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-logout.ant-btn{height:32px;padding:0 14px;font-size:13px;font-weight:500;color:#e2e8f0!important;border-color:#e2e8f061!important;background:#0f172a40!important;border-radius:6px}.dashboard-logout.ant-btn:hover{color:#fff!important;border-color:#f8fafc8c!important;background:#ffffff1a!important}.dashboard-sider.ant-layout-sider{background:linear-gradient(180deg,#070b12,#0a101c 40%,#080c14)!important;border-right:1px solid rgba(51,65,85,.65);box-shadow:inset 0 1px #ffffff0a}.dashboard-sider .ant-layout-sider-children{display:flex;flex-direction:column;min-height:0}.dashboard-sider .ant-layout-sider-trigger{background:#1e293b!important;color:#94a3b8!important;border-top:1px solid rgba(51,65,85,.85);height:44px;line-height:44px}.dashboard-sider .ant-layout-sider-trigger:hover{color:#e2e8f0!important;background:#334155!important}.dashboard-menu.ant-menu.ant-menu-root.ant-menu-inline,.dashboard-menu.ant-menu.ant-menu-root.ant-menu-vertical{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;border-inline-end:none!important;background:transparent!important;padding:10px 8px 16px}.dashboard-sider.ant-layout-sider-collapsed .dashboard-menu.ant-menu-inline-collapsed{padding-left:6px!important;padding-right:6px!important}.dashboard-menu.ant-menu-dark,.dashboard-menu.ant-menu-dark>.ant-menu-item,.dashboard-menu.ant-menu-dark .ant-menu-sub.ant-menu-inline{background:transparent!important}.dashboard-menu.ant-menu-dark .ant-menu-item,.dashboard-menu.ant-menu-dark>.ant-menu-submenu>.ant-menu-submenu-title{border-radius:6px;margin:3px 0;height:42px;line-height:42px;width:100%;color:#e2e8f0eb}.dashboard-menu.ant-menu-dark .ant-menu-item .anticon,.dashboard-menu.ant-menu-dark .ant-menu-submenu-title .anticon{font-size:16px;color:#94a3b8f2}.dashboard-menu.ant-menu-dark .ant-menu-item-selected{background:#2563eb61!important;color:#fff!important}.dashboard-menu.ant-menu-dark .ant-menu-item-selected:after{display:none}.dashboard-menu.ant-menu-dark .ant-menu-item-selected .anticon{color:#93c5fd}.dashboard-menu.ant-menu-dark:not(.ant-menu-horizontal) .ant-menu-item:not(.ant-menu-item-selected):hover,.dashboard-menu.ant-menu-dark .ant-menu-submenu-title:hover{background:#f8fafc0f!important;color:#f8fafc!important}.dashboard-menu.ant-menu-dark .ant-menu-submenu-open>.ant-menu-submenu-title{background:#0000001f!important}.dashboard-menu.ant-menu-dark .ant-menu-sub.ant-menu-inline{background:#0000002e!important;border-radius:6px;padding:4px 0 6px;margin:4px 0 6px}.dashboard-menu.ant-menu-dark .ant-menu-sub .ant-menu-item{height:38px;line-height:38px;padding-left:40px!important}.dashboard-menu.ant-menu-dark .ant-menu-item-selected.ant-menu-item-only-child{background:#2563eb52!important}.dashboard-inner.ant-layout{background:transparent;min-width:0}.dashboard-body{padding:0 16px 20px 14px}.dashboard-content-spacer{height:12px}.dashboard-content.ant-layout-content{padding:22px 24px;min-height:280px;overflow:initial;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 2px #0f172a0d}@media(max-width:768px){.dashboard-header.ant-layout-header{height:54px;line-height:54px;padding:0 12px 0 10px}.dashboard-brand{padding:4px 6px 4px 4px;margin:-4px -6px -4px -4px}.dashboard-brand-logo{padding:4px 6px}.dashboard-brand-logo img{height:26px}.dashboard-brand-divider{height:28px;margin:0 10px}.dashboard-brand-title{max-width:min(52vw,240px);font-size:14px}.dashboard-brand-badge{letter-spacing:.08em;padding:2px 7px;font-size:10px}.dashboard-body{padding:0 12px 16px}}@media(max-width:520px){.dashboard-brand-badge{display:none}.dashboard-brand-title{max-width:58vw}}.overview-page{box-sizing:border-box;width:100%;max-width:100%;margin:-12px -16px 0;padding:20px 20px 28px;min-height:calc(100vh - 120px);background:linear-gradient(180deg,#f4f6f9,#eef1f6)}.overview-page-inner{width:100%;max-width:100%;margin-left:0;margin-right:0}.overview-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(15,23,42,.08)}.overview-header-title{margin:0!important;font-size:20px!important;font-weight:600!important;color:#0f172a!important;letter-spacing:.02em}.overview-header-desc{margin-top:6px;font-size:13px;color:#64748b;line-height:1.5}.overview-kpi-row{margin-bottom:4px}.overview-kpi-card.ant-card{height:100%;cursor:pointer;border-radius:8px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 2px #0f172a0a;transition:border-color .2s,box-shadow .2s}.overview-kpi-card.ant-card:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #0f172a0f}.overview-kpi-card .ant-card-body{padding:18px 20px}.overview-kpi-inner{display:flex;align-items:flex-start;gap:14px}.overview-kpi-icon-wrap{flex-shrink:0;width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#1e3a5f;background:linear-gradient(145deg,#e8eef6,#dce6f2);border:1px solid #cfd8e8}.overview-kpi-icon-wrap--tasks{color:#0c4a6e;background:linear-gradient(145deg,#e0f2fe,#bae6fd 55%,#e0f2fe);border-color:#93c5fd}.overview-kpi-text{flex:1;min-width:0}.overview-kpi-label{font-size:12px;font-weight:500;color:#64748b;letter-spacing:.04em;text-transform:none;margin-bottom:4px}.overview-kpi-value{font-size:28px;font-weight:600;color:#0f172a;line-height:1.2;font-variant-numeric:tabular-nums}.overview-kpi-hint{margin-top:6px;font-size:12px;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-section-card.ant-card{border-radius:8px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 2px #0f172a0a}.overview-section-card .ant-card-head{min-height:48px;padding:0 20px;border-bottom:1px solid #eef1f5;font-weight:600;color:#0f172a}.overview-section-card .ant-card-head-title{padding:14px 0;font-size:15px}.overview-section-card .ant-card-body{padding:20px}.overview-section-card .ant-card-extra{padding:12px 0}.overview-status-panel{display:flex;flex-direction:column;gap:8px;padding:14px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;height:100%;min-height:280px}.overview-status-panel-title{font-size:12px;font-weight:600;color:#475569;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}.overview-status-row{display:flex;align-items:center;gap:10px;min-height:36px;padding:8px 12px;border-radius:6px;background:#fff;border:1px solid #e8ecf1;cursor:pointer;transition:border-color .15s,background .15s}.overview-status-row:hover{border-color:#cbd5e1;background:#fafbfc}.overview-status-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.overview-status-name{flex:1;color:#334155;font-size:13px}.overview-status-count{font-weight:600;min-width:28px;text-align:right;color:#0f172a;font-size:13px;font-variant-numeric:tabular-nums}.overview-ip-row{display:flex;flex-wrap:nowrap;gap:12px;width:100%}.overview-ip-col{flex:1 1 0;min-width:0;display:flex}.overview-ip-col .overview-ip-card{flex:1;width:100%}@media(max-width:1100px){.overview-ip-row{flex-wrap:wrap}.overview-ip-col{flex:1 1 calc(50% - 6px);max-width:calc(50% - 6px)}}@media(max-width:520px){.overview-ip-col{flex:1 1 100%;max-width:100%}}.overview-ip-card{padding:16px 14px;border:1px solid #e8ecf1;border-radius:8px;border-left:3px solid #2563eb;background:#fff;cursor:pointer;height:100%;display:flex;flex-direction:column;align-items:center;text-align:center;transition:border-color .2s,box-shadow .2s}.overview-ip-card:hover{border-color:#cbd5e1;box-shadow:0 4px 14px #0f172a12}.overview-ip-title{font-weight:600;font-size:13px;color:#0f172a;margin-bottom:6px;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-ip-meta{font-size:11px;color:#64748b;margin-bottom:12px;width:100%;line-height:1.45;word-break:break-all}.overview-ip-foot{margin-top:10px;color:#64748b;font-size:12px;font-variant-numeric:tabular-nums}.overview-chart-wrap{padding:4px 0}@media(max-width:767px){.overview-page{margin:-8px -12px 0;padding:16px 12px 24px}}
