.home-container{font-family:PingFang SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;position:relative;overflow-x:hidden;color:#1e1b4b;background:linear-gradient(135deg,#fdf2f8,#ede9fe,#dbeafe,#f0fdf4,#fef3c7);background-size:400% 400%;animation:gradientShift 20s ease infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}25%{background-position:50% 0%}50%{background-position:100% 50%}75%{background-position:50% 100%}}.home-bubble{position:fixed;border-radius:50%;pointer-events:none;opacity:.35;z-index:0}.home-bubble-1{width:280px;height:280px;background:linear-gradient(135deg,#fbcfe8,#f9a8d4);top:-80px;left:-60px;animation:bubbleFloat1 12s ease-in-out infinite}.home-bubble-2{width:200px;height:200px;background:linear-gradient(135deg,#c4b5fd,#a78bfa);top:10%;right:-40px;animation:bubbleFloat2 15s ease-in-out infinite}.home-bubble-3{width:160px;height:160px;background:linear-gradient(135deg,#93c5fd,#60a5fa);bottom:30%;left:5%;animation:bubbleFloat3 13s ease-in-out infinite}.home-bubble-4{width:120px;height:120px;background:linear-gradient(135deg,#86efac,#4ade80);bottom:-30px;right:15%;animation:bubbleFloat1 10s ease-in-out infinite reverse}.home-bubble-5{width:80px;height:80px;background:linear-gradient(135deg,#fde68a,#fbbf24);top:45%;left:12%;animation:bubbleFloat2 9s ease-in-out infinite reverse}.home-bubble-6{width:100px;height:100px;background:linear-gradient(135deg,#fca5a5,#f87171);top:60%;right:8%;animation:bubbleFloat3 11s ease-in-out infinite}.home-bubble-7{width:60px;height:60px;background:linear-gradient(135deg,#a5f3fc,#22d3ee);top:25%;left:40%;animation:bubbleFloat1 14s ease-in-out infinite}@keyframes bubbleFloat1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(25px,-35px) scale(1.06)}66%{transform:translate(-18px,18px) scale(.94)}}@keyframes bubbleFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-30px,25px) scale(1.08)}}@keyframes bubbleFloat3{0%,to{transform:translate(0) scale(1) rotate(0)}50%{transform:translate(25px,-25px) scale(1.06) rotate(5deg)}}.navbar{position:fixed;top:0;left:0;width:100%;padding:14px 32px;display:flex;justify-content:space-between;align-items:center;z-index:100;background:#fff9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.8);box-shadow:0 2px 20px #0000000a}.nav-brand{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:800}.brand-icon{font-size:26px;animation:bounce 2s ease infinite}.brand-text{background:linear-gradient(135deg,#8b5cf6,#a78bfa,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 24px 60px;position:relative}.hero-mascot{position:relative;width:160px;height:160px;display:flex;align-items:center;justify-content:center;margin-bottom:32px}.mascot-glow{position:absolute;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.2) 0%,transparent 70%);animation:glowPulse 3s ease-in-out infinite}@keyframes glowPulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.3);opacity:1}}.mascot-emoji{font-size:80px;position:relative;z-index:2;filter:drop-shadow(0 8px 24px rgba(139,92,246,.2));animation:mascotBounce 3s ease-in-out infinite}@keyframes mascotBounce{0%,to{transform:translateY(0) scale(1) rotate(0)}25%{transform:translateY(-12px) scale(1.05) rotate(-3deg)}75%{transform:translateY(-6px) scale(1.02) rotate(3deg)}}.mascot-sparkle{position:absolute;font-size:20px;z-index:3;animation:sparkleFloat 2.5s ease-in-out infinite}.sparkle-1{top:5px;right:10px;animation-delay:0s}.sparkle-2{bottom:15px;left:5px;animation-delay:.8s}.sparkle-3{top:20px;left:15px;font-size:16px;animation-delay:1.5s}@keyframes sparkleFloat{0%,to{transform:translateY(0) scale(1);opacity:1}50%{transform:translateY(-8px) scale(1.2);opacity:.6}}.hero-content{text-align:center;max-width:600px;position:relative;z-index:1}.hero-badge{display:inline-block;padding:8px 24px;background:#ffffffb3;border:1.5px solid rgba(139,92,246,.2);border-radius:50px;font-size:14px;font-weight:600;color:#7c3aed;margin-bottom:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 12px #8b5cf614}.hero-title{font-size:64px;font-weight:900;margin:0 0 16px;background:linear-gradient(135deg,#7c3aed,#a855f7 40%,#ec4899,#f472b6);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:textShine 4s linear infinite;text-shadow:none}@keyframes textShine{0%{background-position:0% center}to{background-position:200% center}}.hero-subtitle{font-size:18px;color:#6b7280;margin:0 0 36px;font-weight:500}.hero-buttons{display:flex;justify-content:center}.download-btn{display:inline-flex;align-items:center;gap:12px;padding:16px 48px;font-size:18px;font-weight:700;text-decoration:none;border-radius:50px;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#8b5cf6,#a78bfa,#c084fc);color:#fff;box-shadow:0 6px 24px #8b5cf659}.download-btn:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 12px 36px #8b5cf673;color:#fff}.btn-icon{font-size:22px}.btn-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);animation:shine 2.5s infinite}@keyframes shine{0%{left:-100%}50%,to{left:100%}}.hero-notes{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;z-index:0}.float-note{position:absolute;font-size:28px;opacity:.3;animation:noteFloat 6s ease-in-out infinite}.note-1{top:20%;left:10%;animation-delay:0s}.note-2{top:30%;right:12%;animation-delay:1.5s;font-size:32px}.note-3{bottom:25%;left:15%;animation-delay:3s}.note-4{bottom:20%;right:10%;animation-delay:4.5s;font-size:36px}@keyframes noteFloat{0%,to{transform:translateY(0) rotate(0);opacity:.3}50%{transform:translateY(-20px) rotate(15deg);opacity:.5}}.features{padding:80px 24px 100px;position:relative;z-index:1}.section-title{text-align:center;font-size:34px;font-weight:800;margin-bottom:50px;color:#1e1b4b}.title-deco{display:inline-block;animation:sparkle 1.5s ease infinite;margin:0 4px}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;max-width:1000px;margin:0 auto}.feature-card{position:relative;background:#ffffffa6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid rgba(255,255,255,.8);border-radius:24px;padding:36px 28px;text-align:center;transition:all .35s cubic-bezier(.34,1.56,.64,1);overflow:hidden;box-shadow:0 4px 20px #0000000a}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:24px 24px 0 0;opacity:0;transition:opacity .3s ease}.card-pink:before{background:linear-gradient(90deg,#fbcfe8,#f9a8d4)}.card-purple:before{background:linear-gradient(90deg,#c4b5fd,#a78bfa)}.card-blue:before{background:linear-gradient(90deg,#93c5fd,#60a5fa)}.card-green:before{background:linear-gradient(90deg,#86efac,#4ade80)}.feature-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 40px #00000014;background:#ffffffd9}.feature-card:hover:before{opacity:1}.feature-icon{font-size:52px;margin-bottom:16px;animation:iconBounce 3s ease infinite}.feature-card:nth-child(2) .feature-icon{animation-delay:.4s}.feature-card:nth-child(3) .feature-icon{animation-delay:.8s}.feature-card:nth-child(4) .feature-icon{animation-delay:1.2s}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.feature-card h3{font-size:20px;font-weight:700;margin:0 0 10px;color:#1e1b4b}.feature-card p{font-size:14px;color:#6b7280;line-height:1.7;margin:0}.download-section{padding:60px 24px 80px;display:flex;justify-content:center;position:relative;z-index:1}.download-card{position:relative;background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1.5px solid rgba(255,255,255,.8);border-radius:32px;padding:60px 80px;text-align:center;max-width:600px;width:100%;box-shadow:0 8px 40px #0000000d;overflow:hidden}.download-deco-left,.download-deco-right{position:absolute;font-size:48px;opacity:.3;animation:decoSway 4s ease-in-out infinite}.download-deco-left{top:20px;left:24px}.download-deco-right{bottom:20px;right:24px;animation-delay:2s}@keyframes decoSway{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(10deg) scale(1.1)}}.download-card h2{font-size:32px;font-weight:800;margin:0 0 12px;color:#1e1b4b}.download-card p{font-size:16px;color:#6b7280;margin:0 0 32px}.download-btn-large{display:inline-flex;align-items:center;gap:14px;padding:18px 56px;background:linear-gradient(135deg,#8b5cf6,#a78bfa,#c084fc);color:#fff;font-size:20px;font-weight:700;text-decoration:none;border-radius:50px;box-shadow:0 8px 30px #8b5cf659;transition:all .3s cubic-bezier(.34,1.56,.64,1);animation:btnGlow 2.5s ease infinite}.download-btn-large:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 14px 44px #8b5cf673;color:#fff}@keyframes btnGlow{0%,to{box-shadow:0 8px 30px #8b5cf659}50%{box-shadow:0 8px 50px #8b5cf680}}.footer{padding:40px 24px 32px;text-align:center;position:relative;z-index:1}.footer p{font-size:13px;color:#9ca3af;margin:0}@media(max-width:768px){.navbar{padding:12px 20px}.nav-brand{font-size:18px}.hero-title{font-size:42px}.hero-subtitle{font-size:15px}.hero-mascot{width:120px;height:120px}.mascot-emoji{font-size:56px}.download-btn{padding:14px 36px;font-size:16px}.section-title{font-size:26px}.feature-card{padding:28px 22px}.download-card{padding:40px 28px;margin:0 16px}.download-card h2{font-size:24px}.download-btn-large{padding:16px 40px;font-size:17px}.home-bubble-1{width:180px;height:180px}.home-bubble-2{width:130px;height:130px}.home-bubble-3{width:100px;height:100px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#fdf2f8,#ede9fe,#dbeafe 60%,#f0fdf4);background-size:400% 400%;animation:gradientShift 15s ease infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.login-bubble{position:absolute;border-radius:50%;pointer-events:none;opacity:.45}.login-bubble-1{width:220px;height:220px;background:linear-gradient(135deg,#fbcfe8,#f9a8d4);top:-60px;left:-40px;animation:bubbleFloat1 8s ease-in-out infinite}.login-bubble-2{width:160px;height:160px;background:linear-gradient(135deg,#c4b5fd,#a78bfa);top:15%;right:-30px;animation:bubbleFloat2 10s ease-in-out infinite}.login-bubble-3{width:120px;height:120px;background:linear-gradient(135deg,#93c5fd,#60a5fa);bottom:10%;left:8%;animation:bubbleFloat3 12s ease-in-out infinite}.login-bubble-4{width:80px;height:80px;background:linear-gradient(135deg,#86efac,#4ade80);bottom:-20px;right:20%;animation:bubbleFloat1 9s ease-in-out infinite reverse}.login-bubble-5{width:50px;height:50px;background:linear-gradient(135deg,#fde68a,#fbbf24);top:40%;left:15%;animation:bubbleFloat2 7s ease-in-out infinite reverse}@keyframes bubbleFloat1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(20px,-30px) scale(1.05)}66%{transform:translate(-15px,15px) scale(.95)}}@keyframes bubbleFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-25px,20px) scale(1.08)}}@keyframes bubbleFloat3{0%,to{transform:translate(0) scale(1) rotate(0)}50%{transform:translate(20px,-20px) scale(1.06) rotate(5deg)}}.login-card{width:100%;max-width:420px;padding:40px 36px;background:#ffffffb8;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:28px;border:1px solid rgba(255,255,255,.8);box-shadow:0 8px 40px #0000000f,0 2px 8px #0000000a;position:relative;z-index:1;animation:cardPop .5s cubic-bezier(.34,1.56,.64,1)}@keyframes cardPop{0%{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.login-card-header{text-align:center;margin-bottom:32px}.login-avatar{width:72px;height:72px;border-radius:22px;background:linear-gradient(135deg,#e0e7ff,#fce7f3);display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 16px;box-shadow:0 4px 16px #8b5cf61f;animation:avatarBounce 2s ease-in-out infinite}@keyframes avatarBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.login-title{font-size:26px;font-weight:800;color:#1e1b4b;margin:0 0 8px;letter-spacing:1px}.login-subtitle{font-size:14px;color:#6b7280;margin:0;line-height:1.5}.login-form{text-align:left}.login-form .ant-form-item{margin-bottom:20px}.login-form .ant-input-affix-wrapper,.login-form .ant-input{height:48px;background:#ffffffb3!important;border:1.5px solid #e5e7eb!important;border-radius:14px;color:#1f2937!important;font-size:15px;transition:all .25s ease}.login-form .ant-input-affix-wrapper .ant-input,.login-form .ant-input-outlined .ant-input,.login-form .ant-input-affix-wrapper input{background:transparent!important;border:none!important;box-shadow:none!important;color:#1f2937!important;height:auto}.login-form .ant-input-outlined{background:#ffffffb3!important;border-color:#e5e7eb!important}.login-form .ant-input-affix-wrapper:hover,.login-form .ant-input:hover,.login-form .ant-input-outlined:hover{border-color:#a78bfa!important;background:#ffffffd9!important}.login-form .ant-input-affix-wrapper:focus,.login-form .ant-input-affix-wrapper-focused,.login-form .ant-input:focus,.login-form .ant-input-outlined:focus,.login-form .ant-input-affix-wrapper-focused.ant-input-outlined{border-color:#8b5cf6!important;box-shadow:0 0 0 3px #8b5cf61a,0 2px 8px #8b5cf614!important;background:#fff!important}.login-form .ant-input::placeholder,.login-form .ant-input-affix-wrapper input::placeholder{color:#9ca3af!important}.login-form .ant-input-prefix{color:#a78bfa;margin-right:10px;font-size:16px}.login-form .ant-input-password-icon,.login-form .ant-input-suffix .anticon{color:#9ca3af!important}.login-form .ant-input-password-icon:hover,.login-form .ant-input-suffix .anticon:hover{color:#6b7280!important}.login-form input:-webkit-autofill,.login-form input:-webkit-autofill:hover,.login-form input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #fff inset!important;-webkit-text-fill-color:#1f2937!important;caret-color:#1f2937}.login-btn-primary{height:48px;border-radius:14px;font-size:16px;font-weight:700;letter-spacing:3px;background:linear-gradient(135deg,#8b5cf6,#a78bfa,#c084fc)!important;border:none!important;box-shadow:0 4px 16px #8b5cf64d;transition:all .3s cubic-bezier(.34,1.56,.64,1);color:#fff!important}.login-btn-primary:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 8px 28px #8b5cf666!important}.login-btn-primary:active{transform:translateY(-1px) scale(.99)}.login-divider{display:flex;align-items:center;margin:20px 0;gap:14px}.login-divider-line{flex:1;height:1px;background:#e5e7eb}.login-divider-text{font-size:12px;color:#9ca3af;font-weight:500}.login-btn-wechat{height:48px;border-radius:14px;font-size:14px;font-weight:500;background:#fff9!important;border:1.5px solid #e5e7eb!important;color:#374151!important;transition:all .25s ease;display:flex;align-items:center;justify-content:center;gap:8px}.login-btn-wechat:hover{background:#ffffffe6!important;border-color:#07c160!important;color:#07c160!important;transform:translateY(-2px);box-shadow:0 4px 12px #07c1601f}.login-btn-wechat .wechat-icon{color:#07c160;font-size:18px}.login-qrcode-wrap{display:flex;justify-content:center;margin:16px 0 24px;border-radius:16px;overflow:hidden;background:#fff;padding:8px;box-shadow:0 2px 8px #0000000d}.login-qrcode-iframe{width:280px;height:340px;border:none;border-radius:12px;background:#fff}.login-footer{margin-top:28px;text-align:center}.login-footer p{margin:0;font-size:12px;color:#9ca3af}@media(max-width:480px){.login-card{margin:16px;padding:32px 24px;border-radius:24px}.login-avatar{width:60px;height:60px;font-size:30px;border-radius:18px}.login-title{font-size:22px}.login-bubble-1{width:140px;height:140px}.login-bubble-2{width:100px;height:100px}.login-bubble-3{width:80px;height:80px}}.dashboard{padding:0}.main-stats-card{border:1px solid #f2f2f2;border-radius:5px}.stat-panel{background-color:#f8f8f8;border-radius:3px;height:100%}.stat-panel .ant-card-head{padding:8px 12px;min-height:auto;border-bottom:none}.stat-panel .ant-card-head-title{padding:0}.stat-panel .ant-card-body{padding:10px 12px}.stat-panel-header{display:flex;justify-content:space-between;align-items:center}.stat-panel-title{font-size:12px;color:#333;font-weight:500}.stat-panel-badge{display:inline-block;padding:2px 6px;font-size:10px;background-color:#1e9fff;color:#fff;border-radius:3px}.stat-panel-total{font-size:12px;color:#1e9fff;font-weight:500}.stat-panel-content,.stat-item{text-align:center}.stat-label{color:#00000059;font-size:12px;margin-bottom:4px}.stat-value{font-size:14px;color:#333;font-weight:500}.online-panel{padding:10px}.online-header{display:flex;justify-content:space-between;align-items:center}.online-header h5{margin:0;font-size:14px;color:#333}.online-badge{display:inline-block;padding:2px 8px;font-size:10px;background-color:#1e9fff;color:#fff;border-radius:3px}.online-count{margin-top:12px;display:flex;align-items:center}.count-number{font-size:24px;font-weight:500;color:#333}.tips-content{max-height:156px;overflow:hidden;font-size:13px;line-height:1.6;color:#666}.tips-content:hover{overflow-y:auto}@media(max-width:768px){.stat-panel-title{font-size:11px}.stat-value{font-size:12px}.stat-label{font-size:10px}}.admin-layout{min-height:100vh}.admin-sider{box-shadow:2px 0 8px #00000014}.admin-logo{height:64px;display:flex;align-items:center;justify-content:center;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);margin:16px;border-radius:12px;cursor:pointer;transition:all .3s ease}.admin-logo:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.logo-icon{font-size:28px;color:#fff}.logo-text{color:#fff;margin-left:12px;font-size:20px;font-weight:700;letter-spacing:1px}.admin-sider .ant-menu-dark{background:transparent}.admin-sider .ant-menu-item{margin:4px 8px;border-radius:8px;transition:all .3s ease}.admin-sider .ant-menu-item:hover{background:#ffffff1a!important}.admin-sider .ant-menu-item-selected{background:linear-gradient(135deg,#667eea,#764ba2)!important;font-weight:600}.admin-header{background:#fff;padding:0 32px;box-shadow:0 2px 8px #0000000d;z-index:10}.admin-header-content{display:flex;justify-content:space-between;align-items:center;height:100%}.header-title{margin:0;font-size:20px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-user{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px 16px;border-radius:12px;transition:all .3s ease;background:linear-gradient(135deg,#667eea1a,#764ba21a)}.admin-user:hover{background:linear-gradient(135deg,#667eea33,#764ba233);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.user-avatar{background:linear-gradient(135deg,#667eea,#764ba2)}.user-name{font-weight:600;color:#1a202c;font-size:14px}.admin-content{margin:24px;min-height:calc(100vh - 136px)}@media(max-width:768px){.admin-content{margin:16px}.admin-header{padding:0 16px}.header-title{font-size:16px}.user-name{display:none}}
