*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5;color:#333;background:#f5f5f5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{border:none;background:none;font:inherit;color:inherit;cursor:pointer}input,textarea{font:inherit;color:inherit}img{max-width:100%;display:block}.page-container{max-width:640px;margin:0 auto;background:#fff;min-height:100vh}@media (min-width: 768px){.page-container{max-width:768px;border-left:1px solid #e8e8e8;border-right:1px solid #e8e8e8}}::-webkit-scrollbar{width:0;height:0}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000bf;color:#fff;padding:10px 24px;border-radius:8px;font-size:14px;z-index:10000;pointer-events:none;animation:toastFade 2s ease forwards}@keyframes toastFade{0%{opacity:0}10%{opacity:1}80%{opacity:1}to{opacity:0}}.loading-spinner{display:flex;justify-content:center;padding:24px}.spinner{width:28px;height:28px;border:3px solid #e8e8e8;border-top-color:#6751a2;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;padding:60px 20px;color:#999}.empty-state .icon{font-size:48px;margin-bottom:12px}.empty-state .text{font-size:14px}
