*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Helvetica Neue,Microsoft YaHei,sans-serif;background-color:#f5f6fa;color:#1f1f2e;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}.app-layout{min-height:100vh}.app-sider{border-right:1px solid #f0f0f5;box-shadow:0 0 0 transparent;position:sticky;top:0;height:100vh;overflow:auto}.app-sider-logo{display:flex;align-items:center;gap:10px;height:56px;padding:0 20px;font-weight:700;font-size:16px;letter-spacing:.5px;background:linear-gradient(135deg,#fff5f8,#fff);border-bottom:1px solid #f0f0f5}.app-sider-logo .logo-mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#ff6b9d,#e91e63);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 4px 10px #e91e6340}.app-sider-logo .logo-text{display:flex;flex-direction:column;line-height:1.2}.app-sider-logo .logo-text small{font-size:11px;color:#8c8c9a;font-weight:400}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#fff;border-bottom:1px solid #f0f0f5;position:sticky;top:0;z-index:9}.app-header-left,.app-header-right{display:flex;align-items:center;gap:12px}.app-content{padding:16px 24px 24px}.app-content-inner{background:transparent}.page-header{margin-bottom:16px}.page-header h2{margin:0 0 4px;font-size:20px;font-weight:600}.page-header p{margin:0;color:#8c8c9a;font-size:13px}.stat-card{background:#fff;border-radius:12px;padding:20px;position:relative;overflow:hidden;border:1px solid #f0f0f5}.stat-card:after{content:"";position:absolute;width:90px;height:90px;right:-20px;bottom:-20px;border-radius:50%;background:linear-gradient(135deg,#e91e6314,#e91e6300)}.stat-card .stat-label{color:#8c8c9a;font-size:13px;margin-bottom:8px}.stat-card .stat-value{font-size:26px;font-weight:700;color:#1f1f2e}.stat-card .stat-trend{margin-top:10px;font-size:12px;display:flex;align-items:center;gap:4px}.stat-card .stat-trend.up{color:#10b981}.stat-card .stat-trend.down{color:#ef4444}.stat-card .stat-icon{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:10px;background:#e91e6314;color:#e91e63;display:flex;align-items:center;justify-content:center;font-size:18px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 20%,rgba(233,30,99,.18),transparent 40%),radial-gradient(circle at 80% 80%,rgba(255,107,157,.18),transparent 40%),linear-gradient(135deg,#fff5f8,#fff,#f5f6fa);padding:24px}.login-card{width:100%;max-width:400px;background:#fff;border-radius:16px;padding:40px 32px;box-shadow:0 20px 60px #1f1f2e14;border:1px solid #f0f0f5}.login-brand{text-align:center;margin-bottom:28px}.login-brand .logo-mark{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,#ff6b9d,#e91e63);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;margin-bottom:12px;box-shadow:0 8px 20px #e91e634d}.login-brand h1{margin:0 0 4px;font-size:22px;font-weight:700}.login-brand p{margin:0;color:#8c8c9a;font-size:13px}.placeholder-card{min-height:320px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:12px;border:1px dashed #e5e5ec;color:#8c8c9a}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#e5e5ec;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#c8c8d0}
