*{box-sizing:border-box;margin:0;padding:0}html,body{color:#1e293b;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;font-family:Inter,PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::selection{color:#fff;background:#3b82f6}a{color:#3b82f6;text-decoration:none;transition:color .2s}a:hover{color:#2563eb}h1,h2,h3,h4,h5,h6{color:#1e293b;font-weight:600}.ant-card:hover{box-shadow:0 4px 12px #00000014!important}.ant-table-tbody>tr:hover>td{background:#f8fafc!important}.ant-input:focus,.ant-input-focused,.ant-input-affix-wrapper:focus,.ant-input-affix-wrapper-focused{box-shadow:0 0 0 3px #3b82f626!important}.ant-btn:active{transform:scale(.98)}.page-header{margin-bottom:24px}.page-header h2{color:#1e293b;margin-bottom:4px;font-size:20px;font-weight:600}.page-header p{color:#64748b;font-size:14px}.stat-card{background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border:1px solid #e2e8f0;border-radius:12px;padding:20px;transition:all .3s}.stat-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626}.empty-state{text-align:center;color:#94a3b8;padding:60px 20px}.empty-state .anticon{margin-bottom:16px;font-size:48px}.sidebar{z-index:100;min-height:100vh;top:0;bottom:0;left:0;box-shadow:4px 0 20px #00000026;background:linear-gradient(#1e293b 0%,#0f172a 100%)!important;position:fixed!important}.sidebar-logo{border-bottom:1px solid #ffffff1a;align-items:center;margin-bottom:8px;padding:20px 16px;display:flex}.logo-icon{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#60a5fa 100%);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:700;display:flex;box-shadow:0 4px 12px #3b82f666}.logo-text{white-space:nowrap;margin-left:12px;overflow:hidden}.sidebar-menu{padding:0 8px;background:0 0!important;border:none!important}.sidebar-menu .ant-menu-item{color:#94a3b8!important;border-radius:10px!important;height:44px!important;margin:4px 0!important;padding-left:16px!important;line-height:44px!important;transition:all .3s!important}.sidebar-menu .ant-menu-item:hover{color:#fff!important;background:#3b82f626!important}.sidebar-menu .ant-menu-item-selected{box-shadow:0 4px 12px #3b82f666;color:#fff!important;background:linear-gradient(90deg,#3b82f6 0%,#2563eb 100%)!important}.sidebar-menu .ant-menu-item-selected:before{content:"";background:#fff;border-radius:0 4px 4px 0;width:4px;height:24px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-menu .ant-menu-item .anticon,.sidebar-menu .ant-menu-item .ant-menu-item-icon{font-size:18px!important}.ant-layout-sider-collapsed .sidebar-logo{justify-content:center;padding:20px 8px}.ant-layout-sider-collapsed .sidebar-menu .ant-menu-item{justify-content:center;display:flex;padding-left:0!important}.ant-layout-sider-collapsed .sidebar-menu .ant-menu-item-selected:before{display:none}.main-header{z-index:99;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #00000014;background:#fff!important;height:64px!important;padding:0 24px!important;line-height:64px!important}.header-left{align-items:center;gap:16px;display:flex}.page-title{color:#1e293b;font-size:18px;font-weight:600}.collapse-btn{color:#64748b;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:all .3s;display:flex}.collapse-btn:hover{color:#3b82f6;background:#f1f5f9}.header-right{align-items:center;gap:8px;display:flex}.header-btn{color:#64748b;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:all .3s;display:flex}.header-btn:hover{color:#3b82f6;background:#f1f5f9}.user-info{cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:6px 12px;transition:all .3s;display:flex}.user-info:hover{background:#f1f5f9}.user-detail{flex-direction:column;line-height:1.3;display:flex}.user-name{color:#1e293b;font-size:14px;font-weight:600}.user-role{color:#94a3b8;font-size:12px}@media (width<=768px){.user-detail{display:none}.page-title{font-size:16px}}.main-layout{background:#f1f5f9;min-height:100vh}.site-layout{background:#f1f5f9;min-height:100vh;margin-left:240px;transition:margin-left .2s}.ant-layout-sider-collapsed+.site-layout{margin-left:80px}.site-content{min-height:calc(100vh - 112px);margin:24px;padding:0}.content-wrapper{background:#fff;border-radius:12px;min-height:calc(100vh - 160px);padding:24px;box-shadow:0 1px 3px #0000000d}@media (width<=1024px){.site-layout{margin-left:80px}.content-wrapper{border-radius:10px;padding:20px}}@media (width<=768px){.site-layout{margin-left:0}.site-content{margin:16px}.content-wrapper{border-radius:8px;min-height:calc(100vh - 128px);padding:16px}}.login-page{background:linear-gradient(135deg,#1e3a8a 0%,#3b82f6 50%,#60a5fa 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#ffffff1a 0%,#0000 50%);width:200%;height:200%;animation:15s ease-in-out infinite pulse;position:absolute;top:-50%;left:-50%}.login-page:after{content:"";background:radial-gradient(circle,#ffffff14 0%,#0000 50%);width:200%;height:200%;animation:20s ease-in-out infinite reverse pulse;position:absolute;bottom:-50%;right:-50%}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.login-container{z-index:1;width:100%;max-width:400px;padding:20px;position:relative}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-radius:20px;padding:48px 40px;animation:.5s ease-out slideUp;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.logo-icon{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#1e3a8a 100%);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 20px;font-size:28px;display:flex;box-shadow:0 8px 16px #3b82f64d}.login-header h3{color:#1e293b;letter-spacing:-.5px;margin:0 0 8px;font-size:24px;font-weight:700}.login-header .subtitle{color:#64748b;font-size:14px}.login-card .ant-form-item{margin-bottom:20px}.login-card .ant-input-affix-wrapper{border:2px solid #e2e8f0;border-radius:10px;padding:12px 16px;transition:all .3s}.login-card .ant-input-affix-wrapper:hover{border-color:#3b82f6}.login-card .ant-input-affix-wrapper:focus,.login-card .ant-input-affix-wrapper-focused{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.login-card .ant-input{font-size:15px}.login-card .ant-btn-primary{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:10px;height:48px;font-size:16px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #3b82f666}.login-card .ant-btn-primary:hover{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f680}.login-card .ant-btn-primary:active{transform:translateY(0)}@media (width<=480px){.login-card{border-radius:16px;margin:16px;padding:32px 24px}.logo-icon{width:56px;height:56px;font-size:24px}.login-header h3{font-size:20px}}
