.main-layout{height:100vh}.main-sider{box-shadow:0 2px 8px #00000014;position:relative;z-index:10;transition:all .3s ease}.logo{height:64px;display:flex;align-items:center;justify-content:center;padding:0 16px;background:linear-gradient(to right,#f0f5ff,#fff);overflow:hidden;box-shadow:0 1px 2px #00000008}.logo-icon{font-size:24px;color:#1677ff;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#e6f7ff,#fff);box-shadow:0 2px 6px #1890ff33;margin-right:12px;transition:all .3s}.logo h1{color:#1677ff;font-size:18px;font-weight:600;margin:0;white-space:nowrap;background:linear-gradient(90deg,#1677ff,#0958d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;transition:all .3s}.main-menu{border-right:none!important;padding:12px 8px}.main-menu .ant-menu-item{border-radius:6px;margin:4px 0;transition:all .3s}.main-menu .ant-menu-item:hover{background-color:#f0f5ff;transform:translate(4px)}.main-menu .ant-menu-item-selected{background:linear-gradient(90deg,#1677ff,#0958d9)!important;box-shadow:0 4px 12px #1890ff4d}.main-menu .ant-menu-item-selected span,.main-menu .ant-menu-item-selected .anticon{color:#fff!important}.sider-footer{position:absolute;bottom:0;width:100%;padding:16px;background:linear-gradient(to top,#f0f5ff,transparent)}.system-time{text-align:center;padding:12px;border-radius:8px;background-color:#fffc;box-shadow:0 2px 8px #0000000d}.system-time .time{font-size:20px;font-weight:600;color:#1677ff}.system-time .date{font-size:12px;color:#666;margin-top:4px}.main-header{padding:0;background:#fff;box-shadow:0 2px 8px #0000000d;position:sticky;top:0;z-index:9;transition:all .3s}.header-content{display:flex;justify-content:space-between;align-items:center;padding:0 16px;height:64px;overflow:visible}.header-left{display:flex;align-items:center;flex:1}.trigger-button{font-size:18px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:8px;margin-right:16px;transition:all .3s}.trigger-button:hover{background-color:#f0f5ff;color:#1677ff}.breadcrumb{font-size:14px}.header-right{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0}.datetime{display:flex;align-items:center;justify-content:center;margin-right:16px;background:linear-gradient(135deg,#f0f7ff,#e6f7ff);padding:6px 16px;border-radius:20px;box-shadow:0 2px 6px #1890ff1a;border:1px solid #e6f7ff}.datetime .time{font-size:16px;font-weight:600;color:#1677ff;display:flex;align-items:center;white-space:nowrap}.action-button{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-right:8px;font-size:16px;transition:all .3s}.action-button:hover{background-color:#f0f5ff;color:#1677ff}.notification-badge{margin-right:8px}.user-dropdown{cursor:pointer;padding:4px 8px;height:48px;display:flex;align-items:center;border-radius:24px;transition:all .3s}.user-dropdown:hover{background-color:#f0f5ff}.user-avatar{background:linear-gradient(135deg,#1677ff,#0958d9)}.username{margin-left:8px;font-size:14px;font-weight:500}.content-wrapper{display:flex;flex-direction:column;height:calc(100vh - 64px)}.main-content{margin:16px;padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000d;overflow:auto;flex:1;transition:all .3s}.main-footer{text-align:center;padding:16px;color:#666;font-size:14px;background:transparent}@media(max-width:768px){.logo h1{font-size:16px}.main-content{margin:12px;padding:16px}.breadcrumb,.username{display:none}.datetime{padding:4px 12px}.datetime .time{font-size:14px}}@media(max-width:576px){.notification-badge{display:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.main-content{animation:fadeIn .5s ease-out}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;position:relative;overflow:hidden}.login-background{position:absolute;inset:0;background:linear-gradient(135deg,#1677ff,#0958d9);z-index:-2}.particle{position:absolute;background-color:#fffc;border-radius:50%;pointer-events:none;animation:float 15s infinite ease-in-out}@keyframes float{0%{transform:translateY(0) translate(0) rotate(0) scale(1)}25%{transform:translateY(-20px) translate(10px) rotate(90deg) scale(1.1)}50%{transform:translateY(-40px) translate(20px) rotate(180deg) scale(1)}75%{transform:translateY(-20px) translate(10px) rotate(270deg) scale(.9)}to{transform:translateY(0) translate(0) rotate(360deg) scale(1)}}.wave{position:absolute;bottom:0;left:0;width:100%;height:100px;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1440 320"><path fill="rgba(255, 255, 255, 0.05)" fill-opacity="1" d="M0,32L48,69.3C96,107,192,181,288,186.7C384,192,480,128,576,117.3C672,107,768,149,864,165.3C960,181,1056,171,1152,144C1248,117,1344,75,1392,53.3L1440,32L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z"></path></svg>') no-repeat;background-size:100% 100px;animation:wave 10s linear infinite}@keyframes wave{0%{background-position-x:0}to{background-position-x:1000px}}.login-content{width:100%;max-width:450px;padding:20px;position:relative;z-index:1}.login-card{border-radius:16px;box-shadow:0 10px 30px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2;overflow:hidden;padding:20px;transition:all .3s ease;animation:fadeIn .8s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card:hover{box-shadow:0 15px 40px #0003;transform:translateY(-5px)}.login-logo{text-align:center;margin-bottom:20px;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.logo-icon{font-size:60px;color:#1677ff;padding:20px;border-radius:50%;background:linear-gradient(145deg,#fff,#f0f0f0);box-shadow:5px 5px 10px #0000001a,-5px -5px 10px #fffc}.login-header{text-align:center;margin-bottom:10px}.login-header h2{color:#1677ff;font-weight:600;margin-bottom:8px;background:linear-gradient(90deg,#1677ff,#0958d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 2s infinite;background-size:200% 100%}@keyframes shimmer{0%{background-position:-100% 0}to{background-position:200% 0}}.login-subtitle{color:#666;margin-top:8px;font-size:16px}.login-divider{margin:15px 0 25px}.divider-text{font-size:14px;color:#8c8c8c;background-color:#fffffff2;padding:0 15px}.login-form{margin-top:15px}.form-icon{color:#1677ff}.login-button{height:48px;font-size:16px;font-weight:500;letter-spacing:2px;border-radius:8px;background:linear-gradient(90deg,#1677ff,#0958d9);border:none;box-shadow:0 5px 15px #1677ff4d;transition:all .3s ease;overflow:hidden;position:relative}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:all .6s ease}.login-button:hover:before{left:100%}.login-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #1677ff66}.remember-me{margin-bottom:15px}.login-footer{text-align:center;margin-top:30px;color:#8c8c8c;font-size:12px}@media(max-width:576px){.login-content{padding:10px}.login-card{padding:15px}.logo-icon{font-size:50px;padding:15px}}.ant-input-affix-wrapper:focus,.ant-input-affix-wrapper-focused{box-shadow:0 0 0 2px #1677ff33}.ant-input-affix-wrapper{border-radius:8px;transition:all .3s ease;overflow:hidden}.ant-input-affix-wrapper:hover{border-color:#1677ff}.ant-form-item{margin-bottom:24px;transition:all .3s ease}.ant-form-item:hover{transform:translate(5px)}.app-loading{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:#f0f2f5}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{background-color:#f0f2f5}
